MDL-52195 tool_lp: Normalise the navigation in templates
[moodle.git] / admin / tool / lp / edittemplate.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  * This page lets users to manage site wide learning plan templates.
19  *
20  * @package    tool_lp
21  * @copyright  2015 Damyon Wiese
22  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 require_once(__DIR__ . '/../../../config.php');
26 require_once($CFG->libdir.'/adminlib.php');
28 $id = optional_param('id', 0, PARAM_INT);
29 $pagecontextid = required_param('pagecontextid', PARAM_INT);  // Reference to where we can from.
31 $template = null;
32 if (!empty($id)) {
33     // Always use the context from the framework when it exists.
34     $template = new \tool_lp\template($id);
35     $context = $template->get_context();
36 } else {
37     $context = context::instance_by_id($pagecontextid);
38 }
40 // We check that we have the permission to edit this framework, in its own context.
41 require_login(0, false);
42 require_capability('tool/lp:templatemanage', $context);
44 // We keep the original context in the URLs, so that we remain in the same context.
45 $url = new moodle_url("/admin/tool/lp/edittemplate.php", array('id' => $id, 'pagecontextid' => $pagecontextid));
46 $formurl = new moodle_url("/admin/tool/lp/edittemplate.php", array('pagecontextid' => $pagecontextid));
48 if (empty($id)) {
49     $pagetitle = get_string('addnewtemplate', 'tool_lp');
50     list($title, $subtitle, $returnurl) = \tool_lp\page_helper::setup_for_template($pagecontextid, $url, null, $pagetitle);
51 } else {
52     $template = \tool_lp\api::read_template($id);
53     $pagetitle = get_string('edittemplate', 'tool_lp');
54     list($title, $subtitle, $returnurl) = \tool_lp\page_helper::setup_for_template($pagecontextid, $url, $template, $pagetitle);
55 }
57 $form = new \tool_lp\form\template($formurl->out(false), array('template' => $template, 'context' => $context));
58 if ($form->is_cancelled()) {
59     redirect($returnurl);
60 }
62 $output = $PAGE->get_renderer('tool_lp');
63 echo $output->header();
64 echo $output->heading($title);
65 if (!empty($subtitle)) {
66     echo $output->heading($subtitle, 3);
67 }
69 $data = $form->get_data();
70 if ($data) {
71     // Save the changes and continue back to the manage page.
72     // Massage the editor data.
73     $data->descriptionformat = $data->description['format'];
74     $data->description = $data->description['text'];
75     if (empty($data->id)) {
76         // Create new template.
77         require_sesskey();
78         $data->contextid = $context->id;
79         \tool_lp\api::create_template($data);
80         echo $output->notification(get_string('templatecreated', 'tool_lp'), 'notifysuccess');
81         echo $output->continue_button($returnurl);
82     } else {
83         require_sesskey();
84         \tool_lp\api::update_template($data);
85         echo $output->notification(get_string('templateupdated', 'tool_lp'), 'notifysuccess');
86         echo $output->continue_button($returnurl);
87     }
88 } else {
89     $form->display();
90 }
93 echo $output->footer();