forked from PukunuiAustralia/moodle-courseformat_grid
-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathadmin_setting_markdown.php
108 lines (96 loc) · 3.36 KB
/
admin_setting_markdown.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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?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/>.
/**
* Grid Format.
*
* @package format_grid
* @copyright © 2022 G J Barnard in respect to modifications of standard topics format.
* @author G J Barnard - {@link https://about.me/gjbarnard} and
* {@link https://moodle.org/user/profile.php?id=442195}
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace format_grid;
use admin_setting;
use stdClass;
/**
* Setting that displays markdown files. Based on admin_setting_description in adminlib.php.
*
* @copyright © 2022-onwards G J Barnard.
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later.
*/
class admin_setting_markdown extends admin_setting {
/** @var string Filename */
private $filename;
/**
* Not a setting, just markup.
*
* @param string $name Setting name.
* @param string $visiblename Setting name on the device.
* @param string $description Setting description on the device.
* @param string $filename The file to show.
*/
public function __construct($name, $visiblename, $description, $filename) {
$this->nosave = true;
$this->filename = $filename;
parent::__construct($name, $visiblename, $description, '');
}
/**
* Always returns true.
*
* @return bool Always returns true.
*/
public function get_setting() {
return true;
}
/**
* Always returns true.
*
* @return bool Always returns true.
*/
public function get_defaultsetting() {
return true;
}
/**
* Never write settings
*
* @param mixed $data Gets converted to str for comparison against yes value.
* @return string Always returns an empty string.
*/
public function write_setting($data) {
// Do not write any setting.
return '';
}
/**
* Returns an HTML string
*
* @param string $data
* @param string $query
* @return string Returns an HTML string
*/
public function output_html($data, $query = '') {
global $CFG, $OUTPUT;
$context = new stdClass();
$context->title = $this->visiblename;
$context->description = $this->description;
if (file_exists("{$CFG->dirroot}/course/format/grid/{$this->filename}")) {
$filecontents = file_get_contents($CFG->dirroot . '/course/format/grid/' . $this->filename);
} else {
$filecontents = 'Grid format admin_setting_markdown -> file not found: ' . $this->filename;
}
$context->markdown = format_text($filecontents, FORMAT_MARKDOWN);
return $OUTPUT->render_from_template('format_grid/grid_admin_setting_markdown', $context);
}
}