UNPKG

@nlabs/gothamjs

Version:
107 lines (106 loc) 12.9 kB
import { Logger, LoggerDebugLevel } from "@nlabs/arkhamjs-middleware-logger"; import { BrowserStorage } from "@nlabs/arkhamjs-storage-browser"; import { useFlux } from "@nlabs/arkhamjs-utils-react"; import { merge } from "@nlabs/utils"; import { useEffect, useMemo, useState } from "react"; import { I18nextProvider } from "react-i18next"; import { createBrowserRouter, RouterProvider } from "react-router"; import { GothamActions } from "../../actions/GothamActions.js"; import { Config } from "../../config/appConfig.js"; import { GothamConstants } from "../../constants/GothamConstants.js"; import { gothamApp } from "../../stores/GothamAppStore.js"; import { GothamContext } from "../../utils/GothamContext.js"; import { parseRoutes } from "../../utils/routeUtils.js"; import { GothamRoot } from "./GothamRoot.js"; import { jsx, jsxs } from "react/jsx-runtime"; const defaultGothamConfig = { app: { name: "gotham", title: "GothamJS" }, baseUrl: "", isAuth: () => false, middleware: [], routes: [], storageType: "session", stores: [], theme: {}, translations: { translation: {} } }; const init = (config) => () => { const { onInit } = config; GothamActions.init(); if (onInit) { onInit(); } }; const signOut = (flux) => async () => { await flux.clearAppData(); await GothamActions.loading(false); GothamActions.navGoto("/signIn"); }; const GothamProvider = ({ children, config: appConfig }) => { const flux = useFlux(); const config = merge(defaultGothamConfig, appConfig); const { isAuth, middleware, routes = [], storageType, stores, i18n } = config; const name = config?.app?.name; const [session, setSession] = useState({}); const router = useMemo(() => { return createBrowserRouter( [ { Component: GothamRoot, children: parseRoutes(routes), index: false, path: "/" } ] ); }, [routes]); useEffect(() => { Config.set(config); if (flux) { const env = Config.get("environment"); const logger = new Logger({ debugLevel: env === "development" ? LoggerDebugLevel.DISPATCH : LoggerDebugLevel.DISABLED }); const storage = new BrowserStorage({ type: storageType }); flux.init({ middleware: [logger, ...middleware || []], name, // state: {app: {title}}, storage, stores: [gothamApp, ...stores || []] }); flux.on(GothamConstants.SIGN_OUT, signOut(flux)); flux.on(GothamConstants.UPDATE_SESSION, ({ session: session2 }) => { setSession(session2); }); } init(config); }, [flux, config, middleware, name, storageType, stores]); if (i18n) { return /* @__PURE__ */ jsx(I18nextProvider, { i18n, children: /* @__PURE__ */ jsxs(GothamContext.Provider, { value: { Flux: flux, isAuth, session }, children: [ router && /* @__PURE__ */ jsx(RouterProvider, { router }), children ] }) }); } return /* @__PURE__ */ jsxs(GothamContext.Provider, { value: { Flux: flux, isAuth, session }, children: [ router && /* @__PURE__ */ jsx(RouterProvider, { router }), children ] }); }; export { GothamProvider, defaultGothamConfig, init, signOut }; //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/views/Gotham/GothamProvider.tsx"],
  "sourcesContent": ["/**\n * Copyright (c) 2024-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {Logger, LoggerDebugLevel} from '@nlabs/arkhamjs-middleware-logger';\nimport {BrowserStorage} from '@nlabs/arkhamjs-storage-browser';\nimport {useFlux} from '@nlabs/arkhamjs-utils-react';\nimport {merge} from '@nlabs/utils';\nimport i18n from 'i18next';\nimport {useEffect, useMemo, useState} from 'react';\nimport {I18nextProvider} from 'react-i18next';\nimport {createBrowserRouter, RouterProvider} from 'react-router';\n\nimport {GothamActions} from '../../actions/GothamActions.js';\nimport {Config} from '../../config/appConfig.js';\nimport {GothamConstants} from '../../constants/GothamConstants.js';\nimport {gothamApp} from '../../stores/GothamAppStore.js';\nimport {GothamContext} from '../../utils/GothamContext.js';\n\nimport type {FluxFramework, FluxMiddlewareType, FluxOptions} from '@nlabs/arkhamjs';\nimport type {FC, ReactNode} from 'react';\nimport type {GothamRouteData} from '../../types/gotham.js';\nimport {parseRoutes, type CustomRouteProps} from '../../utils/routeUtils.js';\nimport {GothamRoot} from './GothamRoot.js';\n\nexport interface GothamProviderProps {\n  readonly children?: ReactNode;\n  readonly config: GothamConfiguration;\n  readonly session?: Record<string, unknown>;\n}\n\nexport type GothamPosition = 't' | 'tc' | 'tl' | 'tr' | 'b' | 'bc' | 'br' | 'bl';\n\nexport type GothamStatus = 'default' | 'error' | 'info' | 'success' | 'warning' | number;\n\nexport type ThemeDisplayMode = 'auto' | 'dark' | 'light';\n\nexport interface GothamConfiguration {\n  readonly app?: {\n    readonly logo?: string;\n    readonly name?: string;\n    readonly title?: string;\n    readonly titleBarSeparator?: string;\n  };\n  readonly baseUrl?: string;\n  readonly config?: FluxOptions;\n  readonly displayMode?: ThemeDisplayMode;\n  readonly flux?: FluxFramework;\n  readonly isAuth?: () => boolean;\n  readonly middleware?: FluxMiddlewareType[];\n  readonly onInit?: () => void;\n  readonly routes?: GothamRouteData[];\n  readonly storageType?: 'local' | 'session';\n  readonly stores?: unknown[];\n  readonly theme?: Record<string, unknown>;\n  readonly translations?: Record<string, unknown>;\n  readonly i18n?: typeof i18n;\n}\n\nexport const defaultGothamConfig: GothamConfiguration = {\n  app: {\n    name: 'gotham',\n    title: 'GothamJS'\n  },\n  baseUrl: '',\n  isAuth: () => false,\n  middleware: [],\n  routes: [],\n  storageType: 'session',\n  stores: [],\n  theme: {},\n  translations: {translation: {}}\n};\n\nexport const init = (config: GothamConfiguration) => (): void => {\n  const {onInit} = config;\n  GothamActions.init();\n\n  if(onInit) {\n    onInit();\n  }\n};\n\nexport const signOut = (flux: FluxFramework) => async () => {\n  await flux.clearAppData();\n  await GothamActions.loading(false);\n  GothamActions.navGoto('/signIn');\n};\n\nexport const GothamProvider: FC<GothamProviderProps> = ({children, config: appConfig}) => {\n  const flux = useFlux();\n  const config: GothamConfiguration = merge(defaultGothamConfig, appConfig);\n  const {\n    isAuth,\n    middleware,\n    routes = [],\n    storageType,\n    stores,\n    i18n\n  } = config;\n  const name = config?.app?.name;\n  const [session, setSession] = useState({});\n  const router = useMemo(() => {\n    return createBrowserRouter(\n      [\n        {\n          Component: GothamRoot,\n          children: parseRoutes(routes as unknown as CustomRouteProps[]),\n          index: false,\n          path: '/'\n        }\n      ]\n    );\n  }, [routes]);\n\n  useEffect(() => {\n    Config.set(config as Record<string, unknown>);\n\n    if(flux) {\n      const env: string = Config.get('environment') as string;\n      const logger: Logger = new Logger({\n        debugLevel: env === 'development' ? LoggerDebugLevel.DISPATCH : LoggerDebugLevel.DISABLED\n      });\n      const storage: BrowserStorage = new BrowserStorage({type: storageType});\n\n      flux.init({\n        middleware: [logger, ...(middleware || [])],\n        name,\n        // state: {app: {title}},\n        storage,\n        stores: [gothamApp, ...(stores || [])]\n      });\n\n      flux.on(GothamConstants.SIGN_OUT, signOut(flux));\n      flux.on(GothamConstants.UPDATE_SESSION, ({session}) => {\n        setSession(session);\n      });\n    }\n\n    init(config);\n  }, [flux, config, middleware, name, storageType, stores]);\n\n  if(i18n) {\n    return (\n      <I18nextProvider i18n={i18n}>\n        <GothamContext.Provider value={{Flux: flux, isAuth, session}}>\n          {router && <RouterProvider router={router}/>}\n          {children}\n        </GothamContext.Provider>\n      </I18nextProvider>\n    );\n  }\n\n  return (\n    <GothamContext.Provider value={{Flux: flux, isAuth, session}}>\n      {router && <RouterProvider router={router}/>}\n      {children}\n    </GothamContext.Provider>\n  );\n};"],
  "mappings": "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",
  "names": ["session"]
}
