2011-03-09 07:33:26 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* StatusNet - the distributed open-source microblogging tool
|
|
|
|
* Copyright (C) 2011, StatusNet, Inc.
|
|
|
|
*
|
|
|
|
* Form for entering an event
|
2011-04-07 13:01:40 +01:00
|
|
|
*
|
2011-03-09 07:33:26 +00:00
|
|
|
* PHP version 5
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @category Event
|
|
|
|
* @package StatusNet
|
|
|
|
* @author Evan Prodromou <evan@status.net>
|
|
|
|
* @copyright 2011 StatusNet, Inc.
|
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
|
|
|
* @link http://status.net/
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (!defined('STATUSNET')) {
|
|
|
|
// This check helps protect against security problems;
|
|
|
|
// your code file can't be executed directly from the web.
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Form for adding an event
|
|
|
|
*
|
|
|
|
* @category Event
|
|
|
|
* @package StatusNet
|
|
|
|
* @author Evan Prodromou <evan@status.net>
|
|
|
|
* @copyright 2011 StatusNet, Inc.
|
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
|
|
|
* @link http://status.net/
|
|
|
|
*/
|
|
|
|
class EventForm extends Form
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* ID of the form
|
|
|
|
*
|
|
|
|
* @return int ID of the form
|
|
|
|
*/
|
|
|
|
function id()
|
|
|
|
{
|
|
|
|
return 'form_new_event';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* class of the form
|
|
|
|
*
|
|
|
|
* @return string class of the form
|
|
|
|
*/
|
|
|
|
function formClass()
|
|
|
|
{
|
2011-03-09 07:48:14 +00:00
|
|
|
return 'form_settings ajax-notice';
|
2011-03-09 07:33:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Action of the form
|
|
|
|
*
|
|
|
|
* @return string URL of the action
|
|
|
|
*/
|
|
|
|
function action()
|
|
|
|
{
|
|
|
|
return common_local_url('newevent');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Data elements of the form
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function formData()
|
|
|
|
{
|
2011-04-18 02:38:09 +01:00
|
|
|
$this->out->elementStart('fieldset', array('id' => 'new_event_data'));
|
2011-08-02 09:17:56 +01:00
|
|
|
|
|
|
|
// Passing in the URL of the Ajax action that the .js for this form hits
|
|
|
|
// when selecting event start and end times. JavaScript will try to
|
|
|
|
// use a relative path, unless explicitely told where an action is,
|
|
|
|
// and that's a bit difficult to calculate since the event form is on
|
|
|
|
// so many pages with different paths. It might be worth solving this
|
|
|
|
// globally by putting the base site path in the Identifier-URL meta tag
|
|
|
|
// or something similar, so it would be easy to calculate the exact path
|
|
|
|
// for actions and other things in JavaScripts. -z
|
|
|
|
$this->out->hidden('timelist_action_url', common_local_url('timelist'));
|
|
|
|
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->out->elementStart('ul', 'form_data');
|
|
|
|
|
|
|
|
$this->li();
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->input('event-title',
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field label on event form.
|
2011-03-30 21:30:23 +01:00
|
|
|
_m('LABEL','Title'),
|
2011-03-09 07:33:26 +00:00
|
|
|
null,
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field title on event form.
|
2011-04-18 00:32:52 +01:00
|
|
|
_m('Title of the event.'),
|
2014-04-06 10:27:41 +01:00
|
|
|
'title',
|
|
|
|
true); // HTML5 "required" attribute
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
|
|
|
$this->li();
|
2011-08-02 09:17:56 +01:00
|
|
|
|
2011-08-23 23:21:55 +01:00
|
|
|
$today = new DateTime('now');
|
2011-08-02 09:17:56 +01:00
|
|
|
$today->setTimezone(new DateTimeZone(common_timezone()));
|
|
|
|
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->input('event-startdate',
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field label on event form.
|
2011-03-30 21:30:23 +01:00
|
|
|
_m('LABEL','Start date'),
|
2011-08-02 09:17:56 +01:00
|
|
|
$today->format('m/d/Y'),
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field title on event form.
|
2011-04-18 00:32:52 +01:00
|
|
|
_m('Date the event starts.'),
|
|
|
|
'startdate');
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
|
|
|
$this->li();
|
2011-08-02 09:17:56 +01:00
|
|
|
|
2011-09-08 08:42:13 +01:00
|
|
|
$times = EventTimeList::getTimes($today->format('m/d/Y 12:00') . ' am ' . $today->format('T'));
|
2011-09-17 21:27:14 +01:00
|
|
|
$start = EventTimeList::nearestHalfHour($today->format('c'));
|
2011-09-08 08:42:13 +01:00
|
|
|
$start->setTimezone(new DateTimeZone(common_timezone()));
|
2011-08-02 09:17:56 +01:00
|
|
|
|
|
|
|
$this->out->dropdown(
|
|
|
|
'event-starttime',
|
|
|
|
// TRANS: Field label on event form.
|
|
|
|
_m('LABEL','Start time'),
|
|
|
|
$times,
|
2011-08-23 23:43:14 +01:00
|
|
|
// TRANS: Field title on event form. %s is the abbreviated timezone
|
2011-09-08 08:42:13 +01:00
|
|
|
sprintf(_m("Time the event starts (%s)."), $today->format('T')),
|
2011-08-02 09:17:56 +01:00
|
|
|
false,
|
2011-09-08 08:42:13 +01:00
|
|
|
$start->format('g:ia')
|
2011-08-02 09:17:56 +01:00
|
|
|
);
|
|
|
|
|
2011-09-08 08:42:13 +01:00
|
|
|
// Need to keep JavaScript TZ in sync with PHP TZ
|
|
|
|
$this->out->hidden('tz', $today->format('T'));
|
|
|
|
$this->out->hidden('now', $today->format('F d, Y H:i:s T'));
|
|
|
|
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
|
|
|
$this->li();
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->input('event-enddate',
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field label on event form.
|
2011-03-30 21:30:23 +01:00
|
|
|
_m('LABEL','End date'),
|
2011-08-02 09:17:56 +01:00
|
|
|
$today->format('m/d/Y'),
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field title on event form.
|
2011-04-18 00:32:52 +01:00
|
|
|
_m('Date the event ends.'),
|
|
|
|
'enddate');
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
|
|
|
$this->li();
|
2011-08-02 09:17:56 +01:00
|
|
|
|
|
|
|
$this->out->dropdown(
|
|
|
|
'event-endtime',
|
|
|
|
// TRANS: Field label on event form.
|
|
|
|
_m('LABEL','End time'),
|
2011-09-17 21:27:14 +01:00
|
|
|
EventTimeList::getTimes($start->format('c'), true),
|
2011-08-02 09:17:56 +01:00
|
|
|
// TRANS: Field title on event form.
|
|
|
|
_m('Time the event ends.'),
|
|
|
|
false,
|
|
|
|
null
|
|
|
|
);
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
|
|
|
$this->li();
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->input('event-location',
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field label on event form.
|
2011-08-02 09:17:56 +01:00
|
|
|
_m('LABEL','Where?'),
|
2011-03-09 07:33:26 +00:00
|
|
|
null,
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field title on event form.
|
2011-04-18 00:32:52 +01:00
|
|
|
_m('Event location.'),
|
|
|
|
'location');
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
2011-03-09 15:07:30 +00:00
|
|
|
$this->li();
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->input('event-url',
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field label on event form.
|
2011-03-30 21:30:23 +01:00
|
|
|
_m('LABEL','URL'),
|
2011-03-09 15:07:30 +00:00
|
|
|
null,
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field title on event form.
|
2011-04-18 00:32:52 +01:00
|
|
|
_m('URL for more information.'),
|
|
|
|
'url');
|
2011-03-09 15:07:30 +00:00
|
|
|
$this->unli();
|
|
|
|
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->li();
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->input('event-description',
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field label on event form.
|
2011-03-30 21:30:23 +01:00
|
|
|
_m('LABEL','Description'),
|
2011-03-09 07:33:26 +00:00
|
|
|
null,
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Field title on event form.
|
2011-04-18 00:32:52 +01:00
|
|
|
_m('Description of the event.'),
|
2014-04-06 10:27:41 +01:00
|
|
|
'description',
|
|
|
|
true); // HTML5 "required" attribute
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->unli();
|
|
|
|
|
2011-04-05 16:18:10 +01:00
|
|
|
$this->out->elementEnd('ul');
|
|
|
|
|
2011-04-05 03:16:38 +01:00
|
|
|
$toWidget = new ToSelector($this->out,
|
|
|
|
common_current_user(),
|
|
|
|
null);
|
|
|
|
$toWidget->show();
|
|
|
|
|
2011-03-09 07:33:26 +00:00
|
|
|
$this->out->elementEnd('fieldset');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Action elements
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function formActions()
|
|
|
|
{
|
2011-04-07 13:01:40 +01:00
|
|
|
// TRANS: Button text to save an event..
|
2011-04-18 00:32:52 +01:00
|
|
|
$this->out->submit('event-submit', _m('BUTTON', 'Save'), 'submit', 'submit');
|
2011-03-09 07:33:26 +00:00
|
|
|
}
|
|
|
|
}
|