Breaking database changes to support periods and studyplan pages.
This commit is contained in:
parent
c9e25b765d
commit
ff321e21c5
6 changed files with 184 additions and 21 deletions
|
@ -125,9 +125,9 @@ class badgeinfo {
|
||||||
|
|
||||||
if($issued) {
|
if($issued) {
|
||||||
$issueinfo = $DB->get_record('badge_issued', array('badgeid' => $this->badge->id, 'userid' => $userid));
|
$issueinfo = $DB->get_record('badge_issued', array('badgeid' => $this->badge->id, 'userid' => $userid));
|
||||||
$badge['dateissued'] = userdate($issueinfo->dateissued,"%e %b %G");
|
$badge['dateissued'] = date("Y-m-d",$issueinfo->dateissued);
|
||||||
if($issueinfo->expiredate){
|
if($issueinfo->expiredate){
|
||||||
$badge['dateexpire'] = userdate($issueinfo->dateexpire,"%e %b %G");
|
$badge['dateexpire'] = date("Y-m-d",$issueinfo->dateexpire);
|
||||||
}
|
}
|
||||||
$badge['uniquehash'] = $issueinfo->uniquehash;
|
$badge['uniquehash'] = $issueinfo->uniquehash;
|
||||||
$badge['issuedlink'] = (new \moodle_url('/badges/badge.php', ['hash' => $issueinfo->uniquehash]))->out(false);
|
$badge['issuedlink'] = (new \moodle_url('/badges/badge.php', ['hash' => $issueinfo->uniquehash]))->out(false);
|
||||||
|
|
|
@ -179,7 +179,7 @@ class corecompletioninfo {
|
||||||
$details = [
|
$details = [
|
||||||
"type" => get_string('datepassed', 'completion'),
|
"type" => get_string('datepassed', 'completion'),
|
||||||
"criteria" => get_string('remainingenroleduntildate', 'completion'),
|
"criteria" => get_string('remainingenroleduntildate', 'completion'),
|
||||||
"requirement" => userdate($criteria->timeend, '%d %B %Y'),
|
"requirement" => date("Y-m-d",$criteria->timeend),
|
||||||
"status" => "",
|
"status" => "",
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
|
@ -197,8 +197,8 @@ class courseinfo {
|
||||||
'context' => $contextinfo->model(),
|
'context' => $contextinfo->model(),
|
||||||
'ctxid' => $this->coursecontext->id,
|
'ctxid' => $this->coursecontext->id,
|
||||||
'timing' => $timing,
|
'timing' => $timing,
|
||||||
'startdate' => userdate($this->course->startdate,"%e %b %G"),
|
'startdate' => date("Y-m-d",$this->course->startdate,),
|
||||||
'enddate' => userdate($this->course->enddate, "%e %b %G"),
|
'enddate' => date("Y-m-d",$this->course->enddate),
|
||||||
'amteacher' => $this->amTeacher(),
|
'amteacher' => $this->amTeacher(),
|
||||||
'canselectgradables' => $this->iCanSelectGradables(),
|
'canselectgradables' => $this->iCanSelectGradables(),
|
||||||
'tag' => "Editormodel",
|
'tag' => "Editormodel",
|
||||||
|
@ -250,12 +250,11 @@ class courseinfo {
|
||||||
'context' => $contextinfo->model(),
|
'context' => $contextinfo->model(),
|
||||||
'ctxid' => $this->coursecontext->id,
|
'ctxid' => $this->coursecontext->id,
|
||||||
'timing' => $timing,
|
'timing' => $timing,
|
||||||
'startdate' => userdate($this->course->startdate,"%e %b %G"),
|
'startdate' => date("Y-m-d",$this->course->startdate),
|
||||||
'enddate' => userdate($this->course->enddate, "%e %b %G"),
|
'enddate' => date("Y-m-d",$this->course->enddate),
|
||||||
'grades' => [],
|
'grades' => [],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
if(!$usecorecompletioninfo){
|
if(!$usecorecompletioninfo){
|
||||||
$gradables = gradeinfo::list_studyitem_gradables($this->studyitem);
|
$gradables = gradeinfo::list_studyitem_gradables($this->studyitem);
|
||||||
foreach($gradables as $gi) {
|
foreach($gradables as $gi) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<XMLDB PATH="local/treestudyplan/db" VERSION="20230718" COMMENT="XMLDB file for Moodle local/treestudyplan"
|
<XMLDB PATH="local/treestudyplan/db" VERSION="20230719" COMMENT="XMLDB file for Moodle local/treestudyplan"
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:noNamespaceSchemaLocation="../../../lib/xmldb/xmldb.xsd"
|
xsi:noNamespaceSchemaLocation="../../../lib/xmldb/xmldb.xsd"
|
||||||
>
|
>
|
||||||
|
@ -65,6 +65,7 @@
|
||||||
<FIELDS>
|
<FIELDS>
|
||||||
<FIELD NAME="id" TYPE="int" LENGTH="18" NOTNULL="true" SEQUENCE="true"/>
|
<FIELD NAME="id" TYPE="int" LENGTH="18" NOTNULL="true" SEQUENCE="true"/>
|
||||||
<FIELD NAME="studyplan_id" TYPE="int" LENGTH="18" NOTNULL="true" SEQUENCE="false"/>
|
<FIELD NAME="studyplan_id" TYPE="int" LENGTH="18" NOTNULL="true" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="page_id" TYPE="int" LENGTH="20" NOTNULL="true" SEQUENCE="false"/>
|
||||||
<FIELD NAME="name" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="name" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="shortname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="shortname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="color" TYPE="char" LENGTH="12" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="color" TYPE="char" LENGTH="12" NOTNULL="false" SEQUENCE="false"/>
|
||||||
|
@ -72,7 +73,7 @@
|
||||||
</FIELDS>
|
</FIELDS>
|
||||||
<KEYS>
|
<KEYS>
|
||||||
<KEY NAME="primary" TYPE="primary" FIELDS="id"/>
|
<KEY NAME="primary" TYPE="primary" FIELDS="id"/>
|
||||||
<KEY NAME="studyplan_id-id" TYPE="foreign" FIELDS="studyplan_id" REFTABLE="local_treestudyplan" REFFIELDS="id"/>
|
<KEY NAME="page_id-id" TYPE="foreign" FIELDS="page_id" REFTABLE="local_treestudyplan_page" REFFIELDS="id"/>
|
||||||
</KEYS>
|
</KEYS>
|
||||||
</TABLE>
|
</TABLE>
|
||||||
<TABLE NAME="local_treestudyplan_item" COMMENT="Table">
|
<TABLE NAME="local_treestudyplan_item" COMMENT="Table">
|
||||||
|
@ -149,14 +150,30 @@
|
||||||
</TABLE>
|
</TABLE>
|
||||||
<TABLE NAME="local_treestudyplan_period" COMMENT="Stores timing information about the different periods in a study plan page">
|
<TABLE NAME="local_treestudyplan_period" COMMENT="Stores timing information about the different periods in a study plan page">
|
||||||
<FIELDS>
|
<FIELDS>
|
||||||
<FIELD NAME="id" TYPE="int" LENGTH="10" NOTNULL="true" SEQUENCE="true"/>
|
<FIELD NAME="id" TYPE="int" LENGTH="20" NOTNULL="true" SEQUENCE="true"/>
|
||||||
<FIELD NAME="studyplan_id" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="page_id" TYPE="int" LENGTH="20" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="period" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="period" TYPE="int" LENGTH="10" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="starttime" TYPE="int" LENGTH="20" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="startdate" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="endtime" TYPE="int" LENGTH="20" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="enddate" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="shortname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="shortname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
<FIELD NAME="fullname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
<FIELD NAME="fullname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
</FIELDS>
|
</FIELDS>
|
||||||
|
<KEYS>
|
||||||
|
<KEY NAME="primary" TYPE="primary" FIELDS="id"/>
|
||||||
|
<KEY NAME="page_id-id" TYPE="foreign" FIELDS="page_id" REFTABLE="local_treestudyplan_page" REFFIELDS="id"/>
|
||||||
|
</KEYS>
|
||||||
|
</TABLE>
|
||||||
|
<TABLE NAME="local_treestudyplan_page" COMMENT="Single page in a studyplan">
|
||||||
|
<FIELDS>
|
||||||
|
<FIELD NAME="id" TYPE="int" LENGTH="20" NOTNULL="true" SEQUENCE="true"/>
|
||||||
|
<FIELD NAME="studyplan_id" TYPE="int" LENGTH="20" NOTNULL="true" DEFAULT="0" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="periods" TYPE="int" LENGTH="10" NOTNULL="true" DEFAULT="0" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="fullname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="shortname" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="description" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="startdate" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
|
<FIELD NAME="enddate" TYPE="text" NOTNULL="false" SEQUENCE="false"/>
|
||||||
|
</FIELDS>
|
||||||
<KEYS>
|
<KEYS>
|
||||||
<KEY NAME="primary" TYPE="primary" FIELDS="id"/>
|
<KEY NAME="primary" TYPE="primary" FIELDS="id"/>
|
||||||
</KEYS>
|
</KEYS>
|
||||||
|
|
159
db/upgrade.php
159
db/upgrade.php
|
@ -219,31 +219,178 @@ function xmldb_local_treestudyplan_upgrade($oldversion) {
|
||||||
// Treestudyplan savepoint reached.
|
// Treestudyplan savepoint reached.
|
||||||
upgrade_plugin_savepoint(true, 2023063002, 'local', 'treestudyplan');
|
upgrade_plugin_savepoint(true, 2023063002, 'local', 'treestudyplan');
|
||||||
}
|
}
|
||||||
if ($oldversion < 2023071801) {
|
if ($oldversion < 2023071900) {
|
||||||
|
|
||||||
|
/******
|
||||||
|
* Prepare the studyline table to hold links to pages insted of study plans
|
||||||
|
* And drop the foreign key constraint for the studyplan_id-id relation
|
||||||
|
*/
|
||||||
|
// Define field page_id to be added to local_treestudyplan_line.
|
||||||
|
$table = new xmldb_table('local_treestudyplan_line');
|
||||||
|
$field = new xmldb_field('page_id', XMLDB_TYPE_INTEGER, '20', null, null, null, null, 'studyplan_id');
|
||||||
|
|
||||||
|
// Conditionally launch add field page_id.
|
||||||
|
if (!$dbman->field_exists($table, $field)) {
|
||||||
|
$dbman->add_field($table, $field);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Define key studyplan_id-id (foreign) to be dropped form local_treestudyplan_line.
|
||||||
|
$table = new xmldb_table('local_treestudyplan_line');
|
||||||
|
$key = new xmldb_key('studyplan_id-id', XMLDB_KEY_FOREIGN, ['studyplan_id'], 'local_treestudyplan', ['id']);
|
||||||
|
|
||||||
|
// Launch drop key studyplan_id-id.
|
||||||
|
$dbman->drop_key($table, $key);
|
||||||
|
|
||||||
|
|
||||||
|
/******
|
||||||
|
* Create the page table and copy data from treestudyplan there
|
||||||
|
* Also re-link the studylines to the newly created page instead of the studyplan
|
||||||
|
*/
|
||||||
|
// Define table local_treestudyplan_page to be created.
|
||||||
|
$table = new xmldb_table('local_treestudyplan_page');
|
||||||
|
|
||||||
|
// Adding fields to table local_treestudyplan_page.
|
||||||
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '20', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
||||||
|
$table->add_field('studyplan_id', XMLDB_TYPE_INTEGER, '20', null, XMLDB_NOTNULL, null, '0');
|
||||||
|
$table->add_field('periods', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
||||||
|
$table->add_field('fullname', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
|
$table->add_field('shortname', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
|
$table->add_field('description', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
|
$table->add_field('startdate', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
|
$table->add_field('enddate', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
|
|
||||||
|
// Adding keys to table local_treestudyplan_page.
|
||||||
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
||||||
|
|
||||||
|
// Conditionally launch create table for local_treestudyplan_page.
|
||||||
|
if (!$dbman->table_exists($table)) {
|
||||||
|
$dbman->create_table($table);
|
||||||
|
|
||||||
|
// Create a page 0 with it's data copied
|
||||||
|
$plans = $DB->get_recordset("local_treestudyplan");
|
||||||
|
foreach($plans as $p){
|
||||||
|
$o = [ "studyplan_id" => $p->id,
|
||||||
|
"periods" => $p->slots,
|
||||||
|
"fullname" => $p->name,
|
||||||
|
"shortname" => $p->shortname,
|
||||||
|
"description" => $p->description,
|
||||||
|
"startdate" => $p->startdate,
|
||||||
|
"enddate" => $p->enddate,
|
||||||
|
];
|
||||||
|
$pageid = $DB->insert_record("local_treestudyplan_page",$o);
|
||||||
|
|
||||||
|
// Now find all studyline references to the studyplan
|
||||||
|
// And update their record to reference the page instead of the plan
|
||||||
|
$lines = $DB->get_recordset("local_treestudyplan_line",["studyplan_id" => $p->id]);
|
||||||
|
foreach($lines as $l){
|
||||||
|
$lo = [
|
||||||
|
"id" => $l->id,
|
||||||
|
"page_id"=> $pageid,
|
||||||
|
];
|
||||||
|
$DB->update_record("local_treestudyplan_line",$lo);
|
||||||
|
}
|
||||||
|
$lines->close();
|
||||||
|
}
|
||||||
|
$plans->close();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finalize studyline table to drop studyplan_id field and have page id be a non-nullable and foreign key
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Changing nullability of field page_id on table local_treestudyplan_line to not null.
|
||||||
|
$table = new xmldb_table('local_treestudyplan_line');
|
||||||
|
$field = new xmldb_field('page_id', XMLDB_TYPE_INTEGER, '20', null, XMLDB_NOTNULL, null, null, 'studyplan_id');
|
||||||
|
|
||||||
|
// Launch change of nullability for field page_id.
|
||||||
|
$dbman->change_field_notnull($table, $field);
|
||||||
|
|
||||||
|
// Define field studyplan_id to be dropped from local_treestudyplan_line.
|
||||||
|
$table = new xmldb_table('local_treestudyplan_line');
|
||||||
|
$field = new xmldb_field('studyplan_id');
|
||||||
|
|
||||||
|
// Conditionally launch drop field studyplan_id.
|
||||||
|
if ($dbman->field_exists($table, $field)) {
|
||||||
|
$dbman->drop_field($table, $field);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Define key page_id-id (foreign) to be added to local_treestudyplan_line.
|
||||||
|
$table = new xmldb_table('local_treestudyplan_line');
|
||||||
|
$key = new xmldb_key('page_id-id', XMLDB_KEY_FOREIGN, ['page_id'], 'local_treestudyplan_page', ['id']);
|
||||||
|
|
||||||
|
// Launch add key page_id-id.
|
||||||
|
$dbman->add_key($table, $key);
|
||||||
|
|
||||||
|
|
||||||
|
/***
|
||||||
|
* Create Period table and make a period record for all studyplan periods
|
||||||
|
*/
|
||||||
|
|
||||||
// Define table local_treestudyplan_period to be created.
|
// Define table local_treestudyplan_period to be created.
|
||||||
$table = new xmldb_table('local_treestudyplan_period');
|
$table = new xmldb_table('local_treestudyplan_period');
|
||||||
|
|
||||||
// Adding fields to table local_treestudyplan_period.
|
// Adding fields to table local_treestudyplan_period.
|
||||||
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '20', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
||||||
$table->add_field('studyplan_id', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
$table->add_field('page_id', XMLDB_TYPE_INTEGER, '20', null, null, null, null);
|
||||||
$table->add_field('period', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
$table->add_field('period', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
||||||
$table->add_field('starttime', XMLDB_TYPE_INTEGER, '20', null, null, null, null);
|
$table->add_field('startdate', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
$table->add_field('endtime', XMLDB_TYPE_INTEGER, '20', null, null, null, null);
|
$table->add_field('enddate', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
$table->add_field('shortname', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
$table->add_field('shortname', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
$table->add_field('fullname', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
$table->add_field('fullname', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
||||||
|
|
||||||
// Adding keys to table local_treestudyplan_period.
|
// Adding keys to table local_treestudyplan_period.
|
||||||
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
||||||
|
$table->add_key('page_id-id', XMLDB_KEY_FOREIGN, ['page_id'], 'local_treestudyplan_page', ['id']);
|
||||||
|
|
||||||
|
|
||||||
// Conditionally launch create table for local_treestudyplan_period.
|
// Conditionally launch create table for local_treestudyplan_period.
|
||||||
if (!$dbman->table_exists($table)) {
|
if (!$dbman->table_exists($table)) {
|
||||||
$dbman->create_table($table);
|
$dbman->create_table($table);
|
||||||
|
|
||||||
|
// Create a period page for all slots in the study
|
||||||
|
$recordset = $DB->get_recordset("local_treestudyplan_page");
|
||||||
|
foreach($recordset as $r){
|
||||||
|
|
||||||
|
// Make a best guess for the periods based on the specified period for the plan and the
|
||||||
|
$pcount = $r->periods;
|
||||||
|
$ystart = strtotime($r->startdate)+0;
|
||||||
|
$yend = strtotime($r->enddate)+0;
|
||||||
|
if($yend < $ystart){
|
||||||
|
// If no end time is given, assume a year duration for period calculations
|
||||||
|
$ydelta = (365*24*60*60)/$pcount;
|
||||||
|
}
|
||||||
|
|
||||||
|
$ydelta = $yend - $ystart;
|
||||||
|
$ptime = $ydelta / $pcount;
|
||||||
|
|
||||||
|
for($i=0; $i < $pcount; $i++){
|
||||||
|
$pnum = $i+1;
|
||||||
|
$pstart = $ystart + ($i*$ptime);
|
||||||
|
$pend = $pstart + $ptime;
|
||||||
|
|
||||||
|
$o = [ "page_id" => $r->id,
|
||||||
|
"period" => $pnum,
|
||||||
|
"fullname" => "Period {$pnum}",
|
||||||
|
"shortname" => "P{$pnum}",
|
||||||
|
"startdate" => date("Y-m-d",$pstart),
|
||||||
|
"enddate" => date("Y-m-d",$pend)
|
||||||
|
];
|
||||||
|
$DB->insert_record("local_treestudyplan_period",$o);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$recordset->close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Treestudyplan savepoint reached.
|
// Treestudyplan savepoint reached.
|
||||||
upgrade_plugin_savepoint(true, 2023071801, 'local', 'treestudyplan');
|
upgrade_plugin_savepoint(true, 2023071900, 'local', 'treestudyplan');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
$plugin->component = 'local_treestudyplan'; // Recommended since 2.0.2 (MDL-26035). Required since 3.0 (MDL-48494)
|
$plugin->component = 'local_treestudyplan'; // Recommended since 2.0.2 (MDL-26035). Required since 3.0 (MDL-48494)
|
||||||
$plugin->version = 2023071801; // YYYYMMDDHH (year, month, day, iteration)
|
$plugin->version = 2023071900; // YYYYMMDDHH (year, month, day, iteration)
|
||||||
$plugin->requires = 2021051700; // YYYYMMDDHH (This is the release version for Moodle 3.11)
|
$plugin->requires = 2021051700; // YYYYMMDDHH (This is the release version for Moodle 3.11)
|
||||||
|
|
||||||
$plugin->dependencies = [
|
$plugin->dependencies = [
|
||||||
|
|
Reference in a new issue