2015-04-28 15:26:48 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PhabricatorCalendarEventTransaction
|
|
|
|
extends PhabricatorApplicationTransaction {
|
|
|
|
|
2015-04-28 17:34:26 +02:00
|
|
|
const TYPE_NAME = 'calendar.name';
|
2015-04-28 15:26:48 +02:00
|
|
|
const TYPE_START_DATE = 'calendar.startdate';
|
|
|
|
const TYPE_END_DATE = 'calendar.enddate';
|
|
|
|
const TYPE_STATUS = 'calendar.status';
|
|
|
|
const TYPE_DESCRIPTION = 'calendar.description';
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
const TYPE_CANCEL = 'calendar.cancel';
|
2015-04-28 15:26:48 +02:00
|
|
|
|
|
|
|
const MAILTAG_CONTENT = 'calendar-content';
|
|
|
|
const MAILTAG_OTHER = 'calendar-other';
|
|
|
|
|
|
|
|
public function getApplicationName() {
|
|
|
|
return 'calendar';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getApplicationTransactionType() {
|
|
|
|
return PhabricatorCalendarEventPHIDType::TYPECONST;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getApplicationTransactionCommentObject() {
|
|
|
|
return new PhabricatorCalendarEventTransactionComment();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getRequiredHandlePHIDs() {
|
|
|
|
$phids = parent::getRequiredHandlePHIDs();
|
|
|
|
|
|
|
|
switch ($this->getTransactionType()) {
|
2015-04-28 17:34:26 +02:00
|
|
|
case self::TYPE_NAME:
|
2015-04-28 15:26:48 +02:00
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
case self::TYPE_STATUS:
|
|
|
|
case self::TYPE_DESCRIPTION:
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
2015-04-28 15:26:48 +02:00
|
|
|
$phids[] = $this->getObjectPHID();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $phids;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function shouldHide() {
|
|
|
|
$old = $this->getOldValue();
|
|
|
|
switch ($this->getTransactionType()) {
|
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
case self::TYPE_STATUS:
|
|
|
|
case self::TYPE_DESCRIPTION:
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
2015-04-28 15:26:48 +02:00
|
|
|
return ($old === null);
|
|
|
|
}
|
|
|
|
return parent::shouldHide();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getIcon() {
|
|
|
|
switch ($this->getTransactionType()) {
|
2015-04-28 17:34:26 +02:00
|
|
|
case self::TYPE_NAME:
|
2015-04-28 15:26:48 +02:00
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
case self::TYPE_STATUS:
|
|
|
|
case self::TYPE_DESCRIPTION:
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
2015-04-28 15:26:48 +02:00
|
|
|
return 'fa-pencil';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return parent::getIcon();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitle() {
|
|
|
|
$author_phid = $this->getAuthorPHID();
|
|
|
|
$object_phid = $this->getObjectPHID();
|
|
|
|
|
|
|
|
$old = $this->getOldValue();
|
|
|
|
$new = $this->getNewValue();
|
|
|
|
|
|
|
|
$type = $this->getTransactionType();
|
|
|
|
switch ($type) {
|
2015-04-28 17:34:26 +02:00
|
|
|
case self::TYPE_NAME:
|
2015-04-28 17:56:00 +02:00
|
|
|
if ($old === null) {
|
|
|
|
return pht(
|
|
|
|
'%s created this event.',
|
|
|
|
$this->renderHandleLink($author_phid));
|
|
|
|
} else {
|
2015-04-28 17:34:26 +02:00
|
|
|
return pht(
|
|
|
|
'%s changed the name of this event from %s to %s.',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$old,
|
|
|
|
$new);
|
|
|
|
}
|
|
|
|
break;
|
2015-04-28 15:26:48 +02:00
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
if ($old) {
|
|
|
|
return pht(
|
|
|
|
'%s edited the start date of this event.',
|
|
|
|
$this->renderHandleLink($author_phid));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
if ($old) {
|
|
|
|
return pht(
|
|
|
|
'%s edited the end date of this event.',
|
|
|
|
$this->renderHandleLink($author_phid));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case self::TYPE_STATUS:
|
|
|
|
$old_name = PhabricatorCalendarEvent::getNameForStatus($old);
|
|
|
|
$new_name = PhabricatorCalendarEvent::getNameForStatus($new);
|
|
|
|
return pht(
|
|
|
|
'%s updated the event status from %s to %s.',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$old_name,
|
|
|
|
$new_name);
|
|
|
|
break;
|
|
|
|
case self::TYPE_DESCRIPTION:
|
|
|
|
return pht(
|
|
|
|
"%s updated the event's description.",
|
|
|
|
$this->renderHandleLink($author_phid));
|
|
|
|
break;
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
|
|
|
if ($new) {
|
|
|
|
return pht(
|
|
|
|
'%s cancelled this event.',
|
|
|
|
$this->renderHandleLink($author_phid));
|
|
|
|
break;
|
|
|
|
} else {
|
|
|
|
return pht(
|
|
|
|
'%s reinstated this event.',
|
|
|
|
$this->renderHandleLink($author_phid));
|
|
|
|
break;
|
|
|
|
}
|
2015-04-28 15:26:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return parent::getTitle();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitleForFeed() {
|
|
|
|
$author_phid = $this->getAuthorPHID();
|
|
|
|
$object_phid = $this->getObjectPHID();
|
|
|
|
|
|
|
|
$old = $this->getOldValue();
|
|
|
|
$new = $this->getNewValue();
|
|
|
|
|
2015-04-28 21:01:59 +02:00
|
|
|
$viewer = $this->getViewer();
|
|
|
|
|
2015-04-28 15:26:48 +02:00
|
|
|
$type = $this->getTransactionType();
|
|
|
|
switch ($type) {
|
2015-04-28 17:34:26 +02:00
|
|
|
case self::TYPE_NAME:
|
2015-04-28 21:01:59 +02:00
|
|
|
if ($old === null) {
|
|
|
|
return pht(
|
|
|
|
'%s created %s',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$this->renderHandleLink($object_phid));
|
|
|
|
} else {
|
2015-04-28 17:34:26 +02:00
|
|
|
return pht(
|
|
|
|
'%s changed the name of %s from %s to %s.',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$this->renderHandleLink($object_phid),
|
|
|
|
$old,
|
|
|
|
$new);
|
|
|
|
}
|
|
|
|
break;
|
2015-04-28 15:26:48 +02:00
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
if ($old) {
|
2015-04-28 21:01:59 +02:00
|
|
|
$old = phabricator_datetime($old, $viewer);
|
|
|
|
$new = phabricator_datetime($new, $viewer);
|
2015-04-28 15:26:48 +02:00
|
|
|
return pht(
|
2015-04-28 21:01:59 +02:00
|
|
|
'%s changed the start date of %s from %s to %s.',
|
2015-04-28 15:26:48 +02:00
|
|
|
$this->renderHandleLink($author_phid),
|
2015-04-28 21:01:59 +02:00
|
|
|
$this->renderHandleLink($object_phid),
|
2015-04-28 15:26:48 +02:00
|
|
|
$old,
|
|
|
|
$new);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
if ($old) {
|
2015-04-28 21:01:59 +02:00
|
|
|
$old = phabricator_datetime($old, $viewer);
|
|
|
|
$new = phabricator_datetime($new, $viewer);
|
2015-04-28 15:26:48 +02:00
|
|
|
return pht(
|
2015-04-28 21:01:59 +02:00
|
|
|
'%s edited the end date of %s from %s to %s.',
|
2015-04-28 15:26:48 +02:00
|
|
|
$this->renderHandleLink($author_phid),
|
2015-04-28 21:01:59 +02:00
|
|
|
$this->renderHandleLink($object_phid),
|
2015-04-28 15:26:48 +02:00
|
|
|
$old,
|
|
|
|
$new);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case self::TYPE_STATUS:
|
2015-04-28 21:01:59 +02:00
|
|
|
$old_name = PhabricatorCalendarEvent::getNameForStatus($old);
|
|
|
|
$new_name = PhabricatorCalendarEvent::getNameForStatus($new);
|
2015-04-28 15:26:48 +02:00
|
|
|
return pht(
|
2015-04-28 21:01:59 +02:00
|
|
|
'%s updated the status of %s from %s to %s.',
|
2015-04-28 15:26:48 +02:00
|
|
|
$this->renderHandleLink($author_phid),
|
2015-04-28 21:01:59 +02:00
|
|
|
$this->renderHandleLink($object_phid),
|
|
|
|
$old_name,
|
|
|
|
$new_name);
|
2015-04-28 15:26:48 +02:00
|
|
|
break;
|
|
|
|
case self::TYPE_DESCRIPTION:
|
|
|
|
return pht(
|
2015-04-28 21:01:59 +02:00
|
|
|
'%s updated the description of %s.',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$this->renderHandleLink($object_phid));
|
2015-04-28 15:26:48 +02:00
|
|
|
break;
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
|
|
|
if ($new) {
|
|
|
|
return pht(
|
|
|
|
'%s cancelled %s.',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$this->renderHandleLink($object_phid));
|
|
|
|
break;
|
|
|
|
} else {
|
|
|
|
return pht(
|
|
|
|
'%s reinstated %s.',
|
|
|
|
$this->renderHandleLink($author_phid),
|
|
|
|
$this->renderHandleLink($object_phid));
|
|
|
|
break;
|
|
|
|
}
|
2015-04-28 15:26:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return parent::getTitleForFeed();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getColor() {
|
|
|
|
$old = $this->getOldValue();
|
|
|
|
$new = $this->getNewValue();
|
|
|
|
|
|
|
|
switch ($this->getTransactionType()) {
|
2015-04-28 17:34:26 +02:00
|
|
|
case self::TYPE_NAME:
|
2015-04-28 15:26:48 +02:00
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
case self::TYPE_STATUS:
|
|
|
|
case self::TYPE_DESCRIPTION:
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
2015-04-28 15:26:48 +02:00
|
|
|
return PhabricatorTransactions::COLOR_GREEN;
|
|
|
|
}
|
|
|
|
|
|
|
|
return parent::getColor();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function hasChangeDetails() {
|
|
|
|
switch ($this->getTransactionType()) {
|
|
|
|
case self::TYPE_DESCRIPTION:
|
|
|
|
return ($this->getOldValue() !== null);
|
|
|
|
}
|
|
|
|
|
|
|
|
return parent::hasChangeDetails();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function renderChangeDetails(PhabricatorUser $viewer) {
|
|
|
|
switch ($this->getTransactionType()) {
|
|
|
|
case self::TYPE_DESCRIPTION:
|
|
|
|
$old = $this->getOldValue();
|
|
|
|
$new = $this->getNewValue();
|
|
|
|
|
|
|
|
return $this->renderTextCorpusChangeDetails(
|
|
|
|
$viewer,
|
|
|
|
$old,
|
|
|
|
$new);
|
|
|
|
}
|
|
|
|
|
|
|
|
return parent::renderChangeDetails($viewer);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getMailTags() {
|
|
|
|
$tags = array();
|
|
|
|
switch ($this->getTransactionType()) {
|
2015-04-28 17:34:26 +02:00
|
|
|
case self::TYPE_NAME:
|
|
|
|
$tags[] = self::MAILTAG_CONTENT;
|
|
|
|
break;
|
2015-04-28 15:26:48 +02:00
|
|
|
case self::TYPE_START_DATE:
|
|
|
|
$tags[] = self::MAILTAG_CONTENT;
|
|
|
|
break;
|
|
|
|
case self::TYPE_END_DATE:
|
|
|
|
$tags[] = self::MAILTAG_CONTENT;
|
|
|
|
break;
|
|
|
|
case self::TYPE_STATUS:
|
|
|
|
$tags[] = self::MAILTAG_OTHER;
|
|
|
|
break;
|
|
|
|
case self::TYPE_DESCRIPTION:
|
|
|
|
$tags[] = self::MAILTAG_CONTENT;
|
|
|
|
break;
|
Canceling calendar events should deactivate the event
Summary: Closes T7943, Canceling calendar event should deactivate the event instead of destroying data.
Test Plan: Create an event, cancel it, see changed status icon, query for active events, event should not appear, query for deactivated events, event should appear in results.
Reviewers: #blessed_reviewers, epriestley
Reviewed By: #blessed_reviewers, epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7943
Differential Revision: https://secure.phabricator.com/D12604
2015-04-29 17:39:39 +02:00
|
|
|
case self::TYPE_CANCEL:
|
|
|
|
$tags[] = self::MAILTAG_CONTENT;
|
|
|
|
break;
|
2015-04-28 15:26:48 +02:00
|
|
|
}
|
|
|
|
return $tags;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|