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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
/*
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 {
Codec,
buildCodecForObject,
canonicalizeBaseUrl,
codecForBoolean,
codecForMap,
codecForNumber,
codecForString,
codecOptional,
} from "@gnu-taler/taler-util";
export interface UiSettings {
// Where libeufin backend is localted
// default: window.origin without "webui/"
backendBaseURL?: string;
// Shows a button "create random account" in the registration form
// Useful for testing
// default: false
allowRandomAccountCreation?: boolean;
// Create all random accounts with password "123"
// Useful for testing
// default: false
simplePasswordForRandomAccounts?: boolean;
// URL where the user is going to be redirected after
// clicking in Taler Logo
// default: home page
iconLinkURL?: string;
// Mapping for every link shown in the top navitation bar
// - key: link label, what the user will read
// - value: link target, where the user is going to be redirected
// default: empty list
topNavSites?: Record<string, string>;
// When the withdrawal form use the suggested amount the bank
// will send a default value that the user can change.
// default: 10
defaultSuggestedAmount?: number;
}
/**
* Global settings for the bank UI.
*/
const defaultSettings: UiSettings = {
backendBaseURL: buildDefaultBackendBaseURL(),
iconLinkURL: undefined,
simplePasswordForRandomAccounts: false,
allowRandomAccountCreation: false,
topNavSites: {},
defaultSuggestedAmount: 10,
};
const codecForUISettings = (): Codec<UiSettings> =>
buildCodecForObject<UiSettings>()
.property("backendBaseURL", codecOptional(codecForString()))
.property("allowRandomAccountCreation", codecOptional(codecForBoolean()))
.property("defaultSuggestedAmount", codecOptional(codecForNumber()))
.property(
"simplePasswordForRandomAccounts",
codecOptional(codecForBoolean()),
)
.property("iconLinkURL", codecOptional(codecForString()))
.property("topNavSites", codecOptional(codecForMap(codecForString())))
.build("UiSettings");
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 fetchSettings(listener: (s: UiSettings) => void): void {
fetch("./settings.json")
.then((resp) => resp.json())
.then((json) => codecForUISettings().decode(json))
.then((result) =>
listener({
...defaultSettings,
...removeUndefineField(result),
}),
)
.catch((e) => {
console.log("failed to fetch settings", e);
listener(defaultSettings);
});
}
function buildDefaultBackendBaseURL(): string | undefined {
if (typeof window !== "undefined") {
const currentLocation = new URL(
window.location.pathname,
window.location.origin,
).href;
/**
* By default, bank backend serves the html content
* from the /webui root.
*/
return canonicalizeBaseUrl(currentLocation.replace("/webui", ""));
}
throw Error("No default URL");
}
|