MDL-52195 tool_lp: New page that lists the plans of a template
[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 if (!empty($id)) {
32     // Always use the context from the framework when it exists.
33     $template = new \tool_lp\template($id);
34     $context = $template->get_context();
35 } else {
36     $context = context::instance_by_id($pagecontextid);
37 }
39 // We check that we have the permission to edit this framework, in its own context.
40 require_login();
41 require_capability('tool/lp:templatemanage', $context);
43 // We keep the original context in the URLs, so that we remain in the same context.
44 $url = new moodle_url("/admin/tool/lp/edittemplate.php", array('id' => $id, 'pagecontextid' => $pagecontextid));
45 $templatesurl = new moodle_url('/admin/tool/lp/learningplans.php', array('pagecontextid' => $pagecontextid));
46 $formurl = new moodle_url("/admin/tool/lp/edittemplate.php", array('pagecontextid' => $pagecontextid));
48 $title = get_string('templates', 'tool_lp');
49 if (empty($id)) {
50     $pagetitle = get_string('addnewtemplate', 'tool_lp');
51 } else {
52     $pagetitle = get_string('edittemplate', 'tool_lp');
53 }
54 // Set up the page.
55 $PAGE->navigation->override_active_url($templatesurl);
56 $PAGE->set_context(context::instance_by_id($pagecontextid));
57 $PAGE->set_pagelayout('admin');
58 $PAGE->set_url($url);
59 $PAGE->set_title($title);
60 $PAGE->set_heading($title);
61 $output = $PAGE->get_renderer('tool_lp');
63 $form = new \tool_lp\form\template($formurl->out(false), array('id' => $id, 'context' => $context));
65 if ($form->is_cancelled()) {
66     redirect($templatesurl);
67 }
69 echo $output->header();
70 echo $output->heading($pagetitle);
72 $data = $form->get_data();
73 if ($data) {
74     // Save the changes and continue back to the manage page.
75     // Massage the editor data.
76     $data->descriptionformat = $data->description['format'];
77     $data->description = $data->description['text'];
78     if (empty($data->id)) {
79         // Create new template.
80         require_sesskey();
81         $data->contextid = $context->id;
82         \tool_lp\api::create_template($data);
83         echo $output->notification(get_string('templatecreated', 'tool_lp'), 'notifysuccess');
84         echo $output->continue_button($templatesurl);
85     } else {
86         require_sesskey();
87         \tool_lp\api::update_template($data);
88         echo $output->notification(get_string('templateupdated', 'tool_lp'), 'notifysuccess');
89         echo $output->continue_button($templatesurl);
90     }
91 } else {
92     $form->display();
93 }
96 echo $output->footer();