import { hooks } from "@gnu-taler/web-util/lib/index.browser"; /** * Has the information to reach and * authenticate at the bank's backend. */ export type BackendState = LoggedIn | LoggedOut; export interface BackendInfo { url: string; username: string; password: string; } interface LoggedIn extends BackendInfo { status: "loggedIn"; } interface LoggedOut { status: "loggedOut"; } export const defaultState: BackendState = { status: "loggedOut" }; export interface BackendStateHandler { state: BackendState; clear(): void; save(info: BackendInfo): void; } /** * Return getters and setters for * login credentials and backend's * base URL. */ export function useBackendState(): BackendStateHandler { const [value, update] = hooks.useLocalStorage( "backend-state", JSON.stringify(defaultState), ); // const parsed = value !== undefined ? JSON.parse(value) : value; let parsed; try { parsed = JSON.parse(value!); } catch { parsed = undefined; } const state: BackendState = !parsed?.status ? defaultState : parsed; return { state, clear() { update(JSON.stringify(defaultState)); }, save(info) { const nextState: BackendState = { status: "loggedIn", ...info }; update(JSON.stringify(nextState)); }, }; }