diff options
author | Sebastian <sebasjm@gmail.com> | 2021-10-19 10:56:52 -0300 |
---|---|---|
committer | Sebastian <sebasjm@gmail.com> | 2021-10-19 11:05:32 -0300 |
commit | 5883d42d800c7b444c59d626bcaa5abca7dc83d0 (patch) | |
tree | ac42ad7b9e26c4dd2145a31101305884906a543e /packages/anastasis-webui/src/pages/home/SolveScreen.tsx | |
parent | 269022a526b670d602ca146f4df02850983bb72e (diff) | |
download | wallet-core-5883d42d800c7b444c59d626bcaa5abca7dc83d0.tar.xz |
add template from merchant backoffice
Diffstat (limited to 'packages/anastasis-webui/src/pages/home/SolveScreen.tsx')
-rw-r--r-- | packages/anastasis-webui/src/pages/home/SolveScreen.tsx | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/packages/anastasis-webui/src/pages/home/SolveScreen.tsx b/packages/anastasis-webui/src/pages/home/SolveScreen.tsx new file mode 100644 index 000000000..46ff8227d --- /dev/null +++ b/packages/anastasis-webui/src/pages/home/SolveScreen.tsx @@ -0,0 +1,41 @@ +import { h, VNode } from "preact"; +import { AnastasisReducerApi, ChallengeFeedback, ChallengeInfo } from "../../hooks/use-anastasis-reducer"; +import { SolveEmailEntry } from "./SolveEmailEntry"; +import { SolvePostEntry } from "./SolvePostEntry"; +import { SolveQuestionEntry } from "./SolveQuestionEntry"; +import { SolveSmsEntry } from "./SolveSmsEntry"; +import { SolveUnsupportedEntry } from "./SolveUnsupportedEntry"; +import { RecoveryReducerProps } from "./index"; + +export function SolveScreen(props: RecoveryReducerProps): VNode { + const chArr = props.recoveryState.recovery_information!.challenges; + const challengeFeedback = props.recoveryState.challenge_feedback ?? {}; + const selectedUuid = props.recoveryState.selected_challenge_uuid!; + const challenges: { + [uuid: string]: ChallengeInfo; + } = {}; + for (const ch of chArr) { + challenges[ch.uuid] = ch; + } + const selectedChallenge = challenges[selectedUuid]; + const dialogMap: Record<string, (p: SolveEntryProps) => h.JSX.Element> = { + question: SolveQuestionEntry, + sms: SolveSmsEntry, + email: SolveEmailEntry, + post: SolvePostEntry, + }; + const SolveDialog = dialogMap[selectedChallenge.type] ?? SolveUnsupportedEntry; + return ( + <SolveDialog + challenge={selectedChallenge} + reducer={props.reducer} + feedback={challengeFeedback[selectedUuid]} /> + ); +} + +export interface SolveEntryProps { + reducer: AnastasisReducerApi; + challenge: ChallengeInfo; + feedback?: ChallengeFeedback; +} + |