UNPKG

@nlabs/gothamjs

Version:
157 lines (156 loc) 17.8 kB
import { jsx as _jsx } from "react/jsx-runtime"; /** * Copyright (c) 2024-Present, Nitrogen Labs, Inc. * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms. */ 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 i18n from 'i18next'; import { useEffect, useMemo, useState } from 'react'; import { I18nextProvider, initReactI18next } 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'; export const defaultGothamConfig = { app: { name: 'gotham', title: 'GothamJS' }, baseUrl: '', isAuth: ()=>false, middleware: [], routes: [], storageType: 'session', stores: [], theme: {}, translations: { translation: {} } }; export const init = (config)=>()=>{ const { onInit } = config; GothamActions.init(); if (onInit) { onInit(); } }; export const signOut = (flux)=>async ()=>{ await flux.clearAppData(); await GothamActions.loading(false); GothamActions.navGoto('/signIn'); }; export const GothamProvider = ({ children, config: appConfig })=>{ const flux = useFlux(); const config = merge(defaultGothamConfig, appConfig); const { isAuth, middleware, routes = [], storageType, stores, i18n: providedI18n, translations } = config; const name = config?.app?.name; const [session, setSession] = useState({}); const router = useMemo(()=>{ return createBrowserRouter([ { Component: GothamRoot, children: parseRoutes(routes), index: false, path: '/' } ]); }, [ routes ]); // Initialize i18next if translations are provided but no i18n instance is given const i18nInstance = useMemo(()=>{ if (providedI18n) { return providedI18n; } if (translations && Object.keys(translations).length > 0) { // Create a new i18next instance and initialize it const newI18n = i18n.createInstance(); newI18n.use(initReactI18next).init({ resources: translations, lng: 'en', fallbackLng: 'en', interpolation: { escapeValue: false } }); return newI18n; } return null; }, [ providedI18n, translations ]); 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 })=>{ setSession(session); }); } init(config); }, [ flux, config, middleware, name, storageType, stores ]); if (i18nInstance) { return /*#__PURE__*/ _jsx(I18nextProvider, { i18n: i18nInstance, children: /*#__PURE__*/ _jsx(GothamContext.Provider, { value: { Flux: flux, isAuth, session }, children: /*#__PURE__*/ _jsx("div", { children: /*#__PURE__*/ _jsx(RouterProvider, { router: router }) }) }) }); } return /*#__PURE__*/ _jsx(GothamContext.Provider, { value: { Flux: flux, isAuth, session }, children: /*#__PURE__*/ _jsx("div", { children: /*#__PURE__*/ _jsx(RouterProvider, { router: router }) }) }); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/gothamjs/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, initReactI18next} 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';\nimport {parseRoutes} from '../../utils/routeUtils.js';\nimport {GothamRoot} from './GothamRoot.js';\n\nimport type {FluxFramework, FluxMiddlewareType, FluxOptions} from '@nlabs/arkhamjs';\nimport type {FC, ReactNode} from 'react';\nimport type {GothamRouteData} from '../../types/gotham.js';\nimport type {CustomRouteProps} from '../../utils/routeUtils.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';\nexport type GothamStatus = 'default' | 'error' | 'info' | 'success' | 'warning' | number;\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: providedI18n,\n    translations\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    // Initialize i18next if translations are provided but no i18n instance is given\n  const i18nInstance = useMemo(() => {\n    if (providedI18n) {\n      return providedI18n;\n    }\n\n    if (translations && Object.keys(translations).length > 0) {\n      // Create a new i18next instance and initialize it\n      const newI18n = i18n.createInstance();\n\n      newI18n\n        .use(initReactI18next)\n        .init({\n          resources: translations as Record<string, Record<string, Record<string, string>>>,\n          lng: 'en', // default language\n          fallbackLng: 'en',\n          interpolation: {\n            escapeValue: false, // React already escapes values\n          },\n        });\n\n      return newI18n;\n    }\n\n    return null;\n  }, [providedI18n, translations]);\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(i18nInstance) {\n    return (\n      <I18nextProvider i18n={i18nInstance}>\n        <GothamContext.Provider value={{Flux: flux, isAuth, session}}>\n          <div>\n            <RouterProvider router={router}/>\n          </div>\n        </GothamContext.Provider>\n      </I18nextProvider>\n    );\n  }\n\n  return (\n    <GothamContext.Provider value={{Flux: flux, isAuth, session}}>\n      <div>\n        <RouterProvider router={router}/>\n      </div>\n    </GothamContext.Provider>\n  );\n};"],"names":["Logger","LoggerDebugLevel","BrowserStorage","useFlux","merge","i18n","useEffect","useMemo","useState","I18nextProvider","initReactI18next","createBrowserRouter","RouterProvider","GothamActions","Config","GothamConstants","gothamApp","GothamContext","parseRoutes","GothamRoot","defaultGothamConfig","app","name","title","baseUrl","isAuth","middleware","routes","storageType","stores","theme","translations","translation","init","config","onInit","signOut","flux","clearAppData","loading","navGoto","GothamProvider","children","appConfig","providedI18n","session","setSession","router","Component","index","path","i18nInstance","Object","keys","length","newI18n","createInstance","use","resources","lng","fallbackLng","interpolation","escapeValue","set","env","get","logger","debugLevel","DISPATCH","DISABLED","storage","type","on","SIGN_OUT","UPDATE_SESSION","Provider","value","Flux","div"],"mappings":"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"}