123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437 |
- <?php
- if (!defined('GNUSOCIAL')) { exit(1); }
- class EventPlugin extends ActivityVerbHandlerPlugin
- {
- const PLUGIN_VERSION = '2.0.0';
-
- function onCheckSchema()
- {
- $schema = Schema::get();
- $schema->ensureTable('happening', Happening::schemaDef());
- $schema->ensureTable('rsvp', RSVP::schemaDef());
- return true;
- }
- public function onBeforePluginCheckSchema()
- {
- RSVP::beforeSchemaUpdate();
- return true;
- }
-
- public function onRouterInitialized(URLMapper $m)
- {
- $m->connect('main/event/new',
- ['action' => 'newevent']);
- $m->connect('main/event/rsvp',
- ['action' => 'rsvp']);
- $m->connect('main/event/rsvp/:rsvp',
- ['action' => 'rsvp'],
- ['rsvp' => '[a-z]+']);
- $m->connect('event/:id',
- ['action' => 'showevent'],
- ['id' => '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}']);
- $m->connect('rsvp/:id',
- ['action' => 'showrsvp'],
- ['id' => '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}']);
- $m->connect('main/event/updatetimes',
- ['action' => 'timelist']);
- $m->connect(':nickname/events',
- ['action' => 'events'],
- ['nickname' => Nickname::DISPLAY_FMT]);
- return true;
- }
- function onPluginVersion(array &$versions)
- {
- $versions[] = array('name' => 'Event',
- 'version' => self::PLUGIN_VERSION,
- 'author' => 'Evan Prodromou',
- 'homepage' => 'https://git.gnu.io/gnu/gnu-social/tree/master/plugins/Event',
- 'description' =>
-
- _m('Event invitations and RSVPs.'));
- return true;
- }
- function appTitle() {
-
- return _m('TITLE','Event');
- }
- function tag() {
- return 'event';
- }
- function types() {
- return array(Happening::OBJECT_TYPE);
- }
- function verbs() {
- return array(ActivityVerb::POST,
- RSVP::POSITIVE,
- RSVP::NEGATIVE,
- RSVP::POSSIBLE);
- }
- function isMyNotice(Notice $notice) {
- if (!empty($notice->object_type)) {
- return parent::isMyNotice($notice);
- }
- return $this->isMyVerb($notice->verb);
- }
- public function newFormAction() {
-
- return 'new'.$this->tag();
- }
- function onStartShowEntryForms(&$tabs)
- {
- $tabs[$this->tag()] = array('title' => $this->appTitle(),
- 'href' => common_local_url($this->newFormAction()),
- );
- return true;
- }
- function onStartMakeEntryForm($tag, $out, &$form)
- {
- if ($tag == $this->tag()) {
- $form = $this->entryForm($out);
- return false;
- }
- return true;
- }
- protected function getActionTitle(ManagedAction $action, $verb, Notice $target, Profile $scoped)
- {
- return $verb;
- }
- protected function doActionPreparation(ManagedAction $action, $verb, Notice $target, Profile $scoped)
- {
- return true;
- }
- protected function doActionPost(ManagedAction $action, $verb, Notice $target, Profile $scoped)
- {
- throw new ServerException('Event does not handle doActionPost yet', 501);
- }
- protected function getActivityForm(ManagedAction $action, $verb, Notice $target, Profile $scoped)
- {
- return new RSVPForm(Happening::fromStored($target), $action);
- }
- protected function saveObjectFromActivity(Activity $act, Notice $stored, array $options=array())
- {
- switch (true) {
- case ActivityUtils::compareVerbs($stored->getVerb(), [ActivityVerb::POST]):
- return Happening::saveActivityObject($act, $stored);
- break;
- case ActivityUtils::compareVerbs($stored->getVerb(), [RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE]):
- return RSVP::saveActivityObject($act, $stored);
- break;
- }
- return null;
- }
- function activityObjectFromNotice(Notice $stored)
- {
- $happening = null;
- switch (true) {
- case $stored->isVerb([ActivityVerb::POST]) && $stored->isObjectType([Happening::OBJECT_TYPE]):
- $obj = Happening::fromStored($stored)->asActivityObject();
- break;
-
- case $stored->isObjectType([RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE]):
- case $stored->isVerb([RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE]):
- $obj = RSVP::fromStored($stored)->asActivityObject();
- break;
- default:
-
- throw new Exception(_m('Unknown object type.'));
- }
- return $obj;
- }
-
- function entryForm($out)
- {
- return new EventForm($out);
- }
- function deleteRelated(Notice $stored)
- {
- switch (true) {
- case $stored->isObjectType([Happening::OBJECT_TYPE]):
- common_log(LOG_DEBUG, "Deleting event from notice...");
- try {
- $happening = Happening::fromStored($stored);
- $happening->delete();
- } catch (NoResultException $e) {
-
- }
- break;
-
- case $stored->isObjectType([RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE]):
- case $stored->isVerb([RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE]):
- common_log(LOG_DEBUG, "Deleting rsvp from notice...");
- try {
- $rsvp = RSVP::fromStored($stored);
- $rsvp->delete();
- } catch (NoResultException $e) {
-
- }
- break;
- }
- }
- function onEndShowScripts($action)
- {
- $action->script($this->path('js/event.js'));
- }
- function onEndShowStyles($action)
- {
- $action->cssLink($this->path('css/event.css'));
- return true;
- }
- function onStartAddNoticeReply($nli, $parent, $child)
- {
- if (($parent->object_type == Happening::OBJECT_TYPE) &&
- in_array($child->object_type, array(RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE))) {
- return false;
- }
- return true;
- }
- protected function showNoticeContent(Notice $stored, HTMLOutputter $out, Profile $scoped=null)
- {
- switch (true) {
- case ActivityUtils::compareTypes($stored->verb, array(ActivityVerb::POST)) &&
- ActivityUtils::compareTypes($stored->object_type, array(Happening::OBJECT_TYPE)):
- $this->showEvent($stored, $out, $scoped);
- break;
- case ActivityUtils::compareVerbs($stored->verb, array(RSVP::POSITIVE, RSVP::NEGATIVE, RSVP::POSSIBLE)):
- $this->showRSVP($stored, $out, $scoped);
- break;
- default:
- throw new ServerException('This is not an Event notice');
- }
- return true;
- }
- protected function showEvent(Notice $stored, HTMLOutputter $out, Profile $scoped=null)
- {
- $profile = $stored->getProfile();
- $event = Happening::fromStored($stored);
- $out->elementStart('div', 'h-event');
- $out->elementStart('h3', 'p-summary p-name');
- try {
- $out->element('a', array('href' => $event->getUrl()), $event->title);
- } catch (InvalidUrlException $e) {
- $out->text($event->title);
- }
- $out->elementEnd('h3');
- $now = new DateTime();
- $startDate = new DateTime($event->start_time);
- $endDate = new DateTime($event->end_time);
- $userTz = new DateTimeZone(common_timezone());
-
- $now->setTimeZone($userTz);
- $startDate->setTimezone($userTz);
- $endDate->setTimezone($userTz);
- $thisYear = $now->format('Y');
- $startYear = $startDate->format('Y');
- $endYear = $endDate->format('Y');
- $dateFmt = 'D, F j, ';
- if ($startYear != $thisYear || $endYear != $thisYear) {
- $dateFmt .= 'Y,';
- }
- $startDateStr = $startDate->format($dateFmt);
- $endDateStr = $endDate->format($dateFmt);
- $timeFmt = 'g:ia';
- $startTimeStr = $startDate->format($timeFmt);
- $endTimeStr = $endDate->format("{$timeFmt} (T)");
- $out->elementStart('div', 'event-times');
-
- $out->element('strong', null, _m('Time:'));
- $out->element('time', array('class' => 'dt-start',
- 'datetime' => common_date_iso8601($event->start_time)),
- $startDateStr . ' ' . $startTimeStr);
- $out->text(' – ');
- $out->element('time', array('class' => 'dt-end',
- 'datetime' => common_date_iso8601($event->end_time)),
- $startDateStr != $endDateStr
- ? "$endDateStr $endTimeStr"
- : $endTimeStr);
- $out->elementEnd('div');
- if (!empty($event->location)) {
- $out->elementStart('div', 'event-location');
-
- $out->element('strong', null, _m('Location:'));
- $out->element('span', 'p-location', $event->location);
- $out->elementEnd('div');
- }
- if (!empty($event->description)) {
- $out->elementStart('div', 'event-description');
-
- $out->element('strong', null, _m('Description:'));
- $out->element('div', 'p-description', $event->description);
- $out->elementEnd('div');
- }
- $rsvps = $event->getRSVPs();
- $out->elementStart('div', 'event-rsvps');
-
- $out->element('strong', null, _m('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;
- }
- $ids = array_slice($ids, 0, ProfileMiniList::MAX_PROFILES + 1);
- $minilist = new ProfileMiniList(Profile::multiGet('id', $ids), $out);
- $minilist->show();
- $out->elementEnd('li');
- }
- $out->elementEnd('ul');
- $out->elementEnd('div');
- if ($scoped instanceof Profile) {
- $form = new RSVPForm($out, array('event'=>$event, 'scoped'=>$scoped));
- $form->show();
- }
- $out->elementEnd('div');
- }
- protected function showRSVP(Notice $stored, HTMLOutputter $out, Profile $scoped=null)
- {
- try {
- $rsvp = RSVP::fromStored($stored)->asHTML();
- } catch (NoResultException $e) {
-
- $out->element('p', null, _m('Deleted.'));
- return;
- }
- $out->elementStart('div', 'rsvp');
- $out->raw($rsvp);
- $out->elementEnd('div');
- }
- function onEndPersonalGroupNav(Menu $menu, Profile $target, Profile $scoped=null)
- {
- $menu->menuItem(common_local_url('events', array('nickname' => $target->getNickname())),
-
- _m('Happenings'),
-
- _m('A list of your events'), false, 'nav_timeline_events');
- return true;
- }
- }
|