You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
39 lines
1.1 KiB
39 lines
1.1 KiB
import { useCallback } from "react";
|
|
import { eventBus } from "@core/utils/eventBus.ts";
|
|
import { useDevice } from "@core/stores/deviceStore.ts";
|
|
|
|
export const UNSAFE_ROLES = ["ROUTER", "REPEATER"];
|
|
export type UnsafeRole = typeof UNSAFE_ROLES[number];
|
|
|
|
export const useUnsafeRolesDialog = () => {
|
|
const { setDialogOpen } = useDevice();
|
|
|
|
const handleCloseDialog = useCallback(() => {
|
|
setDialogOpen("unsafeRoles", false);
|
|
}, [setDialogOpen]);
|
|
|
|
const validateRoleSelection = useCallback(
|
|
(newRoleKey: string): Promise<boolean> => {
|
|
if (!UNSAFE_ROLES.includes(newRoleKey as UnsafeRole)) {
|
|
return Promise.resolve(true);
|
|
}
|
|
|
|
setDialogOpen("unsafeRoles", true);
|
|
|
|
return new Promise((resolve) => {
|
|
const handleResponse = ({ action }: { action: "confirm" | "dismiss" }) => {
|
|
eventBus.off("dialog:unsafeRoles", handleResponse);
|
|
resolve(action === "confirm");
|
|
};
|
|
|
|
eventBus.on("dialog:unsafeRoles", handleResponse);
|
|
});
|
|
},
|
|
[setDialogOpen]
|
|
);
|
|
|
|
return {
|
|
handleCloseDialog,
|
|
validateRoleSelection,
|
|
};
|
|
};
|
|
|