MDL-68963 qtype_calculatedmulti: show question content inline
[moodle.git] / contentbank / edit.php
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
17 /**
18  * Create or update contents through the specific content type editor
19  *
20  * @package    core_contentbank
21  * @copyright  2020 Victor Deniz <victor@moodle.com>
22  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 require('../config.php');
27 require_login();
29 $contextid = required_param('contextid', PARAM_INT);
30 $pluginname = required_param('plugin', PARAM_PLUGIN);
31 $id = optional_param('id', null, PARAM_INT);
32 $context = context::instance_by_id($contextid, MUST_EXIST);
33 require_capability('moodle/contentbank:access', $context);
35 $returnurl = new \moodle_url('/contentbank/view.php', ['id' => $id]);
37 if (!empty($id)) {
38     $record = $DB->get_record('contentbank_content', ['id' => $id], '*', MUST_EXIST);
39     $contentclass = "$record->contenttype\\content";
40     $content = new $contentclass($record);
41     // Set the heading title.
42     $heading = $content->get_name();
43     // The content type of the content overwrites the pluginname param value.
44     $contenttypename = $content->get_content_type();
45 } else {
46     $contenttypename = "contenttype_$pluginname";
47     $heading = get_string('addinganew', 'moodle', get_string('description', $contenttypename));
48 }
50 // Check plugin is enabled.
51 $plugin = core_plugin_manager::instance()->get_plugin_info($contenttypename);
52 if (!$plugin || !$plugin->is_enabled()) {
53     print_error('unsupported', 'core_contentbank', $returnurl);
54 }
56 // Create content type instance.
57 $contenttypeclass = "$contenttypename\\contenttype";
58 if (class_exists($contenttypeclass)) {
59     $contenttype = new $contenttypeclass($context);
60 } else {
61     print_error('unsupported', 'core_contentbank', $returnurl);
62 }
64 // Checks the user can edit this content type.
65 if (!$contenttype->can_edit()) {
66     print_error('contenttypenoedit', 'core_contentbank', $returnurl, $contenttype->get_plugin_name());
67 }
69 $values = [
70     'contextid' => $contextid,
71     'plugin' => $pluginname,
72     'id' => $id
73 ];
75 $title = get_string('contentbank');
76 \core_contentbank\helper::get_page_ready($context, $title, true);
77 if ($PAGE->course) {
78     require_login($PAGE->course->id);
79 }
81 $PAGE->set_url(new \moodle_url('/contentbank/edit.php', $values));
82 $PAGE->set_context($context);
83 $PAGE->navbar->add(get_string('edit'));
84 $PAGE->set_title($title);
86 $PAGE->set_heading($heading);
88 // Instantiate the content type form.
89 $editorclass = "$contenttypename\\form\\editor";
90 if (!class_exists($editorclass)) {
91     print_error('noformdesc');
92 }
94 $editorform = new $editorclass(null, $values);
96 if ($editorform->is_cancelled()) {
97     if (empty($id)) {
98         $returnurl = new \moodle_url('/contentbank/index.php', ['contextid' => $context->id]);
99     }
100     redirect($returnurl);
101 } else if ($data = $editorform->get_data()) {
102     $id = $editorform->save_content($data);
103     // Just in case we've created a new content.
104     $returnurl->param('id', $id);
105     redirect($returnurl);
108 echo $OUTPUT->header();
109 $editorform->display();
110 echo $OUTPUT->footer();