/* This file is part of GNU Anastasis (C) 2021-2022 Anastasis SARL GNU Anastasis is free software; you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GNU Anastasis is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with GNU Anastasis; see the file COPYING. If not, see */ import { ChallengeInfo } from "@gnu-taler/anastasis-core"; import { h, VNode } from "preact"; import { useState } from "preact/hooks"; import { AsyncButton } from "../../../components/AsyncButton.js"; import { TextInput } from "../../../components/fields/TextInput.js"; import { useAnastasisContext } from "../../../context/anastasis.js"; import { useTranslator } from "../../../i18n/index.js"; import { AnastasisClientFrame } from "../index.js"; import { SolveOverviewFeedbackDisplay } from "../SolveScreen.js"; import { shouldHideConfirm } from "./helpers.js"; import { AuthMethodSolveProps } from "./index.js"; export function AuthMethodPostSolve({ id }: AuthMethodSolveProps): VNode { const [answer, _setAnswer] = useState("A-"); function setAnswer(str: string): void { //A-12345-678-1234-5678 const unformatted = str .replace(/^A-/, "") .replace(/-/g, "") .toLocaleUpperCase(); let result = `A-${unformatted.substring(0, 5)}`; if (unformatted.length > 5) { result += `-${unformatted.substring(5, 8)}`; } if (unformatted.length > 8) { result += `-${unformatted.substring(8, 12)}`; } if (unformatted.length > 12) { result += `-${unformatted.substring(12)}`; } _setAnswer(result); } const i18n = useTranslator(); const reducer = useAnastasisContext(); if (!reducer) { return (
no reducer in context
); } if (reducer.currentReducerState?.reducer_type !== "recovery") { return (
invalid state
); } if (!reducer.currentReducerState.recovery_information) { return (
no recovery information found
); } if (!reducer.currentReducerState.selected_challenge_uuid) { return (
invalid state
); } const chArr = reducer.currentReducerState.recovery_information.challenges; const challengeFeedback = reducer.currentReducerState.challenge_feedback ?? {}; const selectedUuid = reducer.currentReducerState.selected_challenge_uuid; const challenges: { [uuid: string]: ChallengeInfo; } = {}; for (const ch of chArr) { challenges[ch.uuid] = ch; } const selectedChallenge = challenges[selectedUuid]; const feedback = challengeFeedback[selectedUuid]; async function onNext(): Promise { return reducer?.transition("solve_challenge", { answer: `A-${answer.replace(/^A-/, "").replace(/-/g, "").trim()}`, }); } function onCancel(): void { reducer?.back(); } const error = answer.length > 21 ? i18n`The answer should not be greater than 21 characters.` : undefined; return (

Wait for the answer

{!shouldHideConfirm(feedback) && ( Confirm )}
); }