@j2inn/fin5-ui-utils 6.0.5-beta.0 → 6.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -5
- package/dist/fantomProps/createFin5Props/index.d.ts +12 -12
- package/dist/fantomProps/createFin5Props/index.js +146 -146
- package/dist/fantomProps/createFin5Props/runCreateFin5Props.d.ts +2 -2
- package/dist/fantomProps/createFin5Props/runCreateFin5Props.js +16 -16
- package/dist/fantomProps/fantomPropsToObject.d.ts +8 -8
- package/dist/fantomProps/fantomPropsToObject.js +183 -183
- package/dist/fantomProps/generateJsonFromFantomPropsFile.d.ts +4 -4
- package/dist/fantomProps/generateJsonFromFantomPropsFile.js +41 -41
- package/dist/fantomProps/localePropsToJson.d.ts +1 -1
- package/dist/fantomProps/localePropsToJson.js +50 -50
- package/dist/fantomProps/readFantomPropsFile.d.ts +5 -5
- package/dist/fantomProps/readFantomPropsFile.js +65 -66
- package/dist/fantomProps/readFantomPropsFile.js.map +1 -1
- package/dist/fin5Top/fin5FileUpload.d.ts +24 -24
- package/dist/fin5Top/fin5FileUpload.js +51 -51
- package/dist/fin5Top/fin5Top.d.ts +124 -124
- package/dist/fin5Top/fin5Top.js +53 -53
- package/dist/fin5Top/finEdge2Cloud.d.ts +6 -6
- package/dist/fin5Top/finEdge2Cloud.js +15 -15
- package/dist/fin5Top/getFin5BinUrl.d.ts +2 -2
- package/dist/fin5Top/getFin5BinUrl.js +9 -9
- package/dist/fin5Top/openFin5Alarm.d.ts +22 -22
- package/dist/fin5Top/openFin5Alarm.js +23 -23
- package/dist/fin5Top/openFin5Historian.d.ts +3 -3
- package/dist/fin5Top/openFin5Historian.js +19 -19
- package/dist/fin5Top/useFin5AppURLHashParameter.d.ts +18 -18
- package/dist/fin5Top/useFin5AppURLHashParameter.js +133 -133
- package/dist/index.d.ts +35 -35
- package/dist/index.js +69 -69
- package/dist/jobs/jobUtils.d.ts +14 -14
- package/dist/jobs/jobUtils.js +15 -15
- package/dist/react/app/Fin5AppContainer.d.ts +36 -36
- package/dist/react/app/Fin5AppContainer.js +102 -102
- package/dist/react/app/Fin5AppRootStore.d.ts +40 -40
- package/dist/react/app/Fin5AppRootStore.js +69 -69
- package/dist/react/components/ErrorBoundary.d.ts +57 -57
- package/dist/react/components/ErrorBoundary.js +150 -150
- package/dist/react/components/ErrorDisplayer.d.ts +19 -19
- package/dist/react/components/ErrorDisplayer.js +36 -36
- package/dist/react/components/Loader.d.ts +9 -9
- package/dist/react/components/Loader.js +17 -17
- package/dist/react/components/LoadingSpinner.d.ts +2 -2
- package/dist/react/components/LoadingSpinner.js +27 -27
- package/dist/react/components/RecordImage.d.ts +20 -20
- package/dist/react/components/RecordImage.js +51 -51
- package/dist/react/components/charts/QRCode.d.ts +25 -25
- package/dist/react/components/charts/QRCode.js +82 -82
- package/dist/react/components/charts/line-bar/Chart.d.ts +166 -166
- package/dist/react/components/charts/line-bar/Chart.js +442 -442
- package/dist/react/components/charts/line-bar/HGridChart.d.ts +58 -58
- package/dist/react/components/charts/line-bar/HGridChart.js +285 -285
- package/dist/react/components/charts/pie/PieChart.d.ts +94 -94
- package/dist/react/components/charts/pie/PieChart.js +204 -204
- package/dist/react/components/charts/pie/SimplePieChart.d.ts +21 -21
- package/dist/react/components/charts/pie/SimplePieChart.js +55 -55
- package/dist/react/components/graphics/GraphicViewer.d.ts +10 -10
- package/dist/react/components/graphics/GraphicViewer.js +29 -29
- package/dist/react/components/graphics/GraphicsTabViewer.d.ts +17 -17
- package/dist/react/components/graphics/GraphicsTabViewer.js +90 -90
- package/dist/react/components/makeCustomElement.d.ts +16 -16
- package/dist/react/components/makeCustomElement.js +150 -150
- package/dist/react/components/navigation/BasicLayout.d.ts +41 -41
- package/dist/react/components/navigation/BasicLayout.js +155 -155
- package/dist/react/components/navigation/HeaderSiderLayout.d.ts +13 -13
- package/dist/react/components/navigation/HeaderSiderLayout.js +110 -110
- package/dist/react/components/navigation/MenuPage.d.ts +37 -37
- package/dist/react/components/navigation/MenuPage.js +36 -36
- package/dist/react/components/navigation/MenuTrigger.d.ts +9 -9
- package/dist/react/components/navigation/MenuTrigger.js +33 -33
- package/dist/react/components/navigation/ReactRouterHeaderSiderLayout.d.ts +11 -11
- package/dist/react/components/navigation/ReactRouterHeaderSiderLayout.js +25 -25
- package/dist/react/components/navigation/ReactRouterLayout.d.ts +46 -46
- package/dist/react/components/navigation/ReactRouterLayout.js +132 -132
- package/dist/react/components/navigation/customRouting/Router.d.ts +12 -12
- package/dist/react/components/navigation/customRouting/Router.js +45 -45
- package/dist/react/components/navigation/customRouting/RouterLayout.d.ts +11 -11
- package/dist/react/components/navigation/customRouting/RouterLayout.js +61 -61
- package/dist/react/components/resolvable/configurationForm/ConfigurationForm.d.ts +27 -27
- package/dist/react/components/resolvable/configurationForm/ConfigurationForm.js +95 -95
- package/dist/react/components/resolvable/configurationForm/ConfigurationFormEntry.d.ts +16 -16
- package/dist/react/components/resolvable/configurationForm/ConfigurationFormEntry.js +88 -88
- package/dist/react/components/resolvable/configurationForm/getSectionDefault.d.ts +16 -16
- package/dist/react/components/resolvable/configurationForm/getSectionDefault.js +99 -99
- package/dist/react/hooks/useFin5BinUrl.d.ts +6 -6
- package/dist/react/hooks/useFin5BinUrl.js +15 -15
- package/dist/react/hooks/useFin5ColorScheme.d.ts +2 -2
- package/dist/react/hooks/useFin5ColorScheme.js +49 -49
- package/dist/react/hooks/useScreenSize.d.ts +7 -7
- package/dist/react/hooks/useScreenSize.js +31 -31
- package/dist_es/fantomProps/createFin5Props/index.d.ts +12 -12
- package/dist_es/fantomProps/createFin5Props/index.js +140 -140
- package/dist_es/fantomProps/createFin5Props/runCreateFin5Props.d.ts +2 -2
- package/dist_es/fantomProps/createFin5Props/runCreateFin5Props.js +11 -11
- package/dist_es/fantomProps/fantomPropsToObject.d.ts +8 -8
- package/dist_es/fantomProps/fantomPropsToObject.js +178 -178
- package/dist_es/fantomProps/generateJsonFromFantomPropsFile.d.ts +4 -4
- package/dist_es/fantomProps/generateJsonFromFantomPropsFile.js +12 -12
- package/dist_es/fantomProps/localePropsToJson.d.ts +1 -1
- package/dist_es/fantomProps/localePropsToJson.js +21 -21
- package/dist_es/fantomProps/readFantomPropsFile.d.ts +5 -5
- package/dist_es/fantomProps/readFantomPropsFile.js +39 -40
- package/dist_es/fantomProps/readFantomPropsFile.js.map +1 -1
- package/dist_es/fin5Top/fin5FileUpload.d.ts +24 -24
- package/dist_es/fin5Top/fin5FileUpload.js +47 -47
- package/dist_es/fin5Top/fin5Top.d.ts +124 -124
- package/dist_es/fin5Top/fin5Top.js +49 -49
- package/dist_es/fin5Top/finEdge2Cloud.d.ts +6 -6
- package/dist_es/fin5Top/finEdge2Cloud.js +11 -11
- package/dist_es/fin5Top/getFin5BinUrl.d.ts +2 -2
- package/dist_es/fin5Top/getFin5BinUrl.js +5 -5
- package/dist_es/fin5Top/openFin5Alarm.d.ts +22 -22
- package/dist_es/fin5Top/openFin5Alarm.js +19 -19
- package/dist_es/fin5Top/openFin5Historian.d.ts +3 -3
- package/dist_es/fin5Top/openFin5Historian.js +15 -15
- package/dist_es/fin5Top/useFin5AppURLHashParameter.d.ts +18 -18
- package/dist_es/fin5Top/useFin5AppURLHashParameter.js +124 -124
- package/dist_es/index.d.ts +35 -35
- package/dist_es/index.js +53 -53
- package/dist_es/jobs/jobUtils.d.ts +14 -14
- package/dist_es/jobs/jobUtils.js +9 -9
- package/dist_es/react/app/Fin5AppContainer.d.ts +36 -36
- package/dist_es/react/app/Fin5AppContainer.js +73 -73
- package/dist_es/react/app/Fin5AppRootStore.d.ts +40 -40
- package/dist_es/react/app/Fin5AppRootStore.js +65 -65
- package/dist_es/react/components/ErrorBoundary.d.ts +57 -57
- package/dist_es/react/components/ErrorBoundary.js +123 -123
- package/dist_es/react/components/ErrorDisplayer.d.ts +19 -19
- package/dist_es/react/components/ErrorDisplayer.js +28 -28
- package/dist_es/react/components/Loader.d.ts +9 -9
- package/dist_es/react/components/Loader.js +12 -12
- package/dist_es/react/components/LoadingSpinner.d.ts +2 -2
- package/dist_es/react/components/LoadingSpinner.js +20 -20
- package/dist_es/react/components/RecordImage.d.ts +20 -20
- package/dist_es/react/components/RecordImage.js +24 -24
- package/dist_es/react/components/charts/QRCode.d.ts +25 -25
- package/dist_es/react/components/charts/QRCode.js +52 -52
- package/dist_es/react/components/charts/line-bar/Chart.d.ts +166 -166
- package/dist_es/react/components/charts/line-bar/Chart.js +415 -415
- package/dist_es/react/components/charts/line-bar/HGridChart.d.ts +58 -58
- package/dist_es/react/components/charts/line-bar/HGridChart.js +250 -250
- package/dist_es/react/components/charts/pie/PieChart.d.ts +94 -94
- package/dist_es/react/components/charts/pie/PieChart.js +177 -177
- package/dist_es/react/components/charts/pie/SimplePieChart.d.ts +21 -21
- package/dist_es/react/components/charts/pie/SimplePieChart.js +25 -25
- package/dist_es/react/components/graphics/GraphicViewer.d.ts +10 -10
- package/dist_es/react/components/graphics/GraphicViewer.js +22 -22
- package/dist_es/react/components/graphics/GraphicsTabViewer.d.ts +17 -17
- package/dist_es/react/components/graphics/GraphicsTabViewer.js +60 -60
- package/dist_es/react/components/makeCustomElement.d.ts +16 -16
- package/dist_es/react/components/makeCustomElement.js +142 -142
- package/dist_es/react/components/navigation/BasicLayout.d.ts +41 -41
- package/dist_es/react/components/navigation/BasicLayout.js +124 -124
- package/dist_es/react/components/navigation/HeaderSiderLayout.d.ts +13 -13
- package/dist_es/react/components/navigation/HeaderSiderLayout.js +80 -80
- package/dist_es/react/components/navigation/MenuPage.d.ts +37 -37
- package/dist_es/react/components/navigation/MenuPage.js +30 -30
- package/dist_es/react/components/navigation/MenuTrigger.d.ts +9 -9
- package/dist_es/react/components/navigation/MenuTrigger.js +28 -28
- package/dist_es/react/components/navigation/ReactRouterHeaderSiderLayout.d.ts +11 -11
- package/dist_es/react/components/navigation/ReactRouterHeaderSiderLayout.js +18 -18
- package/dist_es/react/components/navigation/ReactRouterLayout.d.ts +46 -46
- package/dist_es/react/components/navigation/ReactRouterLayout.js +99 -99
- package/dist_es/react/components/navigation/customRouting/Router.d.ts +12 -12
- package/dist_es/react/components/navigation/customRouting/Router.js +18 -18
- package/dist_es/react/components/navigation/customRouting/RouterLayout.d.ts +11 -11
- package/dist_es/react/components/navigation/customRouting/RouterLayout.js +34 -34
- package/dist_es/react/components/resolvable/configurationForm/ConfigurationForm.d.ts +27 -27
- package/dist_es/react/components/resolvable/configurationForm/ConfigurationForm.js +64 -64
- package/dist_es/react/components/resolvable/configurationForm/ConfigurationFormEntry.d.ts +16 -16
- package/dist_es/react/components/resolvable/configurationForm/ConfigurationFormEntry.js +58 -58
- package/dist_es/react/components/resolvable/configurationForm/getSectionDefault.d.ts +16 -16
- package/dist_es/react/components/resolvable/configurationForm/getSectionDefault.js +94 -94
- package/dist_es/react/hooks/useFin5BinUrl.d.ts +6 -6
- package/dist_es/react/hooks/useFin5BinUrl.js +11 -11
- package/dist_es/react/hooks/useFin5ColorScheme.d.ts +2 -2
- package/dist_es/react/hooks/useFin5ColorScheme.js +45 -45
- package/dist_es/react/hooks/useScreenSize.d.ts +7 -7
- package/dist_es/react/hooks/useScreenSize.js +27 -27
- package/package.json +1 -1
- package/dist_es/react/app/Fin5AppContainer.jsx +0 -82
- package/dist_es/react/app/Fin5AppContainer.jsx.map +0 -1
- package/dist_es/react/components/ErrorBoundary.jsx +0 -150
- package/dist_es/react/components/ErrorBoundary.jsx.map +0 -1
- package/dist_es/react/components/ErrorDisplayer.jsx +0 -36
- package/dist_es/react/components/ErrorDisplayer.jsx.map +0 -1
- package/dist_es/react/components/Loader.jsx +0 -13
- package/dist_es/react/components/Loader.jsx.map +0 -1
- package/dist_es/react/components/LoadingSpinner.jsx +0 -22
- package/dist_es/react/components/LoadingSpinner.jsx.map +0 -1
- package/dist_es/react/components/charts/line-bar/ZincGridChart.d.ts +0 -12
- package/dist_es/react/components/charts/line-bar/ZincGridChart.js +0 -17
- package/dist_es/react/components/charts/line-bar/ZincGridChart.js.map +0 -1
- package/dist_es/react/components/graphics/GraphicViewer.jsx +0 -23
- package/dist_es/react/components/graphics/GraphicViewer.jsx.map +0 -1
- package/dist_es/react/components/graphics/GraphicsTabViewer.jsx +0 -63
- package/dist_es/react/components/graphics/GraphicsTabViewer.jsx.map +0 -1
- package/dist_es/react/components/navigation/BasicLayout.jsx +0 -133
- package/dist_es/react/components/navigation/BasicLayout.jsx.map +0 -1
- package/dist_es/react/components/navigation/MenuPage.jsx +0 -31
- package/dist_es/react/components/navigation/MenuPage.jsx.map +0 -1
- package/dist_es/react/components/navigation/Router.d.ts +0 -12
- package/dist_es/react/components/navigation/Router.js +0 -19
- package/dist_es/react/components/navigation/Router.js.map +0 -1
- package/dist_es/react/components/navigation/Router.jsx +0 -19
- package/dist_es/react/components/navigation/Router.jsx.map +0 -1
- package/dist_es/react/components/navigation/react-router/BasicLayout.d.ts +0 -23
- package/dist_es/react/components/navigation/react-router/BasicLayout.js +0 -82
- package/dist_es/react/components/navigation/react-router/BasicLayout.js.map +0 -1
- package/dist_es/react/components/navigation/react-router/ReactRouterBasicLayout.d.ts +0 -24
- package/dist_es/react/components/navigation/react-router/ReactRouterBasicLayout.js +0 -82
- package/dist_es/react/components/navigation/react-router/ReactRouterBasicLayout.js.map +0 -1
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2022, J2 Innovations. All Rights Reserved
|
|
3
|
-
*/
|
|
4
|
-
import React, { useEffect, useRef, useState } from 'react';
|
|
5
|
-
import { AppRootStoreContext, AppStoreContext } from '@j2inn/app-react';
|
|
6
|
-
import { observer } from 'mobx-react-lite';
|
|
7
|
-
import { Fin5AppRootStore } from './Fin5AppRootStore';
|
|
8
|
-
import { Client, } from 'haystack-nclient';
|
|
9
|
-
import { ClientContext } from 'haystack-react';
|
|
10
|
-
import { I18NProvider } from '@j2inn/utils';
|
|
11
|
-
import { ThemeProvider } from 'react-jss';
|
|
12
|
-
import { DEFAULT_THEME, GenerateTheme } from '@j2inn/ui';
|
|
13
|
-
import { fin5Top } from '../../fin5Top/fin5Top';
|
|
14
|
-
import { useFin5AppURLHashParameter } from '../../fin5Top/useFin5AppURLHashParameter';
|
|
15
|
-
import { HRef } from 'haystack-core';
|
|
16
|
-
import { ErrorBoundary } from '../components/ErrorBoundary';
|
|
17
|
-
import Loader from '../components/Loader';
|
|
18
|
-
const PATH_PREFIX = 'finApp';
|
|
19
|
-
const getServiceUrl = ({ origin, path }) => `${origin}/${PATH_PREFIX}/api/${path}`;
|
|
20
|
-
const getOpUrl = ({ origin, project, op }) => `${origin}/api/${project}/${op}`;
|
|
21
|
-
const getHaystackServiceUrl = ({ origin, project, path, }) => `${origin}/${PATH_PREFIX}/api/haystack${project ? `/${project}` : ''}/${path}`;
|
|
22
|
-
const getHostServiceUrl = ({ origin, path, }) => `${origin}/${PATH_PREFIX}/api/host/${path}`;
|
|
23
|
-
/**
|
|
24
|
-
* Creates a basic application container environment to run a view in FIN5.
|
|
25
|
-
*/
|
|
26
|
-
export const Fin5AppContainer = observer(({ children, appStore, client, project, theme = GenerateTheme(DEFAULT_THEME).light, }) => {
|
|
27
|
-
const [loading, setLoading] = useState(true);
|
|
28
|
-
const [loadingi18n, setLoadingi18n] = useState(true);
|
|
29
|
-
const rootStoreRef = useRef(null);
|
|
30
|
-
rootStoreRef.current ??= new Fin5AppRootStore();
|
|
31
|
-
const rootStore = rootStoreRef.current;
|
|
32
|
-
const [hashProjName] = useFin5AppURLHashParameter('projectName');
|
|
33
|
-
const containerProject = project || hashProjName || fin5Top?.finstack?.projectName || '';
|
|
34
|
-
const locale = fin5Top?.languageManager?.currentLang ?? navigator?.language;
|
|
35
|
-
rootStore.locale = locale;
|
|
36
|
-
if (!rootStore.allLocales.includes(locale)) {
|
|
37
|
-
rootStore.allLocales.push(locale);
|
|
38
|
-
}
|
|
39
|
-
const target = fin5Top?.app?.TargetRef?.() || '';
|
|
40
|
-
rootStore.target = target ? HRef.make(target).value : '';
|
|
41
|
-
const getClient = () => client ??
|
|
42
|
-
new Client({
|
|
43
|
-
base: new URL(window.location.href),
|
|
44
|
-
project: containerProject,
|
|
45
|
-
options: { headers: { accept: 'text/zinc' } },
|
|
46
|
-
getServiceUrl,
|
|
47
|
-
getOpUrl,
|
|
48
|
-
getHaystackServiceUrl,
|
|
49
|
-
getHostServiceUrl,
|
|
50
|
-
});
|
|
51
|
-
const [containerClient, setContainerClient] = useState(getClient);
|
|
52
|
-
useEffect(() => {
|
|
53
|
-
setLoading(true);
|
|
54
|
-
const newClient = getClient();
|
|
55
|
-
setContainerClient(newClient);
|
|
56
|
-
// Load everything network wise before we load
|
|
57
|
-
// the application.
|
|
58
|
-
Promise.all([
|
|
59
|
-
newClient.ext.eval('finGetCurrentUser()'),
|
|
60
|
-
newClient.ext.loadDefs(),
|
|
61
|
-
]).then(([userGrid]) => {
|
|
62
|
-
rootStore.currentUser = userGrid.first;
|
|
63
|
-
setLoading(false);
|
|
64
|
-
});
|
|
65
|
-
}, [client, containerProject]);
|
|
66
|
-
return (React.createElement(AppRootStoreContext.Provider, { value: rootStore },
|
|
67
|
-
React.createElement(AppStoreContext.Provider, { value: appStore },
|
|
68
|
-
React.createElement(ClientContext.Provider, { value: containerClient },
|
|
69
|
-
React.createElement(I18NProvider, { locale: locale, setLoading: setLoadingi18n },
|
|
70
|
-
React.createElement(ThemeProvider, { theme: theme },
|
|
71
|
-
React.createElement(Loader, { loading: loading || loadingi18n },
|
|
72
|
-
React.createElement(ErrorBoundary, { mode: "global" /* ErrorBoundaryMode.global */ }, children))))))));
|
|
73
|
-
});
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2022, J2 Innovations. All Rights Reserved
|
|
3
|
+
*/
|
|
4
|
+
import React, { useEffect, useRef, useState } from 'react';
|
|
5
|
+
import { AppRootStoreContext, AppStoreContext } from '@j2inn/app-react';
|
|
6
|
+
import { observer } from 'mobx-react-lite';
|
|
7
|
+
import { Fin5AppRootStore } from './Fin5AppRootStore';
|
|
8
|
+
import { Client, } from 'haystack-nclient';
|
|
9
|
+
import { ClientContext } from 'haystack-react';
|
|
10
|
+
import { I18NProvider } from '@j2inn/utils';
|
|
11
|
+
import { ThemeProvider } from 'react-jss';
|
|
12
|
+
import { DEFAULT_THEME, GenerateTheme } from '@j2inn/ui';
|
|
13
|
+
import { fin5Top } from '../../fin5Top/fin5Top';
|
|
14
|
+
import { useFin5AppURLHashParameter } from '../../fin5Top/useFin5AppURLHashParameter';
|
|
15
|
+
import { HRef } from 'haystack-core';
|
|
16
|
+
import { ErrorBoundary } from '../components/ErrorBoundary';
|
|
17
|
+
import Loader from '../components/Loader';
|
|
18
|
+
const PATH_PREFIX = 'finApp';
|
|
19
|
+
const getServiceUrl = ({ origin, path }) => `${origin}/${PATH_PREFIX}/api/${path}`;
|
|
20
|
+
const getOpUrl = ({ origin, project, op }) => `${origin}/api/${project}/${op}`;
|
|
21
|
+
const getHaystackServiceUrl = ({ origin, project, path, }) => `${origin}/${PATH_PREFIX}/api/haystack${project ? `/${project}` : ''}/${path}`;
|
|
22
|
+
const getHostServiceUrl = ({ origin, path, }) => `${origin}/${PATH_PREFIX}/api/host/${path}`;
|
|
23
|
+
/**
|
|
24
|
+
* Creates a basic application container environment to run a view in FIN5.
|
|
25
|
+
*/
|
|
26
|
+
export const Fin5AppContainer = observer(({ children, appStore, client, project, theme = GenerateTheme(DEFAULT_THEME).light, }) => {
|
|
27
|
+
const [loading, setLoading] = useState(true);
|
|
28
|
+
const [loadingi18n, setLoadingi18n] = useState(true);
|
|
29
|
+
const rootStoreRef = useRef(null);
|
|
30
|
+
rootStoreRef.current ??= new Fin5AppRootStore();
|
|
31
|
+
const rootStore = rootStoreRef.current;
|
|
32
|
+
const [hashProjName] = useFin5AppURLHashParameter('projectName');
|
|
33
|
+
const containerProject = project || hashProjName || fin5Top?.finstack?.projectName || '';
|
|
34
|
+
const locale = fin5Top?.languageManager?.currentLang ?? navigator?.language;
|
|
35
|
+
rootStore.locale = locale;
|
|
36
|
+
if (!rootStore.allLocales.includes(locale)) {
|
|
37
|
+
rootStore.allLocales.push(locale);
|
|
38
|
+
}
|
|
39
|
+
const target = fin5Top?.app?.TargetRef?.() || '';
|
|
40
|
+
rootStore.target = target ? HRef.make(target).value : '';
|
|
41
|
+
const getClient = () => client ??
|
|
42
|
+
new Client({
|
|
43
|
+
base: new URL(window.location.href),
|
|
44
|
+
project: containerProject,
|
|
45
|
+
options: { headers: { accept: 'text/zinc' } },
|
|
46
|
+
getServiceUrl,
|
|
47
|
+
getOpUrl,
|
|
48
|
+
getHaystackServiceUrl,
|
|
49
|
+
getHostServiceUrl,
|
|
50
|
+
});
|
|
51
|
+
const [containerClient, setContainerClient] = useState(getClient);
|
|
52
|
+
useEffect(() => {
|
|
53
|
+
setLoading(true);
|
|
54
|
+
const newClient = getClient();
|
|
55
|
+
setContainerClient(newClient);
|
|
56
|
+
// Load everything network wise before we load
|
|
57
|
+
// the application.
|
|
58
|
+
Promise.all([
|
|
59
|
+
newClient.ext.eval('finGetCurrentUser()'),
|
|
60
|
+
newClient.ext.loadDefs(),
|
|
61
|
+
]).then(([userGrid]) => {
|
|
62
|
+
rootStore.currentUser = userGrid.first;
|
|
63
|
+
setLoading(false);
|
|
64
|
+
});
|
|
65
|
+
}, [client, containerProject]);
|
|
66
|
+
return (React.createElement(AppRootStoreContext.Provider, { value: rootStore },
|
|
67
|
+
React.createElement(AppStoreContext.Provider, { value: appStore },
|
|
68
|
+
React.createElement(ClientContext.Provider, { value: containerClient },
|
|
69
|
+
React.createElement(I18NProvider, { locale: locale, setLoading: setLoadingi18n },
|
|
70
|
+
React.createElement(ThemeProvider, { theme: theme },
|
|
71
|
+
React.createElement(Loader, { loading: loading || loadingi18n },
|
|
72
|
+
React.createElement(ErrorBoundary, { mode: "global" /* ErrorBoundaryMode.global */ }, children))))))));
|
|
73
|
+
});
|
|
74
74
|
//# sourceMappingURL=Fin5AppContainer.js.map
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import { App, AppAccessLevel, AppRootStore, AppView, CustomHistory } from '@j2inn/app';
|
|
2
|
-
import { HDict } from 'haystack-core';
|
|
3
|
-
/**
|
|
4
|
-
* An application root store for use with FIN5.
|
|
5
|
-
*/
|
|
6
|
-
export declare class Fin5AppRootStore implements AppRootStore {
|
|
7
|
-
project: string;
|
|
8
|
-
sidebarOpen: boolean;
|
|
9
|
-
locale: string;
|
|
10
|
-
allLocales: string[];
|
|
11
|
-
target: string;
|
|
12
|
-
targetSidebar: string;
|
|
13
|
-
currentUser: HDict | undefined;
|
|
14
|
-
get app(): {
|
|
15
|
-
id: string;
|
|
16
|
-
name: string;
|
|
17
|
-
app: App;
|
|
18
|
-
view: AppView;
|
|
19
|
-
} | undefined;
|
|
20
|
-
get sidebar(): {
|
|
21
|
-
id: string;
|
|
22
|
-
name: string;
|
|
23
|
-
app: App;
|
|
24
|
-
view: AppView;
|
|
25
|
-
} | undefined;
|
|
26
|
-
readonly apps: App[];
|
|
27
|
-
readonly history: CustomHistory;
|
|
28
|
-
readonly historySidebar: CustomHistory;
|
|
29
|
-
constructor();
|
|
30
|
-
openAppInNewWindow(): void;
|
|
31
|
-
open(): void;
|
|
32
|
-
openSidebar(): void;
|
|
33
|
-
postAppMessage(): void;
|
|
34
|
-
registerSidebars(): void;
|
|
35
|
-
unregisterSidebars(): void;
|
|
36
|
-
registerQuicklinks(): void;
|
|
37
|
-
unregisterQuicklinks(): void;
|
|
38
|
-
hasAppAccess: (_: string, access: AppAccessLevel) => boolean;
|
|
39
|
-
hasSidebar(): boolean;
|
|
40
|
-
}
|
|
1
|
+
import { App, AppAccessLevel, AppRootStore, AppView, CustomHistory } from '@j2inn/app';
|
|
2
|
+
import { HDict } from 'haystack-core';
|
|
3
|
+
/**
|
|
4
|
+
* An application root store for use with FIN5.
|
|
5
|
+
*/
|
|
6
|
+
export declare class Fin5AppRootStore implements AppRootStore {
|
|
7
|
+
project: string;
|
|
8
|
+
sidebarOpen: boolean;
|
|
9
|
+
locale: string;
|
|
10
|
+
allLocales: string[];
|
|
11
|
+
target: string;
|
|
12
|
+
targetSidebar: string;
|
|
13
|
+
currentUser: HDict | undefined;
|
|
14
|
+
get app(): {
|
|
15
|
+
id: string;
|
|
16
|
+
name: string;
|
|
17
|
+
app: App;
|
|
18
|
+
view: AppView;
|
|
19
|
+
} | undefined;
|
|
20
|
+
get sidebar(): {
|
|
21
|
+
id: string;
|
|
22
|
+
name: string;
|
|
23
|
+
app: App;
|
|
24
|
+
view: AppView;
|
|
25
|
+
} | undefined;
|
|
26
|
+
readonly apps: App[];
|
|
27
|
+
readonly history: CustomHistory;
|
|
28
|
+
readonly historySidebar: CustomHistory;
|
|
29
|
+
constructor();
|
|
30
|
+
openAppInNewWindow(): void;
|
|
31
|
+
open(): void;
|
|
32
|
+
openSidebar(): void;
|
|
33
|
+
postAppMessage(): void;
|
|
34
|
+
registerSidebars(): void;
|
|
35
|
+
unregisterSidebars(): void;
|
|
36
|
+
registerQuicklinks(): void;
|
|
37
|
+
unregisterQuicklinks(): void;
|
|
38
|
+
hasAppAccess: (_: string, access: AppAccessLevel) => boolean;
|
|
39
|
+
hasSidebar(): boolean;
|
|
40
|
+
}
|
|
@@ -1,66 +1,66 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2022, J2 Innovations. All Rights Reserved
|
|
3
|
-
*/
|
|
4
|
-
import { makeAutoObservable, observable } from 'mobx';
|
|
5
|
-
/**
|
|
6
|
-
* An application root store for use with FIN5.
|
|
7
|
-
*/
|
|
8
|
-
export class Fin5AppRootStore {
|
|
9
|
-
project = '';
|
|
10
|
-
sidebarOpen = false;
|
|
11
|
-
locale = '';
|
|
12
|
-
allLocales = [];
|
|
13
|
-
target = '';
|
|
14
|
-
targetSidebar = '';
|
|
15
|
-
currentUser;
|
|
16
|
-
get app() {
|
|
17
|
-
return undefined;
|
|
18
|
-
}
|
|
19
|
-
get sidebar() {
|
|
20
|
-
return undefined;
|
|
21
|
-
}
|
|
22
|
-
apps = [];
|
|
23
|
-
history = {
|
|
24
|
-
state: {},
|
|
25
|
-
pushState: (state) => {
|
|
26
|
-
this.history.state = state;
|
|
27
|
-
},
|
|
28
|
-
replaceState: (state) => {
|
|
29
|
-
this.history.state = state;
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
historySidebar = {
|
|
33
|
-
state: {},
|
|
34
|
-
pushState: (state) => {
|
|
35
|
-
this.historySidebar.state = state;
|
|
36
|
-
},
|
|
37
|
-
replaceState: (state) => {
|
|
38
|
-
this.historySidebar.state = state;
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
constructor() {
|
|
42
|
-
makeAutoObservable(this, {
|
|
43
|
-
currentUser: observable.ref,
|
|
44
|
-
apps: observable.ref,
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
openAppInNewWindow() { }
|
|
48
|
-
open() { }
|
|
49
|
-
openSidebar() { }
|
|
50
|
-
postAppMessage() { }
|
|
51
|
-
registerSidebars() { }
|
|
52
|
-
unregisterSidebars() { }
|
|
53
|
-
registerQuicklinks() { }
|
|
54
|
-
unregisterQuicklinks() { }
|
|
55
|
-
hasAppAccess = (_, access) => {
|
|
56
|
-
// For FIN5, an operator only has readonly app level access.
|
|
57
|
-
const user = this.currentUser;
|
|
58
|
-
return user?.get('userRole')?.value === 'op'
|
|
59
|
-
? access === 'read'
|
|
60
|
-
: !!user;
|
|
61
|
-
};
|
|
62
|
-
hasSidebar() {
|
|
63
|
-
return false;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2022, J2 Innovations. All Rights Reserved
|
|
3
|
+
*/
|
|
4
|
+
import { makeAutoObservable, observable } from 'mobx';
|
|
5
|
+
/**
|
|
6
|
+
* An application root store for use with FIN5.
|
|
7
|
+
*/
|
|
8
|
+
export class Fin5AppRootStore {
|
|
9
|
+
project = '';
|
|
10
|
+
sidebarOpen = false;
|
|
11
|
+
locale = '';
|
|
12
|
+
allLocales = [];
|
|
13
|
+
target = '';
|
|
14
|
+
targetSidebar = '';
|
|
15
|
+
currentUser;
|
|
16
|
+
get app() {
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
19
|
+
get sidebar() {
|
|
20
|
+
return undefined;
|
|
21
|
+
}
|
|
22
|
+
apps = [];
|
|
23
|
+
history = {
|
|
24
|
+
state: {},
|
|
25
|
+
pushState: (state) => {
|
|
26
|
+
this.history.state = state;
|
|
27
|
+
},
|
|
28
|
+
replaceState: (state) => {
|
|
29
|
+
this.history.state = state;
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
historySidebar = {
|
|
33
|
+
state: {},
|
|
34
|
+
pushState: (state) => {
|
|
35
|
+
this.historySidebar.state = state;
|
|
36
|
+
},
|
|
37
|
+
replaceState: (state) => {
|
|
38
|
+
this.historySidebar.state = state;
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
constructor() {
|
|
42
|
+
makeAutoObservable(this, {
|
|
43
|
+
currentUser: observable.ref,
|
|
44
|
+
apps: observable.ref,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
openAppInNewWindow() { }
|
|
48
|
+
open() { }
|
|
49
|
+
openSidebar() { }
|
|
50
|
+
postAppMessage() { }
|
|
51
|
+
registerSidebars() { }
|
|
52
|
+
unregisterSidebars() { }
|
|
53
|
+
registerQuicklinks() { }
|
|
54
|
+
unregisterQuicklinks() { }
|
|
55
|
+
hasAppAccess = (_, access) => {
|
|
56
|
+
// For FIN5, an operator only has readonly app level access.
|
|
57
|
+
const user = this.currentUser;
|
|
58
|
+
return user?.get('userRole')?.value === 'op'
|
|
59
|
+
? access === 'read'
|
|
60
|
+
: !!user;
|
|
61
|
+
};
|
|
62
|
+
hasSidebar() {
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
66
|
//# sourceMappingURL=Fin5AppRootStore.js.map
|
|
@@ -1,57 +1,57 @@
|
|
|
1
|
-
import React, { ErrorInfo, ReactNode } from 'react';
|
|
2
|
-
/**
|
|
3
|
-
* An error boundary can work at the global level (where something really screws up)
|
|
4
|
-
* or an an app level (where the error is captured just for the running application).
|
|
5
|
-
*/
|
|
6
|
-
export declare const enum ErrorBoundaryMode {
|
|
7
|
-
global = "global",
|
|
8
|
-
app = "app"
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* The properties for an error boundary.
|
|
12
|
-
*/
|
|
13
|
-
interface ErrorBoundaryProps {
|
|
14
|
-
/**
|
|
15
|
-
* The associated application id.
|
|
16
|
-
*/
|
|
17
|
-
appId?: string;
|
|
18
|
-
/**
|
|
19
|
-
* The error mode.
|
|
20
|
-
*/
|
|
21
|
-
mode: ErrorBoundaryMode;
|
|
22
|
-
/**
|
|
23
|
-
* Optional callback to display a report dialog.
|
|
24
|
-
*/
|
|
25
|
-
showReportDialog?: () => void;
|
|
26
|
-
/**
|
|
27
|
-
* Optional callback used to capture the error.
|
|
28
|
-
*/
|
|
29
|
-
onError?: (error: Error) => void;
|
|
30
|
-
/**
|
|
31
|
-
* Child components.
|
|
32
|
-
*/
|
|
33
|
-
children?: React.ReactNode;
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* The state for an error boundary.
|
|
37
|
-
*/
|
|
38
|
-
interface ErrorBoundryState {
|
|
39
|
-
/**
|
|
40
|
-
* The last captured error.
|
|
41
|
-
*/
|
|
42
|
-
error?: Error;
|
|
43
|
-
}
|
|
44
|
-
/**
|
|
45
|
-
* A common error boundary used to capture errors.
|
|
46
|
-
*/
|
|
47
|
-
export declare class ErrorBoundary extends React.Component<ErrorBoundaryProps, ErrorBoundryState> {
|
|
48
|
-
state: {
|
|
49
|
-
error?: Error;
|
|
50
|
-
};
|
|
51
|
-
componentDidCatch(error: Error, info: ErrorInfo): void;
|
|
52
|
-
static getDerivedStateFromError(error: Error): {
|
|
53
|
-
error: Error;
|
|
54
|
-
};
|
|
55
|
-
render(): ReactNode | JSX.Element;
|
|
56
|
-
}
|
|
57
|
-
export {};
|
|
1
|
+
import React, { ErrorInfo, ReactNode } from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* An error boundary can work at the global level (where something really screws up)
|
|
4
|
+
* or an an app level (where the error is captured just for the running application).
|
|
5
|
+
*/
|
|
6
|
+
export declare const enum ErrorBoundaryMode {
|
|
7
|
+
global = "global",
|
|
8
|
+
app = "app"
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* The properties for an error boundary.
|
|
12
|
+
*/
|
|
13
|
+
interface ErrorBoundaryProps {
|
|
14
|
+
/**
|
|
15
|
+
* The associated application id.
|
|
16
|
+
*/
|
|
17
|
+
appId?: string;
|
|
18
|
+
/**
|
|
19
|
+
* The error mode.
|
|
20
|
+
*/
|
|
21
|
+
mode: ErrorBoundaryMode;
|
|
22
|
+
/**
|
|
23
|
+
* Optional callback to display a report dialog.
|
|
24
|
+
*/
|
|
25
|
+
showReportDialog?: () => void;
|
|
26
|
+
/**
|
|
27
|
+
* Optional callback used to capture the error.
|
|
28
|
+
*/
|
|
29
|
+
onError?: (error: Error) => void;
|
|
30
|
+
/**
|
|
31
|
+
* Child components.
|
|
32
|
+
*/
|
|
33
|
+
children?: React.ReactNode;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* The state for an error boundary.
|
|
37
|
+
*/
|
|
38
|
+
interface ErrorBoundryState {
|
|
39
|
+
/**
|
|
40
|
+
* The last captured error.
|
|
41
|
+
*/
|
|
42
|
+
error?: Error;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* A common error boundary used to capture errors.
|
|
46
|
+
*/
|
|
47
|
+
export declare class ErrorBoundary extends React.Component<ErrorBoundaryProps, ErrorBoundryState> {
|
|
48
|
+
state: {
|
|
49
|
+
error?: Error;
|
|
50
|
+
};
|
|
51
|
+
componentDidCatch(error: Error, info: ErrorInfo): void;
|
|
52
|
+
static getDerivedStateFromError(error: Error): {
|
|
53
|
+
error: Error;
|
|
54
|
+
};
|
|
55
|
+
render(): ReactNode | JSX.Element;
|
|
56
|
+
}
|
|
57
|
+
export {};
|