chamilo/chamilo-lms

View on GitHub
public/main/social/message_for_group_form.inc.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

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

/**
 * Form for group message.
 */
$cidReset = true;
require_once __DIR__.'/../inc/global.inc.php';

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

$tok = Security::get_token();

if (isset($_REQUEST['user_friend'])) {
    $userfriend_id = (int) $_REQUEST['user_friend'];
}

$group_id = isset($_GET['group_id']) ? intval($_GET['group_id']) : null;
$message_id = isset($_GET['message_id']) ? intval($_GET['message_id']) : null;
$actions = ['add_message_group', 'edit_message_group', 'reply_message_group'];
$allowed_action = isset($_GET['action']) && in_array($_GET['action'], $actions) ? Security::remove_XSS($_GET['action']) : '';

$to_group = '';
$subject = '';
$message = '';
$usergroup = new UserGroupModel();
if (!empty($group_id) && $allowed_action) {
    $group_info = $usergroup->get($group_id);
    $is_member = $usergroup->is_group_member($group_id);

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

    $to_group = $group_info['title'];
    if (!empty($message_id)) {
        /*$message_info = MessageManager::get_message_by_id($message_id);
        if ('reply_message_group' === $allowed_action) {
            $subject = get_lang('Reply').': '.api_xml_http_response_encode($message_info['title']);
        } else {
            $subject = api_xml_http_response_encode($message_info['title']);
            $message = api_xml_http_response_encode($message_info['content']);
        }*/
    }
}

$page_item = !empty($_GET['topics_page_nr']) ? intval($_GET['topics_page_nr']) : 1;
$param_item_page = isset($_GET['items_page_nr']) && isset($_GET['topic_id']) ? ('&items_'.intval($_GET['topic_id']).'_page_nr='.(!empty($_GET['topics_page_nr']) ? intval($_GET['topics_page_nr']) : 1)) : '';
if (isset($_GET['topic_id'])) {
    $param_item_page .= '&topic_id='.intval($_GET['topic_id']);
}
$page_topic = isset($_GET['topics_page_nr']) ? intval($_GET['topics_page_nr']) : 1;
$anchor_topic = isset($_GET['anchor_topic']) ? Security::remove_XSS($_GET['anchor_topic']) : null;

$url = api_get_path(WEB_CODE_PATH).'social/group_topics.php?id='.$group_id.'&anchor_topic='.$anchor_topic.'&topics_page_nr='.$page_topic.$param_item_page;

$form = new FormValidator(
    'form',
    'post',
    $url,
    null,
    ['enctype' => 'multipart/form-data']
);
$form->addHidden('action', $allowed_action);
$form->addHidden('group_id', $group_id);
$form->addHidden('parent_id', $message_id);
$form->addHidden('message_id', $message_id);
$form->addHidden('token', $tok);

$tpl = new Template(get_lang('Groups'));

if ('true' === api_get_setting('allow_message_tool')) {
    // Normal message
    $user_info = api_get_user_info($userfriend_id);
    $height = 180;
    if ('add_message_group' === $allowed_action) {
        $form->addElement('text', 'title', get_lang('Title'));
        $height = 140;
    }
    $config = ['ToolbarSet' => 'Messages'];
    $form->addHtmlEditor('content', get_lang('Message'), true, false, $config);

    $form->addElement(
        'label',
        get_lang('Attachments'),
        '<div id="link-more-attach">
            <a class="btn btn--plain" href="javascript://" onclick="return add_image_form()">
                '.get_lang('Add one more file').'
            </a>
        </div>'
    );

    $form->addElement('label', null, '<div id="filepaths"></div>');
    $form->addElement(
        'file',
        'attach_1',
        sprintf(
            get_lang('Maximun file size: %s'),
            format_file_size(api_get_setting('message_max_upload_filesize'))
        )
    );
    $form->addButtonSend(get_lang('Send message'));
    $form->setDefaults(['content' => $message, 'title' => $subject]);
    $tpl->assign('content', $form->returnForm());
}

$tpl->displayBlankTemplateNoHeader();