From aa6227b2b858d48272129c96fcf3d7fae39bba30 Mon Sep 17 00:00:00 2001 From: Sebastian Date: Thu, 27 Oct 2022 16:06:41 -0300 Subject: [PATCH] showing error field when there is not account yet --- .../src/mui/input/FormLabel.tsx | 6 +- .../src/mui/input/InputBase.tsx | 2 +- .../src/wallet/AddAccount/state.ts | 12 +- .../src/wallet/AddAccount/views.tsx | 194 +++++++++++------- .../src/wallet/DepositPage/state.ts | 11 +- 5 files changed, 134 insertions(+), 91 deletions(-) diff --git a/packages/taler-wallet-webextension/src/mui/input/FormLabel.tsx b/packages/taler-wallet-webextension/src/mui/input/FormLabel.tsx index fb2df1cc3..1d4b5eff5 100644 --- a/packages/taler-wallet-webextension/src/mui/input/FormLabel.tsx +++ b/packages/taler-wallet-webextension/src/mui/input/FormLabel.tsx @@ -68,7 +68,7 @@ export function FormLabel({ return ( ); } diff --git a/packages/taler-wallet-webextension/src/mui/input/InputBase.tsx b/packages/taler-wallet-webextension/src/mui/input/InputBase.tsx index fce82f9d2..80f5bd44e 100644 --- a/packages/taler-wallet-webextension/src/mui/input/InputBase.tsx +++ b/packages/taler-wallet-webextension/src/mui/input/InputBase.tsx @@ -65,7 +65,7 @@ export function InputBaseRoot({ data-multiline={multiline} data-hasStart={!!startAdornment} data-hasEnd={!!endAdornment} - data-error={error} + data-error={!error ? undefined : true} class={[ _class, rootStyle, diff --git a/packages/taler-wallet-webextension/src/wallet/AddAccount/state.ts b/packages/taler-wallet-webextension/src/wallet/AddAccount/state.ts index a9e8dfb30..6c113d732 100644 --- a/packages/taler-wallet-webextension/src/wallet/AddAccount/state.ts +++ b/packages/taler-wallet-webextension/src/wallet/AddAccount/state.ts @@ -67,15 +67,11 @@ export function useComponentState( } const paytoUriError = - payto === "" - ? undefined - : !uri - ? "the uri is not ok" - : found - ? "that account is already present" - : undefined; + found + ? "that account is already present" + : undefined; - const unableToAdd = !type || !alias || paytoUriError; + const unableToAdd = !type || !alias || !!paytoUriError || !uri; return { status: "ready", diff --git a/packages/taler-wallet-webextension/src/wallet/AddAccount/views.tsx b/packages/taler-wallet-webextension/src/wallet/AddAccount/views.tsx index fa7014d70..d6ab7e967 100644 --- a/packages/taler-wallet-webextension/src/wallet/AddAccount/views.tsx +++ b/packages/taler-wallet-webextension/src/wallet/AddAccount/views.tsx @@ -105,7 +105,11 @@ export function ReadyView({ > Cancel - @@ -113,6 +117,118 @@ export function ReadyView({ ); } +function BitcoinAddressAccount({ field }: { field: TextFieldHandler }): VNode { + const { i18n } = useTranslationContext(); + const [value, setValue] = useState(undefined); + const errors = undefinedIfEmpty({ + value: !value ? i18n.str`Can't be empty` : undefined, + }); + return ( + + { + setValue(v); + if (!errors) { + field.onInput(`payto://bitcoin/${value}`); + } + }} + /> + {value !== undefined && errors?.value && ( + {errors?.value}} /> + )} + + ); +} + +function undefinedIfEmpty(obj: T): T | undefined { + return Object.keys(obj).some((k) => (obj as any)[k] !== undefined) + ? obj + : undefined; +} + +function TalerBankAddressAccount({ + field, +}: { + field: TextFieldHandler; +}): VNode { + const { i18n } = useTranslationContext(); + const [host, setHost] = useState(undefined); + const [account, setAccount] = useState(undefined); + const errors = undefinedIfEmpty({ + host: !host ? i18n.str`Can't be empty` : undefined, + account: !account ? i18n.str`Can't be empty` : undefined, + }); + return ( + + { + setHost(v); + if (!errors) { + field.onInput(`payto://x-taler-bank/${host}/${account}`); + } + }} + />{" "} + {host !== undefined && errors?.host && ( + {errors?.host}} /> + )} + { + setAccount(v || ""); + if (!errors) { + field.onInput(`payto://x-taler-bank/${host}/${account}`); + } + }} + />{" "} + {account !== undefined && errors?.account && ( + {errors?.account}} /> + )} + + ); +} + +function IbanAddressAccount({ field }: { field: TextFieldHandler }): VNode { + const { i18n } = useTranslationContext(); + const [value, setValue] = useState(undefined); + const errors = undefinedIfEmpty({ + value: !value ? i18n.str`Can't be empty` : undefined, + }); + return ( + + { + setValue(v); + if (!errors) { + field.onInput(`payto://iba/${value}`); + } + }} + /> + {value !== undefined && errors?.value && ( + {errors?.value}} /> + )} + + ); +} + function CustomFieldByAccountType({ type, field, @@ -120,84 +236,14 @@ function CustomFieldByAccountType({ type: string; field: TextFieldHandler; }): VNode { - const p = parsePaytoUri(field.value); - const parts = !p ? [] : p.targetPath.split("/"); - const initialPart1 = parts.length > 0 ? parts[0] : ""; - const initialPart2 = parts.length > 1 ? parts[1] : ""; - const [part1, setPart1] = useState(initialPart1); - const [part2, setPart2] = useState(initialPart2); - function updateField(): void { - if (part1 && part2) { - field.onInput(`payto://${type}/${part1}/${part2}`); - } else { - if (part1) field.onInput(`payto://${type}/${part1}`); - } - } - if (type === "bitcoin") { - return ( - - {field.error && {field.error}} />} - { - setPart1(v); - updateField(); - }} - /> - - ); + return ; } if (type === "x-taler-bank") { - return ( - - {field.error && {field.error}} />} - { - setPart1(v); - updateField(); - }} - />{" "} - { - setPart2(v); - updateField(); - }} - /> - - ); + return ; } if (type === "iban") { - return ( - - {field.error && {field.error}} />} - { - setPart1(v); - updateField(); - }} - /> - - ); + return ; } return ; } diff --git a/packages/taler-wallet-webextension/src/wallet/DepositPage/state.ts b/packages/taler-wallet-webextension/src/wallet/DepositPage/state.ts index 686cfb4b4..b3a377040 100644 --- a/packages/taler-wallet-webextension/src/wallet/DepositPage/state.ts +++ b/packages/taler-wallet-webextension/src/wallet/DepositPage/state.ts @@ -178,12 +178,11 @@ export function useComponentState( : undefined; const unableToDeposit = - !parsedAmount || - selectedAccount === undefined || - Amounts.isZero(totalToDeposit) || - fee === undefined || - amountError !== undefined; - // console.log(parsedAmount, selectedAccount, fee, totalToDeposit, amountError) + !parsedAmount || //no amount specified + selectedAccount === undefined || //no account selected + Amounts.isZero(totalToDeposit) || //deposit may be zero because of fee + fee === undefined || //no fee calculated yet + amountError !== undefined; //amount field may be invalid async function doSend(): Promise { if (!selectedAccount || !parsedAmount || !currency) return;