diff options
Diffstat (limited to 'packages/anastasis-webui/src/pages/home/SolvePostEntry.tsx')
-rw-r--r-- | packages/anastasis-webui/src/pages/home/SolvePostEntry.tsx | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/packages/anastasis-webui/src/pages/home/SolvePostEntry.tsx b/packages/anastasis-webui/src/pages/home/SolvePostEntry.tsx new file mode 100644 index 000000000..b11ceed27 --- /dev/null +++ b/packages/anastasis-webui/src/pages/home/SolvePostEntry.tsx @@ -0,0 +1,22 @@ +import { h, VNode } from "preact"; +import { useState } from "preact/hooks"; +import { AnastasisClientFrame, LabeledInput } from "./index"; +import { SolveEntryProps } from "./SolveScreen"; + +export function SolvePostEntry(props: SolveEntryProps): VNode { + const [answer, setAnswer] = useState(""); + const { reducer, challenge, feedback } = props; + const next = (): void => reducer.transition("solve_challenge", { + answer, + }); + return ( + <AnastasisClientFrame + title="Recovery: Solve challenge" + onNext={() => next()} + > + <p>Feedback: {JSON.stringify(feedback)}</p> + <p>{challenge.instructions}</p> + <LabeledInput label="Answer" grabFocus bind={[answer, setAnswer]} /> + </AnastasisClientFrame> + ); +} |