@c8y/ngx-components 1021.29.1 → 1021.30.3
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/device-profile/device-profile.component.d.ts.map +1 -1
- package/device-profile/device-profile.model.d.ts +3 -0
- package/device-profile/device-profile.model.d.ts.map +1 -1
- package/device-profile/device-profile.service.d.ts +1 -1
- package/device-profile/device-profile.service.d.ts.map +1 -1
- package/device-profile/device-tab-profile/device-tab-profile.component.d.ts +2 -1
- package/device-profile/device-tab-profile/device-tab-profile.component.d.ts.map +1 -1
- package/esm2022/core/i18n/translation-loader.service.mjs +2 -2
- package/esm2022/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.mjs +3 -3
- package/esm2022/device-profile/device-profile.component.mjs +4 -3
- package/esm2022/device-profile/device-profile.model.mjs +1 -1
- package/esm2022/device-profile/device-profile.service.mjs +17 -16
- package/esm2022/device-profile/device-tab-profile/device-profile-item-list.component.mjs +3 -3
- package/esm2022/device-profile/device-tab-profile/device-tab-profile.component.mjs +20 -4
- package/esm2022/repository/shared/repository.model.mjs +1 -1
- package/esm2022/widgets/implementations/alarms/alarm-widget.service.mjs +2 -2
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs +2 -2
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-device-profile.mjs +38 -20
- package/fesm2022/c8y-ngx-components-device-profile.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-repository-shared.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +1 -1
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/package.json +1 -1
- package/repository/shared/repository.model.d.ts +1 -0
- package/repository/shared/repository.model.d.ts.map +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"device-profile.component.d.ts","sourceRoot":"","sources":["../../device-profile/device-profile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAe,MAAM,aAAa,CAAC;AAC5E,OAAO,EACL,YAAY,
|
|
1
|
+
{"version":3,"file":"device-profile.component.d.ts","sourceRoot":"","sources":["../../device-profile/device-profile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAe,MAAM,aAAa,CAAC;AAC5E,OAAO,EACL,YAAY,EAIZ,sBAAsB,EACtB,4BAA4B,EAC7B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,cAAc,EAEd,iBAAiB,EACjB,cAAc,EACf,MAAM,uCAAuC,CAAC;AAE/C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAEnD,OAAO,EACL,aAAa,EAKd,MAAM,wBAAwB,CAAC;;AAGhC,qBAUa,sBAAuB,YAAW,MAAM,EAAE,4BAA4B;IAmB/E,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,iBAAiB;IAtB3B,mBAAmB,iJAEjB;IACF,4BAA4B,2KAE1B;IACF,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;MAAqC;IACvD,aAAa,EAAE,aAAa,CAAC;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,sBAAsB,EAAE,sBAAsB,CAK5C;IACF,OAAO,CAAC,WAAW,CAAc;gBAGvB,KAAK,EAAE,cAAc,EACrB,YAAY,EAAE,YAAY,EAC1B,gBAAgB,EAAE,gBAAgB,EAClC,OAAO,EAAE,cAAc,EACvB,iBAAiB,EAAE,iBAAiB;IAKxC,QAAQ;IAcd,WAAW;IAkDX,iCAAiC,CAC/B,WAAW,EAAE,eAAe,CAAC,cAAc,CAAC,EAC5C,QAAQ,EAAE,cAAc;IAkB1B,8BAA8B,CAAC,GAAG,EAAE,cAAc,EAAE;IAOpD,gBAAgB;IAuChB,WAAW;IAuDX,IAAI,oBAAoB,YASvB;IAED,UAAU,CAAC,WAAW,KAAA,EAAE,QAAQ,KAAA;IAWhC,cAAc;IAKR,mBAAmB,CAAC,oBAAoB,KAAA;YAehC,gBAAgB;IAS9B,OAAO,CAAC,kBAAkB;yCAxQf,sBAAsB;2CAAtB,sBAAsB;CA6RlC"}
|
|
@@ -20,6 +20,7 @@ export interface DeviceProfileFirmware {
|
|
|
20
20
|
}
|
|
21
21
|
export interface DeviceProfileSoftware {
|
|
22
22
|
name: string;
|
|
23
|
+
softwareType: string;
|
|
23
24
|
version: string;
|
|
24
25
|
url: string;
|
|
25
26
|
action: string;
|
|
@@ -33,11 +34,13 @@ export interface ComparisonResult {
|
|
|
33
34
|
profile: {
|
|
34
35
|
itemName: string;
|
|
35
36
|
itemDetails?: string;
|
|
37
|
+
itemType?: string;
|
|
36
38
|
itemUrl: string;
|
|
37
39
|
};
|
|
38
40
|
device: {
|
|
39
41
|
itemName: string;
|
|
40
42
|
itemDetails?: string;
|
|
43
|
+
itemType?: string;
|
|
41
44
|
itemUrl: string;
|
|
42
45
|
};
|
|
43
46
|
comparisonAlert?: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"device-profile.model.d.ts","sourceRoot":"","sources":["../../device-profile/device-profile.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,MAAM,WAAW,aAAc,SAAQ,OAAO,CAAC,cAAc,CAAC;IAC5D,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE;QACV,IAAI,CAAC,EAAE,MAAM,CAAC;KACf,CAAC;IACF,iBAAiB,EAAE;QACjB,QAAQ,CAAC,EAAE,qBAAqB,CAAC;QACjC,QAAQ,CAAC,EAAE,qBAAqB,EAAE,CAAC;QACnC,aAAa,CAAC,EAAE,0BAA0B,EAAE,CAAC;KAC9C,CAAC;CACH;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,OAAO,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,0BAA0B;IACzC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE;QACP,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,MAAM,EAAE;QACN,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,oBAAY,sBAAsB;IAChC,aAAa,sBAAsB;CACpC;AAED,eAAO,MAAM,iCAAiC;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BpC,CAAC"}
|
|
1
|
+
{"version":3,"file":"device-profile.model.d.ts","sourceRoot":"","sources":["../../device-profile/device-profile.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,MAAM,WAAW,aAAc,SAAQ,OAAO,CAAC,cAAc,CAAC;IAC5D,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE;QACV,IAAI,CAAC,EAAE,MAAM,CAAC;KACf,CAAC;IACF,iBAAiB,EAAE;QACjB,QAAQ,CAAC,EAAE,qBAAqB,CAAC;QACjC,QAAQ,CAAC,EAAE,qBAAqB,EAAE,CAAC;QACnC,aAAa,CAAC,EAAE,0BAA0B,EAAE,CAAC;KAC9C,CAAC;CACH;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,OAAO,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,0BAA0B;IACzC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE;QACP,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,MAAM,EAAE;QACN,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,oBAAY,sBAAsB;IAChC,aAAa,sBAAsB;CACpC;AAED,eAAO,MAAM,iCAAiC;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BpC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { IManagedObject, InventoryService, IOperation, IResultList, OperationService } from '@c8y/client';
|
|
2
|
-
import { DeviceProfile, ComparisonResult } from './device-profile.model';
|
|
3
2
|
import { AlertService } from '@c8y/ngx-components';
|
|
3
|
+
import { ComparisonResult, DeviceProfile } from './device-profile.model';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class DeviceProfileService {
|
|
6
6
|
private inventoryService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"device-profile.service.d.ts","sourceRoot":"","sources":["../../device-profile/device-profile.service.ts"],"names":[],"mappings":"AACA,OAAO,EACL,cAAc,EACd,gBAAgB,EAChB,UAAU,EACV,WAAW,EACX,gBAAgB,EAGjB,MAAM,aAAa,CAAC;AACrB,OAAO,
|
|
1
|
+
{"version":3,"file":"device-profile.service.d.ts","sourceRoot":"","sources":["../../device-profile/device-profile.service.ts"],"names":[],"mappings":"AACA,OAAO,EACL,cAAc,EACd,gBAAgB,EAChB,UAAU,EACV,WAAW,EACX,gBAAgB,EAGjB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,YAAY,EAAW,MAAM,qBAAqB,CAAC;AAE5D,OAAO,EACL,gBAAgB,EAChB,aAAa,EAGd,MAAM,wBAAwB,CAAC;;AAEhC,qBACa,oBAAoB;IAY7B,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,YAAY;IAbtB,QAAQ,CAAC,QAAQ,OAAe;IAChC,QAAQ,CAAC,MAAM,OAAmC;IAClD,OAAO,CAAC,WAAW,CAAc;IAEjC,OAAO,CAAC,qBAAqB,CAA0C;IACvE,OAAO,CAAC,yBAAyB,CAA+B;IAChE,OAAO,CAAC,gBAAgB,CAEtB;gBAGQ,gBAAgB,EAAE,gBAAgB,EAClC,gBAAgB,EAAE,gBAAgB,EAClC,YAAY,EAAE,YAAY;IAKpC,mBAAmB,CAAC,aAAa,EAAE,OAAO,CAAC,aAAa,CAAC;IAOzD,6BAA6B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IAWvF,iBAAiB,CAAC,QAAQ,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IAYjE,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM;IAc7C,sBAAsB,CAAC,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,OAAO,CAAC,aAAa,CAAC;IAkB1F,gBAAgB,CACd,MAAM,EAAE,cAAc,EACtB,eAAe,EAAE,OAAO,CAAC,aAAa,CAAC,GACtC,gBAAgB,EAAE;IAsBrB,gBAAgB,CACd,MAAM,EAAE,cAAc,EACtB,eAAe,EAAE,OAAO,CAAC,aAAa,CAAC,GACtC,gBAAgB,EAAE;IAarB,qBAAqB,CACnB,MAAM,EAAE,cAAc,EACtB,eAAe,EAAE,OAAO,CAAC,aAAa,CAAC,GACtC,gBAAgB,EAAE;IAkBrB,OAAO,CAAC,QAAQ;IA6BhB,OAAO,CAAC,uBAAuB;IAyB/B,OAAO,CAAC,sCAAsC;IA0B9C,OAAO,CAAC,uCAAuC;yCA/NpC,oBAAoB;6CAApB,oBAAoB;CA2PhC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { ActivatedRoute } from '@angular/router';
|
|
3
3
|
import { IManagedObject, IOperation, IResultList } from '@c8y/client';
|
|
4
|
-
import { AlertService, ManagedObjectRealtimeService, OperationRealtimeService, ProductExperienceEvent, ProductExperienceEventSource
|
|
4
|
+
import { AlertService, ForOfFilterPipe, ManagedObjectRealtimeService, OperationRealtimeService, ProductExperienceEvent, ProductExperienceEventSource } from '@c8y/ngx-components';
|
|
5
5
|
import { ComparisonResult, DeviceProfile } from '../device-profile.model';
|
|
6
6
|
import { DeviceProfileService } from '../device-profile.service';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
@@ -63,6 +63,7 @@ export declare class DeviceTabProfileComponent implements OnInit, OnDestroy, Pro
|
|
|
63
63
|
updateProfileItems(device: any, profile: any): void;
|
|
64
64
|
private subscribeToManagedObjects;
|
|
65
65
|
private subscribeToOperations;
|
|
66
|
+
private toProfileForDevice;
|
|
66
67
|
static ɵfac: i0.ɵɵFactoryDeclaration<DeviceTabProfileComponent, never>;
|
|
67
68
|
static ɵcmp: i0.ɵɵComponentDeclaration<DeviceTabProfileComponent, "c8y-device-tab-profile", never, {}, {}, never, never, false, never>;
|
|
68
69
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"device-tab-profile.component.d.ts","sourceRoot":"","sources":["../../../device-profile/device-tab-profile/device-tab-profile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AACtE,OAAO,EACL,YAAY,
|
|
1
|
+
{"version":3,"file":"device-tab-profile.component.d.ts","sourceRoot":"","sources":["../../../device-profile/device-tab-profile/device-tab-profile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AACtE,OAAO,EACL,YAAY,EACZ,eAAe,EAEf,4BAA4B,EAC5B,wBAAwB,EAExB,sBAAsB,EACtB,4BAA4B,EAC7B,MAAM,qBAAqB,CAAC;AAI7B,OAAO,EACL,gBAAgB,EAChB,aAAa,EAEd,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;;AAEjE,qBAWa,yBAA0B,YAAW,MAAM,EAAE,SAAS,EAAE,4BAA4B;IAwBtF,cAAc,EAAE,4BAA4B;IACnD,OAAO,CAAC,oBAAoB;IAC5B,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,YAAY;IA3BtB,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;MAAqC;IACvD,MAAM,EAAE,cAAc,CAAC;IACvB,cAAc,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;IAC5C,eAAe,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;IACxC,SAAS,EAAE,UAAU,CAAC;IACtB,aAAa,EAAE,gBAAgB,EAAE,CAAM;IACvC,aAAa,EAAE,gBAAgB,EAAE,CAAM;IACvC,kBAAkB,EAAE,gBAAgB,EAAE,CAAM;IAE5C,UAAU,EAAE,eAAe,CAAC;IAC5B,OAAO,SAAM;IACb,SAAS,UAAS;IAClB,sBAAsB,EAAE,sBAAsB,CAK5C;IACF,OAAO,CAAC,sBAAsB,CAAe;IAC7C,OAAO,CAAC,sBAAsB,CAAe;IAC7C,OAAO,CAAC,sBAAsB,CAAe;gBAGpC,cAAc,EAAE,4BAA4B,EAC3C,oBAAoB,EAAE,oBAAoB,EAC1C,KAAK,EAAE,cAAc,EACrB,iBAAiB,EAAE,wBAAwB,EAC3C,YAAY,EAAE,YAAY;IAG9B,QAAQ;IAMR,sCAAsC;IAe5C,aAAa,CAAC,EAAE,EAAE,aAAa;IAKzB,eAAe;IAOrB,OAAO,CAAC,SAAS,EAAE,MAAM;IAWzB,WAAW;IAMX,kBAAkB,CAAC,MAAM,KAAA,EAAE,OAAO,KAAA;IAMlC,OAAO,CAAC,yBAAyB;IAgBjC,OAAO,CAAC,qBAAqB;IAY7B,OAAO,CAAC,kBAAkB;yCAnHf,yBAAyB;2CAAzB,yBAAyB;CAqIrC"}
|
|
@@ -34,7 +34,7 @@ export class TranslationLoaderService {
|
|
|
34
34
|
this.translateService.onLangChange
|
|
35
35
|
.pipe(map(event => event.lang), distinctUntilChanged(), switchMap(lang => this.getTranslation(lang).pipe(map(translations => ({ lang, translations })))))
|
|
36
36
|
.subscribe(({ lang, translations }) => {
|
|
37
|
-
this.translateService.setTranslation(lang, translations,
|
|
37
|
+
this.translateService.setTranslation(lang, translations, true);
|
|
38
38
|
});
|
|
39
39
|
}
|
|
40
40
|
getTranslation(lang) {
|
|
@@ -129,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
129
129
|
type: Inject,
|
|
130
130
|
args: [LANGUAGES]
|
|
131
131
|
}] }] });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation-loader.service.js","sourceRoot":"","sources":["../../../../core/i18n/translation-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { OptionsService } from '../common';\nimport { CachedLocaleDictionaryService } from './cached-locale-dictionary.service';\nimport { PluginsResolveService } from '../plugins';\nimport { LOCALE_PATH } from './locale.path';\nimport { LANGUAGES } from './languages';\nimport { BehaviorSubject, combineLatest, defer, Observable, of } from 'rxjs';\nimport { catchError, distinctUntilChanged, map, shareReplay, switchMap, tap } from 'rxjs/operators';\nimport { TranslateService } from '@ngx-translate/core';\nimport { getDictionaryWithTrimmedKeys } from './translation-utils';\n\n/**\n * A service to load translations from different sources.\n * It combines translations from the app, user-defined translations, and plugins.\n * It also caches translations to avoid unnecessary requests.\n *\n * Is used instead of the default TranslateLoader functionality that ngx-translate provides as otherwise only the first translations from TranslateLoader observable would have been picked up.\n * This would have been problematic, as we can only load the plugin translations after the login and we need to have at least the basic translations already on the login screen.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class TranslationLoaderService {\n  private cache = new Map<string, Observable<{ [key: string]: string }>>();\n  private reloadTrigger$ = new BehaviorSubject<void>(null);\n\n  constructor(\n    private optionsService: OptionsService,\n    private cachedLocaleDictionaryService: CachedLocaleDictionaryService,\n    private pluginResolverService: PluginsResolveService,\n    private translateService: TranslateService,\n    @Inject(LOCALE_PATH) private path: string = null,\n    @Inject(LANGUAGES) private languages: { [key: string]: { url?: string } } | null = null\n  ) {\n    this.translateService.onLangChange\n      .pipe(\n        map(event => event.lang),\n        distinctUntilChanged(),\n        switchMap(lang =>\n          this.getTranslation(lang).pipe(map(translations => ({ lang, translations })))\n        )\n      )\n      .subscribe(({ lang, translations }) => {\n        this.translateService.setTranslation(lang, translations, false);\n      });\n  }\n\n  getTranslation(lang: string): Observable<{ [key: string]: string }> {\n    const translations$ = combineLatest([\n      defer(() => this.getTranslationsFromApp(lang)),\n      defer(() => this.getUserDefinedTranslations(lang)),\n      defer(() => this.optionsService.get$('langsDetails', {})),\n      defer(() => this.getTranslationsForPugins(lang))\n    ]).pipe(\n      map(([appTranslations, userDefinedTranslations, langsDetails, pluginTranslations]) => {\n        const translationsFromBranding = (langsDetails && langsDetails[lang]) || {};\n        return {\n          ...appTranslations,\n          ...pluginTranslations,\n          ...translationsFromBranding,\n          ...userDefinedTranslations\n        };\n      }),\n      tap(dictionary => {\n        this.cachedLocaleDictionaryService.cachedDictionary[lang] = dictionary;\n      }),\n      map(dictionary => getDictionaryWithTrimmedKeys(dictionary)),\n      catchError(() => of({}))\n    );\n\n    return this.reloadTrigger$.pipe(switchMap(() => translations$));\n  }\n\n  triggerReload() {\n    this.clearCache();\n    this.reloadTrigger$.next();\n  }\n\n  clearCache() {\n    this.cache.clear();\n  }\n\n  protected getTranslationsForPugins(lang: string) {\n    return this.pluginResolverService.contextPathsFromWhereRemotesHaveBeenLoaded$.pipe(\n      switchMap(plugins => {\n        // no need to load translations for self scoped plugins\n        plugins = plugins.filter(plugin => plugin !== this.optionsService.contextPath);\n        if (!plugins.length) {\n          return of({});\n        }\n        return combineLatest(\n          plugins.map(plugin => this.getTranslationsForPlugin(lang, plugin))\n        ).pipe(\n          map(translations => {\n            return translations.reduce((acc, translation) => ({ ...acc, ...translation }), {});\n          })\n        );\n      })\n    );\n  }\n\n  protected getTranslationsForPlugin(lang: string, pluginId: string) {\n    const url = `/apps/${pluginId}/${lang}.json`;\n    return this.getTranslationFromPath(url, lang);\n  }\n\n  protected getTranslationsFromApp(lang: string) {\n    const path = this.path || '';\n    let url = `${path}${lang}.json`;\n    if (this.languages && this.languages[lang] && this.languages[lang].url) {\n      url = this.languages[lang].url;\n    }\n\n    return this.getTranslationFromPath(url, lang);\n  }\n\n  protected getUserDefinedTranslations(lang: string) {\n    const url = `/apps/public/user-defined-translations/${lang}.json`;\n    return this.getTranslationFromPath(url, lang);\n  }\n\n  protected getTranslationFromPath(\n    path: string,\n    lang: string\n  ): Observable<{ [key: string]: string }> {\n    if (this.cache.has(path)) {\n      return this.cache.get(path);\n    }\n    const observable = defer(async () => {\n      try {\n        const fetchResponse = await fetch(path);\n        if (!fetchResponse.ok) {\n          throw new Error(`Unexpected response status: ${fetchResponse.status}`);\n        }\n\n        const responseBody = await fetchResponse.json();\n\n        if (responseBody[lang]) {\n          return responseBody[lang];\n        }\n      } catch (e) {\n        console.warn(`Failed to fetch translations from ${path}`);\n      }\n      return {};\n    }).pipe(shareReplay(1));\n    this.cache.set(path, observable);\n    return observable;\n  }\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation-loader.service.js","sourceRoot":"","sources":["../../../../core/i18n/translation-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { OptionsService } from '../common';\nimport { CachedLocaleDictionaryService } from './cached-locale-dictionary.service';\nimport { PluginsResolveService } from '../plugins';\nimport { LOCALE_PATH } from './locale.path';\nimport { LANGUAGES } from './languages';\nimport { BehaviorSubject, combineLatest, defer, Observable, of } from 'rxjs';\nimport { catchError, distinctUntilChanged, map, shareReplay, switchMap, tap } from 'rxjs/operators';\nimport { TranslateService } from '@ngx-translate/core';\nimport { getDictionaryWithTrimmedKeys } from './translation-utils';\n\n/**\n * A service to load translations from different sources.\n * It combines translations from the app, user-defined translations, and plugins.\n * It also caches translations to avoid unnecessary requests.\n *\n * Is used instead of the default TranslateLoader functionality that ngx-translate provides as otherwise only the first translations from TranslateLoader observable would have been picked up.\n * This would have been problematic, as we can only load the plugin translations after the login and we need to have at least the basic translations already on the login screen.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class TranslationLoaderService {\n  private cache = new Map<string, Observable<{ [key: string]: string }>>();\n  private reloadTrigger$ = new BehaviorSubject<void>(null);\n\n  constructor(\n    private optionsService: OptionsService,\n    private cachedLocaleDictionaryService: CachedLocaleDictionaryService,\n    private pluginResolverService: PluginsResolveService,\n    private translateService: TranslateService,\n    @Inject(LOCALE_PATH) private path: string = null,\n    @Inject(LANGUAGES) private languages: { [key: string]: { url?: string } } | null = null\n  ) {\n    this.translateService.onLangChange\n      .pipe(\n        map(event => event.lang),\n        distinctUntilChanged(),\n        switchMap(lang =>\n          this.getTranslation(lang).pipe(map(translations => ({ lang, translations })))\n        )\n      )\n      .subscribe(({ lang, translations }) => {\n        this.translateService.setTranslation(lang, translations, true);\n      });\n  }\n\n  getTranslation(lang: string): Observable<{ [key: string]: string }> {\n    const translations$ = combineLatest([\n      defer(() => this.getTranslationsFromApp(lang)),\n      defer(() => this.getUserDefinedTranslations(lang)),\n      defer(() => this.optionsService.get$('langsDetails', {})),\n      defer(() => this.getTranslationsForPugins(lang))\n    ]).pipe(\n      map(([appTranslations, userDefinedTranslations, langsDetails, pluginTranslations]) => {\n        const translationsFromBranding = (langsDetails && langsDetails[lang]) || {};\n        return {\n          ...appTranslations,\n          ...pluginTranslations,\n          ...translationsFromBranding,\n          ...userDefinedTranslations\n        };\n      }),\n      tap(dictionary => {\n        this.cachedLocaleDictionaryService.cachedDictionary[lang] = dictionary;\n      }),\n      map(dictionary => getDictionaryWithTrimmedKeys(dictionary)),\n      catchError(() => of({}))\n    );\n\n    return this.reloadTrigger$.pipe(switchMap(() => translations$));\n  }\n\n  triggerReload() {\n    this.clearCache();\n    this.reloadTrigger$.next();\n  }\n\n  clearCache() {\n    this.cache.clear();\n  }\n\n  protected getTranslationsForPugins(lang: string) {\n    return this.pluginResolverService.contextPathsFromWhereRemotesHaveBeenLoaded$.pipe(\n      switchMap(plugins => {\n        // no need to load translations for self scoped plugins\n        plugins = plugins.filter(plugin => plugin !== this.optionsService.contextPath);\n        if (!plugins.length) {\n          return of({});\n        }\n        return combineLatest(\n          plugins.map(plugin => this.getTranslationsForPlugin(lang, plugin))\n        ).pipe(\n          map(translations => {\n            return translations.reduce((acc, translation) => ({ ...acc, ...translation }), {});\n          })\n        );\n      })\n    );\n  }\n\n  protected getTranslationsForPlugin(lang: string, pluginId: string) {\n    const url = `/apps/${pluginId}/${lang}.json`;\n    return this.getTranslationFromPath(url, lang);\n  }\n\n  protected getTranslationsFromApp(lang: string) {\n    const path = this.path || '';\n    let url = `${path}${lang}.json`;\n    if (this.languages && this.languages[lang] && this.languages[lang].url) {\n      url = this.languages[lang].url;\n    }\n\n    return this.getTranslationFromPath(url, lang);\n  }\n\n  protected getUserDefinedTranslations(lang: string) {\n    const url = `/apps/public/user-defined-translations/${lang}.json`;\n    return this.getTranslationFromPath(url, lang);\n  }\n\n  protected getTranslationFromPath(\n    path: string,\n    lang: string\n  ): Observable<{ [key: string]: string }> {\n    if (this.cache.has(path)) {\n      return this.cache.get(path);\n    }\n    const observable = defer(async () => {\n      try {\n        const fetchResponse = await fetch(path);\n        if (!fetchResponse.ok) {\n          throw new Error(`Unexpected response status: ${fetchResponse.status}`);\n        }\n\n        const responseBody = await fetchResponse.json();\n\n        if (responseBody[lang]) {\n          return responseBody[lang];\n        }\n      } catch (e) {\n        console.warn(`Failed to fetch translations from ${path}`);\n      }\n      return {};\n    }).pipe(shareReplay(1));\n    this.cache.set(path, observable);\n    return observable;\n  }\n}\n"]}
|
package/esm2022/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.mjs
CHANGED
|
@@ -131,7 +131,7 @@ export class DatapointSelectionListComponent {
|
|
|
131
131
|
useExisting: forwardRef(() => DatapointSelectionListComponent),
|
|
132
132
|
multi: true
|
|
133
133
|
}
|
|
134
|
-
], usesOnChanges: true, ngImport: i0, template: "<div class=\"card-header separator sticky-top bg-
|
|
134
|
+
], usesOnChanges: true, ngImport: i0, template: "<div class=\"card-header separator sticky-top bg-inherit\">\n <span\n class=\"card-title h4\"\n *ngIf=\"listTitle\"\n >\n {{ listTitle | translate }}\n </span>\n <span\n class=\"card-title h4\"\n *ngIf=\"!listTitle\"\n >\n {{ 'Data points' | translate }}\n </span>\n</div>\n\n<c8y-list-group\n class=\"flex-grow ff-scroll-fix cdk-droplist\"\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n [cdkDropListDisabled]=\"!allowDragAndDrop || formArray.controls?.length < 2\"\n>\n <div\n class=\"alert alert-warning m-t-8\"\n role=\"alert\"\n ngNonBindable\n *ngIf=\"formArray.errors?.minActiveCount\"\n translate\n [translateParams]=\"formArray.errors?.minActiveCount\"\n >\n At least {{ minActive }} active data points must be selected.\n </div>\n\n <div\n class=\"alert alert-warning m-t-8\"\n role=\"alert\"\n ngNonBindable\n *ngIf=\"formArray.errors?.maxActiveCount\"\n translate\n [translateParams]=\"formArray.errors?.maxActiveCount\"\n >\n At maximum {{ maxActive }} active data points are allowed to be selected.\n </div>\n\n <ng-content select=\".alert\"></ng-content>\n\n <div\n class=\"p-t-8\"\n *ngIf=\"!formArray.controls?.length\"\n >\n <c8y-ui-empty-state\n class=\"p-t-8\"\n [icon]=\"'c8y-data-points'\"\n [title]=\"'No data points to display.' | translate\"\n [subtitle]=\"'Add your first data point.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </div>\n <div\n [formGroup]=\"dpForm\"\n *ngFor=\"let dpForm of formArray.controls; let index = index\"\n >\n <c8y-datapoint-selector-list-item\n class=\"d-block\"\n [defaultFormOptions]=\"defaultFormOptions\"\n [activeToggleDisabled]=\"maxActiveCountReached\"\n [showActiveToggle]=\"true\"\n [showAddRemoveButton]=\"false\"\n [showOptions]=\"true\"\n [editable]=\"true\"\n [colorPickerDisabled]=\"false\"\n [actions]=\"actions\"\n [optionToRemove]=\"true\"\n [datapointLibraryEntries]=\"datapointLibraryEntries\"\n [hasUnlinkTemplateOption]=\"true\"\n formControlName=\"details\"\n (removed)=\"onItemRemoved(index)\"\n cdkDrag\n >\n <c8y-li-drag-handle\n title=\"{{ 'Click and drag to reorder' | translate }}\"\n cdkDragHandle\n >\n <i c8yIcon=\"drag-reorder\"></i>\n </c8y-li-drag-handle>\n </c8y-datapoint-selector-list-item>\n </div>\n</c8y-list-group>\n\n<div class=\"card-footer bg-inherit\">\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Add data point' | translate\"\n type=\"button\"\n data-cy=\"c8y-datapoint-selection-list--add-datapoint-button\"\n (click)=\"add()\"\n >\n <i c8yIcon=\"plus-circle\"></i>\n {{ 'Add data point' | translate }}\n </button>\n</div>\n", dependencies: [{ kind: "component", type: i5.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i5.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i5.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i5.ListGroupComponent, selector: "c8y-list-group" }, { kind: "component", type: i5.ListItemDragHandleComponent, selector: "c8y-list-item-drag-handle, c8y-li-drag-handle" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i7.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i7.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i7.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: i8.DatapointSelectorListItemComponent, selector: "c8y-datapoint-selector-list-item", inputs: ["defaultFormOptions", "isSelected", "isCollapsed", "showAddRemoveButton", "editable", "showActiveToggle", "activeToggleDisabled", "showOptions", "datapointLibraryEntries", "actions", "optionToRemove", "hasUnlinkTemplateOption", "colorPickerDisabled", "disableTypeaheadIfSelected", "highlightText"], outputs: ["added", "removed"] }, { kind: "pipe", type: i5.C8yTranslatePipe, name: "translate" }] }); }
|
|
135
135
|
}
|
|
136
136
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointSelectionListComponent, decorators: [{
|
|
137
137
|
type: Component,
|
|
@@ -146,7 +146,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
146
146
|
useExisting: forwardRef(() => DatapointSelectionListComponent),
|
|
147
147
|
multi: true
|
|
148
148
|
}
|
|
149
|
-
], template: "<div class=\"card-header separator sticky-top bg-
|
|
149
|
+
], template: "<div class=\"card-header separator sticky-top bg-inherit\">\n <span\n class=\"card-title h4\"\n *ngIf=\"listTitle\"\n >\n {{ listTitle | translate }}\n </span>\n <span\n class=\"card-title h4\"\n *ngIf=\"!listTitle\"\n >\n {{ 'Data points' | translate }}\n </span>\n</div>\n\n<c8y-list-group\n class=\"flex-grow ff-scroll-fix cdk-droplist\"\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n [cdkDropListDisabled]=\"!allowDragAndDrop || formArray.controls?.length < 2\"\n>\n <div\n class=\"alert alert-warning m-t-8\"\n role=\"alert\"\n ngNonBindable\n *ngIf=\"formArray.errors?.minActiveCount\"\n translate\n [translateParams]=\"formArray.errors?.minActiveCount\"\n >\n At least {{ minActive }} active data points must be selected.\n </div>\n\n <div\n class=\"alert alert-warning m-t-8\"\n role=\"alert\"\n ngNonBindable\n *ngIf=\"formArray.errors?.maxActiveCount\"\n translate\n [translateParams]=\"formArray.errors?.maxActiveCount\"\n >\n At maximum {{ maxActive }} active data points are allowed to be selected.\n </div>\n\n <ng-content select=\".alert\"></ng-content>\n\n <div\n class=\"p-t-8\"\n *ngIf=\"!formArray.controls?.length\"\n >\n <c8y-ui-empty-state\n class=\"p-t-8\"\n [icon]=\"'c8y-data-points'\"\n [title]=\"'No data points to display.' | translate\"\n [subtitle]=\"'Add your first data point.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </div>\n <div\n [formGroup]=\"dpForm\"\n *ngFor=\"let dpForm of formArray.controls; let index = index\"\n >\n <c8y-datapoint-selector-list-item\n class=\"d-block\"\n [defaultFormOptions]=\"defaultFormOptions\"\n [activeToggleDisabled]=\"maxActiveCountReached\"\n [showActiveToggle]=\"true\"\n [showAddRemoveButton]=\"false\"\n [showOptions]=\"true\"\n [editable]=\"true\"\n [colorPickerDisabled]=\"false\"\n [actions]=\"actions\"\n [optionToRemove]=\"true\"\n [datapointLibraryEntries]=\"datapointLibraryEntries\"\n [hasUnlinkTemplateOption]=\"true\"\n formControlName=\"details\"\n (removed)=\"onItemRemoved(index)\"\n cdkDrag\n >\n <c8y-li-drag-handle\n title=\"{{ 'Click and drag to reorder' | translate }}\"\n cdkDragHandle\n >\n <i c8yIcon=\"drag-reorder\"></i>\n </c8y-li-drag-handle>\n </c8y-datapoint-selector-list-item>\n </div>\n</c8y-list-group>\n\n<div class=\"card-footer bg-inherit\">\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Add data point' | translate\"\n type=\"button\"\n data-cy=\"c8y-datapoint-selection-list--add-datapoint-button\"\n (click)=\"add()\"\n >\n <i c8yIcon=\"plus-circle\"></i>\n {{ 'Add data point' | translate }}\n </button>\n</div>\n" }]
|
|
150
150
|
}], ctorParameters: () => [{ type: i1.DatapointSelectorService }, { type: i2.DatapointLibraryService }, { type: i3.FormBuilder }, { type: i4.WidgetConfigComponent, decorators: [{
|
|
151
151
|
type: Optional
|
|
152
152
|
}] }], propDecorators: { actions: [{
|
|
@@ -170,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
170
170
|
}], change: [{
|
|
171
171
|
type: Output
|
|
172
172
|
}] } });
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoint-selection-list.component.js","sourceRoot":"","sources":["../../../../datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.ts","../../../../datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  Component,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormArray,\n  FormBuilder,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  ValidatorFn\n} from '@angular/forms';\nimport { IResultList } from '@c8y/client';\nimport { C8yValidators } from '@c8y/ngx-components';\nimport { WidgetConfigComponent } from '@c8y/ngx-components/context-dashboard';\nimport { from, Observable } from 'rxjs';\nimport { map, shareReplay, take, tap } from 'rxjs/operators';\nimport { DatapointLibraryService } from '../datapoint-library.service';\nimport {\n  DatapointAction,\n  DatapointAttributesFormConfig,\n  KPIDetails,\n  ManagedObjectKPI\n} from '../datapoint-selection.model';\nimport { DatapointSelectorModalOptions } from '../datapoint-selector-modal/datapoint-selector-modal.model';\nimport { DatapointSelectorService } from '../datapoint-selector.service';\n\n@Component({\n  selector: 'c8y-datapoint-selection-list',\n  templateUrl: './datapoint-selection-list.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => DatapointSelectionListComponent)\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatapointSelectionListComponent),\n      multi: true\n    }\n  ]\n})\nexport class DatapointSelectionListComponent\n  implements ControlValueAccessor, Validator, OnInit, OnChanges\n{\n  @Input() actions: DatapointAction[] = [];\n  @Input() allowDragAndDrop = true;\n  @Input() config: Partial<DatapointSelectorModalOptions> = {};\n  @Input() defaultFormOptions: Partial<DatapointAttributesFormConfig> = {};\n  @Input() maxActiveCount: number;\n  @Input() minActiveCount = 1;\n  @Input() resolveContext = true;\n  @Input() listTitle = '';\n  formArray: FormArray;\n  datapointLibraryEntries: Observable<IResultList<ManagedObjectKPI>>;\n  maxActiveCountReached = false;\n\n  @Output() isValid: Observable<boolean>;\n  @Output() change: Observable<any[]>;\n  private usedValidators: { [key: string]: ValidatorFn } = {};\n\n  constructor(\n    private datapointSelector: DatapointSelectorService,\n    private datapointLibrary: DatapointLibraryService,\n    private formBuilder: FormBuilder,\n    @Optional() private widgetComponent: WidgetConfigComponent\n  ) {\n    this.formArray = this.formBuilder.array([]);\n    this.isValid = this.formArray.statusChanges.pipe(map(status => status === 'VALID'));\n    this.datapointLibraryEntries = from(this.datapointLibrary.getFirstDatapointLibraryPage()).pipe(\n      shareReplay()\n    );\n    this.change = this.formArray.valueChanges.pipe(map(res => this.transformValue(res)));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!changes.maxActiveCount && !changes.minActiveCount) {\n      return;\n    }\n    if (changes.maxActiveCount) {\n      this.usedValidators.maxActiveCount = C8yValidators.maxActiveCount(this.maxActiveCount);\n    }\n\n    if (changes.minActiveCount) {\n      this.usedValidators.minActiveCount = C8yValidators.minActiveCount(this.minActiveCount);\n    }\n    const validators = Object.values(this.usedValidators);\n    this.formArray.setValidators(validators);\n  }\n\n  registerOnTouched(fn: any): void {\n    this.formArray.valueChanges.pipe(take(1)).subscribe(fn);\n  }\n\n  validate(_control: AbstractControl): ValidationErrors {\n    return this.formArray.valid ? null : { formInvalid: {} };\n  }\n\n  ngOnInit(): void {\n    const context = this.widgetComponent?.context;\n    if (context?.id && this.resolveContext) {\n      const { name, id, c8y_IsDevice } = context;\n      this.config.contextAsset = { name, id, c8y_IsDevice };\n    }\n  }\n\n  writeValue(obj: KPIDetails[]): void {\n    this.formArray.clear();\n    if (obj?.length) {\n      obj.forEach(val => {\n        const formgroup = this.formBuilder.group({ details: [] });\n        formgroup.patchValue({ details: val });\n        this.formArray.push(formgroup);\n      });\n    }\n    this.calculateMaxActiveCount();\n  }\n\n  registerOnChange(fn: any): void {\n    this.formArray.valueChanges\n      .pipe(\n        map(res => this.transformValue(res)),\n        // check maxActiveCount\n        tap(() => {\n          this.calculateMaxActiveCount();\n        })\n      )\n      .subscribe(fn);\n  }\n\n  add() {\n    const allowChangingContext =\n      !this.widgetComponent?.isDeviceTypeDashboard && this.config?.allowChangingContext !== false;\n    this.datapointSelector\n      .selectDataPoints({\n        ...(this.config || {}),\n        selectedDatapoints: this.transformValue(this.formArray.value),\n        defaultActiveState: true,\n        allowChangingContext,\n        allowSearch: !this.config?.contextAsset\n      })\n      .then(\n        result => {\n          this.writeValue(result);\n        },\n        () => {\n          // nothing to do, modal was closed\n        }\n      );\n  }\n\n  onItemRemoved(index: number) {\n    this.formArray.removeAt(index);\n  }\n\n  drop(event: CdkDragDrop<KPIDetails[]>) {\n    const currentSorting = this.formArray.value;\n    moveItemInArray(currentSorting, event.previousIndex, event.currentIndex);\n    this.formArray.setValue(currentSorting);\n  }\n\n  private transformValue(formArrayValue: any[]) {\n    if (!formArrayValue) {\n      return [];\n    }\n    return formArrayValue.map(tmp => Object.assign({}, ...Object.values(tmp)));\n  }\n\n  private calculateMaxActiveCount() {\n    if (this.maxActiveCount) {\n      const currentlyActive = this.formArray.value.filter(tmp => tmp.details?.__active).length;\n      this.maxActiveCountReached = currentlyActive >= this.maxActiveCount;\n    }\n    this.maxActiveCountReached = false;\n  }\n}\n","<div class=\"card-header separator sticky-top bg-component\">\n  <span\n    class=\"card-title h4\"\n    *ngIf=\"listTitle\"\n  >\n    {{ listTitle | translate }}\n  </span>\n  <span\n    class=\"card-title h4\"\n    *ngIf=\"!listTitle\"\n  >\n    {{ 'Data points' | translate }}\n  </span>\n</div>\n\n<c8y-list-group\n  class=\"flex-grow ff-scroll-fix cdk-droplist\"\n  cdkDropList\n  (cdkDropListDropped)=\"drop($event)\"\n  [cdkDropListDisabled]=\"!allowDragAndDrop || formArray.controls?.length < 2\"\n>\n  <div\n    class=\"alert alert-warning m-t-8\"\n    role=\"alert\"\n    ngNonBindable\n    *ngIf=\"formArray.errors?.minActiveCount\"\n    translate\n    [translateParams]=\"formArray.errors?.minActiveCount\"\n  >\n    At least {{ minActive }} active data points must be selected.\n  </div>\n\n  <div\n    class=\"alert alert-warning m-t-8\"\n    role=\"alert\"\n    ngNonBindable\n    *ngIf=\"formArray.errors?.maxActiveCount\"\n    translate\n    [translateParams]=\"formArray.errors?.maxActiveCount\"\n  >\n    At maximum {{ maxActive }} active data points are allowed to be selected.\n  </div>\n\n  <ng-content select=\".alert\"></ng-content>\n\n  <div\n    class=\"p-t-8\"\n    *ngIf=\"!formArray.controls?.length\"\n  >\n    <c8y-ui-empty-state\n      class=\"p-t-8\"\n      [icon]=\"'c8y-data-points'\"\n      [title]=\"'No data points to display.' | translate\"\n      [subtitle]=\"'Add your first data point.' | translate\"\n      [horizontal]=\"true\"\n    ></c8y-ui-empty-state>\n  </div>\n  <div\n    [formGroup]=\"dpForm\"\n    *ngFor=\"let dpForm of formArray.controls; let index = index\"\n  >\n    <c8y-datapoint-selector-list-item\n      class=\"d-block\"\n      [defaultFormOptions]=\"defaultFormOptions\"\n      [activeToggleDisabled]=\"maxActiveCountReached\"\n      [showActiveToggle]=\"true\"\n      [showAddRemoveButton]=\"false\"\n      [showOptions]=\"true\"\n      [editable]=\"true\"\n      [colorPickerDisabled]=\"false\"\n      [actions]=\"actions\"\n      [optionToRemove]=\"true\"\n      [datapointLibraryEntries]=\"datapointLibraryEntries\"\n      [hasUnlinkTemplateOption]=\"true\"\n      formControlName=\"details\"\n      (removed)=\"onItemRemoved(index)\"\n      cdkDrag\n    >\n      <c8y-li-drag-handle\n        title=\"{{ 'Click and drag to reorder' | translate }}\"\n        cdkDragHandle\n      >\n        <i c8yIcon=\"drag-reorder\"></i>\n      </c8y-li-drag-handle>\n    </c8y-datapoint-selector-list-item>\n  </div>\n</c8y-list-group>\n\n<div class=\"card-footer bg-inherit\">\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Add data point' | translate\"\n    type=\"button\"\n    data-cy=\"c8y-datapoint-selection-list--add-datapoint-button\"\n    (click)=\"add()\"\n  >\n    <i c8yIcon=\"plus-circle\"></i>\n    {{ 'Add data point' | translate }}\n  </button>\n</div>\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoint-selection-list.component.js","sourceRoot":"","sources":["../../../../datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.ts","../../../../datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  Component,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormArray,\n  FormBuilder,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  ValidatorFn\n} from '@angular/forms';\nimport { IResultList } from '@c8y/client';\nimport { C8yValidators } from '@c8y/ngx-components';\nimport { WidgetConfigComponent } from '@c8y/ngx-components/context-dashboard';\nimport { from, Observable } from 'rxjs';\nimport { map, shareReplay, take, tap } from 'rxjs/operators';\nimport { DatapointLibraryService } from '../datapoint-library.service';\nimport {\n  DatapointAction,\n  DatapointAttributesFormConfig,\n  KPIDetails,\n  ManagedObjectKPI\n} from '../datapoint-selection.model';\nimport { DatapointSelectorModalOptions } from '../datapoint-selector-modal/datapoint-selector-modal.model';\nimport { DatapointSelectorService } from '../datapoint-selector.service';\n\n@Component({\n  selector: 'c8y-datapoint-selection-list',\n  templateUrl: './datapoint-selection-list.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => DatapointSelectionListComponent)\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatapointSelectionListComponent),\n      multi: true\n    }\n  ]\n})\nexport class DatapointSelectionListComponent\n  implements ControlValueAccessor, Validator, OnInit, OnChanges\n{\n  @Input() actions: DatapointAction[] = [];\n  @Input() allowDragAndDrop = true;\n  @Input() config: Partial<DatapointSelectorModalOptions> = {};\n  @Input() defaultFormOptions: Partial<DatapointAttributesFormConfig> = {};\n  @Input() maxActiveCount: number;\n  @Input() minActiveCount = 1;\n  @Input() resolveContext = true;\n  @Input() listTitle = '';\n  formArray: FormArray;\n  datapointLibraryEntries: Observable<IResultList<ManagedObjectKPI>>;\n  maxActiveCountReached = false;\n\n  @Output() isValid: Observable<boolean>;\n  @Output() change: Observable<any[]>;\n  private usedValidators: { [key: string]: ValidatorFn } = {};\n\n  constructor(\n    private datapointSelector: DatapointSelectorService,\n    private datapointLibrary: DatapointLibraryService,\n    private formBuilder: FormBuilder,\n    @Optional() private widgetComponent: WidgetConfigComponent\n  ) {\n    this.formArray = this.formBuilder.array([]);\n    this.isValid = this.formArray.statusChanges.pipe(map(status => status === 'VALID'));\n    this.datapointLibraryEntries = from(this.datapointLibrary.getFirstDatapointLibraryPage()).pipe(\n      shareReplay()\n    );\n    this.change = this.formArray.valueChanges.pipe(map(res => this.transformValue(res)));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!changes.maxActiveCount && !changes.minActiveCount) {\n      return;\n    }\n    if (changes.maxActiveCount) {\n      this.usedValidators.maxActiveCount = C8yValidators.maxActiveCount(this.maxActiveCount);\n    }\n\n    if (changes.minActiveCount) {\n      this.usedValidators.minActiveCount = C8yValidators.minActiveCount(this.minActiveCount);\n    }\n    const validators = Object.values(this.usedValidators);\n    this.formArray.setValidators(validators);\n  }\n\n  registerOnTouched(fn: any): void {\n    this.formArray.valueChanges.pipe(take(1)).subscribe(fn);\n  }\n\n  validate(_control: AbstractControl): ValidationErrors {\n    return this.formArray.valid ? null : { formInvalid: {} };\n  }\n\n  ngOnInit(): void {\n    const context = this.widgetComponent?.context;\n    if (context?.id && this.resolveContext) {\n      const { name, id, c8y_IsDevice } = context;\n      this.config.contextAsset = { name, id, c8y_IsDevice };\n    }\n  }\n\n  writeValue(obj: KPIDetails[]): void {\n    this.formArray.clear();\n    if (obj?.length) {\n      obj.forEach(val => {\n        const formgroup = this.formBuilder.group({ details: [] });\n        formgroup.patchValue({ details: val });\n        this.formArray.push(formgroup);\n      });\n    }\n    this.calculateMaxActiveCount();\n  }\n\n  registerOnChange(fn: any): void {\n    this.formArray.valueChanges\n      .pipe(\n        map(res => this.transformValue(res)),\n        // check maxActiveCount\n        tap(() => {\n          this.calculateMaxActiveCount();\n        })\n      )\n      .subscribe(fn);\n  }\n\n  add() {\n    const allowChangingContext =\n      !this.widgetComponent?.isDeviceTypeDashboard && this.config?.allowChangingContext !== false;\n    this.datapointSelector\n      .selectDataPoints({\n        ...(this.config || {}),\n        selectedDatapoints: this.transformValue(this.formArray.value),\n        defaultActiveState: true,\n        allowChangingContext,\n        allowSearch: !this.config?.contextAsset\n      })\n      .then(\n        result => {\n          this.writeValue(result);\n        },\n        () => {\n          // nothing to do, modal was closed\n        }\n      );\n  }\n\n  onItemRemoved(index: number) {\n    this.formArray.removeAt(index);\n  }\n\n  drop(event: CdkDragDrop<KPIDetails[]>) {\n    const currentSorting = this.formArray.value;\n    moveItemInArray(currentSorting, event.previousIndex, event.currentIndex);\n    this.formArray.setValue(currentSorting);\n  }\n\n  private transformValue(formArrayValue: any[]) {\n    if (!formArrayValue) {\n      return [];\n    }\n    return formArrayValue.map(tmp => Object.assign({}, ...Object.values(tmp)));\n  }\n\n  private calculateMaxActiveCount() {\n    if (this.maxActiveCount) {\n      const currentlyActive = this.formArray.value.filter(tmp => tmp.details?.__active).length;\n      this.maxActiveCountReached = currentlyActive >= this.maxActiveCount;\n    }\n    this.maxActiveCountReached = false;\n  }\n}\n","<div class=\"card-header separator sticky-top bg-inherit\">\n  <span\n    class=\"card-title h4\"\n    *ngIf=\"listTitle\"\n  >\n    {{ listTitle | translate }}\n  </span>\n  <span\n    class=\"card-title h4\"\n    *ngIf=\"!listTitle\"\n  >\n    {{ 'Data points' | translate }}\n  </span>\n</div>\n\n<c8y-list-group\n  class=\"flex-grow ff-scroll-fix cdk-droplist\"\n  cdkDropList\n  (cdkDropListDropped)=\"drop($event)\"\n  [cdkDropListDisabled]=\"!allowDragAndDrop || formArray.controls?.length < 2\"\n>\n  <div\n    class=\"alert alert-warning m-t-8\"\n    role=\"alert\"\n    ngNonBindable\n    *ngIf=\"formArray.errors?.minActiveCount\"\n    translate\n    [translateParams]=\"formArray.errors?.minActiveCount\"\n  >\n    At least {{ minActive }} active data points must be selected.\n  </div>\n\n  <div\n    class=\"alert alert-warning m-t-8\"\n    role=\"alert\"\n    ngNonBindable\n    *ngIf=\"formArray.errors?.maxActiveCount\"\n    translate\n    [translateParams]=\"formArray.errors?.maxActiveCount\"\n  >\n    At maximum {{ maxActive }} active data points are allowed to be selected.\n  </div>\n\n  <ng-content select=\".alert\"></ng-content>\n\n  <div\n    class=\"p-t-8\"\n    *ngIf=\"!formArray.controls?.length\"\n  >\n    <c8y-ui-empty-state\n      class=\"p-t-8\"\n      [icon]=\"'c8y-data-points'\"\n      [title]=\"'No data points to display.' | translate\"\n      [subtitle]=\"'Add your first data point.' | translate\"\n      [horizontal]=\"true\"\n    ></c8y-ui-empty-state>\n  </div>\n  <div\n    [formGroup]=\"dpForm\"\n    *ngFor=\"let dpForm of formArray.controls; let index = index\"\n  >\n    <c8y-datapoint-selector-list-item\n      class=\"d-block\"\n      [defaultFormOptions]=\"defaultFormOptions\"\n      [activeToggleDisabled]=\"maxActiveCountReached\"\n      [showActiveToggle]=\"true\"\n      [showAddRemoveButton]=\"false\"\n      [showOptions]=\"true\"\n      [editable]=\"true\"\n      [colorPickerDisabled]=\"false\"\n      [actions]=\"actions\"\n      [optionToRemove]=\"true\"\n      [datapointLibraryEntries]=\"datapointLibraryEntries\"\n      [hasUnlinkTemplateOption]=\"true\"\n      formControlName=\"details\"\n      (removed)=\"onItemRemoved(index)\"\n      cdkDrag\n    >\n      <c8y-li-drag-handle\n        title=\"{{ 'Click and drag to reorder' | translate }}\"\n        cdkDragHandle\n      >\n        <i c8yIcon=\"drag-reorder\"></i>\n      </c8y-li-drag-handle>\n    </c8y-datapoint-selector-list-item>\n  </div>\n</c8y-list-group>\n\n<div class=\"card-footer bg-inherit\">\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Add data point' | translate\"\n    type=\"button\"\n    data-cy=\"c8y-datapoint-selection-list--add-datapoint-button\"\n    (click)=\"add()\"\n  >\n    <i c8yIcon=\"plus-circle\"></i>\n    {{ 'Add data point' | translate }}\n  </button>\n</div>\n"]}
|