diff --git a/lib.php b/lib.php index f63a8b4..5ae9389 100644 --- a/lib.php +++ b/lib.php @@ -23,7 +23,6 @@ * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ -use core\plugininfo\format; use mod_learningmap\cachemanager; /** @@ -50,7 +49,20 @@ */ function learningmap_add_instance($data): int { global $DB; - return $DB->insert_record("learningmap", $data); + $learningmapid = $DB->insert_record('learningmap', $data); + + $context = context_module::instance($data->coursemodule); + if (!empty($data->backgroundfile)) { + file_save_draft_area_files( + $data->backgroundfile, + $context->id, + 'mod_learningmap', + 'background', + 0, + ['subdirs' => 0, 'maxfiles' => 1] + ); + } + return $learningmapid; } /** @@ -62,6 +74,22 @@ function learningmap_add_instance($data): int { function learningmap_update_instance($data): int { global $DB; $data->id = $data->instance; + + $context = context_module::instance($data->coursemodule); + if (!empty($data->backgroundfile)) { + // Delete old background files. + $fs = get_file_storage(); + $fs->delete_area_files($context->id, 'mod_learningmap', 'background'); + file_save_draft_area_files( + $data->backgroundfile, + $context->id, + 'mod_learningmap', + 'background', + 0, + ['subdirs' => 0, 'maxfiles' => 1] + ); + } + return $DB->update_record("learningmap", $data); } @@ -74,8 +102,10 @@ function learningmap_update_instance($data): int { function learningmap_delete_instance($id): int { global $DB; + $fs = get_file_storage(); + $fs->delete_area_files($context->id, 'mod_learningmap', 'background'); + return $DB->delete_records("learningmap", ["id" => $id]); - // ToDo: Check whether intro files are automatically deleted. } /** diff --git a/mod_form.php b/mod_form.php index 39f421e..245e1e2 100644 --- a/mod_form.php +++ b/mod_form.php @@ -212,8 +212,6 @@ public function add_completion_rules(): array { public function data_preprocessing(&$defaultvalues): void { global $OUTPUT; - $draftitemid = file_get_submitted_draft_itemid('backgroundfile'); - // Initialize a new learningmap instance. if (!$this->current->instance) { // Every map gets a unique id for applying CSS. @@ -264,17 +262,20 @@ public function data_preprocessing(&$defaultvalues): void { $mapworker->process_map_objects(); $mapworker->replace_stylesheet(); $defaultvalues['svgcode'] = $mapworker->get_svgcode(); + + $draftitemid = file_get_submitted_draft_itemid('backgroundfile'); + + $defaultvalues['svgcode'] = file_prepare_draft_area( + $draftitemid, + $context->id, + 'mod_learningmap', + 'background', + 0, + ['subdirs' => 0, 'maxfiles' => 1], + $defaultvalues['svgcode'] + ); + $defaultvalues['backgroundfile'] = $draftitemid; } - $defaultvalues['svgcode'] = file_prepare_draft_area( - $draftitemid, - $context->id, - 'mod_learningmap', - 'background', - 0, - ['subdirs' => 0, 'maxfiles' => 1], - $defaultvalues['svgcode'] - ); - $defaultvalues['backgroundfile'] = $draftitemid; } /** @@ -294,16 +295,12 @@ public function data_postprocessing($data): void { $mapworker->replace_stylesheet(); $data->svgcode = $mapworker->get_svgcode(); - $data->svgcode = file_save_draft_area_files( - $data->backgroundfile, - $this->context->id, - 'mod_learningmap', - 'background', - 0, - ['subdirs' => 0, 'maxfiles' => 1], - $data->svgcode + $data->svgcode = file_rewrite_urls_to_pluginfile( + $data->svgcode, + $data->backgroundfile ); } + parent::data_postprocessing($data); } /**