Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is supported too.
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * Bulk activity completion selection
 *
 * @package     core_completion
 * @category    completion
 * @copyright   2017 Adrian Greeve
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

require_once(__DIR__.'/../config.php');
require_once($CFG->dirroot.'/course/lib.php');
require_once($CFG->libdir.'/completionlib.php');

$id = required_param('id', PARAM_INT); // Course id.
$cmids = optional_param_array('cmid', [], PARAM_INT);

// Perform some basic access control checks.
if ($id) {

    if ($id == SITEID) {
        // Don't allow editing of 'site course' using this form.
< print_error('cannoteditsiteform');
> throw new \moodle_exception('cannoteditsiteform');
} if (!$course = $DB->get_record('course', array('id' => $id))) {
< print_error('invalidcourseid');
> throw new \moodle_exception('invalidcourseid');
} require_login($course); } else { require_login();
< print_error('needcourseid');
> throw new \moodle_exception('needcourseid');
} // Set up the page. navigation_node::override_active_url(new moodle_url('/course/completion.php', array('id' => $course->id))); $PAGE->set_course($course); $PAGE->set_url('/course/bulkcompletion.php', array('id' => $course->id)); $PAGE->set_title($course->shortname); $PAGE->set_heading($course->fullname); $PAGE->set_pagelayout('admin'); // Check access. if (!core_completion\manager::can_edit_bulk_completion($id)) { require_capability('moodle/course:manageactivities', context_course::instance($course->id)); } // Get all that stuff I need for the renderer. $manager = new \core_completion\manager($id); $bulkcompletiondata = $manager->get_activities_and_headings(); $renderer = $PAGE->get_renderer('core_course', 'bulk_activity_completion'); // Print the form. echo $OUTPUT->header();
< echo $OUTPUT->heading(get_string('bulkactivitycompletion', 'completion'));
< echo $renderer->navigation($course, 'bulkcompletion'); < < $PAGE->requires->yui_module('moodle-core-formchangechecker', < 'M.core_formchangechecker.init', < array(array( < 'formid' => 'theform' < )) < ); < $PAGE->requires->string_for_js('changesmadereallygoaway', 'moodle');
> $actionbar = new \core_course\output\completion_action_bar($course->id, $PAGE->url); > echo $renderer->render_course_completion_action_bar($actionbar);
> $PAGE->requires->js_call_amd('core_form/changechecker', 'watchFormById', ['theform']);
echo $renderer->bulkcompletion($bulkcompletiondata); echo $OUTPUT->footer();