mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-10-04 11:15:55 +02:00
* Portal tooltips * Add ability to time_range filter chroma searches * centering and padding consistency * add event id back to chroma metadata * query sqlite first and pass those ids to chroma for embeddings search * ensure we pass timezone to the api call * remove object lifecycle from search details for non-object events * simplify hour calculation * fix query without filters * bump chroma version * chroma 0.5.7 * fix selecting camera group in cameras filter button
91 lines
2.2 KiB
TypeScript
91 lines
2.2 KiB
TypeScript
import { FrigateConfig } from "@/types/frigateConfig";
|
|
import { formatUnixTimestampToDateTime } from "@/utils/dateUtil";
|
|
import { useMemo } from "react";
|
|
|
|
export function useFormattedTimestamp(
|
|
timestamp: number,
|
|
format: string,
|
|
timezone?: string,
|
|
) {
|
|
const formattedTimestamp = useMemo(() => {
|
|
return formatUnixTimestampToDateTime(timestamp, {
|
|
timezone,
|
|
strftime_fmt: format,
|
|
});
|
|
}, [format, timestamp, timezone]);
|
|
|
|
return formattedTimestamp;
|
|
}
|
|
|
|
export function useFormattedRange(start: number, end: number, format: string) {
|
|
const formattedStart = useMemo(() => {
|
|
return formatUnixTimestampToDateTime(start, {
|
|
strftime_fmt: format,
|
|
});
|
|
}, [format, start]);
|
|
const formattedEnd = useMemo(() => {
|
|
return formatUnixTimestampToDateTime(end, {
|
|
strftime_fmt: format,
|
|
});
|
|
}, [format, end]);
|
|
|
|
return `${formattedStart} - ${formattedEnd}`;
|
|
}
|
|
|
|
export function useTimezone(config: FrigateConfig | undefined) {
|
|
return useMemo(() => {
|
|
if (!config) {
|
|
return undefined;
|
|
}
|
|
|
|
return (
|
|
config.ui?.timezone || Intl.DateTimeFormat().resolvedOptions().timeZone
|
|
);
|
|
}, [config]);
|
|
}
|
|
|
|
function use24HourTime(config: FrigateConfig | undefined) {
|
|
const localeUses24HourTime = useMemo(
|
|
() =>
|
|
new Intl.DateTimeFormat(undefined, {
|
|
hour: "numeric",
|
|
})
|
|
?.formatToParts(new Date(2020, 0, 1, 13))
|
|
?.find((part) => part.type === "hour")?.value?.length === 2,
|
|
[],
|
|
);
|
|
|
|
return useMemo(() => {
|
|
if (!config) {
|
|
return false;
|
|
}
|
|
|
|
if (config.ui.time_format != "browser") {
|
|
return config.ui.time_format == "24hour";
|
|
}
|
|
|
|
return localeUses24HourTime;
|
|
}, [config, localeUses24HourTime]);
|
|
}
|
|
|
|
export function useFormattedHour(
|
|
config: FrigateConfig | undefined,
|
|
time: string, // hour is assumed to be in 24 hour format per the Date object
|
|
) {
|
|
const hour24 = use24HourTime(config);
|
|
|
|
return useMemo(() => {
|
|
if (hour24) {
|
|
return time;
|
|
}
|
|
|
|
const [hour, minute] = time.includes(":") ? time.split(":") : [time, "00"];
|
|
const hourNum = parseInt(hour);
|
|
|
|
const adjustedHour = hourNum % 12 || 12;
|
|
const period = hourNum < 12 ? "AM" : "PM";
|
|
|
|
return `${adjustedHour}:${minute} ${period}`;
|
|
}, [hour24, time]);
|
|
}
|