@c8y/ngx-components 1021.54.10 → 1021.54.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/datapoint-selector/datapoint-library.service.d.ts +2 -2
  2. package/datapoint-selector/datapoint-library.service.d.ts.map +1 -1
  3. package/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.d.ts +5 -0
  4. package/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.d.ts.map +1 -1
  5. package/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.d.ts +13 -2
  6. package/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.d.ts.map +1 -1
  7. package/datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.d.ts +2 -0
  8. package/datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.d.ts.map +1 -1
  9. package/datapoint-selector/datapoint-selector.component.d.ts +11 -1
  10. package/datapoint-selector/datapoint-selector.component.d.ts.map +1 -1
  11. package/esm2022/datapoint-selector/datapoint-library.service.mjs +11 -6
  12. package/esm2022/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.mjs +5 -3
  13. package/esm2022/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.mjs +12 -6
  14. package/esm2022/datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.mjs +5 -3
  15. package/esm2022/datapoint-selector/datapoint-selector.component.mjs +22 -5
  16. package/esm2022/upgrade/ng1/downgraded.services.mjs +3 -1
  17. package/esm2022/upgrade/ng1/index.mjs +4 -3
  18. package/fesm2022/c8y-ngx-components-datapoint-selector.mjs +49 -19
  19. package/fesm2022/c8y-ngx-components-datapoint-selector.mjs.map +1 -1
  20. package/fesm2022/c8y-ngx-components-upgrade.mjs +4 -2
  21. package/fesm2022/c8y-ngx-components-upgrade.mjs.map +1 -1
  22. package/locales/de.po +6 -6
  23. package/locales/fr.po +7 -7
  24. package/locales/ja_JP.po +222 -171
  25. package/locales/locales.pot +12 -3
  26. package/package.json +1 -1
  27. package/upgrade/ng1/downgraded.services.d.ts +1 -0
  28. package/upgrade/ng1/downgraded.services.d.ts.map +1 -1
  29. package/upgrade/ng1/index.d.ts.map +1 -1
@@ -13,7 +13,7 @@ export declare class DatapointLibraryService {
13
13
  getFirstDatapointLibraryPage(): Promise<IResultList<ManagedObjectKPI>>;
14
14
  getAllDatapointLibraryItemsCached(): Promise<KPIDetails[]>;
15
15
  updateDatapoints(datapoints: KPIDetails[], skipUpdatingTarget?: boolean): Promise<KPIDetails[]>;
16
- getDatapointsOfAsset(parentReference: IIdentified, ignoreDatapointTemplates?: boolean): Promise<KPIDetails[]>;
16
+ getDatapointsOfAsset(parentReference: IIdentified, ignoreDatapointTemplates?: boolean, datapointTemplatesOnly?: boolean): Promise<KPIDetails[]>;
17
17
  /**
18
18
  * Requests the last measurement with the given fragment and series to extract it's unit.
19
19
  * If the source attribute is provided, it will check the last measurement for this specific source.
@@ -23,7 +23,7 @@ export declare class DatapointLibraryService {
23
23
  protected combineFragmentSeriesTuplesWithDetails(tuples: Array<{
24
24
  fragment: string;
25
25
  series: string;
26
- }>, target: IIdentified, kpis: ManagedObjectKPI[]): Promise<KPIDetails[]>;
26
+ }>, target: IIdentified, kpis: ManagedObjectKPI[], datapointTemplatesOnly?: boolean): Promise<KPIDetails[]>;
27
27
  protected assignColorToDatapoints(datapoints: KPIDetails[]): Promise<void>;
28
28
  protected getAllDatapointLibraryEntries(): Promise<ManagedObjectKPI[]>;
29
29
  protected mapDatapointLibraryEntry(entry: ManagedObjectKPI): KPIDetails;
@@ -1 +1 @@
1
- {"version":3,"file":"datapoint-library.service.d.ts","sourceRoot":"","sources":["../../datapoint-selector/datapoint-library.service.ts"],"names":[],"mappings":"AACA,OAAO,EACL,WAAW,EACX,cAAc,EACd,gBAAgB,EAChB,WAAW,EACX,kBAAkB,EACnB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAiB,MAAM,qBAAqB,CAAC;AAGnF,OAAO,EAEL,UAAU,EACV,gBAAgB,EACjB,MAAM,6BAA6B,CAAC;;AAErC,qBACa,uBAAuB;IAGhC,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,KAAK;IALf,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;gBAEnC,SAAS,EAAE,gBAAgB,EAC3B,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,kBAAkB,EAChC,KAAK,EAAE,YAAY;IAOvB,mCAAmC,CAAC,eAAe,UAAQ,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAUzF,4BAA4B,IAAI,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;IAUtE,iCAAiC,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;IAQ1D,gBAAgB,CACpB,UAAU,EAAE,UAAU,EAAE,EACxB,kBAAkB,UAAQ,GACzB,OAAO,CAAC,UAAU,EAAE,CAAC;IAyClB,oBAAoB,CACxB,eAAe,EAAE,WAAW,EAC5B,wBAAwB,CAAC,EAAE,OAAO,GACjC,OAAO,CAAC,UAAU,EAAE,CAAC;IAexB;;;;OAIG;IACG,oBAAoB,CACxB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,MAAM,CAAC;cA2BF,sCAAsC,CACpD,MAAM,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,EACnD,MAAM,EAAE,WAAW,EACnB,IAAI,EAAE,gBAAgB,EAAE;cAwBV,uBAAuB,CAAC,UAAU,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;cAWhE,6BAA6B,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAsB5E,SAAS,CAAC,wBAAwB,CAAC,KAAK,EAAE,gBAAgB,GAAG,UAAU;cAUvD,iCAAiC,CAC/C,UAAU,EAAE,UAAU,EAAE,GACvB,OAAO,CAAC,cAAc,EAAE,CAAC;cAMZ,wCAAwC,CACtD,UAAU,EAAE,UAAU,EAAE,GACvB,OAAO,CAAC,cAAc,EAAE,CAAC;cAMZ,WAAW,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;yCAjOxE,uBAAuB;6CAAvB,uBAAuB;CAsPnC"}
1
+ {"version":3,"file":"datapoint-library.service.d.ts","sourceRoot":"","sources":["../../datapoint-selector/datapoint-library.service.ts"],"names":[],"mappings":"AACA,OAAO,EACL,WAAW,EACX,cAAc,EACd,gBAAgB,EAChB,WAAW,EACX,kBAAkB,EACnB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAiB,MAAM,qBAAqB,CAAC;AAGnF,OAAO,EAEL,UAAU,EACV,gBAAgB,EACjB,MAAM,6BAA6B,CAAC;;AAErC,qBACa,uBAAuB;IAGhC,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,KAAK;IALf,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;gBAEnC,SAAS,EAAE,gBAAgB,EAC3B,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,kBAAkB,EAChC,KAAK,EAAE,YAAY;IAOvB,mCAAmC,CAAC,eAAe,UAAQ,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAUzF,4BAA4B,IAAI,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;IAUtE,iCAAiC,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;IAQ1D,gBAAgB,CACpB,UAAU,EAAE,UAAU,EAAE,EACxB,kBAAkB,UAAQ,GACzB,OAAO,CAAC,UAAU,EAAE,CAAC;IAyClB,oBAAoB,CACxB,eAAe,EAAE,WAAW,EAC5B,wBAAwB,CAAC,EAAE,OAAO,EAClC,sBAAsB,UAAQ,GAC7B,OAAO,CAAC,UAAU,EAAE,CAAC;IAoBxB;;;;OAIG;IACG,oBAAoB,CACxB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,MAAM,CAAC;cA2BF,sCAAsC,CACpD,MAAM,EAAE,KAAK,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,EACnD,MAAM,EAAE,WAAW,EACnB,IAAI,EAAE,gBAAgB,EAAE,EACxB,sBAAsB,UAAQ;cA6BhB,uBAAuB,CAAC,UAAU,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;cAWhE,6BAA6B,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAsB5E,SAAS,CAAC,wBAAwB,CAAC,KAAK,EAAE,gBAAgB,GAAG,UAAU;cAUvD,iCAAiC,CAC/C,UAAU,EAAE,UAAU,EAAE,GACvB,OAAO,CAAC,cAAc,EAAE,CAAC;cAMZ,wCAAwC,CACtD,UAAU,EAAE,UAAU,EAAE,GACvB,OAAO,CAAC,cAAc,EAAE,CAAC;cAMZ,WAAW,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;yCA7OxE,uBAAuB;6CAAvB,uBAAuB;CAkQnC"}
@@ -25,6 +25,11 @@ export declare class DatapointSelectionListComponent implements ControlValueAcce
25
25
  formArray: FormArray;
26
26
  datapointLibraryEntries: Observable<IResultList<ManagedObjectKPI>>;
27
27
  maxActiveCountReached: boolean;
28
+ AddButtonTypes: {
29
+ readonly none: "none";
30
+ readonly addRemove: "add-remove";
31
+ readonly select: "select";
32
+ };
28
33
  isValid: Observable<boolean>;
29
34
  change: Observable<any[]>;
30
35
  private usedValidators;
@@ -1 +1 @@
1
- {"version":3,"file":"datapoint-selection-list.component.d.ts","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAmB,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAIL,SAAS,EACT,MAAM,EAGN,aAAa,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,eAAe,EACf,oBAAoB,EACpB,SAAS,EACT,WAAW,EAGX,gBAAgB,EAChB,SAAS,EAEV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAQ,UAAU,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EACL,eAAe,EACf,6BAA6B,EAC7B,UAAU,EACV,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,6BAA6B,EAAE,MAAM,4DAA4D,CAAC;AAC3G,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;;AAEzE,qBAgBa,+BACX,YAAW,oBAAoB,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS;IAmB3D,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,WAAW;IACP,OAAO,CAAC,eAAe;IApB5B,OAAO,EAAE,eAAe,EAAE,CAAM;IAChC,gBAAgB,UAAQ;IACxB,MAAM,EAAE,OAAO,CAAC,6BAA6B,CAAC,CAAM;IACpD,kBAAkB,EAAE,OAAO,CAAC,6BAA6B,CAAC,CAAM;IAChE,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,SAAK;IACnB,cAAc,UAAQ;IACtB,SAAS,SAAM;IACxB,SAAS,EAAE,SAAS,CAAC;IACrB,uBAAuB,EAAE,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACnE,qBAAqB,UAAS;IAEpB,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC7B,MAAM,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,OAAO,CAAC,cAAc,CAAsC;gBAGlD,iBAAiB,EAAE,wBAAwB,EAC3C,gBAAgB,EAAE,uBAAuB,EACzC,WAAW,EAAE,WAAW,EACZ,eAAe,EAAE,qBAAqB;IAU5D,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAezC,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,QAAQ,CAAC,QAAQ,EAAE,eAAe,GAAG,gBAAgB;IAIrD,QAAQ,IAAI,IAAI;IAQhB,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,IAAI;IAYnC,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAY/B,GAAG;IAqBH,aAAa,CAAC,KAAK,EAAE,MAAM;IAI3B,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,UAAU,EAAE,CAAC;IAMrC,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,uBAAuB;yCA9HpB,+BAA+B;2CAA/B,+BAA+B;CAqI3C"}
1
+ {"version":3,"file":"datapoint-selection-list.component.d.ts","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAmB,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAIL,SAAS,EACT,MAAM,EAGN,aAAa,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,eAAe,EACf,oBAAoB,EACpB,SAAS,EACT,WAAW,EAGX,gBAAgB,EAChB,SAAS,EAEV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAQ,UAAU,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EACL,eAAe,EACf,6BAA6B,EAC7B,UAAU,EACV,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,6BAA6B,EAAE,MAAM,4DAA4D,CAAC;AAC3G,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;;AAGzE,qBAgBa,+BACX,YAAW,oBAAoB,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS;IAoB3D,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,WAAW;IACP,OAAO,CAAC,eAAe;IArB5B,OAAO,EAAE,eAAe,EAAE,CAAM;IAChC,gBAAgB,UAAQ;IACxB,MAAM,EAAE,OAAO,CAAC,6BAA6B,CAAC,CAAM;IACpD,kBAAkB,EAAE,OAAO,CAAC,6BAA6B,CAAC,CAAM;IAChE,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,SAAK;IACnB,cAAc,UAAQ;IACtB,SAAS,SAAM;IACxB,SAAS,EAAE,SAAS,CAAC;IACrB,uBAAuB,EAAE,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACnE,qBAAqB,UAAS;IAC9B,cAAc;;;;MAAkB;IAEtB,OAAO,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC7B,MAAM,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,OAAO,CAAC,cAAc,CAAsC;gBAGlD,iBAAiB,EAAE,wBAAwB,EAC3C,gBAAgB,EAAE,uBAAuB,EACzC,WAAW,EAAE,WAAW,EACZ,eAAe,EAAE,qBAAqB;IAU5D,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAezC,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,QAAQ,CAAC,QAAQ,EAAE,eAAe,GAAG,gBAAgB;IAIrD,QAAQ,IAAI,IAAI;IAQhB,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,IAAI;IAYnC,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAY/B,GAAG;IAqBH,aAAa,CAAC,KAAK,EAAE,MAAM;IAI3B,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,UAAU,EAAE,CAAC;IAMrC,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,uBAAuB;yCA/HpB,+BAA+B;2CAA/B,+BAA+B;CAsI3C"}
@@ -5,13 +5,19 @@ import { Observable } from 'rxjs';
5
5
  import { ForOfFilterPipe, ListItemDragHandleComponent } from '@c8y/ngx-components';
6
6
  import { DatapointAction, DatapointAttributesFormConfig, KPIDetails, ManagedObjectKPI } from '../datapoint-selection.model';
7
7
  import * as i0 from "@angular/core";
8
+ export declare const AddButtonTypes: {
9
+ readonly none: "none";
10
+ readonly addRemove: "add-remove";
11
+ readonly select: "select";
12
+ };
13
+ export type AddButtonType = (typeof AddButtonTypes)[keyof typeof AddButtonTypes];
8
14
  export declare class DatapointSelectorListItemComponent implements ControlValueAccessor, Validator {
9
15
  private formBuilder;
10
16
  formGroup: FormGroup;
11
17
  defaultFormOptions: Partial<DatapointAttributesFormConfig>;
12
18
  isSelected: boolean;
13
19
  isCollapsed: boolean;
14
- showAddRemoveButton: boolean;
20
+ addButtonType: AddButtonType;
15
21
  editable: boolean;
16
22
  showActiveToggle: boolean;
17
23
  activeToggleDisabled: boolean;
@@ -30,6 +36,11 @@ export declare class DatapointSelectorListItemComponent implements ControlValueA
30
36
  filterPipe: ForOfFilterPipe<ManagedObjectKPI>;
31
37
  isValid$: Observable<boolean>;
32
38
  errorMessage: string;
39
+ AddButtonTypes: {
40
+ readonly none: "none";
41
+ readonly addRemove: "add-remove";
42
+ readonly select: "select";
43
+ };
33
44
  constructor(formBuilder: FormBuilder);
34
45
  validate(_control: AbstractControl): ValidationErrors;
35
46
  writeValue(obj: any): void;
@@ -46,6 +57,6 @@ export declare class DatapointSelectorListItemComponent implements ControlValueA
46
57
  private filterDatapointLabel;
47
58
  private transformFormValue;
48
59
  static ɵfac: i0.ɵɵFactoryDeclaration<DatapointSelectorListItemComponent, never>;
49
- static ɵcmp: i0.ɵɵComponentDeclaration<DatapointSelectorListItemComponent, "c8y-datapoint-selector-list-item", never, { "defaultFormOptions": { "alias": "defaultFormOptions"; "required": false; }; "isSelected": { "alias": "isSelected"; "required": false; }; "isCollapsed": { "alias": "isCollapsed"; "required": false; }; "showAddRemoveButton": { "alias": "showAddRemoveButton"; "required": false; }; "editable": { "alias": "editable"; "required": false; }; "showActiveToggle": { "alias": "showActiveToggle"; "required": false; }; "activeToggleDisabled": { "alias": "activeToggleDisabled"; "required": false; }; "showOptions": { "alias": "showOptions"; "required": false; }; "datapointLibraryEntries": { "alias": "datapointLibraryEntries"; "required": false; }; "actions": { "alias": "actions"; "required": false; }; "optionToRemove": { "alias": "optionToRemove"; "required": false; }; "hasUnlinkTemplateOption": { "alias": "hasUnlinkTemplateOption"; "required": false; }; "colorPickerDisabled": { "alias": "colorPickerDisabled"; "required": false; }; "disableTypeaheadIfSelected": { "alias": "disableTypeaheadIfSelected"; "required": false; }; "highlightText": { "alias": "highlightText"; "required": false; }; }, { "added": "added"; "removed": "removed"; }, ["dragHandle"], ["c8y-li-drag-handle"], false, never>;
60
+ static ɵcmp: i0.ɵɵComponentDeclaration<DatapointSelectorListItemComponent, "c8y-datapoint-selector-list-item", never, { "defaultFormOptions": { "alias": "defaultFormOptions"; "required": false; }; "isSelected": { "alias": "isSelected"; "required": false; }; "isCollapsed": { "alias": "isCollapsed"; "required": false; }; "addButtonType": { "alias": "addButtonType"; "required": false; }; "editable": { "alias": "editable"; "required": false; }; "showActiveToggle": { "alias": "showActiveToggle"; "required": false; }; "activeToggleDisabled": { "alias": "activeToggleDisabled"; "required": false; }; "showOptions": { "alias": "showOptions"; "required": false; }; "datapointLibraryEntries": { "alias": "datapointLibraryEntries"; "required": false; }; "actions": { "alias": "actions"; "required": false; }; "optionToRemove": { "alias": "optionToRemove"; "required": false; }; "hasUnlinkTemplateOption": { "alias": "hasUnlinkTemplateOption"; "required": false; }; "colorPickerDisabled": { "alias": "colorPickerDisabled"; "required": false; }; "disableTypeaheadIfSelected": { "alias": "disableTypeaheadIfSelected"; "required": false; }; "highlightText": { "alias": "highlightText"; "required": false; }; }, { "added": "added"; "removed": "removed"; }, ["dragHandle"], ["c8y-li-drag-handle"], false, never>;
50
61
  }
51
62
  //# sourceMappingURL=datapoint-selector-list-item.component.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"datapoint-selector-list-item.component.d.ts","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,YAAY,EAA6B,MAAM,eAAe,CAAC;AACjG,OAAO,EACL,eAAe,EACf,oBAAoB,EACpB,WAAW,EACX,SAAS,EAGT,gBAAgB,EAChB,SAAS,EACV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAQ,MAAM,MAAM,CAAC;AAExC,OAAO,EAAE,eAAe,EAAE,2BAA2B,EAAE,MAAM,qBAAqB,CAAC;AACnF,OAAO,EACL,eAAe,EACf,6BAA6B,EAE7B,UAAU,EACV,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;;AAEtC,qBAgBa,kCAAmC,YAAW,oBAAoB,EAAE,SAAS;IA0B5E,OAAO,CAAC,WAAW;IAzB/B,SAAS,EAAE,SAAS,CAAC;IACZ,kBAAkB,EAAE,OAAO,CAAC,6BAA6B,CAAC,CAAM;IAChE,UAAU,UAAS;IACnB,WAAW,UAAQ;IACnB,mBAAmB,UAAQ;IAC3B,QAAQ,UAAQ;IAChB,gBAAgB,UAAS;IACzB,oBAAoB,UAAS;IAC7B,WAAW,UAAS;IACpB,uBAAuB,EAAE,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACnE,OAAO,EAAE,eAAe,EAAE,CAAM;IAChC,cAAc,UAAS;IACvB,uBAAuB,UAAS;IAC/B,KAAK,2BAAkC;IACvC,OAAO,2BAAkC;IAC1C,mBAAmB,UAAQ;IAC3B,0BAA0B,UAAS;IACnC,aAAa,EAAE,MAAM,CAAC;IACY,UAAU,EAAE,2BAA2B,CAAC;IAEnF,OAAO,SAAM;IACb,UAAU,EAAE,eAAe,CAAC,gBAAgB,CAAC,CAAC;IAC9C,QAAQ,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC9B,YAAY,EAAE,MAAM,CAAC;gBAED,WAAW,EAAE,WAAW;IAgB5C,QAAQ,CAAC,QAAQ,EAAE,eAAe,GAAG,gBAAgB;IAerD,UAAU,CAAC,GAAG,EAAE,GAAG,GAAG,IAAI;IAI1B,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAI/B,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,gBAAgB,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAO3C,QAAQ;IAIR,eAAe;IASf,MAAM;IAIN,OAAO,CAAC,SAAS,EAAE,MAAM;IASzB,uBAAuB,IAAI,IAAI;IAM/B,yBAAyB,CAAC,QAAQ,EAAE,gBAAgB;IA8BpD,OAAO,CAAC,qBAAqB;IAgB7B,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,kBAAkB;yCApKf,kCAAkC;2CAAlC,kCAAkC;CAyK9C"}
1
+ {"version":3,"file":"datapoint-selector-list-item.component.d.ts","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,YAAY,EAA6B,MAAM,eAAe,CAAC;AACjG,OAAO,EACL,eAAe,EACf,oBAAoB,EACpB,WAAW,EACX,SAAS,EAGT,gBAAgB,EAChB,SAAS,EACV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAQ,MAAM,MAAM,CAAC;AAExC,OAAO,EAAE,eAAe,EAAE,2BAA2B,EAAE,MAAM,qBAAqB,CAAC;AACnF,OAAO,EACL,eAAe,EACf,6BAA6B,EAE7B,UAAU,EACV,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;;AAEtC,eAAO,MAAM,cAAc;;;;CAIjB,CAAC;AACX,MAAM,MAAM,aAAa,GAAG,CAAC,OAAO,cAAc,CAAC,CAAC,MAAM,OAAO,cAAc,CAAC,CAAC;AAEjF,qBAgBa,kCAAmC,YAAW,oBAAoB,EAAE,SAAS;IA2B5E,OAAO,CAAC,WAAW;IA1B/B,SAAS,EAAE,SAAS,CAAC;IACZ,kBAAkB,EAAE,OAAO,CAAC,6BAA6B,CAAC,CAAM;IAChE,UAAU,UAAS;IACnB,WAAW,UAAQ;IACnB,aAAa,EAAE,aAAa,CAA4B;IACxD,QAAQ,UAAQ;IAChB,gBAAgB,UAAS;IACzB,oBAAoB,UAAS;IAC7B,WAAW,UAAS;IACpB,uBAAuB,EAAE,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACnE,OAAO,EAAE,eAAe,EAAE,CAAM;IAChC,cAAc,UAAS;IACvB,uBAAuB,UAAS;IAC/B,KAAK,2BAAkC;IACvC,OAAO,2BAAkC;IAC1C,mBAAmB,UAAQ;IAC3B,0BAA0B,UAAS;IACnC,aAAa,EAAE,MAAM,CAAC;IACY,UAAU,EAAE,2BAA2B,CAAC;IAEnF,OAAO,SAAM;IACb,UAAU,EAAE,eAAe,CAAC,gBAAgB,CAAC,CAAC;IAC9C,QAAQ,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc;;;;MAAkB;gBAEZ,WAAW,EAAE,WAAW;IAgB5C,QAAQ,CAAC,QAAQ,EAAE,eAAe,GAAG,gBAAgB;IAerD,UAAU,CAAC,GAAG,EAAE,GAAG,GAAG,IAAI;IAI1B,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAI/B,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,gBAAgB,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAO3C,QAAQ;IAIR,eAAe;IASf,MAAM;IAIN,OAAO,CAAC,SAAS,EAAE,MAAM;IASzB,uBAAuB,IAAI,IAAI;IAM/B,yBAAyB,CAAC,QAAQ,EAAE,gBAAgB;IA8BpD,OAAO,CAAC,qBAAqB;IAgB7B,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,kBAAkB;yCArKf,kCAAkC;2CAAlC,kCAAkC;CA0K9C"}
@@ -17,6 +17,8 @@ export declare class DatapointSelectorModalComponent implements OnInit {
17
17
  defaultActiveState: boolean;
18
18
  finishWithFirstSelection: boolean;
19
19
  ignoreDatapointTemplates: boolean;
20
+ itemsEditable: boolean;
21
+ datapointTemplatesOnly: boolean;
20
22
  assetSelectorConfig: Partial<DatapointSelectorModalAssetSelectorOptions>;
21
23
  readonly result: Promise<KPIDetails[]>;
22
24
  private save;
@@ -1 +1 @@
1
- {"version":3,"file":"datapoint-selector-modal.component.d.ts","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EACL,0CAA0C,EAC1C,UAAU,EACX,MAAM,8BAA8B,CAAC;;AAEtC,qBAIa,+BAAgC,YAAW,MAAM;IAqBhD,OAAO,CAAC,OAAO;IAAc,OAAO,CAAC,UAAU;IApB3D,YAAY,EAAE,WAAW,CAAC;IAC1B,oBAAoB,UAAQ;IAC5B,WAAW,UAAQ;IACnB,iCAAiC,UAAQ;IACzC,kBAAkB,eAA2B;IAC7C,KAAK,EAAE,MAAM,CAAkC;IAC/C,eAAe,EAAE,MAAM,CAA8B;IACrD,kBAAkB,UAAQ;IAC1B,kBAAkB,UAAQ;IAC1B,wBAAwB,UAAS;IACjC,wBAAwB,UAAS;IACjC,mBAAmB,EAAE,OAAO,CAAC,0CAA0C,CAAC,CAAM;IAC9E,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,CAGnC;IAEH,OAAO,CAAC,IAAI,CAAgC;IAC5C,OAAO,CAAC,MAAM,CAAyB;gBAEnB,OAAO,EAAE,UAAU,EAAU,UAAU,EAAE,UAAU;IAEvE,QAAQ,IAAI,IAAI;IAIhB,WAAW,IAAI,IAAI;IAKnB,KAAK;IAKL,eAAe,CAAC,SAAS,EAAE,KAAK,CAAC,UAAU,CAAC;IAO5C;;;;OAIG;IACH,OAAO,CAAC,4DAA4D;yCAjDzD,+BAA+B;2CAA/B,+BAA+B;CAwD3C"}
1
+ {"version":3,"file":"datapoint-selector-modal.component.d.ts","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EACL,0CAA0C,EAC1C,UAAU,EACX,MAAM,8BAA8B,CAAC;;AAEtC,qBAIa,+BAAgC,YAAW,MAAM;IAwB1D,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,UAAU;IAxBpB,YAAY,EAAE,WAAW,CAAC;IAC1B,oBAAoB,UAAQ;IAC5B,WAAW,UAAQ;IACnB,iCAAiC,UAAQ;IACzC,kBAAkB,eAA2B;IAC7C,KAAK,EAAE,MAAM,CAAkC;IAC/C,eAAe,EAAE,MAAM,CAA8B;IACrD,kBAAkB,UAAQ;IAC1B,kBAAkB,UAAQ;IAC1B,wBAAwB,UAAS;IACjC,wBAAwB,UAAS;IACjC,aAAa,UAAQ;IACrB,sBAAsB,UAAS;IAC/B,mBAAmB,EAAE,OAAO,CAAC,0CAA0C,CAAC,CAAM;IAC9E,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,CAGnC;IAEH,OAAO,CAAC,IAAI,CAAgC;IAC5C,OAAO,CAAC,MAAM,CAAyB;gBAG7B,OAAO,EAAE,UAAU,EACnB,UAAU,EAAE,UAAU;IAGhC,QAAQ,IAAI,IAAI;IAIhB,WAAW,IAAI,IAAI;IAKnB,KAAK;IAKL,eAAe,CAAC,SAAS,EAAE,KAAK,CAAC,UAAU,CAAC;IAO5C;;;;OAIG;IACH,OAAO,CAAC,4DAA4D;yCAtDzD,+BAA+B;2CAA/B,+BAA+B;CA6D3C"}
@@ -13,11 +13,21 @@ export declare class DatapointSelectorComponent implements OnInit, ControlValueA
13
13
  selectedDatapoints: KPIDetails[];
14
14
  defaultActiveState: boolean;
15
15
  ignoreDatapointTemplates: boolean;
16
+ datapointTemplatesOnly: boolean;
16
17
  guessDatapointUnit: boolean;
17
18
  allowSearch: boolean;
18
19
  hideSelection: boolean;
20
+ itemsEditable: boolean;
19
21
  searchString: string;
20
22
  maxNumberOfDatapoints: number;
23
+ selectorTitle: string;
24
+ emptyStateTitle: string;
25
+ selectedListTitle: string;
26
+ AddButtonTypes: {
27
+ readonly none: "none";
28
+ readonly addRemove: "add-remove";
29
+ readonly select: "select";
30
+ };
21
31
  loadingDatapoints: boolean;
22
32
  assetSelection: BehaviorSubject<IIdentified>;
23
33
  datapoints$: Observable<KPIDetails[]>;
@@ -47,6 +57,6 @@ export declare class DatapointSelectorComponent implements OnInit, ControlValueA
47
57
  private markAsTouched;
48
58
  private includesSearchString;
49
59
  static ɵfac: i0.ɵɵFactoryDeclaration<DatapointSelectorComponent, never>;
50
- static ɵcmp: i0.ɵɵComponentDeclaration<DatapointSelectorComponent, "c8y-datapoint-selector", never, { "contextAsset": { "alias": "contextAsset"; "required": false; }; "allowChangingContext": { "alias": "allowChangingContext"; "required": false; }; "allowDatapointsFromMultipleAssets": { "alias": "allowDatapointsFromMultipleAssets"; "required": false; }; "defaultActiveState": { "alias": "defaultActiveState"; "required": false; }; "ignoreDatapointTemplates": { "alias": "ignoreDatapointTemplates"; "required": false; }; "guessDatapointUnit": { "alias": "guessDatapointUnit"; "required": false; }; "allowSearch": { "alias": "allowSearch"; "required": false; }; "hideSelection": { "alias": "hideSelection"; "required": false; }; }, {}, never, never, false, never>;
60
+ static ɵcmp: i0.ɵɵComponentDeclaration<DatapointSelectorComponent, "c8y-datapoint-selector", never, { "contextAsset": { "alias": "contextAsset"; "required": false; }; "allowChangingContext": { "alias": "allowChangingContext"; "required": false; }; "allowDatapointsFromMultipleAssets": { "alias": "allowDatapointsFromMultipleAssets"; "required": false; }; "defaultActiveState": { "alias": "defaultActiveState"; "required": false; }; "ignoreDatapointTemplates": { "alias": "ignoreDatapointTemplates"; "required": false; }; "datapointTemplatesOnly": { "alias": "datapointTemplatesOnly"; "required": false; }; "guessDatapointUnit": { "alias": "guessDatapointUnit"; "required": false; }; "allowSearch": { "alias": "allowSearch"; "required": false; }; "hideSelection": { "alias": "hideSelection"; "required": false; }; "itemsEditable": { "alias": "itemsEditable"; "required": false; }; }, {}, never, never, false, never>;
51
61
  }
52
62
  //# sourceMappingURL=datapoint-selector.component.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"datapoint-selector.component.d.ts","sourceRoot":"","sources":["../../datapoint-selector/datapoint-selector.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,MAAM,EAAE,MAAM,eAAe,CAAC;AACrE,OAAO,EAAE,oBAAoB,EAAqB,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAEvD,OAAO,EAAE,eAAe,EAAuB,UAAU,EAAE,MAAM,MAAM,CAAC;AASxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;;AAE3E,qBAWa,0BAA2B,YAAW,MAAM,EAAE,oBAAoB;IA8BjE,OAAO,CAAC,gBAAgB;IA7B3B,YAAY,EAAE,WAAW,CAAC;IAC1B,oBAAoB,UAAQ;IAC5B,iCAAiC,UAAQ;IAClD,kBAAkB,eAA2B;IACpC,kBAAkB,UAAQ;IAC1B,wBAAwB,UAAS;IACjC,kBAAkB,UAAQ;IAC1B,WAAW,UAAQ;IACnB,aAAa,UAAS;IAC/B,YAAY,SAAM;IAClB,qBAAqB,SAAM;IAE3B,iBAAiB,UAAS;IAC1B,cAAc,+BAA0C;IACxD,WAAW,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC;IACtC,mBAAmB,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC;IAC9C,oBAAoB,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;IACzC,uBAAuB,EAAE,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEnE,0CAA0C,6BAAuC;IACjF,yCAAyC,oDAEvC;IAEF,OAAO,CAAC,aAAa,CAA2B;IAChD,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,QAAQ,CAAmC;IACnD,OAAO,CAAC,SAAS,CAAa;gBAEV,gBAAgB,EAAE,uBAAuB;IAE7D,QAAQ,IAAI,IAAI;IAWhB,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,IAAI;IAInC,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAI/B,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,cAAc,CAAC,EAAE,EAAE,UAAU,GAAG,IAAI;IAYpC,gBAAgB,CAAC,EAAE,EAAE,UAAU,GAAG,IAAI;IAWtC,gBAAgB,CAAC,GAAG,EAAE,WAAW,GAAG,WAAW,EAAE,GAAG,IAAI;IAiBxD,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,MAAM;IAInD,mBAAmB,CAAC,QAAQ,SAAK,GAAG,IAAI;IAKxC,OAAO,CAAC,gBAAgB;IAkCxB,OAAO,CAAC,WAAW;IAQnB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,oBAAoB;yCAlKjB,0BAA0B;2CAA1B,0BAA0B;CAoLtC"}
1
+ {"version":3,"file":"datapoint-selector.component.d.ts","sourceRoot":"","sources":["../../datapoint-selector/datapoint-selector.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,MAAM,EAAE,MAAM,eAAe,CAAC;AACrE,OAAO,EAAE,oBAAoB,EAAqB,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAEvD,OAAO,EAAE,eAAe,EAAuB,UAAU,EAAE,MAAM,MAAM,CAAC;AASxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;;AAG3E,qBAWa,0BAA2B,YAAW,MAAM,EAAE,oBAAoB;IAoCjE,OAAO,CAAC,gBAAgB;IAnC3B,YAAY,EAAE,WAAW,CAAC;IAC1B,oBAAoB,UAAQ;IAC5B,iCAAiC,UAAQ;IAClD,kBAAkB,eAA2B;IACpC,kBAAkB,UAAQ;IAC1B,wBAAwB,UAAS;IACjC,sBAAsB,UAAS;IAC/B,kBAAkB,UAAQ;IAC1B,WAAW,UAAQ;IACnB,aAAa,UAAS;IACtB,aAAa,UAAQ;IAC9B,YAAY,SAAM;IAClB,qBAAqB,SAAM;IAC3B,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,cAAc;;;;MAAkB;IAEhC,iBAAiB,UAAS;IAC1B,cAAc,+BAA0C;IACxD,WAAW,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC;IACtC,mBAAmB,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC;IAC9C,oBAAoB,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;IACzC,uBAAuB,EAAE,UAAU,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEnE,0CAA0C,6BAAuC;IACjF,yCAAyC,oDAEvC;IAEF,OAAO,CAAC,aAAa,CAA2B;IAChD,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,QAAQ,CAAmC;IACnD,OAAO,CAAC,SAAS,CAAa;gBAEV,gBAAgB,EAAE,uBAAuB;IAE7D,QAAQ,IAAI,IAAI;IAoBhB,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,IAAI;IAInC,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAI/B,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,cAAc,CAAC,EAAE,EAAE,UAAU,GAAG,IAAI;IAYpC,gBAAgB,CAAC,EAAE,EAAE,UAAU,GAAG,IAAI;IAWtC,gBAAgB,CAAC,GAAG,EAAE,WAAW,GAAG,WAAW,EAAE,GAAG,IAAI;IAiBxD,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,MAAM;IAInD,mBAAmB,CAAC,QAAQ,SAAK,GAAG,IAAI;IAKxC,OAAO,CAAC,gBAAgB;IAsCxB,OAAO,CAAC,WAAW;IAQnB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,oBAAoB;yCArLjB,0BAA0B;2CAA1B,0BAA0B;CAuMtC"}
@@ -79,7 +79,7 @@ export class DatapointLibraryService {
79
79
  }
80
80
  return datapoints;
81
81
  }
82
- async getDatapointsOfAsset(parentReference, ignoreDatapointTemplates) {
82
+ async getDatapointsOfAsset(parentReference, ignoreDatapointTemplates, datapointTemplatesOnly = false) {
83
83
  const [kpiResponse, details] = await Promise.all([
84
84
  (ignoreDatapointTemplates
85
85
  ? Promise.resolve(null)
@@ -88,7 +88,7 @@ export class DatapointLibraryService {
88
88
  ]);
89
89
  const kpis = kpiResponse && kpiResponse.data ? kpiResponse.data : [];
90
90
  const sortedDetails = sortBy(details, ['fragment', 'series']);
91
- return await this.combineFragmentSeriesTuplesWithDetails(sortedDetails, parentReference, kpis);
91
+ return await this.combineFragmentSeriesTuplesWithDetails(sortedDetails, parentReference, kpis, datapointTemplatesOnly);
92
92
  }
93
93
  /**
94
94
  * Requests the last measurement with the given fragment and series to extract it's unit.
@@ -122,11 +122,15 @@ export class DatapointLibraryService {
122
122
  }
123
123
  return '';
124
124
  }
125
- async combineFragmentSeriesTuplesWithDetails(tuples, target, kpis) {
126
- const datapoints = tuples.map(tuple => {
125
+ async combineFragmentSeriesTuplesWithDetails(tuples, target, kpis, datapointTemplatesOnly = false) {
126
+ const datapoints = tuples
127
+ .map(tuple => {
127
128
  const foundDatapointLibraryEntry = kpis.find(kpi => kpi[DATAPOINT_LIBRARY_FRAGMENT] &&
128
129
  kpi[DATAPOINT_LIBRARY_FRAGMENT].fragment === tuple.fragment &&
129
130
  kpi[DATAPOINT_LIBRARY_FRAGMENT].series === tuple.series);
131
+ if (!foundDatapointLibraryEntry && datapointTemplatesOnly) {
132
+ return null;
133
+ }
130
134
  const datapoint = this.mapDatapointLibraryEntry(foundDatapointLibraryEntry) || tuple;
131
135
  if (!datapoint.label) {
132
136
  datapoint.label = `${datapoint.fragment} → ${datapoint.series}`;
@@ -136,7 +140,8 @@ export class DatapointLibraryService {
136
140
  }
137
141
  datapoint.__target = target;
138
142
  return datapoint;
139
- });
143
+ })
144
+ .filter(Boolean);
140
145
  await this.assignColorToDatapoints(datapoints);
141
146
  return datapoints;
142
147
  }
@@ -211,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
211
216
  type: Injectable,
212
217
  args: [{ providedIn: 'root' }]
213
218
  }], ctorParameters: () => [{ type: i1.InventoryService }, { type: i2.AppStateService }, { type: i1.MeasurementService }, { type: i2.ColorService }] });
214
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoint-library.service.js","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-library.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  IIdentified,\n  IManagedObject,\n  InventoryService,\n  IResultList,\n  MeasurementService\n} from '@c8y/client';\nimport { AppStateService, ColorService, MAX_PAGE_SIZE } from '@c8y/ngx-components';\nimport { get, sortBy, uniq } from 'lodash-es';\nimport { filter } from 'rxjs/operators';\nimport {\n  DATAPOINT_LIBRARY_FRAGMENT,\n  KPIDetails,\n  ManagedObjectKPI\n} from './datapoint-selection.model';\n\n@Injectable({ providedIn: 'root' })\nexport class DatapointLibraryService {\n  protected cache: Promise<ManagedObjectKPI[]>;\n  constructor(\n    private inventory: InventoryService,\n    private appState: AppStateService,\n    private measurements: MeasurementService,\n    private color: ColorService\n  ) {\n    this.appState.currentUser.pipe(filter(user => !user)).subscribe(() => {\n      this.cache = undefined;\n    });\n  }\n\n  async getAllDatapointLibraryEntriesCached(forceCacheRenew = false): Promise<ManagedObjectKPI[]> {\n    if (forceCacheRenew) {\n      this.cache = undefined;\n    }\n    if (!this.cache) {\n      this.cache = this.getAllDatapointLibraryEntries();\n    }\n    return this.cache;\n  }\n\n  async getFirstDatapointLibraryPage(): Promise<IResultList<ManagedObjectKPI>> {\n    const filterObj = {\n      currentPage: 1,\n      pageSize: 50,\n      fragmentType: DATAPOINT_LIBRARY_FRAGMENT,\n      withTotalPages: true\n    };\n    return (await this.inventory.list(filterObj)) as IResultList<ManagedObjectKPI>;\n  }\n\n  async getAllDatapointLibraryItemsCached(): Promise<KPIDetails[]> {\n    if (!this.cache) {\n      this.cache = this.getAllDatapointLibraryEntries();\n    }\n    const res = await this.cache;\n    return res.map(tmp => tmp[DATAPOINT_LIBRARY_FRAGMENT]);\n  }\n\n  async updateDatapoints(\n    datapoints: KPIDetails[],\n    skipUpdatingTarget = false\n  ): Promise<KPIDetails[]> {\n    if (!Array.isArray(datapoints)) {\n      return datapoints;\n    }\n    const currentTargetsPromise: Promise<IManagedObject[]> = !skipUpdatingTarget\n      ? this.getCurrentVersionOfTargetsFromDatapoints(datapoints)\n      : Promise.resolve([]);\n    const [currentTemplates, currentTargets] = await Promise.all([\n      this.getCurrentTemplatesFromDatapoints(datapoints),\n      currentTargetsPromise\n    ]);\n    const currentTemplateVersions = currentTemplates\n      .map(tmp => this.mapDatapointLibraryEntry(tmp as ManagedObjectKPI))\n      .filter(tmp => !!tmp);\n    for (const datapoint of datapoints) {\n      const { fragment, series, __active, __target, color, label, __template } = datapoint;\n      const foundCurrentTemplateVersion = currentTemplateVersions.find(\n        tmp => tmp.__template === datapoint.__template\n      );\n      if (foundCurrentTemplateVersion) {\n        Object.assign(datapoint, foundCurrentTemplateVersion);\n        Object.assign(datapoint, {\n          fragment,\n          series,\n          __active,\n          __target,\n          color,\n          label,\n          __template\n        });\n      }\n\n      const foundCurrentTarget = currentTargets.find(target => target.id === __target?.id);\n      if (foundCurrentTarget) {\n        const { id, name } = foundCurrentTarget;\n        datapoint.__target = { id, name };\n      }\n    }\n    return datapoints;\n  }\n\n  async getDatapointsOfAsset(\n    parentReference: IIdentified,\n    ignoreDatapointTemplates?: boolean\n  ): Promise<KPIDetails[]> {\n    const [kpiResponse, details] = await Promise.all([\n      (ignoreDatapointTemplates\n        ? Promise.resolve(null)\n        : this.inventory.assetKPIsList(parentReference, { pageSize: MAX_PAGE_SIZE })) as Promise<\n        IResultList<ManagedObjectKPI>\n      >,\n      this.inventory.getMeasurementsAndSeries(parentReference)\n    ]);\n    const kpis = kpiResponse && kpiResponse.data ? kpiResponse.data : [];\n    const sortedDetails = sortBy(details, ['fragment', 'series']);\n\n    return await this.combineFragmentSeriesTuplesWithDetails(sortedDetails, parentReference, kpis);\n  }\n\n  /**\n   * Requests the last measurement with the given fragment and series to extract it's unit.\n   * If the source attribute is provided, it will check the last measurement for this specific source.\n   * @returns found unit or an empty string instead\n   */\n  async guessUnitOfDatapoint(\n    fragment: string,\n    series: string,\n    source?: IIdentified\n  ): Promise<string> {\n    const measurementfilter: any = {\n      valueFragmentSeries: series,\n      valueFragmentType: fragment,\n      pageSize: 1,\n      revert: true,\n      dateFrom: '1970-01-01'\n    };\n    if (source?.id) {\n      measurementfilter.source = source?.id;\n    }\n    try {\n      const { data: lastMeasurements } = await this.measurements.list(measurementfilter);\n      const measurement = lastMeasurements[0];\n      if (measurement) {\n        const pathToUnit = `${fragment}.${series}.unit`;\n        const unit = get(measurement, pathToUnit);\n        if (unit?.length && typeof unit === 'string') {\n          return unit;\n        }\n      }\n    } catch {\n      // nothing to do\n    }\n    return '';\n  }\n\n  protected async combineFragmentSeriesTuplesWithDetails(\n    tuples: Array<{ fragment: string; series: string }>,\n    target: IIdentified,\n    kpis: ManagedObjectKPI[]\n  ) {\n    const datapoints = tuples.map(tuple => {\n      const foundDatapointLibraryEntry = kpis.find(\n        kpi =>\n          kpi[DATAPOINT_LIBRARY_FRAGMENT] &&\n          kpi[DATAPOINT_LIBRARY_FRAGMENT].fragment === tuple.fragment &&\n          kpi[DATAPOINT_LIBRARY_FRAGMENT].series === tuple.series\n      );\n      const datapoint: KPIDetails =\n        this.mapDatapointLibraryEntry(foundDatapointLibraryEntry) || tuple;\n      if (!datapoint.label) {\n        datapoint.label = `${datapoint.fragment} → ${datapoint.series}`;\n      }\n      if (!datapoint.unit?.length) {\n        datapoint.unit = '';\n      }\n      datapoint.__target = target;\n      return datapoint;\n    });\n    await this.assignColorToDatapoints(datapoints);\n    return datapoints;\n  }\n\n  protected async assignColorToDatapoints(datapoints: KPIDetails[]): Promise<void> {\n    const datapointsWithoutColor = datapoints.filter(datapoint => !datapoint.color);\n    await Promise.all(\n      datapointsWithoutColor.map(datapoint =>\n        this.color\n          .generateColorForDatapoint(datapoint.fragment, datapoint.series)\n          .then(color => (datapoint.color = color))\n      )\n    );\n  }\n\n  protected async getAllDatapointLibraryEntries(): Promise<ManagedObjectKPI[]> {\n    const entries = new Array<ManagedObjectKPI>();\n    const filterObj = {\n      currentPage: 1,\n      pageSize: MAX_PAGE_SIZE,\n      fragmentType: DATAPOINT_LIBRARY_FRAGMENT\n    };\n    let res = await this.inventory.list(filterObj);\n    while (res.data.length) {\n      entries.push(...(res.data as ManagedObjectKPI[]));\n      if (res.data.length < res.paging.pageSize) {\n        break;\n      }\n      if (!res.paging.nextPage) {\n        break;\n      }\n\n      res = await res.paging.next();\n    }\n    return entries;\n  }\n\n  protected mapDatapointLibraryEntry(entry: ManagedObjectKPI): KPIDetails {\n    if (!entry || !entry[DATAPOINT_LIBRARY_FRAGMENT]) {\n      return null;\n    }\n\n    const datapoint = entry[DATAPOINT_LIBRARY_FRAGMENT];\n    datapoint.__template = entry.id;\n    return datapoint;\n  }\n\n  protected async getCurrentTemplatesFromDatapoints(\n    datapoints: KPIDetails[]\n  ): Promise<IManagedObject[]> {\n    const datapointsWithTemplateId = datapoints.filter(dp => !!dp.__template);\n    const usedTemplateIds = datapointsWithTemplateId.map(dp => dp.__template);\n    return await this.getMOsByIds(usedTemplateIds);\n  }\n\n  protected async getCurrentVersionOfTargetsFromDatapoints(\n    datapoints: KPIDetails[]\n  ): Promise<IManagedObject[]> {\n    const datapointsWithTarget = datapoints.filter(dp => !!dp.__target?.id);\n    const usedTargetIds = datapointsWithTarget.map(dp => dp.__target.id);\n    return await this.getMOsByIds(usedTargetIds);\n  }\n\n  protected async getMOsByIds(ids: Array<string | number>): Promise<IManagedObject[]> {\n    const uniqManagedObjectIds = uniq(ids);\n    if (!uniqManagedObjectIds.length) {\n      return [];\n    }\n    try {\n      const { data: managedObjects } = await this.inventory.list({\n        ids: uniqManagedObjectIds.join(),\n        pageSize: MAX_PAGE_SIZE\n      });\n      return managedObjects;\n    } catch {\n      // Fail silently in case we are not able to talk to the inventory API.\n      // Should only be reached in case of an server side error.\n      // instead of failing, pretend like we didn't receive any items.\n      console.warn(\n        `Failed to get the current version of the following managedObjects: ${uniqManagedObjectIds.join()}.`\n      );\n      return [];\n    }\n  }\n}\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoint-library.service.js","sourceRoot":"","sources":["../../../datapoint-selector/datapoint-library.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAGL,gBAAgB,EAEhB,kBAAkB,EACnB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACnF,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxC,OAAO,EACL,0BAA0B,EAG3B,MAAM,6BAA6B,CAAC;;;;AAGrC,MAAM,OAAO,uBAAuB;IAElC,YACU,SAA2B,EAC3B,QAAyB,EACzB,YAAgC,EAChC,KAAmB;QAHnB,cAAS,GAAT,SAAS,CAAkB;QAC3B,aAAQ,GAAR,QAAQ,CAAiB;QACzB,iBAAY,GAAZ,YAAY,CAAoB;QAChC,UAAK,GAAL,KAAK,CAAc;QAE3B,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACnE,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,mCAAmC,CAAC,eAAe,GAAG,KAAK;QAC/D,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,6BAA6B,EAAE,CAAC;QACpD,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,4BAA4B;QAChC,MAAM,SAAS,GAAG;YAChB,WAAW,EAAE,CAAC;YACd,QAAQ,EAAE,EAAE;YACZ,YAAY,EAAE,0BAA0B;YACxC,cAAc,EAAE,IAAI;SACrB,CAAC;QACF,OAAO,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAkC,CAAC;IACjF,CAAC;IAED,KAAK,CAAC,iCAAiC;QACrC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,6BAA6B,EAAE,CAAC;QACpD,CAAC;QACD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC;QAC7B,OAAO,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,KAAK,CAAC,gBAAgB,CACpB,UAAwB,EACxB,kBAAkB,GAAG,KAAK;QAE1B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;YAC/B,OAAO,UAAU,CAAC;QACpB,CAAC;QACD,MAAM,qBAAqB,GAA8B,CAAC,kBAAkB;YAC1E,CAAC,CAAC,IAAI,CAAC,wCAAwC,CAAC,UAAU,CAAC;YAC3D,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,gBAAgB,EAAE,cAAc,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC3D,IAAI,CAAC,iCAAiC,CAAC,UAAU,CAAC;YAClD,qBAAqB;SACtB,CAAC,CAAC;QACH,MAAM,uBAAuB,GAAG,gBAAgB;aAC7C,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,wBAAwB,CAAC,GAAuB,CAAC,CAAC;aAClE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACxB,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;YACnC,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,SAAS,CAAC;YACrF,MAAM,2BAA2B,GAAG,uBAAuB,CAAC,IAAI,CAC9D,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,KAAK,SAAS,CAAC,UAAU,CAC/C,CAAC;YACF,IAAI,2BAA2B,EAAE,CAAC;gBAChC,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,2BAA2B,CAAC,CAAC;gBACtD,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE;oBACvB,QAAQ;oBACR,MAAM;oBACN,QAAQ;oBACR,QAAQ;oBACR,KAAK;oBACL,KAAK;oBACL,UAAU;iBACX,CAAC,CAAC;YACL,CAAC;YAED,MAAM,kBAAkB,GAAG,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,QAAQ,EAAE,EAAE,CAAC,CAAC;YACrF,IAAI,kBAAkB,EAAE,CAAC;gBACvB,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,kBAAkB,CAAC;gBACxC,SAAS,CAAC,QAAQ,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC;YACpC,CAAC;QACH,CAAC;QACD,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,oBAAoB,CACxB,eAA4B,EAC5B,wBAAkC,EAClC,sBAAsB,GAAG,KAAK;QAE9B,MAAM,CAAC,WAAW,EAAE,OAAO,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC/C,CAAC,wBAAwB;gBACvB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC;gBACvB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,eAAe,EAAE,EAAE,QAAQ,EAAE,aAAa,EAAE,CAAC,CAE7E;YACD,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,eAAe,CAAC;SACzD,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,WAAW,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QACrE,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;QAE9D,OAAO,MAAM,IAAI,CAAC,sCAAsC,CACtD,aAAa,EACb,eAAe,EACf,IAAI,EACJ,sBAAsB,CACvB,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,oBAAoB,CACxB,QAAgB,EAChB,MAAc,EACd,MAAoB;QAEpB,MAAM,iBAAiB,GAAQ;YAC7B,mBAAmB,EAAE,MAAM;YAC3B,iBAAiB,EAAE,QAAQ;YAC3B,QAAQ,EAAE,CAAC;YACX,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,YAAY;SACvB,CAAC;QACF,IAAI,MAAM,EAAE,EAAE,EAAE,CAAC;YACf,iBAAiB,CAAC,MAAM,GAAG,MAAM,EAAE,EAAE,CAAC;QACxC,CAAC;QACD,IAAI,CAAC;YACH,MAAM,EAAE,IAAI,EAAE,gBAAgB,EAAE,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YACnF,MAAM,WAAW,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC;YACxC,IAAI,WAAW,EAAE,CAAC;gBAChB,MAAM,UAAU,GAAG,GAAG,QAAQ,IAAI,MAAM,OAAO,CAAC;gBAChD,MAAM,IAAI,GAAG,GAAG,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;gBAC1C,IAAI,IAAI,EAAE,MAAM,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;oBAC7C,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,gBAAgB;QAClB,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAES,KAAK,CAAC,sCAAsC,CACpD,MAAmD,EACnD,MAAmB,EACnB,IAAwB,EACxB,sBAAsB,GAAG,KAAK;QAE9B,MAAM,UAAU,GAAG,MAAM;aACtB,GAAG,CAAC,KAAK,CAAC,EAAE;YACX,MAAM,0BAA0B,GAAG,IAAI,CAAC,IAAI,CAC1C,GAAG,CAAC,EAAE,CACJ,GAAG,CAAC,0BAA0B,CAAC;gBAC/B,GAAG,CAAC,0BAA0B,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ;gBAC3D,GAAG,CAAC,0BAA0B,CAAC,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,CAC1D,CAAC;YACF,IAAI,CAAC,0BAA0B,IAAI,sBAAsB,EAAE,CAAC;gBAC1D,OAAO,IAAI,CAAC;YACd,CAAC;YACD,MAAM,SAAS,GACb,IAAI,CAAC,wBAAwB,CAAC,0BAA0B,CAAC,IAAI,KAAK,CAAC;YACrE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;gBACrB,SAAS,CAAC,KAAK,GAAG,GAAG,SAAS,CAAC,QAAQ,MAAM,SAAS,CAAC,MAAM,EAAE,CAAC;YAClE,CAAC;YACD,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC;gBAC5B,SAAS,CAAC,IAAI,GAAG,EAAE,CAAC;YACtB,CAAC;YACD,SAAS,CAAC,QAAQ,GAAG,MAAM,CAAC;YAC5B,OAAO,SAAS,CAAC;QACnB,CAAC,CAAC;aACD,MAAM,CAAC,OAAO,CAAC,CAAC;QACnB,MAAM,IAAI,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;QAC/C,OAAO,UAAU,CAAC;IACpB,CAAC;IAES,KAAK,CAAC,uBAAuB,CAAC,UAAwB;QAC9D,MAAM,sBAAsB,GAAG,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAChF,MAAM,OAAO,CAAC,GAAG,CACf,sBAAsB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CACrC,IAAI,CAAC,KAAK;aACP,yBAAyB,CAAC,SAAS,CAAC,QAAQ,EAAE,SAAS,CAAC,MAAM,CAAC;aAC/D,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAC5C,CACF,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,6BAA6B;QAC3C,MAAM,OAAO,GAAG,IAAI,KAAK,EAAoB,CAAC;QAC9C,MAAM,SAAS,GAAG;YAChB,WAAW,EAAE,CAAC;YACd,QAAQ,EAAE,aAAa;YACvB,YAAY,EAAE,0BAA0B;SACzC,CAAC;QACF,IAAI,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/C,OAAO,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACvB,OAAO,CAAC,IAAI,CAAC,GAAI,GAAG,CAAC,IAA2B,CAAC,CAAC;YAClD,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAC1C,MAAM;YACR,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACzB,MAAM;YACR,CAAC;YAED,GAAG,GAAG,MAAM,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QAChC,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAES,wBAAwB,CAAC,KAAuB;QACxD,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,0BAA0B,CAAC,EAAE,CAAC;YACjD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,SAAS,GAAG,KAAK,CAAC,0BAA0B,CAAC,CAAC;QACpD,SAAS,CAAC,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC;QAChC,OAAO,SAAS,CAAC;IACnB,CAAC;IAES,KAAK,CAAC,iCAAiC,CAC/C,UAAwB;QAExB,MAAM,wBAAwB,GAAG,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC;QAC1E,MAAM,eAAe,GAAG,wBAAwB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC;QAC1E,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IACjD,CAAC;IAES,KAAK,CAAC,wCAAwC,CACtD,UAAwB;QAExB,MAAM,oBAAoB,GAAG,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACxE,MAAM,aAAa,GAAG,oBAAoB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACrE,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;IAC/C,CAAC;IAES,KAAK,CAAC,WAAW,CAAC,GAA2B;QACrD,MAAM,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;QACvC,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;YACjC,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,IAAI,CAAC;YACH,MAAM,EAAE,IAAI,EAAE,cAAc,EAAE,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;gBACzD,GAAG,EAAE,oBAAoB,CAAC,IAAI,EAAE;gBAChC,QAAQ,EAAE,aAAa;aACxB,CAAC,CAAC;YACH,OAAO,cAAc,CAAC;QACxB,CAAC;QAAC,MAAM,CAAC;YACP,sEAAsE;YACtE,0DAA0D;YAC1D,gEAAgE;YAChE,OAAO,CAAC,IAAI,CACV,sEAAsE,oBAAoB,CAAC,IAAI,EAAE,GAAG,CACrG,CAAC;YACF,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;8GAjQU,uBAAuB;kHAAvB,uBAAuB,cADV,MAAM;;2FACnB,uBAAuB;kBADnC,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  IIdentified,\n  IManagedObject,\n  InventoryService,\n  IResultList,\n  MeasurementService\n} from '@c8y/client';\nimport { AppStateService, ColorService, MAX_PAGE_SIZE } from '@c8y/ngx-components';\nimport { get, sortBy, uniq } from 'lodash-es';\nimport { filter } from 'rxjs/operators';\nimport {\n  DATAPOINT_LIBRARY_FRAGMENT,\n  KPIDetails,\n  ManagedObjectKPI\n} from './datapoint-selection.model';\n\n@Injectable({ providedIn: 'root' })\nexport class DatapointLibraryService {\n  protected cache: Promise<ManagedObjectKPI[]>;\n  constructor(\n    private inventory: InventoryService,\n    private appState: AppStateService,\n    private measurements: MeasurementService,\n    private color: ColorService\n  ) {\n    this.appState.currentUser.pipe(filter(user => !user)).subscribe(() => {\n      this.cache = undefined;\n    });\n  }\n\n  async getAllDatapointLibraryEntriesCached(forceCacheRenew = false): Promise<ManagedObjectKPI[]> {\n    if (forceCacheRenew) {\n      this.cache = undefined;\n    }\n    if (!this.cache) {\n      this.cache = this.getAllDatapointLibraryEntries();\n    }\n    return this.cache;\n  }\n\n  async getFirstDatapointLibraryPage(): Promise<IResultList<ManagedObjectKPI>> {\n    const filterObj = {\n      currentPage: 1,\n      pageSize: 50,\n      fragmentType: DATAPOINT_LIBRARY_FRAGMENT,\n      withTotalPages: true\n    };\n    return (await this.inventory.list(filterObj)) as IResultList<ManagedObjectKPI>;\n  }\n\n  async getAllDatapointLibraryItemsCached(): Promise<KPIDetails[]> {\n    if (!this.cache) {\n      this.cache = this.getAllDatapointLibraryEntries();\n    }\n    const res = await this.cache;\n    return res.map(tmp => tmp[DATAPOINT_LIBRARY_FRAGMENT]);\n  }\n\n  async updateDatapoints(\n    datapoints: KPIDetails[],\n    skipUpdatingTarget = false\n  ): Promise<KPIDetails[]> {\n    if (!Array.isArray(datapoints)) {\n      return datapoints;\n    }\n    const currentTargetsPromise: Promise<IManagedObject[]> = !skipUpdatingTarget\n      ? this.getCurrentVersionOfTargetsFromDatapoints(datapoints)\n      : Promise.resolve([]);\n    const [currentTemplates, currentTargets] = await Promise.all([\n      this.getCurrentTemplatesFromDatapoints(datapoints),\n      currentTargetsPromise\n    ]);\n    const currentTemplateVersions = currentTemplates\n      .map(tmp => this.mapDatapointLibraryEntry(tmp as ManagedObjectKPI))\n      .filter(tmp => !!tmp);\n    for (const datapoint of datapoints) {\n      const { fragment, series, __active, __target, color, label, __template } = datapoint;\n      const foundCurrentTemplateVersion = currentTemplateVersions.find(\n        tmp => tmp.__template === datapoint.__template\n      );\n      if (foundCurrentTemplateVersion) {\n        Object.assign(datapoint, foundCurrentTemplateVersion);\n        Object.assign(datapoint, {\n          fragment,\n          series,\n          __active,\n          __target,\n          color,\n          label,\n          __template\n        });\n      }\n\n      const foundCurrentTarget = currentTargets.find(target => target.id === __target?.id);\n      if (foundCurrentTarget) {\n        const { id, name } = foundCurrentTarget;\n        datapoint.__target = { id, name };\n      }\n    }\n    return datapoints;\n  }\n\n  async getDatapointsOfAsset(\n    parentReference: IIdentified,\n    ignoreDatapointTemplates?: boolean,\n    datapointTemplatesOnly = false\n  ): Promise<KPIDetails[]> {\n    const [kpiResponse, details] = await Promise.all([\n      (ignoreDatapointTemplates\n        ? Promise.resolve(null)\n        : this.inventory.assetKPIsList(parentReference, { pageSize: MAX_PAGE_SIZE })) as Promise<\n        IResultList<ManagedObjectKPI>\n      >,\n      this.inventory.getMeasurementsAndSeries(parentReference)\n    ]);\n    const kpis = kpiResponse && kpiResponse.data ? kpiResponse.data : [];\n    const sortedDetails = sortBy(details, ['fragment', 'series']);\n\n    return await this.combineFragmentSeriesTuplesWithDetails(\n      sortedDetails,\n      parentReference,\n      kpis,\n      datapointTemplatesOnly\n    );\n  }\n\n  /**\n   * Requests the last measurement with the given fragment and series to extract it's unit.\n   * If the source attribute is provided, it will check the last measurement for this specific source.\n   * @returns found unit or an empty string instead\n   */\n  async guessUnitOfDatapoint(\n    fragment: string,\n    series: string,\n    source?: IIdentified\n  ): Promise<string> {\n    const measurementfilter: any = {\n      valueFragmentSeries: series,\n      valueFragmentType: fragment,\n      pageSize: 1,\n      revert: true,\n      dateFrom: '1970-01-01'\n    };\n    if (source?.id) {\n      measurementfilter.source = source?.id;\n    }\n    try {\n      const { data: lastMeasurements } = await this.measurements.list(measurementfilter);\n      const measurement = lastMeasurements[0];\n      if (measurement) {\n        const pathToUnit = `${fragment}.${series}.unit`;\n        const unit = get(measurement, pathToUnit);\n        if (unit?.length && typeof unit === 'string') {\n          return unit;\n        }\n      }\n    } catch {\n      // nothing to do\n    }\n    return '';\n  }\n\n  protected async combineFragmentSeriesTuplesWithDetails(\n    tuples: Array<{ fragment: string; series: string }>,\n    target: IIdentified,\n    kpis: ManagedObjectKPI[],\n    datapointTemplatesOnly = false\n  ) {\n    const datapoints = tuples\n      .map(tuple => {\n        const foundDatapointLibraryEntry = kpis.find(\n          kpi =>\n            kpi[DATAPOINT_LIBRARY_FRAGMENT] &&\n            kpi[DATAPOINT_LIBRARY_FRAGMENT].fragment === tuple.fragment &&\n            kpi[DATAPOINT_LIBRARY_FRAGMENT].series === tuple.series\n        );\n        if (!foundDatapointLibraryEntry && datapointTemplatesOnly) {\n          return null;\n        }\n        const datapoint: KPIDetails =\n          this.mapDatapointLibraryEntry(foundDatapointLibraryEntry) || tuple;\n        if (!datapoint.label) {\n          datapoint.label = `${datapoint.fragment} → ${datapoint.series}`;\n        }\n        if (!datapoint.unit?.length) {\n          datapoint.unit = '';\n        }\n        datapoint.__target = target;\n        return datapoint;\n      })\n      .filter(Boolean);\n    await this.assignColorToDatapoints(datapoints);\n    return datapoints;\n  }\n\n  protected async assignColorToDatapoints(datapoints: KPIDetails[]): Promise<void> {\n    const datapointsWithoutColor = datapoints.filter(datapoint => !datapoint.color);\n    await Promise.all(\n      datapointsWithoutColor.map(datapoint =>\n        this.color\n          .generateColorForDatapoint(datapoint.fragment, datapoint.series)\n          .then(color => (datapoint.color = color))\n      )\n    );\n  }\n\n  protected async getAllDatapointLibraryEntries(): Promise<ManagedObjectKPI[]> {\n    const entries = new Array<ManagedObjectKPI>();\n    const filterObj = {\n      currentPage: 1,\n      pageSize: MAX_PAGE_SIZE,\n      fragmentType: DATAPOINT_LIBRARY_FRAGMENT\n    };\n    let res = await this.inventory.list(filterObj);\n    while (res.data.length) {\n      entries.push(...(res.data as ManagedObjectKPI[]));\n      if (res.data.length < res.paging.pageSize) {\n        break;\n      }\n      if (!res.paging.nextPage) {\n        break;\n      }\n\n      res = await res.paging.next();\n    }\n    return entries;\n  }\n\n  protected mapDatapointLibraryEntry(entry: ManagedObjectKPI): KPIDetails {\n    if (!entry || !entry[DATAPOINT_LIBRARY_FRAGMENT]) {\n      return null;\n    }\n\n    const datapoint = entry[DATAPOINT_LIBRARY_FRAGMENT];\n    datapoint.__template = entry.id;\n    return datapoint;\n  }\n\n  protected async getCurrentTemplatesFromDatapoints(\n    datapoints: KPIDetails[]\n  ): Promise<IManagedObject[]> {\n    const datapointsWithTemplateId = datapoints.filter(dp => !!dp.__template);\n    const usedTemplateIds = datapointsWithTemplateId.map(dp => dp.__template);\n    return await this.getMOsByIds(usedTemplateIds);\n  }\n\n  protected async getCurrentVersionOfTargetsFromDatapoints(\n    datapoints: KPIDetails[]\n  ): Promise<IManagedObject[]> {\n    const datapointsWithTarget = datapoints.filter(dp => !!dp.__target?.id);\n    const usedTargetIds = datapointsWithTarget.map(dp => dp.__target.id);\n    return await this.getMOsByIds(usedTargetIds);\n  }\n\n  protected async getMOsByIds(ids: Array<string | number>): Promise<IManagedObject[]> {\n    const uniqManagedObjectIds = uniq(ids);\n    if (!uniqManagedObjectIds.length) {\n      return [];\n    }\n    try {\n      const { data: managedObjects } = await this.inventory.list({\n        ids: uniqManagedObjectIds.join(),\n        pageSize: MAX_PAGE_SIZE\n      });\n      return managedObjects;\n    } catch {\n      // Fail silently in case we are not able to talk to the inventory API.\n      // Should only be reached in case of an server side error.\n      // instead of failing, pretend like we didn't receive any items.\n      console.warn(\n        `Failed to get the current version of the following managedObjects: ${uniqManagedObjectIds.join()}.`\n      );\n      return [];\n    }\n  }\n}\n"]}
@@ -7,6 +7,7 @@ import { from, Observable } from 'rxjs';
7
7
  import { map, shareReplay, take, tap } from 'rxjs/operators';
8
8
  import { DatapointLibraryService } from '../datapoint-library.service';
9
9
  import { DatapointSelectorService } from '../datapoint-selector.service';
10
+ import { AddButtonTypes } from '../datapoint-selector-list-item/datapoint-selector-list-item.component';
10
11
  import * as i0 from "@angular/core";
11
12
  import * as i1 from "../datapoint-selector.service";
12
13
  import * as i2 from "../datapoint-library.service";
@@ -30,6 +31,7 @@ export class DatapointSelectionListComponent {
30
31
  this.resolveContext = true;
31
32
  this.listTitle = '';
32
33
  this.maxActiveCountReached = false;
34
+ this.AddButtonTypes = AddButtonTypes;
33
35
  this.usedValidators = {};
34
36
  this.formArray = this.formBuilder.array([]);
35
37
  this.isValid = this.formArray.statusChanges.pipe(map(status => status === 'VALID'));
@@ -131,7 +133,7 @@ export class DatapointSelectionListComponent {
131
133
  useExisting: forwardRef(() => DatapointSelectionListComponent),
132
134
  multi: true
133
135
  }
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" }] }); }
136
+ ], 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 [addButtonType]=\"AddButtonTypes.none\"\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", "addButtonType", "editable", "showActiveToggle", "activeToggleDisabled", "showOptions", "datapointLibraryEntries", "actions", "optionToRemove", "hasUnlinkTemplateOption", "colorPickerDisabled", "disableTypeaheadIfSelected", "highlightText"], outputs: ["added", "removed"] }, { kind: "pipe", type: i5.C8yTranslatePipe, name: "translate" }] }); }
135
137
  }
136
138
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointSelectionListComponent, decorators: [{
137
139
  type: Component,
@@ -146,7 +148,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
146
148
  useExisting: forwardRef(() => DatapointSelectionListComponent),
147
149
  multi: true
148
150
  }
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" }]
151
+ ], 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 [addButtonType]=\"AddButtonTypes.none\"\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
152
  }], ctorParameters: () => [{ type: i1.DatapointSelectorService }, { type: i2.DatapointLibraryService }, { type: i3.FormBuilder }, { type: i4.WidgetConfigComponent, decorators: [{
151
153
  type: Optional
152
154
  }] }], propDecorators: { actions: [{
@@ -170,4 +172,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
170
172
  }], change: [{
171
173
  type: Output
172
174
  }] } });
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"]}
175
+ //# 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';\nimport { AddButtonTypes } from '../datapoint-selector-list-item/datapoint-selector-list-item.component';\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  AddButtonTypes = AddButtonTypes;\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      [addButtonType]=\"AddButtonTypes.none\"\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"]}