@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.
Files changed (115) hide show
  1. package/CHANGELOG.md +1201 -0
  2. package/LICENSE +21 -0
  3. package/README.md +92 -0
  4. package/dist/esm/bookmark/index.js +3 -0
  5. package/dist/esm/bookmark/index.js.map +1 -0
  6. package/dist/esm/bookmark/useBookmark.js +4 -0
  7. package/dist/esm/bookmark/useBookmark.js.map +1 -0
  8. package/dist/esm/bookmark/useCurrentBookmark.js +4 -0
  9. package/dist/esm/bookmark/useCurrentBookmark.js.map +1 -0
  10. package/dist/esm/context/index.js +5 -0
  11. package/dist/esm/context/index.js.map +1 -0
  12. package/dist/esm/context/useContextProvider.js +4 -0
  13. package/dist/esm/context/useContextProvider.js.map +1 -0
  14. package/dist/esm/context/useCurrentContext.js +5 -0
  15. package/dist/esm/context/useCurrentContext.js.map +1 -0
  16. package/dist/esm/create-component.js +30 -0
  17. package/dist/esm/create-component.js.map +1 -0
  18. package/dist/esm/create-legacy-app.js +21 -0
  19. package/dist/esm/create-legacy-app.js.map +1 -0
  20. package/dist/esm/feature-flag/index.js +2 -0
  21. package/dist/esm/feature-flag/index.js.map +1 -0
  22. package/dist/esm/feature-flag/useFeature.js +33 -0
  23. package/dist/esm/feature-flag/useFeature.js.map +1 -0
  24. package/dist/esm/framework/index.js +3 -0
  25. package/dist/esm/framework/index.js.map +1 -0
  26. package/dist/esm/framework/useFrameworkCurrentContext.js +5 -0
  27. package/dist/esm/framework/useFrameworkCurrentContext.js.map +1 -0
  28. package/dist/esm/http/index.js +2 -0
  29. package/dist/esm/http/index.js.map +1 -0
  30. package/dist/esm/index.js +9 -0
  31. package/dist/esm/index.js.map +1 -0
  32. package/dist/esm/make-component.js +28 -0
  33. package/dist/esm/make-component.js.map +1 -0
  34. package/dist/esm/msal/index.js +4 -0
  35. package/dist/esm/msal/index.js.map +1 -0
  36. package/dist/esm/msal/useAccessToken.js +6 -0
  37. package/dist/esm/msal/useAccessToken.js.map +1 -0
  38. package/dist/esm/msal/useCurrentAccount.js +6 -0
  39. package/dist/esm/msal/useCurrentAccount.js.map +1 -0
  40. package/dist/esm/msal/useToken.js +20 -0
  41. package/dist/esm/msal/useToken.js.map +1 -0
  42. package/dist/esm/navigation/index.js +3 -0
  43. package/dist/esm/navigation/index.js.map +1 -0
  44. package/dist/esm/navigation/useNavigationModule.js +3 -0
  45. package/dist/esm/navigation/useNavigationModule.js.map +1 -0
  46. package/dist/esm/navigation/useRouter.js +7 -0
  47. package/dist/esm/navigation/useRouter.js.map +1 -0
  48. package/dist/esm/render-app.js +10 -0
  49. package/dist/esm/render-app.js.map +1 -0
  50. package/dist/esm/render-component.js +17 -0
  51. package/dist/esm/render-component.js.map +1 -0
  52. package/dist/esm/useAppModule.js +10 -0
  53. package/dist/esm/useAppModule.js.map +1 -0
  54. package/dist/esm/useAppModules.js +4 -0
  55. package/dist/esm/useAppModules.js.map +1 -0
  56. package/dist/esm/version.js +2 -0
  57. package/dist/esm/version.js.map +1 -0
  58. package/dist/tsconfig.tsbuildinfo +1 -0
  59. package/dist/types/bookmark/index.d.ts +3 -0
  60. package/dist/types/bookmark/useBookmark.d.ts +2 -0
  61. package/dist/types/bookmark/useCurrentBookmark.d.ts +3 -0
  62. package/dist/types/context/index.d.ts +4 -0
  63. package/dist/types/context/useContextProvider.d.ts +2 -0
  64. package/dist/types/context/useCurrentContext.d.ts +5 -0
  65. package/dist/types/create-component.d.ts +21 -0
  66. package/dist/types/create-legacy-app.d.ts +4 -0
  67. package/dist/types/feature-flag/index.d.ts +2 -0
  68. package/dist/types/feature-flag/useFeature.d.ts +6 -0
  69. package/dist/types/framework/index.d.ts +2 -0
  70. package/dist/types/framework/useFrameworkCurrentContext.d.ts +5 -0
  71. package/dist/types/http/index.d.ts +1 -0
  72. package/dist/types/index.d.ts +10 -0
  73. package/dist/types/make-component.d.ts +24 -0
  74. package/dist/types/msal/index.d.ts +3 -0
  75. package/dist/types/msal/useAccessToken.d.ts +6 -0
  76. package/dist/types/msal/useCurrentAccount.d.ts +2 -0
  77. package/dist/types/msal/useToken.d.ts +7 -0
  78. package/dist/types/navigation/index.d.ts +2 -0
  79. package/dist/types/navigation/useNavigationModule.d.ts +2 -0
  80. package/dist/types/navigation/useRouter.d.ts +2 -0
  81. package/dist/types/render-app.d.ts +5 -0
  82. package/dist/types/render-component.d.ts +4 -0
  83. package/dist/types/useAppModule.d.ts +4 -0
  84. package/dist/types/useAppModules.d.ts +3 -0
  85. package/dist/types/version.d.ts +1 -0
  86. package/package.json +112 -0
  87. package/src/bookmark/index.ts +4 -0
  88. package/src/bookmark/useBookmark.ts +21 -0
  89. package/src/bookmark/useCurrentBookmark.ts +21 -0
  90. package/src/context/index.ts +6 -0
  91. package/src/context/useContextProvider.ts +6 -0
  92. package/src/context/useCurrentContext.ts +6 -0
  93. package/src/create-component.tsx +114 -0
  94. package/src/create-legacy-app.tsx +35 -0
  95. package/src/feature-flag/README.md +20 -0
  96. package/src/feature-flag/index.ts +6 -0
  97. package/src/feature-flag/useFeature.ts +66 -0
  98. package/src/framework/index.ts +7 -0
  99. package/src/framework/useFrameworkCurrentContext.ts +6 -0
  100. package/src/http/index.ts +1 -0
  101. package/src/index.ts +30 -0
  102. package/src/make-component.tsx +74 -0
  103. package/src/msal/index.ts +3 -0
  104. package/src/msal/useAccessToken.ts +15 -0
  105. package/src/msal/useCurrentAccount.ts +11 -0
  106. package/src/msal/useToken.ts +29 -0
  107. package/src/navigation/index.ts +2 -0
  108. package/src/navigation/useNavigationModule.ts +5 -0
  109. package/src/navigation/useRouter.ts +16 -0
  110. package/src/render-app.ts +14 -0
  111. package/src/render-component.tsx +46 -0
  112. package/src/useAppModule.ts +31 -0
  113. package/src/useAppModules.ts +9 -0
  114. package/src/version.ts +2 -0
  115. 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,3 @@
1
+ export { useCurrentAccount } from './useCurrentAccount';
2
+ export { useAccessToken } from './useAccessToken';
3
+ export { useToken } from './useToken';
@@ -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,2 @@
1
+ export { useNavigationModule } from './useNavigationModule';
2
+ export { useRouter } from './useRouter';
@@ -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
@@ -0,0 +1,2 @@
1
+ // Generated by genversion.
2
+ export const version = '4.3.0';
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
+ }