-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathblock_deft.php
126 lines (112 loc) · 3.6 KB
/
block_deft.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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<?php
// This file is part of Moodle - https://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 <https://www.gnu.org/licenses/>.
use block_deft\output\main;
use block_deft\task;
/**
* Block Deft is defined here.
*
* @package block_deft
* @copyright 2022 Daniel Thies <[email protected]>
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class block_deft extends block_base {
/**
* Initializes class member variables.
*/
public function init() {
// Needed by Moodle to differentiate between blocks.
$this->title = get_string('pluginname', 'block_deft');
}
/**
* Returns the block contents.
*
* @return stdClass The block contents.
*/
public function get_content() {
if ($this->content !== null) {
return $this->content;
}
$renderable = new main($this->context, $this->config);
$renderer = $this->page->get_renderer('block_deft');
$this->content = (object) [
'text' => $renderer->render($renderable),
'footer' => '',
];
return $this->content;
}
/**
* Defines configuration data.
*
* The function is called immediately after init().
*/
public function specialization() {
// Load user defined title and make sure it's never empty.
if (empty($this->config->title)) {
$this->title = get_string('pluginname', 'block_deft');
} else {
$this->title = $this->config->title;
}
}
/**
* Allow multiple instances in a single course?
*
* @return bool True if multiple instances are allowed, false otherwise.
*/
public function instance_allow_multiple() {
return true;
}
/**
* Enables global configuration of the block in settings.php.
*
* @return bool True if the global configuration is enabled.
*/
public function has_config() {
return true;
}
/**
* Sets the applicable formats for the block.
*
* @return string[] Array of pages and permissions.
*/
public function applicable_formats() {
return [
'course' => true,
'mod' => true,
'site' => true,
];
}
/**
* Function to export the renderer data in a format that is suitable for a
* mustache template. This means:
*
* @param renderer_base $output Used to do a final render of any components that need to be rendered for export.
* @return \stdClass|array
*/
public function export_for_template($output) {
$main = new main($this->context, $this->config);
return $main->export_for_template($output);
}
/**
* Delete everything related to this instance if you have been using persistent storage other than the configdata field.
* @return boolean
*/
public function instance_delete() {
$tasks = task::get_records(['instance' => $this->context->instanceid]);
foreach ($tasks as $task) {
$task->delete();
}
}
}