mirror of
https://github.com/moodle/moodle.git
synced 2025-03-14 20:50:21 +01:00
MDL-57877 mod_data: added action events
Part of MDL-55611 epic.
This commit is contained in:
parent
d4718e5ab9
commit
7c6f961bf9
@ -39,6 +39,9 @@ define('DATA_PRESET_COMPONENT', 'mod_data');
|
|||||||
define('DATA_PRESET_FILEAREA', 'site_presets');
|
define('DATA_PRESET_FILEAREA', 'site_presets');
|
||||||
define('DATA_PRESET_CONTEXT', SYSCONTEXTID);
|
define('DATA_PRESET_CONTEXT', SYSCONTEXTID);
|
||||||
|
|
||||||
|
define('DATA_EVENT_TYPE_OPEN', 'open');
|
||||||
|
define('DATA_EVENT_TYPE_CLOSE', 'close');
|
||||||
|
|
||||||
// Users having assigned the default role "Non-editing teacher" can export database records
|
// Users having assigned the default role "Non-editing teacher" can export database records
|
||||||
// Using the mod/data capability "viewalluserpresets" existing in Moodle 1.9.x.
|
// Using the mod/data capability "viewalluserpresets" existing in Moodle 1.9.x.
|
||||||
// In Moodle >= 2, new roles may be introduced and used instead.
|
// In Moodle >= 2, new roles may be introduced and used instead.
|
||||||
@ -3272,7 +3275,7 @@ function data_extend_navigation($navigation, $course, $module, $cm) {
|
|||||||
$currentgroup = groups_get_activity_group($cm);
|
$currentgroup = groups_get_activity_group($cm);
|
||||||
$groupmode = groups_get_activity_groupmode($cm);
|
$groupmode = groups_get_activity_groupmode($cm);
|
||||||
|
|
||||||
$numentries = data_numentries($data);
|
$numentries = data_numentries($data);
|
||||||
$canmanageentries = has_capability('mod/data:manageentries', context_module::instance($cm->id));
|
$canmanageentries = has_capability('mod/data:manageentries', context_module::instance($cm->id));
|
||||||
|
|
||||||
if ($data->entriesleft = data_get_entries_left_to_add($data, $numentries, $canmanageentries)) {
|
if ($data->entriesleft = data_get_entries_left_to_add($data, $numentries, $canmanageentries)) {
|
||||||
@ -4212,3 +4215,47 @@ function data_check_updates_since(cm_info $cm, $from, $filter = array()) {
|
|||||||
|
|
||||||
return $updates;
|
return $updates;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Is the event visible?
|
||||||
|
*
|
||||||
|
* @param \core_calendar\event $event
|
||||||
|
* @return bool Returns true if the event is visible to the current user, false otherwise.
|
||||||
|
*/
|
||||||
|
function mod_data_core_calendar_is_event_visible(\core_calendar\event $event) {
|
||||||
|
$cm = get_fast_modinfo($event->courseid)->instances['data'][$event->instance];
|
||||||
|
$context = context_module::instance($cm->id);
|
||||||
|
|
||||||
|
return has_capability('mod/data:view', $context);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Handles creating actions for events.
|
||||||
|
*
|
||||||
|
* @param \core_calendar\event $event
|
||||||
|
* @param \core_calendar\action_factory $factory
|
||||||
|
* @return \core_calendar\local\event\value_objects\action|\core_calendar\local\interfaces\action_interface|null
|
||||||
|
*/
|
||||||
|
function mod_data_core_calendar_provide_event_action(\core_calendar\event $event,
|
||||||
|
\core_calendar\action_factory $factory) {
|
||||||
|
global $DB;
|
||||||
|
|
||||||
|
$cm = get_fast_modinfo($event->courseid)->instances['data'][$event->instance];
|
||||||
|
$data = $DB->get_record('data', array('id' => $event->instance), 'id, timeavailablefrom, timeavailableto');
|
||||||
|
|
||||||
|
if ($data->timeavailablefrom && $data->timeavailableto) {
|
||||||
|
$actionable = (time() >= $data->timeavailablefrom) && (time() <= $data->timeavailableto);
|
||||||
|
} else if ($data->timeavailableto) {
|
||||||
|
$actionable = time() < $data->timeavailableto;
|
||||||
|
} else if ($data->timeavailablefrom) {
|
||||||
|
$actionable = time() >= $data->timeavailablefrom;
|
||||||
|
} else {
|
||||||
|
$actionable = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $factory->create_instance(
|
||||||
|
get_string('add', 'data'),
|
||||||
|
new \moodle_url('/mod/data/view.php', array('id' => $cm->id)),
|
||||||
|
1,
|
||||||
|
$actionable
|
||||||
|
);
|
||||||
|
}
|
||||||
|
@ -599,13 +599,17 @@ function data_set_events($data) {
|
|||||||
}
|
}
|
||||||
// Data start calendar events.
|
// Data start calendar events.
|
||||||
$event = new stdClass();
|
$event = new stdClass();
|
||||||
|
$event->eventtype = DATA_EVENT_TYPE_OPEN;
|
||||||
|
// The DATA_EVENT_TYPE_OPEN event should only be an action event if no close time was specified.
|
||||||
|
$event->type = empty($data->timeavailableto) ? CALENDAR_EVENT_TYPE_ACTION : CALENDAR_EVENT_TYPE_STANDARD;
|
||||||
if ($event->id = $DB->get_field('event', 'id',
|
if ($event->id = $DB->get_field('event', 'id',
|
||||||
array('modulename' => 'data', 'instance' => $data->id, 'eventtype' => 'open'))) {
|
array('modulename' => 'data', 'instance' => $data->id, 'eventtype' => $event->eventtype))) {
|
||||||
if ($data->timeavailablefrom > 0) {
|
if ($data->timeavailablefrom > 0) {
|
||||||
// Calendar event exists so update it.
|
// Calendar event exists so update it.
|
||||||
$event->name = get_string('calendarstart', 'data', $data->name);
|
$event->name = get_string('calendarstart', 'data', $data->name);
|
||||||
$event->description = format_module_intro('data', $data, $data->coursemodule);
|
$event->description = format_module_intro('data', $data, $data->coursemodule);
|
||||||
$event->timestart = $data->timeavailablefrom;
|
$event->timestart = $data->timeavailablefrom;
|
||||||
|
$event->timesort = $data->timeavailablefrom;
|
||||||
$event->visible = instance_is_visible('data', $data);
|
$event->visible = instance_is_visible('data', $data);
|
||||||
$event->timeduration = 0;
|
$event->timeduration = 0;
|
||||||
$calendarevent = \core_calendar\event::load($event->id);
|
$calendarevent = \core_calendar\event::load($event->id);
|
||||||
@ -625,8 +629,8 @@ function data_set_events($data) {
|
|||||||
$event->userid = 0;
|
$event->userid = 0;
|
||||||
$event->modulename = 'data';
|
$event->modulename = 'data';
|
||||||
$event->instance = $data->id;
|
$event->instance = $data->id;
|
||||||
$event->eventtype = 'open';
|
|
||||||
$event->timestart = $data->timeavailablefrom;
|
$event->timestart = $data->timeavailablefrom;
|
||||||
|
$event->timesort = $data->timeavailablefrom;
|
||||||
$event->visible = instance_is_visible('data', $data);
|
$event->visible = instance_is_visible('data', $data);
|
||||||
$event->timeduration = 0;
|
$event->timeduration = 0;
|
||||||
\core_calendar\event::create($event);
|
\core_calendar\event::create($event);
|
||||||
@ -635,13 +639,16 @@ function data_set_events($data) {
|
|||||||
|
|
||||||
// Data end calendar events.
|
// Data end calendar events.
|
||||||
$event = new stdClass();
|
$event = new stdClass();
|
||||||
|
$event->type = CALENDAR_EVENT_TYPE_ACTION;
|
||||||
|
$event->eventtype = DATA_EVENT_TYPE_CLOSE;
|
||||||
if ($event->id = $DB->get_field('event', 'id',
|
if ($event->id = $DB->get_field('event', 'id',
|
||||||
array('modulename' => 'data', 'instance' => $data->id, 'eventtype' => 'close'))) {
|
array('modulename' => 'data', 'instance' => $data->id, 'eventtype' => $event->eventtype))) {
|
||||||
if ($data->timeavailableto > 0) {
|
if ($data->timeavailableto > 0) {
|
||||||
// Calendar event exists so update it.
|
// Calendar event exists so update it.
|
||||||
$event->name = get_string('calendarend', 'data', $data->name);
|
$event->name = get_string('calendarend', 'data', $data->name);
|
||||||
$event->description = format_module_intro('data', $data, $data->coursemodule);
|
$event->description = format_module_intro('data', $data, $data->coursemodule);
|
||||||
$event->timestart = $data->timeavailableto;
|
$event->timestart = $data->timeavailableto;
|
||||||
|
$event->timesort = $data->timeavailableto;
|
||||||
$event->visible = instance_is_visible('data', $data);
|
$event->visible = instance_is_visible('data', $data);
|
||||||
$event->timeduration = 0;
|
$event->timeduration = 0;
|
||||||
$calendarevent = \core_calendar\event::load($event->id);
|
$calendarevent = \core_calendar\event::load($event->id);
|
||||||
@ -654,7 +661,6 @@ function data_set_events($data) {
|
|||||||
} else {
|
} else {
|
||||||
// Event doesn't exist so create one.
|
// Event doesn't exist so create one.
|
||||||
if (isset($data->timeavailableto) && $data->timeavailableto > 0) {
|
if (isset($data->timeavailableto) && $data->timeavailableto > 0) {
|
||||||
$event = new stdClass();
|
|
||||||
$event->name = get_string('calendarend', 'data', $data->name);
|
$event->name = get_string('calendarend', 'data', $data->name);
|
||||||
$event->description = format_module_intro('data', $data, $data->coursemodule);
|
$event->description = format_module_intro('data', $data, $data->coursemodule);
|
||||||
$event->courseid = $data->course;
|
$event->courseid = $data->course;
|
||||||
@ -662,8 +668,8 @@ function data_set_events($data) {
|
|||||||
$event->userid = 0;
|
$event->userid = 0;
|
||||||
$event->modulename = 'data';
|
$event->modulename = 'data';
|
||||||
$event->instance = $data->id;
|
$event->instance = $data->id;
|
||||||
$event->eventtype = 'close';
|
|
||||||
$event->timestart = $data->timeavailableto;
|
$event->timestart = $data->timeavailableto;
|
||||||
|
$event->timesort = $data->timeavailableto;
|
||||||
$event->visible = instance_is_visible('data', $data);
|
$event->visible = instance_is_visible('data', $data);
|
||||||
$event->timeduration = 0;
|
$event->timeduration = 0;
|
||||||
\core_calendar\event::create($event);
|
\core_calendar\event::create($event);
|
||||||
|
@ -994,4 +994,182 @@ class mod_data_lib_testcase extends advanced_testcase {
|
|||||||
$this->assertTrue($updates->entries->updated);
|
$this->assertTrue($updates->entries->updated);
|
||||||
$this->assertEquals([$datarecor1did, $datarecor2did], $updates->entries->itemids, '', 0, 10, true);
|
$this->assertEquals([$datarecor1did, $datarecor2did], $updates->entries->itemids, '', 0, 10, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_data_core_calendar_is_event_visible() {
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$this->setAdminUser();
|
||||||
|
|
||||||
|
// Create a course.
|
||||||
|
$course = $this->getDataGenerator()->create_course();
|
||||||
|
|
||||||
|
// Create a database activity.
|
||||||
|
$data = $this->getDataGenerator()->create_module('data', array('course' => $course->id));
|
||||||
|
|
||||||
|
// Create a calendar event.
|
||||||
|
$event = $this->create_action_event($course->id, $data->id, DATA_EVENT_TYPE_OPEN);
|
||||||
|
|
||||||
|
// Check that we can see the event.
|
||||||
|
$this->assertTrue(mod_data_core_calendar_is_event_visible($event));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_data_core_calendar_is_event_visible_as_non_user() {
|
||||||
|
global $CFG;
|
||||||
|
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$this->setAdminUser();
|
||||||
|
|
||||||
|
// Create a course.
|
||||||
|
$course = $this->getDataGenerator()->create_course();
|
||||||
|
|
||||||
|
// Create a database activity.
|
||||||
|
$data = $this->getDataGenerator()->create_module('data', array('course' => $course->id));
|
||||||
|
|
||||||
|
// Create a calendar event.
|
||||||
|
$event = $this->create_action_event($course->id, $data->id, DATA_EVENT_TYPE_OPEN);
|
||||||
|
|
||||||
|
// Log out the user and set force login to true.
|
||||||
|
\core\session\manager::init_empty_session();
|
||||||
|
$CFG->forcelogin = true;
|
||||||
|
|
||||||
|
// Check that we can't see the event.
|
||||||
|
$this->assertFalse(mod_data_core_calendar_is_event_visible($event));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_data_core_calendar_provide_event_action_open() {
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$this->setAdminUser();
|
||||||
|
|
||||||
|
// Create a course.
|
||||||
|
$course = $this->getDataGenerator()->create_course();
|
||||||
|
|
||||||
|
// Create a database activity.
|
||||||
|
$data = $this->getDataGenerator()->create_module('data', array('course' => $course->id,
|
||||||
|
'timeavailablefrom' => time() - DAYSECS, 'timeavailableto' => time() + DAYSECS));
|
||||||
|
|
||||||
|
// Create a calendar event.
|
||||||
|
$event = $this->create_action_event($course->id, $data->id, DATA_EVENT_TYPE_OPEN);
|
||||||
|
|
||||||
|
// Create an action factory.
|
||||||
|
$factory = new \core_calendar\action_factory();
|
||||||
|
|
||||||
|
// Decorate action event.
|
||||||
|
$actionevent = mod_data_core_calendar_provide_event_action($event, $factory);
|
||||||
|
|
||||||
|
// Confirm the event was decorated.
|
||||||
|
$this->assertInstanceOf('\core_calendar\local\event\value_objects\action', $actionevent);
|
||||||
|
$this->assertEquals(get_string('add', 'data'), $actionevent->get_name());
|
||||||
|
$this->assertInstanceOf('moodle_url', $actionevent->get_url());
|
||||||
|
$this->assertEquals(1, $actionevent->get_item_count());
|
||||||
|
$this->assertTrue($actionevent->is_actionable());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_data_core_calendar_provide_event_action_closed() {
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$this->setAdminUser();
|
||||||
|
|
||||||
|
// Create a course.
|
||||||
|
$course = $this->getDataGenerator()->create_course();
|
||||||
|
|
||||||
|
// Create a database activity.
|
||||||
|
$data = $this->getDataGenerator()->create_module('data', array('course' => $course->id,
|
||||||
|
'timeavailableto' => time() - DAYSECS));
|
||||||
|
|
||||||
|
// Create a calendar event.
|
||||||
|
$event = $this->create_action_event($course->id, $data->id, DATA_EVENT_TYPE_OPEN);
|
||||||
|
|
||||||
|
// Create an action factory.
|
||||||
|
$factory = new \core_calendar\action_factory();
|
||||||
|
|
||||||
|
// Decorate action event.
|
||||||
|
$actionevent = mod_data_core_calendar_provide_event_action($event, $factory);
|
||||||
|
|
||||||
|
// Confirm the event was decorated.
|
||||||
|
$this->assertInstanceOf('\core_calendar\local\event\value_objects\action', $actionevent);
|
||||||
|
$this->assertEquals(get_string('add', 'data'), $actionevent->get_name());
|
||||||
|
$this->assertInstanceOf('moodle_url', $actionevent->get_url());
|
||||||
|
$this->assertEquals(1, $actionevent->get_item_count());
|
||||||
|
$this->assertFalse($actionevent->is_actionable());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_data_core_calendar_provide_event_action_open_in_future() {
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$this->setAdminUser();
|
||||||
|
|
||||||
|
// Create a course.
|
||||||
|
$course = $this->getDataGenerator()->create_course();
|
||||||
|
|
||||||
|
// Create a database activity.
|
||||||
|
$data = $this->getDataGenerator()->create_module('data', array('course' => $course->id,
|
||||||
|
'timeavailablefrom' => time() + DAYSECS));
|
||||||
|
|
||||||
|
// Create a calendar event.
|
||||||
|
$event = $this->create_action_event($course->id, $data->id, DATA_EVENT_TYPE_OPEN);
|
||||||
|
|
||||||
|
// Create an action factory.
|
||||||
|
$factory = new \core_calendar\action_factory();
|
||||||
|
|
||||||
|
// Decorate action event.
|
||||||
|
$actionevent = mod_data_core_calendar_provide_event_action($event, $factory);
|
||||||
|
|
||||||
|
// Confirm the event was decorated.
|
||||||
|
$this->assertInstanceOf('\core_calendar\local\event\value_objects\action', $actionevent);
|
||||||
|
$this->assertEquals(get_string('add', 'data'), $actionevent->get_name());
|
||||||
|
$this->assertInstanceOf('moodle_url', $actionevent->get_url());
|
||||||
|
$this->assertEquals(1, $actionevent->get_item_count());
|
||||||
|
$this->assertFalse($actionevent->is_actionable());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_data_core_calendar_provide_event_action_no_time_specified() {
|
||||||
|
$this->resetAfterTest();
|
||||||
|
|
||||||
|
$this->setAdminUser();
|
||||||
|
|
||||||
|
// Create a course.
|
||||||
|
$course = $this->getDataGenerator()->create_course();
|
||||||
|
|
||||||
|
// Create a database activity.
|
||||||
|
$data = $this->getDataGenerator()->create_module('data', array('course' => $course->id));
|
||||||
|
|
||||||
|
// Create a calendar event.
|
||||||
|
$event = $this->create_action_event($course->id, $data->id, DATA_EVENT_TYPE_OPEN);
|
||||||
|
|
||||||
|
// Create an action factory.
|
||||||
|
$factory = new \core_calendar\action_factory();
|
||||||
|
|
||||||
|
// Decorate action event.
|
||||||
|
$actionevent = mod_data_core_calendar_provide_event_action($event, $factory);
|
||||||
|
|
||||||
|
// Confirm the event was decorated.
|
||||||
|
$this->assertInstanceOf('\core_calendar\local\event\value_objects\action', $actionevent);
|
||||||
|
$this->assertEquals(get_string('add', 'data'), $actionevent->get_name());
|
||||||
|
$this->assertInstanceOf('moodle_url', $actionevent->get_url());
|
||||||
|
$this->assertEquals(1, $actionevent->get_item_count());
|
||||||
|
$this->assertTrue($actionevent->is_actionable());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an action event.
|
||||||
|
*
|
||||||
|
* @param int $courseid
|
||||||
|
* @param int $instanceid The data id.
|
||||||
|
* @param string $eventtype The event type. eg. DATA_EVENT_TYPE_OPEN.
|
||||||
|
* @return bool|\core_calendar\event
|
||||||
|
*/
|
||||||
|
private function create_action_event($courseid, $instanceid, $eventtype) {
|
||||||
|
$event = new stdClass();
|
||||||
|
$event->name = 'Calendar event';
|
||||||
|
$event->modulename = 'data';
|
||||||
|
$event->courseid = $courseid;
|
||||||
|
$event->instance = $instanceid;
|
||||||
|
$event->type = CALENDAR_EVENT_TYPE_ACTION;
|
||||||
|
$event->eventtype = $eventtype;
|
||||||
|
$event->timestart = time();
|
||||||
|
|
||||||
|
return \core_calendar\event::create($event);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user