2023-02-18 20:37:37 +01:00
|
|
|
import { Box, MediaQuery } from '@mantine/core';
|
2023-02-14 10:26:58 +01:00
|
|
|
import React, { useState, useEffect } from 'react';
|
|
|
|
|
|
|
|
|
|
export interface Props {
|
|
|
|
|
startTime: Date | string;
|
|
|
|
|
endTime?: Date | string | null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const TimeElapsed = ({ startTime, endTime }: Props) => {
|
|
|
|
|
const [elapsed, setElapsed] = useState(
|
|
|
|
|
(new Date(endTime || Date.now()).getTime() -
|
|
|
|
|
new Date(startTime).getTime()) /
|
|
|
|
|
1000
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
if (endTime) return;
|
|
|
|
|
const interval = setInterval(() => {
|
|
|
|
|
setElapsed(
|
|
|
|
|
(new Date(endTime || Date.now()).getTime() -
|
|
|
|
|
new Date(startTime).getTime()) /
|
|
|
|
|
1000
|
|
|
|
|
);
|
|
|
|
|
}, 1000);
|
|
|
|
|
return () => clearInterval(interval);
|
|
|
|
|
}, [startTime, endTime]);
|
|
|
|
|
|
|
|
|
|
const hours = Math.floor(elapsed / 60 / 60);
|
|
|
|
|
const minutes = Math.floor((elapsed - hours * 60 * 60) / 60);
|
|
|
|
|
const seconds = Math.floor(elapsed - hours * 60 * 60 - minutes * 60);
|
|
|
|
|
|
|
|
|
|
const hoursString = `${hours}:${minutes.toString().padStart(2, '0')}:${seconds
|
|
|
|
|
.toString()
|
|
|
|
|
.padStart(2, '0')}`;
|
|
|
|
|
|
|
|
|
|
return (
|
2023-02-18 20:37:37 +01:00
|
|
|
<Box
|
|
|
|
|
sx={{
|
2023-02-14 10:26:58 +01:00
|
|
|
display: 'flex',
|
|
|
|
|
alignItems: 'center',
|
|
|
|
|
justifyContent: 'center',
|
2023-02-18 23:15:03 +01:00
|
|
|
flexDirection: 'column'
|
2023-02-14 10:26:58 +01:00
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<pre
|
|
|
|
|
style={{
|
|
|
|
|
fontSize: '1rem',
|
|
|
|
|
margin: 0
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<code>{hoursString}</code>
|
|
|
|
|
</pre>
|
2023-02-18 20:37:37 +01:00
|
|
|
<MediaQuery
|
|
|
|
|
smallerThan="sm"
|
|
|
|
|
styles={{
|
|
|
|
|
display: 'none'
|
2023-02-14 10:26:58 +01:00
|
|
|
}}
|
|
|
|
|
>
|
2023-02-18 20:37:37 +01:00
|
|
|
<p
|
|
|
|
|
style={{
|
|
|
|
|
fontSize: '0.75rem',
|
|
|
|
|
margin: 0
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
<span>
|
|
|
|
|
{Intl.DateTimeFormat('it-IT', {
|
|
|
|
|
hour: '2-digit',
|
|
|
|
|
minute: '2-digit',
|
|
|
|
|
hour12: false
|
|
|
|
|
}).format(new Date(startTime))}
|
|
|
|
|
</span>
|
|
|
|
|
<span dangerouslySetInnerHTML={{ __html: ' — ' }} />
|
|
|
|
|
<span>
|
|
|
|
|
{endTime
|
|
|
|
|
? Intl.DateTimeFormat('it-IT', {
|
|
|
|
|
hour: '2-digit',
|
|
|
|
|
minute: '2-digit',
|
|
|
|
|
hour12: false
|
|
|
|
|
}).format(new Date(endTime))
|
|
|
|
|
: 'now'}
|
|
|
|
|
</span>
|
|
|
|
|
</p>
|
|
|
|
|
</MediaQuery>
|
|
|
|
|
</Box>
|
2023-02-14 10:26:58 +01:00
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default TimeElapsed;
|