. /** * Potential social breadth indicator. * * @package core_course * @copyright 2017 David Monllao {@link http://www.davidmonllao.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core_course\analytics\indicator; defined('MOODLE_INTERNAL') || die(); use \core_analytics\local\indicator\community_of_inquiry_activity; /** * Potential social breadth indicator. * * It extends linear instead of discrete as there is a linear relation between * the different social levels activities can reach. * * @package core_course * @copyright 2017 David Monllao {@link http://www.davidmonllao.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class potential_social_breadth extends \core_analytics\local\indicator\linear { /** * get_name * * @return \lang_string */ public static function get_name() : \lang_string { return new \lang_string('indicator:potentialsocial', 'moodle'); } /** * Specify the required data to process this indicator. * * @return string[] */ public static function required_sample_data() { // We require course because, although this indicator can also work with course_modules we can't // calculate anything without the course. return array('course'); } /** * calculate_sample * * @param int $sampleid * @param string $sampleorigin * @param int|false $notusedstarttime * @param int|false $notusedendtime * @return float */ public function calculate_sample($sampleid, $sampleorigin, $notusedstarttime = false, $notusedendtime = false) { if ($sampleorigin === 'course_modules') { $cm = $this->retrieve('course_modules', $sampleid); $cminfo = \cm_info::create($cm); $socialbreadthindicator = $this->get_social_indicator($cminfo->modname); $potentiallevel = $socialbreadthindicator->get_social_breadth_level($cminfo); if ($potentiallevel > community_of_inquiry_activity::MAX_SOCIAL_LEVEL) { $this->level_not_accepted($potentiallevel); } } else { $course = $this->retrieve('course', $sampleid); $modinfo = get_fast_modinfo($course); $cms = $modinfo->get_cms(); if (!$cms) { return self::get_min_value(); } $potentiallevel = 0; foreach ($cms as $cm) { if (!$socialbreadthindicator = $this->get_social_indicator($cm->modname)) { continue; } $level = $socialbreadthindicator->get_social_breadth_level($cm); if ($level > community_of_inquiry_activity::MAX_SOCIAL_LEVEL) { $this->level_not_accepted($level); } if ($level > $potentiallevel) { $potentiallevel = $level; } } } // Core activities social breadth only reaches level 2, until core activities social // breadth do not reach level 5 we limit it to what we currently support, which is level 2. if ($potentiallevel > 2) { $potentiallevel = 2; } // Supporting only social breadth level 1 and 2 the possible values are -1 or 1. $levelscore = round(self::get_max_value() - self::get_min_value(), 2); // We substract $levelscore because we want to start from the lower socre and there is no cognitive depth level 0. return self::get_min_value() + ($levelscore * $potentiallevel) - $levelscore; } /** * Returns the social breadth class of this indicator. * * @param string $modname * @return \core_analytics\local\indicator\base|false */ protected function get_social_indicator($modname) { $indicators = \core_analytics\manager::get_all_indicators(); foreach ($indicators as $indicator) { if ($indicator instanceof community_of_inquiry_activity && $indicator->get_indicator_type() === community_of_inquiry_activity::INDICATOR_SOCIAL && $indicator->get_activity_type() === $modname) { return $indicator; } } return false; } /** * Throw a \coding_exception. * * @param int $level */ protected function level_not_accepted($level) { throw new \coding_exception('Activities\' potential social breadth go from 1 to ' . community_of_inquiry_activity::MAX_SOCIAL_LEVEL . '.'); } }