From 452f08ecd2e49fe81a9315a2695f5b23321a9cd8 Mon Sep 17 00:00:00 2001 From: M <12033826+maksudr@users.noreply.github.com> Date: Mon, 29 Jul 2019 22:08:27 +0100 Subject: [PATCH] Issue #405 Convert shift click functionality to drop down menu. Use user preferences to remember the value of the drop-down --- lang/en/attendance.php | 2 ++ renderer.php | 42 +++++++++++++++++++++++++++--- tests/behat/extra_features.feature | 14 +++++----- 3 files changed, 48 insertions(+), 10 deletions(-) diff --git a/lang/en/attendance.php b/lang/en/attendance.php index d45e10b..0511229 100644 --- a/lang/en/attendance.php +++ b/lang/en/attendance.php @@ -463,6 +463,8 @@ $string['statusdeleted'] = 'Status deleted'; $string['statuses'] = 'Statuses'; $string['statusset'] = 'Status set {$a}'; $string['statussetsettings'] = 'Status set'; +$string['statusall'] = 'all'; +$string['statusunselected'] = 'unselected'; $string['strftimedm'] = '%b %d'; $string['strftimedmy'] = '%d %b %Y'; $string['strftimedmyhm'] = '%d %b %Y %I.%M%p'; // Line added to allow multiple sessions in the same day. diff --git a/renderer.php b/renderer.php index c11bc95..e6a2321 100644 --- a/renderer.php +++ b/renderer.php @@ -28,6 +28,7 @@ require_once(dirname(__FILE__).'/locallib.php'); require_once(dirname(__FILE__).'/renderables.php'); require_once(dirname(__FILE__).'/renderhelpers.php'); require_once($CFG->libdir.'/tablelib.php'); +require_once($CFG->libdir.'/moodlelib.php'); /** * Attendance module renderer class @@ -414,6 +415,8 @@ class mod_attendance_renderer extends plugin_renderer_base { * @return string */ protected function render_attendance_take_data(attendance_take_data $takedata) { + user_preference_allow_ajax_update('mod_attendance_statusdropdown', PARAM_RAW); + $controls = $this->render_attendance_take_controls($takedata); $table = html_writer::start_div('no-overflow'); if ($takedata->pageparams->viewmode == mod_attendance_take_page_params::SORTED_LIST) { @@ -595,6 +598,26 @@ class mod_attendance_renderer extends plugin_renderer_base { return $controls; } + /** + * Render statusdropdown + * + * @param string $preference + * @return string + */ + private function render_statusdropdown($preference) { + if ($preference == 'unselected') { + return " "; + } else { + return " "; + } + } + /** * Render take list. * @@ -649,7 +672,11 @@ class mod_attendance_renderer extends plugin_renderer_base { foreach ($extrasearchfields as $field) { $row->cells[] = ''; } - $row->cells[] = html_writer::div(get_string('setallstatuses', 'attendance'), 'setallstatuses'); + + $selectmenu = $this->render_statusdropdown(get_user_preferences('mod_attendance_statusdropdown')); + + $row->cells[] = html_writer::div(get_string('setallstatuses', 'attendance'). + $selectmenu, 'setallstatuses'); foreach ($takedata->statuses as $st) { $attribs = array( 'id' => 'radiocheckstatus'.$st->id, @@ -663,11 +690,13 @@ class mod_attendance_renderer extends plugin_renderer_base { $PAGE->requires->js_amd_inline(" require(['jquery'], function($) { $('#radiocheckstatus".$st->id."').click(function(e) { - if (e.shiftKey) { + if ($('#setallstatus-select').val() == 'all') { $('#attendancetakeform').find('.st".$st->id."').prop('checked', true); + M.util.set_user_preference('mod_attendance_statusdropdown','all'); } else { $('#attendancetakeform').find('input:indeterminate.st".$st->id."').prop('checked', true); + M.util.set_user_preference('mod_attendance_statusdropdown','unselected'); } }); });"); @@ -726,7 +755,12 @@ class mod_attendance_renderer extends plugin_renderer_base { } $table->attributes['class'] = 'generaltable takegrid'; $table->headspan = $takedata->pageparams->gridcols; + + $selectmenu = $this->render_statusdropdown(get_user_preferences('mod_attendance_statusdropdown')); + $head = array(); + $head[] = html_writer::div(get_string('setallstatuses', 'attendance'). + $selectmenu, 'setallstatuses'); foreach ($takedata->statuses as $st) { $head[] = html_writer::link("#", $st->acronym, array('id' => 'checkstatus'.$st->id, 'title' => get_string('setallstatusesto', 'attendance', $st->description))); @@ -734,11 +768,13 @@ class mod_attendance_renderer extends plugin_renderer_base { $PAGE->requires->js_amd_inline(" require(['jquery'], function($) { $('#checkstatus".$st->id."').click(function(e) { - if (e.shiftKey) { + if ($('#setallstatus-select').val() == 'unselected') { $('#attendancetakeform').find('input:indeterminate.st".$st->id."').prop('checked', true); + M.util.set_user_preference('mod_attendance_statusdropdown','unselected'); } else { $('#attendancetakeform').find('.st".$st->id."').prop('checked', true); + M.util.set_user_preference('mod_attendance_statusdropdown','all'); } e.preventDefault(); }); diff --git a/tests/behat/extra_features.feature b/tests/behat/extra_features.feature index db7c77c..ab9d4c2 100644 --- a/tests/behat/extra_features.feature +++ b/tests/behat/extra_features.feature @@ -182,16 +182,16 @@ Feature: Test the various new features in the attendance module And I click on "submitbutton" "button" When I click on "Take attendance" "link" in the "10AM" "table_row" - Then "Set status for all users to «Present»" "link" should exist - And "Set status for all users to «Late»" "link" should exist - And "Set status for all users to «Excused»" "link" should exist - And "Set status for all users to «Absent»" "link" should exist + Then "Set status to «Present»" "link" should exist + And "Set status to «Late»" "link" should exist + And "Set status to «Excused»" "link" should exist + And "Set status to «Absent»" "link" should exist When I follow "Sessions" And I click on "Take attendance" "link" in the "12PM" "table_row" - Then "Set status for all users to «Great»" "link" should exist - And "Set status for all users to «OK»" "link" should exist - And "Set status for all users to «Bad»" "link" should exist + Then "Set status to «Great»" "link" should exist + And "Set status to «OK»" "link" should exist + And "Set status to «Bad»" "link" should exist Scenario: A teacher can use the radio buttons to set attendance values for all users Given I log in as "teacher1"