[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[taler-wallet-core] 67/189: add kyc form, testing vqf
From: |
gnunet |
Subject: |
[taler-wallet-core] 67/189: add kyc form, testing vqf |
Date: |
Fri, 13 Dec 2024 15:25:57 +0100 |
This is an automated email from the git hooks/post-receive script.
sebasjm pushed a commit to branch master
in repository wallet-core.
commit 02ac6ca0b43b0f5ab19771560eda5113afbcf438
Author: Sebastian <sebasjm@gmail.com>
AuthorDate: Mon Dec 2 12:06:24 2024 -0300
add kyc form, testing vqf
---
packages/kyc-ui/build.mjs | 2 +-
packages/kyc-ui/dev.mjs | 2 +-
packages/kyc-ui/src/app.tsx | 8 +-
packages/kyc-ui/src/context/ui-forms.ts | 76 +++++++++++
packages/kyc-ui/src/forms.json | 215 ++++++++++++++++++++++++++++++++
packages/kyc-ui/src/pages/FillForm.tsx | 12 +-
6 files changed, 310 insertions(+), 5 deletions(-)
diff --git a/packages/kyc-ui/build.mjs b/packages/kyc-ui/build.mjs
index cd3825dc9..8286ac4fd 100755
--- a/packages/kyc-ui/build.mjs
+++ b/packages/kyc-ui/build.mjs
@@ -24,7 +24,7 @@ await build({
assets: [{
base: "src",
files: [
- "src/index.html",
+ "src/index.html","src/forms.json",
]
}],
},
diff --git a/packages/kyc-ui/dev.mjs b/packages/kyc-ui/dev.mjs
index 2d7e564e8..821ea80cb 100755
--- a/packages/kyc-ui/dev.mjs
+++ b/packages/kyc-ui/dev.mjs
@@ -27,7 +27,7 @@ const build = initializeDev({
assets: [{
base: "src",
files: [
- "src/index.html",
+ "src/index.html","src/forms.json",
]
}],
},
diff --git a/packages/kyc-ui/src/app.tsx b/packages/kyc-ui/src/app.tsx
index e74249f73..27539ac44 100644
--- a/packages/kyc-ui/src/app.tsx
+++ b/packages/kyc-ui/src/app.tsx
@@ -28,6 +28,7 @@ import {
Loading,
TalerWalletIntegrationBrowserProvider,
TranslationProvider,
+ UiForms,
} from "@gnu-taler/web-util/browser";
import { VNode, h } from "preact";
import { useEffect, useState } from "preact/hooks";
@@ -38,15 +39,18 @@ import { strings } from "./i18n/strings.js";
import { Frame } from "./pages/Frame.js";
import { KycUiSettings, fetchSettings } from "./settings.js";
import { revalidateKycInfo } from "./hooks/kyc.js";
+import { fetchUiForms, UiFormsProvider } from "./context/ui-forms.js";
const WITH_LOCAL_STORAGE_CACHE = false;
export function App(): VNode {
const [settings, setSettings] = useState<KycUiSettings>();
+ const [forms, setForms] = useState<UiForms>();
useEffect(() => {
fetchSettings(setSettings);
+ fetchUiForms(setForms);
}, []);
- if (!settings) return <Loading />;
+ if (!settings || !forms) return <Loading />;
const baseUrl = getInitialBackendBaseURL(settings.backendBaseURL);
return (
@@ -95,7 +99,9 @@ export function App(): VNode {
>
<TalerWalletIntegrationBrowserProvider>
<BrowserHashNavigationProvider>
+ <UiFormsProvider value={forms}>
<Routing />
+ </UiFormsProvider>
</BrowserHashNavigationProvider>
</TalerWalletIntegrationBrowserProvider>
</SWRConfig>
diff --git a/packages/kyc-ui/src/context/ui-forms.ts
b/packages/kyc-ui/src/context/ui-forms.ts
new file mode 100644
index 000000000..3a25234d2
--- /dev/null
+++ b/packages/kyc-ui/src/context/ui-forms.ts
@@ -0,0 +1,76 @@
+/*
+ This file is part of GNU Taler
+ (C) 2022-2024 Taler Systems S.A.
+
+ GNU Taler is free software; you can redistribute it and/or modify it under the
+ terms of the GNU General Public License as published by the Free Software
+ Foundation; either version 3, or (at your option) any later version.
+
+ GNU Taler 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 General Public License for more details.
+
+ You should have received a copy of the GNU General Public License along with
+ GNU Taler; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
+ */
+
+import { codecForUIForms, UiForms } from "@gnu-taler/web-util/browser";
+import { ComponentChildren, createContext, h, VNode } from "preact";
+import { useContext } from "preact/hooks";
+
+/**
+ *
+ * @author Sebastian Javier Marchano (sebasjm)
+ */
+
+export type Type = UiForms;
+
+const defaultForms: UiForms = {
+ forms: [],
+};
+const Context = createContext<Type>(defaultForms);
+
+export type BaseForm = Record<string, unknown>;
+
+export const useUiFormsContext = (): Type => useContext(Context);
+
+export const UiFormsProvider = ({
+ children,
+ value,
+}: {
+ value: UiForms;
+ children: ComponentChildren;
+}): VNode => {
+ return h(Context.Provider, {
+ value,
+ children,
+ });
+};
+
+
+
+function removeUndefineField<T extends object>(obj: T): T {
+ const keys = Object.keys(obj) as Array<keyof T>;
+ return keys.reduce((prev, cur) => {
+ if (typeof prev[cur] === "undefined") {
+ delete prev[cur];
+ }
+ return prev;
+ }, obj);
+}
+
+export function fetchUiForms(listener: (s: UiForms) => void): void {
+ fetch("./forms.json")
+ .then((resp) => resp.json())
+ .then((json) => codecForUIForms().decode(json))
+ .then((result) =>
+ listener({
+ ...defaultForms,
+ ...removeUndefineField(result),
+ }),
+ )
+ .catch((e) => {
+ console.log("failed to fetch forms", e);
+ listener(defaultForms);
+ });
+}
diff --git a/packages/kyc-ui/src/forms.json b/packages/kyc-ui/src/forms.json
new file mode 100644
index 000000000..b0c198574
--- /dev/null
+++ b/packages/kyc-ui/src/forms.json
@@ -0,0 +1,215 @@
+{
+ "forms": [
+ {
+ "label": "VQF starting form",
+ "id": "vqf-type",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "Information on the beneficial owner of the assets and/or
controlling person",
+ "description": "Establishment of the beneficial owner of the
assets and/or controlling person",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "a natural person and there are no doubts that
this person is the sole beneficial owner of the assets",
+ "value": "natural"
+ },
+ {
+ "label": "a foundation (or a similar construct; incl.
underlying companies)",
+ "value": "foundation"
+ },
+ {
+ "label": "an operation legal entity or partnership",
+ "value": "legal-entity"
+ },
+ {
+ "label": "a trust (incl. underlying companies)",
+ "value": "trust"
+ },
+ {
+ "label": "a life insurance policy with separately managed
accounts/securities accounts",
+ "value": "insurance"
+ },
+ {
+ "label": "all other cases",
+ "value": "other"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ },
+ {
+ "label": "VQF natural person form",
+ "id": "vqf-natural",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "Natural person form",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "natural",
+ "value": "natural"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ },
+ {
+ "label": "VQF legal entity form",
+ "id": "vqf-legal-entity",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "Legal entity form",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "legal entity",
+ "value": "natural"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ },
+ {
+ "label": "VQF foundation form",
+ "id": "vqf-foundation",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "foundation form",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "foundation",
+ "value": "natural"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ },
+ {
+ "label": "VQF trust form",
+ "id": "vqf-trust",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "Natural trust form",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "trust",
+ "value": "natural"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ },
+ {
+ "label": "VQF insurance form",
+ "id": "vqf-insurance",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "insurance form",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "insurance",
+ "value": "natural"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ },
+ {
+ "label": "VQF other form",
+ "id": "vqf-other",
+ "version": 1,
+ "config": {
+ "type": "double-column",
+ "design": [
+ {
+ "title": "other form",
+ "fields": [
+ {
+ "type": "choiceStacked",
+ "id": "LEGAL_ENTITY_TYPE",
+ "label": "The customer is",
+ "required": true,
+ "choices": [
+ {
+ "label": "other",
+ "value": "natural"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ }
+ ],
+ "not_yet_supported": []
+}
diff --git a/packages/kyc-ui/src/pages/FillForm.tsx
b/packages/kyc-ui/src/pages/FillForm.tsx
index 0b691dc11..52b893e40 100644
--- a/packages/kyc-ui/src/pages/FillForm.tsx
+++ b/packages/kyc-ui/src/pages/FillForm.tsx
@@ -43,6 +43,7 @@ import {
validateRequiredFields,
} from "../hooks/form.js";
import { undefinedIfEmpty } from "./Start.js";
+import { useUiFormsContext } from "../context/ui-forms.js";
type Props = {
token: AccessToken;
@@ -80,14 +81,21 @@ export function FillForm({
const customForm =
requirement.context && "form" in requirement.context
? ({
- id: "by-context",
+ id: (requirement.context.form as any).id,
config: requirement.context.form,
label: "Officer defined form",
version: 1,
} as FormMetadata)
: undefined;
- const theForm = searchForm(i18n, customForm ? [customForm] : [], formId,
requirement.context);
+ const { forms } = useUiFormsContext();
+ const allForms = customForm ? [...forms, customForm] : forms
+ const theForm = searchForm(
+ i18n,
+ allForms,
+ formId,
+ requirement.context,
+ );
if (!theForm) {
return <div>form with id {formId} not found</div>;
}
--
To stop receiving notification emails like this one, please contact
gnunet@gnunet.org.
- [taler-wallet-core] 56/189: Translated using Weblate (German), (continued)
- [taler-wallet-core] 56/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 61/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 63/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 64/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 60/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 62/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 66/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 75/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 58/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 65/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 67/189: add kyc form, testing vqf,
gnunet <=
- [taler-wallet-core] 68/189: fix program input interface, gnunet, 2024/12/13
- [taler-wallet-core] 72/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 69/189: test using multiple form in kyc measures, gnunet, 2024/12/13
- [taler-wallet-core] 77/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 88/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 98/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 78/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 76/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 70/189: Translated using Weblate (German), gnunet, 2024/12/13
- [taler-wallet-core] 73/189: Translated using Weblate (German), gnunet, 2024/12/13