forked from moodleou/moodle-report_customsql
-
Notifications
You must be signed in to change notification settings - Fork 0
/
addcategory.php
89 lines (74 loc) · 2.75 KB
/
addcategory.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Custom SQL reporting categories.
*
* Users with the report/customsql:managecategories capability can enter custom
*
* This page shows the list of categories, with edit icons, and an add new button
* if you have the report/customsql:managecategories capability.
*
* @package report_customsql
* @copyright 2013 The Open University
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(dirname(__FILE__) . '/../../config.php');
require_once(dirname(__FILE__) . '/locallib.php');
require_once(dirname(__FILE__) . '/categoryadd_form.php');
require_once($CFG->libdir . '/adminlib.php');
$context = context_system::instance();
admin_externalpage_setup('report_customsql', '', null, '/report/customsql/addcategory.php');
require_capability('report/customsql:managecategories', $context);
$relativeurl = 'addcategory.php';
// Are we editing an existing report, or creating a new one.
$id = optional_param('id', 0, PARAM_INT);
$queryparams = array();
if ($id) {
$queryparams['categoryid'] = $id;
$isadding = false;
// Editing an existing category.
$category = $DB->get_record('report_customsql_categories',
array('id' => $id), '*', MUST_EXIST);
} else {
$queryparams['categoryid'] = null;
$isadding = true;
}
$mform = new report_customsql_addcategory_form(report_customsql_url($relativeurl), $queryparams);
if ($mform->is_cancelled()) {
redirect(report_customsql_url('manage.php'));
}
if ($data = $mform->get_data()) {
if ($isadding) {
$DB->insert_record('report_customsql_categories', $data);
} else {
$updrec = new stdClass();
$updrec->id = $data->id;
$updrec->name = $data->name;
$DB->update_record('report_customsql_categories', $updrec);
}
redirect(report_customsql_url('manage.php'));
}
if ($id) {
$headstr = get_string('editcategory', 'report_customsql');
} else {
$headstr = get_string('addcategory', 'report_customsql');
}
echo $OUTPUT->header() . $OUTPUT->heading($headstr);
if ($id) {
$mform->set_data($category);
}
$mform->display();
echo $OUTPUT->footer();