Closed cjohn001 closed 5 months ago
A note regarding this.
In android runtime, we have this feature configurable using handleTimeZoneChanges
as mentioned above.
See: https://github.com/NativeScript/android/pull/1033
In iOS runtime, we'll need a listener that calls V8's Date::DateTimeConfigurationChangeNotification
to reset timezone.
@CatchABus , thanks for the directions. The Android solution (handleTimeZoneChanges) I have already found. Do you know of an example app where I could see how this needs to be done on IOS? Would also be great if the info could be added to the NS documentation. Likely having timezone changes activitated by default would be quite helpful as well. I assume people expect that those are applied to the runtime till they realise it is not the case. Maybe a good change for future NS versions.
I created a draft that exposes the V8 function to the user, so you can manually reset the timezone (by attaching a notification observer and calling that function).
It's still a draft because I believe we can implement handleTimeZoneChanges
in the runtime itself which would handle threading a bit better (to avoid unnecessary main thread locks when updating worker times)
@edusperoni : thanks for the directions. I assume you mean I need to call it from an application event
Application.on(Application.resumeEvent, (args: ApplicationEventData) => {
if(timezoneChanged){
DefineDateTimeConfigurationChangeNotificationMethod()
}
}
What would I have to provide for the parameters?
v8::Isolate* isolate,
v8::Local
Thanks for the directions. I am also wondering, why the timezone changes are not set automatically in the runtime. Should this not be the default behaviour? Was wondering about handleTimeZoneChanges on android side as well. I mean the ios and android runtimes also change the timezone automatically. Hence, as app developer I would expect the same behaviour with NS.
I think there should also be a refresh of all opened ui pages. I have seen on android, that I manually have to reload all data on all opened pages in order for the timezone change to take effect in the ui
@cjohn001 tbh I didn't even know that flag existed on Android 😅. The PR I did exposes the function on iOS so the user can register the notification listener and call that in userland. We're still debating if this change is better handled as in core (core will register the notification and call it) or in the runtime as Android does it.
Tbh I expect the TimeZone to be accurate even without any flags.
@edusperoni : I am absolutely with you, handleTimeZoneChanges on android should be true by default and it would be great if the user would not have to handle things manually with a notification listener on ios as well. I will than wait for the result of your discussions :)
@cjohn001 tbh I didn't even know that flag existed on Android 😅. The PR I did exposes the function on iOS so the user can register the notification listener and call that in userland. We're still debating if this change is better handled as in core (core will register the notification and call it) or in the runtime as Android does it.
Tbh I expect the TimeZone to be accurate even without any flags.
@edusperoni I digged like a lot to find a 2018 PR implementing this and I was shocked about its existence as well :D
I think your idea is much better than handleTimeZoneChanges
configuration, and we could let core contain timezone change listeners for both platforms.
@cjohn001 If we call that runtime method for both platforms, android will have to use a BroadcastReceiver to track change by checking for Intent.ACTION_TIMEZONE_CHANGED
See: https://github.com/NativeScript/android/blob/main/test-app/app/src/main/java/com/tns/RuntimeHelper.java#L258
Regarding iOS, I think an NSSystemTimeZoneDidChangeNotification
observer would do to call the runtime method.
Check this post: https://stackoverflow.com/a/27779954
@CatchABus my only issue is that it needs to be called per isolate, and the callbacks are called in the main thread. This means that it'll try to enter the worker isolates from the main thread which could lead to locking the main thread if the worker is doing heavy work. If done at the runtime level, we can dispatch a message to the worker's runloop.
If done at core level, I'd most likely create a native helper that would wrap the callback to replicate the same behavior.
Issue Description
When changing the timezone settings on iOS the locale seems to be changed, but the time is not set to the correct time for that timezone.
Here is an example on IOS from Date object:
Starting in London timezone: time: Mon Jun 05 2023 15:50:00 GMT+0100 (BST)
switching timezone to CEST (GMT+0200): time: Mon Jun 05 2023 15:50:15 GMT+0100 (CEST) --> you can see, time zone was switched but time is not updated to reflect time in timezone (should be +0200)
After restarting application the timezone is set up correctly. time: Mon Jun 05 2023 16:53:10 GMT+0200 (CEST)
Please note, I had an initial issue in the NS core repo
https://github.com/NativeScript/NativeScript/issues/10300
However, seems like the correct place is here. When setting:
like recommended here:
https://github.com/NativeScript/NativeScript/issues/10300#issuecomment-1584389309
things are working correctly on Android.
I tried also setting this flag for"ios", however, this had no effect.
Reproduction
console.log( new Date());
switch timezone via device settings
Workaround
The only workaround I have found so far is forcing the app to close. On restart the timezone settings or ok.
Environment
Dependencies