/*
This file is part of GNU Taler
(C) 2021-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
*/
import { canonicalizeBaseUrl } from "@gnu-taler/taler-util";
import { StateUpdater, useState } from "preact/hooks";
import { ValueOrFunction } from "../utils/types.js";
export function useBackendURL(url?: string): [string, StateUpdater] {
const canonUrl = canonicalizeBaseUrl(url ?? calculateRootPath());
const [value, setter] = useSimpleLocalStorage("auditor-base-url", canonUrl);
const checkedSetter = (v: ValueOrFunction) => {
// FIXME: Explain?!
return setter((p) =>
(v instanceof Function ? v(p ?? "") : v).replace(/\/$/, ""),
);
};
return [value!, checkedSetter];
}
function calculateRootPath() {
const rootPath =
typeof window !== undefined
? window.location.origin + window.location.pathname
: "/";
/*
* By default, auditor backend serves the html content
* from the /webui root. This should cover most of the
* cases and the rootPath will be the auditor backend
* URL where the instances are
*/
return rootPath.replace("/spa/", "");
}
function useSimpleLocalStorage(
key: string,
initialValue?: string,
): [string | undefined, StateUpdater] {
const [storedValue, setStoredValue] = useState(
(): string | undefined => {
return typeof window !== "undefined"
? window.localStorage.getItem(key) || initialValue
: initialValue;
},
);
const setValue = (
value?: string | ((val?: string) => string | undefined),
) => {
setStoredValue((p) => {
const toStore = value instanceof Function ? value(p) : value;
if (typeof window !== "undefined") {
if (!toStore) {
window.localStorage.removeItem(key);
} else {
window.localStorage.setItem(key, toStore);
}
}
return toStore;
});
};
return [storedValue, setValue];
}