forked from GNUsocial/gnu-social
Cancelling RSVPs now seems to work.
This commit is contained in:
parent
9accd953e4
commit
21cc737f5c
@ -28,9 +28,7 @@
|
|||||||
* @link http://status.net/
|
* @link http://status.net/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!defined('STATUSNET') && !defined('LACONICA')) {
|
if (!defined('GNUSOCIAL')) { exit(1); }
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class for UI widgets
|
* Base class for UI widgets
|
||||||
@ -65,9 +63,13 @@ class Widget
|
|||||||
* @param Action $out output helper, defaults to null
|
* @param Action $out output helper, defaults to null
|
||||||
*/
|
*/
|
||||||
|
|
||||||
function __construct(Action $out=null)
|
function __construct(Action $out=null, array $widgetOpts=array())
|
||||||
{
|
{
|
||||||
$this->out = $out;
|
$this->out = $out;
|
||||||
|
if (!array_key_exists('scoped', $widgetOpts)) {
|
||||||
|
$this->widgetOpts['scoped'] = Profile::current();
|
||||||
|
}
|
||||||
|
$this->scoped = $this->widgetOpts['scoped'];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -78,9 +78,10 @@ class EventPlugin extends ActivityVerbHandlerPlugin
|
|||||||
$m->connect('main/event/new',
|
$m->connect('main/event/new',
|
||||||
array('action' => 'newevent'));
|
array('action' => 'newevent'));
|
||||||
$m->connect('main/event/rsvp',
|
$m->connect('main/event/rsvp',
|
||||||
array('action' => 'newrsvp'));
|
array('action' => 'rsvp'));
|
||||||
$m->connect('main/event/rsvp/cancel',
|
$m->connect('main/event/rsvp/:rsvp', // this will probably change to include event notice id
|
||||||
array('action' => 'cancelrsvp'));
|
array('action' => 'rsvp'),
|
||||||
|
array('rsvp' => '[a-z]+'));
|
||||||
$m->connect('event/:id',
|
$m->connect('event/:id',
|
||||||
array('action' => 'showevent'),
|
array('action' => 'showevent'),
|
||||||
array('id' => '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}'));
|
array('id' => '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}'));
|
||||||
@ -433,14 +434,7 @@ class EventPlugin extends ActivityVerbHandlerPlugin
|
|||||||
$out->elementEnd('div');
|
$out->elementEnd('div');
|
||||||
|
|
||||||
if ($scoped instanceof Profile) {
|
if ($scoped instanceof Profile) {
|
||||||
$rsvp = $event->getRSVP($scoped);
|
$form = new RSVPForm($out, array('event'=>$event, 'scoped'=>$scoped));
|
||||||
|
|
||||||
if (empty($rsvp)) {
|
|
||||||
$form = new RSVPForm($out, array('event'=>$event));
|
|
||||||
} else {
|
|
||||||
$form = new CancelRSVPForm($out, array('rsvp'=>$rsvp));
|
|
||||||
}
|
|
||||||
|
|
||||||
$form->show();
|
$form->show();
|
||||||
}
|
}
|
||||||
$out->elementEnd('div');
|
$out->elementEnd('div');
|
||||||
|
@ -1,89 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* StatusNet - the distributed open-source microblogging tool
|
|
||||||
* Copyright (C) 2011, StatusNet, Inc.
|
|
||||||
*
|
|
||||||
* Cancel the RSVP for an event
|
|
||||||
*
|
|
||||||
* 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('GNUSOCIAL')) { exit(1); }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* RSVP for 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 CancelrsvpAction extends FormAction
|
|
||||||
{
|
|
||||||
protected $form = 'CancelRSVP';
|
|
||||||
|
|
||||||
function title()
|
|
||||||
{
|
|
||||||
// TRANS: Title for RSVP ("please respond") action.
|
|
||||||
return _m('TITLE','Cancel RSVP');
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: Merge this action with RSVPAction and add a 'cancel' thing there...
|
|
||||||
protected function doPreparation()
|
|
||||||
{
|
|
||||||
$rsvpId = $this->trimmed('rsvp');
|
|
||||||
if (empty($rsvpId)) {
|
|
||||||
// TRANS: Client exception thrown when referring to a non-existing RSVP ("please respond") item.
|
|
||||||
throw new ClientException(_m('No such RSVP.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->rsvp = RSVP::getKV('id', $rsvpId);
|
|
||||||
if (empty($this->rsvp)) {
|
|
||||||
// TRANS: Client exception thrown when referring to a non-existing RSVP ("please respond") item.
|
|
||||||
throw new ClientException(_m('No such RSVP.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->formOpts['rsvp'] = $this->rsvp;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function doPost()
|
|
||||||
{
|
|
||||||
$this->event = Happening::getKV('uri', $this->rsvp->event_uri);
|
|
||||||
if (empty($this->event)) {
|
|
||||||
// TRANS: Client exception thrown when referring to a non-existing event.
|
|
||||||
throw new ClientException(_m('No such event.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
$notice = $this->rsvp->getNotice();
|
|
||||||
// NB: this will delete the rsvp, too
|
|
||||||
if (!empty($notice)) {
|
|
||||||
common_log(LOG_DEBUG, "Deleting notice...");
|
|
||||||
$notice->deleteAs($this->scoped);
|
|
||||||
} else {
|
|
||||||
common_log(LOG_DEBUG, "Deleting RSVP alone...");
|
|
||||||
$this->rsvp->delete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -40,11 +40,11 @@ if (!defined('GNUSOCIAL')) { exit(1); }
|
|||||||
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
||||||
* @link http://status.net/
|
* @link http://status.net/
|
||||||
*/
|
*/
|
||||||
class NewrsvpAction extends FormAction
|
class RsvpAction extends FormAction
|
||||||
{
|
{
|
||||||
protected $form = 'RSVP';
|
protected $form = 'RSVP';
|
||||||
|
|
||||||
protected $event;
|
protected $event = null;
|
||||||
|
|
||||||
function title()
|
function title()
|
||||||
{
|
{
|
||||||
@ -61,9 +61,19 @@ class NewrsvpAction extends FormAction
|
|||||||
|
|
||||||
protected function doPost()
|
protected function doPost()
|
||||||
{
|
{
|
||||||
|
if ($this->trimmed('rsvp') === 'cancel') {
|
||||||
|
$rsvp = RSVP::byEventAndActor($this->event, $this->scoped);
|
||||||
|
try {
|
||||||
|
$notice = $rsvp->getStored();
|
||||||
|
$notice->deleteAs($this->scoped);
|
||||||
|
} catch (NoResultException $e) {
|
||||||
|
// Notice already gone
|
||||||
|
$rsvp->delete();
|
||||||
|
}
|
||||||
|
return _m('Cancelled RSVP');
|
||||||
|
}
|
||||||
|
|
||||||
$verb = RSVP::verbFor(strtolower($this->trimmed('submitvalue')));
|
$verb = RSVP::verbFor(strtolower($this->trimmed('rsvp')));
|
||||||
|
|
||||||
$options = array('source' => 'web');
|
$options = array('source' => 'web');
|
||||||
|
|
||||||
$act = new Activity();
|
$act = new Activity();
|
@ -208,7 +208,7 @@ class RSVP extends Managed_DataObject
|
|||||||
return $this->event_uri;
|
return $this->event_uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
static function getStored()
|
public function getStored()
|
||||||
{
|
{
|
||||||
return Notice::getByKeys(['uri' => $this->getUri()]);
|
return Notice::getByKeys(['uri' => $this->getUri()]);
|
||||||
}
|
}
|
||||||
@ -218,6 +218,12 @@ class RSVP extends Managed_DataObject
|
|||||||
return self::getByKeys(['uri' => $stored->getUri()]);
|
return self::getByKeys(['uri' => $stored->getUri()]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static function byEventAndActor(Happening $event, Profile $actor)
|
||||||
|
{
|
||||||
|
return self::getByKeys(['event_uri' => $event->getUri(),
|
||||||
|
'profile_id' => $actor->getID()]);
|
||||||
|
}
|
||||||
|
|
||||||
static function forEvent(Happening $event)
|
static function forEvent(Happening $event)
|
||||||
{
|
{
|
||||||
$keypart = sprintf('rsvp:for-event:%s', $event->getUri());
|
$keypart = sprintf('rsvp:for-event:%s', $event->getUri());
|
||||||
|
@ -1,127 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* StatusNet - the distributed open-source microblogging tool
|
|
||||||
* Copyright (C) 2011, StatusNet, Inc.
|
|
||||||
*
|
|
||||||
* Form to RSVP for an event
|
|
||||||
*
|
|
||||||
* 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')) { exit(1); }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A form to RSVP for 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 CancelRSVPForm extends Form
|
|
||||||
{
|
|
||||||
protected $rsvp = null;
|
|
||||||
|
|
||||||
function __construct($out=null, array $formOpts=array())
|
|
||||||
{
|
|
||||||
parent::__construct($out);
|
|
||||||
if (!isset($formOpts['rsvp'])) {
|
|
||||||
throw new ServerException('You must set the "rsvp" form option for RSVPForm.');
|
|
||||||
} elseif (!$formOpts['rsvp'] instanceof RSVP) {
|
|
||||||
throw new ServerException('The "rsvp" form option for RSVPForm must be an RSVP object.');
|
|
||||||
}
|
|
||||||
$this->rsvp = $formOpts['rsvp'];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ID of the form
|
|
||||||
*
|
|
||||||
* @return int ID of the form
|
|
||||||
*/
|
|
||||||
function id()
|
|
||||||
{
|
|
||||||
return 'form_event_rsvp';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* class of the form
|
|
||||||
*
|
|
||||||
* @return string class of the form
|
|
||||||
*/
|
|
||||||
function formClass()
|
|
||||||
{
|
|
||||||
return 'ajax';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Action of the form
|
|
||||||
*
|
|
||||||
* @return string URL of the action
|
|
||||||
*/
|
|
||||||
function action()
|
|
||||||
{
|
|
||||||
return common_local_url('cancelrsvp');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Data elements of the form
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
function formData()
|
|
||||||
{
|
|
||||||
$this->out->elementStart('fieldset', array('id' => 'new_rsvp_data'));
|
|
||||||
|
|
||||||
$this->out->hidden('rsvp-id', $this->rsvp->getUri(), 'rsvp');
|
|
||||||
|
|
||||||
switch (RSVP::verbFor($this->rsvp->response)) {
|
|
||||||
case RSVP::POSITIVE:
|
|
||||||
// TRANS: Possible status for RSVP ("please respond") item.
|
|
||||||
$this->out->text(_m('You will attend this event.'));
|
|
||||||
break;
|
|
||||||
case RSVP::NEGATIVE:
|
|
||||||
// TRANS: Possible status for RSVP ("please respond") item.
|
|
||||||
$this->out->text(_m('You will not attend this event.'));
|
|
||||||
break;
|
|
||||||
case RSVP::POSSIBLE:
|
|
||||||
// TRANS: Possible status for RSVP ("please respond") item.
|
|
||||||
$this->out->text(_m('You might attend this event.'));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->out->elementEnd('fieldset');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Action elements
|
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
|
||||||
function formActions()
|
|
||||||
{
|
|
||||||
// TRANS: Button text to cancel responding to an RSVP ("please respond") item.
|
|
||||||
$this->out->submit('rsvp-cancel', _m('BUTTON', 'Cancel'));
|
|
||||||
}
|
|
||||||
}
|
|
@ -82,7 +82,7 @@ class RSVPForm extends Form
|
|||||||
*/
|
*/
|
||||||
function action()
|
function action()
|
||||||
{
|
{
|
||||||
return common_local_url('newrsvp');
|
return common_local_url('rsvp');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -98,7 +98,7 @@ class RSVPForm extends Form
|
|||||||
$this->out->text(_m('RSVP:'));
|
$this->out->text(_m('RSVP:'));
|
||||||
|
|
||||||
$this->out->hidden('event-id', $this->event->getUri(), 'event');
|
$this->out->hidden('event-id', $this->event->getUri(), 'event');
|
||||||
$this->out->hidden('submitvalue', '');
|
$this->out->hidden('rsvp', '');
|
||||||
|
|
||||||
$this->out->elementEnd('fieldset');
|
$this->out->elementEnd('fieldset');
|
||||||
}
|
}
|
||||||
@ -110,26 +110,31 @@ class RSVPForm extends Form
|
|||||||
*/
|
*/
|
||||||
function formActions()
|
function formActions()
|
||||||
{
|
{
|
||||||
// TRANS: Button text for RSVP ("please respond") reply to confirm attendence.
|
try {
|
||||||
$this->submitButton('yes', _m('BUTTON', 'Yes'));
|
$rsvp = RSVP::byEventAndActor($this->event, $this->scoped);
|
||||||
// TRANS: Button text for RSVP ("please respond") reply to deny attendence.
|
$this->submitButton('cancel', _m('BUTTON', 'Cancel'));
|
||||||
$this->submitButton('no', _m('BUTTON', 'No'));
|
} catch (NoResultException $e) {
|
||||||
// TRANS: Button text for RSVP ("please respond") reply to indicate one might attend.
|
// TRANS: Button text for RSVP ("please respond") reply to confirm attendence.
|
||||||
$this->submitButton('maybe', _m('BUTTON', 'Maybe'));
|
$this->submitButton('yes', _m('BUTTON', 'Yes'));
|
||||||
|
// TRANS: Button text for RSVP ("please respond") reply to deny attendence.
|
||||||
|
$this->submitButton('no', _m('BUTTON', 'No'));
|
||||||
|
// TRANS: Button text for RSVP ("please respond") reply to indicate one might attend.
|
||||||
|
$this->submitButton('maybe', _m('BUTTON', 'Maybe'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function submitButton($id, $label)
|
function submitButton($answer, $label)
|
||||||
{
|
{
|
||||||
$this->out->element(
|
$this->out->element(
|
||||||
'input',
|
'input',
|
||||||
array(
|
array(
|
||||||
'type' => 'submit',
|
'type' => 'submit',
|
||||||
'id' => 'rsvp-submit',
|
'id' => 'rsvp-submit-'.$answer,
|
||||||
'name' => $id,
|
'name' => $answer,
|
||||||
'class' => 'submit',
|
'class' => 'submit',
|
||||||
'value' => $label,
|
'value' => $answer,
|
||||||
'title' => $label,
|
'title' => $label,
|
||||||
'onClick' => 'this.form.submitvalue.value = this.name; return true;'
|
'onClick' => 'this.form.rsvp.value = this.name; return true;'
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user