index.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  1. <?php
  2. // This file is part of Moodle - http://moodle.org/
  3. //
  4. // Moodle is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // Moodle is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU General Public License
  15. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
  16. /**
  17. * The main group management user interface.
  18. *
  19. * @copyright 2006 The Open University, N.D.Freear AT open.ac.uk, J.White AT open.ac.uk
  20. * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  21. * @package core_group
  22. */
  23. require_once('../config.php');
  24. require_once('lib.php');
  25. $courseid = required_param('id', PARAM_INT);
  26. $groupid = optional_param('group', false, PARAM_INT);
  27. $userid = optional_param('user', false, PARAM_INT);
  28. $action = groups_param_action();
  29. // Support either single group= parameter, or array groups[]
  30. if ($groupid) {
  31. $groupids = array($groupid);
  32. } else {
  33. $groupids = optional_param_array('groups', array(), PARAM_INT);
  34. }
  35. $singlegroup = (count($groupids) == 1);
  36. $returnurl = $CFG->wwwroot.'/group/index.php?id='.$courseid;
  37. // Get the course information so we can print the header and
  38. // check the course id is valid
  39. $course = $DB->get_record('course', array('id'=>$courseid), '*', MUST_EXIST);
  40. $url = new moodle_url('/group/index.php', array('id'=>$courseid));
  41. if ($userid) {
  42. $url->param('user', $userid);
  43. }
  44. if ($groupid) {
  45. $url->param('group', $groupid);
  46. }
  47. $PAGE->set_url($url);
  48. // Make sure that the user has permissions to manage groups.
  49. require_login($course);
  50. $context = context_course::instance($course->id);
  51. require_capability('moodle/course:managegroups', $context);
  52. $PAGE->requires->js('/group/clientlib.js');
  53. // Check for multiple/no group errors
  54. if (!$singlegroup) {
  55. switch($action) {
  56. case 'ajax_getmembersingroup':
  57. case 'showgroupsettingsform':
  58. case 'showaddmembersform':
  59. case 'updatemembers':
  60. print_error('errorselectone', 'group', $returnurl);
  61. }
  62. }
  63. switch ($action) {
  64. case false: //OK, display form.
  65. break;
  66. case 'ajax_getmembersingroup':
  67. $roles = array();
  68. if ($groupmemberroles = groups_get_members_by_role($groupids[0], $courseid, 'u.id, ' . get_all_user_name_fields(true, 'u'))) {
  69. foreach($groupmemberroles as $roleid=>$roledata) {
  70. $shortroledata = new stdClass();
  71. $shortroledata->name = $roledata->name;
  72. $shortroledata->users = array();
  73. foreach($roledata->users as $member) {
  74. $shortmember = new stdClass();
  75. $shortmember->id = $member->id;
  76. $shortmember->name = fullname($member, true);
  77. $shortroledata->users[] = $shortmember;
  78. }
  79. $roles[] = $shortroledata;
  80. }
  81. }
  82. echo json_encode($roles);
  83. die; // Client side JavaScript takes it from here.
  84. case 'deletegroup':
  85. if (count($groupids) == 0) {
  86. print_error('errorselectsome','group',$returnurl);
  87. }
  88. $groupidlist = implode(',', $groupids);
  89. redirect(new moodle_url('/group/delete.php', array('courseid'=>$courseid, 'groups'=>$groupidlist)));
  90. break;
  91. case 'showcreateorphangroupform':
  92. redirect(new moodle_url('/group/group.php', array('courseid'=>$courseid)));
  93. break;
  94. case 'showautocreategroupsform':
  95. redirect(new moodle_url('/group/autogroup.php', array('courseid'=>$courseid)));
  96. break;
  97. case 'showimportgroups':
  98. redirect(new moodle_url('/group/import.php', array('id'=>$courseid)));
  99. break;
  100. case 'showgroupsettingsform':
  101. redirect(new moodle_url('/group/group.php', array('courseid'=>$courseid, 'id'=>$groupids[0])));
  102. break;
  103. case 'updategroups': //Currently reloading.
  104. break;
  105. case 'removemembers':
  106. break;
  107. case 'showaddmembersform':
  108. redirect(new moodle_url('/group/members.php', array('group'=>$groupids[0])));
  109. break;
  110. case 'updatemembers': //Currently reloading.
  111. break;
  112. default: //ERROR.
  113. print_error('unknowaction', '', $returnurl);
  114. break;
  115. }
  116. // Print the page and form
  117. $strgroups = get_string('groups');
  118. $strparticipants = get_string('participants');
  119. /// Print header
  120. $PAGE->set_title($strgroups);
  121. $PAGE->set_heading($course->fullname);
  122. $PAGE->set_pagelayout('standard');
  123. echo $OUTPUT->header();
  124. // Add tabs
  125. $currenttab = 'groups';
  126. require('tabs.php');
  127. $disabled = 'disabled="disabled"';
  128. // Some buttons are enabled if single group selected.
  129. $showaddmembersform_disabled = $singlegroup ? '' : $disabled;
  130. $showeditgroupsettingsform_disabled = $singlegroup ? '' : $disabled;
  131. $deletegroup_disabled = count($groupids) > 0 ? '' : $disabled;
  132. echo $OUTPUT->heading(format_string($course->shortname, true, array('context' => $context)) .' '.$strgroups, 3);
  133. echo '<form id="groupeditform" action="index.php" method="post">'."\n";
  134. echo '<div>'."\n";
  135. echo '<input type="hidden" name="id" value="' . $courseid . '" />'."\n";
  136. echo html_writer::start_tag('div', array('class' => 'groupmanagementtable boxaligncenter'));
  137. echo html_writer::start_tag('div', array('class' => 'groups'));
  138. echo '<p><label for="groups"><span id="groupslabel">'.get_string('groups').':</span><span id="thegrouping">&nbsp;</span></label></p>'."\n";
  139. $onchange = 'M.core_group.membersCombo.refreshMembers();';
  140. echo '<select name="groups[]" multiple="multiple" id="groups" size="15" class="select" onchange="'.$onchange.'">'."\n";
  141. $groups = groups_get_all_groups($courseid);
  142. $selectedname = '&nbsp;';
  143. $preventgroupremoval = array();
  144. if ($groups) {
  145. // Print out the HTML
  146. foreach ($groups as $group) {
  147. $select = '';
  148. $usercount = $DB->count_records('groups_members', array('groupid'=>$group->id));
  149. $groupname = format_string($group->name).' ('.$usercount.')';
  150. if (in_array($group->id,$groupids)) {
  151. $select = ' selected="selected"';
  152. if ($singlegroup) {
  153. // Only keep selected name if there is one group selected
  154. $selectedname = $groupname;
  155. }
  156. }
  157. if (!empty($group->idnumber) && !has_capability('moodle/course:changeidnumber', $context)) {
  158. $preventgroupremoval[$group->id] = true;
  159. }
  160. echo "<option value=\"{$group->id}\"$select title=\"$groupname\">$groupname</option>\n";
  161. }
  162. } else {
  163. // Print an empty option to avoid the XHTML error of having an empty select element
  164. echo '<option>&nbsp;</option>';
  165. }
  166. echo '</select>'."\n";
  167. echo '<p><input type="submit" name="act_updatemembers" id="updatemembers" value="'
  168. . get_string('showmembersforgroup', 'group') . '" /></p>'."\n";
  169. echo '<p><input type="submit" '. $showeditgroupsettingsform_disabled . ' name="act_showgroupsettingsform" id="showeditgroupsettingsform" value="'
  170. . get_string('editgroupsettings', 'group') . '" /></p>'."\n";
  171. echo '<p><input type="submit" '. $deletegroup_disabled . ' name="act_deletegroup" id="deletegroup" value="'
  172. . get_string('deleteselectedgroup', 'group') . '" /></p>'."\n";
  173. echo '<p><input type="submit" name="act_showcreateorphangroupform" id="showcreateorphangroupform" value="'
  174. . get_string('creategroup', 'group') . '" /></p>'."\n";
  175. echo '<p><input type="submit" name="act_showautocreategroupsform" id="showautocreategroupsform" value="'
  176. . get_string('autocreategroups', 'group') . '" /></p>'."\n";
  177. echo '<p><input type="submit" name="act_showimportgroups" id="showimportgroups" value="'
  178. . get_string('importgroups', 'core_group') . '" /></p>'."\n";
  179. echo html_writer::end_tag('div');
  180. echo html_writer::start_tag('div', array('class' => 'members'));
  181. echo '<p><label for="members"><span id="memberslabel">'.
  182. get_string('membersofselectedgroup', 'group').
  183. ' </span><span id="thegroup">'.$selectedname.'</span></label></p>'."\n";
  184. //NOTE: the SELECT was, multiple="multiple" name="user[]" - not used and breaks onclick.
  185. echo '<select name="user" id="members" size="15" class="select"'."\n";
  186. echo ' onclick="window.status=this.options[this.selectedIndex].title;" onmouseout="window.status=\'\';">'."\n";
  187. $member_names = array();
  188. $atleastonemember = false;
  189. if ($singlegroup) {
  190. if ($groupmemberroles = groups_get_members_by_role($groupids[0], $courseid, 'u.id, ' . get_all_user_name_fields(true, 'u'))) {
  191. foreach($groupmemberroles as $roleid=>$roledata) {
  192. echo '<optgroup label="'.s($roledata->name).'">';
  193. foreach($roledata->users as $member) {
  194. echo '<option value="'.$member->id.'">'.fullname($member, true).'</option>';
  195. $atleastonemember = true;
  196. }
  197. echo '</optgroup>';
  198. }
  199. }
  200. }
  201. if (!$atleastonemember) {
  202. // Print an empty option to avoid the XHTML error of having an empty select element
  203. echo '<option>&nbsp;</option>';
  204. }
  205. echo '</select>'."\n";
  206. echo '<p><input type="submit" ' . $showaddmembersform_disabled . ' name="act_showaddmembersform" '
  207. . 'id="showaddmembersform" value="' . get_string('adduserstogroup', 'group'). '" /></p>'."\n";
  208. echo html_writer::end_tag('div');
  209. echo html_writer::end_tag('div');
  210. //<input type="hidden" name="rand" value="om" />
  211. echo '</div>'."\n";
  212. echo '</form>'."\n";
  213. $PAGE->requires->js_init_call('M.core_group.init_index', array($CFG->wwwroot, $courseid));
  214. $PAGE->requires->js_init_call('M.core_group.groupslist', array($preventgroupremoval));
  215. echo $OUTPUT->footer();
  216. /**
  217. * Returns the first button action with the given prefix, taken from
  218. * POST or GET, otherwise returns false.
  219. * @see /lib/moodlelib.php function optional_param().
  220. * @param string $prefix 'act_' as in 'action'.
  221. * @return string The action without the prefix, or false if no action found.
  222. */
  223. function groups_param_action($prefix = 'act_') {
  224. $action = false;
  225. //($_SERVER['QUERY_STRING'] && preg_match("/$prefix(.+?)=(.+)/", $_SERVER['QUERY_STRING'], $matches)) { //b_(.*?)[&;]{0,1}/
  226. if ($_POST) {
  227. $form_vars = $_POST;
  228. }
  229. elseif ($_GET) {
  230. $form_vars = $_GET;
  231. }
  232. if ($form_vars) {
  233. foreach ($form_vars as $key => $value) {
  234. if (preg_match("/$prefix(.+)/", $key, $matches)) {
  235. $action = $matches[1];
  236. break;
  237. }
  238. }
  239. }
  240. if ($action && !preg_match('/^\w+$/', $action)) {
  241. $action = false;
  242. print_error('unknowaction');
  243. }
  244. ///if (debugging()) echo 'Debug: '.$action;
  245. return $action;
  246. }