forked from brickfield/moodle-block_accessibility
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathedit_form.php
84 lines (72 loc) · 3.6 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/>.
class block_accessibility_edit_form extends block_edit_form {
const CNF_AUTOSAVE = 'config_autosave';
const CNF_ATBAR = 'config_showATbar';
const CNF_FG = 'config_fg';
const CNF_BG = 'config_bg';
const RE_COLOUR = '/^#[a-f0-9]{6}$/i';
protected function specific_definition($mform) {
// Load default colours.
global $CFG;
require_once($CFG->dirroot . '/blocks/accessibility/defaults.php');
// Allow ATbar.
$mform->addElement('advcheckbox', self::CNF_ATBAR,
get_string(self::CNF_ATBAR, 'block_accessibility'),
get_string(self::CNF_ATBAR . '_checkbox', 'block_accessibility'),
null,
array(0, 1)
);
$mform->setDefault(self::CNF_ATBAR, 1);
$mform->setType(self::CNF_ATBAR, PARAM_INT);
$mform->addHelpButton(self::CNF_ATBAR, self::CNF_ATBAR, 'block_accessibility');
// Colour schemes.
for ($i = 2; $i < 5; $i++) { // This is how many declarations we defined in defaults.php.
// Get previously saved configuration.
$form = $this->block->config; // Or cast it to (array) and get properties like with [].
$fg = str_replace('config_', '', self::CNF_FG);
$bg = str_replace('config_', '', self::CNF_BG);
$fgcolour = isset($form->{$fg . $i}) ? $form->{$fg . $i} : $defaults['fg' . $i];
$bgcolour = isset($form->{$bg . $i}) ? $form->{$bg . $i} : $defaults['bg' . $i];
// Display scheme example and identifier number of a scheme.
$mform->addElement('html', '
<div class="fitem" style="padding:10px 0 8px">
<div class="fitemtitle"></div>
<div class="felement">
<span style="padding:2px 8px; color:' . $fgcolour . '; border:1px solid ' . $fgcolour . '; background:' .
$bgcolour . ' !important">A</span>
Colour scheme #' . $i . '
</div>
</div>');
// Foreground colour.
$id = self::CNF_FG . $i;
$mform->addElement('text', $id, get_string(self::CNF_FG, 'block_accessibility'));
$mform->setDefault($id, $defaults['fg' . $i]);
$mform->setType($id, PARAM_TEXT);
$mform->addHelpButton($id, self::CNF_FG, 'block_accessibility');
$mform->addRule($id, get_string('color_input_error', 'block_accessibility'), 'regex', self::RE_COLOUR, 'server', false,
false);
// Background colour.
$id = self::CNF_BG . $i;
$mform->addElement('text', $id, get_string(self::CNF_BG, 'block_accessibility'));
$mform->setDefault($id, $defaults['bg' . $i]);
$mform->setType($id, PARAM_TEXT);
$mform->addHelpButton($id, self::CNF_BG, 'block_accessibility');
$mform->addRule($id, get_string('color_input_error', 'block_accessibility'), 'regex', self::RE_COLOUR, 'server', false,
false);
}
}
}