-
Notifications
You must be signed in to change notification settings - Fork 0
/
block_user_favorites.php
134 lines (117 loc) · 4.09 KB
/
block_user_favorites.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
127
128
129
130
131
132
133
<?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/>.
/**
* block_user_favorites
*
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*
* @package block_user_favorites
* @copyright 26-10-2018 MFreak.nl
* @author Luuk Verhoeven
**/
use block_user_favorites\favorites;
use block_user_favorites\output\output_favorites;
/**
* Class block_user_favorites
*
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @copyright 26-10-2018 MFreak.nl
*/
class block_user_favorites extends block_base {
/**
* Set the initial properties for the block
*
* @throws coding_exception
*/
public function init(): void {
$this->title = get_string('pluginname', 'block_user_favorites');
}
/**
* Is each block of this type going to have instance-specific configuration?
* Normally, this setting is controlled by instance_allow_multiple() if multiple
* instances are allowed, then each will surely need its own configuration. However, in some
* cases it may be necessary to provide instance configuration to blocks that do not want to
* allow multiple instances. In that case, make this function return true.
* I stress again that this makes a difference ONLY if instance_allow_multiple() returns false.
*
* @return boolean
*/
public function instance_allow_config(): bool {
return true;
}
/**
* Set the applicable formats for this block to all
*
* @return array
*/
public function applicable_formats(): array {
return ['all' => true];
}
/**
* Specialization.
*
* Happens right after the initialisation is complete.
*
* @return void
* @throws coding_exception
*/
public function specialization(): void {
if (empty($this->config->title)) {
$this->title = get_string('pluginname', 'block_user_favorites');
} else {
$this->title = $this->config->title;
}
}
/**
* The content object.
*
* @return stdClass
* @throws coding_exception
* @throws moodle_exception
*/
public function get_content(): stdClass {
global $USER;
if ($this->content !== null) {
return $this->content;
}
if ((!isloggedin() || isguestuser() || !has_capability('block/user_favorites:view', $this->context))) {
$this->content = new stdClass();
$this->content->text = '';
return $this->content;
}
$this->page->requires->strings_for_js([
'javascript:yes',
'javascript:no',
'javascript:set_title',
], 'block_user_favorites');
$url = $this->page->url->out(false);
$this->page->requires->js_call_amd('block_user_favorites/favorites', 'initialise', [
[
'debugjs' => \block_user_favorites\helper::has_debugging_enabled(),
'id' => $this->instance->id,
'url' => $url,
'hash' => md5($url),
// TODO We should add a global config with salt, this way we can make sure there is no bad guy.
],
]);
$this->content = new stdClass();
$favorites = new favorites($USER->id);
$renderer = $this->page->get_renderer('block_user_favorites');
$this->content->text = $renderer->render_favorites(new output_favorites($favorites,
$url));
return $this->content;
}
}