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('GNUSOCIAL')) { exit(1); }
34 * Form for posting a direct message
38 * @author Evan Prodromou <evan@status.net>
39 * @author Sarven Capadisli <csarven@status.net>
40 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
41 * @link http://status.net/
45 class MessageForm extends Form
48 * User to send a direct message to
53 * Pre-filled content of the form
60 * @param HTMLOutputter $out output channel
61 * @param User $to user to send a message to
62 * @param string $content content to pre-fill
64 function __construct($out=null, $to=null, $content=null)
66 parent::__construct($out);
69 $this->content = $content;
75 * @return string ID of the form
79 return 'form_notice-direct';
85 * @return string class of the form
89 return 'form_notice ajax-notice';
95 * @return string URL of the action
99 return common_local_url('newmessage');
107 function formLegend()
109 // TRANS: Form legend for direct notice.
110 $this->out->element('legend', null, _('Send a direct notice'));
120 $user = common_current_user();
122 $mutual_users = $user->mutuallySubscribedUsers();
125 // TRANS: Label entry in drop-down selection box in direct-message inbox/outbox.
126 // TRANS: This is the default entry in the drop-down box, doubling as instructions
127 // TRANS: and a brake against accidental submissions with the first user in the list.
128 $mutual[0] = _('Select recipient:');
130 while ($mutual_users->fetch()) {
131 if ($mutual_users->id != $user->id) {
132 $mutual[$mutual_users->id] = $mutual_users->nickname;
136 $mutual_users->free();
137 unset($mutual_users);
139 if (count($mutual) == 1) {
140 // TRANS: Entry in drop-down selection box in direct-message inbox/outbox when no one is available to message.
141 $mutual[0] = _('No mutual subscribers.');
144 // TRANS: Dropdown label in direct notice form.
145 $this->out->dropdown('to', _('To'), $mutual, null, false,
146 ($this->to) ? $this->to->id : null);
148 $this->out->element('textarea', array('class' => 'notice_data-text',
151 'name' => 'content'),
152 ($this->content) ? $this->content : '');
154 $contentLimit = Message::maxContent();
156 if ($contentLimit > 0) {
157 $this->out->element('span',
158 array('class' => 'count'),
168 function formActions()
170 $this->out->element('input', array('id' => 'notice_action-submit',
172 'name' => 'message_send',
174 // TRANS: Button text for sending a direct notice.
175 'value' => _m('Send button for sending notice', 'Send')));
182 * Uses a recipe to output the form.
185 * @see Widget::show()
190 $this->elementStart('div', 'input_forms');
194 'id' => 'input_form_direct',
195 'class' => 'input_form current nonav'
201 $this->elementEnd('div');
202 $this->elementEnd('div');