2024-04-11 23:54:09 +03:00
|
|
|
import { ENV } from "@/env";
|
2024-11-26 23:41:49 +03:00
|
|
|
import { FrigateConfig } from "@/types/frigateConfig";
|
2024-04-11 23:54:09 +03:00
|
|
|
import { NavData } from "@/types/navigation";
|
|
|
|
|
import { useMemo } from "react";
|
2024-11-26 23:41:49 +03:00
|
|
|
import { isDesktop } from "react-device-detect";
|
2024-04-11 23:54:09 +03:00
|
|
|
import { FaCompactDisc, FaVideo } from "react-icons/fa";
|
2024-06-23 23:58:00 +03:00
|
|
|
import { IoSearch } from "react-icons/io5";
|
2024-04-11 23:54:09 +03:00
|
|
|
import { LuConstruction } from "react-icons/lu";
|
2025-06-05 02:09:55 +03:00
|
|
|
import { MdCategory, MdVideoLibrary } from "react-icons/md";
|
2024-11-26 23:41:49 +03:00
|
|
|
import { TbFaceId } from "react-icons/tb";
|
|
|
|
|
import useSWR from "swr";
|
2025-09-12 14:19:29 +03:00
|
|
|
import { useIsAdmin } from "./use-is-admin";
|
2024-04-11 23:54:09 +03:00
|
|
|
|
2024-06-23 23:58:00 +03:00
|
|
|
export const ID_LIVE = 1;
|
|
|
|
|
export const ID_REVIEW = 2;
|
2024-09-11 17:41:16 +03:00
|
|
|
export const ID_EXPLORE = 3;
|
2024-06-23 23:58:00 +03:00
|
|
|
export const ID_EXPORT = 4;
|
2024-09-11 22:20:41 +03:00
|
|
|
export const ID_PLAYGROUND = 5;
|
2024-11-26 23:41:49 +03:00
|
|
|
export const ID_FACE_LIBRARY = 6;
|
2025-06-05 02:09:55 +03:00
|
|
|
export const ID_CLASSIFICATION = 7;
|
2024-06-23 23:58:00 +03:00
|
|
|
|
2024-04-11 23:54:09 +03:00
|
|
|
export default function useNavigation(
|
|
|
|
|
variant: "primary" | "secondary" = "primary",
|
|
|
|
|
) {
|
2024-11-26 23:41:49 +03:00
|
|
|
const { data: config } = useSWR<FrigateConfig>("config", {
|
|
|
|
|
revalidateOnFocus: false,
|
|
|
|
|
});
|
2025-09-12 14:19:29 +03:00
|
|
|
const isAdmin = useIsAdmin();
|
2024-11-26 23:41:49 +03:00
|
|
|
|
2024-04-11 23:54:09 +03:00
|
|
|
return useMemo(
|
|
|
|
|
() =>
|
|
|
|
|
[
|
|
|
|
|
{
|
2024-06-23 23:58:00 +03:00
|
|
|
id: ID_LIVE,
|
2024-04-11 23:54:09 +03:00
|
|
|
variant,
|
|
|
|
|
icon: FaVideo,
|
2025-03-17 15:26:01 +03:00
|
|
|
title: "menu.live.title",
|
2024-04-11 23:54:09 +03:00
|
|
|
url: "/",
|
|
|
|
|
},
|
|
|
|
|
{
|
2024-06-23 23:58:00 +03:00
|
|
|
id: ID_REVIEW,
|
2024-04-11 23:54:09 +03:00
|
|
|
variant,
|
|
|
|
|
icon: MdVideoLibrary,
|
2025-03-16 18:36:20 +03:00
|
|
|
title: "menu.review",
|
2024-04-11 23:54:09 +03:00
|
|
|
url: "/review",
|
|
|
|
|
},
|
|
|
|
|
{
|
2024-09-11 17:41:16 +03:00
|
|
|
id: ID_EXPLORE,
|
2024-06-23 23:58:00 +03:00
|
|
|
variant,
|
|
|
|
|
icon: IoSearch,
|
2025-03-16 18:36:20 +03:00
|
|
|
title: "menu.explore",
|
2024-09-11 17:41:16 +03:00
|
|
|
url: "/explore",
|
2024-06-23 23:58:00 +03:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
id: ID_EXPORT,
|
2024-04-11 23:54:09 +03:00
|
|
|
variant,
|
|
|
|
|
icon: FaCompactDisc,
|
2025-03-16 18:36:20 +03:00
|
|
|
title: "menu.export",
|
2024-04-11 23:54:09 +03:00
|
|
|
url: "/export",
|
|
|
|
|
},
|
|
|
|
|
{
|
2024-06-23 23:58:00 +03:00
|
|
|
id: ID_PLAYGROUND,
|
2024-04-11 23:54:09 +03:00
|
|
|
variant,
|
|
|
|
|
icon: LuConstruction,
|
2025-03-16 18:36:20 +03:00
|
|
|
title: "menu.uiPlayground",
|
2024-04-11 23:54:09 +03:00
|
|
|
url: "/playground",
|
|
|
|
|
enabled: ENV !== "production",
|
|
|
|
|
},
|
2024-11-26 23:41:49 +03:00
|
|
|
{
|
|
|
|
|
id: ID_FACE_LIBRARY,
|
|
|
|
|
variant,
|
|
|
|
|
icon: TbFaceId,
|
2025-03-16 18:36:20 +03:00
|
|
|
title: "menu.faceLibrary",
|
2024-11-26 23:41:49 +03:00
|
|
|
url: "/faces",
|
2025-09-12 14:19:29 +03:00
|
|
|
enabled: isDesktop && config?.face_recognition.enabled && isAdmin,
|
2024-11-26 23:41:49 +03:00
|
|
|
},
|
2025-06-05 02:09:55 +03:00
|
|
|
{
|
|
|
|
|
id: ID_CLASSIFICATION,
|
|
|
|
|
variant,
|
|
|
|
|
icon: MdCategory,
|
|
|
|
|
title: "menu.classification",
|
|
|
|
|
url: "/classification",
|
2025-09-12 14:19:29 +03:00
|
|
|
enabled: isDesktop && isAdmin,
|
2025-06-05 02:09:55 +03:00
|
|
|
},
|
2024-04-11 23:54:09 +03:00
|
|
|
] as NavData[],
|
2025-09-12 14:19:29 +03:00
|
|
|
[config?.face_recognition?.enabled, variant, isAdmin],
|
2024-04-11 23:54:09 +03:00
|
|
|
);
|
|
|
|
|
}
|