From 76b877dcb9e5e50d83f238261c143f8448611916 Mon Sep 17 00:00:00 2001
From: Josh Stompro <stompro@stompro.org>
Date: Thu, 4 Mar 2021 19:09:44 -0600
Subject: [PATCH] LP#1917396 - Staff Curbside Scheduling UTC Issues

When a staff person tries to schedule curbside appointments
after their UTC equivalent time moves to the next day, the
timeslots for the next day are shown, and appointments get
made for the next day.

For example, when CST is the local timezone (UTC-6), after 6pm
appointments for the current day are scheduled for the next day.
Appointments for the next day get scheduled for the day after.

This happens because toISOString is used to grab the current date,
but toISOString always returns UTC time.  The date widget will show
the correct date, but the time slots will actually be for the next
day.  This is more noticeable if days have different schedules.

Another clue is that the time slot selector will show all timeslots for
the day, not just the ones that are upcoming.

Testing Plan:

1. Enable curbside for test location, and set org unit hours to
   be at least through 8pm for open hours.

2. Wait until after 4PM (Pacific), 6pm CST, 7PM EST, or
   change your computer clock.

3. Try to schedule an appointment for the current day.

4. The appointment should get scheduled for the next day.

5. Apply the fix.

6. Try to schedule another appointment and see that the correct
   date gets selected.

Signed-off-by: Josh Stompro <stompro@stompro.org>
Signed-off-by: Terran McCanna <tmccanna@georgialibraries.org>
Signed-off-by: Galen Charlton <gmc@equinoxOLI.org>
---
 .../ui/default/staff/circ/curbside/directives/schedule_pickup.js | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)

diff --git a/Open-ILS/web/js/ui/default/staff/circ/curbside/directives/schedule_pickup.js b/Open-ILS/web/js/ui/default/staff/circ/curbside/directives/schedule_pickup.js
index 6d8ae65e0a..cf5e4fe5d5 100644
--- a/Open-ILS/web/js/ui/default/staff/circ/curbside/directives/schedule_pickup.js
+++ b/Open-ILS/web/js/ui/default/staff/circ/curbside/directives/schedule_pickup.js
@@ -269,7 +269,8 @@ function($scope , $q , egCurbsideCoreSvc , egCore , patronSvc ,
             'open-ils.curbside',
             'open-ils.curbside.times_for_date.atomic',
             egCore.auth.token(),
-            hash.slot.substring(0, 10),
+            // Use date based on local time, not UTC
+            new Date(hash.slot_date - (hash.slot_date.getTimezoneOffset() * 60000)).toISOString().substring(0, 10),
         ).then(function(times) {
             mungeAvailableTimes(hash, times);
         });
@@ -295,7 +296,8 @@ function($scope , $q , egCurbsideCoreSvc , egCore , patronSvc ,
 
     $scope.minDate = new Date();
     $scope.refreshAvailableTimes = function(hash) {
-        var dateStr = (new Date(hash.slot_date)).toISOString().substring(0, 10);
+        // Use date based on local time, not UTC
+        var dateStr = (new Date(hash.slot_date - (hash.slot_date.getTimezoneOffset() * 60000))).toISOString().substring(0, 10);
         egCore.net.request (
             'open-ils.curbside',
             'open-ils.curbside.times_for_date.atomic',
@@ -321,7 +323,8 @@ function($scope , $q , egCurbsideCoreSvc , egCore , patronSvc ,
             'open-ils.curbside.' + op + '_appointment',
             egCore.auth.token(),
             $scope.user_id,
-            (new Date(appt.slot_date)).toISOString().substring(0, 10),
+            // Use date based on local time, not UTC
+            (new Date(appt.slot_date - (appt.slot_date.getTimezoneOffset() * 60000))).toISOString().substring(0, 10),
             appt.slot_time,
             egCore.auth.user().ws_ou(),
             appt.notes
-- 
2.11.0