diff options
author | Nic Eigel <nic@eigel.ch> | 2024-01-14 15:18:12 +0100 |
---|---|---|
committer | Nic Eigel <nic@eigel.ch> | 2024-01-14 15:18:12 +0100 |
commit | 7a201c3b885c5d23bf0fd0f3da32379a49b30c38 (patch) | |
tree | 13f35c4761087b0e6adce39153be5ca03c5c846b /packages/auditor-backoffice-ui/src/components/menu/index.tsx | |
parent | 2be9142ac5f944fbc03186b22ca67e6020187c92 (diff) | |
download | wallet-core-7a201c3b885c5d23bf0fd0f3da32379a49b30c38.tar.gz wallet-core-7a201c3b885c5d23bf0fd0f3da32379a49b30c38.tar.bz2 wallet-core-7a201c3b885c5d23bf0fd0f3da32379a49b30c38.zip |
adding auditor-backoffice-ui
Diffstat (limited to 'packages/auditor-backoffice-ui/src/components/menu/index.tsx')
-rw-r--r-- | packages/auditor-backoffice-ui/src/components/menu/index.tsx | 269 |
1 files changed, 269 insertions, 0 deletions
diff --git a/packages/auditor-backoffice-ui/src/components/menu/index.tsx b/packages/auditor-backoffice-ui/src/components/menu/index.tsx new file mode 100644 index 000000000..03ae3b005 --- /dev/null +++ b/packages/auditor-backoffice-ui/src/components/menu/index.tsx @@ -0,0 +1,269 @@ +/* + This file is part of GNU Taler + (C) 2021-2023 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 { ComponentChildren, Fragment, h, VNode } from "preact"; +import { useEffect, useState } from "preact/hooks"; +import { AdminPaths } from "../../AdminRoutes.js"; +import { InstancePaths } from "../../InstanceRoutes.js"; +import { Notification } from "../../utils/types.js"; +import { NavigationBar } from "./NavigationBar.js"; +import { Sidebar } from "./SideBar.js"; + +function getInstanceTitle(path: string, id: string): string { + switch (path) { + case InstancePaths.settings: + return `${id}: Settings`; + case InstancePaths.order_list: + return `${id}: Orders`; + case InstancePaths.order_new: + return `${id}: New order`; + case InstancePaths.inventory_list: + return `${id}: Inventory`; + case InstancePaths.deposit_confirmation_list: + return `${id}: Deposit Confirmation`; + case InstancePaths.inventory_new: + return `${id}: New product`; + case InstancePaths.inventory_update: + return `${id}: Update product`; + case InstancePaths.reserves_new: + return `${id}: New reserve`; + case InstancePaths.reserves_list: + return `${id}: Reserves`; + case InstancePaths.transfers_list: + return `${id}: Transfers`; + case InstancePaths.transfers_new: + return `${id}: New transfer`; + case InstancePaths.webhooks_list: + return `${id}: Webhooks`; + case InstancePaths.webhooks_new: + return `${id}: New webhook`; + case InstancePaths.webhooks_update: + return `${id}: Update webhook`; + case InstancePaths.otp_devices_list: + return `${id}: otp devices`; + case InstancePaths.otp_devices_new: + return `${id}: New otp devices`; + case InstancePaths.otp_devices_update: + return `${id}: Update otp devices`; + case InstancePaths.templates_new: + return `${id}: New template`; + case InstancePaths.templates_update: + return `${id}: Update template`; + case InstancePaths.templates_list: + return `${id}: Templates`; + case InstancePaths.templates_use: + return `${id}: Use template`; + case InstancePaths.interface: + return `${id}: Interface`; + default: + return ""; + } +} + +function getAdminTitle(path: string, instance: string) { + if (path === AdminPaths.new_instance) return `New instance`; + if (path === AdminPaths.list_instances) return `Instances`; + return getInstanceTitle(path, instance); +} + +interface MenuProps { + title?: string; + path: string; + instance: string; + admin?: boolean; + onLogout?: () => void; + onShowSettings: () => void; + setInstanceName: (s: string) => void; + isPasswordOk: boolean; +} + +function WithTitle({ + title, + children, +}: { + title: string; + children: ComponentChildren; +}): VNode { + useEffect(() => { + document.title = `Taler Backoffice: ${title}`; + }, [title]); + return <Fragment>{children}</Fragment>; +} + +export function Menu({ + onLogout, + onShowSettings, + title, + instance, + path, + admin, + setInstanceName, + isPasswordOk +}: MenuProps): VNode { + const [mobileOpen, setMobileOpen] = useState(false); + + const titleWithSubtitle = title + ? title + : !admin + ? getInstanceTitle(path, instance) + : getAdminTitle(path, instance); + const adminInstance = instance === "default"; + const mimic = admin && !adminInstance; + return ( + <WithTitle title={titleWithSubtitle}> + <div + class={mobileOpen ? "has-aside-mobile-expanded" : ""} + onClick={() => setMobileOpen(false)} + > + <NavigationBar + onMobileMenu={() => setMobileOpen(!mobileOpen)} + title={titleWithSubtitle} + /> + + {onLogout && ( + <Sidebar + onShowSettings={onShowSettings} + onLogout={onLogout} + admin={admin} + mimic={mimic} + instance={instance} + mobile={mobileOpen} + isPasswordOk={isPasswordOk} + /> + )} + + {mimic && ( + <nav class="level" style={{ + zIndex: 100, + position: "fixed", + width: "50%", + marginLeft: "20%" + }}> + <div class="level-item has-text-centered has-background-warning"> + <p class="is-size-5"> + You are viewing the instance <b>"{instance}"</b>.{" "} + <a + href="#/instances" + onClick={(e) => { + setInstanceName("default"); + }} + > + go back + </a> + </p> + </div> + </nav> + )} + </div> + </WithTitle> + ); +} + +interface NotYetReadyAppMenuProps { + title: string; + onShowSettings: () => void; + onLogout?: () => void; + isPasswordOk: boolean; +} + +interface NotifProps { + notification?: Notification; +} +export function NotificationCard({ + notification: n, +}: NotifProps): VNode | null { + if (!n) return null; + return ( + <div class="notification"> + <div class="columns is-vcentered"> + <div class="column is-12"> + <article + class={ + n.type === "ERROR" + ? "message is-danger" + : n.type === "WARN" + ? "message is-warning" + : "message is-info" + } + > + <div class="message-header"> + <p>{n.message}</p> + </div> + {n.description && ( + <div class="message-body"> + <div>{n.description}</div> + {n.details && <pre>{n.details}</pre>} + </div> + )} + </article> + </div> + </div> + </div> + ); +} + +interface NotConnectedAppMenuProps { + title: string; +} +export function NotConnectedAppMenu({ + title, +}: NotConnectedAppMenuProps): VNode { + const [mobileOpen, setMobileOpen] = useState(false); + + useEffect(() => { + document.title = `Taler Backoffice: ${title}`; + }, [title]); + + return ( + <div + class={mobileOpen ? "has-aside-mobile-expanded" : ""} + onClick={() => setMobileOpen(false)} + > + <NavigationBar + onMobileMenu={() => setMobileOpen(!mobileOpen)} + title={title} + /> + </div> + ); +} + +export function NotYetReadyAppMenu({ + onLogout, + onShowSettings, + title, + isPasswordOk +}: NotYetReadyAppMenuProps): VNode { + const [mobileOpen, setMobileOpen] = useState(false); + + useEffect(() => { + document.title = `Taler Backoffice: ${title}`; + }, [title]); + + return ( + <div + class={mobileOpen ? "has-aside-mobile-expanded" : ""} + onClick={() => setMobileOpen(false)} + > + <NavigationBar + onMobileMenu={() => setMobileOpen(!mobileOpen)} + title={title} + /> + {onLogout && ( + <Sidebar onShowSettings={onShowSettings} onLogout={onLogout} instance="" mobile={mobileOpen} isPasswordOk={isPasswordOk} /> + )} + </div> + ); +} |