@eo-sdk/client 11.5.0-rc.2 → 11.6.0-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/app/eo-client/about-state/about-state.component.d.ts.map +1 -1
  2. package/app/eo-framework/actions/actions/custom-actions/custom-actions.component.d.ts.map +1 -1
  3. package/app/eo-framework/actions/actions/workflow-action/simple-workflow-action.component.d.ts.map +1 -1
  4. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +1 -1
  5. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
  6. package/app/eo-framework/form-elements/organization/organization.component.d.ts +1 -0
  7. package/app/eo-framework/form-elements/organization/organization.component.d.ts.map +1 -1
  8. package/app/eo-framework/grid/grid.component.d.ts +7 -0
  9. package/app/eo-framework/grid/grid.component.d.ts.map +1 -1
  10. package/app/eo-framework/media/media.component.d.ts +3 -2
  11. package/app/eo-framework/media/media.component.d.ts.map +1 -1
  12. package/app/eo-framework/object-details/object-details.component.d.ts +13 -4
  13. package/app/eo-framework/object-details/object-details.component.d.ts.map +1 -1
  14. package/app/eo-framework/object-details/object-history/object-history.component.d.ts +3 -2
  15. package/app/eo-framework/object-details/object-history/object-history.component.d.ts.map +1 -1
  16. package/app/eo-framework/result-list/result-list.component.d.ts.map +1 -1
  17. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts +50 -0
  18. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts.map +1 -1
  19. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.d.ts +10 -0
  20. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.d.ts.map +1 -0
  21. package/app/eo-framework-core/search/app-search.service.d.ts +12 -1
  22. package/app/eo-framework-core/search/app-search.service.d.ts.map +1 -1
  23. package/assets/_default/i18n/de.json +5 -3
  24. package/assets/_default/i18n/en.json +10 -8
  25. package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
  26. package/esm2022/app/eo-framework/actions/actions/custom-actions/custom-actions.component.mjs +2 -1
  27. package/esm2022/app/eo-framework/actions/actions/workflow-action/simple-workflow-action.component.mjs +2 -2
  28. package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +18 -4
  29. package/esm2022/app/eo-framework/form-elements/organization/organization.component.mjs +25 -16
  30. package/esm2022/app/eo-framework/grid/extensions/filter/text/text-filter.component.mjs +3 -3
  31. package/esm2022/app/eo-framework/grid/grid.component.mjs +36 -10
  32. package/esm2022/app/eo-framework/media/media.component.mjs +8 -4
  33. package/esm2022/app/eo-framework/object-details/object-details.component.mjs +30 -15
  34. package/esm2022/app/eo-framework/object-details/object-history/object-history.component.mjs +11 -6
  35. package/esm2022/app/eo-framework/object-form/object-form/form-element-table/form-element-table.component.mjs +3 -3
  36. package/esm2022/app/eo-framework/prepare-details/prepare-details.component.mjs +1 -1
  37. package/esm2022/app/eo-framework/recyclebin-details/recyclebin-details.component.mjs +1 -1
  38. package/esm2022/app/eo-framework/result-list/result-list.component.mjs +7 -2
  39. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary-entry/indexdata-summary-entry.component.mjs +2 -2
  40. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.mjs +138 -5
  41. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.interface.mjs +2 -0
  42. package/esm2022/app/eo-framework-core/api/grid.service.mjs +3 -3
  43. package/esm2022/app/eo-framework-core/search/app-search.service.mjs +25 -4
  44. package/fesm2022/eo-sdk-client.mjs +303 -746
  45. package/fesm2022/eo-sdk-client.mjs.map +1 -1
  46. package/misc/scripts/copy-client-assets.js +1 -1
  47. package/package.json +3 -3
  48. package/proxy.config.js +13 -0
  49. package/scss/_migrationTemp.scss +1 -0
  50. package/styles.css +1 -0
  51. package/app/eo-framework/grid/row-grouping/batchRemover.d.ts +0 -13
  52. package/app/eo-framework/grid/row-grouping/batchRemover.d.ts.map +0 -1
  53. package/app/eo-framework/grid/row-grouping/group-stage.d.ts +0 -45
  54. package/app/eo-framework/grid/row-grouping/group-stage.d.ts.map +0 -1
  55. package/app/eo-framework/grid/row-grouping/row-grouping.module.d.ts +0 -8
  56. package/app/eo-framework/grid/row-grouping/row-grouping.module.d.ts.map +0 -1
  57. package/esm2022/app/eo-framework/grid/row-grouping/batchRemover.mjs +0 -50
  58. package/esm2022/app/eo-framework/grid/row-grouping/group-stage.mjs +0 -623
  59. package/esm2022/app/eo-framework/grid/row-grouping/row-grouping.module.mjs +0 -8
  60. 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
- if (term.length >= this.minLength || term === this.wildCard) {
101
- if (this.multiselect || (!this.multiselect && this.innerValue.length === 0)) {
102
- this.backend.getJson(this.buildAutocompleteUri(term))
103
- .subscribe((res) => {
104
- // autocomplete values should be unique and not part of the exceptions
105
- 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))
106
- .sort(Utils.sortValues('title')).slice(0, 10);
107
- }, Utils.throw(null, this.translate.instant('eo.form.property.organization.request.error.title'), this.translate.instant('eo.form.property.organization.request.error.msg')));
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
- return observableForkJoin(map).subscribe(data => {
123
- this.innerValue = data;
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":"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","sourcesContent":["import {\n  AfterContentChecked,\n  Component,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator} from '@angular/forms';\nimport {BackendService, SystemService, TranslateService, UserService, Utils} from '@eo-sdk/core';\nimport {AutoComplete} from '@yuuvis/components/autocomplete';\nimport {forkJoin as observableForkJoin, of as observableOf, Subscription} from 'rxjs';\n\nexport interface OrganizationFilter {\n  type?: string;        // The type of the organization unit ('USER' or 'GROUP') to be displayed\n  groups?: string[];    // an array of group names to filter autocomplete results with\n  roles?: string[];     // an array of role names to filter autocomplete results with\n  activeonly?: boolean; // whether or not to fetch only active organization objects\n}\n\n@Component({\n  selector: 'eo-organization',\n  templateUrl: './organization.component.html',\n  styleUrls: ['./organization.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => OrganizationComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => OrganizationComponent),\n      multi: true\n    }\n  ]\n})\nexport class OrganizationComponent implements ControlValueAccessor, AfterContentChecked, Validator {\n\n  @ViewChild('autocomplete') autoCompleteInput: AutoComplete;\n\n  icon = {\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>',\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>'\n  }\n\n  remoteUrl = '/organization/query?q=';\n  minLength = 2;\n  wildCard = '*';\n  @HostBinding('class.readonly') _readonly: boolean;\n\n  @Output()\n  onValueResolved = new EventEmitter();\n  // emitted when value changed holding the resolved data_meta\n  @Output()\n  onDataMetaChanged = new EventEmitter();\n\n  autocompleteRes: any[];\n  // model value\n  value;\n  currentUserId: string;\n  // inner ng-model value\n  innerValue: any[] = [];\n  error: any = {};\n  deletedItemID: string;\n  private _removeCurrentUser: boolean = false;\n  @Input() set removeCurrentUser(b: boolean) {\n    this._removeCurrentUser = b;\n    this.currentUserId = b ? this.userService.getCurrentUser()?.id : undefined;\n  }\n  get removeCurrentUser() {\n    return this._removeCurrentUser\n  }\n  @Input() situation: string;\n  @Input() multiselect: boolean;\n  @Input() set readonly(r: boolean) {\n    this._readonly = r;\n  }\n  get readonly() {\n    return this._readonly;\n  }\n  @Input() set dataMeta(dM: any) {\n    if (dM) {\n      this.innerValue = Array.isArray(dM) ? dM : [dM];\n    }\n  }\n  @Input() placeholder: string;\n  // list of values that should not be selectable\n  @Input() exceptions: string[] = [];\n  @Input() filterObject: OrganizationFilter;\n\n  constructor(private backend: BackendService,\n    private translate: TranslateService,\n    private systemService: SystemService,\n    public userService: UserService,\n  ) { }\n\n  public validate() {\n    return null;\n  }\n\n  private buildAutocompleteUri(query: string): string {\n    const params = {\n      q: query,\n      activeonly: (this.situation !== 'SEARCH') ? 'true' : 'false',\n      details: true\n    };\n\n    if (this.filterObject) {\n      if (this.filterObject.type) {\n        params['scope'] = this.filterObject.type;\n      }\n      if (this.filterObject.groups) {\n        params['groupfilter'] = this.filterObject.groups;\n      }\n      if (this.filterObject.roles) {\n        params['rolefilter'] = this.filterObject.roles;\n      }\n      if (this.filterObject.hasOwnProperty('activeonly')) {\n        params['activeonly'] = this.filterObject.activeonly ? 'true' : 'false' ;\n      }\n    }\n    return Utils.buildUri('/organization/query', params);\n  }\n\n  propagateChange = (_: any) => {\n  }\n\n  writeValue(value: any): void {\n    if (value) {\n      this.value = value;\n      this.resolveFn(value);\n    } else {\n      this.value = null;\n      this.innerValue = [];\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  private propagate() {\n    this.propagateChange(this.value);\n    this.onDataMetaChanged.emit(this.innerValue);\n  }\n\n  autocompleteFn(term: string) {\n    if (term.length >= this.minLength || term === this.wildCard) {\n      if (this.multiselect || (!this.multiselect && this.innerValue.length === 0)) {\n        this.backend.getJson(this.buildAutocompleteUri(term))\n          .subscribe((res) => {\n            // autocomplete values should be unique and not part of the exceptions\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))\n              .sort(Utils.sortValues('title')).slice(0, 10);\n          },\n            Utils.throw(null,\n              this.translate.instant('eo.form.property.organization.request.error.title'),\n              this.translate.instant('eo.form.property.organization.request.error.msg')\n            )\n          );\n      } else {\n        this.autocompleteRes = [];\n      }\n    } else {\n      this.autocompleteRes = [];\n    }\n  }\n\n  resolveFn(value: any): Subscription {\n    let map = (value instanceof Array ? value : [value]).map(v => {\n      let match = this.innerValue.find(iv => iv.name === v);\n      return match ? observableOf(match) : this.systemService.getOrganizationObject(v);\n    });\n    return observableForkJoin(map).subscribe(data => {\n      this.innerValue = data;\n      this.onValueResolved.emit(this.innerValue);\n    });\n  }\n\n  // handle selection changes to the model\n  onUnselect(value) {\n    this.innerValue = this.innerValue.filter(v => v.name !== value.name);\n    let _value = this.innerValue.map(v => v.name);\n    this.value = this.multiselect ? _value : null;\n    if (!this.multiselect) {\n      this.clearInnerInput();\n    }\n    this.autoCompleteInput.focusInput();\n    this.propagate();\n  }\n\n  // handle selection changes to the model\n  onSelect(value) {\n    if (this.multiselect) {\n      this.value = this.innerValue.map(v => v.name);\n    } else {\n      // internal autocomplete control is always set to multiselect\n      // so the resolved value is always an array\n      this.value = this.innerValue[0].name;\n    }\n    this.propagate();\n  }\n\n  onAutoCompleteBlur() {\n    this.clearInnerInput();\n  }\n\n  private clearInnerInput() {\n    this.autoCompleteInput.clearInput();\n  }\n\n  ngAfterContentChecked() {\n    if (this.situation === 'SEARCH') {\n      this.multiselect = true;\n    }\n  }\n}\n","<div class=\"eo-organization\" [ngClass]=\"{acInputHidden: !multiselect && innerValue.length}\">\n\n  <yvc-autocomplete [(ngModel)]=\"innerValue\" #autocomplete (suggestionSelect)=\"onSelect($event)\"\n    [placeholder]=\"placeholder\" (suggestionUnselect)=\"onUnselect($event)\" (blur)=\"onAutoCompleteBlur()\"\n    [disabled]=\"readonly\" [autocompleteValues]=\"autocompleteRes\" field=\"id\"\n    [forceSelection]=\"true\"\n    (autocompleteFnc)=\"autocompleteFn($event)\" [multiple]=\"true\">\n\n    <ng-template #autocompleteOptionTemplate let-item>\n      <div class=\"org-item\">\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\n        <span *ngIf=\"(item.firstname?.length && item.lastname?.length) || item.type === 'group'\">{{item.title}}\n          ({{item.name}})</span>\n        <span *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.type !== 'group'\">({{item.name}})</span>\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\n      </div>\n    </ng-template>\n\n    <ng-template #chipTemplate let-item>\n      <div class=\"org-item\">\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\n        <span\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && item.active) || item.type === 'group'\">{{item.title}}\n          ({{item.name}})</span>\n        <span class=\"inactive\"\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && !item.active)\">{{item.title}}\n          ({{item.name}})</span>\n        <span *ngIf=\"(!item.firstname?.length && !item.lastname?.length && !item.active && !item.type)\"\n          class=\"deleted-user-label\">{{'eo.form.property.organization.error.usernotfound'|translate}}</span>\n        <span\n          *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.active && item.type !== 'group'\">({{item.name}})</span>\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\n      </div>\n    </ng-template>\n\n  </yvc-autocomplete>\n</div>\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 {\n  AfterContentChecked,\n  Component,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator} from '@angular/forms';\nimport {BackendService, SystemService, TranslateService, UserService, Utils} from '@eo-sdk/core';\nimport {AutoComplete} from '@yuuvis/components/autocomplete';\nimport {forkJoin as observableForkJoin, of as observableOf, Subscription} from 'rxjs';\n\nexport interface OrganizationFilter {\n  type?: string;        // The type of the organization unit ('USER' or 'GROUP') to be displayed\n  groups?: string[];    // an array of group names to filter autocomplete results with\n  roles?: string[];     // an array of role names to filter autocomplete results with\n  activeonly?: boolean; // whether or not to fetch only active organization objects\n}\n\n@Component({\n  selector: 'eo-organization',\n  templateUrl: './organization.component.html',\n  styleUrls: ['./organization.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => OrganizationComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => OrganizationComponent),\n      multi: true\n    }\n  ]\n})\nexport class OrganizationComponent implements ControlValueAccessor, AfterContentChecked, Validator {\n\n  @ViewChild('autocomplete') autoCompleteInput: AutoComplete;\n\n  icon = {\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>',\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>'\n  }\n\n  remoteUrl = '/organization/query?q=';\n  minLength = 2;\n  wildCard = '*';\n  @HostBinding('class.readonly') _readonly: boolean;\n\n  @Output()\n  onValueResolved = new EventEmitter();\n  // emitted when value changed holding the resolved data_meta\n  @Output()\n  onDataMetaChanged = new EventEmitter();\n\n  autocompleteRes: any[];\n  // model value\n  value;\n  currentUserId: string;\n  // inner ng-model value\n  innerValue: any[] = [];\n  error: any = {};\n  deletedItemID: string;\n  private _removeCurrentUser: boolean = false;\n  @Input() set removeCurrentUser(b: boolean) {\n    this._removeCurrentUser = b;\n    this.currentUserId = b ? this.userService.getCurrentUser()?.id : undefined;\n  }\n  get removeCurrentUser() {\n    return this._removeCurrentUser\n  }\n  @Input() situation: string;\n  @Input() multiselect: boolean;\n  @Input() set readonly(r: boolean) {\n    this._readonly = r;\n  }\n  get readonly() {\n    return this._readonly;\n  }\n  @Input() set dataMeta(dM: any) {\n    if (dM) {\n      this.innerValue = Array.isArray(dM) ? dM : [dM];\n    }\n  }\n  autocompleteTimeout: any\n  @Input() placeholder: string;\n  // list of values that should not be selectable\n  @Input() exceptions: string[] = [];\n  @Input() filterObject: OrganizationFilter;\n\n  constructor(private backend: BackendService,\n    private translate: TranslateService,\n    private systemService: SystemService,\n    public userService: UserService,\n  ) { }\n\n  public validate() {\n    return null;\n  }\n\n  private buildAutocompleteUri(query: string): string {\n    const params = {\n      q: query,\n      activeonly: (this.situation !== 'SEARCH') ? 'true' : 'false',\n      details: true\n    };\n\n    if (this.filterObject) {\n      if (this.filterObject.type) {\n        params['scope'] = this.filterObject.type;\n      }\n      if (this.filterObject.groups) {\n        params['groupfilter'] = this.filterObject.groups;\n      }\n      if (this.filterObject.roles) {\n        params['rolefilter'] = this.filterObject.roles;\n      }\n      if (this.filterObject.hasOwnProperty('activeonly')) {\n        params['activeonly'] = this.filterObject.activeonly ? 'true' : 'false' ;\n      }\n    }\n    return Utils.buildUri('/organization/query', params);\n  }\n\n  propagateChange = (_: any) => {\n  }\n\n  writeValue(value: any): void {\n    if (value) {\n      this.value = value;\n      this.resolveFn(value);\n    } else {\n      this.value = null;\n      this.innerValue = [];\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  private propagate() {\n    this.propagateChange(this.value);\n    this.onDataMetaChanged.emit(this.innerValue);\n  }\n\n  autocompleteFn(term: string) {\n    clearTimeout(this.autocompleteTimeout);\n    this.autocompleteTimeout = setTimeout(() => {\n      if (term.length >= this.minLength || term === this.wildCard) {\n        if (this.multiselect || (!this.multiselect && this.innerValue.length === 0)) {\n          this.backend.getJson(this.buildAutocompleteUri(term))\n            .subscribe((res) => {\n              // autocomplete values should be unique and not part of the exceptions\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))\n                .sort(Utils.sortValues('title')).slice(0, 10);\n              },\n              Utils.throw(null,\n                this.translate.instant('eo.form.property.organization.request.error.title'),\n                this.translate.instant('eo.form.property.organization.request.error.msg')\n              )\n            );\n        } else {\n          this.autocompleteRes = [];\n        }\n      } else {\n        this.autocompleteRes = [];\n      }\n    }, 1000);\n  }\n\n  resolveFn(value: any): Subscription {\n    let map = (value instanceof Array ? value : [value]).map(v => {\n      let match = this.innerValue.find(iv => iv.name === v);\n      return match ? observableOf(match) : this.systemService.getOrganizationObject(v);\n    });\n\n    if (map.length === 0) {\n      this.innerValue = [];\n      this.onValueResolved.emit(this.innerValue);\n    } else {\n      return observableForkJoin(map).subscribe(data => {\n        this.innerValue = data;\n        this.onValueResolved.emit(this.innerValue);\n      });\n    }\n  }\n\n  // handle selection changes to the model\n  onUnselect(value) {\n    this.innerValue = this.innerValue.filter(v => v.name !== value.name);\n    let _value = this.innerValue.map(v => v.name);\n    this.value = this.multiselect ? _value : null;\n    if (!this.multiselect) {\n      this.clearInnerInput();\n    }\n    this.autoCompleteInput.focusInput();\n    this.propagate();\n  }\n\n  // handle selection changes to the model\n  onSelect(value) {\n    if (this.multiselect) {\n      this.value = this.innerValue.map(v => v.name);\n    } else {\n      // internal autocomplete control is always set to multiselect\n      // so the resolved value is always an array\n      this.value = this.innerValue[0].name;\n    }\n    this.propagate();\n  }\n\n  onAutoCompleteBlur() {\n    this.clearInnerInput();\n  }\n\n  private clearInnerInput() {\n    this.autoCompleteInput.clearInput();\n  }\n\n  ngAfterContentChecked() {\n    if (this.situation === 'SEARCH') {\n      this.multiselect = true;\n    }\n  }\n}\n","<div class=\"eo-organization\" [ngClass]=\"{acInputHidden: !multiselect && innerValue.length}\">\n\n  <yvc-autocomplete [(ngModel)]=\"innerValue\" #autocomplete (suggestionSelect)=\"onSelect($event)\"\n    [placeholder]=\"placeholder\" (suggestionUnselect)=\"onUnselect($event)\" (blur)=\"onAutoCompleteBlur()\"\n    [disabled]=\"readonly\" [autocompleteValues]=\"autocompleteRes\" field=\"id\"\n    [forceSelection]=\"true\"\n    (autocompleteFnc)=\"autocompleteFn($event)\" [multiple]=\"true\">\n\n    <ng-template #autocompleteOptionTemplate let-item>\n      <div class=\"org-item\">\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\n        <span *ngIf=\"(item.firstname?.length && item.lastname?.length) || item.type === 'group'\">{{item.title}}\n          ({{item.name}})</span>\n        <span *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.type !== 'group'\">({{item.name}})</span>\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\n      </div>\n    </ng-template>\n\n    <ng-template #chipTemplate let-item>\n      <div class=\"org-item\">\n        <yvc-icon [svg]=\"item.type === 'group' ?  icon.group : icon.user\"></yvc-icon>\n        <span\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && item.active) || item.type === 'group'\">{{item.title}}\n          ({{item.name}})</span>\n        <span class=\"inactive\"\n          *ngIf=\"(item.firstname?.length && item.lastname?.length && !item.active)\">{{item.title}}\n          ({{item.name}})</span>\n        <span *ngIf=\"(!item.firstname?.length && !item.lastname?.length && !item.active && !item.type)\"\n          class=\"deleted-user-label\">{{'eo.form.property.organization.error.usernotfound'|translate}}</span>\n        <span\n          *ngIf=\"!item.firstname?.length && !item.lastname?.length && item.active && item.type !== 'group'\">({{item.name}})</span>\n        <span *ngIf=\"!item.firstname?.length && item.lastname?.length\">{{item.lastname}} ({{item.name}})</span>\n        <span *ngIf=\"item.firstname?.length && !item.lastname?.length\">{{item.firstname}} ({{item.name}})</span>\n      </div>\n    </ng-template>\n\n  </yvc-autocomplete>\n</div>\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\">\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\n</header>\n<div class=\"flex-row\">\n <eo-form-input>\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\n </eo-form-input>\n <eo-icon class=\"save-filter-icon\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\n (click)=\"saveFilter(value)\"\n [iconTitle]=\"'eo.filter.save' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\n</div>\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\n <div class=\"saved-filters-container\">\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\n [iconTitle]=\"'eo.filter.delete' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\n </div>\n </div>\n</div>\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\">\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\n</header>\n<div class=\"flex-row\">\n <eo-form-input>\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\n </eo-form-input>\n <eo-icon class=\"save-filter-icon\" [tabindex]=\"(!value || savedFilters.includes(value)) ? '-1' : '0'\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\n (click)=\"saveFilter(value)\"\n (keydown.enter)=\"saveFilter(value)\"\n [iconTitle]=\"'eo.filter.save' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\n</div>\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\n <div class=\"saved-filters-container\">\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\n [iconTitle]=\"'eo.filter.delete' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\n </div>\n </div>\n</div>\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\">\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\n</header>\n<div class=\"flex-row\">\n <eo-form-input>\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\n </eo-form-input>\n <eo-icon class=\"save-filter-icon\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\n (click)=\"saveFilter(value)\"\n [iconTitle]=\"'eo.filter.save' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\n</div>\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\n <div class=\"saved-filters-container\">\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\n [iconTitle]=\"'eo.filter.delete' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\n </div>\n </div>\n</div>\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\">\n <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\n</header>\n<div class=\"flex-row\">\n <eo-form-input>\n <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\n placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\n </eo-form-input>\n <eo-icon class=\"save-filter-icon\" [tabindex]=\"(!value || savedFilters.includes(value)) ? '-1' : '0'\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\n (click)=\"saveFilter(value)\"\n (keydown.enter)=\"saveFilter(value)\"\n [iconTitle]=\"'eo.filter.save' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\n</div>\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\n <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\n <div class=\"saved-filters-container\">\n <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\n <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\n <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\n [iconTitle]=\"'eo.filter.delete' | translate\"\n [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\n </div>\n </div>\n</div>\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';\nimport {IFilterParams, IRowNode, RowNode} from '@ag-grid-community/core';\nimport {ListSettingsService} from '../../services/list-settings.service';\nimport {AbstractFilterComponent} from '../abstract-filter.component';\nimport {LocalStorageService, UserService, Utils} from '@eo-sdk/core';\n\n@Component({\n  selector: 'eo-text-filter',\n  templateUrl: './text-filter.component.html',\n  styleUrls: ['./text-filter.component.scss']\n})\nexport class TextFilterComponent extends AbstractFilterComponent {\n\n  @Input() title = '';\n  @Input() placeholder = 'eo.filter.input.placeholder';\n  @Input() enableSave = false;\n  private focused = false;\n  savedFilters = [];\n\n  @Input() set filterParams(params: IFilterParams) {\n    super.filterParams = params;\n  }\n\n  @Input()\n  set matchFields(fields: string[]) {\n    this.valueGetter = (rowNode: IRowNode) => fields.map(f => Utils.getProperty(rowNode.data, f)).join('\\n');\n    const value = this.defaultValue || this.settingsService.setupSettings(this.id, [{id: 'text', value: this.value}])[0].value;\n    setTimeout(() => this.onChange(value), 0);\n  }\n\n  constructor(private settingsService: ListSettingsService,\n              private storageService: LocalStorageService,\n              private userService: UserService) {\n    super();\n    this.id = '#text';\n    this.getSavedFilters();\n  }\n\n  onChange(newValue, oldValue?): void {\n    if (this.value !== newValue) {\n      this.value = newValue;\n      if (!this.defaultValue) {\n        this.settingsService.saveSettings(this.id, this.value ? {'text': this.value} : '');\n      }\n      this.params.filterChangedCallback();\n    }\n  }\n\n  doesExternalFilterPass(rowNode: IRowNode): boolean {\n    const filterTerms = this.value.toLowerCase().split(' ');\n    const rowValue = this.valueGetter(rowNode).toString().toLowerCase();\n    const everyTermFound = !filterTerms.find(term => rowValue.indexOf(term) === -1);\n    return everyTermFound;\n  }\n\n  reset() {\n    super.reset();\n    this.settingsService.saveSettings(this.id);\n  }\n\n  focusout () {\n    this.focused = false;\n  }\n\n  getSavedFilters() {\n    if (this.userService.getCurrentUser().userSettings.savedInboxFilter) {\n      this.savedFilters = this.userService.getCurrentUser().userSettings.savedInboxFilter;\n    } else {\n      this.savedFilters = this.storageService.getItem('eo.inbox.filter.suggestions') ? this.storageService.getItem('eo.inbox.filter.suggestions') : [];\n    }\n  }\n\n  saveFilter(term: string) {\n    if (term && !this.savedFilters.includes(term)) {\n      this.savedFilters.push(term);\n      this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\n    }\n  }\n\n  removeFilter(term: string) {\n    this.savedFilters = this.savedFilters.filter(t => t !== term);\n    this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\n  }\n\n  focus () {\n    if (!this.focused) {\n      this.focused = true;\n\n      // Timeout for cross browser compatibility (Chrome)\n      setTimeout(() => { document.execCommand('selectall', false, null); });\n    }\n  }\n}\n","<header class=\"filter__header\">\n  <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\n</header>\n<div class=\"flex-row\">\n  <eo-form-input>\n    <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\n           placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\n  </eo-form-input>\n  <eo-icon class=\"save-filter-icon\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\n           (click)=\"saveFilter(value)\"\n           [iconTitle]=\"'eo.filter.save' | translate\"\n           [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\n</div>\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\n  <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\n  <div class=\"saved-filters-container\">\n    <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\n      <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\n      <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\n               [iconTitle]=\"'eo.filter.delete' | translate\"\n               [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\n    </div>\n  </div>\n</div>\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';\nimport {IFilterParams, IRowNode, RowNode} from '@ag-grid-community/core';\nimport {ListSettingsService} from '../../services/list-settings.service';\nimport {AbstractFilterComponent} from '../abstract-filter.component';\nimport {LocalStorageService, UserService, Utils} from '@eo-sdk/core';\n\n@Component({\n  selector: 'eo-text-filter',\n  templateUrl: './text-filter.component.html',\n  styleUrls: ['./text-filter.component.scss']\n})\nexport class TextFilterComponent extends AbstractFilterComponent {\n\n  @Input() title = '';\n  @Input() placeholder = 'eo.filter.input.placeholder';\n  @Input() enableSave = false;\n  private focused = false;\n  savedFilters = [];\n\n  @Input() set filterParams(params: IFilterParams) {\n    super.filterParams = params;\n  }\n\n  @Input()\n  set matchFields(fields: string[]) {\n    this.valueGetter = (rowNode: IRowNode) => fields.map(f => Utils.getProperty(rowNode.data, f)).join('\\n');\n    const value = this.defaultValue || this.settingsService.setupSettings(this.id, [{id: 'text', value: this.value}])[0].value;\n    setTimeout(() => this.onChange(value), 0);\n  }\n\n  constructor(private settingsService: ListSettingsService,\n              private storageService: LocalStorageService,\n              private userService: UserService) {\n    super();\n    this.id = '#text';\n    this.getSavedFilters();\n  }\n\n  onChange(newValue, oldValue?): void {\n    if (this.value !== newValue) {\n      this.value = newValue;\n      if (!this.defaultValue) {\n        this.settingsService.saveSettings(this.id, this.value ? {'text': this.value} : '');\n      }\n      this.params.filterChangedCallback();\n    }\n  }\n\n  doesExternalFilterPass(rowNode: IRowNode): boolean {\n    const filterTerms = this.value.toLowerCase().split(' ');\n    const rowValue = this.valueGetter(rowNode).toString().toLowerCase();\n    const everyTermFound = !filterTerms.find(term => rowValue.indexOf(term) === -1);\n    return everyTermFound;\n  }\n\n  reset() {\n    super.reset();\n    this.settingsService.saveSettings(this.id);\n  }\n\n  focusout () {\n    this.focused = false;\n  }\n\n  getSavedFilters() {\n    if (this.userService.getCurrentUser().userSettings.savedInboxFilter) {\n      this.savedFilters = this.userService.getCurrentUser().userSettings.savedInboxFilter;\n    } else {\n      this.savedFilters = this.storageService.getItem('eo.inbox.filter.suggestions') ? this.storageService.getItem('eo.inbox.filter.suggestions') : [];\n    }\n  }\n\n  saveFilter(term: string) {\n    if (term && !this.savedFilters.includes(term)) {\n      this.savedFilters.push(term);\n      this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\n    }\n  }\n\n  removeFilter(term: string) {\n    this.savedFilters = this.savedFilters.filter(t => t !== term);\n    this.userService.changeSavedInboxFilters(this.savedFilters).subscribe();\n  }\n\n  focus () {\n    if (!this.focused) {\n      this.focused = true;\n\n      // Timeout for cross browser compatibility (Chrome)\n      setTimeout(() => { document.execCommand('selectall', false, null); });\n    }\n  }\n}\n","<header class=\"filter__header\">\n  <h3 class=\"filter__title title\" *ngIf=\"title\">{{title}}</h3>\n</header>\n<div class=\"flex-row\">\n  <eo-form-input>\n    <input (ngModelChange)=\"onChange($event)\" [ngModel]=\"value\" class=\"form-control\"\n           placeholder=\"{{ placeholder | translate}}\" (focus)=\"focus()\" (focusout)=\"focusout()\">\n  </eo-form-input>\n  <eo-icon class=\"save-filter-icon\" [tabindex]=\"(!value || savedFilters.includes(value)) ? '-1' : '0'\" *ngIf=\"enableSave\" [ngClass]=\"{'disable-save-filter': !value || savedFilters.includes(value)}\"\n           (click)=\"saveFilter(value)\"\n           (keydown.enter)=\"saveFilter(value)\"\n           [iconTitle]=\"'eo.filter.save' | translate\"\n           [iconSrc]=\"'assets/_default/svg/ic_add.svg'\"></eo-icon>\n</div>\n<div *ngIf=\"enableSave && savedFilters && savedFilters.length !== 0\">\n  <h4 class=\"filter__title saved-filters-title\" translate>eo.filter.save.title</h4>\n  <div class=\"saved-filters-container\">\n    <div class=\"saved-filter flex-row\" *ngFor=\"let savedFilter of savedFilters\">\n      <span class=\"saved-filter-text\" (click)=\"onChange(savedFilter, value)\">{{savedFilter}}</span>\n      <eo-icon class=\"remove-filter-icon\" (click)=\"removeFilter(savedFilter)\"\n               [iconTitle]=\"'eo.filter.delete' | translate\"\n               [iconSrc]=\"'assets/_default/svg/ic_trash.svg'\"></eo-icon>\n    </div>\n  </div>\n</div>\n"]}