Bugfix in studyplan period creator
This commit is contained in:
parent
9bd0f2002e
commit
cae51717a9
5 changed files with 16 additions and 6 deletions
2
amd/build/studyplan-editor-components.min.js
vendored
2
amd/build/studyplan-editor-components.min.js
vendored
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -1455,7 +1455,7 @@ export default {
|
||||||
if(modalresponse){
|
if(modalresponse){
|
||||||
call([{
|
call([{
|
||||||
methodname: 'local_treestudyplan_delete_studyplan',
|
methodname: 'local_treestudyplan_delete_studyplan',
|
||||||
args: { 'id': studyplan.id, }
|
args: { 'id': studyplan.id, force: true}
|
||||||
}])[0].done(function(response){
|
}])[0].done(function(response){
|
||||||
if(response.success == true){
|
if(response.success == true){
|
||||||
self.$root.$emit("studyplanRemoved",studyplan);
|
self.$root.$emit("studyplanRemoved",studyplan);
|
||||||
|
|
|
@ -195,7 +195,7 @@ class studyplan {
|
||||||
// TODO: Remove this when proper page management is implemented
|
// TODO: Remove this when proper page management is implemented
|
||||||
if(!$bare){
|
if(!$bare){
|
||||||
|
|
||||||
$pageaddable = ['name','shortname','description',];
|
$pageaddable = ['name','shortname','description','periods','startdate','enddate'];
|
||||||
$pageinfo = ['studyplan_id' => $id];
|
$pageinfo = ['studyplan_id' => $id];
|
||||||
foreach($pageaddable as $f){
|
foreach($pageaddable as $f){
|
||||||
if(array_key_exists($f,$fields)){
|
if(array_key_exists($f,$fields)){
|
||||||
|
@ -217,7 +217,7 @@ class studyplan {
|
||||||
|
|
||||||
public function edit($fields){
|
public function edit($fields){
|
||||||
global $DB;
|
global $DB;
|
||||||
$editable = ['name','shortname','description','idnumber','context_id','periods','startdate','enddate','aggregation','aggregation_config'];
|
$editable = ['name','shortname','description','idnumber','context_id','aggregation','aggregation_config'];
|
||||||
$info = ['id' => $this->id,];
|
$info = ['id' => $this->id,];
|
||||||
foreach($editable as $f){
|
foreach($editable as $f){
|
||||||
if(array_key_exists($f,$fields)){
|
if(array_key_exists($f,$fields)){
|
||||||
|
@ -240,7 +240,7 @@ class studyplan {
|
||||||
if(count($this->pages()) == 1){
|
if(count($this->pages()) == 1){
|
||||||
// update the info to the page as well
|
// update the info to the page as well
|
||||||
$page = $this->pages()[0];
|
$page = $this->pages()[0];
|
||||||
$pageeditable = ['name','shortname','description'];
|
$pageeditable = ['name','shortname','description','periods','startdate','enddate'];
|
||||||
$pageinfo = [];
|
$pageinfo = [];
|
||||||
foreach($pageeditable as $f){
|
foreach($pageeditable as $f){
|
||||||
if(array_key_exists($f,$fields)){
|
if(array_key_exists($f,$fields)){
|
||||||
|
|
|
@ -145,6 +145,12 @@ class studyplanpage {
|
||||||
$info[$f] = $fields[$f];
|
$info[$f] = $fields[$f];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(!isset($addable['periods'])){
|
||||||
|
$addable['periods'] = 4;
|
||||||
|
} else if($addable['periods'] < 1){
|
||||||
|
$addable['periods'] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
$id = $DB->insert_record(self::TABLE, $info);
|
$id = $DB->insert_record(self::TABLE, $info);
|
||||||
return self::findById($id); // make sure the new page is immediately cached
|
return self::findById($id); // make sure the new page is immediately cached
|
||||||
}
|
}
|
||||||
|
@ -158,6 +164,10 @@ class studyplanpage {
|
||||||
$info[$f] = $fields[$f];
|
$info[$f] = $fields[$f];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(isset($info['periods']) && $info['periods'] < 1){
|
||||||
|
$info['periods'] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
$DB->update_record(self::TABLE, $info);
|
$DB->update_record(self::TABLE, $info);
|
||||||
//reload record after edit
|
//reload record after edit
|
||||||
$this->r = $DB->get_record(self::TABLE,['id' => $this->id],"*",MUST_EXIST);
|
$this->r = $DB->get_record(self::TABLE,['id' => $this->id],"*",MUST_EXIST);
|
||||||
|
|
Reference in a new issue