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:
parent
b6daa049de
commit
439af11e70
6 changed files with 101 additions and 25 deletions
|
@ -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(
|
||||||
|
|
|
@ -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()) {
|
||||||
|
|
|
@ -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':
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue