From 6f1b2820f6071393e4e03d716014f95f92079afa Mon Sep 17 00:00:00 2001 From: Jwalit Shah Date: Thu, 6 Jan 2022 11:23:02 +1100 Subject: [PATCH 01/10] Add privacy policy --- classes/privacy/provider.php | 43 ++++++++++++++++++++++++++++++++++++ lang/en/block_progress.php | 2 ++ 2 files changed, 45 insertions(+) create mode 100644 classes/privacy/provider.php diff --git a/classes/privacy/provider.php b/classes/privacy/provider.php new file mode 100644 index 0000000..73ac7bc --- /dev/null +++ b/classes/privacy/provider.php @@ -0,0 +1,43 @@ +. + +/** + * Privacy Subsystem implementation for block_progress. + * + * @package block_progress + * @copyright 2018 Nathan Nguyen + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +namespace block_progress\privacy; + +defined('MOODLE_INTERNAL') || die(); + +/** + * The block_progress plugin does not store any data. + * + */ +class provider implements \core_privacy\local\metadata\null_provider { + /** + * Get the language string identifier with the component's language + * file to explain why this plugin stores no data. + * + * @return string + */ + public static function get_reason() : string { + return 'privacy:metadata'; + } +} diff --git a/lang/en/block_progress.php b/lang/en/block_progress.php index 9dd24bc..b150e1a 100755 --- a/lang/en/block_progress.php +++ b/lang/en/block_progress.php @@ -251,3 +251,5 @@ // For My home page. $string['no_blocks'] = "No Progress Bar blocks are set up for your courses."; $string['no_courses'] = "You are not enrolled in any courses. Only bars from enrolled courses will be shown."; + +$string['privacy:metadata'] = "Progress block does not store any personal data."; From e4e335405f8271038af074fc0741813c72638820 Mon Sep 17 00:00:00 2001 From: Marcus Boon Date: Thu, 22 Oct 2015 11:07:41 +1000 Subject: [PATCH 02/10] WR#247995: Raised max_execution time in plugins settings form to 60 seconds for large courses --- edit_form.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/edit_form.php b/edit_form.php index c72103d..538c889 100644 --- a/edit_form.php +++ b/edit_form.php @@ -39,6 +39,9 @@ protected function specific_definition($mform) { global $CFG, $COURSE, $DB, $OUTPUT, $SCRIPT; $loggingenabled = true; + // Raise the max_execution time to 60 seconds for courses with many modules. + core_php_time_limit::raise(60); + // The My home version is not configurable. if (block_progress_on_site_page()) { return; From d54f6098c1b1f794369792b0237fe065cffecf93 Mon Sep 17 00:00:00 2001 From: Marcus Boon Date: Thu, 22 Oct 2015 11:12:21 +1000 Subject: [PATCH 03/10] WR#247995: Raised memory limit in block_progress for large courses --- edit_form.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/edit_form.php b/edit_form.php index 538c889..50a31e1 100644 --- a/edit_form.php +++ b/edit_form.php @@ -42,6 +42,9 @@ protected function specific_definition($mform) { // Raise the max_execution time to 60 seconds for courses with many modules. core_php_time_limit::raise(60); + // Also raise memory limit for courses with many modules. + raise_memory_limit(MEMORY_EXTRA); + // The My home version is not configurable. if (block_progress_on_site_page()) { return; From bc9af0f2130cd8eee9a345e2a52e5224368cd801 Mon Sep 17 00:00:00 2001 From: Matt Porritt Date: Sun, 2 Dec 2018 14:36:35 +1100 Subject: [PATCH 04/10] adding missing file, fixing deprecated string ang fixing undefined var --- edit_form.php | 2 +- lang/en/block_progress.php | 1 + overview.php | 4 +- user_module.js | 75 ++++++++++++++++++++++++++++++++++++++ 4 files changed, 79 insertions(+), 3 deletions(-) create mode 100755 user_module.js diff --git a/edit_form.php b/edit_form.php index 50a31e1..3840f11 100644 --- a/edit_form.php +++ b/edit_form.php @@ -312,7 +312,7 @@ protected function specific_definition($mform) { ); foreach ($sections as $i => $section) { - if (count($section->sequence) > 0) { + if ($section->sequence != null && (count($section->sequence) > 0)) { // Output the section header. $sectionname = get_string('section').': '.get_section_name($COURSE, $section); diff --git a/lang/en/block_progress.php b/lang/en/block_progress.php index b150e1a..2a41646 100755 --- a/lang/en/block_progress.php +++ b/lang/en/block_progress.php @@ -40,6 +40,7 @@ $string['folder'] = 'Folder'; $string['forum'] = 'Forum'; $string['glossary'] = 'Glossary'; +$string['groupaddnewnote'] = 'Add a common note'; $string['hotpot'] = 'Hot Potatoes'; $string['hsuforum'] = 'Advanced Forum'; $string['imscp'] = 'IMS Content Package'; diff --git a/overview.php b/overview.php index 85f28d0..6f48999 100644 --- a/overview.php +++ b/overview.php @@ -325,7 +325,7 @@ } if (!empty($CFG->enablenotes) && has_capability('moodle/notes:manage', $context)) { $displaylist['addnote.php'] = get_string('addnewnote', 'notes'); - $displaylist['groupaddnote.php'] = get_string('groupaddnewnote', 'notes'); + $displaylist['groupaddnote.php'] = get_string('groupaddnewnote', 'block_progress'); } echo html_writer::tag('label', get_string("withselectedusers"), array('for' => 'formactionid')); echo html_writer::select($displaylist, 'formaction', '', array('' => 'choosedots'), array('id' => 'formactionid')); @@ -339,7 +339,7 @@ } // Organise access to JS for messaging. -$module = array('name' => 'core_user', 'fullpath' => '/user/module.js'); +$module = array('name' => 'core_user', 'fullpath' => '/blocks/progress/user_module.js'); $PAGE->requires->js_init_call('M.core_user.init_participation', null, false, $module); // Organise access to JS for progress bars. diff --git a/user_module.js b/user_module.js new file mode 100755 index 0000000..5a75407 --- /dev/null +++ b/user_module.js @@ -0,0 +1,75 @@ + +M.core_user = {}; + +M.core_user.init_participation = function(Y) { + Y.on('change', function() { + var action = Y.one('#formactionid'); + if (action.get('value') == '') { + return; + } + var ok = false; + Y.all('input.usercheckbox').each(function() { + if (this.get('checked')) { + ok = true; + } + }); + if (!ok) { + // no checkbox selected + return; + } + + if (action.get('value') == 'email') { + var mailto = ''; + Y.all('input.usercheckbox').each(function() { + if (this.get('checked')) { + var email = document.getElementById(this.get('name')+'_email').value; + if (mailto.length > 0) { + mailto = mailto+'; '; + } + mailto = mailto+email; + } + }); + location.href='mailto:?bcc='+mailto; + document.getElementById('formactionid').selectedIndex = 0; + return; + } + + Y.one('#participantsform').submit(); + }, '#formactionid'); + + Y.on('click', function(e) { + // Presence of a show all link indicates we should redirect to + // a page with all users listed and checked, otherwise just check + // those already shown. + var showallink = this.getAttribute('data-showallink'); + if (showallink) { + window.location = showallink; + } + Y.all('input.usercheckbox').each(function() { + this.set('checked', 'checked'); + }); + }, '#checkall, #checkallonpage'); + + Y.on('click', function(e) { + Y.all('input.usercheckbox').each(function() { + this.set('checked', ''); + }); + }, '#checknone'); +}; + +M.core_user.init_tree = function(Y, expand_all, htmlid) { + Y.use('yui2-treeview', function(Y) { + var tree = new Y.YUI2.widget.TreeView(htmlid); + + tree.subscribe("clickEvent", function(node, event) { + // we want normal clicking which redirects to url + return false; + }); + + if (expand_all) { + tree.expandAll(); + } + + tree.render(); + }); +}; From 0089b9da7511c3a925959480e98d8647de8c9d79 Mon Sep 17 00:00:00 2001 From: Matt Porritt Date: Sun, 2 Dec 2018 14:53:25 +1100 Subject: [PATCH 05/10] add customisations --- lang/en/block_progress.php | 3 +-- lib.php | 39 ++++++++++++++++++++++++++++++++------ 2 files changed, 34 insertions(+), 8 deletions(-) diff --git a/lang/en/block_progress.php b/lang/en/block_progress.php index 2a41646..a3610e7 100755 --- a/lang/en/block_progress.php +++ b/lang/en/block_progress.php @@ -43,6 +43,7 @@ $string['groupaddnewnote'] = 'Add a common note'; $string['hotpot'] = 'Hot Potatoes'; $string['hsuforum'] = 'Advanced Forum'; +$string['hvp'] = 'Interactive Content'; $string['imscp'] = 'IMS Content Package'; $string['journal'] = 'Journal'; $string['lesson'] = 'Lesson'; @@ -252,5 +253,3 @@ // For My home page. $string['no_blocks'] = "No Progress Bar blocks are set up for your courses."; $string['no_courses'] = "You are not enrolled in any courses. Only bars from enrolled courses will be shown."; - -$string['privacy:metadata'] = "Progress block does not store any personal data."; diff --git a/lib.php b/lib.php index f6d62eb..f0b68fb 100755 --- a/lib.php +++ b/lib.php @@ -490,6 +490,7 @@ function block_progress_monitorable_modules() { 'defaultAction' => 'viewed' ), 'forum' => array( + 'defaultTime' => 'assesstimefinish', 'actions' => array( 'posted_to' => "SELECT id FROM {forum_posts} @@ -565,6 +566,27 @@ function block_progress_monitorable_modules() { ), 'defaultAction' => 'posted_to' ), + 'hvp' => array( + 'actions' => array( + 'viewed' => array ( + 'logstore_legacy' => "SELECT id + FROM {log} + WHERE course = :courseid + AND module = 'hvp' + AND action = 'view' + AND cmid = :cmid + AND userid = :userid", + 'sql_internal_reader' => "SELECT id + FROM {log} + WHERE courseid = :courseid + AND component = 'mod_hvp' + AND action = 'viewed' + AND objectid = :eventid + AND userid = :userid", + ), + ), + 'defaultAction' => 'viewed' + ), 'imscp' => array( 'actions' => array( 'viewed' => array ( @@ -1563,6 +1585,11 @@ function block_progress_bar($modules, $config, $events, $userid, $instance, $att 'id' => 'progressBarInfo'.$instance.'-'.$userid.'-info'); $content .= HTML_WRITER::start_tag('div', $divoptions); if (!$simple) { + if (isset($config->showpercentage) && $config->showpercentage == 1) { + $progress = block_progress_percentage($events, $attempts); + $content .= get_string('progress', 'block_progress').': '; + $content .= $progress.'%'.HTML_WRITER::empty_tag('br'); + } $content .= get_string('mouse_over_prompt', 'block_progress'); $content .= ' '; $attributes = array ( @@ -1712,7 +1739,7 @@ function block_progress_filter_visibility($events, $userid, $coursecontext, $cou if ($coursemodule->uservisible != 1 && empty($coursemodule->availableinfo)) { continue; } - } else if (!groups_course_module_visible($coursemodule, $userid)) { + } else if (!$coursemodule->uservisible) { continue; } } @@ -1728,10 +1755,10 @@ function block_progress_filter_visibility($events, $userid, $coursecontext, $cou * * @return bool True when on the My home page. */ -function block_progress_on_site_page() { - global $SCRIPT, $COURSE; +function block_progress_on_my_page() { + global $SCRIPT; - return $SCRIPT === '/my/index.php' || $COURSE->id == 1; + return $SCRIPT === '/my/index.php'; } /** @@ -1744,7 +1771,7 @@ function block_progress_get_course_context($courseid) { if (class_exists('context_course')) { return context_course::instance($courseid); } else { - return get_context_instance(CONTEXT_COURSE, $courseid); + return context_course::instance($courseid); } } @@ -1758,7 +1785,7 @@ function block_progress_get_block_context($blockid) { if (class_exists('context_block')) { return context_block::instance($blockid); } else { - return get_context_instance(CONTEXT_BLOCK, $blockid); + return context_block::instance($blockid); } } From 897708129872db417da89c9e16fb95c16b8b266a Mon Sep 17 00:00:00 2001 From: Matt Porritt Date: Sun, 2 Dec 2018 14:55:59 +1100 Subject: [PATCH 06/10] bump version --- version.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/version.php b/version.php index 706b9ab..0c74818 100755 --- a/version.php +++ b/version.php @@ -24,8 +24,8 @@ * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ -$plugin->version = 2016081800; +$plugin->version = 2016081800.01; $plugin->requires = 2010121000; $plugin->maturity = MATURITY_STABLE; -$plugin->release = 'Version for Moodle 2.0 to 3.1 (final)'; +$plugin->release = 'Version for Moodle 2.0 onwards'; $plugin->component = 'block_progress'; From 6eff21e979c9cc892ef99ed1944d9e297c1769b3 Mon Sep 17 00:00:00 2001 From: Owen Herbert Date: Tue, 22 Aug 2023 13:52:38 +1000 Subject: [PATCH 07/10] Add language translation --- lang/en/block_progress.php | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lang/en/block_progress.php b/lang/en/block_progress.php index a3610e7..2c0c8b6 100755 --- a/lang/en/block_progress.php +++ b/lang/en/block_progress.php @@ -253,3 +253,5 @@ // For My home page. $string['no_blocks'] = "No Progress Bar blocks are set up for your courses."; $string['no_courses'] = "You are not enrolled in any courses. Only bars from enrolled courses will be shown."; + +$string['privacy:metadata'] = "Progress block does not store any personal data."; From da80833965570c6bea67ddd6c72e5b8601ee857f Mon Sep 17 00:00:00 2001 From: Owen Herbert Date: Tue, 22 Aug 2023 13:55:00 +1000 Subject: [PATCH 08/10] Micro-bump version --- version.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/version.php b/version.php index 0c74818..dd75df2 100755 --- a/version.php +++ b/version.php @@ -24,7 +24,7 @@ * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ -$plugin->version = 2016081800.01; +$plugin->version = 2016081801.01; $plugin->requires = 2010121000; $plugin->maturity = MATURITY_STABLE; $plugin->release = 'Version for Moodle 2.0 onwards'; From 2fba082e2e6b3ce08e8b90c9245e911e51b897db Mon Sep 17 00:00:00 2001 From: Owen Herbert Date: Tue, 22 Aug 2023 14:03:10 +1000 Subject: [PATCH 09/10] Remove decimal from version --- version.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/version.php b/version.php index dd75df2..83e230e 100755 --- a/version.php +++ b/version.php @@ -24,7 +24,7 @@ * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ -$plugin->version = 2016081801.01; +$plugin->version = 2016081801; $plugin->requires = 2010121000; $plugin->maturity = MATURITY_STABLE; $plugin->release = 'Version for Moodle 2.0 onwards'; From e1ac9abfa069c19f26ebdd32a03938f843f4d467 Mon Sep 17 00:00:00 2001 From: Owen Herbert Date: Mon, 13 Nov 2023 15:33:03 +1000 Subject: [PATCH 10/10] WR-421584: Fix bad method names --- block_progress.php | 6 +++--- edit_form.php | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/block_progress.php b/block_progress.php index b946349..929ca6e 100755 --- a/block_progress.php +++ b/block_progress.php @@ -70,7 +70,7 @@ public function specialization() { * @return bool */ public function instance_allow_multiple() { - return !block_progress_on_site_page(); + return !block_progress_on_my_page(); } /** @@ -79,7 +79,7 @@ public function instance_allow_multiple() { * @return bool */ public function instance_allow_config() { - return !block_progress_on_site_page(); + return !block_progress_on_my_page(); } /** @@ -119,7 +119,7 @@ public function get_content() { } // Draw the multi-bar content for the Dashboard and Front page. - if (block_progress_on_site_page()) { + if (block_progress_on_my_page()) { $courses = enrol_get_my_courses(); $coursenametoshow = get_config('block_progress', 'coursenametoshow') ?: DEFAULT_COURSENAMETOSHOW; $sql = "SELECT bi.id, diff --git a/edit_form.php b/edit_form.php index 3840f11..bb68d02 100644 --- a/edit_form.php +++ b/edit_form.php @@ -46,7 +46,7 @@ protected function specific_definition($mform) { raise_memory_limit(MEMORY_EXTRA); // The My home version is not configurable. - if (block_progress_on_site_page()) { + if (block_progress_on_my_page()) { return; }