@equinor/fusion-framework-react-app 0.0.0-context-error-20240131144633
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/CHANGELOG.md +1201 -0
- package/LICENSE +21 -0
- package/README.md +92 -0
- package/dist/esm/bookmark/index.js +3 -0
- package/dist/esm/bookmark/index.js.map +1 -0
- package/dist/esm/bookmark/useBookmark.js +4 -0
- package/dist/esm/bookmark/useBookmark.js.map +1 -0
- package/dist/esm/bookmark/useCurrentBookmark.js +4 -0
- package/dist/esm/bookmark/useCurrentBookmark.js.map +1 -0
- package/dist/esm/context/index.js +5 -0
- package/dist/esm/context/index.js.map +1 -0
- package/dist/esm/context/useContextProvider.js +4 -0
- package/dist/esm/context/useContextProvider.js.map +1 -0
- package/dist/esm/context/useCurrentContext.js +5 -0
- package/dist/esm/context/useCurrentContext.js.map +1 -0
- package/dist/esm/create-component.js +30 -0
- package/dist/esm/create-component.js.map +1 -0
- package/dist/esm/create-legacy-app.js +21 -0
- package/dist/esm/create-legacy-app.js.map +1 -0
- package/dist/esm/feature-flag/index.js +2 -0
- package/dist/esm/feature-flag/index.js.map +1 -0
- package/dist/esm/feature-flag/useFeature.js +33 -0
- package/dist/esm/feature-flag/useFeature.js.map +1 -0
- package/dist/esm/framework/index.js +3 -0
- package/dist/esm/framework/index.js.map +1 -0
- package/dist/esm/framework/useFrameworkCurrentContext.js +5 -0
- package/dist/esm/framework/useFrameworkCurrentContext.js.map +1 -0
- package/dist/esm/http/index.js +2 -0
- package/dist/esm/http/index.js.map +1 -0
- package/dist/esm/index.js +9 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/make-component.js +28 -0
- package/dist/esm/make-component.js.map +1 -0
- package/dist/esm/msal/index.js +4 -0
- package/dist/esm/msal/index.js.map +1 -0
- package/dist/esm/msal/useAccessToken.js +6 -0
- package/dist/esm/msal/useAccessToken.js.map +1 -0
- package/dist/esm/msal/useCurrentAccount.js +6 -0
- package/dist/esm/msal/useCurrentAccount.js.map +1 -0
- package/dist/esm/msal/useToken.js +20 -0
- package/dist/esm/msal/useToken.js.map +1 -0
- package/dist/esm/navigation/index.js +3 -0
- package/dist/esm/navigation/index.js.map +1 -0
- package/dist/esm/navigation/useNavigationModule.js +3 -0
- package/dist/esm/navigation/useNavigationModule.js.map +1 -0
- package/dist/esm/navigation/useRouter.js +7 -0
- package/dist/esm/navigation/useRouter.js.map +1 -0
- package/dist/esm/render-app.js +10 -0
- package/dist/esm/render-app.js.map +1 -0
- package/dist/esm/render-component.js +17 -0
- package/dist/esm/render-component.js.map +1 -0
- package/dist/esm/useAppModule.js +10 -0
- package/dist/esm/useAppModule.js.map +1 -0
- package/dist/esm/useAppModules.js +4 -0
- package/dist/esm/useAppModules.js.map +1 -0
- package/dist/esm/version.js +2 -0
- package/dist/esm/version.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types/bookmark/index.d.ts +3 -0
- package/dist/types/bookmark/useBookmark.d.ts +2 -0
- package/dist/types/bookmark/useCurrentBookmark.d.ts +3 -0
- package/dist/types/context/index.d.ts +4 -0
- package/dist/types/context/useContextProvider.d.ts +2 -0
- package/dist/types/context/useCurrentContext.d.ts +5 -0
- package/dist/types/create-component.d.ts +21 -0
- package/dist/types/create-legacy-app.d.ts +4 -0
- package/dist/types/feature-flag/index.d.ts +2 -0
- package/dist/types/feature-flag/useFeature.d.ts +6 -0
- package/dist/types/framework/index.d.ts +2 -0
- package/dist/types/framework/useFrameworkCurrentContext.d.ts +5 -0
- package/dist/types/http/index.d.ts +1 -0
- package/dist/types/index.d.ts +10 -0
- package/dist/types/make-component.d.ts +24 -0
- package/dist/types/msal/index.d.ts +3 -0
- package/dist/types/msal/useAccessToken.d.ts +6 -0
- package/dist/types/msal/useCurrentAccount.d.ts +2 -0
- package/dist/types/msal/useToken.d.ts +7 -0
- package/dist/types/navigation/index.d.ts +2 -0
- package/dist/types/navigation/useNavigationModule.d.ts +2 -0
- package/dist/types/navigation/useRouter.d.ts +2 -0
- package/dist/types/render-app.d.ts +5 -0
- package/dist/types/render-component.d.ts +4 -0
- package/dist/types/useAppModule.d.ts +4 -0
- package/dist/types/useAppModules.d.ts +3 -0
- package/dist/types/version.d.ts +1 -0
- package/package.json +112 -0
- package/src/bookmark/index.ts +4 -0
- package/src/bookmark/useBookmark.ts +21 -0
- package/src/bookmark/useCurrentBookmark.ts +21 -0
- package/src/context/index.ts +6 -0
- package/src/context/useContextProvider.ts +6 -0
- package/src/context/useCurrentContext.ts +6 -0
- package/src/create-component.tsx +114 -0
- package/src/create-legacy-app.tsx +35 -0
- package/src/feature-flag/README.md +20 -0
- package/src/feature-flag/index.ts +6 -0
- package/src/feature-flag/useFeature.ts +66 -0
- package/src/framework/index.ts +7 -0
- package/src/framework/useFrameworkCurrentContext.ts +6 -0
- package/src/http/index.ts +1 -0
- package/src/index.ts +30 -0
- package/src/make-component.tsx +74 -0
- package/src/msal/index.ts +3 -0
- package/src/msal/useAccessToken.ts +15 -0
- package/src/msal/useCurrentAccount.ts +11 -0
- package/src/msal/useToken.ts +29 -0
- package/src/navigation/index.ts +2 -0
- package/src/navigation/useNavigationModule.ts +5 -0
- package/src/navigation/useRouter.ts +16 -0
- package/src/render-app.ts +14 -0
- package/src/render-component.tsx +46 -0
- package/src/useAppModule.ts +31 -0
- package/src/useAppModules.ts +9 -0
- package/src/version.ts +2 -0
- package/tsconfig.json +42 -0
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import React, { lazy } from 'react';
|
|
2
|
+
|
|
3
|
+
import { FrameworkProvider } from '@equinor/fusion-framework-react';
|
|
4
|
+
import type { Fusion } from '@equinor/fusion-framework-react';
|
|
5
|
+
|
|
6
|
+
import { AppEnv, configureModules } from '@equinor/fusion-framework-app';
|
|
7
|
+
import type { AppModuleInitiator, AppModulesInstance } from '@equinor/fusion-framework-app';
|
|
8
|
+
|
|
9
|
+
import type { AnyModule } from '@equinor/fusion-framework-module';
|
|
10
|
+
|
|
11
|
+
import type { FrameworkEvent, FrameworkEventInit } from '@equinor/fusion-framework-module-event';
|
|
12
|
+
|
|
13
|
+
import { ModuleProvider as AppModuleProvider } from '@equinor/fusion-framework-react-module';
|
|
14
|
+
|
|
15
|
+
export type ComponentRenderArgs<TFusion extends Fusion = Fusion, TEnv = AppEnv> = {
|
|
16
|
+
fusion: TFusion;
|
|
17
|
+
env: TEnv;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export type ComponentRenderer<TFusion extends Fusion = Fusion, TEnv = AppEnv> = (
|
|
21
|
+
fusion: TFusion,
|
|
22
|
+
env: TEnv,
|
|
23
|
+
) => React.LazyExoticComponent<React.ComponentType>;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Creates an lazy loading Component which configures modules
|
|
27
|
+
* and provides context to framework and configured modules
|
|
28
|
+
*
|
|
29
|
+
* __Exposed providers__
|
|
30
|
+
* @see {@link @equinor/fusion-framework-react.FrameworkProvider | FrameworkProvider}
|
|
31
|
+
* @see {@link ModuleProvider | ModuleProvider}
|
|
32
|
+
*
|
|
33
|
+
* @template TModules module types included in configuration.
|
|
34
|
+
* @param Component - React component to render
|
|
35
|
+
* @param configure - Callback for configuring application
|
|
36
|
+
* @param modules - required modules for application
|
|
37
|
+
*/
|
|
38
|
+
export const makeComponent = <
|
|
39
|
+
TModules extends Array<AnyModule>,
|
|
40
|
+
TRef extends Fusion = Fusion,
|
|
41
|
+
TEnv extends AppEnv = AppEnv,
|
|
42
|
+
>(
|
|
43
|
+
Component: React.ReactNode,
|
|
44
|
+
args: { fusion: TRef; env: TEnv },
|
|
45
|
+
configure?: AppModuleInitiator<TModules, TRef, TEnv>,
|
|
46
|
+
) =>
|
|
47
|
+
lazy(async () => {
|
|
48
|
+
const init = configureModules<TModules, TRef, TEnv>(configure);
|
|
49
|
+
const modules = (await init(args)) as unknown as AppModulesInstance;
|
|
50
|
+
|
|
51
|
+
const { fusion } = args;
|
|
52
|
+
|
|
53
|
+
modules.event.dispatchEvent('onReactAppLoaded', {
|
|
54
|
+
detail: { modules, fusion },
|
|
55
|
+
source: Component,
|
|
56
|
+
});
|
|
57
|
+
return {
|
|
58
|
+
default: () => (
|
|
59
|
+
<FrameworkProvider value={fusion}>
|
|
60
|
+
<AppModuleProvider value={modules}>{Component}</AppModuleProvider>
|
|
61
|
+
</FrameworkProvider>
|
|
62
|
+
),
|
|
63
|
+
};
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
declare module '@equinor/fusion-framework-module-event' {
|
|
67
|
+
interface FrameworkEventMap {
|
|
68
|
+
onReactAppLoaded: FrameworkEvent<
|
|
69
|
+
FrameworkEventInit<{ modules: AppModulesInstance; fusion: Fusion }, React.ComponentType>
|
|
70
|
+
>;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export default makeComponent;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AuthRequest } from '@equinor/fusion-framework-module-msal/client';
|
|
2
|
+
import { useToken } from './useToken';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Custom hook that retrieves an access token for the specified authentication request.
|
|
6
|
+
*
|
|
7
|
+
* @param req - The authentication request.
|
|
8
|
+
* @returns An object containing the access token, pending state, and error.
|
|
9
|
+
*/
|
|
10
|
+
export const useAccessToken = (
|
|
11
|
+
req: AuthRequest,
|
|
12
|
+
): { token?: string; pending: boolean; error: unknown } => {
|
|
13
|
+
const { token, error, pending } = useToken(req);
|
|
14
|
+
return { token: token?.accessToken, pending, error };
|
|
15
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AccountInfo } from '@equinor/fusion-framework-module-msal';
|
|
2
|
+
import useAppModule from '../useAppModule';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Retrieves the current account information from the MSAL provider.
|
|
6
|
+
* @returns The current account information or undefined if no account is available.
|
|
7
|
+
*/
|
|
8
|
+
export const useCurrentAccount = (): AccountInfo | undefined => {
|
|
9
|
+
const msalProvider = useAppModule('auth');
|
|
10
|
+
return msalProvider.defaultAccount;
|
|
11
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { AuthRequest, AuthenticationResult } from '@equinor/fusion-framework-module-msal/client';
|
|
2
|
+
import useAppModule from '../useAppModule';
|
|
3
|
+
import { useEffect, useState } from 'react';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Custom hook for acquiring an authentication token using MSAL.
|
|
7
|
+
* @param req - The authentication request.
|
|
8
|
+
* @returns An object containing the acquired token, pending state, and error.
|
|
9
|
+
*/
|
|
10
|
+
export const useToken = (
|
|
11
|
+
req: AuthRequest,
|
|
12
|
+
): { token?: AuthenticationResult; pending: boolean; error: unknown } => {
|
|
13
|
+
const msalProvider = useAppModule('auth');
|
|
14
|
+
const [token, setToken] = useState<AuthenticationResult | undefined>(undefined);
|
|
15
|
+
const [pending, setPending] = useState<boolean>(false);
|
|
16
|
+
const [error, setError] = useState<unknown>(null);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
setPending(true);
|
|
19
|
+
setToken(undefined);
|
|
20
|
+
msalProvider
|
|
21
|
+
.acquireToken(req)
|
|
22
|
+
.then((token) => token && setToken(token))
|
|
23
|
+
.catch(setError)
|
|
24
|
+
.finally(() => setPending(false));
|
|
25
|
+
}, [msalProvider, req]);
|
|
26
|
+
return { token, pending, error };
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
export default useToken;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import useAppModule from '../useAppModule';
|
|
2
|
+
import { INavigationProvider } from '@equinor/fusion-framework-module-navigation';
|
|
3
|
+
|
|
4
|
+
/** hook for getting the navigation provider (if enabled!) */
|
|
5
|
+
export const useNavigationModule = (): INavigationProvider => useAppModule('navigation');
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { useMemo } from 'react';
|
|
2
|
+
import { useNavigationModule } from './useNavigationModule';
|
|
3
|
+
import { type INavigationProvider } from '@equinor/fusion-framework-module-navigation';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* create a router for react routing
|
|
7
|
+
* @see {@link [docs](https://equinor.github.io/fusion-framework/modules/navigation/)}
|
|
8
|
+
* @see {@link [react-router](https://reactrouter.com/en/main/routers/create-browser-router)}
|
|
9
|
+
* @param routes router objects __(must be static | memorized)__
|
|
10
|
+
*/
|
|
11
|
+
export const useRouter = (
|
|
12
|
+
routes: Parameters<INavigationProvider['createRouter']>[0],
|
|
13
|
+
): ReturnType<INavigationProvider['createRouter']> => {
|
|
14
|
+
const provider = useNavigationModule();
|
|
15
|
+
return useMemo(() => provider.createRouter(routes), [provider, routes]);
|
|
16
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createComponent } from './create-component';
|
|
2
|
+
import { renderComponent, RenderTeardown } from './render-component';
|
|
3
|
+
|
|
4
|
+
import type { ComponentRenderArgs } from './create-component';
|
|
5
|
+
|
|
6
|
+
/** @deprecated */
|
|
7
|
+
export const renderApp = (...componentArgs: Parameters<typeof createComponent>) => {
|
|
8
|
+
const renderer = renderComponent(createComponent(...componentArgs));
|
|
9
|
+
return (el: HTMLElement, args: ComponentRenderArgs): RenderTeardown => {
|
|
10
|
+
return renderer(el, args);
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export default renderApp;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { Suspense, StrictMode } from 'react';
|
|
2
|
+
import type { FunctionComponent } from 'react';
|
|
3
|
+
import type { ComponentRenderArgs, ComponentRenderer } from './create-component';
|
|
4
|
+
import ReactDOM from 'react-dom';
|
|
5
|
+
|
|
6
|
+
export type RenderTeardown = VoidFunction;
|
|
7
|
+
|
|
8
|
+
/** @deprecated */
|
|
9
|
+
export const renderComponent = (renderer: ComponentRenderer) => {
|
|
10
|
+
return (el: HTMLElement, args: ComponentRenderArgs): RenderTeardown => {
|
|
11
|
+
const Component = renderer(args.fusion, args.env);
|
|
12
|
+
return render(el, Component);
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
const render = (el: Element, Component: FunctionComponent): RenderTeardown => {
|
|
17
|
+
// eslint-disable-next-line react/no-deprecated
|
|
18
|
+
ReactDOM.render(
|
|
19
|
+
<StrictMode>
|
|
20
|
+
<Suspense fallback={<p>loading app</p>}>
|
|
21
|
+
<Component />
|
|
22
|
+
</Suspense>
|
|
23
|
+
</StrictMode>,
|
|
24
|
+
el,
|
|
25
|
+
);
|
|
26
|
+
return () => {
|
|
27
|
+
// eslint-disable-next-line react/no-deprecated
|
|
28
|
+
ReactDOM.unmountComponentAtNode(el);
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
// const render = (el: Element, Component: FunctionComponent): RenderTeardown => {
|
|
33
|
+
// const root = createRoot(el);
|
|
34
|
+
// root.render(
|
|
35
|
+
// <StrictMode>
|
|
36
|
+
// <Suspense fallback={<p>loading app</p>}>
|
|
37
|
+
// <Component />
|
|
38
|
+
// </Suspense>
|
|
39
|
+
// </StrictMode>
|
|
40
|
+
// );
|
|
41
|
+
// return () => {
|
|
42
|
+
// root.unmount();
|
|
43
|
+
// };
|
|
44
|
+
// };
|
|
45
|
+
|
|
46
|
+
export default renderComponent;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { AppModules, AppModulesInstance } from '@equinor/fusion-framework-app';
|
|
2
|
+
import { AnyModule, ModuleKey, ModuleType, ModuleTypes } from '@equinor/fusion-framework-module';
|
|
3
|
+
import { useAppModules } from './useAppModules';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* hook for getting a module from the application scope
|
|
7
|
+
*
|
|
8
|
+
* @template TType type of the module
|
|
9
|
+
*
|
|
10
|
+
* @param module name of the module, provide TType if not registered
|
|
11
|
+
*
|
|
12
|
+
* @returns provider of the module
|
|
13
|
+
*/
|
|
14
|
+
export const useAppModule = <
|
|
15
|
+
TType extends AnyModule | unknown = unknown,
|
|
16
|
+
TKey extends string = ModuleKey<ModuleTypes<AppModules<[TType]>>>,
|
|
17
|
+
>(
|
|
18
|
+
module: TKey,
|
|
19
|
+
): TType extends AnyModule
|
|
20
|
+
? ModuleType<TType>
|
|
21
|
+
: AppModulesInstance[Extract<keyof AppModulesInstance, TKey>] => {
|
|
22
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
23
|
+
// @ts-ignore
|
|
24
|
+
const appModule = useAppModules()[module];
|
|
25
|
+
if (!appModule) {
|
|
26
|
+
throw Error(`the requested module [${module}] is not included in the app scope`);
|
|
27
|
+
}
|
|
28
|
+
return appModule;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
export default useAppModule;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { AppModulesInstance } from '@equinor/fusion-framework-app';
|
|
2
|
+
import type { AnyModule } from '@equinor/fusion-framework-module';
|
|
3
|
+
import { useModules } from '@equinor/fusion-framework-react-module';
|
|
4
|
+
|
|
5
|
+
export const useAppModules = <
|
|
6
|
+
T extends Array<AnyModule> | unknown = unknown,
|
|
7
|
+
>(): AppModulesInstance<T> => useModules<AppModulesInstance<T>>();
|
|
8
|
+
|
|
9
|
+
export default useAppModules;
|
package/src/version.ts
ADDED
package/tsconfig.json
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "../tsconfig.react.json",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"outDir": "dist/esm",
|
|
5
|
+
"rootDir": "src",
|
|
6
|
+
"declarationDir": "./dist/types",
|
|
7
|
+
"paths": {
|
|
8
|
+
"react": [ "./node_modules/@types/react" ],
|
|
9
|
+
},
|
|
10
|
+
},
|
|
11
|
+
"references": [
|
|
12
|
+
|
|
13
|
+
{
|
|
14
|
+
"path": "../../app"
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
"path": "../framework"
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
"path": "../modules/module"
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
"path": "../modules/http"
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"path": "../modules/context"
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
"path": "../modules/bookmark"
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
"path": "../../modules/navigation"
|
|
33
|
+
}
|
|
34
|
+
],
|
|
35
|
+
"include": [
|
|
36
|
+
"src/**/*"
|
|
37
|
+
],
|
|
38
|
+
"exclude": [
|
|
39
|
+
"node_modules",
|
|
40
|
+
"lib"
|
|
41
|
+
]
|
|
42
|
+
}
|