UNPKG

@allma/admin-shell

Version:

The web-based administration panel for the Allma platform.

1,298 lines (1,268 loc) 614 kB
'use client' var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __commonJS = (cb, mod) => function __require() { return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; }; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); // ../../node_modules/@babel/runtime/helpers/extends.js var require_extends = __commonJS({ "../../node_modules/@babel/runtime/helpers/extends.js"(exports, module) { "use strict"; function _extends23() { return module.exports = _extends23 = Object.assign ? Object.assign.bind() : function(n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, module.exports.__esModule = true, module.exports["default"] = module.exports, _extends23.apply(null, arguments); } module.exports = _extends23, module.exports.__esModule = true, module.exports["default"] = module.exports; } }); // ../../node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js var require_objectWithoutPropertiesLoose = __commonJS({ "../../node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js"(exports, module) { "use strict"; function _objectWithoutPropertiesLoose12(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; } module.exports = _objectWithoutPropertiesLoose12, module.exports.__esModule = true, module.exports["default"] = module.exports; } }); // ../../node_modules/@babel/runtime/helpers/objectDestructuringEmpty.js var require_objectDestructuringEmpty = __commonJS({ "../../node_modules/@babel/runtime/helpers/objectDestructuringEmpty.js"(exports, module) { "use strict"; function _objectDestructuringEmpty2(t) { if (null == t) throw new TypeError("Cannot destructure " + t); } module.exports = _objectDestructuringEmpty2, module.exports.__esModule = true, module.exports["default"] = module.exports; } }); // src/createAllmaAdminApp.tsx import React14 from "react"; import ReactDOM from "react-dom/client"; import { BrowserRouter } from "react-router-dom"; import { MantineProvider } from "@mantine/core"; import { Notifications } from "@mantine/notifications"; import { QueryClient, QueryClientProvider } from "@tanstack/react-query"; import { ReactQueryDevtools } from "@tanstack/react-query-devtools"; import { ModalsProvider } from "@mantine/modals"; import { Amplify } from "aws-amplify"; import "@aws-amplify/ui-react/styles.css"; import "@mantine/core/styles.css"; import "@mantine/notifications/styles.css"; import { Authenticator as Authenticator2 } from "@aws-amplify/ui-react"; // src/AuthenticatedApp.tsx import { useRoutes, Navigate } from "react-router-dom"; import { Container as Container3, Paper as Paper20, Title as Title14, Button as Button25, Loader as Loader6, Group as Group39, Text as Text44 } from "@mantine/core"; import { IconAlertCircle as IconAlertCircle15, IconGauge as IconGauge2, IconListDetails as IconListDetails2, IconActivity as IconActivity2, IconPrompt as IconPrompt2, IconTemplate as IconTemplate3, IconPlugConnected as IconPlugConnected3 } from "@tabler/icons-react"; import { useAuthenticator as useAuthenticator2, Authenticator } from "@aws-amplify/ui-react"; import { ADMIN_COGNITO_GROUP_NAME } from "@allma/core-sdk"; // src/hooks/useAdminAuth.ts import { useQuery } from "@tanstack/react-query"; import { fetchAuthSession } from "aws-amplify/auth"; import { AdminUserPermissionsSchema, getDefaultPermissionsForRole } from "@allma/core-types"; import { CUSTOM_ADMIN_ROLES_ATTRIBUTE } from "@allma/core-sdk"; async function fetchAuthContext() { try { const session = await fetchAuthSession(); const idToken = session.tokens?.idToken; if (!idToken) { throw new Error("Not authenticated. No ID token found."); } const claims = idToken.payload; const cognitoGroups = claims["cognito:groups"] || []; const customRolesString = claims[CUSTOM_ADMIN_ROLES_ATTRIBUTE]; let roles = []; let explicitPermissions = []; if (customRolesString) { try { const parsed = JSON.parse(customRolesString); const validationResult = AdminUserPermissionsSchema.safeParse(parsed); if (validationResult.success) { roles = validationResult.data.roles ?? []; explicitPermissions = validationResult.data.permissions ?? []; } else { console.warn("Could not parse custom:admin_roles attribute", validationResult.error); } } catch (e) { console.error("Failed to JSON.parse custom:admin_roles attribute", e); } } const effectivePermissions = new Set(explicitPermissions); roles.forEach((role) => { getDefaultPermissionsForRole(role).forEach((p) => effectivePermissions.add(p)); }); const isSuperAdmin = roles.includes("SUPER_ADMIN"); return { userId: claims.sub, username: claims.email || claims.username, cognitoGroups, roles, permissions: Array.from(effectivePermissions), hasPermission: (permission) => isSuperAdmin || effectivePermissions.has(permission) }; } catch (err) { console.error("Error fetching auth context:", err); throw new Error(err.message || "Failed to fetch user session."); } } function useAdminAuth() { const { data, isLoading, error, isError } = useQuery({ queryKey: ["adminAuthContext"], queryFn: fetchAuthContext, staleTime: 1e3 * 60 * 5, // Cache for 5 minutes retry: false // Don't retry on auth errors }); return { authContext: data, isLoading, error, isError }; } // src/features/layout/AdminLayout.tsx import { useState, useEffect } from "react"; import { Link, useLocation } from "react-router-dom"; import { AppShell, Burger, Group, NavLink, ScrollArea, Title, Text, ActionIcon, useMantineColorScheme, Tooltip, Stack, Image } from "@mantine/core"; import { IconLogout, IconSun, IconMoon, IconLayoutSidebarLeftCollapse, IconLayoutSidebarRightExpand } from "@tabler/icons-react"; import { useAuthenticator } from "@aws-amplify/ui-react"; import { useLocalStorage } from "@mantine/hooks"; // assets/powered-by-logo.png var powered_by_logo_default = ""; // src/features/layout/AdminLayout.tsx import { jsx, jsxs } from "react/jsx-runtime"; function AdminLayout({ navItems, children }) { const [opened, setOpened] = useState(false); const [navbarCollapsed, setNavbarCollapsed] = useLocalStorage({ key: "allma-admin-navbar-collapsed", defaultValue: false }); const location = useLocation(); const { signOut, user } = useAuthenticator(); const { authContext } = useAdminAuth(); const { colorScheme, setColorScheme } = useMantineColorScheme(); const [appTitle, setAppTitle] = useState("ALLMA Admin"); useEffect(() => { if (document.title && document.title.trim().length > 0) { setAppTitle(document.title); } }, []); return /* @__PURE__ */ jsxs( AppShell, { padding: "md", navbar: { width: navbarCollapsed ? 60 : 220, breakpoint: "sm", collapsed: { mobile: !opened } }, header: { height: 60 }, children: [ /* @__PURE__ */ jsx(AppShell.Header, { children: /* @__PURE__ */ jsxs(Group, { h: "100%", px: "md", justify: "space-between", children: [ /* @__PURE__ */ jsxs(Group, { children: [ /* @__PURE__ */ jsx(Burger, { opened, onClick: () => setOpened((o) => !o), hiddenFrom: "sm", size: "sm" }), /* @__PURE__ */ jsx( ActionIcon, { onClick: () => setNavbarCollapsed((c) => !c), variant: "default", size: "lg", visibleFrom: "sm", "aria-label": navbarCollapsed ? "Expand sidebar" : "Collapse sidebar", children: navbarCollapsed ? /* @__PURE__ */ jsx(IconLayoutSidebarRightExpand, {}) : /* @__PURE__ */ jsx(IconLayoutSidebarLeftCollapse, {}) } ), /* @__PURE__ */ jsx(Title, { order: 3, children: appTitle }) ] }), /* @__PURE__ */ jsxs(Group, { children: [ /* @__PURE__ */ jsx(Text, { size: "sm", children: user?.signInDetails?.loginId }), /* @__PURE__ */ jsx(ActionIcon, { onClick: () => setColorScheme(colorScheme === "dark" ? "light" : "dark"), variant: "default", "aria-label": "Toggle color scheme", children: colorScheme === "dark" ? /* @__PURE__ */ jsx(IconSun, { size: "1rem" }) : /* @__PURE__ */ jsx(IconMoon, { size: "1rem" }) }), /* @__PURE__ */ jsx(ActionIcon, { onClick: () => signOut(), variant: "default", title: "Sign Out", children: /* @__PURE__ */ jsx(IconLogout, { size: "1rem" }) }) ] }) ] }) }), /* @__PURE__ */ jsx(AppShell.Navbar, { p: navbarCollapsed ? "xs" : "md", children: /* @__PURE__ */ jsx(ScrollArea, { children: /* @__PURE__ */ jsx(Stack, { gap: "xs", children: navItems.map((link) => { const Icon = link.icon; const navLinkComponent = /* @__PURE__ */ jsx( NavLink, { label: !navbarCollapsed ? link.label : void 0, leftSection: Icon ? /* @__PURE__ */ jsx(Icon, { size: 16 }) : void 0, component: Link, to: link.path, onClick: () => setOpened(false), active: location.pathname.startsWith(link.path) }, link.path ); if (navbarCollapsed) { return /* @__PURE__ */ jsx( Tooltip, { label: link.label, position: "right", withArrow: true, children: navLinkComponent }, link.path ); } return navLinkComponent; }) }) }) }), /* @__PURE__ */ jsxs(AppShell.Main, { style: { display: "flex", flexDirection: "column", minHeight: "100vh" }, children: [ /* @__PURE__ */ jsx("div", { style: { flex: 1 }, children }), /* @__PURE__ */ jsx(Group, { justify: "flex-end", mt: "xl", pt: "lg", pb: "sm", px: "md", children: /* @__PURE__ */ jsxs( Group, { component: "a", href: "https://allma.dev", target: "_blank", rel: "noopener noreferrer", gap: "xs", align: "center", opacity: 0.6, style: { textDecoration: "none", cursor: "pointer" }, children: [ /* @__PURE__ */ jsx(Text, { size: "xs", c: "dimmed", fw: 500, children: "Powered by" }), /* @__PURE__ */ jsx( Image, { src: powered_by_logo_default, h: 22, w: "auto", fit: "contain", alt: "Logo" } ) ] } ) }) ] }) ] } ); } // src/AuthenticatedApp.tsx import { AdminPermission } from "@allma/core-types"; // src/features/dashboard/DashboardPage.tsx import { SimpleGrid, Paper as Paper3, Title as Title3, Text as Text3, Group as Group4, Alert, useMantineTheme as useMantineTheme2, Table } from "@mantine/core"; // ../ui-components/dist/index.mjs import { Paper, Title as Title2, Box, Group as Group2, Stack as Stack2, LoadingOverlay } from "@mantine/core"; import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime"; import { useState as useState4, useEffect as useEffect6 } from "react"; import { useMantineColorScheme as useMantineColorScheme2, JsonInput, Group as Group22, ActionIcon as ActionIcon2, Tooltip as Tooltip2, Stack as Stack22, Paper as Paper2, Button, useMantineTheme, Code } from "@mantine/core"; import { IconPencil, IconDeviceFloppy, IconX } from "@tabler/icons-react"; // ../../node_modules/@uiw/react-json-view/esm/index.js var import_extends22 = __toESM(require_extends()); var import_objectWithoutPropertiesLoose11 = __toESM(require_objectWithoutPropertiesLoose()); import { forwardRef as forwardRef2 } from "react"; // ../../node_modules/@uiw/react-json-view/esm/store.js var import_extends7 = __toESM(require_extends()); import React3, { createContext as createContext6, useContext as useContext6, useEffect as useEffect2, useReducer as useReducer6 } from "react"; // ../../node_modules/@uiw/react-json-view/esm/store/ShowTools.js var import_extends = __toESM(require_extends()); import { createContext, useContext, useReducer } from "react"; import { jsx as _jsx } from "react/jsx-runtime"; var initialState = {}; var Context = /* @__PURE__ */ createContext(initialState); var reducer = (state, action) => (0, import_extends.default)({}, state, action); var useShowToolsStore = () => { return useContext(Context); }; var DispatchShowTools = /* @__PURE__ */ createContext(() => { }); DispatchShowTools.displayName = "JVR.DispatchShowTools"; function useShowTools() { return useReducer(reducer, initialState); } function useShowToolsDispatch() { return useContext(DispatchShowTools); } var ShowTools = (_ref) => { var { initial, dispatch, children } = _ref; return /* @__PURE__ */ _jsx(Context.Provider, { value: initial, children: /* @__PURE__ */ _jsx(DispatchShowTools.Provider, { value: dispatch, children }) }); }; ShowTools.displayName = "JVR.ShowTools"; // ../../node_modules/@uiw/react-json-view/esm/store/Expands.js var import_extends2 = __toESM(require_extends()); import { createContext as createContext2, useContext as useContext2, useReducer as useReducer2 } from "react"; import { jsx as _jsx2 } from "react/jsx-runtime"; var initialState2 = {}; var Context2 = /* @__PURE__ */ createContext2(initialState2); var reducer2 = (state, action) => (0, import_extends2.default)({}, state, action); var useExpandsStore = () => { return useContext2(Context2); }; var DispatchExpands = /* @__PURE__ */ createContext2(() => { }); DispatchExpands.displayName = "JVR.DispatchExpands"; function useExpands() { return useReducer2(reducer2, initialState2); } function useExpandsDispatch() { return useContext2(DispatchExpands); } var Expands = (_ref) => { var { initial, dispatch, children } = _ref; return /* @__PURE__ */ _jsx2(Context2.Provider, { value: initial, children: /* @__PURE__ */ _jsx2(DispatchExpands.Provider, { value: dispatch, children }) }); }; Expands.displayName = "JVR.Expands"; // ../../node_modules/@uiw/react-json-view/esm/store/Types.js var import_extends3 = __toESM(require_extends()); import { createContext as createContext3, useContext as useContext3, useReducer as useReducer3 } from "react"; import { jsx as _jsx3 } from "react/jsx-runtime"; var initialState3 = { Str: { as: "span", "data-type": "string", style: { color: "var(--w-rjv-type-string-color, #cb4b16)" }, className: "w-rjv-type", children: "string" }, Url: { as: "a", style: { color: "var(--w-rjv-type-url-color, #0969da)" }, "data-type": "url", className: "w-rjv-type", children: "url" }, Undefined: { style: { color: "var(--w-rjv-type-undefined-color, #586e75)" }, as: "span", "data-type": "undefined", className: "w-rjv-type", children: "undefined" }, Null: { style: { color: "var(--w-rjv-type-null-color, #d33682)" }, as: "span", "data-type": "null", className: "w-rjv-type", children: "null" }, Map: { style: { color: "var(--w-rjv-type-map-color, #268bd2)", marginRight: 3 }, as: "span", "data-type": "map", className: "w-rjv-type", children: "Map" }, Nan: { style: { color: "var(--w-rjv-type-nan-color, #859900)" }, as: "span", "data-type": "nan", className: "w-rjv-type", children: "NaN" }, Bigint: { style: { color: "var(--w-rjv-type-bigint-color, #268bd2)" }, as: "span", "data-type": "bigint", className: "w-rjv-type", children: "bigint" }, Int: { style: { color: "var(--w-rjv-type-int-color, #268bd2)" }, as: "span", "data-type": "int", className: "w-rjv-type", children: "int" }, Set: { style: { color: "var(--w-rjv-type-set-color, #268bd2)", marginRight: 3 }, as: "span", "data-type": "set", className: "w-rjv-type", children: "Set" }, Float: { style: { color: "var(--w-rjv-type-float-color, #859900)" }, as: "span", "data-type": "float", className: "w-rjv-type", children: "float" }, True: { style: { color: "var(--w-rjv-type-boolean-color, #2aa198)" }, as: "span", "data-type": "bool", className: "w-rjv-type", children: "bool" }, False: { style: { color: "var(--w-rjv-type-boolean-color, #2aa198)" }, as: "span", "data-type": "bool", className: "w-rjv-type", children: "bool" }, Date: { style: { color: "var(--w-rjv-type-date-color, #268bd2)" }, as: "span", "data-type": "date", className: "w-rjv-type", children: "date" } }; var Context3 = /* @__PURE__ */ createContext3(initialState3); var reducer3 = (state, action) => (0, import_extends3.default)({}, state, action); var useTypesStore = () => { return useContext3(Context3); }; var DispatchTypes = /* @__PURE__ */ createContext3(() => { }); DispatchTypes.displayName = "JVR.DispatchTypes"; function useTypes() { return useReducer3(reducer3, initialState3); } function useTypesDispatch() { return useContext3(DispatchTypes); } function Types(_ref) { var { initial, dispatch, children } = _ref; return /* @__PURE__ */ _jsx3(Context3.Provider, { value: initial, children: /* @__PURE__ */ _jsx3(DispatchTypes.Provider, { value: dispatch, children }) }); } Types.displayName = "JVR.Types"; // ../../node_modules/@uiw/react-json-view/esm/store/Symbols.js var import_extends5 = __toESM(require_extends()); import { createContext as createContext4, useContext as useContext4, useReducer as useReducer4 } from "react"; // ../../node_modules/@uiw/react-json-view/esm/arrow/TriangleArrow.js var import_extends4 = __toESM(require_extends()); var import_objectWithoutPropertiesLoose = __toESM(require_objectWithoutPropertiesLoose()); import React from "react"; import { jsx as _jsx4 } from "react/jsx-runtime"; var _excluded = ["style"]; function TriangleArrow(props) { var { style } = props, reset = (0, import_objectWithoutPropertiesLoose.default)(props, _excluded); var defaultStyle = (0, import_extends4.default)({ cursor: "pointer", height: "1em", width: "1em", userSelect: "none", display: "inline-flex" }, style); return /* @__PURE__ */ _jsx4("svg", (0, import_extends4.default)({ viewBox: "0 0 24 24", fill: "var(--w-rjv-arrow-color, currentColor)", style: defaultStyle }, reset, { children: /* @__PURE__ */ _jsx4("path", { d: "M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z" }) })); } TriangleArrow.displayName = "JVR.TriangleArrow"; // ../../node_modules/@uiw/react-json-view/esm/store/Symbols.js import { jsx as _jsx5 } from "react/jsx-runtime"; var initialState4 = { Arrow: { as: "span", className: "w-rjv-arrow", style: { transform: "rotate(0deg)", transition: "all 0.3s" }, children: /* @__PURE__ */ _jsx5(TriangleArrow, {}) }, Colon: { as: "span", style: { color: "var(--w-rjv-colon-color, var(--w-rjv-color))", marginLeft: 0, marginRight: 2 }, className: "w-rjv-colon", children: ":" }, Quote: { as: "span", style: { color: "var(--w-rjv-quotes-color, #236a7c)" }, className: "w-rjv-quotes", children: '"' }, ValueQuote: { as: "span", style: { color: "var(--w-rjv-quotes-string-color, #cb4b16)" }, className: "w-rjv-quotes", children: '"' }, BracketsLeft: { as: "span", style: { color: "var(--w-rjv-brackets-color, #236a7c)" }, className: "w-rjv-brackets-start", children: "[" }, BracketsRight: { as: "span", style: { color: "var(--w-rjv-brackets-color, #236a7c)" }, className: "w-rjv-brackets-end", children: "]" }, BraceLeft: { as: "span", style: { color: "var(--w-rjv-curlybraces-color, #236a7c)" }, className: "w-rjv-curlybraces-start", children: "{" }, BraceRight: { as: "span", style: { color: "var(--w-rjv-curlybraces-color, #236a7c)" }, className: "w-rjv-curlybraces-end", children: "}" } }; var Context4 = /* @__PURE__ */ createContext4(initialState4); var reducer4 = (state, action) => (0, import_extends5.default)({}, state, action); var useSymbolsStore = () => { return useContext4(Context4); }; var DispatchSymbols = /* @__PURE__ */ createContext4(() => { }); DispatchSymbols.displayName = "JVR.DispatchSymbols"; function useSymbols() { return useReducer4(reducer4, initialState4); } function useSymbolsDispatch() { return useContext4(DispatchSymbols); } var Symbols = (_ref) => { var { initial, dispatch, children } = _ref; return /* @__PURE__ */ _jsx5(Context4.Provider, { value: initial, children: /* @__PURE__ */ _jsx5(DispatchSymbols.Provider, { value: dispatch, children }) }); }; Symbols.displayName = "JVR.Symbols"; // ../../node_modules/@uiw/react-json-view/esm/store/Section.js var import_extends6 = __toESM(require_extends()); import React2, { createContext as createContext5, useContext as useContext5, useReducer as useReducer5 } from "react"; import { jsx as _jsx6 } from "react/jsx-runtime"; var initialState5 = { Copied: { className: "w-rjv-copied", style: { height: "1em", width: "1em", cursor: "pointer", verticalAlign: "middle", marginLeft: 5 } }, CountInfo: { as: "span", className: "w-rjv-object-size", style: { color: "var(--w-rjv-info-color, #0000004d)", paddingLeft: 8, fontStyle: "italic" } }, CountInfoExtra: { as: "span", className: "w-rjv-object-extra", style: { paddingLeft: 8 } }, Ellipsis: { as: "span", style: { cursor: "pointer", color: "var(--w-rjv-ellipsis-color, #cb4b16)", userSelect: "none" }, className: "w-rjv-ellipsis", children: "..." }, Row: { as: "div", className: "w-rjv-line" }, KeyName: { as: "span", className: "w-rjv-object-key" } }; var Context5 = /* @__PURE__ */ createContext5(initialState5); var reducer5 = (state, action) => (0, import_extends6.default)({}, state, action); var useSectionStore = () => { return useContext5(Context5); }; var DispatchSection = /* @__PURE__ */ createContext5(() => { }); DispatchSection.displayName = "JVR.DispatchSection"; function useSection() { return useReducer5(reducer5, initialState5); } function useSectionDispatch() { return useContext5(DispatchSection); } var Section = (_ref) => { var { initial, dispatch, children } = _ref; return /* @__PURE__ */ _jsx6(Context5.Provider, { value: initial, children: /* @__PURE__ */ _jsx6(DispatchSection.Provider, { value: dispatch, children }) }); }; Section.displayName = "JVR.Section"; // ../../node_modules/@uiw/react-json-view/esm/store.js import { jsx as _jsx7 } from "react/jsx-runtime"; var initialState6 = { objectSortKeys: false, indentWidth: 15 }; var Context6 = /* @__PURE__ */ createContext6(initialState6); Context6.displayName = "JVR.Context"; var DispatchContext = /* @__PURE__ */ createContext6(() => { }); DispatchContext.displayName = "JVR.DispatchContext"; function reducer6(state, action) { return (0, import_extends7.default)({}, state, action); } var useStore = () => { return useContext6(Context6); }; var Provider = (_ref) => { var { children, initialState: init, initialTypes } = _ref; var [state, dispatch] = useReducer6(reducer6, Object.assign({}, initialState6, init)); var [showTools, showToolsDispatch] = useShowTools(); var [expands, expandsDispatch] = useExpands(); var [types, typesDispatch] = useTypes(); var [symbols, symbolsDispatch] = useSymbols(); var [section, sectionDispatch] = useSection(); useEffect2(() => dispatch((0, import_extends7.default)({}, init)), [init]); return /* @__PURE__ */ _jsx7(Context6.Provider, { value: state, children: /* @__PURE__ */ _jsx7(DispatchContext.Provider, { value: dispatch, children: /* @__PURE__ */ _jsx7(ShowTools, { initial: showTools, dispatch: showToolsDispatch, children: /* @__PURE__ */ _jsx7(Expands, { initial: expands, dispatch: expandsDispatch, children: /* @__PURE__ */ _jsx7(Types, { initial: (0, import_extends7.default)({}, types, initialTypes), dispatch: typesDispatch, children: /* @__PURE__ */ _jsx7(Symbols, { initial: symbols, dispatch: symbolsDispatch, children: /* @__PURE__ */ _jsx7(Section, { initial: section, dispatch: sectionDispatch, children }) }) }) }) }) }) }); }; Provider.displayName = "JVR.Provider"; // ../../node_modules/@uiw/react-json-view/esm/Container.js var import_extends21 = __toESM(require_extends()); var import_objectWithoutPropertiesLoose10 = __toESM(require_objectWithoutPropertiesLoose()); import React4, { forwardRef } from "react"; // ../../node_modules/@uiw/react-json-view/esm/comps/NestedClose.js var import_extends9 = __toESM(require_extends()); // ../../node_modules/@uiw/react-json-view/esm/symbol/index.js var import_objectDestructuringEmpty = __toESM(require_objectDestructuringEmpty()); var import_extends8 = __toESM(require_extends()); var import_objectWithoutPropertiesLoose2 = __toESM(require_objectWithoutPropertiesLoose()); import { jsx as _jsx8 } from "react/jsx-runtime"; var _excluded2 = ["isNumber", "value", "parentValue", "keyName", "keys"]; var _excluded22 = ["as", "render"]; var _excluded3 = ["as", "render"]; var _excluded4 = ["as", "render"]; var _excluded5 = ["as", "style", "render"]; var _excluded6 = ["as", "render"]; var _excluded7 = ["as", "render"]; var _excluded8 = ["as", "render"]; var _excluded9 = ["as", "render"]; var Quote = (props) => { var { Quote: Comp = {} } = useSymbolsStore(); var { isNumber, value, parentValue, keyName, keys } = props, other = (0, import_objectWithoutPropertiesLoose2.default)(props, _excluded2); if (isNumber) return null; var { as, render } = Comp, reset = (0, import_objectWithoutPropertiesLoose2.default)(Comp, _excluded22); var Elm = as || "span"; var elmProps = (0, import_extends8.default)({}, other, reset); var result = { value, parentValue, keyName, keys: keys || (keyName ? [keyName] : []) }; var child = render && typeof render === "function" && render(elmProps, result); if (child) return child; return /* @__PURE__ */ _jsx8(Elm, (0, import_extends8.default)({}, elmProps)); }; Quote.displayName = "JVR.Quote"; var ValueQuote = (props) => { var { ValueQuote: Comp = {} } = useSymbolsStore(); var other = (0, import_extends8.default)({}, ((0, import_objectDestructuringEmpty.default)(props), props)); var { as, render } = Comp, reset = (0, import_objectWithoutPropertiesLoose2.default)(Comp, _excluded3); var Elm = as || "span"; var elmProps = (0, import_extends8.default)({}, other, reset); var child = render && typeof render === "function" && render(elmProps, {}); if (child) return child; return /* @__PURE__ */ _jsx8(Elm, (0, import_extends8.default)({}, elmProps)); }; ValueQuote.displayName = "JVR.ValueQuote"; var Colon = (props) => { var { value, parentValue, keyName, keys } = props; var { Colon: Comp = {} } = useSymbolsStore(); var { as, render } = Comp, reset = (0, import_objectWithoutPropertiesLoose2.default)(Comp, _excluded4); var Elm = as || "span"; var child = render && typeof render === "function" && render(reset, { value, parentValue, keyName, keys: keys || (keyName ? [keyName] : []) }); if (child) return child; return /* @__PURE__ */ _jsx8(Elm, (0, import_extends8.default)({}, reset)); }; Colon.displayName = "JVR.Colon"; var Arrow = (props) => { var { Arrow: Comp = {} } = useSymbolsStore(); var expands = useExpandsStore(); var { expandKey, style: resetStyle, value, parentValue, keyName, keys } = props; var isExpanded = !!expands[expandKey]; var { as, style, render } = Comp, reset = (0, import_objectWithoutPropertiesLoose2.default)(Comp, _excluded5); var Elm = as || "span"; var isRender = render && typeof render === "function"; var elmProps = (0, import_extends8.default)({}, reset, { "data-expanded": isExpanded, style: (0, import_extends8.default)({}, style, resetStyle) }); var result = { value, parentValue, keyName, keys: keys || (keyName ? [keyName] : []) }; var child = isRender && render(elmProps, result); if (child) return child; return /* @__PURE__ */ _jsx8(Elm, (0, import_extends8.default)({}, reset, { style: (0, import_extends8.default)({}, style, resetStyle) })); }; Arrow.displayName = "JVR.Arrow"; var BracketsOpen = (props) => { var { isBrackets, value, parentValue, keyName, keys } = props; var { BracketsLeft: BracketsLeft2 = {}, BraceLeft: BraceLeft2 = {} } = useSymbolsStore(); var result = { value, parentValue, keyName, keys: keys || (keyName ? [keyName] : []) }; if (isBrackets) { var { as, render: _render } = BracketsLeft2, reset = (0, import_objectWithoutPropertiesLoose2.default)(BracketsLeft2, _excluded6); var BracketsLeftComp = as || "span"; var _child = _render && typeof _render === "function" && _render(reset, result); if (_child) return _child; return /* @__PURE__ */ _jsx8(BracketsLeftComp, (0, import_extends8.default)({}, reset)); } var { as: elm, render } = BraceLeft2, resetProps = (0, import_objectWithoutPropertiesLoose2.default)(BraceLeft2, _excluded7); var BraceLeftComp = elm || "span"; var child = render && typeof render === "function" && render(resetProps, result); if (child) return child; return /* @__PURE__ */ _jsx8(BraceLeftComp, (0, import_extends8.default)({}, resetProps)); }; BracketsOpen.displayName = "JVR.BracketsOpen"; var BracketsClose = (props) => { var { isBrackets, isVisiable, value, parentValue, keyName, keys } = props; var result = { value, parentValue, keyName, keys: keys || (keyName ? [keyName] : []) }; if (!isVisiable) return null; var { BracketsRight: BracketsRight2 = {}, BraceRight: BraceRight2 = {} } = useSymbolsStore(); if (isBrackets) { var { as, render: _render2 } = BracketsRight2, _reset = (0, import_objectWithoutPropertiesLoose2.default)(BracketsRight2, _excluded8); var BracketsRightComp = as || "span"; var _child2 = _render2 && typeof _render2 === "function" && _render2(_reset, result); if (_child2) return _child2; return /* @__PURE__ */ _jsx8(BracketsRightComp, (0, import_extends8.default)({}, _reset)); } var { as: elm, render } = BraceRight2, reset = (0, import_objectWithoutPropertiesLoose2.default)(BraceRight2, _excluded9); var BraceRightComp = elm || "span"; var child = render && typeof render === "function" && render(reset, result); if (child) return child; return /* @__PURE__ */ _jsx8(BraceRightComp, (0, import_extends8.default)({}, reset)); }; BracketsClose.displayName = "JVR.BracketsClose"; // ../../node_modules/@uiw/react-json-view/esm/comps/NestedClose.js import { jsx as _jsx9 } from "react/jsx-runtime"; var NestedClose = (props) => { var _expands$expandKey; var { keyName, value, expandKey, parentValue, level, keys = [] } = props; var expands = useExpandsStore(); var { collapsed, shouldExpandNodeInitially } = useStore(); var defaultExpanded = typeof collapsed === "boolean" ? collapsed : typeof collapsed === "number" ? level > collapsed : false; var isExpanded = (_expands$expandKey = expands[expandKey]) != null ? _expands$expandKey : shouldExpandNodeInitially ? false : defaultExpanded; var shouldExpand = shouldExpandNodeInitially && shouldExpandNodeInitially(!isExpanded, { value, keys, level, keyName, parentValue }); if (expands[expandKey] === void 0 && !shouldExpand) { return null; } var len = Object.keys(value).length; if (isExpanded || len === 0) { return null; } var style = { paddingLeft: 4 }; var compProps = { keyName, value, keys, parentValue }; var isArray = Array.isArray(value); var isMySet = value instanceof Set; return /* @__PURE__ */ _jsx9("div", { style, children: /* @__PURE__ */ _jsx9(BracketsClose, (0, import_extends9.default)({ isBrackets: isArray || isMySet }, compProps, { isVisiable: true })) }); }; NestedClose.displayName = "JVR.NestedClose"; // ../../node_modules/@uiw/react-json-view/esm/comps/NestedOpen.js var import_extends20 = __toESM(require_extends()); // ../../node_modules/@uiw/react-json-view/esm/comps/KeyValues.js var import_extends16 = __toESM(require_extends()); import { Fragment as Fragment2, useRef as useRef3 } from "react"; // ../../node_modules/@uiw/react-json-view/esm/comps/Value.js var import_extends11 = __toESM(require_extends()); // ../../node_modules/@uiw/react-json-view/esm/types/index.js var import_extends10 = __toESM(require_extends()); var import_objectWithoutPropertiesLoose3 = __toESM(require_objectWithoutPropertiesLoose()); import { Fragment, useEffect as useEffect3, useState as useState2 } from "react"; import { jsx as _jsx10, jsxs as _jsxs } from "react/jsx-runtime"; var _excluded10 = ["as", "render"]; var _excluded23 = ["as", "render"]; var _excluded32 = ["as", "render"]; var _excluded42 = ["as", "render"]; var _excluded52 = ["as", "render"]; var _excluded62 = ["as", "render"]; var _excluded72 = ["as", "render"]; var _excluded82 = ["as", "render"]; var _excluded92 = ["as", "render"]; var _excluded0 = ["as", "render"]; var _excluded1 = ["as", "render"]; var _excluded102 = ["as", "render"]; var _excluded11 = ["as", "render"]; var bigIntToString = (bi) => { if (bi === void 0) { return "0n"; } else if (typeof bi === "string") { try { bi = BigInt(bi); } catch (e) { return "0n"; } } return bi ? bi.toString() + "n" : "0n"; }; var SetComp = (_ref) => { var { value, keyName } = _ref; var { Set: Comp = {}, displayDataTypes } = useTypesStore(); var isSet = value instanceof Set; if (!isSet || !displayDataTypes) return null; var { as, render } = Comp, reset = (0, import_objectWithoutPropertiesLoose3.default)(Comp, _excluded10); var isRender = render && typeof render === "function"; var type = isRender && render(reset, { type: "type", value, keyName }); if (type) return type; var Elm = as || "span"; return /* @__PURE__ */ _jsx10(Elm, (0, import_extends10.default)({}, reset)); }; SetComp.displayName = "JVR.SetComp"; var MapComp = (_ref2) => { var { value, keyName } = _ref2; var { Map: Comp = {}, displayDataTypes } = useTypesStore(); var isMap = value instanceof Map; if (!isMap || !displayDataTypes) return null; var { as, render } = Comp, reset = (0, import_objectWithoutPropertiesLoose3.default)(Comp, _excluded23); var isRender = render && typeof render === "function"; var type = isRender && render(reset, { type: "type", value, keyName }); if (type) return type; var Elm = as || "span"; return /* @__PURE__ */ _jsx10(Elm, (0, import_extends10.default)({}, reset)); }; MapComp.displayName = "JVR.MapComp"; var defalutStyle = { opacity: 0.75, paddingRight: 4 }; var TypeString = (_ref3) => { var { children = "", keyName, keys } = _ref3; var { Str = {}, displayDataTypes } = useTypesStore(); var { shortenTextAfterLength: length = 30, stringEllipsis = "..." } = useStore(); var { as, render } = Str, reset = (0, import_objectWithoutPropertiesLoose3.default)(Str, _excluded32); var childrenStr = children; var [shorten, setShorten] = useState2(length && childrenStr.length > length); useEffect3(() => setShorten(length && childrenStr.length > length), [length]); var Comp = as || "span"; var style = (0, import_extends10.default)({}, defalutStyle, Str.style || {}); if (length > 0) { reset.style = (0, import_extends10.default)({}, reset.style, { cursor: childrenStr.length <= length ? "initial" : "pointer" }); if (childrenStr.length > length) { reset.onClick = () => { setShorten(!shorten); }; } } var text = shorten ? "" + childrenStr.slice(0, length) + stringEllipsis : childrenStr; var isRender = render && typeof render === "function"; var type = isRender && render((0, import_extends10.default)({}, reset, { style }), { type: "type", value: children, keyName, keys }); var cls = shorten ? "w-rjv-value w-rjv-value-short" : "w-rjv-value"; var child = isRender && render((0, import_extends10.default)({}, reset, { children: text, className: cls }), { type: "value", value: children, keyName, keys }); return /* @__PURE__ */ _jsxs(Fragment, { children: [displayDataTypes && (type || /* @__PURE__ */ _jsx10(Comp, (0, import_extends10.default)({}, reset, { style }))), child || /* @__PURE__ */ _jsxs(Fragment, { children: [/* @__PURE__ */ _jsx10(ValueQuote, {}), /* @__PURE__ */ _jsx10(Comp, (0, import_extends10.default)({}, reset, { className: cls, children: text })), /* @__PURE__ */ _jsx10(ValueQuote, {})] })] }); }; TypeString.displayName = "JVR.TypeString"; var TypeTrue = (_ref4) => { var { children, keyName, keys } = _ref4; var { True: True2 = {}, displayDataTypes } = useTypesStore(); var { as, render } = True2, reset = (0, import_objectWithoutPropertiesLoose3.default)(True2, _excluded42); var Comp = as || "span"; var style = (0, import_extends10.default)({}, defalutStyle, True2.style || {}); var isRender = render && typeof render === "function"; var type = isRender && render((0, import_extends10.default)({}, reset, { style }), { type: "type", value: children, keyName, keys }); var child = isRender && render((0, import_extends10.default)({}, reset, { children, className: "w-rjv-value" }), { type: "value", value: children, keyName, keys }); return /* @__PURE__ */ _jsxs(Fragment, { children: [displayDataTypes && (type || /* @__PURE__ */ _jsx10(Comp, (0, import_extends10.default)({}, reset, { style }))), child || /* @__PURE__ */ _jsx10(Comp, (0, import_extends10.default)({}, reset, { className: "w-rjv-value", children: children == null ? void 0 : children.toString() }))] }); }; TypeTrue.displayName = "JVR.TypeTrue"; var TypeFalse = (_ref5) => { var { children, keyName, keys } = _ref5; var { False: False2 = {}, displayDataTypes } = useTypesStore(); var { as, render } = False2, reset = (0, import_objectWithoutPropertiesLoose3.default)(False2, _excluded52); var Comp = as || "span"; var style = (0, import_extends10.default)({}, defalutStyle, False2.style || {}); var isRender = render && typeof render === "function"