summaryrefslogtreecommitdiff
path: root/packages/taler-wallet-webextension/src/wallet/Settings.stories.tsx
blob: cd43c45265be4e4d0b88ce3834a7f69313934807 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/*
 This file is part of GNU Taler
 (C) 2022 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 * as tests from "@gnu-taler/web-util/testing";
import { SettingsView as TestedComponent } from "./Settings.js";
import { WalletCoreVersion } from "@gnu-taler/taler-util";

export default {
  title: "settings",
  component: TestedComponent,
  argTypes: {
    setDeviceName: () => Promise.resolve(),
  },
};

const version = {
  coreVersion: {
    exchange: "12:0:0",
    merchant: "2:0:1",
    bank: "0:0:0",
    hash: "d439c3e1bc743f2aa47de4457953dba6ecb0e20f",
    version: "1:2:3",
    devMode: false,
    bankConversionApiRange: "0:0:0",
    bankIntegrationApiRange: "0:0:0",
    corebankApiRange: "0:0:0",
    implementationGitHash: "d439c3e1bc743f2aa47de4457953dba6ecb0e20f",
    implementationSemver: "0.9.0-dev.1",
  } satisfies WalletCoreVersion,
  webexVersion: {
    version: "0.9.0.13",
    hash: "d439c3e1bc743f2aa47de4457953dba6ecb0e20f",
  },
};

export const AllOff = tests.createExample(TestedComponent, {
  deviceName: "this-is-the-device-name",
  advanceToggle: { value: false, button: {} },
  autoOpenToggle: { value: false, button: {} },
  langToggle: { value: false, button: {} },
  setDeviceName: () => Promise.resolve(),
  ...version,
});

export const OneChecked = tests.createExample(TestedComponent, {
  deviceName: "this-is-the-device-name",
  advanceToggle: { value: false, button: {} },
  autoOpenToggle: { value: false, button: {} },
  langToggle: { value: false, button: {} },
  setDeviceName: () => Promise.resolve(),
  ...version,
});

export const WithOneExchange = tests.createExample(TestedComponent, {
  deviceName: "this-is-the-device-name",
  advanceToggle: { value: false, button: {} },
  autoOpenToggle: { value: false, button: {} },
  langToggle: { value: false, button: {} },
  setDeviceName: () => Promise.resolve(),
  ...version,
});

export const WithExchangeInDifferentState = tests.createExample(
  TestedComponent,
  {
    deviceName: "this-is-the-device-name",
    advanceToggle: { value: false, button: {} },
    autoOpenToggle: { value: false, button: {} },
    langToggle: { value: false, button: {} },
    setDeviceName: () => Promise.resolve(),
    ...version,
  },
);