@hmcts/rpx-xui-common-lib 2.0.19-upgrade-ld-client → 2.0.20
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/esm2022/lib/models/feature-user.mjs +1 -1
- package/esm2022/lib/services/feature-toggle/launch-darkly.service.mjs +15 -15
- package/esm2022/lib/services/find-person/find-person.service.mjs +6 -37
- package/fesm2022/hmcts-rpx-xui-common-lib.mjs +18 -69
- package/fesm2022/hmcts-rpx-xui-common-lib.mjs.map +1 -1
- package/lib/models/feature-user.d.ts +5 -3
- package/lib/services/feature-toggle/launch-darkly.service.d.ts +9 -9
- package/package.json +2 -2
- package/esm2022/lib/gov-ui/models/isession-storage.interface.mjs +0 -2
- package/esm2022/lib/gov-ui/util/session-storage/session-storage-utils.mjs +0 -22
- package/lib/gov-ui/models/isession-storage.interface.d.ts +0 -4
- package/lib/gov-ui/util/session-storage/session-storage-utils.d.ts +0 -6
|
@@ -2,4 +2,4 @@ export class AnonymousFeatureUser {
|
|
|
2
2
|
}
|
|
3
3
|
export class LoggedInFeatureUser {
|
|
4
4
|
}
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVhdHVyZS11c2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXh1aS1jb21tb24tbGliL3NyYy9saWIvbW9kZWxzL2ZlYXR1cmUtdXNlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sb0JBQW9CO0NBRWhDO0FBRUQsTUFBTSxPQUFPLG1CQUFtQjtDQU8vQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBBbm9ueW1vdXNGZWF0dXJlVXNlciB7XG4gICAgcHVibGljIGFub255bW91czogdHJ1ZTtcbn1cblxuZXhwb3J0IGNsYXNzIExvZ2dlZEluRmVhdHVyZVVzZXIge1xuICAgIHB1YmxpYyBrZXk6IHN0cmluZztcbiAgICBwdWJsaWMgY3VzdG9tOiB7XG4gICAgICAgIFtrZXk6IHN0cmluZ106IGFueSxcbiAgICAgICAgcm9sZXM6IHN0cmluZ1tdLFxuICAgICAgICBvcmdJZDogc3RyaW5nXG4gICAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRmVhdHVyZVVzZXIgPSBBbm9ueW1vdXNGZWF0dXJlVXNlciB8IExvZ2dlZEluRmVhdHVyZVVzZXI7XG4iXX0=
|
|
@@ -7,16 +7,16 @@ export class LaunchDarklyService {
|
|
|
7
7
|
constructor() {
|
|
8
8
|
this.ready = new BehaviorSubject(false);
|
|
9
9
|
this.features = {};
|
|
10
|
-
this.
|
|
10
|
+
this.user = { anonymous: true };
|
|
11
11
|
this.clientId = '';
|
|
12
12
|
}
|
|
13
13
|
initialize(user = { anonymous: true }, clientId) {
|
|
14
14
|
this.ready.next(false);
|
|
15
|
-
this.
|
|
15
|
+
this.user = user;
|
|
16
16
|
this.clientId = clientId;
|
|
17
|
-
this.client = initialize(this.clientId, this.
|
|
17
|
+
this.client = initialize(this.clientId, this.user, {});
|
|
18
18
|
this.client.on('ready', () => {
|
|
19
|
-
this.client.identify(this.
|
|
19
|
+
this.client.identify(this.user).then(() => this.ready.next(true));
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
22
|
isEnabled(feature, defaultValue = false) {
|
|
@@ -29,7 +29,7 @@ export class LaunchDarklyService {
|
|
|
29
29
|
getValue(feature, defaultValue) {
|
|
30
30
|
if (!this.features.hasOwnProperty(feature)) {
|
|
31
31
|
this.features[feature] = new BehaviorSubject(defaultValue);
|
|
32
|
-
this.ready.pipe(filter(
|
|
32
|
+
this.ready.pipe(filter(ready => ready), map(() => this.client.variation(feature, defaultValue))).subscribe(value => {
|
|
33
33
|
this.features[feature].next(value);
|
|
34
34
|
this.client.on(`change:${feature}`, (val) => {
|
|
35
35
|
this.features[feature].next(val);
|
|
@@ -39,16 +39,16 @@ export class LaunchDarklyService {
|
|
|
39
39
|
return this.features[feature].pipe(distinctUntilChanged());
|
|
40
40
|
}
|
|
41
41
|
/**
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
42
|
+
* This method returns an observable that will only get the state of the feature toggle
|
|
43
|
+
* once. It calls the LD SDK directly, and should only be used in circumstances where
|
|
44
|
+
* only one value should be emitted, that value coming directly from LD. This will likely
|
|
45
|
+
* only apply for Guards, and should be used only when absolutely necessary.
|
|
46
|
+
* @see getValue for regular usage.
|
|
47
|
+
* @param feature string
|
|
48
|
+
* @param defaultValue R
|
|
49
|
+
*/
|
|
50
50
|
getValueOnce(feature, defaultValue) {
|
|
51
|
-
return this.ready.pipe(filter(
|
|
51
|
+
return this.ready.pipe(filter(ready => ready), map(() => this.client.variation(feature, defaultValue)));
|
|
52
52
|
}
|
|
53
53
|
getValueSync(feature, defaultValue) {
|
|
54
54
|
return this.client.variation(feature, defaultValue);
|
|
@@ -62,4 +62,4 @@ export class LaunchDarklyService {
|
|
|
62
62
|
providedIn: 'root'
|
|
63
63
|
}]
|
|
64
64
|
}], null, null); })();
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF1bmNoLWRhcmtseS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXh1aS1jb21tb24tbGliL3NyYy9saWIvc2VydmljZXMvZmVhdHVyZS10b2dnbGUvbGF1bmNoLWRhcmtseS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLFVBQVUsRUFBVyxNQUFNLDRCQUE0QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFPbkUsTUFBTSxPQUFPLG1CQUFtQjtJQUhoQztRQU1xQixVQUFLLEdBQTZCLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ3RFLGFBQVEsR0FBeUMsRUFBRSxDQUFDO1FBQzdELFNBQUksR0FBZ0IsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDeEMsYUFBUSxHQUFXLEVBQUUsQ0FBQztLQTBEakM7SUF4RFUsVUFBVSxDQUFDLE9BQW9CLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxFQUFFLFFBQWdCO1FBQ3ZFLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztRQUN2RCxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUN0RSxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTSxTQUFTLENBQUMsT0FBZSxFQUFFLGVBQXdCLEtBQUs7UUFDM0QsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFVLE9BQU8sRUFBRSxZQUFZLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRU0sUUFBUSxDQUFVLE9BQWU7UUFDcEMsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFNLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQscUdBQXFHO0lBQzlGLFFBQVEsQ0FBSSxPQUFlLEVBQUUsWUFBZTtRQUMvQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUN6QyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksZUFBZSxDQUFJLFlBQVksQ0FBQyxDQUFDO1lBQzlELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNYLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUN0QixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQzFELENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO2dCQUNoQixJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDbkMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsVUFBVSxPQUFPLEVBQUUsRUFBRSxDQUFDLEdBQU0sRUFBRSxFQUFFO29CQUMzQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDckMsQ0FBQyxDQUFDLENBQUM7WUFDUCxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUM5QixvQkFBb0IsRUFBRSxDQUN6QixDQUFDO0lBQ04sQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0ksWUFBWSxDQUFJLE9BQWUsRUFBRSxZQUFlO1FBQ25ELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQ2xCLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUN0QixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQzFELENBQUM7SUFDTixDQUFDO0lBRU0sWUFBWSxDQUFJLE9BQWUsRUFBRSxZQUFlO1FBQ3JELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3RELENBQUM7b0ZBL0RRLG1CQUFtQjt1RUFBbkIsbUJBQW1CLFdBQW5CLG1CQUFtQixtQkFGaEIsTUFBTTs7aUZBRVQsbUJBQW1CO2NBSC9CLFVBQVU7ZUFBQztnQkFDUixVQUFVLEVBQUUsTUFBTTthQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGluaXRpYWxpemUsIExEQ2xpZW50fSBmcm9tICdsYXVuY2hkYXJrbHktanMtY2xpZW50LXNkayc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBmaWx0ZXIsIG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IEZlYXR1cmVVc2VyIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2ZlYXR1cmUtdXNlcic7XG5pbXBvcnQgeyBGZWF0dXJlVG9nZ2xlU2VydmljZSB9IGZyb20gJy4vZmVhdHVyZS10b2dnbGUuc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTGF1bmNoRGFya2x5U2VydmljZSBpbXBsZW1lbnRzIEZlYXR1cmVUb2dnbGVTZXJ2aWNlIHtcblxuICAgIHByaXZhdGUgY2xpZW50OiBMRENsaWVudDtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJlYWR5OiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGZlYXR1cmVzOiBSZWNvcmQ8c3RyaW5nLCBCZWhhdmlvclN1YmplY3Q8YW55Pj4gPSB7fTtcbiAgICBwcml2YXRlIHVzZXI6IEZlYXR1cmVVc2VyID0geyBhbm9ueW1vdXM6IHRydWUgfTtcbiAgICBwcml2YXRlIGNsaWVudElkOiBzdHJpbmcgPSAnJztcblxuICAgIHB1YmxpYyBpbml0aWFsaXplKHVzZXI6IEZlYXR1cmVVc2VyID0geyBhbm9ueW1vdXM6IHRydWUgfSwgY2xpZW50SWQ6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLnJlYWR5Lm5leHQoZmFsc2UpO1xuICAgICAgICB0aGlzLnVzZXIgPSB1c2VyO1xuICAgICAgICB0aGlzLmNsaWVudElkID0gY2xpZW50SWQ7XG4gICAgICAgIHRoaXMuY2xpZW50ID0gaW5pdGlhbGl6ZSh0aGlzLmNsaWVudElkLCB0aGlzLnVzZXIsIHt9KTtcbiAgICAgICAgdGhpcy5jbGllbnQub24oJ3JlYWR5JywgKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5jbGllbnQuaWRlbnRpZnkodGhpcy51c2VyKS50aGVuKCgpID0+IHRoaXMucmVhZHkubmV4dCh0cnVlKSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBpc0VuYWJsZWQoZmVhdHVyZTogc3RyaW5nLCBkZWZhdWx0VmFsdWU6IGJvb2xlYW4gPSBmYWxzZSk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRWYWx1ZTxib29sZWFuPihmZWF0dXJlLCBkZWZhdWx0VmFsdWUpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRBcnJheTxSID0gYW55PihmZWF0dXJlOiBzdHJpbmcpOiBPYnNlcnZhYmxlPFJbXT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRWYWx1ZTxSW10+KGZlYXR1cmUsIFtdKTtcbiAgICB9XG5cbiAgICAvLyBOb3RlIHRoYXQgdGhpcyBmdW5jdGlvbiBhbHdheXMgZW1pdHMgaXRzIGRlZmF1bHQgdmFsdWUgZmlyc3QsIHdoaWNoIGNhbiBsZWFkIHRvIHVuZXhwZWN0ZWQgcmVzdWx0c1xuICAgIHB1YmxpYyBnZXRWYWx1ZTxSPihmZWF0dXJlOiBzdHJpbmcsIGRlZmF1bHRWYWx1ZTogUik6IE9ic2VydmFibGU8Uj4ge1xuICAgICAgICBpZiAoIXRoaXMuZmVhdHVyZXMuaGFzT3duUHJvcGVydHkoZmVhdHVyZSkpIHtcbiAgICAgICAgICAgIHRoaXMuZmVhdHVyZXNbZmVhdHVyZV0gPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFI+KGRlZmF1bHRWYWx1ZSk7XG4gICAgICAgICAgICB0aGlzLnJlYWR5LnBpcGUoXG4gICAgICAgICAgICAgICAgZmlsdGVyKHJlYWR5ID0+IHJlYWR5KSxcbiAgICAgICAgICAgICAgICBtYXAoKCkgPT4gdGhpcy5jbGllbnQudmFyaWF0aW9uKGZlYXR1cmUsIGRlZmF1bHRWYWx1ZSkpXG4gICAgICAgICAgICApLnN1YnNjcmliZSh2YWx1ZSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5mZWF0dXJlc1tmZWF0dXJlXS5uZXh0KHZhbHVlKTtcbiAgICAgICAgICAgICAgICB0aGlzLmNsaWVudC5vbihgY2hhbmdlOiR7ZmVhdHVyZX1gLCAodmFsOiBSKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuZmVhdHVyZXNbZmVhdHVyZV0ubmV4dCh2YWwpO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMuZmVhdHVyZXNbZmVhdHVyZV0ucGlwZShcbiAgICAgICAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKClcbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBUaGlzIG1ldGhvZCByZXR1cm5zIGFuIG9ic2VydmFibGUgdGhhdCB3aWxsIG9ubHkgZ2V0IHRoZSBzdGF0ZSBvZiB0aGUgZmVhdHVyZSB0b2dnbGVcbiAgICAgKiBvbmNlLiBJdCBjYWxscyB0aGUgTEQgU0RLIGRpcmVjdGx5LCBhbmQgc2hvdWxkIG9ubHkgYmUgdXNlZCBpbiBjaXJjdW1zdGFuY2VzIHdoZXJlXG4gICAgICogb25seSBvbmUgdmFsdWUgc2hvdWxkIGJlIGVtaXR0ZWQsIHRoYXQgdmFsdWUgY29taW5nIGRpcmVjdGx5IGZyb20gTEQuIFRoaXMgd2lsbCBsaWtlbHlcbiAgICAgKiBvbmx5IGFwcGx5IGZvciBHdWFyZHMsIGFuZCBzaG91bGQgYmUgdXNlZCBvbmx5IHdoZW4gYWJzb2x1dGVseSBuZWNlc3NhcnkuXG4gICAgICogQHNlZSBnZXRWYWx1ZSBmb3IgcmVndWxhciB1c2FnZS5cbiAgICAgKiBAcGFyYW0gZmVhdHVyZSBzdHJpbmdcbiAgICAgKiBAcGFyYW0gZGVmYXVsdFZhbHVlIFJcbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0VmFsdWVPbmNlPFI+KGZlYXR1cmU6IHN0cmluZywgZGVmYXVsdFZhbHVlOiBSKTogT2JzZXJ2YWJsZTxSPiB7XG4gICAgICAgIHJldHVybiB0aGlzLnJlYWR5LnBpcGUoXG4gICAgICAgICAgICBmaWx0ZXIocmVhZHkgPT4gcmVhZHkpLFxuICAgICAgICAgICAgbWFwKCgpID0+IHRoaXMuY2xpZW50LnZhcmlhdGlvbihmZWF0dXJlLCBkZWZhdWx0VmFsdWUpKVxuICAgICAgICApO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRWYWx1ZVN5bmM8Uj4oZmVhdHVyZTogc3RyaW5nLCBkZWZhdWx0VmFsdWU6IFIpOiBSIHtcbiAgICAgIHJldHVybiB0aGlzLmNsaWVudC52YXJpYXRpb24oZmVhdHVyZSwgZGVmYXVsdFZhbHVlKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import { HttpClient } from '@angular/common/http';
|
|
2
2
|
import { Injectable } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import { map, tap } from 'rxjs/operators';
|
|
5
|
-
import { getAllCaseworkersFromServices, getSessionStorageKeyForServiceId, setCaseworkers } from '../../gov-ui/util/session-storage/session-storage-utils';
|
|
3
|
+
import { map } from 'rxjs/operators';
|
|
6
4
|
import { PersonRole, RoleCategory } from '../../models';
|
|
7
5
|
import { SessionStorageService } from '../storage/session-storage/session-storage.service';
|
|
8
6
|
import * as i0 from "@angular/core";
|
|
@@ -33,35 +31,8 @@ export class FindAPersonService {
|
|
|
33
31
|
}
|
|
34
32
|
this.assignedUser = searchOptions.assignedUser ? searchOptions.assignedUser : null;
|
|
35
33
|
const fullServices = searchOptions.services;
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
const storedCaseworkersByService = [];
|
|
39
|
-
fullServices.forEach(serviceId => {
|
|
40
|
-
const serviceKey = getSessionStorageKeyForServiceId(serviceId);
|
|
41
|
-
if (this.sessionStorageService.getItem(serviceKey)) {
|
|
42
|
-
storedServices.push(serviceId);
|
|
43
|
-
storedCaseworkersByService.push({ service: serviceId, caseworkers: JSON.parse(this.sessionStorageService.getItem(serviceKey)) });
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
newServices.push(serviceId);
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
// if all services are stored then return the stored caseworkers by service
|
|
50
|
-
if (storedServices.length === fullServices.length) {
|
|
51
|
-
const storedCaseworkers = getAllCaseworkersFromServices(storedCaseworkersByService);
|
|
52
|
-
return of(this.searchInCaseworkers(storedCaseworkers, searchOptions));
|
|
53
|
-
}
|
|
54
|
-
// all serviceIds passed in as node layer getting used anyway and caseworkers also stored there
|
|
55
|
-
return this.http.post('/workallocation/retrieveCaseWorkersForServices', { fullServices }).pipe(tap(caseworkersByService => {
|
|
56
|
-
caseworkersByService.forEach(caseworkerListByService => {
|
|
57
|
-
// for any new service, ensure that they are then stored in the session
|
|
58
|
-
if (newServices.includes(caseworkerListByService.service)) {
|
|
59
|
-
setCaseworkers(caseworkerListByService.service, caseworkerListByService.caseworkers, this.sessionStorageService);
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
}), map(caseworkersByService => {
|
|
63
|
-
const givenCaseworkers = getAllCaseworkersFromServices(caseworkersByService);
|
|
64
|
-
return this.searchInCaseworkers(givenCaseworkers, searchOptions);
|
|
34
|
+
return this.http.post('/workallocation/caseworker/getUsersByServiceName', { services: fullServices, term: searchOptions.searchTerm }).pipe(map(caseworkers => {
|
|
35
|
+
return this.searchInCaseworkers(caseworkers, searchOptions);
|
|
65
36
|
}));
|
|
66
37
|
}
|
|
67
38
|
mapCaseworkers(caseworkers, roleCategory) {
|
|
@@ -93,11 +64,9 @@ export class FindAPersonService {
|
|
|
93
64
|
roleCategory = RoleCategory.CTSC;
|
|
94
65
|
}
|
|
95
66
|
}
|
|
96
|
-
const searchTerm = searchOptions && searchOptions.searchTerm ? searchOptions.searchTerm.toLowerCase() : '';
|
|
97
67
|
const people = caseworkers ? this.mapCaseworkers(caseworkers, roleCategory) : [];
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
: finalPeopleList.filter(person => person?.id !== this.assignedUser);
|
|
68
|
+
return searchOptions.userIncluded ? people.filter(person => person && person.id !== this.assignedUser)
|
|
69
|
+
: people.filter(person => person && person.id !== this.userId && person.id !== this.assignedUser);
|
|
101
70
|
}
|
|
102
71
|
searchJudicial(value, serviceId) {
|
|
103
72
|
return this.http.post('api/prd/judicial/getJudicialUsersSearch', { searchString: value, serviceCode: serviceId });
|
|
@@ -111,4 +80,4 @@ export class FindAPersonService {
|
|
|
111
80
|
providedIn: 'root'
|
|
112
81
|
}]
|
|
113
82
|
}], () => [{ type: i1.HttpClient }, { type: i2.SessionStorageService }], null); })();
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-person.service.js","sourceRoot":"","sources":["../../../../../../projects/exui-common-lib/src/lib/services/find-person/find-person.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { map, tap } from 'rxjs/operators';\nimport {\n  getAllCaseworkersFromServices,\n  getSessionStorageKeyForServiceId,\n  setCaseworkers\n} from '../../gov-ui/util/session-storage/session-storage-utils';\nimport {\n  Caseworker,\n  CaseworkersByService,\n  JudicialUserModel,\n  Person,\n  PersonRole,\n  RoleCategory,\n  SearchOptions\n} from '../../models';\nimport { SessionStorageService } from '../storage/session-storage/session-storage.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class FindAPersonService {\n\n  public static caseworkersKey: string = 'caseworkers';\n  public userId: string;\n  public assignedUser: string;\n\n  constructor(private readonly http: HttpClient, private readonly sessionStorageService: SessionStorageService) {\n  }\n\n  public find(searchOptions: SearchOptions): Observable<Person[]> {\n    const userInfoStr = this.sessionStorageService.getItem('userDetails');\n    if (userInfoStr && !searchOptions.userIncluded) {\n      const userInfo = JSON.parse(userInfoStr);\n      this.userId = userInfo.id ? userInfo.id : userInfo.uid;\n    }\n    this.assignedUser = searchOptions.assignedUser ? searchOptions.assignedUser : null;\n    return this.http.post<Person[]>('/workallocation/findPerson', { searchOptions })\n      .pipe(map(judiciary => judiciary.filter(judge => !([this.assignedUser].includes(judge.id)))));\n    // Removed the current user id to fix EUI-8465.\n  }\n\n  public findCaseworkers(searchOptions: SearchOptions): Observable<Person[]> {\n    const userInfoStr = this.sessionStorageService.getItem('userDetails');\n    if (userInfoStr) {\n      const userInfo = JSON.parse(userInfoStr);\n      this.userId = userInfo.id ? userInfo.id : userInfo.uid;\n    }\n    this.assignedUser = searchOptions.assignedUser ? searchOptions.assignedUser : null;\n    const fullServices = searchOptions.services;\n    const storedServices = [];\n    const newServices: string[] = [];\n    const storedCaseworkersByService: CaseworkersByService[] = [];\n    fullServices.forEach(serviceId => {\n      const serviceKey = getSessionStorageKeyForServiceId(serviceId);\n      if (this.sessionStorageService.getItem(serviceKey)) {\n        storedServices.push(serviceId);\n        storedCaseworkersByService.push({ service: serviceId, caseworkers: JSON.parse(this.sessionStorageService.getItem(serviceKey)) });\n      } else {\n        newServices.push(serviceId);\n      }\n    });\n    // if all services are stored then return the stored caseworkers by service\n    if (storedServices.length === fullServices.length) {\n      const storedCaseworkers = getAllCaseworkersFromServices(storedCaseworkersByService);\n      return of(this.searchInCaseworkers(storedCaseworkers, searchOptions));\n    }\n    // all serviceIds passed in as node layer getting used anyway and caseworkers also stored there\n    return this.http.post<CaseworkersByService[]>('/workallocation/retrieveCaseWorkersForServices', { fullServices }).pipe(\n      tap(caseworkersByService => {\n        caseworkersByService.forEach(caseworkerListByService => {\n          // for any new service, ensure that they are then stored in the session\n          if (newServices.includes(caseworkerListByService.service)) {\n            setCaseworkers(caseworkerListByService.service, caseworkerListByService.caseworkers, this.sessionStorageService);\n          }\n        });\n      }),\n      map(caseworkersByService => {\n        const givenCaseworkers = getAllCaseworkersFromServices(caseworkersByService);\n        return this.searchInCaseworkers(givenCaseworkers, searchOptions);\n      })\n    );\n  }\n\n  public mapCaseworkers(caseworkers: Caseworker[], roleCategory: string): Person[] {\n    const people: Person[] = [];\n    caseworkers.forEach((caseworker) => {\n      const thisPerson: Person = {\n        email: caseworker.email,\n        name: `${caseworker.firstName} ${caseworker.lastName}`,\n        id: caseworker.idamId,\n        domain: caseworker.roleCategory === RoleCategory.CASEWORKER ? PersonRole.CASEWORKER : PersonRole.ADMIN,\n        // knownAs can be added if required\n      };\n      if (caseworker.roleCategory === roleCategory || roleCategory === RoleCategory.ALL) {\n        people.push(thisPerson);\n      }\n    });\n    return people;\n  }\n\n  public searchInCaseworkers(caseworkers: Caseworker[], searchOptions: SearchOptions): Person[] {\n    let roleCategory = RoleCategory.ALL;\n    if (!(searchOptions.userRole === PersonRole.ALL)) {\n      if (searchOptions.userRole === PersonRole.CASEWORKER) {\n        roleCategory = RoleCategory.CASEWORKER;\n      } else if (searchOptions.userRole === PersonRole.ADMIN) {\n        roleCategory = RoleCategory.ADMIN;\n      } else if (searchOptions.userRole === PersonRole.CTSC) {\n        roleCategory = RoleCategory.CTSC;\n      }\n    }\n    const searchTerm = searchOptions && searchOptions.searchTerm ? searchOptions.searchTerm.toLowerCase() : '';\n    const people = caseworkers ? this.mapCaseworkers(caseworkers, roleCategory) : [];\n    const finalPeopleList = people.filter(person => person && person.name && person.name.toLowerCase().includes(searchTerm));\n    return searchOptions.userIncluded ? finalPeopleList.filter(person => person && person.id !== this.assignedUser)\n      : finalPeopleList.filter(person => person?.id !== this.assignedUser);\n  }\n\n  public searchJudicial(value: string, serviceId: string): Observable<JudicialUserModel[]> {\n    return this.http.post<JudicialUserModel[]>('api/prd/judicial/getJudicialUsersSearch',\n      { searchString: value, serviceCode: serviceId });\n  }\n}\n\n"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-person.service.js","sourceRoot":"","sources":["../../../../../../projects/exui-common-lib/src/lib/services/find-person/find-person.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport {\n  Caseworker,\n  JudicialUserModel,\n  Person,\n  PersonRole,\n  RoleCategory,\n  SearchOptions\n} from '../../models';\nimport { SessionStorageService } from '../storage/session-storage/session-storage.service';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class FindAPersonService {\n\n  public static caseworkersKey: string = 'caseworkers';\n  public userId: string;\n  public assignedUser: string;\n\n  constructor(private readonly http: HttpClient, private readonly sessionStorageService: SessionStorageService) {\n  }\n\n  public find(searchOptions: SearchOptions): Observable<Person[]> {\n    const userInfoStr = this.sessionStorageService.getItem('userDetails');\n    if (userInfoStr && !searchOptions.userIncluded) {\n      const userInfo = JSON.parse(userInfoStr);\n      this.userId = userInfo.id ? userInfo.id : userInfo.uid;\n    }\n    this.assignedUser = searchOptions.assignedUser ? searchOptions.assignedUser : null;\n    return this.http.post<Person[]>('/workallocation/findPerson', { searchOptions })\n      .pipe(map(judiciary => judiciary.filter(judge => !([this.assignedUser].includes(judge.id)))));\n    // Removed the current user id to fix EUI-8465.\n  }\n\n  public findCaseworkers(searchOptions: SearchOptions): Observable<Person[]> {\n    const userInfoStr = this.sessionStorageService.getItem('userDetails');\n    if (userInfoStr) {\n      const userInfo = JSON.parse(userInfoStr);\n      this.userId = userInfo.id ? userInfo.id : userInfo.uid;\n    }\n    this.assignedUser = searchOptions.assignedUser ? searchOptions.assignedUser : null;\n    const fullServices = searchOptions.services;\n    return this.http.post<Caseworker[]>('/workallocation/caseworker/getUsersByServiceName', {services: fullServices, term: searchOptions.searchTerm}).pipe(\n      map(caseworkers => {\n        return this.searchInCaseworkers(caseworkers, searchOptions);\n      })\n    );\n  }\n\n  public mapCaseworkers(caseworkers: Caseworker[], roleCategory: string): Person[] {\n    const people: Person[] = [];\n    caseworkers.forEach((caseworker) => {\n      const thisPerson: Person = {\n        email: caseworker.email,\n        name: `${caseworker.firstName} ${caseworker.lastName}`,\n        id: caseworker.idamId,\n        domain: caseworker.roleCategory === RoleCategory.CASEWORKER ? PersonRole.CASEWORKER : PersonRole.ADMIN,\n        // knownAs can be added if required\n      };\n      if (caseworker.roleCategory === roleCategory || roleCategory === RoleCategory.ALL) {\n        people.push(thisPerson);\n      }\n    });\n    return people;\n  }\n\n  public searchInCaseworkers(caseworkers: Caseworker[], searchOptions: SearchOptions): Person[] {\n    let roleCategory = RoleCategory.ALL;\n    if (!(searchOptions.userRole === PersonRole.ALL)) {\n      if (searchOptions.userRole === PersonRole.CASEWORKER) {\n        roleCategory = RoleCategory.CASEWORKER;\n      } else if (searchOptions.userRole === PersonRole.ADMIN) {\n        roleCategory = RoleCategory.ADMIN;\n      } else if (searchOptions.userRole === PersonRole.CTSC) {\n        roleCategory = RoleCategory.CTSC;\n      }\n    }\n    const people = caseworkers ? this.mapCaseworkers(caseworkers, roleCategory) : [];\n    return searchOptions.userIncluded ? people.filter(person => person && person.id !== this.assignedUser)\n      : people.filter(person => person && person.id !== this.userId && person.id !== this.assignedUser);\n  }\n\n  public searchJudicial(value: string, serviceId: string): Observable<JudicialUserModel[]> {\n    return this.http.post<JudicialUserModel[]>('api/prd/judicial/getJudicialUsersSearch',\n      { searchString: value, serviceCode: serviceId });\n  }\n}\n\n"]}
|
|
@@ -1280,16 +1280,16 @@ class LaunchDarklyService {
|
|
|
1280
1280
|
constructor() {
|
|
1281
1281
|
this.ready = new BehaviorSubject(false);
|
|
1282
1282
|
this.features = {};
|
|
1283
|
-
this.
|
|
1283
|
+
this.user = { anonymous: true };
|
|
1284
1284
|
this.clientId = '';
|
|
1285
1285
|
}
|
|
1286
1286
|
initialize(user = { anonymous: true }, clientId) {
|
|
1287
1287
|
this.ready.next(false);
|
|
1288
|
-
this.
|
|
1288
|
+
this.user = user;
|
|
1289
1289
|
this.clientId = clientId;
|
|
1290
|
-
this.client = initialize(this.clientId, this.
|
|
1290
|
+
this.client = initialize(this.clientId, this.user, {});
|
|
1291
1291
|
this.client.on('ready', () => {
|
|
1292
|
-
this.client.identify(this.
|
|
1292
|
+
this.client.identify(this.user).then(() => this.ready.next(true));
|
|
1293
1293
|
});
|
|
1294
1294
|
}
|
|
1295
1295
|
isEnabled(feature, defaultValue = false) {
|
|
@@ -1302,7 +1302,7 @@ class LaunchDarklyService {
|
|
|
1302
1302
|
getValue(feature, defaultValue) {
|
|
1303
1303
|
if (!this.features.hasOwnProperty(feature)) {
|
|
1304
1304
|
this.features[feature] = new BehaviorSubject(defaultValue);
|
|
1305
|
-
this.ready.pipe(filter(
|
|
1305
|
+
this.ready.pipe(filter(ready => ready), map(() => this.client.variation(feature, defaultValue))).subscribe(value => {
|
|
1306
1306
|
this.features[feature].next(value);
|
|
1307
1307
|
this.client.on(`change:${feature}`, (val) => {
|
|
1308
1308
|
this.features[feature].next(val);
|
|
@@ -1312,16 +1312,16 @@ class LaunchDarklyService {
|
|
|
1312
1312
|
return this.features[feature].pipe(distinctUntilChanged());
|
|
1313
1313
|
}
|
|
1314
1314
|
/**
|
|
1315
|
-
|
|
1316
|
-
|
|
1317
|
-
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1321
|
-
|
|
1322
|
-
|
|
1315
|
+
* This method returns an observable that will only get the state of the feature toggle
|
|
1316
|
+
* once. It calls the LD SDK directly, and should only be used in circumstances where
|
|
1317
|
+
* only one value should be emitted, that value coming directly from LD. This will likely
|
|
1318
|
+
* only apply for Guards, and should be used only when absolutely necessary.
|
|
1319
|
+
* @see getValue for regular usage.
|
|
1320
|
+
* @param feature string
|
|
1321
|
+
* @param defaultValue R
|
|
1322
|
+
*/
|
|
1323
1323
|
getValueOnce(feature, defaultValue) {
|
|
1324
|
-
return this.ready.pipe(filter(
|
|
1324
|
+
return this.ready.pipe(filter(ready => ready), map(() => this.client.variation(feature, defaultValue)));
|
|
1325
1325
|
}
|
|
1326
1326
|
getValueSync(feature, defaultValue) {
|
|
1327
1327
|
return this.client.variation(feature, defaultValue);
|
|
@@ -2116,28 +2116,6 @@ function getValues(options, values) {
|
|
|
2116
2116
|
}, []);
|
|
2117
2117
|
}
|
|
2118
2118
|
|
|
2119
|
-
const getAllCaseworkersFromServices = (caseworkersByService) => {
|
|
2120
|
-
let allCaseworkers = [];
|
|
2121
|
-
caseworkersByService.forEach(caseworkerListByService => {
|
|
2122
|
-
allCaseworkers = allCaseworkers.concat(caseworkerListByService.caseworkers);
|
|
2123
|
-
});
|
|
2124
|
-
return allCaseworkers;
|
|
2125
|
-
};
|
|
2126
|
-
const getSessionStorageKeyForServiceId = (serviceId) => {
|
|
2127
|
-
return `${serviceId}-caseworkers`;
|
|
2128
|
-
};
|
|
2129
|
-
const getCaseworkers = (serviceId, sessionStorageService) => {
|
|
2130
|
-
const sessionKey = getSessionStorageKeyForServiceId(serviceId);
|
|
2131
|
-
const value = sessionStorageService.getItem(sessionKey);
|
|
2132
|
-
if (value) {
|
|
2133
|
-
return JSON.parse(value);
|
|
2134
|
-
}
|
|
2135
|
-
};
|
|
2136
|
-
const setCaseworkers = (serviceId, caseworkers, sessionStorageService) => {
|
|
2137
|
-
const sessionKey = getSessionStorageKeyForServiceId(serviceId);
|
|
2138
|
-
sessionStorageService.setItem(sessionKey, JSON.stringify(caseworkers));
|
|
2139
|
-
};
|
|
2140
|
-
|
|
2141
2119
|
class SessionStorageService {
|
|
2142
2120
|
/**
|
|
2143
2121
|
* Get an item from the session storage.
|
|
@@ -2204,35 +2182,8 @@ class FindAPersonService {
|
|
|
2204
2182
|
}
|
|
2205
2183
|
this.assignedUser = searchOptions.assignedUser ? searchOptions.assignedUser : null;
|
|
2206
2184
|
const fullServices = searchOptions.services;
|
|
2207
|
-
|
|
2208
|
-
|
|
2209
|
-
const storedCaseworkersByService = [];
|
|
2210
|
-
fullServices.forEach(serviceId => {
|
|
2211
|
-
const serviceKey = getSessionStorageKeyForServiceId(serviceId);
|
|
2212
|
-
if (this.sessionStorageService.getItem(serviceKey)) {
|
|
2213
|
-
storedServices.push(serviceId);
|
|
2214
|
-
storedCaseworkersByService.push({ service: serviceId, caseworkers: JSON.parse(this.sessionStorageService.getItem(serviceKey)) });
|
|
2215
|
-
}
|
|
2216
|
-
else {
|
|
2217
|
-
newServices.push(serviceId);
|
|
2218
|
-
}
|
|
2219
|
-
});
|
|
2220
|
-
// if all services are stored then return the stored caseworkers by service
|
|
2221
|
-
if (storedServices.length === fullServices.length) {
|
|
2222
|
-
const storedCaseworkers = getAllCaseworkersFromServices(storedCaseworkersByService);
|
|
2223
|
-
return of$1(this.searchInCaseworkers(storedCaseworkers, searchOptions));
|
|
2224
|
-
}
|
|
2225
|
-
// all serviceIds passed in as node layer getting used anyway and caseworkers also stored there
|
|
2226
|
-
return this.http.post('/workallocation/retrieveCaseWorkersForServices', { fullServices }).pipe(tap(caseworkersByService => {
|
|
2227
|
-
caseworkersByService.forEach(caseworkerListByService => {
|
|
2228
|
-
// for any new service, ensure that they are then stored in the session
|
|
2229
|
-
if (newServices.includes(caseworkerListByService.service)) {
|
|
2230
|
-
setCaseworkers(caseworkerListByService.service, caseworkerListByService.caseworkers, this.sessionStorageService);
|
|
2231
|
-
}
|
|
2232
|
-
});
|
|
2233
|
-
}), map(caseworkersByService => {
|
|
2234
|
-
const givenCaseworkers = getAllCaseworkersFromServices(caseworkersByService);
|
|
2235
|
-
return this.searchInCaseworkers(givenCaseworkers, searchOptions);
|
|
2185
|
+
return this.http.post('/workallocation/caseworker/getUsersByServiceName', { services: fullServices, term: searchOptions.searchTerm }).pipe(map(caseworkers => {
|
|
2186
|
+
return this.searchInCaseworkers(caseworkers, searchOptions);
|
|
2236
2187
|
}));
|
|
2237
2188
|
}
|
|
2238
2189
|
mapCaseworkers(caseworkers, roleCategory) {
|
|
@@ -2264,11 +2215,9 @@ class FindAPersonService {
|
|
|
2264
2215
|
roleCategory = RoleCategory.CTSC;
|
|
2265
2216
|
}
|
|
2266
2217
|
}
|
|
2267
|
-
const searchTerm = searchOptions && searchOptions.searchTerm ? searchOptions.searchTerm.toLowerCase() : '';
|
|
2268
2218
|
const people = caseworkers ? this.mapCaseworkers(caseworkers, roleCategory) : [];
|
|
2269
|
-
|
|
2270
|
-
|
|
2271
|
-
: finalPeopleList.filter(person => person?.id !== this.assignedUser);
|
|
2219
|
+
return searchOptions.userIncluded ? people.filter(person => person && person.id !== this.assignedUser)
|
|
2220
|
+
: people.filter(person => person && person.id !== this.userId && person.id !== this.assignedUser);
|
|
2272
2221
|
}
|
|
2273
2222
|
searchJudicial(value, serviceId) {
|
|
2274
2223
|
return this.http.post('api/prd/judicial/getJudicialUsersSearch', { searchString: value, serviceCode: serviceId });
|