Proyectos de Subversion Moodle

Rev

Autoría | Ultima modificación | Ver Log |

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * Contacts widget class contains the layout information and generate the data for widget.
 *
 * @package    block_dash
 * @copyright  2022 bdecent gmbh <https://bdecent.de>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace block_dash\local\widget\contacts;

use block_dash\local\widget\abstract_widget;
use context_block;
use moodle_url;

/**
 * Contacts widget contains list of available contacts.
 */
class contacts_widget extends abstract_widget {

    /**
     * Get the name of widget.
     *
     * @return void
     */
    public function get_name() {
        return get_string('widget:mycontacts', 'block_dash');
    }

    /**
     * Check the widget support uses the query method to build the widget.
     *
     * @return bool
     */
    public function supports_query() {
        return false;
    }

    /**
     * Layout class widget will use to render the widget content.
     *
     * @return \abstract_layout
     */
    public function layout() {
        return new contacts_layout($this);
    }

    /**
     * Pre defined preferences that widget uses.
     *
     * @return array
     */
    public function widget_preferences() {
        $preferences = [
            'datasource' => 'contacts',
            'layout' => 'contacts',
        ];
        return $preferences;
    }

    /**
     * Build widget data and send to layout thene the layout will render the widget.
     *
     * @return void
     */
    public function build_widget() {
        global $USER, $DB, $PAGE;
        static $jsincluded = false;
        $userid = $USER->id;
        $contactslist = (method_exists('\core_message\api', 'get_user_contacts'))
            ? \core_message\api::get_user_contacts($userid) : \core_message\api::get_contacts($userid);

        if (defined('\core_message\api::MESSAGE_ACTION_READ')) {
            $unreadcountssql = 'SELECT DISTINCT m.useridfrom, count(m.id) as unreadcount
                                FROM {messages} m
                            INNER JOIN {message_conversations} mc
                                    ON mc.id = m.conversationid
                            INNER JOIN {message_conversation_members} mcm
                                    ON m.conversationid = mcm.conversationid
                            LEFT JOIN {message_user_actions} mua
                                    ON (mua.messageid = m.id AND mua.userid = ? AND
                                    (mua.action = ? OR mua.action = ?))
                                WHERE mcm.userid = ?
                                AND m.useridfrom != ?
                                AND mua.id is NULL
                            GROUP BY m.useridfrom';
            $unreadcounts = $DB->get_records_sql($unreadcountssql,
                [
                    $userid,
                    \core_message\api::MESSAGE_ACTION_READ,
                    \core_message\api::MESSAGE_ACTION_DELETED,
                    $userid,
                    $userid,
                ]
            );
        } else {
            $unreadcountssql = 'SELECT useridfrom, count(*) as count
                                FROM {message}
                                WHERE useridto = ?
                                    AND timeusertodeleted = 0
                                    AND notification = 0
                                GROUP BY useridfrom';
            $unreadcounts = $DB->get_records_sql($unreadcountssql, [$userid]);
        }

        array_walk($contactslist, function($value) use ($unreadcounts, $PAGE) {
            $muserid = (isset($value->id)) ? $value->id : $value->userid; // Totara support.
            $value->contacturl = new \moodle_url('/message/index.php', ['id' => $muserid]);
            $user = \core_user::get_user($muserid);
            $userpicture = new \user_picture($user);
            $userpicture->size = 200; // Size f1.
            $value->profileimageurl = $userpicture->get_url($PAGE)->out(false);
            if ($user->picture == 0) {
                $value->profiletext = ucwords($value->fullname)[0];
            }
            $value->unreadcount = isset($unreadcounts[$user->id]) ?
                (isset($unreadcounts[$user->id]->unreadcount)
                    ? $unreadcounts[$user->id]->unreadcount : $unreadcounts[$user->id]->count) : false;
            $value->profileurl = new \moodle_url('/user/profile.php', ['id' => $muserid]);
            $value->id = $muserid; // Totara support.
        });

        $contextid = $this->get_block_instance()->context->id;
        $this->data = (!empty($contactslist)) ? [
            'contacts' => array_values($contactslist),
            'contextid' => $contextid,

        ] : [];

        $this->include_suggest_contacts();

        if (!$jsincluded) {
            $PAGE->requires->js_call_amd('block_dash/contacts', 'init', ['contextid' => $contextid]);
            $jsincluded = true;
        }

        return $this->data;
    }

    /**
     * Get user picture url for contact.
     *
     * @param stdclass $userid
     * @param string $suggestiontext
     * @return stdclass
     */
    public function get_user_data($userid, $suggestiontext) {
        global $PAGE, $OUTPUT;
        $user = \core_user::get_user($userid);
        $user->fullname = fullname($user);
        $user->suggestinfo[] = $suggestiontext;
        if (isset($user->picture) && $user->picture == 0) {
            $user->profiletext = ucwords($user->fullname)[0];
        }
        $userpicture = new \user_picture($user);
        $userpicture->size = 1; // Size f1.
        $user->profileimageurl = $userpicture->get_url($PAGE)->out(false);
        $user->addcontacticon = $icon = $OUTPUT->pix_icon('t/addcontact', get_string('addtocontacts', 'block_dash'), 'moodle',
        ['class' => 'drag-handle']);
        return $user;
    }

    /**
     * Include suggest contacts.
     *
     * @return array
     */
    public function include_suggest_contacts() {
        global $USER, $DB, $CFG;
        require_once($CFG->dirroot. '/cohort/lib.php');
        $userid = $USER->id;
        // User interests.
        $interests = \core_tag_tag::get_item_tags_array('core', 'user', $userid);
        $intereststatus = get_config('block_dash', 'suggestinterests');

        if (!empty($interests) && $intereststatus) {
            list($insql, $inparams) = $DB->get_in_or_equal($interests, SQL_PARAMS_NAMED, 'tg');

            $sql = "SELECT ti.*, tg.name, tg.rawname FROM {tag_instance} ti
            JOIN {tag} tg ON tg.id = ti.tagid
            WHERE ti.itemid <> :userid AND ti.itemtype = :itemtype AND ti.tagid IN ( SELECT id FROM {tag} t WHERE t.name $insql )";
            $lists = $DB->get_records_sql($sql, $inparams + ['userid' => $userid, 'itemtype' => 'user']);
        }

        $suggestions = [];
        if (isset($lists) && !empty($lists)) {

            $i = 0;
            foreach ($lists as $list) {
                $suggestiontext = get_string('suggestion:interest', 'block_dash', ['interest' => $list->name]);
                if (in_array($list->itemid, array_keys($suggestions))) {
                    $suggestions[$list->itemid]->suggestinfo[] = $suggestiontext;
                } else {
                    if ($intereststatus <= $i) {
                        continue;
                    }
                    $i++;
                    $user = $this->get_user_data($list->itemid, $suggestiontext);
                    $suggestions[$user->id]  = $user;
                }
            }
        }

        // Cohort suggestions.
        $sql = 'SELECT c.*
        FROM {cohort} c
        JOIN {cohort_members} cm ON c.id = cm.cohortid
        WHERE cm.userid = ? AND c.visible = 1';
        $usercohorts = $DB->get_records_sql($sql, [$userid]);
        $cohorts = array_column($usercohorts, 'id');
        $cohortstatus = get_config('block_dash', 'suggestcohort');
        if (!empty($cohorts) && $cohortstatus) {
            list($insql, $inparams) = $DB->get_in_or_equal($cohorts, SQL_PARAMS_NAMED, 'ch');
            $sql = "SELECT cm.*, ch.name FROM {cohort_members} cm
                    JOIN {cohort} ch ON ch.id = cm.cohortid
                    WHERE cm.userid <> :userid AND cm.cohortid $insql";
            $members = $DB->get_records_sql($sql, $inparams + ['userid' => $userid]);
        }
        if (isset($members) && !empty($members)) {
            $i = 0;
            foreach ($members as $member) {
                $suggestiontext = get_string('suggestion:cohort', 'block_dash',
                    ['cohort' => $member->name]);
                if (in_array($member->userid, array_keys($suggestions))) {
                    $suggestions[$member->userid]->suggestinfo[] = $suggestiontext;
                } else {
                    if ($cohortstatus <= $i) {
                        continue;
                    }
                    $i++;
                    $user = $this->get_user_data($member->userid, $suggestiontext);
                    $suggestions[$user->id]  = $user;
                }
            }
        }

        // Groups suggestion.
        $sql = 'SELECT *, gm.id FROM {groups_members} gm
        JOIN {groups} g ON g.id = gm.groupid
        JOIN {user} u ON u.id = gm.userid
        WHERE gm.userid != :userid AND g.id IN (
            SELECT groupid FROM {groups_members} WHERE userid = :currentuserid
        )';
        $groups = $DB->get_records_sql($sql, ['userid' => $userid, 'currentuserid' => $userid]);
        $groupstatus = get_config('block_dash', 'suggestgroups');
        $i = 0;
        if (!empty($groups) && $groupstatus) {
            foreach ($groups as $group) {
                $suggestiontext = get_string('suggestion:groups', 'block_dash', ['group' => $group->name]);
                if (in_array($group->userid, array_keys($suggestions))) {
                    $suggestions[$group->userid]->suggestinfo[] = $suggestiontext;
                } else {
                    if ($groupstatus <= $i) {
                        continue;
                    }
                    $i++;
                    $user = $this->get_user_data($group->userid, $suggestiontext);
                    $suggestions[$user->id]  = $user;
                }
            }
        }

        $suggestusers = get_config('block_dash', 'suggestusers');
        $users = explode(',', $suggestusers);
        $suggestiontext = get_string('suggestion:users', 'block_dash');
        $users = array_filter($users, function($value) {
            return !is_null($value) && $value !== '';
        });
        if (!empty($users)) {
            foreach ($users as $suggestuser) {
                if (in_array($suggestuser, array_keys($suggestions))) {
                    $suggestions[$suggestuser]->suggestinfo[] = $suggestiontext;
                } else {
                    $user = $this->get_user_data($suggestuser, $suggestiontext);
                    $suggestions[$user->id]  = $user;
                }
            }
        }

        $contactslist = (method_exists('\core_message\api', 'get_user_contacts')) ?
            \core_message\api::get_user_contacts($userid) :
            array_flip(array_column(\core_message\api::get_contacts($userid), 'userid'));

        $contactusers = array_keys($contactslist);
        $suggestions = array_filter($suggestions, function($value) use ($contactusers) {
            if (!in_array($value->id, $contactusers)) {
                return $value;
            }
        });
        $this->data['suggestions'] = array_values($suggestions);
        $this->data['currentuser'] = $userid;
    }

    /**
     * Requires the JS libraries for the toggle contact button.
     *
     * @return void
     */
    public static function togglecontact_requirejs() {
        global $PAGE;

        static $done = false;
        if ($done) {
            return;
        }

        $PAGE->requires->js_call_amd('core_message/toggle_contact_button', 'enhance', ['.toggle-contact-button']);
        $done = true;
    }

    /**
     * Load groups that the contact user and the loggedin user in same group.
     *
     * @param context_block $context
     * @param stdclass $args
     * @return string $table html
     */
    public function load_groups($context, $args) {
        global $CFG;
        require_once($CFG->dirroot.'/lib/grouplib.php');
        $contactuserid = (int) $args->contactuser;

        if (block_dash_is_totara()) {
            $table = new \block_dash\table\groups_totara($context->instanceid);
            $table->set_filterset($contactuserid);
        } else {
            $filterset = new \block_dash\table\groups_filterset('dash-groups-'.$context->id);
            $contactuser = new \core_table\local\filter\integer_filter('contactuser');
            $contactuser->add_filter_value($contactuserid);
            $filterset->add_filter($contactuser);

            $table = new \block_dash\table\groups($context->instanceid);
            $table->set_filterset($filterset);
        }

        ob_start();
        echo \html_writer::start_div('dash-widget-table');
        $table->out(10, true);
        echo \html_writer::end_div();
        $tablehtml = ob_get_contents();
        ob_end_clean();

        return $tablehtml;
    }
}