1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-07 05:11:05 +01:00

Make event hosts editable

Summary:
Fixes T10909. I think this is a generally reasonable sort of capability to expose, although I've made it edit-only for now (when creating an event, you're always the host).

Also clean up some minor leftovers in the code, and a couple of little bugs with recurrence frequencies.

Test Plan: Created an event, edited the host of an event.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T10909

Differential Revision: https://secure.phabricator.com/D16292
This commit is contained in:
epriestley 2016-07-13 12:36:49 -07:00
parent b6daa049de
commit 439af11e70
6 changed files with 101 additions and 25 deletions

View file

@ -2036,6 +2036,7 @@ phutil_register_library_map(array(
'PhabricatorCalendarEventEndDateTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventEndDateTransaction.php', 'PhabricatorCalendarEventEndDateTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventEndDateTransaction.php',
'PhabricatorCalendarEventFrequencyTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventFrequencyTransaction.php', 'PhabricatorCalendarEventFrequencyTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventFrequencyTransaction.php',
'PhabricatorCalendarEventFulltextEngine' => 'applications/calendar/search/PhabricatorCalendarEventFulltextEngine.php', 'PhabricatorCalendarEventFulltextEngine' => 'applications/calendar/search/PhabricatorCalendarEventFulltextEngine.php',
'PhabricatorCalendarEventHostTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventHostTransaction.php',
'PhabricatorCalendarEventIconTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventIconTransaction.php', 'PhabricatorCalendarEventIconTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventIconTransaction.php',
'PhabricatorCalendarEventInviteTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventInviteTransaction.php', 'PhabricatorCalendarEventInviteTransaction' => 'applications/calendar/xaction/PhabricatorCalendarEventInviteTransaction.php',
'PhabricatorCalendarEventInvitee' => 'applications/calendar/storage/PhabricatorCalendarEventInvitee.php', 'PhabricatorCalendarEventInvitee' => 'applications/calendar/storage/PhabricatorCalendarEventInvitee.php',
@ -6663,6 +6664,7 @@ phutil_register_library_map(array(
'PhabricatorCalendarEventEndDateTransaction' => 'PhabricatorCalendarEventDateTransaction', 'PhabricatorCalendarEventEndDateTransaction' => 'PhabricatorCalendarEventDateTransaction',
'PhabricatorCalendarEventFrequencyTransaction' => 'PhabricatorCalendarEventTransactionType', 'PhabricatorCalendarEventFrequencyTransaction' => 'PhabricatorCalendarEventTransactionType',
'PhabricatorCalendarEventFulltextEngine' => 'PhabricatorFulltextEngine', 'PhabricatorCalendarEventFulltextEngine' => 'PhabricatorFulltextEngine',
'PhabricatorCalendarEventHostTransaction' => 'PhabricatorCalendarEventTransactionType',
'PhabricatorCalendarEventIconTransaction' => 'PhabricatorCalendarEventTransactionType', 'PhabricatorCalendarEventIconTransaction' => 'PhabricatorCalendarEventTransactionType',
'PhabricatorCalendarEventInviteTransaction' => 'PhabricatorCalendarEventTransactionType', 'PhabricatorCalendarEventInviteTransaction' => 'PhabricatorCalendarEventTransactionType',
'PhabricatorCalendarEventInvitee' => array( 'PhabricatorCalendarEventInvitee' => array(

View file

@ -23,8 +23,7 @@ final class PhabricatorCalendarEventEditEngine
protected function newEditableObject() { protected function newEditableObject() {
return PhabricatorCalendarEvent::initializeNewCalendarEvent( return PhabricatorCalendarEvent::initializeNewCalendarEvent(
$this->getViewer(), $this->getViewer());
$mode = null);
} }
protected function newObjectQuery() { protected function newObjectQuery() {
@ -106,6 +105,17 @@ final class PhabricatorCalendarEventEditEngine
->setConduitDescription(pht('Cancel or restore the event.')) ->setConduitDescription(pht('Cancel or restore the event.'))
->setConduitTypeDescription(pht('True to cancel the event.')) ->setConduitTypeDescription(pht('True to cancel the event.'))
->setValue($object->getIsCancelled()), ->setValue($object->getIsCancelled()),
id(new PhabricatorUsersEditField())
->setKey('hostPHID')
->setAliases(array('host'))
->setLabel(pht('Host'))
->setDescription(pht('Host of the event.'))
->setTransactionType(
PhabricatorCalendarEventHostTransaction::TRANSACTIONTYPE)
->setIsConduitOnly($this->getIsCreate())
->setConduitDescription(pht('Change the host of the event.'))
->setConduitTypeDescription(pht('New event host.'))
->setSingleValue($object->getHostPHID()),
id(new PhabricatorDatasourceEditField()) id(new PhabricatorDatasourceEditField())
->setKey('inviteePHIDs') ->setKey('inviteePHIDs')
->setAliases(array('invite', 'invitee', 'invitees', 'inviteePHID')) ->setAliases(array('invite', 'invitee', 'invitees', 'inviteePHID'))
@ -141,7 +151,7 @@ final class PhabricatorCalendarEventEditEngine
->setDescription(pht('Recurring event frequency.')) ->setDescription(pht('Recurring event frequency.'))
->setConduitDescription(pht('Change the event frequency.')) ->setConduitDescription(pht('Change the event frequency.'))
->setConduitTypeDescription(pht('New event frequency.')) ->setConduitTypeDescription(pht('New event frequency.'))
->setValue($object->getFrequencyUnit()); ->setValue($object->getFrequencyRule());
} }
if ($this->getIsCreate() || $object->getIsRecurring()) { if ($this->getIsCreate() || $object->getIsRecurring()) {

View file

@ -39,8 +39,6 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
protected $spacePHID; protected $spacePHID;
const DEFAULT_ICON = 'fa-calendar';
private $parentEvent = self::ATTACHABLE; private $parentEvent = self::ATTACHABLE;
private $invitees = self::ATTACHABLE; private $invitees = self::ATTACHABLE;
@ -53,24 +51,13 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
const FREQUENCY_MONTHLY = 'monthly'; const FREQUENCY_MONTHLY = 'monthly';
const FREQUENCY_YEARLY = 'yearly'; const FREQUENCY_YEARLY = 'yearly';
public static function initializeNewCalendarEvent( public static function initializeNewCalendarEvent(PhabricatorUser $actor) {
PhabricatorUser $actor,
$mode) {
$app = id(new PhabricatorApplicationQuery()) $app = id(new PhabricatorApplicationQuery())
->setViewer($actor) ->setViewer($actor)
->withClasses(array('PhabricatorCalendarApplication')) ->withClasses(array('PhabricatorCalendarApplication'))
->executeOne(); ->executeOne();
$view_policy = null;
$is_recurring = 0;
if ($mode == 'public') {
$view_policy = PhabricatorPolicies::getMostOpenPolicy(); $view_policy = PhabricatorPolicies::getMostOpenPolicy();
}
if ($mode == 'recurring') {
$is_recurring = true;
}
$start = new DateTime('@'.PhabricatorTime::getNow()); $start = new DateTime('@'.PhabricatorTime::getNow());
$start->setTimeZone($actor->getTimeZone()); $start->setTimeZone($actor->getTimeZone());
@ -82,13 +69,19 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
$epoch_min = $start->format('U'); $epoch_min = $start->format('U');
$epoch_max = $end->format('U'); $epoch_max = $end->format('U');
$default_icon = 'fa-calendar';
return id(new PhabricatorCalendarEvent()) return id(new PhabricatorCalendarEvent())
->setHostPHID($actor->getPHID()) ->setHostPHID($actor->getPHID())
->setIsCancelled(0) ->setIsCancelled(0)
->setIsAllDay(0) ->setIsAllDay(0)
->setIsStub(0) ->setIsStub(0)
->setIsRecurring($is_recurring) ->setIsRecurring(0)
->setIcon(self::DEFAULT_ICON) ->setRecurrenceFrequency(
array(
'rule' => self::FREQUENCY_WEEKLY,
))
->setIcon($default_icon)
->setViewPolicy($view_policy) ->setViewPolicy($view_policy)
->setEditPolicy($actor->getPHID()) ->setEditPolicy($actor->getPHID())
->setSpacePHID($actor->getDefaultSpacePHID()) ->setSpacePHID($actor->getDefaultSpacePHID())
@ -396,8 +389,12 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
return $this; return $this;
} }
public function getFrequencyRule() {
return idx($this->recurrenceFrequency, 'rule');
}
public function getFrequencyUnit() { public function getFrequencyUnit() {
$frequency = idx($this->recurrenceFrequency, 'rule'); $frequency = $this->getFrequencyRule();
switch ($frequency) { switch ($frequency) {
case 'daily': case 'daily':

View file

@ -6,7 +6,7 @@ final class PhabricatorCalendarEventFrequencyTransaction
const TRANSACTIONTYPE = 'calendar.frequency'; const TRANSACTIONTYPE = 'calendar.frequency';
public function generateOldValue($object) { public function generateOldValue($object) {
return $object->getFrequencyUnit(); return $object->getFrequencyRule();
} }
public function applyInternalEffects($object, $value) { public function applyInternalEffects($object, $value) {
@ -17,7 +17,7 @@ final class PhabricatorCalendarEventFrequencyTransaction
} }
public function getTitle() { public function getTitle() {
$frequency = $this->getFrequencyUnit($this->getNewValue()); $frequency = $this->getFrequencyRule($this->getNewValue());
switch ($frequency) { switch ($frequency) {
case PhabricatorCalendarEvent::FREQUENCY_DAILY: case PhabricatorCalendarEvent::FREQUENCY_DAILY:
return pht( return pht(
@ -39,7 +39,7 @@ final class PhabricatorCalendarEventFrequencyTransaction
} }
public function getTitleForFeed() { public function getTitleForFeed() {
$frequency = $this->getFrequencyUnit($this->getNewValue()); $frequency = $this->getFrequencyRule($this->getNewValue());
switch ($frequency) { switch ($frequency) {
case PhabricatorCalendarEvent::FREQUENCY_DAILY: case PhabricatorCalendarEvent::FREQUENCY_DAILY:
return pht( return pht(
@ -64,7 +64,7 @@ final class PhabricatorCalendarEventFrequencyTransaction
} }
} }
private function getFrequencyUnit($value) { private function getFrequencyRule($value) {
if (is_array($value)) { if (is_array($value)) {
$value = idx($value, 'rule'); $value = idx($value, 'rule');
} else { } else {

View file

@ -0,0 +1,59 @@
<?php
final class PhabricatorCalendarEventHostTransaction
extends PhabricatorCalendarEventTransactionType {
const TRANSACTIONTYPE = 'calendar.host';
public function generateOldValue($object) {
return $object->getHostPHID();
}
public function applyInternalEffects($object, $value) {
$object->setHostPHID($value);
}
public function getTitle() {
return pht(
'%s changed the host of this event from %s to %s.',
$this->renderAuthor(),
$this->renderOldHandle(),
$this->renderNewHandle());
}
public function getTitleForFeed() {
return pht(
'%s changed the host of %s from %s to %s.',
$this->renderAuthor(),
$this->renderObject(),
$this->renderOldHandle(),
$this->renderNewHandle());
}
public function validateTransactions($object, array $xactions) {
$errors = array();
foreach ($xactions as $xaction) {
$host_phid = $xaction->getNewValue();
if (!$host_phid) {
$errors[] = $this->newRequiredError(
pht('Event host is required.'));
continue;
}
$user = id(new PhabricatorPeopleQuery())
->setViewer($this->getActor())
->withPHIDs(array($host_phid))
->executeOne();
if (!$user) {
$errors[] = $this->newInvalidError(
pht(
'Host PHID "%s" is not a valid user PHID.',
$host_phid));
}
}
return $errors;
}
}

View file

@ -148,6 +148,14 @@ abstract class PhabricatorModularTransactionType
return $display; return $display;
} }
final protected function renderOldHandle() {
return $this->renderHandle($this->getOldValue());
}
final protected function renderNewHandle() {
return $this->renderHandle($this->getNewValue());
}
final protected function renderHandleList(array $phids) { final protected function renderHandleList(array $phids) {
$viewer = $this->getViewer(); $viewer = $this->getViewer();
$display = $viewer->renderHandleList($phids) $display = $viewer->renderHandleList($phids)