This repository has been archived by the owner on Jul 3, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathedit_form.php
84 lines (72 loc) · 2.85 KB
/
edit_form.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
<?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/>.
/**
* Form for editing Static Link block instances.
*
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*
* @package block_staticlink
* @copyright 21/05/2024 Mfreak.nl | LdesignMedia.nl - Luuk Verhoeven
* @author Nihaal Shaikh
*/
class block_staticlink_edit_form extends block_edit_form {
/**
* Specific fields for block_staticlink
* @param object $mform the form being built.
*/
protected function specific_definition($mform): void {
// Fields for editing Static Link block title and contents.
$mform->addElement('header', 'configheader', get_string('blocksettings', 'block'));
$mform->addElement('text', 'config_title', get_string('configtitle', 'block_staticlink'));
$mform->setType('config_title', PARAM_TEXT);
$mform->addElement('text', 'config_text', get_string('configcontent', 'block_staticlink'));
$mform->setType('config_text', PARAM_TEXT);
}
/**
* Load in existing data as form defaults. Usually new entry defaults are stored directly in
* form definition (new entry form); this function is used to load in data where values
* already exist and data is being edited (edit entry form).
*
* @param $defaults
*/
public function set_data($defaults): void {
$canedit = $this->block->user_can_edit();
$config = $this->block->config;
foreach (['title', 'text'] as $field) {
if (!$canedit && !empty($config->$field)) {
${$field} = $config->$field;
$defaults->{"config_$field"} = format_string(${$field}, true, $this->page->context);
unset($config->$field);
}
}
parent::set_data($defaults);
if (!isset($config)) {
$this->block->config = new stdClass();
}
if (isset($title) || isset($text)) {
$config->title = $title ?? $config->title;
$config->text = $text ?? $config->text;
}
}
/**
* Display the configuration form when block is being added to the page
*
* @return bool
*/
public static function display_form_when_adding(): bool {
return true;
}
}