3 * StatusNet, the distributed open-source microblogging tool
5 * Form for posting a direct message
9 * LICENCE: This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
24 * @author Evan Prodromou <evan@status.net>
25 * @author Sarven Capadisli <csarven@status.net>
26 * @copyright 2009 StatusNet, Inc.
27 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
28 * @link http://status.net/
31 if (!defined('STATUSNET') && !defined('LACONICA')) {
35 require_once INSTALLDIR.'/lib/form.php';
38 * Form for posting a direct message
42 * @author Evan Prodromou <evan@status.net>
43 * @author Sarven Capadisli <csarven@status.net>
44 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
45 * @link http://status.net/
50 class MessageForm extends Form
53 * User to send a direct message to
59 * Pre-filled content of the form
67 * @param HTMLOutputter $out output channel
68 * @param User $to user to send a message to
69 * @param string $content content to pre-fill
72 function __construct($out=null, $to=null, $content=null)
74 parent::__construct($out);
77 $this->content = $content;
83 * @return string ID of the form
88 return 'form_notice-direct';
94 * @return string class of the form
105 * @return string URL of the action
110 return common_local_url('newmessage');
118 function formLegend()
120 $this->out->element('legend', null, _('Send a direct notice'));
131 $user = common_current_user();
133 $mutual_users = $user->mutuallySubscribedUsers();
136 // TRANS Label entry in drop-down selection box in direct-message inbox/outbox. This is the default entry in the drop-down box, doubling as instructions and a brake against accidental submissions with the first user in the list.
137 $mutual[0] = _('Select recipient:');
139 while ($mutual_users->fetch()) {
140 if ($mutual_users->id != $user->id) {
141 $mutual[$mutual_users->id] = $mutual_users->nickname;
145 $mutual_users->free();
146 unset($mutual_users);
148 if (count($mutual) == 1) {
149 // TRANS Entry in drop-down selection box in direct-message inbox/outbox when no one is available to message.
150 $mutual[0] = _('No mutual subscribers.');
153 $this->out->dropdown('to', _('To'), $mutual, null, false,
154 ($this->to) ? $this->to->id : null);
156 $this->out->element('textarea', array('id' => 'notice_data-text',
159 'name' => 'content'),
160 ($this->content) ? $this->content : '');
162 $contentLimit = Message::maxContent();
164 if ($contentLimit > 0) {
165 $this->out->elementStart('dl', 'form_note');
166 $this->out->element('dt', null, _('Available characters'));
167 $this->out->element('dd', array('id' => 'notice_text-count'),
169 $this->out->elementEnd('dl');
179 function formActions()
181 $this->out->element('input', array('id' => 'notice_action-submit',
183 'name' => 'message_send',
185 'value' => _m('Send button for sending notice', 'Send')));