2011-04-20 23:52:57 +09:00
|
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* StatusNet - the distributed open-source microblogging tool
|
|
|
|
|
* Copyright (C) 2011, StatusNet, Inc.
|
|
|
|
|
*
|
|
|
|
|
* Notice-list representation of an event
|
2011-04-22 03:26:58 +09:00
|
|
|
|
*
|
2011-04-20 23:52:57 +09: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);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Notice-list representation of an event
|
|
|
|
|
*
|
|
|
|
|
* @category General
|
|
|
|
|
* @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 EventListItem extends NoticeListItemAdapter
|
|
|
|
|
{
|
|
|
|
|
function showNotice()
|
|
|
|
|
{
|
|
|
|
|
$this->nli->out->elementStart('div', 'entry-title');
|
|
|
|
|
$this->nli->showAuthor();
|
|
|
|
|
$this->showContent();
|
|
|
|
|
$this->nli->out->elementEnd('div');
|
|
|
|
|
}
|
|
|
|
|
|
2011-04-20 23:59:31 +09:00
|
|
|
|
function showContent()
|
2011-04-20 23:52:57 +09:00
|
|
|
|
{
|
2011-04-20 23:59:31 +09:00
|
|
|
|
$notice = $this->nli->notice;
|
|
|
|
|
$out = $this->nli->out;
|
|
|
|
|
|
2011-04-20 23:52:57 +09:00
|
|
|
|
$profile = $notice->getProfile();
|
|
|
|
|
$event = Happening::fromNotice($notice);
|
|
|
|
|
|
|
|
|
|
if (empty($event)) {
|
2011-04-22 03:26:58 +09:00
|
|
|
|
// TRANS: Content for a deleted RSVP list item (RSVP stands for "please respond").
|
|
|
|
|
$out->element('p', null, _m('Deleted.'));
|
2011-04-20 23:52:57 +09:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$out->elementStart('div', 'vevent event'); // VEVENT IN
|
|
|
|
|
|
|
|
|
|
$out->elementStart('h3'); // VEVENT/H3 IN
|
|
|
|
|
|
|
|
|
|
if (!empty($event->url)) {
|
|
|
|
|
$out->element('a',
|
|
|
|
|
array('href' => $event->url,
|
|
|
|
|
'class' => 'event-title entry-title summary'),
|
|
|
|
|
$event->title);
|
|
|
|
|
} else {
|
|
|
|
|
$out->text($event->title);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$out->elementEnd('h3'); // VEVENT/H3 OUT
|
|
|
|
|
|
2011-08-02 17:17:56 +09:00
|
|
|
|
$now = new DateTime();
|
|
|
|
|
$startDate = new DateTime($event->start_time);
|
|
|
|
|
$endDate = new DateTime($event->end_time);
|
|
|
|
|
$userTz = new DateTimeZone(common_timezone());
|
2011-04-20 23:52:57 +09:00
|
|
|
|
|
2011-08-02 17:17:56 +09:00
|
|
|
|
// Localize the time for the observer
|
|
|
|
|
$now->setTimeZone($userTz);
|
|
|
|
|
$startDate->setTimezone($userTz);
|
|
|
|
|
$endDate->setTimezone($userTz);
|
2011-04-20 23:52:57 +09:00
|
|
|
|
|
2011-08-02 17:17:56 +09:00
|
|
|
|
$thisYear = $now->format('Y');
|
|
|
|
|
$startYear = $startDate->format('Y');
|
|
|
|
|
$endYear = $endDate->format('Y');
|
|
|
|
|
|
|
|
|
|
$dateFmt = 'D, F j, '; // e.g.: Mon, Aug 31
|
|
|
|
|
|
|
|
|
|
if ($startYear != $thisYear || $endYear != $thisYear) {
|
|
|
|
|
$dateFmt .= 'Y,'; // append year if we need to think about years
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$startDateStr = $startDate->format($dateFmt);
|
|
|
|
|
$endDateStr = $endDate->format($dateFmt);
|
|
|
|
|
|
|
|
|
|
$timeFmt = 'g:ia';
|
|
|
|
|
|
|
|
|
|
$startTimeStr = $startDate->format($timeFmt);
|
|
|
|
|
$endTimeStr = $endDate->format("{$timeFmt} (T)");
|
2011-04-20 23:52:57 +09:00
|
|
|
|
|
|
|
|
|
$out->elementStart('div', 'event-times'); // VEVENT/EVENT-TIMES IN
|
|
|
|
|
|
|
|
|
|
// TRANS: Field label for event description.
|
|
|
|
|
$out->element('strong', null, _m('Time:'));
|
|
|
|
|
|
|
|
|
|
$out->element('abbr', array('class' => 'dtstart',
|
|
|
|
|
'title' => common_date_iso8601($event->start_time)),
|
2011-08-02 17:17:56 +09:00
|
|
|
|
$startDateStr . ' ' . $startTimeStr);
|
|
|
|
|
$out->text(' – ');
|
|
|
|
|
if ($startDateStr == $endDateStr) {
|
2011-04-20 23:52:57 +09:00
|
|
|
|
$out->element('span', array('class' => 'dtend',
|
|
|
|
|
'title' => common_date_iso8601($event->end_time)),
|
2011-08-02 17:17:56 +09:00
|
|
|
|
$endTimeStr);
|
2011-04-20 23:52:57 +09:00
|
|
|
|
} else {
|
|
|
|
|
$out->element('span', array('class' => 'dtend',
|
|
|
|
|
'title' => common_date_iso8601($event->end_time)),
|
2011-08-02 17:17:56 +09:00
|
|
|
|
$endDateStr . ' ' . $endTimeStr);
|
2011-04-20 23:52:57 +09:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$out->elementEnd('div'); // VEVENT/EVENT-TIMES OUT
|
|
|
|
|
|
|
|
|
|
if (!empty($event->location)) {
|
|
|
|
|
$out->elementStart('div', 'event-location');
|
|
|
|
|
// TRANS: Field label for event description.
|
|
|
|
|
$out->element('strong', null, _m('Location:'));
|
|
|
|
|
$out->element('span', 'location', $event->location);
|
|
|
|
|
$out->elementEnd('div');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!empty($event->description)) {
|
|
|
|
|
$out->elementStart('div', 'event-description');
|
|
|
|
|
// TRANS: Field label for event description.
|
|
|
|
|
$out->element('strong', null, _m('Description:'));
|
|
|
|
|
$out->element('span', 'description', $event->description);
|
|
|
|
|
$out->elementEnd('div');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$rsvps = $event->getRSVPs();
|
|
|
|
|
|
|
|
|
|
$out->elementStart('div', 'event-rsvps');
|
|
|
|
|
// TRANS: Field label for event description.
|
2011-09-30 04:12:30 +09:00
|
|
|
|
|
|
|
|
|
$out->text(_('Attending:'));
|
|
|
|
|
$out->elementStart('ul', 'attending-list');
|
|
|
|
|
|
|
|
|
|
foreach ($rsvps as $verb => $responses) {
|
|
|
|
|
$out->elementStart('li', 'rsvp-list');
|
|
|
|
|
switch ($verb)
|
|
|
|
|
{
|
|
|
|
|
case RSVP::POSITIVE:
|
|
|
|
|
$out->text(_('Yes:'));
|
|
|
|
|
break;
|
|
|
|
|
case RSVP::NEGATIVE:
|
|
|
|
|
$out->text(_('No:'));
|
|
|
|
|
break;
|
|
|
|
|
case RSVP::POSSIBLE:
|
|
|
|
|
$out->text(_('Maybe:'));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
$ids = array();
|
|
|
|
|
foreach ($responses as $response) {
|
|
|
|
|
$ids[] = $response->profile_id;
|
|
|
|
|
}
|
2011-09-30 22:40:15 +09:00
|
|
|
|
$ids = array_slice($ids, 0, ProfileMiniList::MAX_PROFILES + 1);
|
2011-09-30 04:12:30 +09:00
|
|
|
|
$profiles = Profile::pivotGet('id', $ids);
|
|
|
|
|
$profile = new ArrayWrapper(array_values($profiles));
|
|
|
|
|
$minilist = new ProfileMiniList($profile, $out);
|
|
|
|
|
$minilist->show();
|
|
|
|
|
|
|
|
|
|
$out->elementEnd('li');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$out->elementEnd('ul');
|
2011-04-20 23:52:57 +09:00
|
|
|
|
$out->elementEnd('div');
|
|
|
|
|
|
|
|
|
|
$user = common_current_user();
|
|
|
|
|
|
|
|
|
|
if (!empty($user)) {
|
|
|
|
|
$rsvp = $event->getRSVP($user->getProfile());
|
|
|
|
|
|
|
|
|
|
if (empty($rsvp)) {
|
|
|
|
|
$form = new RSVPForm($event, $out);
|
|
|
|
|
} else {
|
|
|
|
|
$form = new CancelRSVPForm($rsvp, $out);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$form->show();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$out->elementEnd('div'); // vevent out
|
|
|
|
|
}
|
|
|
|
|
}
|