Skip to content

Commit

Permalink
CTP-3704 avoid theme init on create
Browse files Browse the repository at this point in the history
  • Loading branch information
watson8 committed Aug 19, 2024
1 parent 0d6965b commit 44aa8d9
Show file tree
Hide file tree
Showing 2 changed files with 90 additions and 48 deletions.
58 changes: 10 additions & 48 deletions lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,8 @@ function mod_coursework_pluginfile($course, $cm, $context, $filearea, $args, $fo
* @return int The id of the newly inserted coursework record
*/
function coursework_add_instance($formdata) {
global $DB;
global $DB, $CFG;
require_once("$CFG->dirroot/mod/coursework/locallib.php");

$formdata->timecreated = time();

Expand Down Expand Up @@ -196,24 +197,19 @@ function coursework_add_instance($formdata) {

// Create event for coursework deadline [due]
if ($coursework && $coursework->deadline) {
$event = coursework_event($coursework, format_module_intro('coursework', $coursework,
$coursemodule->id), $returnid, 'due', $coursework->deadline);

$event = coursework_event($coursework, 'due', $coursework->deadline);
calendar_event::create($event);
}

// Create event for coursework initialmarking deadline [initialgradingdue]
if ($coursework && $coursework->marking_deadline_enabled() && $coursework->initialmarkingdeadline) {
$event = coursework_event($coursework, format_module_intro('coursework', $coursework,
$coursemodule->id), $returnid, 'initialgradingdue', $coursework->initialmarkingdeadline);

$event = coursework_event($coursework, 'initialgradingdue', $coursework->initialmarkingdeadline);
calendar_event::create($event);
}

// Create event for coursework agreedgrademarking deadline [agreedgradingdue]
if ($coursework && $coursework->marking_deadline_enabled() && $coursework->agreedgrademarkingdeadline && $coursework->has_multiple_markers()) {
$event = coursework_event($coursework, format_module_intro('coursework', $coursework,
$coursemodule->id), $returnid, 'agreedgradingdue', $coursework->agreedgrademarkingdeadline);
$event = coursework_event($coursework, 'agreedgradingdue', $coursework->agreedgrademarkingdeadline);
calendar_event::create($event);
}

Expand Down Expand Up @@ -523,7 +519,8 @@ function coursework_update_instance($coursework) {
* @param $coursework
*/
function coursework_update_events($coursework, $eventtype) {
global $DB;
global $DB, $CFG;
require_once("$CFG->dirroot/mod/coursework/locallib.php");

$event = "";
$eventid = $DB->get_record('event', array('modulename' => 'coursework', 'instance' => $coursework->id, 'eventtype' => $eventtype));
Expand All @@ -534,7 +531,7 @@ function coursework_update_events($coursework, $eventtype) {

// Update/create event for coursework deadline [due]
if ($eventtype == 'due') {
$data = coursework_event($coursework, $coursework->intro, $coursework->id, $eventtype, $coursework->deadline);
$data = coursework_event($coursework, $eventtype, $coursework->deadline);
if ($event) {
$event->update($data); //update if event exists
} else {
Expand All @@ -544,7 +541,7 @@ function coursework_update_events($coursework, $eventtype) {

// Update/create event for coursework initialmarking deadline [initialgradingdue]
if ($eventtype == 'initialgradingdue') {
$data = coursework_event($coursework, $coursework->intro, $coursework->id, $eventtype, $coursework->initialmarkingdeadline);
$data = coursework_event($coursework, $eventtype, $coursework->initialmarkingdeadline);
if ($event) {
$event->update($data); //update if event exists
} else {
Expand All @@ -554,7 +551,7 @@ function coursework_update_events($coursework, $eventtype) {

// Update/create event for coursework agreedgrademarking deadline [agreedgradingdue]
if ($eventtype == 'agreedgradingdue') {
$data = coursework_event($coursework, $coursework->intro, $coursework->id, $eventtype, $coursework->agreedgrademarkingdeadline);
$data = coursework_event($coursework, $eventtype, $coursework->agreedgrademarkingdeadline);
if ($event) {
$event->update($data); //update if event exists
} else {
Expand Down Expand Up @@ -1523,41 +1520,6 @@ function coursework_personal_deadline_passed($courseworkid) {

}

/**
* @param coursework $coursework
* @param $description
* @param $instance
* @param $eventtype
* @param $deadline
* @return stdClass
*/
function coursework_event($coursework, $description, $instance, $eventtype, $deadline) {

$event = new stdClass();
$event->type = CALENDAR_EVENT_TYPE_ACTION;

$event->description = $description;
$event->courseid = $coursework->course;
$event->name = $coursework->name;
$event->groupid = 0;
$event->userid = 0;
$event->modulename = 'coursework';
$event->instance = $instance;
$event->eventtype = $eventtype;
$event->timestart = $deadline;
$event->timeduration = 0;
$event->timesort = $deadline;
$event->visible = instance_is_visible('coursework', $coursework);

/* if ($eventtype == 'initialgradingdue') {
$event->name .= " (Initial stage)";
} else if ($eventtype == 'agreedgradingdue') {
$event->name .= " (Agreed Grade stage)";
}*/

return $event;
}

/**
* Purge coursework cache if a role with specific capability passed
*
Expand Down
80 changes: 80 additions & 0 deletions locallib.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
<?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/>.

/**
* Local library for module coursework
*
* @package mod_coursework
* @copyright 2024 UCL
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/

defined('MOODLE_INTERNAL') || die();

global $CFG;

/**
* Get an object to create a calendar event for coursework.
* @param object $coursework
* @param string $eventtype
* @param int|null $deadline
* @return stdClass
*/
function coursework_event(object $coursework, string $eventtype, ?int $deadline) {

$event = new stdClass();
$event->type = CALENDAR_EVENT_TYPE_ACTION;

// Description field needs some formatting in same way a mod_assign does it.
// Convert the links to pluginfile. It is a bit hacky but at this stage the files
// might not have been saved in the module area yet.
if ($draftid = file_get_submitted_draft_itemid('introeditor')) {
$intro = file_rewrite_urls_to_pluginfile($coursework->intro, $draftid);
} else {
$intro = $coursework->intro;
}

$cm = get_coursemodule_from_instance('coursework', $coursework->id);

// We need to remove the links to files as the calendar is not ready
// to support module events with file areas.
$intro = strip_pluginfile_content($intro);
if ($cm->showdescription) {
$event->description = array(
'text' => $intro,
'format' => $coursework->introformat
);
} else {
$event->description = array(
'text' => '',
'format' => $coursework->introformat
);
}

$event->courseid = $coursework->course;
$event->name = $coursework->name;
$event->groupid = 0;
$event->userid = 0;
$event->modulename = 'coursework';
$event->instance = $coursework->id;
$event->eventtype = $eventtype;
$event->timestart = $deadline;
$event->timeduration = 0;
$event->timesort = $deadline;
$event->visible = instance_is_visible('coursework', $coursework);

return $event;
}

0 comments on commit 44aa8d9

Please sign in to comment.