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/ChallengeOverviewScreen.tsx | |
parent | 269022a526b670d602ca146f4df02850983bb72e (diff) | |
download | wallet-core-5883d42d800c7b444c59d626bcaa5abca7dc83d0.tar.xz |
add template from merchant backoffice
Diffstat (limited to 'packages/anastasis-webui/src/pages/home/ChallengeOverviewScreen.tsx')
-rw-r--r-- | packages/anastasis-webui/src/pages/home/ChallengeOverviewScreen.tsx | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/packages/anastasis-webui/src/pages/home/ChallengeOverviewScreen.tsx b/packages/anastasis-webui/src/pages/home/ChallengeOverviewScreen.tsx new file mode 100644 index 000000000..1f108ce6d --- /dev/null +++ b/packages/anastasis-webui/src/pages/home/ChallengeOverviewScreen.tsx @@ -0,0 +1,63 @@ +import { h, VNode } from "preact"; +import { RecoveryReducerProps, AnastasisClientFrame } from "./index"; + +export function ChallengeOverviewScreen(props: RecoveryReducerProps): VNode { + const { recoveryState, reducer } = props; + const policies = recoveryState.recovery_information!.policies; + const chArr = recoveryState.recovery_information!.challenges; + const challenges: { + [uuid: string]: { + type: string; + instructions: string; + cost: string; + }; + } = {}; + for (const ch of chArr) { + challenges[ch.uuid] = { + type: ch.type, + cost: ch.cost, + instructions: ch.instructions, + }; + } + return ( + <AnastasisClientFrame title="Recovery: Solve challenges"> + <h2>Policies</h2> + {policies.map((x, i) => { + return ( + <div key={i}> + <h3>Policy #{i + 1}</h3> + {x.map((x, j) => { + const ch = challenges[x.uuid]; + const feedback = recoveryState.challenge_feedback?.[x.uuid]; + return ( + <div key={j} + style={{ + borderLeft: "2px solid gray", + paddingLeft: "0.5em", + borderRadius: "0.5em", + marginTop: "0.5em", + marginBottom: "0.5em", + }} + > + <h4> + {ch.type} ({ch.instructions}) + </h4> + <p>Status: {feedback?.state ?? "unknown"}</p> + {feedback?.state !== "solved" ? ( + <button + onClick={() => reducer.transition("select_challenge", { + uuid: x.uuid, + })} + > + Solve + </button> + ) : null} + </div> + ); + })} + </div> + ); + })} + </AnastasisClientFrame> + ); +} |