forked from bostelm/moodle-mod_scheduler
-
Notifications
You must be signed in to change notification settings - Fork 0
/
message_form.php
122 lines (103 loc) · 4.43 KB
/
message_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
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
<?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/>.
/**
* Message form for invitations
*
* @package mod_scheduler
* @copyright 2016 Henning Bostelmann and others (see README.txt)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
use mod_scheduler\model\scheduler;
defined('MOODLE_INTERNAL') || die();
require_once($CFG->libdir.'/formslib.php');
/**
* Message form for invitations (using Moodle formslib)
*
* @package mod_scheduler
* @copyright 2016 Henning Bostelmann and others (see README.txt)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class scheduler_message_form extends moodleform {
/**
* @var scheduler scheduler in whose context the messages are sent
*/
protected $scheduler;
/**
* Create a new messge form
*
* @param string $action
* @param scheduler $scheduler scheduler in whose context the messages are sent
* @param object $customdata
*/
public function __construct($action, scheduler $scheduler, $customdata=null) {
$this->scheduler = $scheduler;
parent::__construct($action, $customdata);
}
/**
* Form definition
*/
protected function definition() {
$mform = $this->_form;
// Select users to sent the message to.
$checkboxes = array();
$recipients = $this->_customdata['recipients'];
foreach ($recipients as $recipient) {
$inputid = 'recipient['.$recipient->id.']';
$label = fullname($recipient);
$checkboxes[] = $mform->createElement('checkbox', $inputid, '', $label);
$mform->setDefault($inputid, true);
}
$mform->addGroup($checkboxes, 'recipients', get_string('recipients', 'scheduler'), null, false);
if (get_config('mod_scheduler', 'showemailplain')) {
$maillist = array();
foreach ($recipients as $recipient) {
$maillist[] = trim($recipient->email);
}
$maildisplay = html_writer::div(implode(', ', $maillist));
$mform->addElement('html', $maildisplay);
}
$mform->addElement('selectyesno', 'copytomyself', get_string('copytomyself', 'scheduler'));
$mform->setDefault('copytomyself', true);
$mform->addElement('text', 'subject', get_string('messagesubject', 'scheduler'), array('size' => '60'));
$mform->setType('subject', PARAM_TEXT);
$mform->addRule('subject', null, 'required');
if (isset($this->_customdata['subject'])) {
$mform->setDefault('subject', $this->_customdata['subject']);
}
$bodyedit = $mform->addElement('editor', 'body', get_string('messagebody', 'scheduler'),
array('rows' => 15, 'columns' => 60), array('collapsed' => true));
$mform->setType('body', PARAM_RAW); // Must be PARAM_RAW for rich text editor content.
if (isset($this->_customdata['body'])) {
$bodyedit->setValue(array('text' => $this->_customdata['body']));
}
$buttonarray = array();
$buttonarray[] = $mform->createElement('submit', 'submitbutton', get_string('sendmessage', 'scheduler'));
$buttonarray[] = $mform->createElement('cancel');
$mform->addGroup($buttonarray, 'buttonar', '', array(' '), false);
}
/**
* Form validation
*
* @param array $data array of ("fieldname"=>value) of submitted data
* @param array $files array of uploaded files "element_name"=>tmp_file_path
* @return array of "element_name"=>"error_description" if there are errors,
* or an empty array if everything is OK (true allowed for backwards compatibility too).
*/
public function validation($data, $files) {
$errors = parent::validation($data, $files);
return $errors;
}
}