From da68b83a0709f7c704ae896653e367f12eedffc1 Mon Sep 17 00:00:00 2001 From: nathan Date: Wed, 19 Apr 2023 11:00:35 -0600 Subject: [PATCH] Calendar: When moving an event reset status of non-users according to event owner's preference instead of always resetting --- calendar/inc/class.calendar_boupdate.inc.php | 37 +++++++++++--------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/calendar/inc/class.calendar_boupdate.inc.php b/calendar/inc/class.calendar_boupdate.inc.php index 5443416ee8..ff6409d3b3 100644 --- a/calendar/inc/class.calendar_boupdate.inc.php +++ b/calendar/inc/class.calendar_boupdate.inc.php @@ -3163,34 +3163,37 @@ class calendar_boupdate extends calendar_bo foreach((array)$event['participants'] as $uid => $status) { $q = $r = null; - calendar_so::split_status($status,$q,$r); + calendar_so::split_status($status, $q, $r); if($uid == $this->user || $status == 'U') { continue; } - // Just user accounts - if (is_int($uid)) + if(is_int($uid)) { + // Just user accounts $preferences = new Api\Preferences($uid); - $part_prefs = $preferences->read_repository(); - switch ($part_prefs['calendar']['reset_stati']) - { - case 'no': - break; - case 'startday': - if ($sameday) break; - default: - $status_reset = true; - $event['participants'][$uid] = calendar_so::combine_status('U',$q,$r); - } } - // All other participant types else { - $status_reset = true; - $event['participants'][$uid] = calendar_so::combine_status('U',$q,$r); + // For non-users, use the owner's preference + $preferences = new Api\Preferences($event['owner']); } + $part_prefs = $preferences->read_repository(); + switch($part_prefs['calendar']['reset_stati']) + { + case 'no': + break; + case 'startday': + if($sameday) + { + break; + } + default: + $status_reset = true; + $event['participants'][$uid] = calendar_so::combine_status('U', $q, $r); + } + } return $status_reset;