-
Notifications
You must be signed in to change notification settings - Fork 100
/
manage.php
68 lines (57 loc) · 3.01 KB
/
manage.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
<?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 report categories.
*
* Users with the report/customsql:managequeries capability can create and edit
* the custom categories.
*
* This page shows the list of categories, with edit icons, and an add new button
* if you have the report/customsql:managequeries 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($CFG->libdir . '/adminlib.php');
admin_externalpage_setup('report_customsql', '', null, '/report/customsql/manage.php');
$context = context_system::instance();
require_capability('report/customsql:managecategories', $context);
$PAGE->navbar->add(get_string('managecategories', 'report_customsql'), report_customsql_url('manage.php'));
echo $OUTPUT->header() . $OUTPUT->heading(get_string('managecategories', 'report_customsql'));
$categories = $DB->get_records('report_customsql_categories', null, 'name ASC');
echo html_writer::tag('p', get_string('addcategorydesc', 'report_customsql'));
if (!empty($categories)) {
foreach ($categories as $category) {
echo html_writer::start_tag('div');
echo ' ' . html_writer::link(report_customsql_url('category.php', ['id' => $category->id]),
format_string($category->name) . ' ', ['class' => 'report_customsql']) .
html_writer::tag('a', $OUTPUT->pix_icon('t/edit', get_string('edit')),
['title' => get_string('editcategoryx', 'report_customsql', format_string($category->name)),
'href' => report_customsql_url('addcategory.php?id=' . $category->id)]);
if ($category->id != 1 && !$DB->record_exists('report_customsql_queries', ['categoryid' => $category->id])) {
echo ' ' . html_writer::tag('a', $OUTPUT->pix_icon('t/delete', get_string('delete')),
['title' => get_string('deletecategoryx', 'report_customsql', format_string($category->name)),
'href' => report_customsql_url('categorydelete.php?id=' . $category->id)]);
}
echo html_writer::end_tag('div');
}
}
echo $OUTPUT->single_button(report_customsql_url('addcategory.php'),
get_string('addcategory', 'report_customsql'));
echo $OUTPUT->footer();