3 * StatusNet, the distributed open-source microblogging tool
5 * Form for editing an application
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 Zach Copley <zach@status.net>
25 * @copyright 2009 StatusNet, Inc.
26 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
27 * @link http://status.net/
30 if (!defined('STATUSNET') && !defined('LACONICA')) {
34 require_once INSTALLDIR . '/lib/form.php';
37 * Form for editing an application
41 * @author Zach Copley <zach@status.net>
42 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
43 * @link http://status.net/
47 class ApplicationEditForm extends Form
50 * group for user to join
53 var $application = null;
58 * @param Action $out output channel
59 * @param User_group $group group to join
62 function __construct($out=null, $application=null)
64 parent::__construct($out);
66 $this->application = $application;
72 * @return string ID of the form
77 if ($this->application) {
78 return 'form_application_edit-' . $this->application->id;
80 return 'form_application_add';
85 * HTTP method used to submit the form
87 * For image data we need to send multipart/form-data
88 * so we set that here too
90 * @return string the method to use for submitting
95 $this->enctype = 'multipart/form-data';
102 * @return string of the form class
107 return 'form_settings';
113 * @return string URL of the action
118 $cur = common_current_user();
120 if (!empty($this->application)) {
121 return common_local_url('editapplication',
122 array('id' => $this->application->id));
124 return common_local_url('newapplication');
134 function formLegend()
136 // TRANS: Form legend.
137 $this->out->element('legend', null, _('Edit application'));
141 * Data elements of the form
148 if ($this->application) {
149 $id = $this->application->id;
150 $icon = $this->application->icon;
151 $name = $this->application->name;
152 $description = $this->application->description;
153 $source_url = $this->application->source_url;
154 $organization = $this->application->organization;
155 $homepage = $this->application->homepage;
156 $callback_url = $this->application->callback_url;
157 $this->type = $this->application->type;
158 $this->access_type = $this->application->access_type;
169 $this->access_type = '';
172 $this->out->elementStart('ul', 'form_data');
174 $this->out->elementStart('li', array('id' => 'application_icon'));
177 $this->out->element('img', array('src' => $icon));
180 $this->out->element('label', array('for' => 'app_icon'),
181 // TRANS: Form input field label for application icon.
183 $this->out->element('input', array('name' => 'app_icon',
185 'id' => 'app_icon'));
186 // TRANS: Form guide.
187 $this->out->element('p', 'form_guide', _('Icon for this application'));
188 $this->out->element('input', array('name' => 'MAX_FILE_SIZE',
190 'id' => 'MAX_FILE_SIZE',
191 'value' => ImageFile::maxFileSizeInt()));
192 $this->out->elementEnd('li');
194 $this->out->elementStart('li');
196 $this->out->hidden('application_id', $id);
198 // TRANS: Form input field label for application name.
199 $this->out->input('name', _('Name'),
200 ($this->out->arg('name')) ? $this->out->arg('name') : $name);
202 $this->out->elementEnd('li');
204 $this->out->elementStart('li');
206 $maxDesc = Oauth_application::maxDesc();
208 // TRANS: Form input field instructions.
209 $descInstr = sprintf(_('Describe your application in %d characters'),
212 // TRANS: Form input field instructions.
213 $descInstr = _('Describe your application');
215 // TRANS: Form input field label.
216 $this->out->textarea('description', _('Description'),
217 ($this->out->arg('description')) ? $this->out->arg('description') : $description,
220 $this->out->elementEnd('li');
222 $this->out->elementStart('li');
223 // TRANS: Form input field instructions.
224 $instruction = _('URL of the homepage of this application');
225 // TRANS: Form input field label.
226 $this->out->input('source_url', _('Source URL'),
227 ($this->out->arg('source_url')) ? $this->out->arg('source_url') : $source_url,
229 $this->out->elementEnd('li');
231 $this->out->elementStart('li');
232 // TRANS: Form input field instructions.
233 $instruction = _('Organization responsible for this application');
234 // TRANS: Form input field label.
235 $this->out->input('organization', _('Organization'),
236 ($this->out->arg('organization')) ? $this->out->arg('organization') : $organization,
238 $this->out->elementEnd('li');
240 $this->out->elementStart('li');
241 // TRANS: Form input field instructions.
242 $instruction = _('URL for the homepage of the organization');
243 // TRANS: Form input field label.
244 $this->out->input('homepage', _('Homepage'),
245 ($this->out->arg('homepage')) ? $this->out->arg('homepage') : $homepage,
247 $this->out->elementEnd('li');
249 $this->out->elementStart('li');
250 // TRANS: Form input field instructions.
251 $instruction = _('URL to redirect to after authentication');
252 // TRANS: Form input field label.
253 $this->out->input('callback_url', ('Callback URL'),
254 ($this->out->arg('callback_url')) ? $this->out->arg('callback_url') : $callback_url,
256 $this->out->elementEnd('li');
258 $this->out->elementStart('li', array('id' => 'application_types'));
260 $attrs = array('name' => 'app_type',
262 'id' => 'app_type-browser',
264 'value' => Oauth_application::$browser);
266 // Default to Browser
268 if ($this->application->type == Oauth_application::$browser
269 || empty($this->application->type)) {
270 $attrs['checked'] = 'checked';
273 $this->out->element('input', $attrs);
275 $this->out->element('label', array('for' => 'app_type-browser',
277 // TRANS: Radio button label for application type
280 $attrs = array('name' => 'app_type',
282 'id' => 'app_type-dekstop',
284 'value' => Oauth_application::$desktop);
286 if ($this->application->type == Oauth_application::$desktop) {
287 $attrs['checked'] = 'checked';
290 $this->out->element('input', $attrs);
292 $this->out->element('label', array('for' => 'app_type-desktop',
294 // TRANS: Radio button label for application type
296 // TRANS: Form guide.
297 $this->out->element('p', 'form_guide', _('Type of application, browser or desktop'));
298 $this->out->elementEnd('li');
300 $this->out->elementStart('li', array('id' => 'default_access_types'));
302 $attrs = array('name' => 'default_access_type',
304 'id' => 'default_access_type-r',
308 // default to read-only access
310 if ($this->application->access_type & Oauth_application::$readAccess
311 || empty($this->application->access_type)) {
312 $attrs['checked'] = 'checked';
315 $this->out->element('input', $attrs);
317 $this->out->element('label', array('for' => 'default_access_type-ro',
319 // TRANS: Radio button label for access type.
322 $attrs = array('name' => 'default_access_type',
324 'id' => 'default_access_type-rw',
328 if ($this->application->access_type & Oauth_application::$readAccess
329 && $this->application->access_type & Oauth_application::$writeAccess
331 $attrs['checked'] = 'checked';
334 $this->out->element('input', $attrs);
336 $this->out->element('label', array('for' => 'default_access_type-rw',
338 // TRANS: Radio button label for access type.
340 // TRANS: Form guide.
341 $this->out->element('p', 'form_guide', _('Default access for this application: read-only, or read-write'));
343 $this->out->elementEnd('li');
345 $this->out->elementEnd('ul');
354 function formActions()
356 // TRANS: Button label
357 $this->out->submit('cancel', _m('BUTTON','Cancel'), 'submit form_action-primary',
358 // TRANS: Submit button title
359 'cancel', _('Cancel'));
360 // TRANS: Button label
361 $this->out->submit('save', _m('BUTTON','Save'), 'submit form_action-secondary',
362 // TRANS: Submit button title