@eo-sdk/client 11.7.0-beta.1 → 11.7.0-beta.2
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/app/eo-framework/actions/actions/workflow-action/simple-workflow-action.component.d.ts.map +1 -1
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +1 -1
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/organization/organization.component.d.ts +1 -0
- package/app/eo-framework/form-elements/organization/organization.component.d.ts.map +1 -1
- package/app/eo-framework/grid/grid.component.d.ts +7 -0
- package/app/eo-framework/grid/grid.component.d.ts.map +1 -1
- package/app/eo-framework/object-details/object-details.component.d.ts +1 -0
- package/app/eo-framework/object-details/object-details.component.d.ts.map +1 -1
- package/app/eo-framework/object-details/object-history/object-history.component.d.ts +3 -2
- package/app/eo-framework/object-details/object-history/object-history.component.d.ts.map +1 -1
- package/app/eo-framework/result-list/result-list.component.d.ts.map +1 -1
- package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts +50 -0
- package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts.map +1 -1
- package/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.d.ts +10 -0
- package/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.d.ts.map +1 -0
- package/app/eo-framework-core/search/app-search.service.d.ts +12 -1
- package/app/eo-framework-core/search/app-search.service.d.ts.map +1 -1
- package/assets/_default/i18n/de.json +5 -3
- package/assets/_default/i18n/en.json +1132 -1130
- package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
- package/esm2022/app/eo-framework/actions/actions/workflow-action/simple-workflow-action.component.mjs +2 -2
- package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +18 -4
- package/esm2022/app/eo-framework/form-elements/organization/organization.component.mjs +25 -16
- package/esm2022/app/eo-framework/grid/extensions/filter/text/text-filter.component.mjs +3 -3
- package/esm2022/app/eo-framework/grid/grid.component.mjs +32 -6
- package/esm2022/app/eo-framework/object-details/object-details.component.mjs +8 -6
- package/esm2022/app/eo-framework/object-details/object-history/object-history.component.mjs +11 -6
- package/esm2022/app/eo-framework/result-list/result-list.component.mjs +7 -2
- package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary-entry/indexdata-summary-entry.component.mjs +2 -2
- package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.mjs +138 -5
- package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.mjs +2 -0
- package/esm2022/app/eo-framework-core/search/app-search.service.mjs +25 -4
- package/fesm2022/eo-sdk-client.mjs +264 -725
- package/fesm2022/eo-sdk-client.mjs.map +1 -1
- package/misc/scripts/copy-client-assets.js +1 -1
- package/package.json +3 -3
- package/proxy.config.js +13 -0
- package/app/eo-framework/grid/row-grouping/batchRemover.d.ts +0 -13
- package/app/eo-framework/grid/row-grouping/batchRemover.d.ts.map +0 -1
- package/app/eo-framework/grid/row-grouping/group-stage.d.ts +0 -45
- package/app/eo-framework/grid/row-grouping/group-stage.d.ts.map +0 -1
- package/app/eo-framework/grid/row-grouping/row-grouping.module.d.ts +0 -8
- package/app/eo-framework/grid/row-grouping/row-grouping.module.d.ts.map +0 -1
- package/esm2022/app/eo-framework/grid/row-grouping/batchRemover.mjs +0 -50
- package/esm2022/app/eo-framework/grid/row-grouping/group-stage.mjs +0 -623
- package/esm2022/app/eo-framework/grid/row-grouping/row-grouping.module.mjs +0 -8
- package/proxy.config.json +0 -97
|
@@ -97,32 +97,41 @@ export class OrganizationComponent {
|
|
|
97
97
|
this.onDataMetaChanged.emit(this.innerValue);
|
|
98
98
|
}
|
|
99
99
|
autocompleteFn(term) {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
100
|
+
clearTimeout(this.autocompleteTimeout);
|
|
101
|
+
this.autocompleteTimeout = setTimeout(() => {
|
|
102
|
+
if (term.length >= this.minLength || term === this.wildCard) {
|
|
103
|
+
if (this.multiselect || (!this.multiselect && this.innerValue.length === 0)) {
|
|
104
|
+
this.backend.getJson(this.buildAutocompleteUri(term))
|
|
105
|
+
.subscribe((res) => {
|
|
106
|
+
// autocomplete values should be unique and not part of the exceptions
|
|
107
|
+
this.autocompleteRes = res.filter(v => (!this.value || this.value.indexOf(v.name) === -1) && this.exceptions.indexOf(v.name) === -1 && (!this.removeCurrentUser || this.currentUserId !== v.id))
|
|
108
|
+
.sort(Utils.sortValues('title')).slice(0, 10);
|
|
109
|
+
}, Utils.throw(null, this.translate.instant('eo.form.property.organization.request.error.title'), this.translate.instant('eo.form.property.organization.request.error.msg')));
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
this.autocompleteRes = [];
|
|
113
|
+
}
|
|
108
114
|
}
|
|
109
115
|
else {
|
|
110
116
|
this.autocompleteRes = [];
|
|
111
117
|
}
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
this.autocompleteRes = [];
|
|
115
|
-
}
|
|
118
|
+
}, 1000);
|
|
116
119
|
}
|
|
117
120
|
resolveFn(value) {
|
|
118
121
|
let map = (value instanceof Array ? value : [value]).map(v => {
|
|
119
122
|
let match = this.innerValue.find(iv => iv.name === v);
|
|
120
123
|
return match ? observableOf(match) : this.systemService.getOrganizationObject(v);
|
|
121
124
|
});
|
|
122
|
-
|
|
123
|
-
this.innerValue =
|
|
125
|
+
if (map.length === 0) {
|
|
126
|
+
this.innerValue = [];
|
|
124
127
|
this.onValueResolved.emit(this.innerValue);
|
|
125
|
-
}
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
return observableForkJoin(map).subscribe(data => {
|
|
131
|
+
this.innerValue = data;
|
|
132
|
+
this.onValueResolved.emit(this.innerValue);
|
|
133
|
+
});
|
|
134
|
+
}
|
|
126
135
|
}
|
|
127
136
|
// handle selection changes to the model
|
|
128
137
|
onUnselect(value) {
|
|
@@ -213,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImpor
|
|
|
213
222
|
}], filterObject: [{
|
|
214
223
|
type: Input
|
|
215
224
|
}] } });
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"organization.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/form-elements/organization/organization.component.ts","../../../../../../../../src/app/eo-framework/form-elements/organization/organization.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EACL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAuB,aAAa,EAAE,iBAAiB,EAAY,MAAM,gBAAgB,CAAC;AACjG,OAAO,EAA+D,KAAK,EAAC,MAAM,cAAc,CAAC;AAEjG,OAAO,EAAC,QAAQ,IAAI,kBAAkB,EAAE,EAAE,IAAI,YAAY,EAAe,MAAM,MAAM,CAAC;;;;;;;;AA0BtF,MAAM,OAAO,qBAAqB;IA6BhC,IAAa,iBAAiB,CAAC,CAAU;QACvC,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7E,CAAC;IACD,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAA;IAChC,CAAC;IAGD,IAAa,QAAQ,CAAC,CAAU;QAC9B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAa,QAAQ,CAAC,EAAO;QAC3B,IAAI,EAAE,EAAE,CAAC;YACP,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAClD,CAAC;IACH,CAAC;IAMD,YAAoB,OAAuB,EACjC,SAA2B,EAC3B,aAA4B,EAC7B,WAAwB;QAHb,YAAO,GAAP,OAAO,CAAgB;QACjC,cAAS,GAAT,SAAS,CAAkB;QAC3B,kBAAa,GAAb,aAAa,CAAe;QAC7B,gBAAW,GAAX,WAAW,CAAa;QArDjC,SAAI,GAAG;YACL,IAAI,EAAE,kTAAkT;YACxT,KAAK,EAAE,2gBAA2gB;SACnhB,CAAA;QAED,cAAS,GAAG,wBAAwB,CAAC;QACrC,cAAS,GAAG,CAAC,CAAC;QACd,aAAQ,GAAG,GAAG,CAAC;QAIf,oBAAe,GAAG,IAAI,YAAY,EAAE,CAAC;QACrC,4DAA4D;QAE5D,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QAMvC,uBAAuB;QACvB,eAAU,GAAU,EAAE,CAAC;QACvB,UAAK,GAAQ,EAAE,CAAC;QAER,uBAAkB,GAAY,KAAK,CAAC;QAsB5C,+CAA+C;QACtC,eAAU,GAAa,EAAE,CAAC;QAqCnC,oBAAe,GAAG,CAAC,CAAM,EAAE,EAAE;QAC7B,CAAC,CAAA;IA/BG,CAAC;IAEE,QAAQ;QACb,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,oBAAoB,CAAC,KAAa;QACxC,MAAM,MAAM,GAAG;YACb,CAAC,EAAE,KAAK;YACR,UAAU,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;YAC5D,OAAO,EAAE,IAAI;SACd,CAAC;QAEF,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;gBAC3B,MAAM,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YAC3C,CAAC;YACD,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC7B,MAAM,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YACnD,CAAC;YACD,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;gBAC5B,MAAM,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YACjD,CAAC;YACD,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE,CAAC;gBACnD,MAAM,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAE;YAC1E,CAAC;QACH,CAAC;QACD,OAAO,KAAK,CAAC,QAAQ,CAAC,qBAAqB,EAAE,MAAM,CAAC,CAAC;IACvD,CAAC;IAKD,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,EAAO;IACzB,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/C,CAAC;IAED,cAAc,CAAC,IAAY;QACzB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,KAAK,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC5D,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE,CAAC;gBAC5E,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;qBAClD,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;oBACjB,sEAAsE;oBACtE,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,aAAa,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;yBAC7L,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBAClD,CAAC,EACC,KAAK,CAAC,KAAK,CAAC,IAAI,EACd,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,mDAAmD,CAAC,EAC3E,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,iDAAiD,CAAC,CAC1E,CACF,CAAC;YACN,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC5B,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,SAAS,CAAC,KAAU;QAClB,IAAI,GAAG,GAAG,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC3D,IAAI,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC;YACtD,OAAO,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACnF,CAAC,CAAC,CAAC;QACH,OAAO,kBAAkB,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC9C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;IACL,CAAC;IAED,wCAAwC;IACxC,UAAU,CAAC,KAAK;QACd,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC;QACrE,IAAI,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;QACpC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,wCAAwC;IACxC,QAAQ,CAAC,KAAK;QACZ,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAChD,CAAC;aAAM,CAAC;YACN,6DAA6D;YAC7D,2CAA2C;YAC3C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACvC,CAAC;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;IACtC,CAAC;IAED,qBAAqB;QACnB,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE,CAAC;YAChC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAC1B,CAAC;IACH,CAAC;8GAtLU,qBAAqB;kGAArB,qBAAqB,yaAbrB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;gBACpD,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,aAAa;gBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;gBACpD,KAAK,EAAE,IAAI;aACZ;SACF,6ICrCH,s6EAuCA;;2FDAa,qBAAqB;kBAjBjC,SAAS;+BACE,iBAAiB,aAGhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,aAAa;4BACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;qBACF;wKAI0B,iBAAiB;sBAA3C,SAAS;uBAAC,cAAc;gBAUM,SAAS;sBAAvC,WAAW;uBAAC,gBAAgB;gBAG7B,eAAe;sBADd,MAAM;gBAIP,iBAAiB;sBADhB,MAAM;gBAYM,iBAAiB;sBAA7B,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACO,QAAQ;sBAApB,KAAK;gBAMO,QAAQ;sBAApB,KAAK;gBAKG,WAAW;sBAAnB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator} from '@angular/forms';\r\nimport {BackendService, SystemService, TranslateService, UserService, Utils} from '@eo-sdk/core';\r\nimport {AutoComplete} from '@yuuvis/components/autocomplete';\r\nimport {forkJoin as observableForkJoin, of as observableOf, Subscription} from 'rxjs';\r\n\r\nexport interface OrganizationFilter {\r\n  type?: string;        // The type of the organization unit ('USER' or 'GROUP') to be displayed\r\n  groups?: string[];    // an array of group names to filter autocomplete results with\r\n  roles?: string[];     // an array of role names to filter autocomplete results with\r\n  activeonly?: boolean; // whether or not to fetch only active organization objects\r\n}\r\n\r\n@Component({\r\n  selector: 'eo-organization',\r\n  templateUrl: './organization.component.html',\r\n  styleUrls: ['./organization.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => OrganizationComponent),\r\n      multi: true\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => OrganizationComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class OrganizationComponent implements ControlValueAccessor, AfterContentChecked, Validator {\r\n\r\n  @ViewChild('autocomplete') autoCompleteInput: AutoComplete;\r\n\r\n  icon = {\r\n    user: '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" viewBox=\"0 -960 960 960\" width=\"20\"><path d=\"M480-480q-60 0-102-42t-42-102q0-60 42-102t102-42q60 0 102 42t42 102q0 60-42 102t-102 42ZM192-192v-96q0-23 12.5-43.5T239-366q55-32 116.5-49T480-432q63 0 124.5 17T721-366q22 13 34.5 34t12.5 44v96H192Z\"/></svg>',\r\n    group: '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" viewBox=\"0 -960 960 960\" width=\"20\"><path d=\"M96-192v-92q0-26 12.5-47.5T143-366q54-32 114.5-49T384-432q66 0 126.5 17T625-366q22 13 34.5 34.5T672-284v92H96Zm648 0v-92q0-42-19.5-78T672-421q39 8 75.5 21.5T817-366q22 13 34.5 34.5T864-284v92H744ZM384-480q-60 0-102-42t-42-102q0-60 42-102t102-42q60 0 102 42t42 102q0 60-42 102t-102 42Zm336-144q0 60-42 102t-102 42q-8 0-15-.5t-15-2.5q25-29 39.5-64.5T600-624q0-41-14.5-76.5T546-765q8-2 15-2.5t15-.5q60 0 102 42t42 102Z\"/></svg>'\r\n  }\r\n\r\n  remoteUrl = '/organization/query?q=';\r\n  minLength = 2;\r\n  wildCard = '*';\r\n  @HostBinding('class.readonly') _readonly: boolean;\r\n\r\n  @Output()\r\n  onValueResolved = new EventEmitter();\r\n  // emitted when value changed holding the resolved data_meta\r\n  @Output()\r\n  onDataMetaChanged = new EventEmitter();\r\n\r\n  autocompleteRes: any[];\r\n  // model value\r\n  value;\r\n  currentUserId: string;\r\n  // inner ng-model value\r\n  innerValue: any[] = [];\r\n  error: any = {};\r\n  deletedItemID: string;\r\n  private _removeCurrentUser: boolean = false;\r\n  @Input() set removeCurrentUser(b: boolean) {\r\n    this._removeCurrentUser = b;\r\n    this.currentUserId = b ? this.userService.getCurrentUser()?.id : undefined;\r\n  }\r\n  get removeCurrentUser() {\r\n    return this._removeCurrentUser\r\n  }\r\n  @Input() situation: string;\r\n  @Input() multiselect: boolean;\r\n  @Input() set readonly(r: boolean) {\r\n    this._readonly = r;\r\n  }\r\n  get readonly() {\r\n    return this._readonly;\r\n  }\r\n  @Input() set dataMeta(dM: any) {\r\n    if (dM) {\r\n      this.innerValue = Array.isArray(dM) ? dM : [dM];\r\n    }\r\n  }\r\n  @Input() placeholder: string;\r\n  // list of values that should not be selectable\r\n  @Input() exceptions: string[] = [];\r\n  @Input() filterObject: OrganizationFilter;\r\n\r\n  constructor(private backend: BackendService,\r\n    private translate: TranslateService,\r\n    private systemService: SystemService,\r\n    public userService: UserService,\r\n  ) { }\r\n\r\n  public validate() {\r\n    return null;\r\n  }\r\n\r\n  private buildAutocompleteUri(query: string): string {\r\n    const params = {\r\n      q: query,\r\n      activeonly: (this.situation !== 'SEARCH') ? 'true' : 'false',\r\n      details: true\r\n    };\r\n\r\n    if (this.filterObject) {\r\n      if (this.filterObject.type) {\r\n        params['scope'] = this.filterObject.type;\r\n      }\r\n      if (this.filterObject.groups) {\r\n        params['groupfilter'] = this.filterObject.groups;\r\n      }\r\n      if (this.filterObject.roles) {\r\n        params['rolefilter'] = this.filterObject.roles;\r\n      }\r\n      if (this.filterObject.hasOwnProperty('activeonly')) {\r\n        params['activeonly'] = this.filterObject.activeonly ? 'true' : 'false' ;\r\n      }\r\n    }\r\n    return Utils.buildUri('/organization/query', params);\r\n  }\r\n\r\n  propagateChange = (_: any) => {\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (value) {\r\n      this.value = value;\r\n      this.resolveFn(value);\r\n    } else {\r\n      this.value = null;\r\n      this.innerValue = [];\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n  }\r\n\r\n  private propagate() {\r\n    this.propagateChange(this.value);\r\n    this.onDataMetaChanged.emit(this.innerValue);\r\n  }\r\n\r\n  autocompleteFn(term: string) {\r\n    if (term.length >= this.minLength || term === this.wildCard) {\r\n      if (this.multiselect || (!this.multiselect && this.innerValue.length === 0)) {\r\n        this.backend.getJson(this.buildAutocompleteUri(term))\r\n          .subscribe((res) => {\r\n            // autocomplete values should be unique and not part of the exceptions\r\n            this.autocompleteRes = res.filter(v => (!this.value || this.value.indexOf(v.name) === -1) && this.exceptions.indexOf(v.name) === -1 && (!this.removeCurrentUser || this.currentUserId !== v.id))\r\n              .sort(Utils.sortValues('title')).slice(0, 10);\r\n          },\r\n            Utils.throw(null,\r\n              this.translate.instant('eo.form.property.organization.request.error.title'),\r\n              this.translate.instant('eo.form.property.organization.request.error.msg')\r\n            )\r\n          );\r\n      } else {\r\n        this.autocompleteRes = [];\r\n      }\r\n    } else {\r\n      this.autocompleteRes = [];\r\n    }\r\n  }\r\n\r\n  resolveFn(value: any): Subscription {\r\n    let map = (value instanceof Array ? value : [value]).map(v => {\r\n      let match = this.innerValue.find(iv => iv.name === v);\r\n      return match ? observableOf(match) : this.systemService.getOrganizationObject(v);\r\n    });\r\n    return observableForkJoin(map).subscribe(data => {\r\n      this.innerValue = data;\r\n      this.onValueResolved.emit(this.innerValue);\r\n    });\r\n  }\r\n\r\n  // handle selection changes to the model\r\n  onUnselect(value) {\r\n    this.innerValue = this.innerValue.filter(v => v.name !== value.name);\r\n    let _value = this.innerValue.map(v => v.name);\r\n    this.value = this.multiselect ? _value : null;\r\n    if (!this.multiselect) {\r\n      this.clearInnerInput();\r\n    }\r\n    this.autoCompleteInput.focusInput();\r\n    this.propagate();\r\n  }\r\n\r\n  // handle selection changes to the model\r\n  onSelect(value) {\r\n    if (this.multiselect) {\r\n      this.value = this.innerValue.map(v => v.name);\r\n    } else {\r\n      // internal autocomplete control is always set to multiselect\r\n      // so the resolved value is always an array\r\n      this.value = this.innerValue[0].name;\r\n    }\r\n    this.propagate();\r\n  }\r\n\r\n  onAutoCompleteBlur() {\r\n    this.clearInnerInput();\r\n  }\r\n\r\n  private clearInnerInput() {\r\n    this.autoCompleteInput.clearInput();\r\n  }\r\n\r\n  ngAfterContentChecked() {\r\n    if (this.situation === 'SEARCH') {\r\n      this.multiselect = true;\r\n    }\r\n  }\r\n}\r\n","<div class=\"eo-organization\" [ngClass]=\"{acInputHidden: !multiselect && innerValue.length}\">\r\n\r\n  <yvc-autocomplete [(ngModel)]=\"innerValue\" #autocomplete (suggestionSelect)=\"onSelect($event)\"\r\n    [placeholder]=\"placeholder\" (suggestionUnselect)=\"onUnselect($event)\" (blur)=\"onAutoCompleteBlur()\"\r\n    [disabled]=\"readonly\" [autocompleteValues]=\"autocompleteRes\" field=\"id\"\r\n    [forceSelection]=\"true\"\r\n    (autocompleteFnc)=\"autocompleteFn($event)\" [multiple]=\"true\">\r\n\r\n    <ng-template #autocompleteOptionTemplate let-item>\r\n      <div class=\"org-item\">\r\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\r\n        <span *ngIf=\"(item.firstname?.length && item.lastname?.length) || item.type === 'group'\">{{item.title}}\r\n          ({{item.name}})</span>\r\n        <span *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.type !== 'group'\">({{item.name}})</span>\r\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\r\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template #chipTemplate let-item>\r\n      <div class=\"org-item\">\r\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\r\n        <span\r\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && item.active) || item.type === 'group'\">{{item.title}}\r\n          ({{item.name}})</span>\r\n        <span class=\"inactive\"\r\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && !item.active)\">{{item.title}}\r\n          ({{item.name}})</span>\r\n        <span *ngIf=\"(!item.firstname?.length && !item.lastname?.length && !item.active && !item.type)\"\r\n          class=\"deleted-user-label\">{{'eo.form.property.organization.error.usernotfound'|translate}}</span>\r\n        <span\r\n          *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.active && item.type !== 'group'\">({{item.name}})</span>\r\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\r\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\r\n      </div>\r\n    </ng-template>\r\n\r\n  </yvc-autocomplete>\r\n</div>\r\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"organization.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/form-elements/organization/organization.component.ts","../../../../../../../../src/app/eo-framework/form-elements/organization/organization.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator} from '@angular/forms';\r\nimport {BackendService, SystemService, TranslateService, UserService, Utils} from '@eo-sdk/core';\r\nimport {AutoComplete} from '@yuuvis/components/autocomplete';\r\nimport {forkJoin as observableForkJoin, of as observableOf, Subscription} from 'rxjs';\r\n\r\nexport interface OrganizationFilter {\r\n  type?: string;        // The type of the organization unit ('USER' or 'GROUP') to be displayed\r\n  groups?: string[];    // an array of group names to filter autocomplete results with\r\n  roles?: string[];     // an array of role names to filter autocomplete results with\r\n  activeonly?: boolean; // whether or not to fetch only active organization objects\r\n}\r\n\r\n@Component({\r\n  selector: 'eo-organization',\r\n  templateUrl: './organization.component.html',\r\n  styleUrls: ['./organization.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => OrganizationComponent),\r\n      multi: true\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => OrganizationComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class OrganizationComponent implements ControlValueAccessor, AfterContentChecked, Validator {\r\n\r\n  @ViewChild('autocomplete') autoCompleteInput: AutoComplete;\r\n\r\n  icon = {\r\n    user: '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" viewBox=\"0 -960 960 960\" width=\"20\"><path d=\"M480-480q-60 0-102-42t-42-102q0-60 42-102t102-42q60 0 102 42t42 102q0 60-42 102t-102 42ZM192-192v-96q0-23 12.5-43.5T239-366q55-32 116.5-49T480-432q63 0 124.5 17T721-366q22 13 34.5 34t12.5 44v96H192Z\"/></svg>',\r\n    group: '<svg xmlns=\"http://www.w3.org/2000/svg\" height=\"20\" viewBox=\"0 -960 960 960\" width=\"20\"><path d=\"M96-192v-92q0-26 12.5-47.5T143-366q54-32 114.5-49T384-432q66 0 126.5 17T625-366q22 13 34.5 34.5T672-284v92H96Zm648 0v-92q0-42-19.5-78T672-421q39 8 75.5 21.5T817-366q22 13 34.5 34.5T864-284v92H744ZM384-480q-60 0-102-42t-42-102q0-60 42-102t102-42q60 0 102 42t42 102q0 60-42 102t-102 42Zm336-144q0 60-42 102t-102 42q-8 0-15-.5t-15-2.5q25-29 39.5-64.5T600-624q0-41-14.5-76.5T546-765q8-2 15-2.5t15-.5q60 0 102 42t42 102Z\"/></svg>'\r\n  }\r\n\r\n  remoteUrl = '/organization/query?q=';\r\n  minLength = 2;\r\n  wildCard = '*';\r\n  @HostBinding('class.readonly') _readonly: boolean;\r\n\r\n  @Output()\r\n  onValueResolved = new EventEmitter();\r\n  // emitted when value changed holding the resolved data_meta\r\n  @Output()\r\n  onDataMetaChanged = new EventEmitter();\r\n\r\n  autocompleteRes: any[];\r\n  // model value\r\n  value;\r\n  currentUserId: string;\r\n  // inner ng-model value\r\n  innerValue: any[] = [];\r\n  error: any = {};\r\n  deletedItemID: string;\r\n  private _removeCurrentUser: boolean = false;\r\n  @Input() set removeCurrentUser(b: boolean) {\r\n    this._removeCurrentUser = b;\r\n    this.currentUserId = b ? this.userService.getCurrentUser()?.id : undefined;\r\n  }\r\n  get removeCurrentUser() {\r\n    return this._removeCurrentUser\r\n  }\r\n  @Input() situation: string;\r\n  @Input() multiselect: boolean;\r\n  @Input() set readonly(r: boolean) {\r\n    this._readonly = r;\r\n  }\r\n  get readonly() {\r\n    return this._readonly;\r\n  }\r\n  @Input() set dataMeta(dM: any) {\r\n    if (dM) {\r\n      this.innerValue = Array.isArray(dM) ? dM : [dM];\r\n    }\r\n  }\r\n  autocompleteTimeout: any\r\n  @Input() placeholder: string;\r\n  // list of values that should not be selectable\r\n  @Input() exceptions: string[] = [];\r\n  @Input() filterObject: OrganizationFilter;\r\n\r\n  constructor(private backend: BackendService,\r\n    private translate: TranslateService,\r\n    private systemService: SystemService,\r\n    public userService: UserService,\r\n  ) { }\r\n\r\n  public validate() {\r\n    return null;\r\n  }\r\n\r\n  private buildAutocompleteUri(query: string): string {\r\n    const params = {\r\n      q: query,\r\n      activeonly: (this.situation !== 'SEARCH') ? 'true' : 'false',\r\n      details: true\r\n    };\r\n\r\n    if (this.filterObject) {\r\n      if (this.filterObject.type) {\r\n        params['scope'] = this.filterObject.type;\r\n      }\r\n      if (this.filterObject.groups) {\r\n        params['groupfilter'] = this.filterObject.groups;\r\n      }\r\n      if (this.filterObject.roles) {\r\n        params['rolefilter'] = this.filterObject.roles;\r\n      }\r\n      if (this.filterObject.hasOwnProperty('activeonly')) {\r\n        params['activeonly'] = this.filterObject.activeonly ? 'true' : 'false' ;\r\n      }\r\n    }\r\n    return Utils.buildUri('/organization/query', params);\r\n  }\r\n\r\n  propagateChange = (_: any) => {\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (value) {\r\n      this.value = value;\r\n      this.resolveFn(value);\r\n    } else {\r\n      this.value = null;\r\n      this.innerValue = [];\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n  }\r\n\r\n  private propagate() {\r\n    this.propagateChange(this.value);\r\n    this.onDataMetaChanged.emit(this.innerValue);\r\n  }\r\n\r\n  autocompleteFn(term: string) {\r\n    clearTimeout(this.autocompleteTimeout);\r\n    this.autocompleteTimeout = setTimeout(() => {\r\n      if (term.length >= this.minLength || term === this.wildCard) {\r\n        if (this.multiselect || (!this.multiselect && this.innerValue.length === 0)) {\r\n          this.backend.getJson(this.buildAutocompleteUri(term))\r\n            .subscribe((res) => {\r\n              // autocomplete values should be unique and not part of the exceptions\r\n              this.autocompleteRes = res.filter(v => (!this.value || this.value.indexOf(v.name) === -1) && this.exceptions.indexOf(v.name) === -1 && (!this.removeCurrentUser || this.currentUserId !== v.id))\r\n                .sort(Utils.sortValues('title')).slice(0, 10);\r\n              },\r\n              Utils.throw(null,\r\n                this.translate.instant('eo.form.property.organization.request.error.title'),\r\n                this.translate.instant('eo.form.property.organization.request.error.msg')\r\n              )\r\n            );\r\n        } else {\r\n          this.autocompleteRes = [];\r\n        }\r\n      } else {\r\n        this.autocompleteRes = [];\r\n      }\r\n    }, 1000);\r\n  }\r\n\r\n  resolveFn(value: any): Subscription {\r\n    let map = (value instanceof Array ? value : [value]).map(v => {\r\n      let match = this.innerValue.find(iv => iv.name === v);\r\n      return match ? observableOf(match) : this.systemService.getOrganizationObject(v);\r\n    });\r\n\r\n    if (map.length === 0) {\r\n      this.innerValue = [];\r\n      this.onValueResolved.emit(this.innerValue);\r\n    } else {\r\n      return observableForkJoin(map).subscribe(data => {\r\n        this.innerValue = data;\r\n        this.onValueResolved.emit(this.innerValue);\r\n      });\r\n    }\r\n  }\r\n\r\n  // handle selection changes to the model\r\n  onUnselect(value) {\r\n    this.innerValue = this.innerValue.filter(v => v.name !== value.name);\r\n    let _value = this.innerValue.map(v => v.name);\r\n    this.value = this.multiselect ? _value : null;\r\n    if (!this.multiselect) {\r\n      this.clearInnerInput();\r\n    }\r\n    this.autoCompleteInput.focusInput();\r\n    this.propagate();\r\n  }\r\n\r\n  // handle selection changes to the model\r\n  onSelect(value) {\r\n    if (this.multiselect) {\r\n      this.value = this.innerValue.map(v => v.name);\r\n    } else {\r\n      // internal autocomplete control is always set to multiselect\r\n      // so the resolved value is always an array\r\n      this.value = this.innerValue[0].name;\r\n    }\r\n    this.propagate();\r\n  }\r\n\r\n  onAutoCompleteBlur() {\r\n    this.clearInnerInput();\r\n  }\r\n\r\n  private clearInnerInput() {\r\n    this.autoCompleteInput.clearInput();\r\n  }\r\n\r\n  ngAfterContentChecked() {\r\n    if (this.situation === 'SEARCH') {\r\n      this.multiselect = true;\r\n    }\r\n  }\r\n}\r\n","<div class=\"eo-organization\" [ngClass]=\"{acInputHidden: !multiselect && innerValue.length}\">\r\n\r\n  <yvc-autocomplete [(ngModel)]=\"innerValue\" #autocomplete (suggestionSelect)=\"onSelect($event)\"\r\n    [placeholder]=\"placeholder\" (suggestionUnselect)=\"onUnselect($event)\" (blur)=\"onAutoCompleteBlur()\"\r\n    [disabled]=\"readonly\" [autocompleteValues]=\"autocompleteRes\" field=\"id\"\r\n    [forceSelection]=\"true\"\r\n    (autocompleteFnc)=\"autocompleteFn($event)\" [multiple]=\"true\">\r\n\r\n    <ng-template #autocompleteOptionTemplate let-item>\r\n      <div class=\"org-item\">\r\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\r\n        <span *ngIf=\"(item.firstname?.length && item.lastname?.length) || item.type === 'group'\">{{item.title}}\r\n          ({{item.name}})</span>\r\n        <span *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.type !== 'group'\">({{item.name}})</span>\r\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\r\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template #chipTemplate let-item>\r\n      <div class=\"org-item\">\r\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\r\n        <span\r\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && item.active) || item.type === 'group'\">{{item.title}}\r\n          ({{item.name}})</span>\r\n        <span class=\"inactive\"\r\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && !item.active)\">{{item.title}}\r\n          ({{item.name}})</span>\r\n        <span *ngIf=\"(!item.firstname?.length && !item.lastname?.length && !item.active && !item.type)\"\r\n          class=\"deleted-user-label\">{{'eo.form.property.organization.error.usernotfound'|translate}}</span>\r\n        <span\r\n          *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.active && item.type !== 'group'\">({{item.name}})</span>\r\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\r\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\r\n      </div>\r\n    </ng-template>\r\n\r\n  </yvc-autocomplete>\r\n</div>\r\n"]}
|
|
@@ -79,11 +79,11 @@ export class TextFilterComponent extends AbstractFilterComponent {
|
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
81
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: TextFilterComponent, deps: [{ token: i1.ListSettingsService }, { token: i2.LocalStorageService }, { token: i2.UserService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
82
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.4", type: TextFilterComponent, selector: "eo-text-filter", inputs: { title: "title", placeholder: "placeholder", enableSave: "enableSave", filterParams: "filterParams", matchFields: "matchFields" }, usesInheritance: true, ngImport: i0, template: "<header class=\"filter__header\">\r\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\r\n</header>\r\n<div class=\"flex-row\">\r\n <eo-form-input>\r\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\r\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\r\n </eo-form-input>\r\n <eo-icon class=\"save-filter-icon\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\r\n (click)=\"saveFilter(value)\"\r\n [iconTitle]=\"'eo.filter.save' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\r\n</div>\r\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\r\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\r\n <div class=\"saved-filters-container\">\r\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\r\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\r\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\r\n [iconTitle]=\"'eo.filter.delete' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".title{margin-top:.5em;font-weight:700}input{border:none}.form-control::-ms-clear{display:none}.save-filter-icon{cursor:pointer}.save-filter-icon.disable-save-filter{cursor:default;color:var(--color-primary-3)}.remove-filter-icon{cursor:pointer;margin-left:auto}.saved-filter-text{cursor:pointer;margin-left:5px}.saved-filter{text-decoration:underline}.saved-filters-title{margin-top:1em}.saved-filters-container{max-height:200px;overflow:auto}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.FormInputComponent, selector: "eo-form-input", inputs: ["label", "tag", "description", "skipToggle", "isNull", "invalid", "disabled", "required"], outputs: ["onToggleLabel"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
|
|
82
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.4", type: TextFilterComponent, selector: "eo-text-filter", inputs: { title: "title", placeholder: "placeholder", enableSave: "enableSave", filterParams: "filterParams", matchFields: "matchFields" }, usesInheritance: true, ngImport: i0, template: "<header class=\"filter__header\">\r\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\r\n</header>\r\n<div class=\"flex-row\">\r\n <eo-form-input>\r\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\r\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\r\n </eo-form-input>\r\n <eo-icon class=\"save-filter-icon\" [tabindex]=\"(!value || savedFilters.includes(value)) ? '-1' : '0'\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\r\n (click)=\"saveFilter(value)\"\r\n (keydown.enter)=\"saveFilter(value)\"\r\n [iconTitle]=\"'eo.filter.save' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\r\n</div>\r\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\r\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\r\n <div class=\"saved-filters-container\">\r\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\r\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\r\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\r\n [iconTitle]=\"'eo.filter.delete' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".title{margin-top:.5em;font-weight:700}input{border:none}.form-control::-ms-clear{display:none}.save-filter-icon{cursor:pointer}.save-filter-icon:focus,.save-filter-icon:hover{color:var(--color-accent)!important}.save-filter-icon.disable-save-filter{cursor:default;color:var(--color-primary-3)}.remove-filter-icon{cursor:pointer;margin-left:auto}.saved-filter-text{cursor:pointer;margin-left:5px}.saved-filter{text-decoration:underline}.saved-filters-title{margin-top:1em}.saved-filters-container{max-height:200px;overflow:auto}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.FormInputComponent, selector: "eo-form-input", inputs: ["label", "tag", "description", "skipToggle", "isNull", "invalid", "disabled", "required"], outputs: ["onToggleLabel"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
|
|
83
83
|
}
|
|
84
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: TextFilterComponent, decorators: [{
|
|
85
85
|
type: Component,
|
|
86
|
-
args: [{ selector: 'eo-text-filter', template: "<header class=\"filter__header\">\r\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\r\n</header>\r\n<div class=\"flex-row\">\r\n <eo-form-input>\r\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\r\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\r\n </eo-form-input>\r\n <eo-icon class=\"save-filter-icon\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\r\n (click)=\"saveFilter(value)\"\r\n [iconTitle]=\"'eo.filter.save' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\r\n</div>\r\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\r\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\r\n <div class=\"saved-filters-container\">\r\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\r\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\r\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\r\n [iconTitle]=\"'eo.filter.delete' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".title{margin-top:.5em;font-weight:700}input{border:none}.form-control::-ms-clear{display:none}.save-filter-icon{cursor:pointer}.save-filter-icon.disable-save-filter{cursor:default;color:var(--color-primary-3)}.remove-filter-icon{cursor:pointer;margin-left:auto}.saved-filter-text{cursor:pointer;margin-left:5px}.saved-filter{text-decoration:underline}.saved-filters-title{margin-top:1em}.saved-filters-container{max-height:200px;overflow:auto}\n"] }]
|
|
86
|
+
args: [{ selector: 'eo-text-filter', template: "<header class=\"filter__header\">\r\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\r\n</header>\r\n<div class=\"flex-row\">\r\n <eo-form-input>\r\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\r\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\r\n </eo-form-input>\r\n <eo-icon class=\"save-filter-icon\" [tabindex]=\"(!value || savedFilters.includes(value)) ? '-1' : '0'\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\r\n (click)=\"saveFilter(value)\"\r\n (keydown.enter)=\"saveFilter(value)\"\r\n [iconTitle]=\"'eo.filter.save' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\r\n</div>\r\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\r\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\r\n <div class=\"saved-filters-container\">\r\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\r\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\r\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\r\n [iconTitle]=\"'eo.filter.delete' | translate\"\r\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".title{margin-top:.5em;font-weight:700}input{border:none}.form-control::-ms-clear{display:none}.save-filter-icon{cursor:pointer}.save-filter-icon:focus,.save-filter-icon:hover{color:var(--color-accent)!important}.save-filter-icon.disable-save-filter{cursor:default;color:var(--color-primary-3)}.remove-filter-icon{cursor:pointer;margin-left:auto}.saved-filter-text{cursor:pointer;margin-left:5px}.saved-filter{text-decoration:underline}.saved-filters-title{margin-top:1em}.saved-filters-container{max-height:200px;overflow:auto}\n"] }]
|
|
87
87
|
}], ctorParameters: () => [{ type: i1.ListSettingsService }, { type: i2.LocalStorageService }, { type: i2.UserService }], propDecorators: { title: [{
|
|
88
88
|
type: Input
|
|
89
89
|
}], placeholder: [{
|
|
@@ -95,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImpor
|
|
|
95
95
|
}], matchFields: [{
|
|
96
96
|
type: Input
|
|
97
97
|
}] } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-filter.component.js","sourceRoot":"","sources":["../../../../../../../../../../src/app/eo-framework/grid/extensions/filter/text/text-filter.component.ts","../../../../../../../../../../src/app/eo-framework/grid/extensions/filter/text/text-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input} from '@angular/core';\r\nimport {IFilterParams, IRowNode, RowNode} from '@ag-grid-community/core';\r\nimport {ListSettingsService} from '../../services/list-settings.service';\r\nimport {AbstractFilterComponent} from '../abstract-filter.component';\r\nimport {LocalStorageService, UserService, Utils} from '@eo-sdk/core';\r\n\r\n@Component({\r\n  selector: 'eo-text-filter',\r\n  templateUrl: './text-filter.component.html',\r\n  styleUrls: ['./text-filter.component.scss']\r\n})\r\nexport class TextFilterComponent extends AbstractFilterComponent {\r\n\r\n  @Input() title = '';\r\n  @Input() placeholder = 'eo.filter.input.placeholder';\r\n  @Input() enableSave = false;\r\n  private focused = false;\r\n  savedFilters = [];\r\n\r\n  @Input() set filterParams(params: IFilterParams) {\r\n    super.filterParams = params;\r\n  }\r\n\r\n  @Input()\r\n  set matchFields(fields: string[]) {\r\n    this.valueGetter = (rowNode: IRowNode) => fields.map(f => Utils.getProperty(rowNode.data, f)).join('\\n');\r\n    const value = this.defaultValue || this.settingsService.setupSettings(this.id, [{id: 'text', value: this.value}])[0].value;\r\n    setTimeout(() => this.onChange(value), 0);\r\n  }\r\n\r\n  constructor(private settingsService: ListSettingsService,\r\n              private storageService: LocalStorageService,\r\n              private userService: UserService) {\r\n    super();\r\n    this.id = '#text';\r\n    this.getSavedFilters();\r\n  }\r\n\r\n  onChange(newValue, oldValue?): void {\r\n    if (this.value !== newValue) {\r\n      this.value = newValue;\r\n      if (!this.defaultValue) {\r\n        this.settingsService.saveSettings(this.id, this.value ? {'text': this.value} : '');\r\n      }\r\n      this.params.filterChangedCallback();\r\n    }\r\n  }\r\n\r\n  doesExternalFilterPass(rowNode: IRowNode): boolean {\r\n    const filterTerms = this.value.toLowerCase().split(' ');\r\n    const rowValue = this.valueGetter(rowNode).toString().toLowerCase();\r\n    const everyTermFound = !filterTerms.find(term => rowValue.indexOf(term) === -1);\r\n    return everyTermFound;\r\n  }\r\n\r\n  reset() {\r\n    super.reset();\r\n    this.settingsService.saveSettings(this.id);\r\n  }\r\n\r\n  focusout () {\r\n    this.focused = false;\r\n  }\r\n\r\n  getSavedFilters() {\r\n    if (this.userService.getCurrentUser().userSettings.savedInboxFilter) {\r\n      this.savedFilters = this.userService.getCurrentUser().userSettings.savedInboxFilter;\r\n    } else {\r\n      this.savedFilters = this.storageService.getItem('eo.inbox.filter.suggestions') ? this.storageService.getItem('eo.inbox.filter.suggestions') : [];\r\n    }\r\n  }\r\n\r\n  saveFilter(term: string) {\r\n    if (term && !this.savedFilters.includes(term)) {\r\n      this.savedFilters.push(term);\r\n      this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\r\n    }\r\n  }\r\n\r\n  removeFilter(term: string) {\r\n    this.savedFilters = this.savedFilters.filter(t => t !== term);\r\n    this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\r\n  }\r\n\r\n  focus () {\r\n    if (!this.focused) {\r\n      this.focused = true;\r\n\r\n      // Timeout for cross browser compatibility (Chrome)\r\n      setTimeout(() => { document.execCommand('selectall', false, null); });\r\n    }\r\n  }\r\n}\r\n","<header class=\"filter__header\">\r\n  <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\r\n</header>\r\n<div class=\"flex-row\">\r\n  <eo-form-input>\r\n    <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\r\n           placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\r\n  </eo-form-input>\r\n  <eo-icon class=\"save-filter-icon\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\r\n           (click)=\"saveFilter(value)\"\r\n           [iconTitle]=\"'eo.filter.save' | translate\"\r\n           [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\r\n</div>\r\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\r\n  <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\r\n  <div class=\"saved-filters-container\">\r\n    <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\r\n      <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\r\n      <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\r\n               [iconTitle]=\"'eo.filter.delete' | translate\"\r\n               [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-filter.component.js","sourceRoot":"","sources":["../../../../../../../../../../src/app/eo-framework/grid/extensions/filter/text/text-filter.component.ts","../../../../../../../../../../src/app/eo-framework/grid/extensions/filter/text/text-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input} from '@angular/core';\r\nimport {IFilterParams, IRowNode, RowNode} from '@ag-grid-community/core';\r\nimport {ListSettingsService} from '../../services/list-settings.service';\r\nimport {AbstractFilterComponent} from '../abstract-filter.component';\r\nimport {LocalStorageService, UserService, Utils} from '@eo-sdk/core';\r\n\r\n@Component({\r\n  selector: 'eo-text-filter',\r\n  templateUrl: './text-filter.component.html',\r\n  styleUrls: ['./text-filter.component.scss']\r\n})\r\nexport class TextFilterComponent extends AbstractFilterComponent {\r\n\r\n  @Input() title = '';\r\n  @Input() placeholder = 'eo.filter.input.placeholder';\r\n  @Input() enableSave = false;\r\n  private focused = false;\r\n  savedFilters = [];\r\n\r\n  @Input() set filterParams(params: IFilterParams) {\r\n    super.filterParams = params;\r\n  }\r\n\r\n  @Input()\r\n  set matchFields(fields: string[]) {\r\n    this.valueGetter = (rowNode: IRowNode) => fields.map(f => Utils.getProperty(rowNode.data, f)).join('\\n');\r\n    const value = this.defaultValue || this.settingsService.setupSettings(this.id, [{id: 'text', value: this.value}])[0].value;\r\n    setTimeout(() => this.onChange(value), 0);\r\n  }\r\n\r\n  constructor(private settingsService: ListSettingsService,\r\n              private storageService: LocalStorageService,\r\n              private userService: UserService) {\r\n    super();\r\n    this.id = '#text';\r\n    this.getSavedFilters();\r\n  }\r\n\r\n  onChange(newValue, oldValue?): void {\r\n    if (this.value !== newValue) {\r\n      this.value = newValue;\r\n      if (!this.defaultValue) {\r\n        this.settingsService.saveSettings(this.id, this.value ? {'text': this.value} : '');\r\n      }\r\n      this.params.filterChangedCallback();\r\n    }\r\n  }\r\n\r\n  doesExternalFilterPass(rowNode: IRowNode): boolean {\r\n    const filterTerms = this.value.toLowerCase().split(' ');\r\n    const rowValue = this.valueGetter(rowNode).toString().toLowerCase();\r\n    const everyTermFound = !filterTerms.find(term => rowValue.indexOf(term) === -1);\r\n    return everyTermFound;\r\n  }\r\n\r\n  reset() {\r\n    super.reset();\r\n    this.settingsService.saveSettings(this.id);\r\n  }\r\n\r\n  focusout () {\r\n    this.focused = false;\r\n  }\r\n\r\n  getSavedFilters() {\r\n    if (this.userService.getCurrentUser().userSettings.savedInboxFilter) {\r\n      this.savedFilters = this.userService.getCurrentUser().userSettings.savedInboxFilter;\r\n    } else {\r\n      this.savedFilters = this.storageService.getItem('eo.inbox.filter.suggestions') ? this.storageService.getItem('eo.inbox.filter.suggestions') : [];\r\n    }\r\n  }\r\n\r\n  saveFilter(term: string) {\r\n    if (term && !this.savedFilters.includes(term)) {\r\n      this.savedFilters.push(term);\r\n      this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\r\n    }\r\n  }\r\n\r\n  removeFilter(term: string) {\r\n    this.savedFilters = this.savedFilters.filter(t => t !== term);\r\n    this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\r\n  }\r\n\r\n  focus () {\r\n    if (!this.focused) {\r\n      this.focused = true;\r\n\r\n      // Timeout for cross browser compatibility (Chrome)\r\n      setTimeout(() => { document.execCommand('selectall', false, null); });\r\n    }\r\n  }\r\n}\r\n","<header class=\"filter__header\">\r\n  <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\r\n</header>\r\n<div class=\"flex-row\">\r\n  <eo-form-input>\r\n    <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\r\n           placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\r\n  </eo-form-input>\r\n  <eo-icon class=\"save-filter-icon\" [tabindex]=\"(!value || savedFilters.includes(value)) ? '-1' : '0'\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\r\n           (click)=\"saveFilter(value)\"\r\n           (keydown.enter)=\"saveFilter(value)\"\r\n           [iconTitle]=\"'eo.filter.save' | translate\"\r\n           [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\r\n</div>\r\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\r\n  <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\r\n  <div class=\"saved-filters-container\">\r\n    <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\r\n      <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\r\n      <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\r\n               [iconTitle]=\"'eo.filter.delete' | translate\"\r\n               [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|