wallet-core/packages/demobank-ui/src/hooks/backend.ts

56 lines
1.2 KiB
TypeScript
Raw Normal View History

2022-12-07 13:29:36 +01:00
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"
2022-12-07 13:29:36 +01:00
}
export const defaultState: BackendState = { status: "loggedOut" }
export interface BackendStateHandler {
state: BackendState,
clear(): void;
save(info: BackendInfo): void;
}
2022-12-07 13:29:36 +01:00
/**
* 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))
},
}
2022-12-07 13:29:36 +01:00
}