From 62cbeb6fab048eab48833854ba16da9c22822a5a Mon Sep 17 00:00:00 2001 From: Peter Thienel <thienel@data-quest.de> Date: Thu, 21 Mar 2024 07:42:49 +0000 Subject: [PATCH] =?UTF-8?q?Resolve=20"Falsche=20Darstellung=20ganzt=C3=A4g?= =?UTF-8?q?iger=20Termine=20an=20den=20Tagen=20der=20Sommer-/Winterzeitums?= =?UTF-8?q?tellung"?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Closes #3864 Merge request studip/studip!2717 --- .../calendar/CalendarDateAssignment.class.php | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/lib/models/calendar/CalendarDateAssignment.class.php b/lib/models/calendar/CalendarDateAssignment.class.php index 9eed0e740f9..101cb9642b5 100644 --- a/lib/models/calendar/CalendarDateAssignment.class.php +++ b/lib/models/calendar/CalendarDateAssignment.class.php @@ -278,7 +278,7 @@ class CalendarDateAssignment extends SimpleORMap implements Event $events_created[$event->calendar_date->id . '_' . $event->calendar_date->begin] = $event; } } elseif ($e_expire > $cal_start) { - $events_created = array_merge($events_created, self::getRepetition($event, $cal_noon, true)); + $events_created = array_merge($events_created, self::getRepetition($event, $cal_noon)); } } @@ -400,7 +400,7 @@ class CalendarDateAssignment extends SimpleORMap implements Event $time_end = $date_end->format('H:i:s'); $rec_date_begin = $date_time->modify(sprintf('today %s', $time_begin)); - $rec_date_end = $rec_date_begin->add($date->getDuration())->modify(sprintf('today %s', $time_end)); + $rec_date_end = $rec_date_begin->add($date->getDuration())->modify($time_end); $rec_date->calendar_date->begin = $rec_date_begin->getTimestamp(); $rec_date->calendar_date->end = $rec_date_end->getTimestamp(); @@ -503,11 +503,12 @@ class CalendarDateAssignment extends SimpleORMap implements Event public function isAllDayEvent(): bool { $begin = $this->getBegin(); - if ($begin->format('His') != '000000') { + if ($begin->format('His') !== '000000') { return false; } - $duration = $this->getDuration(); - return $duration->h === 23 && $duration->i === 59 && $duration->s === 59; + $end = $this->getEnd(); + return ($end->format('Ymd') === $begin->format('Ymd') + && $end->format('His') === '235959'); } public function isWritable(string $user_id): bool @@ -620,13 +621,8 @@ class CalendarDateAssignment extends SimpleORMap implements Event { $begin = $this->getBegin(); $end = $this->getEnd(); - $duration = $this->getDuration(); - - $all_day = $begin->format('H:i:s') === '00:00:00' - && $duration->h === 23 - && $duration->i === 59 - && $duration->s === 59; + $all_day = $this->isAllDayEvent(); $hide_confidential_data = $this->calendar_date->access === 'CONFIDENTIAL' && $user_id !== $this->calendar_date->author_id; -- GitLab