3 * StatusNet - the distributed open-source microblogging tool
4 * Copyright (C) 2011, StatusNet, Inc.
6 * Notice-list representation of an event
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU Affero General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Affero General Public License for more details.
20 * You should have received a copy of the GNU Affero General Public License
21 * along with this program. If not, see <http://www.gnu.org/licenses/>.
25 * @author Evan Prodromou <evan@status.net>
26 * @copyright 2011 StatusNet, Inc.
27 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
28 * @link http://status.net/
31 if (!defined('STATUSNET')) {
32 // This check helps protect against security problems;
33 // your code file can't be executed directly from the web.
38 * Notice-list representation of an event
42 * @author Evan Prodromou <evan@status.net>
43 * @copyright 2011 StatusNet, Inc.
44 * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
45 * @link http://status.net/
47 class EventListItem extends NoticeListItemAdapter
51 $this->nli->showAuthor();
55 function showContent()
57 $notice = $this->nli->notice;
58 $out = $this->nli->out;
60 $profile = $notice->getProfile();
61 $event = Happening::fromNotice($notice);
64 // TRANS: Content for a deleted RSVP list item (RSVP stands for "please respond").
65 $out->element('p', null, _m('Deleted.'));
69 // e-content since we're part of a h-entry
70 $out->elementStart('div', 'h-event e-content'); // VEVENT IN
72 $out->elementStart('h3', 'p-summary p-name'); // VEVENT/H3 IN
75 $out->element('a', array('href' => $event->getUrl()), $event->title);
76 } catch (InvalidUrlException $e) {
77 $out->text($event->title);
80 $out->elementEnd('h3'); // VEVENT/H3 OUT
82 $now = new DateTime();
83 $startDate = new DateTime($event->start_time);
84 $endDate = new DateTime($event->end_time);
85 $userTz = new DateTimeZone(common_timezone());
87 // Localize the time for the observer
88 $now->setTimeZone($userTz);
89 $startDate->setTimezone($userTz);
90 $endDate->setTimezone($userTz);
92 $thisYear = $now->format('Y');
93 $startYear = $startDate->format('Y');
94 $endYear = $endDate->format('Y');
96 $dateFmt = 'D, F j, '; // e.g.: Mon, Aug 31
98 if ($startYear != $thisYear || $endYear != $thisYear) {
99 $dateFmt .= 'Y,'; // append year if we need to think about years
102 $startDateStr = $startDate->format($dateFmt);
103 $endDateStr = $endDate->format($dateFmt);
107 $startTimeStr = $startDate->format($timeFmt);
108 $endTimeStr = $endDate->format("{$timeFmt} (T)");
110 $out->elementStart('div', 'event-times'); // VEVENT/EVENT-TIMES IN
112 // TRANS: Field label for event description.
113 $out->element('strong', null, _m('Time:'));
115 $out->element('time', array('class' => 'dt-start',
116 'datetime' => common_date_iso8601($event->start_time)),
117 $startDateStr . ' ' . $startTimeStr);
119 $out->element('time', array('class' => 'dt-end',
120 'datetime' => common_date_iso8601($event->end_time)),
121 $startDateStr != $endDateStr
122 ? "$endDateStr $endTimeStr"
125 $out->elementEnd('div'); // VEVENT/EVENT-TIMES OUT
127 if (!empty($event->location)) {
128 $out->elementStart('div', 'event-location');
129 // TRANS: Field label for event description.
130 $out->element('strong', null, _m('Location:'));
131 $out->element('span', 'p-location', $event->location);
132 $out->elementEnd('div');
135 if (!empty($event->description)) {
136 $out->elementStart('div', 'event-description');
137 // TRANS: Field label for event description.
138 $out->element('strong', null, _m('Description:'));
139 $out->element('div', 'p-description', $event->description);
140 $out->elementEnd('div');
143 $rsvps = $event->getRSVPs();
145 $out->elementStart('div', 'event-rsvps');
147 // TRANS: Field label for event description.
148 $out->element('strong', null, _m('Attending:'));
149 $out->elementStart('ul', 'attending-list');
151 foreach ($rsvps as $verb => $responses) {
152 $out->elementStart('li', 'rsvp-list');
155 $out->text(_('Yes:'));
158 $out->text(_('No:'));
161 $out->text(_('Maybe:'));
165 foreach ($responses as $response) {
166 $ids[] = $response->profile_id;
168 $ids = array_slice($ids, 0, ProfileMiniList::MAX_PROFILES + 1);
169 $minilist = new ProfileMiniList(Profile::multiGet('id', $ids), $out);
172 $out->elementEnd('li');
175 $out->elementEnd('ul');
176 $out->elementEnd('div');
178 $user = common_current_user();
181 $rsvp = $event->getRSVP($user->getProfile());
184 $form = new RSVPForm($event, $out);
186 $form = new CancelRSVPForm($rsvp, $out);
192 $out->elementEnd('div'); // vevent out