2022-08-02 00:21:11 +02:00
|
|
|
import { Group, Text, Title } from '@mantine/core';
|
2022-05-10 18:56:29 +02:00
|
|
|
import dayjs from 'dayjs';
|
|
|
|
|
import { useEffect, useState } from 'react';
|
2022-05-29 18:42:58 +02:00
|
|
|
import { IconClock as Clock } from '@tabler/icons';
|
2022-07-23 22:22:55 +02:00
|
|
|
import { useConfig } from '../../tools/state';
|
|
|
|
|
import { IModule } from '../ModuleTypes';
|
|
|
|
|
import { useSetSafeInterval } from '../../tools/hooks/useSetSafeInterval';
|
2022-05-10 18:56:29 +02:00
|
|
|
|
|
|
|
|
export const DateModule: IModule = {
|
|
|
|
|
title: 'Date',
|
|
|
|
|
description: 'Show the current time and date in a card',
|
|
|
|
|
icon: Clock,
|
|
|
|
|
component: DateComponent,
|
2022-05-18 22:11:37 +02:00
|
|
|
options: {
|
|
|
|
|
full: {
|
|
|
|
|
name: 'Display full time (24-hour)',
|
|
|
|
|
value: true,
|
|
|
|
|
},
|
|
|
|
|
},
|
2022-05-10 18:56:29 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default function DateComponent(props: any) {
|
|
|
|
|
const [date, setDate] = useState(new Date());
|
2022-06-06 15:20:46 +02:00
|
|
|
const setSafeInterval = useSetSafeInterval();
|
2022-05-18 22:11:37 +02:00
|
|
|
const { config } = useConfig();
|
2022-06-28 12:10:46 +02:00
|
|
|
const isFullTime = config?.modules?.[DateModule.title]?.options?.full?.value ?? true;
|
2022-05-22 20:40:10 +02:00
|
|
|
const formatString = isFullTime ? 'HH:mm' : 'h:mm A';
|
2022-05-10 18:56:29 +02:00
|
|
|
// Change date on minute change
|
|
|
|
|
// Note: Using 10 000ms instead of 1000ms to chill a little :)
|
|
|
|
|
useEffect(() => {
|
2022-06-06 15:20:46 +02:00
|
|
|
setSafeInterval(() => {
|
2022-05-10 18:56:29 +02:00
|
|
|
setDate(new Date());
|
2022-05-18 22:11:37 +02:00
|
|
|
}, 1000 * 60);
|
2022-05-10 18:56:29 +02:00
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
return (
|
2022-07-26 00:51:55 +02:00
|
|
|
<Group p="sm" spacing="xs">
|
2022-05-18 22:50:53 +02:00
|
|
|
<Title>{dayjs(date).format(formatString)}</Title>
|
2022-08-02 00:21:11 +02:00
|
|
|
<Text size="lg">{dayjs(date).format('dddd, MMMM D')}</Text>
|
2022-05-10 18:56:29 +02:00
|
|
|
</Group>
|
|
|
|
|
);
|
|
|
|
|
}
|