@equinor/fusion-framework-react-app 4.2.0 → 4.2.1

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.
@@ -0,0 +1 @@
1
+ export { useFeatureFlag, useFrameworkFeatureFlag, useFeatureFlags, useFrameworkFeatureFlags, } from './useFeatureFlags';
@@ -0,0 +1,21 @@
1
+ import { IFeatureFlag } from '@equinor/fusion-framework-module-feature-flag';
2
+ export declare const useFeatureFlag: (key: string) => {
3
+ feature: IFeatureFlag<unknown> | undefined;
4
+ error: unknown;
5
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
6
+ };
7
+ export declare const useFeatureFlags: () => {
8
+ features: IFeatureFlag<unknown>[] | undefined;
9
+ error: unknown;
10
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
11
+ };
12
+ export declare const useFrameworkFeatureFlag: (key: string) => {
13
+ feature: IFeatureFlag<unknown> | undefined;
14
+ error: unknown;
15
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
16
+ };
17
+ export declare const useFrameworkFeatureFlags: () => {
18
+ features: IFeatureFlag<unknown>[] | undefined;
19
+ error: unknown;
20
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
21
+ };
@@ -1 +1 @@
1
- export declare const version = "4.2.0";
1
+ export declare const version = "4.2.1";
package/package.json CHANGED
@@ -1,37 +1,17 @@
1
1
  {
2
2
  "name": "@equinor/fusion-framework-react-app",
3
- "version": "4.2.0",
3
+ "version": "4.2.1",
4
4
  "description": "",
5
5
  "main": "dist/esm/index.js",
6
6
  "exports": {
7
- ".": {
8
- "import": "./dist/esm/index.js",
9
- "types": "./dist/types/index.d.ts"
10
- },
11
- "./bookmark": {
12
- "import": "./dist/esm/bookmark/index.js",
13
- "types": "./dist/types/bookmark/index.d.ts"
14
- },
15
- "./context": {
16
- "import": "./dist/esm/context/index.js",
17
- "types": "./dist/types/context/index.d.ts"
18
- },
19
- "./framework": {
20
- "import": "./dist/esm/framework/index.js",
21
- "types": "./dist/types/framework/index.d.ts"
22
- },
23
- "./http": {
24
- "import": "./dist/esm/http/index.js",
25
- "types": "./dist/types/http/index.d.ts"
26
- },
27
- "./msal": {
28
- "import": "./dist/esm/msal/index.js",
29
- "types": "./dist/types/msal/index.d.ts"
30
- },
31
- "./navigation": {
32
- "import": "./dist/esm/navigation/index.js",
33
- "types": "./dist/types/navigation/index.d.ts"
34
- }
7
+ ".": "./dist/esm/index.js",
8
+ "./bookmark": "./dist/esm/bookmark/index.js",
9
+ "./context": "./dist/esm/context/index.js",
10
+ "./feature-flag": "./dist/esm/feature-flag/index.js",
11
+ "./framework": "./dist/esm/framework/index.js",
12
+ "./http": "./dist/esm/http/index.js",
13
+ "./msal": "./dist/esm/msal/index.js",
14
+ "./navigation": "./dist/esm/navigation/index.js"
35
15
  },
36
16
  "types": "./dist/types/index.d.ts",
37
17
  "typesVersions": {
@@ -42,6 +22,9 @@
42
22
  "context": [
43
23
  "dist/types/context/index.d.ts"
44
24
  ],
25
+ "feature-flag": [
26
+ "dist/types/feature-flag/index.d.ts"
27
+ ],
45
28
  "framework": [
46
29
  "dist/types/framework/index.d.ts"
47
30
  ],
@@ -70,10 +53,10 @@
70
53
  "dependencies": {
71
54
  "@equinor/fusion-framework-app": "^7.1.15",
72
55
  "@equinor/fusion-framework-module": "^4.2.6",
73
- "@equinor/fusion-framework-module-app": "^5.2.12",
74
- "@equinor/fusion-framework-react": "^5.3.8",
75
- "@equinor/fusion-framework-react-module": "^3.0.7",
76
56
  "@equinor/fusion-framework-module-navigation": "^3.1.3",
57
+ "@equinor/fusion-framework-react": "^5.3.9",
58
+ "@equinor/fusion-framework-react-module": "^3.0.7",
59
+ "@equinor/fusion-framework-module-app": "^5.2.12",
77
60
  "@equinor/fusion-framework-react-module-http": "^4.0.5"
78
61
  },
79
62
  "devDependencies": {
@@ -81,16 +64,20 @@
81
64
  "@types/react-dom": "^18.2.7",
82
65
  "react": "^18.2.0",
83
66
  "react-dom": "^18.2.0",
67
+ "rxjs": "^7.8.1",
84
68
  "typescript": "^5.1.3",
85
- "@equinor/fusion-framework-module-msal": "^3.0.9",
86
- "@equinor/fusion-framework-react-module-bookmark": "^2.0.27",
87
69
  "@equinor/fusion-framework-module-event": "^4.0.7",
88
- "@equinor/fusion-framework-react-module-context": "^6.0.18"
70
+ "@equinor/fusion-framework-module-msal": "^3.0.9",
71
+ "@equinor/fusion-framework-module-feature-flag": "^0.0.1",
72
+ "@equinor/fusion-framework-react-module-context": "^6.0.18",
73
+ "@equinor/fusion-framework-react-module-bookmark": "^2.0.28",
74
+ "@equinor/fusion-observable": "^8.1.4"
89
75
  },
90
76
  "peerDependencies": {
91
77
  "@types/react": "^17.0.0 || ^18.0.0",
92
78
  "react": "^17.0.0 || ^18.0.0",
93
79
  "react-dom": "^17.0.0 || ^18.0.0",
80
+ "rxjs": "^7.8.1",
94
81
  "@equinor/fusion-framework-module-msal": "^3.0.9"
95
82
  },
96
83
  "peerDependenciesMeta": {
@@ -103,11 +90,20 @@
103
90
  "@equinor/fusion-framework-react-module-bookmark": {
104
91
  "optional": true
105
92
  },
93
+ "@equinor/fusion-framework-module-feature-flag": {
94
+ "optional": true
95
+ },
96
+ "@equinor/fusion-observable": {
97
+ "optional": true
98
+ },
106
99
  "@types/react": {
107
100
  "optional": true
108
101
  },
109
102
  "react-dom": {
110
103
  "optional": true
104
+ },
105
+ "rxjs": {
106
+ "optional": true
111
107
  }
112
108
  },
113
109
  "scripts": {
@@ -0,0 +1,6 @@
1
+ export {
2
+ useFeatureFlag,
3
+ useFrameworkFeatureFlag,
4
+ useFeatureFlags,
5
+ useFrameworkFeatureFlags,
6
+ } from './useFeatureFlags';
@@ -0,0 +1,110 @@
1
+ import { useFramework } from '@equinor/fusion-framework-react';
2
+ import { useAppModule } from '../useAppModule';
3
+ import { useCallback, useMemo } from 'react';
4
+ import { useObservableState } from '@equinor/fusion-observable/react';
5
+ import {
6
+ FeatureFlagModule,
7
+ IFeatureFlagProvider,
8
+ IFeatureFlag,
9
+ } from '@equinor/fusion-framework-module-feature-flag';
10
+ import { EMPTY } from 'rxjs';
11
+
12
+ /**
13
+ * useFeatureflag
14
+ *
15
+ * Hook for getting single featureflag from app.
16
+ *
17
+ * @param key string
18
+ */
19
+ export const useFeatureFlag = (
20
+ key: string,
21
+ ): {
22
+ feature: IFeatureFlag<unknown> | undefined;
23
+ error: unknown;
24
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
25
+ } => {
26
+ const provider = useAppModule<FeatureFlagModule>('featureFlag');
27
+ const { value: feature, error } = useObservableState(_useFeatureFlag(key, provider));
28
+ const setFeatureEnabled = _useSetFeatureflag(provider);
29
+ return { feature, error, setFeatureEnabled };
30
+ };
31
+
32
+ /**
33
+ * useFeatureflags
34
+ *
35
+ * Hook for getting all featureflags from app.
36
+ *
37
+ * @param key string
38
+ */
39
+ export const useFeatureFlags = (): {
40
+ features: IFeatureFlag<unknown>[] | undefined;
41
+ error: unknown;
42
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
43
+ } => {
44
+ const provider = useAppModule<FeatureFlagModule>('featureFlag');
45
+ const { value: features, error } = useObservableState(_useFeatureFlags(provider));
46
+ const setFeatureEnabled = _useSetFeatureflag(provider);
47
+ return { features, error, setFeatureEnabled };
48
+ };
49
+
50
+ /**
51
+ * useFrameworkFeatureflag
52
+ *
53
+ * Hook for getting single featureflag from portal.
54
+ *
55
+ * @param key string
56
+ */
57
+ export const useFrameworkFeatureFlag = (
58
+ key: string,
59
+ ): {
60
+ feature: IFeatureFlag<unknown> | undefined;
61
+ error: unknown;
62
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
63
+ } => {
64
+ const provider = useFramework<[FeatureFlagModule]>().modules.featureFlag;
65
+ const { value: feature, error } = useObservableState(_useFeatureFlag(key, provider));
66
+ const setFeatureEnabled = _useSetFeatureflag(provider);
67
+ return { feature, error, setFeatureEnabled };
68
+ };
69
+
70
+ /**
71
+ * useFrameworkFeatureflags
72
+ *
73
+ * Hook for getting all featureflags from portal.
74
+ *
75
+ * @param key string
76
+ */
77
+ export const useFrameworkFeatureFlags = (): {
78
+ features: IFeatureFlag<unknown>[] | undefined;
79
+ error: unknown;
80
+ setFeatureEnabled: (key: string, enabled: boolean) => void;
81
+ } => {
82
+ const provider = useFramework<[FeatureFlagModule]>().modules.featureFlag;
83
+ const { value: features, error } = useObservableState(_useFeatureFlags(provider));
84
+ const setFeatureEnabled = _useSetFeatureflag(provider);
85
+ return { features, error, setFeatureEnabled };
86
+ };
87
+
88
+ const _useFeatureFlag = (key: string, provider?: IFeatureFlagProvider) => {
89
+ return useMemo(() => {
90
+ return provider ? provider.getFeature(key) : EMPTY;
91
+ }, [provider, key]);
92
+ };
93
+
94
+ const _useFeatureFlags = (provider?: IFeatureFlagProvider) => {
95
+ return useMemo(() => {
96
+ return provider ? provider.getFeatures((_) => true) : EMPTY;
97
+ }, [provider]);
98
+ };
99
+
100
+ const _useSetFeatureflag = (provider?: IFeatureFlagProvider) => {
101
+ return useCallback(
102
+ (key: string, enabled: boolean) => {
103
+ if (!provider) {
104
+ throw new Error('Missing IFeatureFlagProvider.');
105
+ }
106
+ provider.toggleFeature({ key, enabled });
107
+ },
108
+ [provider],
109
+ );
110
+ };
package/src/version.ts CHANGED
@@ -1,2 +1,2 @@
1
1
  // Generated by genversion.
2
- export const version = '4.2.0';
2
+ export const version = '4.2.1';