feat(tv): migrate login to white design with navigation modals

This commit is contained in:
Fredrik Burmester
2026-01-29 12:12:20 +01:00
parent 80136f1800
commit 2c0a9b6cd9
18 changed files with 757 additions and 438 deletions

View File

@@ -0,0 +1,34 @@
import { useCallback } from "react";
import useRouter from "@/hooks/useAppRouter";
import { tvAccountSelectModalAtom } from "@/utils/atoms/tvAccountSelectModal";
import type {
SavedServer,
SavedServerAccount,
} from "@/utils/secureCredentials";
import { store } from "@/utils/store";
interface ShowAccountSelectModalParams {
server: SavedServer;
onAccountSelect: (account: SavedServerAccount) => void;
onAddAccount: () => void;
onDeleteAccount: (account: SavedServerAccount) => void;
}
export const useTVAccountSelectModal = () => {
const router = useRouter();
const showAccountSelectModal = useCallback(
(params: ShowAccountSelectModalParams) => {
store.set(tvAccountSelectModalAtom, {
server: params.server,
onAccountSelect: params.onAccountSelect,
onAddAccount: params.onAddAccount,
onDeleteAccount: params.onDeleteAccount,
});
router.push("/tv-account-select-modal");
},
[router],
);
return { showAccountSelectModal };
};

View File

@@ -0,0 +1,29 @@
import { useCallback } from "react";
import useRouter from "@/hooks/useAppRouter";
import { tvServerActionModalAtom } from "@/utils/atoms/tvServerActionModal";
import type { SavedServer } from "@/utils/secureCredentials";
import { store } from "@/utils/store";
interface ShowServerActionModalParams {
server: SavedServer;
onLogin: () => void;
onDelete: () => void;
}
export const useTVServerActionModal = () => {
const router = useRouter();
const showServerActionModal = useCallback(
(params: ShowServerActionModalParams) => {
store.set(tvServerActionModalAtom, {
server: params.server,
onLogin: params.onLogin,
onDelete: params.onDelete,
});
router.push("/tv-server-action-modal");
},
[router],
);
return { showServerActionModal };
};