@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.
- package/CHANGELOG.md +199 -190
- package/dist/esm/feature-flag/index.js +2 -0
- package/dist/esm/feature-flag/index.js.map +1 -0
- package/dist/esm/feature-flag/useFeatureFlags.js +48 -0
- package/dist/esm/feature-flag/useFeatureFlags.js.map +1 -0
- package/dist/esm/version.js +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/types/feature-flag/index.d.ts +1 -0
- package/dist/types/feature-flag/useFeatureFlags.d.ts +21 -0
- package/dist/types/version.d.ts +1 -1
- package/package.json +31 -35
- package/src/feature-flag/index.ts +6 -0
- package/src/feature-flag/useFeatureFlags.ts +110 -0
- package/src/version.ts +1 -1
|
@@ -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
|
+
};
|
package/dist/types/version.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const version = "4.2.
|
|
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.
|
|
3
|
+
"version": "4.2.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "dist/esm/index.js",
|
|
6
6
|
"exports": {
|
|
7
|
-
".":
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
"./
|
|
12
|
-
|
|
13
|
-
|
|
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-
|
|
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,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.
|
|
2
|
+
export const version = '4.2.1';
|