A time zone is a geographical region where all the clocks are set to the same time. This simplifies timekeeping and avoids confusion when communicating across long distances. There are several different time zone standards, including Coordinated Universal Time (UTC), Greenwich Mean Time (GMT), and International Atomic Time (TAI). If we took a deep look at different standards all of them are interlinked with an offset. For example, UTC+0 is a standard time and reflects midnight but if I want to get the time of Kathmandu then an offset of (+5:45) is added to UTC making it UTC+5:45 which is 5:45 AM. A similar concept applies when changing from one timezone to a different timezone. So what is the problem then?
As we can see having different timezone creates an unseen complexities when presenting, storing and calculating time. Timekeeping and presentation in a selected timezone would also be difficult when we have two actively interacting workspaces i.e frontend and backend. Moreover it increases complexities when we have users from different nation following different timezone. Situations where dates needs to be formatted between different formats is also a next possible problem. There are concepts which collides when we dig deeper thus a classification of common upcases has been created.
-
Use case 1: Date time conversion between different timezones ✅
We might bump into a situation where we need to convert time from one time zone to another timezone.
-
Use case 2: Date conversion between different formats ✅
There are several formats of representing time which could vary according to user preferences.
-
Use case 3: Date time calculations to get the difference in time; with/without timezone ✅
We might come across a situation where we need to find differences between the time which might be stored in different formats and could include or exclude timezones.
-
Use case 4: Storing time-related data in the database and backend data consumption ✅
We might encounter a situation where the front end needs to send date-time data to the backend and handle operations accordingly.
-
Use case 5: Displaying date time data based on local ✅
There might be situations when we need to store time in UTC and display it based on the user’s location.
-
Use case 6: Handling date time in different rendering paradigms ✅
Situations when stored time is consumed on the front end using different rendering paradigms and creating issues due to changes in date-time value.
-
Use case 7: Handling recurring dates and events ✅
Situations where we need to keep track of recurring events at different timezone.
Dealing with timezone data is not that difficult after all you need is perfect tool for your situation. Here are some of the findings that might give you some ideas how to approach the problem and solve it.
- When you are facing hydration issues -> Follow guide from
Usecase6
- Its always a good idea to store time related data in UTC
- Convert time for client based on their local and UTC
- Don't store time gap data on server as it may change in reference to time calculated
Well it might sound obvious but here are some golden rule of thumbs that could prevent us form getting timezone related issue.
- Store time related data in UTC
- Request time related data in
ISO 8061
orRFC3339
format which will be easy to manipulate by frontend. - Render time as per user's timezone based on stored UTC time data
- Follow guide from Usecase6 if you are using SSR and have to deal with time related data.
- Select best time related package that supports internationalization as well. I've used
DayJs
as it's a lightweight package.
If there is anything missing let me know or we could collaborate on concepts together. Thanks for making till the end 🎉.