diff --git a/src/applications/calendar/editor/PhabricatorCalendarEventEditEngine.php b/src/applications/calendar/editor/PhabricatorCalendarEventEditEngine.php index 441c3c5de5..4457f60fd8 100644 --- a/src/applications/calendar/editor/PhabricatorCalendarEventEditEngine.php +++ b/src/applications/calendar/editor/PhabricatorCalendarEventEditEngine.php @@ -119,7 +119,7 @@ final class PhabricatorCalendarEventEditEngine ->setDescription(pht('End time of the event.')) ->setConduitDescription(pht('Change the end time of the event.')) ->setConduitTypeDescription(pht('New event end time.')) - ->setValue($object->getEndDateTimeEpoch()), + ->setValue($object->newEndDateTimeForEdit()->getEpoch()), id(new PhabricatorBoolEditField()) ->setKey('cancelled') ->setOptions(pht('Active'), pht('Cancelled')) diff --git a/src/applications/calendar/storage/PhabricatorCalendarEvent.php b/src/applications/calendar/storage/PhabricatorCalendarEvent.php index 1410c0e106..ef7a808a61 100644 --- a/src/applications/calendar/storage/PhabricatorCalendarEvent.php +++ b/src/applications/calendar/storage/PhabricatorCalendarEvent.php @@ -857,7 +857,7 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO return $this->newStartDateTime()->getEpoch(); } - public function newEndDateTime() { + public function newEndDateTimeForEdit() { $datetime = $this->getParameter('endDateTime'); if ($datetime) { return $this->newDateTimeFromDictionary($datetime); @@ -867,6 +867,25 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO return $this->newDateTimeFromEpoch($epoch); } + public function newEndDateTime() { + $datetime = $this->newEndDateTimeForEdit(); + + // If this is an all day event, we move the end date time forward to the + // first second of the following day. This is consistent with what users + // expect: an all day event from "Nov 1" to "Nov 1" lasts the entire day. + if ($this->getIsAllDay()) { + $datetime = $datetime + ->newAbsoluteDateTime() + ->setHour(0) + ->setMinute(0) + ->setSecond(0) + ->newRelativeDateTime('P1D') + ->newAbsoluteDateTime(); + } + + return $datetime; + } + public function getEndDateTimeEpoch() { return $this->newEndDateTime()->getEpoch(); } diff --git a/src/applications/calendar/xaction/PhabricatorCalendarEventEndDateTransaction.php b/src/applications/calendar/xaction/PhabricatorCalendarEventEndDateTransaction.php index a0d127c32f..8d66176ea8 100644 --- a/src/applications/calendar/xaction/PhabricatorCalendarEventEndDateTransaction.php +++ b/src/applications/calendar/xaction/PhabricatorCalendarEventEndDateTransaction.php @@ -7,7 +7,7 @@ final class PhabricatorCalendarEventEndDateTransaction public function generateOldValue($object) { // TODO: Upgrade this. - return $object->getEndDateTimeEpoch(); + return $object->newEndDateTimeForEdit()->getEpoch(); } public function applyInternalEffects($object, $value) {