chamilo/chamilo-lms

View on GitHub
public/main/social/group_topics.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

/* For licensing terms, see /license.txt */

/**
 * @author Julio Montoya <gugli100@gmail.com>
 */
$cidReset = true;

require_once __DIR__.'/../inc/global.inc.php';

api_block_anonymous_users();
if ('true' != api_get_setting('allow_social_tool')) {
    api_not_allowed(true);
}

$group_id = intval($_GET['id']);
$topic_id = isset($_GET['topic_id']) ? intval($_GET['topic_id']) : null;
$message_id = isset($_GET['msg_id']) ? intval($_GET['msg_id']) : null;

$usergroup = new UserGroupModel();
$is_member = false;

//todo @this validation could be in a function in group_portal_manager
if (empty($group_id)) {
    api_not_allowed(true);
} else {
    $group_info = $usergroup->get($group_id);

    if (empty($group_info)) {
        api_not_allowed(true);
    }
    $is_member = $usergroup->is_group_member($group_id);

    if (GROUP_PERMISSION_CLOSED == $group_info['visibility'] && !$is_member) {
        api_not_allowed(true);
    }
}

if (isset($_REQUEST['action']) && 'delete' == $_REQUEST['action']) {
    $group_role = $usergroup->get_user_group_role(api_get_user_id(), $group_id);

    if (api_is_platform_admin() ||
        in_array($group_role, [GROUP_USER_PERMISSION_ADMIN, GROUP_USER_PERMISSION_MODERATOR])
    ) {
        $usergroup->delete_topic($group_id, $topic_id);
        Display::addFlash(Display::return_message(get_lang('Deleted')));
        header("Location: group_view.php?id=$group_id");
        exit;
    }
}

// My friends
$friend_html = SocialManager::listMyFriendsBlock(api_get_user_id());
$content = null;
$social_right_content = '';

if (isset($_POST['action'])) {
    $title = isset($_POST['title']) ? $_POST['title'] : null;
    $content = $_POST['content'];
    $group_id = intval($_POST['group_id']);
    $parent_id = intval($_POST['parent_id']);

    if ('reply_message_group' === $_POST['action']) {
        $title = cut($content, 50);
    }

    if ('edit_message_group' === $_POST['action']) {
        $edit_message_id = intval($_POST['message_id']);
        $res = MessageManager::send_message(
            api_get_user_id(),
            $title,
            $content,
            $_FILES,
            [],
            $group_id,
            $parent_id,
            $edit_message_id,
            $topic_id
        );
    } else {
        if ('add_message_group' === $_POST['action'] && !$is_member) {
            api_not_allowed(true);
        }
        $res = MessageManager::send_message(
            api_get_user_id(),
            $title,
            $content,
            $_FILES,
            [],
            $group_id,
            $parent_id,
            0,
            $topic_id
        );
    }

    // display error messages
    if (!$res) {
        Display::addFlash(Display::return_message(get_lang('Error'), 'error'));
    }

    header('Location: ' . api_get_path(WEB_PATH).'resources/usergroups/show/'.$group_id);
    exit;
    $topic_id = isset($_GET['topic_id']) ? intval($_GET['topic_id']) : null;
    if ('add_message_group' === $_POST['action']) {
        $topic_id = $res;
    }
    $message_id = $res;
}

$htmlHeadXtra[] = '<script>

var counter_image = 1;
function remove_image_form(id_elem1) {
    var elem1 = document.getElementById(id_elem1);
    elem1.parentNode.removeChild(elem1);
    counter_image--;
    var filepaths = document.getElementById("filepaths");
    if (filepaths.childNodes.length < 3) {
        var link_attach = document.getElementById("link-more-attach");
        if (link_attach) {
            link_attach.innerHTML=\'<a href="javascript://" onclick="return add_image_form()">'.get_lang('Add one more file').'</a>\';
        }
    }
}

function add_image_form() {
    // Multiple filepaths for image form
    var filepaths = document.getElementById("filepaths");
    if (document.getElementById("filepath_"+counter_image)) {
        counter_image = counter_image + 1;
    }  else {
        counter_image = counter_image;
    }
    var elem1 = document.createElement("div");
    elem1.setAttribute("id","filepath_"+counter_image);
    filepaths.appendChild(elem1);
    id_elem1 = "filepath_"+counter_image;
    id_elem1 = "\'"+id_elem1+"\'";
    document.getElementById("filepath_"+counter_image).innerHTML = "<input type=\"file\" name=\"attach_"+counter_image+"\"  size=\"20\" />&nbsp;<a href=\"javascript:remove_image_form("+id_elem1+")\"><img src=\"'.Display::returnIconPath('delete.png').'\"></a>";

    if (filepaths.childNodes.length == 3) {
        var link_attach = document.getElementById("link-more-attach");
        if (link_attach) {
            link_attach.innerHTML="";
        }
    }
}

$(function() {
    if ($("#msg_'.$message_id.'").length) {
        $("html,body").animate({
            scrollTop: $("#msg_'.$message_id.'").offset().top
        })
    }

    $(\'.group_message_popup\').on(\'click\', function() {
        var url     = this.href;
        var dialog  = $("#dialog");
        if ($("#dialog").length == 0) {
            dialog  = $(\'<div id="dialog" style="display:hidden"></div>\').appendTo(\'body\');
        }

        // load remote content
        dialog.load(
            url,
            {},
                function(responseText, textStatus, XMLHttpRequest) {
                    dialog.dialog({
                        modal    : true,
                        width    : 520,
                        height    : 400,
                    });
                });
                //prevent the browser to follow the link
                return false;
            });
        });
</script>';

$this_section = SECTION_SOCIAL;
$interbreadcrumb[] = ['url' => 'groups.php', 'name' => get_lang('Groups')];
$interbreadcrumb[] = ['url' => 'group_view.php?id='.$group_id, 'name' => Security::remove_XSS($group_info['title'])];
$interbreadcrumb[] = ['url' => '#', 'name' => get_lang('Discussions')];

$social_left_content = null; //SocialManager::show_social_menu('member_list', $group_id);

$group_message = MessageManager::display_message_for_group(
    $group_id,
    $topic_id,
    $is_member,
    $message_id
);

//$social_menu_block = SocialManager::show_social_menu('member_list', $group_id);

$tpl = new Template(null);
$tpl->setHelp('Groups');
// Block Social Avatar
SocialManager::setSocialUserBlock($tpl, api_get_user_id(), 'groups', $group_id);
$tpl->assign('social_menu_block', '');
$tpl->assign('social_friend_block', $friend_html);
$tpl->assign('group_message', $group_message);
$tpl->assign('social_right_content', $social_right_content);
$social_layout = $tpl->get_template('social/groups_topics.tpl');
$tpl->display($social_layout);