mirror of
https://github.com/immich-app/immich.git
synced 2025-01-16 16:56:46 +01:00
fix(web): Sort timezones in assets settings by offset (#10697)
* fixed timezones on web are sorted alphabetically * swaped order of operations in order to use DataTime.offset property for sorting * optimization
This commit is contained in:
parent
d00d33d8a5
commit
1d282851e2
1 changed files with 17 additions and 5 deletions
|
@ -12,7 +12,7 @@
|
|||
/**
|
||||
* Timezone name
|
||||
*
|
||||
* e.g. Europe/Berlin
|
||||
* e.g. Asia/Jerusalem (+03:00)
|
||||
*/
|
||||
label: string;
|
||||
|
||||
|
@ -24,10 +24,22 @@
|
|||
value: string;
|
||||
};
|
||||
|
||||
const timezones: ZoneOption[] = Intl.supportedValuesOf('timeZone').map((zone: string) => ({
|
||||
label: zone + ` (${DateTime.local({ zone }).toFormat('ZZ')})`,
|
||||
value: 'UTC' + DateTime.local({ zone }).toFormat('ZZ'),
|
||||
}));
|
||||
const timezones: ZoneOption[] = Intl.supportedValuesOf('timeZone')
|
||||
.map((zone) => DateTime.local({ zone }))
|
||||
.sort((zoneA, zoneB) => {
|
||||
let numericallyCorrect = zoneA.offset - zoneB.offset;
|
||||
if (numericallyCorrect != 0) {
|
||||
return numericallyCorrect;
|
||||
}
|
||||
return zoneA.zoneName.localeCompare(zoneB.zoneName, undefined, { sensitivity: 'base' });
|
||||
})
|
||||
.map((zone) => {
|
||||
const offset = zone.toFormat('ZZ');
|
||||
return {
|
||||
label: `${zone.zoneName} (${offset})`,
|
||||
value: 'UTC' + offset,
|
||||
};
|
||||
});
|
||||
|
||||
const initialOption = timezones.find((item) => item.value === 'UTC' + initialDate.toFormat('ZZ'));
|
||||
|
||||
|
|
Loading…
Reference in a new issue