@nlabs/gothamjs
Version:
Platform
157 lines (156 loc) • 17.8 kB
JavaScript
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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"}