mirror of
https://github.com/ajnart/homarr.git
synced 2026-01-30 11:19:12 +01:00
* feat: add object base64 hash method * chore: add script to add package * feat: add request-handler package * wip: add request handlers for all jobs and widget api procedures * wip: remove errors shown in logs, add missing decryption for secrets in cached-request-job-handler * wip: highly improve request handler, add request handlers for calendar, media-server, indexer-manager and more, add support for multiple inputs from job handler creator * refactor: move media-server requests to request-handler, add invalidation logic for dns-hole and media requests * refactor: remove unused integration item middleware * feat: add invalidation to switch entity action of smart-home * fix: lint issues * chore: use integration-kind-by-category instead of union for request-handlers * fix: build not working for tasks and websocket * refactor: add more logs * refactor: readd timestamp logic for diconnect status * fix: lint and typecheck issue * chore: address pull request feedback
41 lines
1.1 KiB
TypeScript
41 lines
1.1 KiB
TypeScript
"use client";
|
|
|
|
import { useEffect, useState } from "react";
|
|
import dayjs from "dayjs";
|
|
import relativeTime from "dayjs/plugin/relativeTime";
|
|
|
|
dayjs.extend(relativeTime);
|
|
|
|
const calculateTimeAgo = (timestamp: Date) => {
|
|
return dayjs().to(timestamp);
|
|
};
|
|
|
|
export const useTimeAgo = (timestamp: Date) => {
|
|
const [timeAgo, setTimeAgo] = useState(calculateTimeAgo(timestamp));
|
|
|
|
useEffect(() => {
|
|
const intervalId = setInterval(() => setTimeAgo(calculateTimeAgo(timestamp)), 1000); // update every second
|
|
|
|
return () => clearInterval(intervalId); // clear interval on hook unmount
|
|
}, [timestamp]);
|
|
|
|
return timeAgo;
|
|
};
|
|
|
|
export const useIntegrationConnected = (updatedAt: Date, { timeout = 30000 }) => {
|
|
const [connected, setConnected] = useState(Math.abs(dayjs(updatedAt).diff()) < timeout);
|
|
|
|
useEffect(() => {
|
|
setConnected(Math.abs(dayjs(updatedAt).diff()) < timeout);
|
|
|
|
const delayUntilTimeout = timeout - Math.abs(dayjs(updatedAt).diff());
|
|
const timeoutRef = setTimeout(() => {
|
|
setConnected(false);
|
|
}, delayUntilTimeout);
|
|
|
|
return () => clearTimeout(timeoutRef);
|
|
}, [updatedAt, timeout]);
|
|
|
|
return connected;
|
|
};
|