From a52a0a7a4fdf2ffcce257cf0b29120265205be77 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Hempel?= Date: Fri, 14 Jun 2024 23:32:42 +0200 Subject: [PATCH] Add time to detail page --- .../layout/Location/LocationInformation.tsx | 35 +++++++++++++++++-- 1 file changed, 33 insertions(+), 2 deletions(-) diff --git a/src/components/layout/Location/LocationInformation.tsx b/src/components/layout/Location/LocationInformation.tsx index ad37a5d..182c031 100644 --- a/src/components/layout/Location/LocationInformation.tsx +++ b/src/components/layout/Location/LocationInformation.tsx @@ -1,4 +1,4 @@ -import React from "react"; +import React, {useEffect, useState} from "react"; import {useTranslation} from "react-i18next"; /* Import configuration. */ @@ -19,6 +19,20 @@ type LocationInformationProps = { number: number } +const getTimeWithOffset = (offset: string) => +{ + const now = new Date(); + const [hoursOffset, minutesOffset] = offset.split(':').map(Number); + const totalOffsetMinutes = (hoursOffset * 60) + (Math.sign(hoursOffset) * minutesOffset); + + // Calculate the current time in UTC + const utcTime = new Date(now.getTime() + (now.getTimezoneOffset() * 60000)); + // Apply the offset to get the target time + const targetTime = new Date(utcTime.getTime() + (totalOffsetMinutes * 60000)); + + return targetTime.toTimeString().split(' ')[0]; +} + /** * This is the LocationInformation part. */ @@ -27,6 +41,21 @@ const LocationInformation = ({location, number}: LocationInformationProps) => /* Import translation. */ const { t } = useTranslation(); + const [time, setTime] = useState(''); + + useEffect(() => { + if (location.hasTimezone()) { + const offset = location.getTimezone()?.getOffset() ?? '00:00'; + setTime(getTimeWithOffset(offset)); + + const intervalId = setInterval(() => { + setTime(getTimeWithOffset(offset)); + }, 1000); + + return () => clearInterval(intervalId); + } + }, [location]); + const classNamesRow1 = ClassNames.Row1; const classNamesRow2 = ClassNames.Row2; @@ -83,7 +112,9 @@ const LocationInformation = ({location, number}: LocationInformationProps) => colSpan={2} title={location.getTimezone()?.getCoordinate().getDMS() ?? ''} >{location.getTimezone()?.getTimezone()}  - {location.getTimezone()?.getOffset()} + {location.getTimezone()?.getOffset()}
+ {time} + : <> } {