@c8y/ngx-components 1021.54.6 → 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.
- package/context-dashboard/context-dashboard.component.d.ts.map +1 -1
- package/context-dashboard/context-dashboard.model.d.ts +1 -0
- package/context-dashboard/context-dashboard.model.d.ts.map +1 -1
- package/context-dashboard/context-dashboard.service.d.ts +1 -0
- package/context-dashboard/context-dashboard.service.d.ts.map +1 -1
- package/datapoint-selector/datapoint-library.service.d.ts +2 -2
- package/datapoint-selector/datapoint-library.service.d.ts.map +1 -1
- package/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.d.ts +5 -0
- package/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.d.ts.map +1 -1
- package/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.d.ts +13 -2
- package/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.d.ts.map +1 -1
- package/datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.d.ts +2 -0
- package/datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.d.ts.map +1 -1
- package/datapoint-selector/datapoint-selector.component.d.ts +11 -1
- package/datapoint-selector/datapoint-selector.component.d.ts.map +1 -1
- package/esm2022/context-dashboard/context-dashboard.component.mjs +15 -33
- package/esm2022/context-dashboard/context-dashboard.model.mjs +1 -1
- package/esm2022/context-dashboard/context-dashboard.service.mjs +31 -21
- package/esm2022/datapoint-selector/datapoint-library.service.mjs +11 -6
- package/esm2022/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.mjs +5 -3
- package/esm2022/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.mjs +12 -6
- package/esm2022/datapoint-selector/datapoint-selector-modal/datapoint-selector-modal.component.mjs +5 -3
- package/esm2022/datapoint-selector/datapoint-selector.component.mjs +22 -5
- package/esm2022/upgrade/ng1/downgraded.services.mjs +3 -1
- package/esm2022/upgrade/ng1/index.mjs +4 -3
- package/fesm2022/c8y-ngx-components-context-dashboard.mjs +44 -52
- package/fesm2022/c8y-ngx-components-context-dashboard.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs +49 -19
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-upgrade.mjs +4 -2
- package/fesm2022/c8y-ngx-components-upgrade.mjs.map +1 -1
- package/locales/de.po +128 -122
- package/locales/es.po +6 -0
- package/locales/fr.po +149 -141
- package/locales/ja_JP.po +296 -215
- package/locales/ko.po +6 -0
- package/locales/locales.pot +18 -3
- package/locales/nl.po +6 -0
- package/locales/pl.po +6 -0
- package/locales/pt_BR.po +6 -0
- package/locales/zh_CN.po +6 -0
- package/locales/zh_TW.po +6 -0
- package/package.json +1 -1
- package/upgrade/ng1/downgraded.services.d.ts +1 -0
- package/upgrade/ng1/downgraded.services.d.ts.map +1 -1
- package/upgrade/ng1/index.d.ts.map +1 -1
|
@@ -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
|
|
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":"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;QAElC,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,CAAC,aAAa,EAAE,eAAe,EAAE,IAAI,CAAC,CAAC;IACjG,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;QAExB,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;YACpC,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,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,CAAC;QACH,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;8GArPU,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  ): 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":"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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    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"]}
|
package/esm2022/datapoint-selector/datapoint-selection-list/datapoint-selection-list.component.mjs
CHANGED
|
@@ -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 [
|
|
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 [
|
|
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"]}
|