mirror of
https://github.com/umami-software/umami.git
synced 2025-12-06 01:18:00 +01:00
add canonicalizeTimezone conversions
Co-authored-by: Om Mishra <contact@om-mishra.com>
This commit is contained in:
parent
49e1582c28
commit
a1d6204373
3 changed files with 36 additions and 4 deletions
|
|
@ -5,7 +5,7 @@ export function useDateParameters() {
|
|||
const {
|
||||
dateRange: { startDate, endDate, unit },
|
||||
} = useDateRange();
|
||||
const { timezone, toUtc } = useTimezone();
|
||||
const { timezone, toUtc, canonicalizeTimezone } = useTimezone();
|
||||
|
||||
return {
|
||||
startAt: +toUtc(startDate),
|
||||
|
|
@ -13,6 +13,6 @@ export function useDateParameters() {
|
|||
startDate: toUtc(startDate).toISOString(),
|
||||
endDate: toUtc(endDate).toISOString(),
|
||||
unit,
|
||||
timezone,
|
||||
timezone: canonicalizeTimezone(timezone),
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
import { setItem } from '@/lib/storage';
|
||||
import { TIMEZONE_CONFIG } from '@/lib/constants';
|
||||
import { TIMEZONE_CONFIG, TIMEZONE_LEGACY } from '@/lib/constants';
|
||||
import { formatInTimeZone, zonedTimeToUtc, utcToZonedTime } from 'date-fns-tz';
|
||||
import { useApp, setTimezone } from '@/store/app';
|
||||
import { useLocale } from './useLocale';
|
||||
|
|
@ -34,5 +34,16 @@ export function useTimezone() {
|
|||
return utcToZonedTime(date, timezone);
|
||||
};
|
||||
|
||||
return { timezone, saveTimezone, formatTimezoneDate, toUtc, fromUtc };
|
||||
const canonicalizeTimezone = (timezone: string): string => {
|
||||
return TIMEZONE_LEGACY[timezone] ?? timezone;
|
||||
};
|
||||
|
||||
return {
|
||||
timezone,
|
||||
saveTimezone,
|
||||
formatTimezoneDate,
|
||||
toUtc,
|
||||
fromUtc,
|
||||
canonicalizeTimezone,
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -658,3 +658,24 @@ export const CURRENCIES = [
|
|||
{ id: 'OMR', name: 'Omani Rial' },
|
||||
{ id: 'GHS', name: 'Ghanaian Cedi' },
|
||||
];
|
||||
|
||||
export const TIMEZONE_LEGACY: Record<string, string> = {
|
||||
'Asia/Batavia': 'Asia/Jakarta',
|
||||
'Asia/Calcutta': 'Asia/Kolkata',
|
||||
'Asia/Chongqing': 'Asia/Shanghai',
|
||||
'Asia/Harbin': 'Asia/Shanghai',
|
||||
'Asia/Jayapura': 'Asia/Pontianak',
|
||||
'Asia/Katmandu': 'Asia/Kathmandu',
|
||||
'Asia/Macao': 'Asia/Macau',
|
||||
'Asia/Rangoon': 'Asia/Yangon',
|
||||
'Asia/Saigon': 'Asia/Ho_Chi_Minh',
|
||||
'Europe/Kiev': 'Europe/Kyiv',
|
||||
'Europe/Zaporozhye': 'Europe/Kyiv',
|
||||
'Etc/UTC': 'UTC',
|
||||
'US/Arizona': 'America/Phoenix',
|
||||
'US/Central': 'America/Chicago',
|
||||
'US/Eastern': 'America/New_York',
|
||||
'US/Mountain': 'America/Denver',
|
||||
'US/Pacific': 'America/Los_Angeles',
|
||||
'US/Samoa': 'Pacific/Pago_Pago',
|
||||
};
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue