/** * Group created * * @param \core\event\group_created $event * @return void */ public static function group_created(\core\event\group_created $event) { global $DB; $group = $event->get_record_snapshot('groups', $event->objectid); $courseids = local_metagroups_parent_courses($group->courseid); foreach ($courseids as $courseid) { $course = get_course($courseid); // If parent course doesn't use groups, we can skip synchronization. if (groups_get_course_groupmode($course) == NOGROUPS) { continue; } if (!$DB->record_exists('groups', array('courseid' => $course->id, 'idnumber' => $group->id))) { $metagroup = new \stdClass(); $metagroup->courseid = $course->id; $metagroup->idnumber = $group->id; $metagroup->name = $group->name; groups_create_group($metagroup, false, false); } } }
/** * group_created * * @param \core\event\group_created $event Event object containing useful data * @return bool true if success */ public static function group_created(\core\event\group_created $event) { global $DB; $data = $event->get_record_snapshot('groups', $event->objectid); $course = $DB->get_record('course', array('id' => $data->courseid)); if (!($grouptools = get_all_instances_in_course('grouptool', $course))) { return true; } $sortorder = $DB->get_records_sql("SELECT agrp.grouptoolid, MAX(agrp.sort_order) AS max\n FROM {grouptool_agrps} agrp\n GROUP BY agrp.grouptoolid"); foreach ($grouptools as $grouptool) { $newagrp = new StdClass(); $newagrp->grouptoolid = $grouptool->id; $newagrp->groupid = $data->id; if (!array_key_exists($grouptool->id, $sortorder)) { $newagrp->sort_order = 1; } else { $newagrp->sort_order = $sortorder[$grouptool->id]->max + 1; } $newagrp->active = 0; if (!$DB->record_exists('grouptool_agrps', array('grouptoolid' => $grouptool->id, 'groupid' => $data->id))) { $newagrp->id = $DB->insert_record('grouptool_agrps', $newagrp); // Trigger event! $cm = get_coursemodule_from_instance('grouptool', $grouptool->id); \mod_grouptool\event\agrp_created::create_from_object($cm, $newagrp)->trigger(); } } return true; }