@eo-sdk/client 8.2.0 → 8.4.0-rc.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.
Files changed (25) hide show
  1. package/app/eo-framework/form-elements/id-reference/id-reference.component.d.ts +14 -3
  2. package/bundles/eo-sdk-client-projects-eo-sdk-core.umd.js +8 -5
  3. package/bundles/eo-sdk-client-projects-eo-sdk-core.umd.js.map +1 -1
  4. package/bundles/eo-sdk-client-projects-eo-sdk-core.umd.min.js +2 -2
  5. package/bundles/eo-sdk-client-projects-eo-sdk-core.umd.min.js.map +1 -1
  6. package/bundles/eo-sdk-client.umd.js +85 -13
  7. package/bundles/eo-sdk-client.umd.js.map +1 -1
  8. package/bundles/eo-sdk-client.umd.min.js +1 -1
  9. package/bundles/eo-sdk-client.umd.min.js.map +1 -1
  10. package/eo-sdk-client.metadata.json +1 -1
  11. package/esm2015/app/eo-client/about-state/about-state.component.js +3 -3
  12. package/esm2015/app/eo-framework/form-elements/id-reference/id-reference.component.js +76 -9
  13. package/esm2015/app/eo-framework/object-form/object-form/form-element/form-element.component.js +2 -2
  14. package/esm2015/app/eo-framework/object-form/object-form/object-form-script/object-form-scripting-scope.js +3 -3
  15. package/esm2015/app/eo-framework/object-form/object-form/object-form.component.js +3 -2
  16. package/esm2015/app/eo-framework/process/history/process-history.component.js +2 -2
  17. package/esm2015/projects/eo-sdk/core/lib/config/translate-json-loader.js +4 -1
  18. package/esm2015/projects/eo-sdk/core/lib/model/eo-user.model.js +2 -2
  19. package/fesm2015/eo-sdk-client-projects-eo-sdk-core.js +4 -1
  20. package/fesm2015/eo-sdk-client-projects-eo-sdk-core.js.map +1 -1
  21. package/fesm2015/eo-sdk-client.js +80 -13
  22. package/fesm2015/eo-sdk-client.js.map +1 -1
  23. package/package.json +2 -2
  24. package/projects/eo-sdk/core/eo-sdk-client-projects-eo-sdk-core.metadata.json +1 -1
  25. package/projects/eo-sdk/core/package.json +1 -1
@@ -6789,16 +6789,28 @@ InputFocusDirective.propDecorators = {
6789
6789
  };
6790
6790
 
6791
6791
  class IdReferenceComponent {
6792
- constructor(clipboardService, system, referenceService) {
6792
+ constructor(clipboardService, system, referenceService, searchService) {
6793
6793
  this.clipboardService = clipboardService;
6794
6794
  this.system = system;
6795
6795
  this.referenceService = referenceService;
6796
- this.innerValues = []; // inner ng-model value
6796
+ this.searchService = searchService;
6797
+ this._innerValues = []; // inner ng-model value
6797
6798
  this.visibleDialog = false;
6798
6799
  this.propagateChange = (value) => { };
6799
6800
  this.clipboardService.clipboard$.subscribe(clipboard => (this.clipboard = clipboard));
6800
6801
  this.clipboard = this.clipboardService.get();
6801
6802
  }
6803
+ set innerValues(data) {
6804
+ if (data) {
6805
+ this._innerValues = data;
6806
+ }
6807
+ else {
6808
+ this._innerValues = [];
6809
+ }
6810
+ }
6811
+ get innerValues() {
6812
+ return this._innerValues;
6813
+ }
6802
6814
  set dataToRender(data) {
6803
6815
  if (data) {
6804
6816
  this.innerValues = data;
@@ -6906,6 +6918,57 @@ class IdReferenceComponent {
6906
6918
  validate(c) {
6907
6919
  return null;
6908
6920
  }
6921
+ // handler invoked when an entry was selected using the autocomplete input
6922
+ onAutoCompleteSelect(evt) {
6923
+ if (!Array.isArray(this.innerValues)) {
6924
+ this.innerValues = [this.innerValues];
6925
+ }
6926
+ this.innerValues = uniqBy(this.innerValues, 'id');
6927
+ if (this.multiselect) {
6928
+ this.value = this.innerValues.map(iv => iv.id);
6929
+ }
6930
+ else {
6931
+ this.value = this.innerValues[0].id;
6932
+ }
6933
+ this.propagateChange(this.value);
6934
+ }
6935
+ autocompleteFn(evt) {
6936
+ let q = {
6937
+ fields: ['title', 'description', 'type'],
6938
+ types: [this.referenceType.name],
6939
+ term: evt.query,
6940
+ highlighting: true,
6941
+ filters: this.queryFilters,
6942
+ options: { withContext: true }
6943
+ };
6944
+ if (this.objectTypesFilter) {
6945
+ q.types = this.objectTypesFilter;
6946
+ }
6947
+ if (this.contextId) {
6948
+ if (q.filters) {
6949
+ q.filters.contextfolderid = { v1: this.contextId, o: 'eq' };
6950
+ }
6951
+ else {
6952
+ q.filters = { contextfolderid: { v1: this.contextId, o: 'eq' } };
6953
+ }
6954
+ }
6955
+ this.searchService
6956
+ .executeQuery(q)
6957
+ .pipe(debounceTime(500), map(item => item ? this.searchService.createResultFromResponse(item) : [])).subscribe((result) => {
6958
+ this.autocompleteRes = result.hits;
6959
+ });
6960
+ }
6961
+ onAutoCompleteBlur() {
6962
+ this.clearInnerInput();
6963
+ }
6964
+ clearInnerInput() {
6965
+ if (this.autoCompleteInput.multiInputEL) {
6966
+ this.autoCompleteInput.multiInputEL.nativeElement.value = '';
6967
+ }
6968
+ else {
6969
+ this.autoCompleteInput.inputEL.nativeElement.value = '';
6970
+ }
6971
+ }
6909
6972
  ngOnInit() {
6910
6973
  if (this.situation === 'SEARCH') {
6911
6974
  this.multiselect = true;
@@ -6915,7 +6978,7 @@ class IdReferenceComponent {
6915
6978
  IdReferenceComponent.decorators = [
6916
6979
  { type: Component, args: [{
6917
6980
  selector: 'eo-id-reference',
6918
- template: "<div class=\"eo-id-reference\">\r\n\r\n <div class=\"eo-id-reference__element\" *ngIf=\"referenceType; else notFound\">\r\n <div *ngFor=\"let item of innerValues\" class=\"chip\">\r\n <a *ngIf=\"!item.state || item.state === 'OK'\" class=\"link router-link\" [routerLink]=\"['/object', item.id, {outlets: {modal: null}}]\" [queryParams]=\"{type: referenceType.qname}\">\r\n <svg focusable=\"false\" class=\"ref-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n viewBox=\"0 0 24 24\">\r\n <path d=\"M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8\r\n 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z\"></path>\r\n </svg>\r\n </a>\r\n <eo-icon [objectType]=\"referenceType\" title=\"{{referenceType.label}}\" class=\"ref-type-icon\" [ngClass]=\"{'deleted-reference-label': item.state && (item.state === 'RECYCLED' || item.state === 'GONE')}\"></eo-icon>\r\n <span *ngIf=\"!(item.state && (item.state === 'RECYCLED' || item.state === 'GONE')); else deleted\" class=\"label\">{{item.title || referenceType.label}}</span>\r\n <ng-template #deleted>\r\n <span class=\"label deleted-reference-label\">{{('eo.references.deleted' | translate)}}</span>\r\n </ng-template>\r\n <eo-icon *ngIf=\"!readonly\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"removeItem(item)\" class=\"remove-icon\"></eo-icon>\r\n </div>\r\n </div>\r\n\r\n <ng-template #notFound><span class=\"label\">{{innerValues && innerValues.length ? ('eo.references.not.available' | translate) : ''}}</span></ng-template>\r\n\r\n <button #button class=\"ui-button\" *ngIf=\"!readonly\"\r\n title=\"{{('eo.references.search' | translate) + ' ' + tooltipTypeHint}}\"\r\n [disabled]=\"selectionDisabled\"\r\n (click)=\"showDialog()\">\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_none.svg'\"></eo-icon>\r\n </button>\r\n</div>\r\n\r\n<eo-dialog [title]=\"('eo.references.add' | translate)\"\r\n [subtitle]=\"referenceType.label\"\r\n [(visible)]=\"visibleDialog\"\r\n [minWidth]=\"577\"\r\n [minHeight]=\"590\"\r\n [styleClass]=\"'reference-field-dialog'\"\r\n #dialog>\r\n\r\n <eo-reference-finder *ngIf=\"dialog.visible\"\r\n [isDisabled]=\"isDisabled\"\r\n [types]=\"referenceType.qname\"\r\n [multiselect]=\"multiselect\"\r\n [currentSelection]=\"innerValues\"\r\n [clipboard]=\"clipboard\"\r\n [contextId]=\"contextId\"\r\n [exceptionIDs]=\"exceptionIDs\"\r\n [queryFilters]=\"queryFilters\"\r\n (addDmsObjects)=\"paste($event)\">\r\n </eo-reference-finder>\r\n</eo-dialog>\r\n",
6981
+ template: "<div class=\"eo-id-reference\">\r\n <p-autoComplete [(ngModel)]=\"innerValues\" [minLength]=\"1\" [delay]=\"500\" #autocomplete\r\n (onSelect)=\"onAutoCompleteSelect($event)\"\r\n (onUnselect)=\"removeItem($event)\"\r\n (onBlur)=\"onAutoCompleteBlur()\"\r\n [suggestions]=\"autocompleteRes\" field=\"title\"\r\n [readonly]=\"readonly\"\r\n [forceSelection]=\"true\"\r\n (completeMethod)=\"autocompleteFn($event)\" [multiple]=\"true\" [styleClass]=\"!multiselect && innerValues.length === 1 ? 'xxx' : ''\">\r\n <ng-template pTemplate=\"selectedItem\" let-item>\r\n <a *ngIf=\"!item.state || item.state === 'OK'\" class=\"link router-link\" [routerLink]=\"['/object', item.id, {outlets: {modal: null}}]\" [queryParams]=\"{type: referenceType.qname}\">\r\n <svg focusable=\"false\" class=\"ref-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n viewBox=\"0 0 24 24\">\r\n <path d=\"M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8\r\n 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z\"></path>\r\n </svg>\r\n </a>\r\n <eo-icon [objectType]=\"referenceType\" title=\"{{referenceType.label}}\" class=\"ref-type-icon\" [ngClass]=\"{'deleted-reference-label': item.state && (item.state === 'RECYCLED' || item.state === 'GONE')}\"></eo-icon>\r\n <span *ngIf=\"!(item.state && (item.state === 'RECYCLED' || item.state === 'GONE')); else deleted\" class=\"label\">{{item.title || referenceType.label}}</span>\r\n <ng-template #deleted>\r\n <span class=\"label deleted-reference-label\">{{('eo.references.deleted' | translate)}}</span>\r\n </ng-template>\r\n </ng-template>\r\n </p-autoComplete>\r\n\r\n <ng-template #notFound><span class=\"label\">{{innerValues && innerValues.length ? ('eo.references.not.available' | translate) : ''}}</span></ng-template>\r\n\r\n <button #button class=\"ui-button\" *ngIf=\"!readonly\"\r\n title=\"{{('eo.references.search' | translate) + ' ' + tooltipTypeHint}}\"\r\n [disabled]=\"selectionDisabled\"\r\n (click)=\"showDialog()\">\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_none.svg'\"></eo-icon>\r\n </button>\r\n</div>\r\n\r\n<eo-dialog [title]=\"('eo.references.add' | translate)\"\r\n [subtitle]=\"referenceType.label\"\r\n [(visible)]=\"visibleDialog\"\r\n [minWidth]=\"577\"\r\n [minHeight]=\"590\"\r\n [styleClass]=\"'reference-field-dialog'\"\r\n #dialog>\r\n\r\n <eo-reference-finder *ngIf=\"dialog.visible\"\r\n [isDisabled]=\"isDisabled\"\r\n [types]=\"referenceType.qname\"\r\n [multiselect]=\"multiselect\"\r\n [currentSelection]=\"innerValues\"\r\n [clipboard]=\"clipboard\"\r\n [contextId]=\"contextId\"\r\n [exceptionIDs]=\"exceptionIDs\"\r\n [queryFilters]=\"queryFilters\"\r\n (addDmsObjects)=\"paste($event)\">\r\n </eo-reference-finder>\r\n</eo-dialog>\r\n",
6919
6982
  providers: [
6920
6983
  {
6921
6984
  provide: NG_VALUE_ACCESSOR,
@@ -6928,13 +6991,14 @@ IdReferenceComponent.decorators = [
6928
6991
  multi: true
6929
6992
  }
6930
6993
  ],
6931
- styles: [".eo-id-reference{align-items:center;display:flex;justify-content:space-between}.eo-id-reference__element{align-self:center;display:flex;flex-wrap:wrap}.eo-id-reference .chip{align-items:center;display:flex}.eo-id-reference .chip .ref-type-icon{height:16px;margin-right:4px;width:16px}.eo-id-reference .chip .label{display:flex;flex-flow:column;margin-right:4px}.eo-id-reference .chip .label>span{font-size:var(--font-hint)}.eo-id-reference .chip .remove-icon{color:var(--text-color-hint);flex:0 0 auto;height:14px;width:14px}.eo-id-reference .chip .remove-icon:hover{color:var(--text-color-caption);cursor:pointer}.eo-id-reference .chip .deleted-reference-label{color:var(--color-error)}.eo-id-reference .ui-button:disabled{cursor:default}::ng-deep .reference-field-dialog{width:577px}"]
6994
+ styles: [".eo-id-reference{align-items:center;display:flex}.eo-id-reference__element{align-self:center;display:flex;flex-wrap:wrap}.eo-id-reference .ui-button:disabled{cursor:default}::ng-deep .reference-field-dialog{width:577px}::ng-deep .ref-type-icon{height:16px;width:16px}::ng-deep .deleted-reference-label{color:var(--color-error)}::ng-deep .label{display:flex;flex-flow:column;margin-right:10px}::ng-deep .label>span{font-size:var(--font-hint)}::ng-deep .remove-icon{color:var(--text-color-hint);flex:0 0 auto;height:14px;width:14px}::ng-deep .remove-icon:hover{color:var(--text-color-caption);cursor:pointer}::ng-deep .ui-autocomplete.xxx .ui-autocomplete-multiple-container.ui-inputtext{cursor:default}::ng-deep .ui-autocomplete.xxx .ui-autocomplete-input-token{display:none}p-autoComplete{width:100%}"]
6932
6995
  },] }
6933
6996
  ];
6934
6997
  IdReferenceComponent.ctorParameters = () => [
6935
6998
  { type: ClipboardService },
6936
6999
  { type: SystemService },
6937
- { type: ReferenceService }
7000
+ { type: ReferenceService },
7001
+ { type: SearchService }
6938
7002
  ];
6939
7003
  IdReferenceComponent.propDecorators = {
6940
7004
  readonly: [{ type: Input }],
@@ -6942,9 +7006,11 @@ IdReferenceComponent.propDecorators = {
6942
7006
  situation: [{ type: Input }],
6943
7007
  contextId: [{ type: Input }],
6944
7008
  exceptionIDs: [{ type: Input }],
7009
+ autoCompleteInput: [{ type: ViewChild, args: ['autocomplete',] }],
6945
7010
  dataToRender: [{ type: Input }],
6946
7011
  reference: [{ type: Input }],
6947
- queryFilters: [{ type: Input }]
7012
+ queryFilters: [{ type: Input }],
7013
+ objectTypesFilter: [{ type: Input }]
6948
7014
  };
6949
7015
 
6950
7016
  class ReferenceFinderEntryComponent {
@@ -8603,9 +8669,9 @@ class ScopeElement {
8603
8669
  this.originalElement.setFilter(obj);
8604
8670
  }
8605
8671
  }
8606
- setQueryFilters(obj) {
8672
+ setQueryFilters(queryFiltersObject, objectTypes) {
8607
8673
  if (this.originalElement.setQueryFilters) {
8608
- this.originalElement.setQueryFilters(obj);
8674
+ this.originalElement.setQueryFilters(queryFiltersObject, objectTypes);
8609
8675
  }
8610
8676
  }
8611
8677
  get name() {
@@ -9341,8 +9407,9 @@ class ObjectFormComponent extends UnsubscribeOnDestroy {
9341
9407
  };
9342
9408
  }
9343
9409
  if (formElement.type === 'REFERENCE') {
9344
- formControl._eoFormElement.setQueryFilters = (queryFiltersObject) => {
9410
+ formControl._eoFormElement.setQueryFilters = (queryFiltersObject, objectTypes) => {
9345
9411
  formControl._eoFormElement.queryFilters = queryFiltersObject;
9412
+ formControl._eoFormElement.objectTypesFilter = objectTypes;
9346
9413
  };
9347
9414
  }
9348
9415
  if (this.formOptions.formModel.situation === 'SEARCH') {
@@ -9819,7 +9886,7 @@ class FormElementComponent {
9819
9886
  FormElementComponent.decorators = [
9820
9887
  { type: Component, args: [{
9821
9888
  selector: 'eo-form-element',
9822
- template: "<div class=\"form-element\" [formGroup]=\"element\" *ngIf=\"element\">\r\n\r\n <div class=\"form-field t-{{formElementRef._eoFormElement.type}}\" #formField\r\n [ngSwitch]=\"formElementRef._eoFormElement.type\"\r\n [ngClass]=\"{disabled: !!formElementRef._eoFormElement.readonly}\">\r\n\r\n <!-- STRING -->\r\n <eo-form-input *ngSwitchCase=\"'STRING'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-string\r\n *ngIf=\"!formElementRef._eoFormElement.reference && formElementRef._eoFormElement.classification !== 'selector'\"\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [autocomplete]=\"formElementRef._eoFormElement.autocomplete\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [multiline]=\"formElementRef._eoFormElement.multiline\"\r\n [classification]=\"formElementRef._eoFormElement.classification\"\r\n [regex]=\"formElementRef._eoFormElement.regex\"\r\n [qname]=\"formElementRef._eoFormElement.qname\"\r\n [size]=\"formElementRef._eoFormElement.size\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [minLength]=\"formElementRef._eoFormElement.minlen\"\r\n [maxLength]=\"formElementRef._eoFormElement.maxlen\"\r\n ></eo-string>\r\n\r\n <!-- Dynamic List -->\r\n <eo-dynamic-list\r\n *ngIf=\"!formElementRef._eoFormElement.reference && formElementRef._eoFormElement.classification === 'selector'\"\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [filterFunction]=\"formElementRef._eoFormElement.filterFunction\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [listObject]=\"formElementRef._eoFormElement.list\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"></eo-dynamic-list>\r\n\r\n\r\n <!-- Reference -->\r\n <eo-reference *ngIf=\"formElementRef._eoFormElement.reference\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [reference]=\"formElementRef._eoFormElement.reference\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [minLength]=\"formElementRef._eoFormElement.minlen\"\r\n [maxLength]=\"formElementRef._eoFormElement.maxlen\"\r\n ></eo-reference>\r\n </eo-form-input>\r\n\r\n <!-- ID-Reference -->\r\n <eo-form-input *ngSwitchCase=\"'REFERENCE'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-id-reference\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [dataToRender]=\"formElementRef._eoFormElement.dataToRender\"\r\n [reference]=\"formElementRef._eoFormElement.reference\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [contextId]=\"formElementRef._eoFormElement.contextId\"\r\n [exceptionIDs]=\"formElementRef._eoFormElement.exceptionIDs\"\r\n [queryFilters]=\"formElementRef._eoFormElement.queryFilters\"\r\n ></eo-id-reference>\r\n </eo-form-input>\r\n\r\n <!-- ID -->\r\n <eo-form-input *ngSwitchCase=\"'ID'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-string\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [autocomplete]=\"formElementRef._eoFormElement.autocomplete\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [regex]=\"'^[0-9a-fA-F]*$'\"\r\n [qname]=\"formElementRef._eoFormElement.qname\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [minLength]=\"32\"\r\n [maxLength]=\"32\"\r\n ></eo-string>\r\n \r\n </eo-form-input>\r\n\r\n\r\n <!-- BOOLEAN -->\r\n <eo-form-input *ngSwitchCase=\"'BOOLEAN'\" [tag]=\"tag\" class=\"checkbox\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-checkbox [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [tristate]=\"true\"></eo-checkbox>\r\n </eo-form-input>\r\n\r\n <!-- CODESYSTEM -->\r\n <eo-form-input *ngSwitchCase=\"'CODESYSTEM'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-codesystem [situation]=\"element._eoFormControlWrapper.situation\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [codesystem]=\"formElementRef._eoFormElement.codesystem\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [filterFunction]=\"formElementRef._eoFormElement.filterFunction\"\r\n [disablingFilterFunction]=\"formElementRef._eoFormElement.disablingFilterFunction\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-codesystem>\r\n </eo-form-input>\r\n\r\n <!-- ORGANIZATION -->\r\n <eo-form-input *ngSwitchCase=\"'ORGANIZATION'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-organization [situation]=\"element._eoFormControlWrapper.situation\"\r\n [dataMeta]=\"formElementRef._eoFormElement.dataMeta\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [filterObject]=\"formElementRef._eoFormElement.filter\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n (onDataMetaChanged)=\"organizationDataMetaResolved($event)\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-organization>\r\n </eo-form-input>\r\n\r\n <!-- NUMBER -->\r\n\r\n <eo-form-input *ngSwitchCase=\"'NUMBER'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-number *ngIf=\"situation !== 'SEARCH'\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [precision]=\"formElementRef._eoFormElement.precision\"\r\n [scale]=\"formElementRef._eoFormElement.scale\"\r\n [grouping]=\"formElementRef._eoFormElement.grouping\"\r\n [pattern]=\"formElementRef._eoFormElement.pattern\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\">\r\n </eo-number>\r\n\r\n <eo-number-range *ngIf=\"situation === 'SEARCH'\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [precision]=\"formElementRef._eoFormElement.precision\"\r\n [scale]=\"formElementRef._eoFormElement.scale\"\r\n [grouping]=\"formElementRef._eoFormElement.grouping\"\r\n [pattern]=\"formElementRef._eoFormElement.pattern\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-number-range>\r\n </eo-form-input>\r\n\r\n <!-- TABLE -->\r\n <div class=\"table\" *ngSwitchCase=\"'TABLE'\">\r\n <eo-table [params]=\"{\r\n situation: element._eoFormControlWrapper.situation,\r\n element: formElementRef._eoFormElement,\r\n size: formElementRef._eoFormElement.size\r\n }\" [formControlName]=\"element._eoFormControlWrapper.controlName\"></eo-table>\r\n </div>\r\n\r\n <!-- DATE AND DATETIME -->\r\n <eo-form-input *ngSwitchCase=\"'DATETIME'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-datetime *ngIf=\"situation !== 'SEARCH'\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [withTime]=\"formElementRef._eoFormElement.withtime\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-datetime>\r\n\r\n <eo-datetime-range *ngIf=\"situation === 'SEARCH'\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [withTime]=\"formElementRef._eoFormElement.withtime\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-datetime-range>\r\n </eo-form-input>\r\n\r\n\r\n <!-- print out the type if it's not matching anything -->\r\n <div *ngSwitchDefault><b>{{formElementRef._eoFormElement.type}}</b></div>\r\n\r\n\r\n <!-- the fields description -->\r\n <div class=\"description\" *ngIf=\"formElementRef._eoFormElement.description\">{{formElementRef._eoFormElement.description}}</div>\r\n\r\n <!-- error/validation messages -->\r\n <div class=\"err-msg\" *ngIf=\"formElementRef.errors\">\r\n\r\n <div *ngIf=\"formElementRef.errors.daterange\" translate>eo.form.property.daterange.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.numberrange\" translate>eo.form.property.numberrange.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.number\" translate>eo.form.property.number</div>\r\n <div *ngIf=\"formElementRef.errors.precision\" translate\r\n [translateParams]=\"formElementRef.errors.precision.translateValues\">{{formElementRef.errors.precision.translateKey}}</div>\r\n <div *ngIf=\"formElementRef.errors.scale\" translate\r\n [translateParams]=\"formElementRef.errors.scale.translateValues\">{{formElementRef.errors.scale.translateKey}}</div>\r\n\r\n <div *ngIf=\"formElementRef.errors.regex || formElementRef.errors.pattern\" translate>eo.form.property.string.regex.nomatch</div>\r\n <div *ngIf=\"formElementRef.errors.classificationemail\" translate>eo.form.property.string.error.classification.email</div>\r\n <div *ngIf=\"formElementRef.errors.classificationurl\" translate>eo.form.property.string.error.classification.url</div>\r\n <div *ngIf=\"formElementRef.errors.onlyWhitespaces\" translate>eo.form.property.string.error.whitespaces</div>\r\n <div *ngIf=\"formElementRef.errors.datecontrol\" translate>eo.form.property.date.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.codesystem\" translate>eo.form.property.codesystem.value.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.eoformScript\">{{formElementRef._eoFormElement.error.msg}}</div>\r\n <div *ngIf=\"formElementRef.errors.required\" translate>eo.form.property.required</div>\r\n <div *ngIf=\"formElementRef.errors.maxlength\" translate [translateParams]=\"{maxlength: formElementRef._eoFormElement.maxlen}\">eo.form.property.maxlength</div>\r\n <div *ngIf=\"formElementRef.errors.minlength\" translate [translateParams]=\"{minlength: formElementRef._eoFormElement.minlen}\">eo.form.property.minlength</div>\r\n <div *ngIf=\"formElementRef.errors.deletedIDReference\" translate>eo.form.property.idreference.deleted</div>\r\n <div *ngIf=\"formElementRef.errors.deletedOrgObject\" translate>eo.form.property.orgobject.deleted</div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n",
9889
+ template: "<div class=\"form-element\" [formGroup]=\"element\" *ngIf=\"element\">\r\n\r\n <div class=\"form-field t-{{formElementRef._eoFormElement.type}}\" #formField\r\n [ngSwitch]=\"formElementRef._eoFormElement.type\"\r\n [ngClass]=\"{disabled: !!formElementRef._eoFormElement.readonly}\">\r\n\r\n <!-- STRING -->\r\n <eo-form-input *ngSwitchCase=\"'STRING'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-string\r\n *ngIf=\"!formElementRef._eoFormElement.reference && formElementRef._eoFormElement.classification !== 'selector'\"\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [autocomplete]=\"formElementRef._eoFormElement.autocomplete\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [multiline]=\"formElementRef._eoFormElement.multiline\"\r\n [classification]=\"formElementRef._eoFormElement.classification\"\r\n [regex]=\"formElementRef._eoFormElement.regex\"\r\n [qname]=\"formElementRef._eoFormElement.qname\"\r\n [size]=\"formElementRef._eoFormElement.size\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [minLength]=\"formElementRef._eoFormElement.minlen\"\r\n [maxLength]=\"formElementRef._eoFormElement.maxlen\"\r\n ></eo-string>\r\n\r\n <!-- Dynamic List -->\r\n <eo-dynamic-list\r\n *ngIf=\"!formElementRef._eoFormElement.reference && formElementRef._eoFormElement.classification === 'selector'\"\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [filterFunction]=\"formElementRef._eoFormElement.filterFunction\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [listObject]=\"formElementRef._eoFormElement.list\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"></eo-dynamic-list>\r\n\r\n\r\n <!-- Reference -->\r\n <eo-reference *ngIf=\"formElementRef._eoFormElement.reference\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [reference]=\"formElementRef._eoFormElement.reference\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [minLength]=\"formElementRef._eoFormElement.minlen\"\r\n [maxLength]=\"formElementRef._eoFormElement.maxlen\"\r\n ></eo-reference>\r\n </eo-form-input>\r\n\r\n <!-- ID-Reference -->\r\n <eo-form-input *ngSwitchCase=\"'REFERENCE'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-id-reference\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [dataToRender]=\"formElementRef._eoFormElement.dataToRender\"\r\n [reference]=\"formElementRef._eoFormElement.reference\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [contextId]=\"formElementRef._eoFormElement.contextId\"\r\n [exceptionIDs]=\"formElementRef._eoFormElement.exceptionIDs\"\r\n [queryFilters]=\"formElementRef._eoFormElement.queryFilters\"\r\n [objectTypesFilter]=\"formElementRef._eoFormElement.objectTypesFilter\"\r\n ></eo-id-reference>\r\n </eo-form-input>\r\n\r\n <!-- ID -->\r\n <eo-form-input *ngSwitchCase=\"'ID'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-string\r\n [situation]=\"element._eoFormControlWrapper.situation\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [autocomplete]=\"formElementRef._eoFormElement.autocomplete\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [regex]=\"'^[0-9a-fA-F]*$'\"\r\n [qname]=\"formElementRef._eoFormElement.qname\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [minLength]=\"32\"\r\n [maxLength]=\"32\"\r\n ></eo-string>\r\n\r\n </eo-form-input>\r\n\r\n\r\n <!-- BOOLEAN -->\r\n <eo-form-input *ngSwitchCase=\"'BOOLEAN'\" [tag]=\"tag\" class=\"checkbox\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-checkbox [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [tristate]=\"true\"></eo-checkbox>\r\n </eo-form-input>\r\n\r\n <!-- CODESYSTEM -->\r\n <eo-form-input *ngSwitchCase=\"'CODESYSTEM'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-codesystem [situation]=\"element._eoFormControlWrapper.situation\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [codesystem]=\"formElementRef._eoFormElement.codesystem\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n [filterFunction]=\"formElementRef._eoFormElement.filterFunction\"\r\n [disablingFilterFunction]=\"formElementRef._eoFormElement.disablingFilterFunction\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-codesystem>\r\n </eo-form-input>\r\n\r\n <!-- ORGANIZATION -->\r\n <eo-form-input *ngSwitchCase=\"'ORGANIZATION'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-organization [situation]=\"element._eoFormControlWrapper.situation\"\r\n [dataMeta]=\"formElementRef._eoFormElement.dataMeta\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [filterObject]=\"formElementRef._eoFormElement.filter\"\r\n [multiselect]=\"formElementRef._eoFormElement.multiselect\"\r\n (onDataMetaChanged)=\"organizationDataMetaResolved($event)\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-organization>\r\n </eo-form-input>\r\n\r\n <!-- NUMBER -->\r\n\r\n <eo-form-input *ngSwitchCase=\"'NUMBER'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-number *ngIf=\"situation !== 'SEARCH'\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [precision]=\"formElementRef._eoFormElement.precision\"\r\n [scale]=\"formElementRef._eoFormElement.scale\"\r\n [grouping]=\"formElementRef._eoFormElement.grouping\"\r\n [pattern]=\"formElementRef._eoFormElement.pattern\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\">\r\n </eo-number>\r\n\r\n <eo-number-range *ngIf=\"situation === 'SEARCH'\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [precision]=\"formElementRef._eoFormElement.precision\"\r\n [scale]=\"formElementRef._eoFormElement.scale\"\r\n [grouping]=\"formElementRef._eoFormElement.grouping\"\r\n [pattern]=\"formElementRef._eoFormElement.pattern\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-number-range>\r\n </eo-form-input>\r\n\r\n <!-- TABLE -->\r\n <div class=\"table\" *ngSwitchCase=\"'TABLE'\">\r\n <eo-table [params]=\"{\r\n situation: element._eoFormControlWrapper.situation,\r\n element: formElementRef._eoFormElement,\r\n size: formElementRef._eoFormElement.size\r\n }\" [formControlName]=\"element._eoFormControlWrapper.controlName\"></eo-table>\r\n </div>\r\n\r\n <!-- DATE AND DATETIME -->\r\n <eo-form-input *ngSwitchCase=\"'DATETIME'\" [tag]=\"tag\" [label]=\"formElementRef._eoFormElement.label\"\r\n [isNull]=\"isNull\"\r\n [skipToggle]=\"skipToggle || situation !== 'SEARCH'\"\r\n (onToggleLabel)=\"labelToggled($event)\"\r\n [required]=\"formElementRef._eoFormElement.required\"\r\n [invalid]=\"formElementRef.invalid\">\r\n\r\n <eo-datetime *ngIf=\"situation !== 'SEARCH'\"\r\n [readonly]=\"formElementRef._eoFormElement.readonly\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [withTime]=\"formElementRef._eoFormElement.withtime\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-datetime>\r\n\r\n <eo-datetime-range *ngIf=\"situation === 'SEARCH'\"\r\n [pickerTitle]=\"formElementRef._eoFormElement.label\"\r\n [withTime]=\"formElementRef._eoFormElement.withtime\"\r\n [formControlName]=\"element._eoFormControlWrapper.controlName\"\r\n ></eo-datetime-range>\r\n </eo-form-input>\r\n\r\n\r\n <!-- print out the type if it's not matching anything -->\r\n <div *ngSwitchDefault><b>{{formElementRef._eoFormElement.type}}</b></div>\r\n\r\n\r\n <!-- the fields description -->\r\n <div class=\"description\" *ngIf=\"formElementRef._eoFormElement.description\">{{formElementRef._eoFormElement.description}}</div>\r\n\r\n <!-- error/validation messages -->\r\n <div class=\"err-msg\" *ngIf=\"formElementRef.errors\">\r\n\r\n <div *ngIf=\"formElementRef.errors.daterange\" translate>eo.form.property.daterange.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.numberrange\" translate>eo.form.property.numberrange.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.number\" translate>eo.form.property.number</div>\r\n <div *ngIf=\"formElementRef.errors.precision\" translate\r\n [translateParams]=\"formElementRef.errors.precision.translateValues\">{{formElementRef.errors.precision.translateKey}}</div>\r\n <div *ngIf=\"formElementRef.errors.scale\" translate\r\n [translateParams]=\"formElementRef.errors.scale.translateValues\">{{formElementRef.errors.scale.translateKey}}</div>\r\n\r\n <div *ngIf=\"formElementRef.errors.regex || formElementRef.errors.pattern\" translate>eo.form.property.string.regex.nomatch</div>\r\n <div *ngIf=\"formElementRef.errors.classificationemail\" translate>eo.form.property.string.error.classification.email</div>\r\n <div *ngIf=\"formElementRef.errors.classificationurl\" translate>eo.form.property.string.error.classification.url</div>\r\n <div *ngIf=\"formElementRef.errors.onlyWhitespaces\" translate>eo.form.property.string.error.whitespaces</div>\r\n <div *ngIf=\"formElementRef.errors.datecontrol\" translate>eo.form.property.date.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.codesystem\" translate>eo.form.property.codesystem.value.invalid</div>\r\n <div *ngIf=\"formElementRef.errors.eoformScript\">{{formElementRef._eoFormElement.error.msg}}</div>\r\n <div *ngIf=\"formElementRef.errors.required\" translate>eo.form.property.required</div>\r\n <div *ngIf=\"formElementRef.errors.maxlength\" translate [translateParams]=\"{maxlength: formElementRef._eoFormElement.maxlen}\">eo.form.property.maxlength</div>\r\n <div *ngIf=\"formElementRef.errors.minlength\" translate [translateParams]=\"{minlength: formElementRef._eoFormElement.minlen}\">eo.form.property.minlength</div>\r\n <div *ngIf=\"formElementRef.errors.deletedIDReference\" translate>eo.form.property.idreference.deleted</div>\r\n <div *ngIf=\"formElementRef.errors.deletedOrgObject\" translate>eo.form.property.orgobject.deleted</div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n",
9823
9890
  styles: [":host-context(.dark) .form-element .form-field .err-msg{background-color:var(--color-error);border:0;border-radius:2px;color:var(--color-white);margin:calc(var(--app-pane-padding)/4) 0;padding:calc(var(--app-pane-padding)/4)}:host{flex:1 1 auto}:host.label-toggled::ng-deep eo-form-input label{text-decoration:line-through}.form-element{box-sizing:border-box}.form-element .form-field{margin:calc(var(--app-pane-padding)/4) calc(var(--app-pane-padding)/2)}.form-element .form-field .description{border:0;font-size:var(--font-hint);font-style:italic;padding:calc(var(--app-pane-padding)/8) calc(var(--app-pane-padding)/8) 0 calc(var(--app-pane-padding)/8)}.form-element .form-field .err-msg{border:0;color:var(--color-error);padding:calc(var(--app-pane-padding)/4) 0}.form-element .form-field .table{align-items:flex-start;border-color:transparent;flex-flow:column}.form-element .form-field .table .label{padding-bottom:calc(var(--app-pane-padding)/4)}.form-element.ng-dirty:not(.ng-invalid)>.form-field:not(.focused)::ng-deep label{background-color:var(--color-dirty-background);color:var(--color-dirty-font)!important}"]
9824
9891
  },] }
9825
9892
  ];
@@ -20627,7 +20694,7 @@ class ProcessHistoryComponent {
20627
20694
  ProcessHistoryComponent.decorators = [
20628
20695
  { type: Component, args: [{
20629
20696
  selector: 'eo-process-history',
20630
- template: "<div class=\"process-history\">\r\n\r\n <div class=\"filter\">\r\n <div class=\"input\" [ngClass]=\"{inactive: !history?.length}\">\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_filter.svg'\"></eo-icon>\r\n <input type=\"text\" [ngModelOptions]=\"{standalone: true}\" [(ngModel)]=\"filterterm\">\r\n\r\n </div>\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"filterterm = null\" *ngIf=\"filterterm\"></eo-icon>\r\n </div>\r\n\r\n\r\n <ng-template #empty>\r\n <eo-error-message [emptyState]=\"{icon: 'ic_no-file.svg', text: 'eo.timeline.empty', className: 'history empty'}\"></eo-error-message>\r\n </ng-template>\r\n\r\n\r\n <div class=\"history eo-timeline\" [ngClass]=\"{single: history?.length === 1}\" *ngIf=\"history?.length; else empty\">\r\n\r\n <div class=\"timeline-entry\"\r\n *ngFor=\"let entry of history | historyFilter:filterterm; trackBy: trackByIndex\"\r\n [ngClass]=\"{user: entry.editor, error: entry.type === 'error' || entry?.errorType}\">\r\n\r\n <div class=\"when\">\r\n <div class=\"date\">{{entry.time | localeDate: 'eoShortDate'}}</div>\r\n <div class=\"time\">{{entry.time | localeDate: 'eoShortTime'}}</div>\r\n </div>\r\n <div class=\"marker\">\r\n <img *ngIf=\"entry.editor\"\r\n title=\"{{entry.editor.lastname}}, {{entry.editor.firstname}} ({{entry.editor.name}})\"\r\n [src]=\"entry.data?.image\">\r\n </div>\r\n <div class=\"what\">\r\n <div class=\"title\">{{entry.title}}</div>\r\n\r\n <div class=\"description\" *ngIf=\"entry.data?.periodFireTime && entry.type === 'DEADLINE_START'; else description\">\r\n <div class=\"deadline-fire\">\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_timer.svg'\"></eo-icon>\r\n <span>{{entry.data.periodFireTime | localeDate}}</span>\r\n </div>\r\n </div>\r\n <ng-template #description>\r\n <div class=\"description\">\r\n {{'eo.process.details.history.entry.type.' + entry.type + '.title'|translate}}\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"meta\" *ngIf=\"entry.performer?.length\">\r\n <span *ngFor=\"let p of entry.performer; trackBy: trackByIndex\">\r\n {{p.label}}\r\n </span>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n</div>\r\n",
20697
+ template: "<div class=\"process-history\">\r\n\r\n <div class=\"filter\">\r\n <div class=\"input\" [ngClass]=\"{inactive: !history?.length}\">\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_filter.svg'\"></eo-icon>\r\n <input type=\"text\" [ngModelOptions]=\"{standalone: true}\" [(ngModel)]=\"filterterm\">\r\n\r\n </div>\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"filterterm = null\" *ngIf=\"filterterm\"></eo-icon>\r\n </div>\r\n\r\n\r\n <ng-template #empty>\r\n <eo-error-message [emptyState]=\"{icon: 'ic_no-file.svg', text: 'eo.timeline.empty', className: 'history empty'}\"></eo-error-message>\r\n </ng-template>\r\n\r\n\r\n <div class=\"history eo-timeline\" [ngClass]=\"{single: history?.length === 1}\" *ngIf=\"history?.length; else empty\">\r\n\r\n <div class=\"timeline-entry\"\r\n *ngFor=\"let entry of history | historyFilter:filterterm; trackBy: trackByIndex\"\r\n [ngClass]=\"{user: entry.editor, error: entry.type === 'error' || entry?.errorType}\">\r\n\r\n <div class=\"when\">\r\n <div class=\"date\">{{entry.time | localeDate: 'eoShortDate'}}</div>\r\n <div class=\"time\">{{entry.time | localeDate: 'eoShortTime'}}</div>\r\n </div>\r\n <div class=\"marker\">\r\n <img *ngIf=\"entry.editor\"\r\n title=\"{{entry.editor.lastname}}, {{entry.editor.firstname}} ({{entry.editor.name}})\"\r\n [src]=\"entry.data?.image\">\r\n </div>\r\n <div class=\"what\">\r\n <div class=\"title\">{{entry.title}}</div>\r\n\r\n <div class=\"description\" *ngIf=\"entry.data?.periodFireTime && entry.type === 'DEADLINE_START'; else description\">\r\n <div class=\"deadline-fire\">\r\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_timer.svg'\"></eo-icon>\r\n <span>{{entry.data.periodFireTime | localeDate}}</span>\r\n </div>\r\n </div>\r\n <ng-template #description>\r\n <div *ngIf=\"entry.type !== 'USERDEFINED'; else userDefined\" class=\"description\">\r\n {{'eo.process.details.history.entry.type.' + entry.type + '.title'|translate}}\r\n </div>\r\n\r\n <ng-template #userDefined>\r\n <div class=\"description\">\r\n {{entry.description}}\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n\r\n <div class=\"meta\" *ngIf=\"entry.performer?.length\">\r\n <span *ngFor=\"let p of entry.performer; trackBy: trackByIndex\">\r\n {{p.label}}\r\n </span>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n</div>\r\n",
20631
20698
  changeDetection: ChangeDetectionStrategy.OnPush,
20632
20699
  styles: [":host .process-history{display:flex;flex:1;flex-direction:column;height:100%;min-height:0;min-width:0}:host .history{flex:1 1 auto;overflow-y:auto;padding:var(--app-pane-padding)}:host .filter{background-color:var(--panel-background-lightgrey);border-bottom:1px solid var(--main-background);display:flex;flex:1;flex:0 0 auto;flex-direction:row;justify-content:space-between;min-height:0;min-width:0}:host .filter .input{background-color:var(--color-white);border:1px solid var(--main-background);display:flex;flex-flow:row nowrap;margin:calc(var(--app-pane-padding)/2);padding:2px 2px 2px 0}:host .filter .input.inactive{opacity:.5;pointer-events:none}:host .filter .input input{background-color:transparent;border:0}:host .filter .input eo-icon{margin:0 calc(var(--app-pane-padding)/4)}:host .filter .input eo-icon,:host .filter>eo-icon{align-self:center;color:var(--text-color-hint);height:16px;width:16px}:host .filter>eo-icon{box-sizing:content-box;cursor:pointer;flex:0 0 auto;padding:calc(var(--app-pane-padding)/2)}:host .timeline-entry.user img{border:2px solid var(--text-color-hint);border-radius:50%;height:30px;width:30px;z-index:1}:host .timeline-entry.user .marker:before{display:none}:host .timeline-entry .what{padding-bottom:0;width:66%}:host .timeline-entry .what .deadline-fire{align-items:center;display:flex;padding-bottom:4px}:host .timeline-entry .what .description{color:var(--text-color-body)}.deadline-fire :host .timeline-entry .what .description{align-items:center;display:flex;flex-flow:row nowrap}.deadline-fire :host .timeline-entry .what .description eo-icon{color:var(--text-color-hint);height:18px;width:18px}.deadline-fire :host .timeline-entry .what .description span{padding:0 calc(var(--app-pane-padding)/4)}:host .timeline-entry .what .meta{display:flex;flex-flow:row wrap;margin-bottom:calc(var(--app-pane-padding)/4)}:host .timeline-entry .what .meta span{background-color:rgba(var(--color-black-rgb),.08);border-radius:2px;display:block;font-size:var(--font-caption);margin:0 calc(var(--app-pane-padding)/4) calc(var(--app-pane-padding)/4) 0;padding:2px 4px}:host .timeline-entry.error .what .title{color:var(--color-error)}:host .timeline-entry.error .marker:before{align-items:center;border-color:var(--color-error);border-width:4px;color:var(--color-error);content:\"!\";display:flex;flex-flow:column;font-weight:var(--font-weight-bold);justify-content:center}"]
20633
20700
  },] }
@@ -22123,10 +22190,10 @@ class AboutStateComponent {
22123
22190
  this.http = http;
22124
22191
  this.userService = userService;
22125
22192
  this.config = config;
22126
- this.__libraries__ = [{ "name": "@ag-grid-community/angular", "version": "22.1.2", "license": "MIT" }, { "name": "@ag-grid-community/client-side-row-model", "version": "22.1.1", "license": "MIT" }, { "name": "@ag-grid-community/core", "version": "22.1.1", "license": "MIT" }, { "name": "@ag-grid-community/csv-export", "version": "22.1.1", "license": "MIT" }, { "name": "@angular/animations", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/cdk", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/common", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/compiler", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/core", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/forms", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/platform-browser", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/platform-browser-dynamic", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/router", "version": "11.2.0", "license": "MIT" }, { "name": "@eo-sdk/core", "version": "8.2.0", "license": "MIT" }, { "name": "@ngx-pwa/local-storage", "version": "11.1.0", "license": "MIT" }, { "name": "@ngx-translate/core", "version": "13.0.0", "license": "MIT" }, { "name": "@types/lodash", "version": "4.14.88", "license": "MIT" }, { "name": "core-js", "version": "2.5.7", "license": "MIT" }, { "name": "file-saver", "version": "2.0.5", "license": "MIT" }, { "name": "font-awesome", "version": "4.7.0", "license": "(OFL-1.1 AND MIT)" }, { "name": "keyboardevent-key-polyfill", "version": "1.1.0", "license": "CC0-1.0" }, { "name": "keycode-js", "version": "0.0.4", "license": "MIT" }, { "name": "mobile-drag-drop", "version": "2.2.0", "license": "MIT" }, { "name": "moment", "version": "2.22.2", "license": "MIT" }, { "name": "ngx-toastr", "version": "13.2.0", "license": "MIT" }, { "name": "primeicons", "version": "1.0.0-beta.6", "license": "MIT" }, { "name": "primeng", "version": "6.0.0-beta.1", "license": "MIT" }, { "name": "reflect-metadata", "version": "0.1.10", "license": "Apache-2.0" }, { "name": "rxjs", "version": "6.6.3", "license": "Apache-2.0" }, { "name": "tslib", "version": "2.1.0", "license": "0BSD" }, { "name": "zone.js", "version": "0.10.3", "license": "MIT" }];
22193
+ this.__libraries__ = [{ "name": "@ag-grid-community/angular", "version": "22.1.2", "license": "MIT" }, { "name": "@ag-grid-community/client-side-row-model", "version": "22.1.1", "license": "MIT" }, { "name": "@ag-grid-community/core", "version": "22.1.1", "license": "MIT" }, { "name": "@ag-grid-community/csv-export", "version": "22.1.1", "license": "MIT" }, { "name": "@angular/animations", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/cdk", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/common", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/compiler", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/core", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/forms", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/platform-browser", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/platform-browser-dynamic", "version": "11.2.0", "license": "MIT" }, { "name": "@angular/router", "version": "11.2.0", "license": "MIT" }, { "name": "@eo-sdk/core", "version": "8.4.0-rc.2", "license": "MIT" }, { "name": "@ngx-pwa/local-storage", "version": "11.1.0", "license": "MIT" }, { "name": "@ngx-translate/core", "version": "13.0.0", "license": "MIT" }, { "name": "@types/lodash", "version": "4.14.88", "license": "MIT" }, { "name": "core-js", "version": "2.5.7", "license": "MIT" }, { "name": "file-saver", "version": "2.0.5", "license": "MIT" }, { "name": "font-awesome", "version": "4.7.0", "license": "(OFL-1.1 AND MIT)" }, { "name": "keyboardevent-key-polyfill", "version": "1.1.0", "license": "CC0-1.0" }, { "name": "keycode-js", "version": "0.0.4", "license": "MIT" }, { "name": "mobile-drag-drop", "version": "2.2.0", "license": "MIT" }, { "name": "moment", "version": "2.22.2", "license": "MIT" }, { "name": "ngx-toastr", "version": "13.2.0", "license": "MIT" }, { "name": "primeicons", "version": "1.0.0-beta.6", "license": "MIT" }, { "name": "primeng", "version": "6.0.0-beta.1", "license": "MIT" }, { "name": "reflect-metadata", "version": "0.1.10", "license": "Apache-2.0" }, { "name": "rxjs", "version": "6.6.3", "license": "Apache-2.0" }, { "name": "tslib", "version": "2.1.0", "license": "0BSD" }, { "name": "zone.js", "version": "0.10.3", "license": "MIT" }];
22127
22194
  this.ctrl = {
22128
22195
  productName: 'yuuvis® RAD client',
22129
- clientVersion: '8.2.0'
22196
+ clientVersion: '8.4.0-rc.2'
22130
22197
  };
22131
22198
  this.licenses = {
22132
22199
  'MIT': {