aboutsummaryrefslogtreecommitdiff
path: root/packages
diff options
context:
space:
mode:
authorSebastian <sebasjm@gmail.com>2022-04-11 11:34:36 -0300
committerSebastian <sebasjm@gmail.com>2022-04-11 11:36:38 -0300
commit2bf8976d887061276df49c105c0527f28b127966 (patch)
tree8c166c7f720aae003eb55d1272044c9dbd2f75cb /packages
parent2bd6dae00d420d3b17a636c206785f06f2f7ae29 (diff)
terms of service stories into its own scenarios (removed from withdraw)
Diffstat (limited to 'packages')
-rw-r--r--packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.stories.tsx179
-rw-r--r--packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.tsx2
2 files changed, 180 insertions, 1 deletions
diff --git a/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.stories.tsx b/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.stories.tsx
new file mode 100644
index 000000000..f24da1e13
--- /dev/null
+++ b/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.stories.tsx
@@ -0,0 +1,179 @@
+/*
+ This file is part of GNU Taler
+ (C) 2021 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/>
+ */
+
+/**
+ *
+ * @author Sebastian Javier Marchano (sebasjm)
+ */
+
+import { createExample } from "../test-utils.js";
+import { termsHtml, termsPdf, termsPlain, termsXml } from "./termsExample.js";
+import { TermsOfServiceSection as TestedComponent } from "./TermsOfServiceSection.js";
+
+function parseFromString(s: string): Document {
+ if (typeof window === "undefined") {
+ return {} as Document;
+ }
+ return new window.DOMParser().parseFromString(s, "text/xml");
+}
+
+export default {
+ title: "cta/terms of service",
+ component: TestedComponent,
+};
+
+export const ReviewingPLAIN = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "plain",
+ content: termsPlain,
+ },
+ status: "new",
+ version: "",
+ },
+ reviewing: true,
+});
+
+export const ReviewingHTML = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "html",
+ href: new URL(`data:text/html;base64,${toBase64(termsHtml)}`),
+ },
+ version: "",
+ status: "new",
+ },
+ reviewing: true,
+});
+
+function toBase64(str: string): string {
+ return btoa(
+ encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function (match, p1) {
+ return String.fromCharCode(parseInt(p1, 16));
+ }),
+ );
+}
+
+export const ReviewingPDF = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "pdf",
+ location: new URL(`data:text/html;base64,${toBase64(termsPdf)}`),
+ },
+ status: "new",
+ version: "",
+ },
+ reviewing: true,
+});
+
+export const ReviewingXML = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ status: "new",
+ version: "",
+ },
+ reviewing: true,
+});
+
+export const NewAccepted = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ status: "new",
+ version: "",
+ },
+ reviewed: true,
+});
+
+export const ShowAgainXML = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ version: "",
+ status: "new",
+ },
+ reviewed: true,
+ reviewing: true,
+});
+
+export const ChangedButNotReviewable = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ version: "",
+ status: "changed",
+ },
+});
+
+export const ChangedAndAllowReview = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ version: "",
+ status: "changed",
+ },
+ onReview: () => null,
+});
+
+export const NewButNotReviewable = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ version: "",
+ status: "new",
+ },
+});
+
+export const NewAndAllowReview = createExample(TestedComponent, {
+ terms: {
+ content: {
+ type: "xml",
+ document: parseFromString(termsXml),
+ },
+ version: "",
+ status: "new",
+ },
+ onReview: () => null,
+});
+
+export const NotFound = createExample(TestedComponent, {
+ terms: {
+ content: undefined,
+ status: "notfound",
+ version: "",
+ },
+});
+
+export const AlreadyAccepted = createExample(TestedComponent, {
+ terms: {
+ status: "accepted",
+ content: undefined,
+ version: "",
+ },
+});
diff --git a/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.tsx b/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.tsx
index b49627689..057144866 100644
--- a/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.tsx
+++ b/packages/taler-wallet-webextension/src/cta/TermsOfServiceSection.tsx
@@ -12,7 +12,7 @@ import {
import { useTranslationContext } from "../context/translation.js";
import { TermsState } from "../utils/index.js";
-interface Props {
+export interface Props {
reviewing: boolean;
reviewed: boolean;
terms: TermsState;