mirror of
https://github.com/moodle/moodle.git
synced 2025-08-08 10:26:40 +02:00

- Templates: 'Learning plan templates' - Plans: 'Learning plans' - Frameworks: 'Competency frameworks' When the context, or sentence, is already stating that we are talking about 'learning plans' or 'competencies', it may sound redundant to repeat those terms, therefore we can simply refer to 'Templates', 'Plans', and 'Frameworks'.
150 lines
4.6 KiB
PHP
150 lines
4.6 KiB
PHP
<?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/>.
|
|
|
|
/**
|
|
* User competency grade rated in course event.
|
|
*
|
|
* @package core_competency
|
|
* @copyright 2016 Issam Taboubi <issam.taboubi@umontreal.ca>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
namespace core\event;
|
|
|
|
use core\event\base;
|
|
use core_competency\user_competency;
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
/**
|
|
* User competency grade rated in plan event class.
|
|
*
|
|
* @property-read array $other {
|
|
* Extra information about event.
|
|
*
|
|
* - int competencyid: id of competency.
|
|
* - int grade: grade name of the user competency
|
|
* - int planid: the plan id
|
|
* }
|
|
*
|
|
* @package core_competency
|
|
* @since Moodle 3.1
|
|
* @copyright 2016 Issam Taboubi <issam.taboubi@umontreal.ca>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
class competency_user_competency_rated_in_plan extends base {
|
|
|
|
/**
|
|
* Convenience method to instantiate the event.
|
|
*
|
|
* @param user_competency $usercompetency The user competency.
|
|
* @param int $planid The plan ID
|
|
* @return self
|
|
*/
|
|
public static function create_from_user_competency(user_competency $usercompetency, $planid) {
|
|
if (!$usercompetency->get_id()) {
|
|
throw new \coding_exception('The user competency ID must be set.');
|
|
}
|
|
|
|
$params = array(
|
|
'contextid' => $usercompetency->get_context()->id,
|
|
'objectid' => $usercompetency->get_id(),
|
|
'relateduserid' => $usercompetency->get_userid(),
|
|
'other' => array(
|
|
'competencyid' => $usercompetency->get_competencyid(),
|
|
'grade' => $usercompetency->get_grade(),
|
|
'planid' => $planid
|
|
)
|
|
);
|
|
|
|
$event = static::create($params);
|
|
$event->add_record_snapshot(user_competency::TABLE, $usercompetency->to_record());
|
|
return $event;
|
|
}
|
|
|
|
/**
|
|
* Returns description of what happened.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_description() {
|
|
return "The user with id '$this->userid' rated the user competency with id '$this->objectid' with "
|
|
. "'" . $this->other['grade'] . "' rating "
|
|
. "in plan with id '" . $this->other['grade'] . "'";
|
|
}
|
|
|
|
/**
|
|
* Return localised event name.
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function get_name() {
|
|
return get_string('eventusercompetencyratedinplan', 'core_competency');
|
|
}
|
|
|
|
/**
|
|
* Get URL related to the action
|
|
*
|
|
* @return \moodle_url
|
|
*/
|
|
public function get_url() {
|
|
return \core_competency\url::user_competency_in_plan($this->relateduserid, $this->other['competencyid'],
|
|
$this->other['planid']);
|
|
}
|
|
|
|
/**
|
|
* Init method.
|
|
*
|
|
* @return void
|
|
*/
|
|
protected function init() {
|
|
$this->data['crud'] = 'u';
|
|
$this->data['edulevel'] = self::LEVEL_TEACHING;
|
|
$this->data['objecttable'] = user_competency::TABLE;
|
|
}
|
|
|
|
/**
|
|
* Get_objectid_mapping method.
|
|
*
|
|
* @return string the name of the restore mapping the objectid links to
|
|
*/
|
|
public static function get_objectid_mapping() {
|
|
return base::NOT_MAPPED;
|
|
}
|
|
|
|
/**
|
|
* Custom validation.
|
|
*
|
|
* Throw \coding_exception notice in case of any problems.
|
|
*/
|
|
protected function validate_data() {
|
|
if (!isset($this->other) || !isset($this->other['competencyid'])) {
|
|
throw new \coding_exception('The \'competencyid\' value must be set.');
|
|
}
|
|
|
|
if (!isset($this->other['planid'])) {
|
|
throw new \coding_exception('The \'planid\' value must be set.');
|
|
}
|
|
|
|
if (!$this->relateduserid) {
|
|
throw new \coding_exception('The \'relateduserid\' value must be set.');
|
|
}
|
|
|
|
if (!isset($this->other['grade'])) {
|
|
throw new \coding_exception('The \'grade\' value must be set.');
|
|
}
|
|
}
|
|
|
|
}
|