nuxeo-development-framework 1.6.3 → 1.6.4

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 (115) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +597 -1430
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/Core/services/translation/translation.service.js +6 -9
  4. package/esm2015/lib/components/card/card.component.js +1 -1
  5. package/esm2015/lib/components/comments/comments.module.js +5 -11
  6. package/esm2015/lib/components/comments/components/comment-item/comment-item.component.js +11 -61
  7. package/esm2015/lib/components/comments/components/comments-dashlet/comments-dashlet.component.js +2 -5
  8. package/esm2015/lib/components/comments/components/comments-list/comments-list.component.js +2 -7
  9. package/esm2015/lib/components/comments/services/comment-api.service.js +1 -23
  10. package/esm2015/lib/components/confirm-caller/confirm-caller.dialog.js +3 -5
  11. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation/correspondence-relation.component.js +3 -5
  12. package/esm2015/lib/components/correspondence-relation/components/correspondence-relation-create-form/correspondence-relation-create-form.component.js +1 -1
  13. package/esm2015/lib/components/correspondence-relation/components/versions/versions.component.js +4 -8
  14. package/esm2015/lib/components/create-entity/create-entity/create-entity.component.js +4 -11
  15. package/esm2015/lib/components/cts-tags/components/correspondence-tags/correspondence-tags.component.js +16 -47
  16. package/esm2015/lib/components/cts-tags/services/tags-api.service.js +1 -30
  17. package/esm2015/lib/components/custom-toastr/components/custom-toastr/custom-toastr.component.js +2 -2
  18. package/esm2015/lib/components/documents/components/attachments-list/attachments-list.component.js +1 -1
  19. package/esm2015/lib/components/documents/components/attachments-page-provider/attachments-page-provider.component.js +1 -1
  20. package/esm2015/lib/components/documents/components/document-list/documents-list.component.js +8 -6
  21. package/esm2015/lib/components/documents/components/document-scan/document-scan.service.js +1 -1
  22. package/esm2015/lib/components/documents/components/document-upload/document-upload.component.js +1 -1
  23. package/esm2015/lib/components/documents/components/documents/documents.component.js +2 -4
  24. package/esm2015/lib/components/documents/services/documents.service.js +6 -4
  25. package/esm2015/lib/components/dynamic-chart/dynamic-chart/dynamic-chart.component.js +6 -43
  26. package/esm2015/lib/components/dynamic-filter/dynamic-filter/dynamic-filter.component.js +10 -30
  27. package/esm2015/lib/components/dynamic-form/components/department-form/department-form.component.js +5 -11
  28. package/esm2015/lib/components/dynamic-form/components/dynamic-form/dynamic-form.component.js +3 -14
  29. package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.js +2 -2
  30. package/esm2015/lib/components/dynamic-form/components/dynamic-form-hijri-dateitem/dynamic-form-hijri-dateitem.component.js +3 -8
  31. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.js +1 -1
  32. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-user-filter/dynamic-form-select-user-filter.component.js +2 -2
  33. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.js +3 -4
  34. package/esm2015/lib/components/dynamic-form/components/dynamic-form-selectitem/dynamic-form-selectitem.component.js +1 -1
  35. package/esm2015/lib/components/dynamic-form/components/dynamic-form-slide-toggleitem/dynamic-form-slide-toggleitem.component.js +1 -1
  36. package/esm2015/lib/components/dynamic-form/components/dynamic-form-textarea/dynamic-form-textarea.component.js +2 -2
  37. package/esm2015/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.js +7 -10
  38. package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select-i18n.js +10 -15
  39. package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.js +2 -4
  40. package/esm2015/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.js +2 -6
  41. package/esm2015/lib/components/dynamic-form/components/form-wrappers/date-wrapper/date-wrapper.component.js +1 -1
  42. package/esm2015/lib/components/dynamic-form/components/form-wrappers/user-selector-wrapper/user-selector-wrapper.component.js +2 -2
  43. package/esm2015/lib/components/dynamic-form/components/form-wrappers/vocabulary-wrapper/vocabulary-wrapper.component.js +1 -1
  44. package/esm2015/lib/components/dynamic-search/dynamic-search/dynamic-search.component.js +6 -37
  45. package/esm2015/lib/components/dynamic-table/dynamic-table/dynamic-table.component.js +5 -22
  46. package/esm2015/lib/components/dynamic-view/data-viewer/data-viewer.component.js +2 -2
  47. package/esm2015/lib/components/dynamic-view/date-viewer/date-viewer.component.js +12 -18
  48. package/esm2015/lib/components/dynamic-view/department-viewer/department-viewer.component.js +26 -44
  49. package/esm2015/lib/components/dynamic-view/dynamic-view.module.js +4 -19
  50. package/esm2015/lib/components/filter/filter/filter.component.js +1 -1
  51. package/esm2015/lib/components/hijri-gregorian-datepicker/hijri-gregorian-datepicker/gregorian-datepicker/gregorian-datepicker.component.js +2 -3
  52. package/esm2015/lib/components/hijri-gregorian-datepicker/hijri-gregorian-datepicker/hijri-datepicker/hijri-datepicker.component.js +2 -3
  53. package/esm2015/lib/components/hijri-gregorian-datepicker/ngx-hijri-gregorian-datepicker.module.js +1 -5
  54. package/esm2015/lib/components/hijri-gregorian-datepicker/services/date-helper.service.js +2 -2
  55. package/esm2015/lib/components/latest-activity/components/activity-line/activity-line.component.js +2 -2
  56. package/esm2015/lib/components/latest-activity/components/latest-activity/latest-activity.component.js +1 -1
  57. package/esm2015/lib/components/latest-activity/components/single-activity/single-activity.component.js +2 -2
  58. package/esm2015/lib/components/notifications/components/notification-item/notification-item.component.js +10 -32
  59. package/esm2015/lib/components/notifications/components/notification-toast/notification-toast.component.js +1 -1
  60. package/esm2015/lib/components/notifications/components/notifications-button/notifications-button.component.js +4 -14
  61. package/esm2015/lib/components/notifications/components/notifications-list/notifications-list.component.js +4 -8
  62. package/esm2015/lib/components/pdf-tron/pdftron/pdftron.component.js +32 -189
  63. package/esm2015/lib/components/select/select/select.component.js +1 -1
  64. package/esm2015/lib/components/table/table/table.component.js +15 -45
  65. package/esm2015/lib/components/users-card/users-card.component.js +1 -1
  66. package/esm2015/lib/components/viewer-log/components/viewer-log/viewer-log.component.js +1 -1
  67. package/esm2015/lib/configuration/app-config.service.js +1 -1
  68. package/esm2015/lib/directive/app-has-role/app-has-role.directive.js +1 -1
  69. package/esm2015/lib/shared/components/button/button.component.js +1 -1
  70. package/esm2015/lib/shared/components/item-list/item-list.component.js +2 -2
  71. package/esm2015/lib/shared/components/user-card/user-card.component.js +1 -1
  72. package/esm2015/public-api.js +1 -8
  73. package/fesm2015/nuxeo-development-framework.js +303 -1109
  74. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  75. package/lib/Core/services/translation/translation.service.d.ts +2 -5
  76. package/lib/components/comments/comments.module.d.ts +12 -13
  77. package/lib/components/comments/components/comment-item/comment-item.component.d.ts +3 -14
  78. package/lib/components/comments/components/comments-dashlet/comments-dashlet.component.d.ts +1 -2
  79. package/lib/components/comments/components/comments-list/comments-list.component.d.ts +1 -3
  80. package/lib/components/comments/services/comment-api.service.d.ts +0 -2
  81. package/lib/components/correspondence-relation/components/versions/versions.component.d.ts +0 -1
  82. package/lib/components/cts-tags/components/correspondence-tags/correspondence-tags.component.d.ts +1 -4
  83. package/lib/components/cts-tags/services/tags-api.service.d.ts +0 -2
  84. package/lib/components/documents/services/documents.service.d.ts +1 -1
  85. package/lib/components/dynamic-chart/dynamic-chart/dynamic-chart.component.d.ts +2 -4
  86. package/lib/components/dynamic-filter/dynamic-filter/dynamic-filter.component.d.ts +2 -11
  87. package/lib/components/dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +0 -1
  88. package/lib/components/dynamic-form/components/dynamic-form-hijri-dateitem/dynamic-form-hijri-dateitem.component.d.ts +1 -4
  89. package/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.d.ts +1 -2
  90. package/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select-i18n.d.ts +2 -2
  91. package/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.d.ts +1 -2
  92. package/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.d.ts +1 -3
  93. package/lib/components/dynamic-search/dynamic-search/dynamic-search.component.d.ts +3 -6
  94. package/lib/components/dynamic-table/dynamic-table/dynamic-table.component.d.ts +1 -6
  95. package/lib/components/dynamic-view/date-viewer/date-viewer.component.d.ts +3 -8
  96. package/lib/components/dynamic-view/department-viewer/department-viewer.component.d.ts +3 -4
  97. package/lib/components/dynamic-view/dynamic-view.module.d.ts +5 -8
  98. package/lib/components/hijri-gregorian-datepicker/ngx-hijri-gregorian-datepicker.module.d.ts +2 -3
  99. package/lib/components/notifications/components/notifications-button/notifications-button.component.d.ts +2 -5
  100. package/lib/components/notifications/components/notifications-list/notifications-list.component.d.ts +2 -3
  101. package/lib/components/pdf-tron/pdftron/pdftron.component.d.ts +3 -22
  102. package/lib/components/table/table/table.component.d.ts +2 -14
  103. package/lib/configuration/app-config.service.d.ts +0 -1
  104. package/package.json +1 -1
  105. package/public-api.d.ts +0 -7
  106. package/esm2015/lib/components/comments/components/edit-delete-modal/edit-delete-modal.component.js +0 -63
  107. package/esm2015/lib/components/dynamic-view/custom-document-viewer/custom-document-viewer.component.js +0 -59
  108. package/esm2015/lib/components/dynamic-view/custom-pp-viewer/custom-pp-viewer.component.js +0 -68
  109. package/esm2015/lib/components/dynamic-view/cutome-voc-viewer/cutome-voc-viewer.component.js +0 -33
  110. package/esm2015/lib/components/dynamic-view/dynamic-viewe.service.js +0 -62
  111. package/lib/components/comments/components/edit-delete-modal/edit-delete-modal.component.d.ts +0 -22
  112. package/lib/components/dynamic-view/custom-document-viewer/custom-document-viewer.component.d.ts +0 -22
  113. package/lib/components/dynamic-view/custom-pp-viewer/custom-pp-viewer.component.d.ts +0 -28
  114. package/lib/components/dynamic-view/cutome-voc-viewer/cutome-voc-viewer.component.d.ts +0 -16
  115. package/lib/components/dynamic-view/dynamic-viewe.service.d.ts +0 -15
@@ -144,7 +144,7 @@ export class DynamicFormTextareaComponent {
144
144
  }
145
145
  DynamicFormTextareaComponent.DEFAULT_SEPARATOR = ', ';
146
146
  DynamicFormTextareaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicFormTextareaComponent, deps: [{ token: i1.DynamicFormUpdateService }, { token: i2.TranslateService }, { token: i3.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
147
- DynamicFormTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DynamicFormTextareaComponent, selector: "app-dynamic-form-textarea", inputs: { property: "property", label: "label", editable: "editable", disabled: "disabled", id: "id", placeholder: "placeholder", displayEmpty: "displayEmpty", horizontalAlign: "horizontalAlign" }, viewQueries: [{ propertyName: "editorInput", first: true, predicate: ["editorInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"app-property-value\">\r\n <div class=\"app-input-wrapper\" [ngClass]=\"{'row' : horizontalAlign}\">\r\n\r\n <label *ngIf=\"label\" for=\"formGroupInputSmall\" [ngClass]=\"{'col-3' : horizontalAlign}\">{{\r\n label | translate\r\n }}<span *ngIf=\"isRequired()\" class=\"text-danger\">*</span></label>\r\n <div [ngClass]=\"{'col-9' : horizontalAlign}\">\r\n <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n <textarea [id]='id' class=\"form-control \" placeholder=\"{{placeholder | translate}}\" [attr.disabled]=\"isDisabled() || null\" #editorInput matTextareaAutosize\r\n matAutosizeMinRows=\"3\" matAutosizeMaxRows=\"5\" [(ngModel)]=\"editedValue\" (input)=\"onTextAreaInputChange()\"\r\n (keyup)=\"update($event)\" [attr.data-automation-id]=\"'card-textitem-edittextarea-' \"></textarea>\r\n <mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\"\r\n *ngIf=\"hasErrors()\">\r\n <ul>\r\n <li *ngIf=\"control.errors.required\">\r\n {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n </li>\r\n </ul>\r\n </mat-error>\r\n </ng-container>\r\n <ng-template #readOnly>\r\n {{editedValue}}\r\n </ng-template>\r\n </div>\r\n </div>\r\n\r\n</div>\r\n", styles: [".app-textitem-editable-error{margin-top:-15px;padding-top:0}textarea::placeholder{font-size:12px}\n"], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.MatTextareaAutosize, selector: "textarea[mat-autosize], textarea[matTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "matAutosizeMinRows", "matAutosizeMaxRows", "mat-autosize", "matTextareaAutosize"], exportAs: ["matTextareaAutosize"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "translate": i2.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
147
+ DynamicFormTextareaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DynamicFormTextareaComponent, selector: "app-dynamic-form-textarea", inputs: { property: "property", label: "label", editable: "editable", disabled: "disabled", id: "id", placeholder: "placeholder", displayEmpty: "displayEmpty", horizontalAlign: "horizontalAlign" }, viewQueries: [{ propertyName: "editorInput", first: true, predicate: ["editorInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"app-property-value\">\r\n <div class=\"app-input-wrapper\" [ngClass]=\"{'row' : horizontalAlign}\">\r\n\r\n <label *ngIf=\"label\" for=\"formGroupInputSmall\" [ngClass]=\"{'col-3' : horizontalAlign}\">{{\r\n label | translate\r\n }}<span *ngIf=\"isRequired()\" class=\"text-danger\">*</span></label>\r\n <div [ngClass]=\"{'col-9' : horizontalAlign}\">\r\n <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n <textarea [id]='id' class=\"form-control \" placeholder=\"{{placeholder | translate}}\" [attr.disabled]=\"isDisabled() || null\" #editorInput matTextareaAutosize\r\n matAutosizeMinRows=\"3\" matAutosizeMaxRows=\"5\" [(ngModel)]=\"editedValue\" (input)=\"onTextAreaInputChange()\"\r\n (keyup)=\"update($event)\" [attr.data-automation-id]=\"'card-textitem-edittextarea-' \"></textarea>\r\n <mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\"\r\n *ngIf=\"hasErrors()\">\r\n <ul>\r\n <li *ngIf=\"control.errors.required\">\r\n {{ 'VALIDATORS.REQUIRED' | translate }}\r\n </li>\r\n </ul>\r\n </mat-error>\r\n </ng-container>\r\n <ng-template #readOnly>\r\n {{editedValue}}\r\n </ng-template>\r\n </div>\r\n </div>\r\n\r\n</div>\r\n", styles: [".app-textitem-editable-error{margin-top:-15px;padding-top:0}textarea::placeholder{font-size:12px}\n"], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.MatTextareaAutosize, selector: "textarea[mat-autosize], textarea[matTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "matAutosizeMinRows", "matAutosizeMaxRows", "mat-autosize", "matTextareaAutosize"], exportAs: ["matTextareaAutosize"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "translate": i2.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
148
148
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicFormTextareaComponent, decorators: [{
149
149
  type: Component,
150
150
  args: [{
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
177
177
  type: ViewChild,
178
178
  args: ['editorInput']
179
179
  }] } });
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-textarea.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textarea/dynamic-form-textarea.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textarea/dynamic-form-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  Optional,\r\n  Self,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { DynamicFormTextItemModel } from '../../models/dynamic-form.models';\r\nimport { DynamicFormUpdateService } from '../../services/dynamic-form-update.service';\r\n\r\n/**\r\n * A textarea input that can be used inside reactive or template driven forms\r\n * @title\r\n * Textarea\r\n * @example\r\n * <app-dynamic-form-textarea\r\n *    [horizontalAlign]=\"false\"\r\n *    formControlName=\"controlName\"\r\n *    [placeholder]=\"'PATH.TO.PLACEHOLDER.STRING'\"\r\n * ></app-dynamic-form-textarea>\r\n */\r\n@Component({\r\n  selector: 'app-dynamic-form-textarea',\r\n  templateUrl: './dynamic-form-textarea.component.html',\r\n  styleUrls: ['./dynamic-form-textarea.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormTextareaComponent\r\n  implements OnChanges, ControlValueAccessor\r\n{\r\n  static DEFAULT_SEPARATOR = ', ';\r\n  /** @deprecated */\r\n  @Input()\r\n  property: DynamicFormTextItemModel;\r\n\r\n  /** Field Label */\r\n  @Input()\r\n  label;\r\n  /** is editable */\r\n  @Input()\r\n  editable = true;\r\n  /** is dsisabled */\r\n  @Input()\r\n  disabled = false;\r\n  /** DOM element Id */\r\n  @Input()\r\n  id;\r\n  /** Input placeholder */\r\n  @Input() placeholder = '';\r\n  /** @deprecated */\r\n  @Input()\r\n  displayEmpty = true;\r\n\r\n  /**  make label and control side by side not vertical */\r\n  @Input() horizontalAlign = true;\r\n\r\n  @ViewChild('editorInput')\r\n  private editorInput: any;\r\n\r\n  inEdit = false;\r\n  editedValue: string;\r\n  errorMessages: string[];\r\n  valueSeparator: string;\r\n\r\n  constructor(\r\n    private dynamicFormUpdateService: DynamicFormUpdateService,\r\n    public translate: TranslateService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    this.control.valueAccessor = this;\r\n    this.valueSeparator = DynamicFormTextareaComponent.DEFAULT_SEPARATOR;\r\n  }\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n\r\n  isRequired() {\r\n    if (!this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  writeValue(obj: any): void {\r\n    this.editedValue = obj;\r\n    // this.property.value = obj;\r\n\r\n    //  throw new Error('Method not implemented.');\r\n  }\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    // this.editedValue = this.property.multiline\r\n    //  ? this.property.displayValue\r\n    // : this.property.value;\r\n  }\r\n\r\n  showProperty(): boolean {\r\n    return this.displayEmpty || !this.property.isEmpty();\r\n  }\r\n\r\n  showClickableIcon(): boolean {\r\n    return this.hasIcon() && this.editable;\r\n  }\r\n\r\n  isEditable(): boolean {\r\n    return this.editable;\r\n  }\r\n  isDisabled(): boolean {\r\n    return this.disabled;\r\n  }\r\n\r\n  isClickable(): boolean {\r\n    return !!this.property.clickable;\r\n  }\r\n\r\n  hasIcon(): boolean {\r\n    return !!this.property.icon;\r\n  }\r\n\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n\r\n  setEditMode(editStatus: boolean): void {\r\n    this.inEdit = editStatus;\r\n    setTimeout(() => {\r\n      if (this.editorInput) {\r\n        this.editorInput.nativeElement.click();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  reset(event: MouseEvent | KeyboardEvent): void {\r\n    event.stopPropagation();\r\n\r\n    /*\r\n     this.editedValue = this.property.multiline\r\n       ? this.property.displayValue\r\n       : this.property.value; */\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  private resetErrorMessages() {\r\n    this.errorMessages = [];\r\n  }\r\n\r\n  update(event: MouseEvent | KeyboardEvent): void {\r\n    event.stopPropagation();\r\n    const updatedValue = this.prepareValueForUpload(\r\n      this.property,\r\n      this.editedValue\r\n    );\r\n    // this.property.value = updatedValue;\r\n    this.onChange(updatedValue);\r\n    this.onTouched();\r\n    // this.dynamicFormUpdateService.update(this.property, updatedValue);\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  prepareValueForUpload(\r\n    property: DynamicFormTextItemModel,\r\n    value: string\r\n  ): string | string[] {\r\n    return value;\r\n  }\r\n\r\n  onTextAreaInputChange() {\r\n    if (this.property) {\r\n      this.errorMessages = this.property.getValidationErrors(this.editedValue);\r\n    }\r\n  }\r\n\r\n  clicked(): void {\r\n    if (typeof this.property.clickCallBack === 'function') {\r\n      this.property.clickCallBack();\r\n    } else {\r\n      this.dynamicFormUpdateService.clicked(this.property);\r\n    }\r\n  }\r\n}\r\n","<div class=\"app-property-value\">\r\n  <div class=\"app-input-wrapper\" [ngClass]=\"{'row' : horizontalAlign}\">\r\n\r\n    <label *ngIf=\"label\" for=\"formGroupInputSmall\" [ngClass]=\"{'col-3' : horizontalAlign}\">{{\r\n      label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger\">*</span></label>\r\n    <div [ngClass]=\"{'col-9' : horizontalAlign}\">\r\n      <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n        <textarea [id]='id' class=\"form-control \" placeholder=\"{{placeholder | translate}}\" [attr.disabled]=\"isDisabled() || null\" #editorInput matTextareaAutosize\r\n          matAutosizeMinRows=\"3\" matAutosizeMaxRows=\"5\" [(ngModel)]=\"editedValue\" (input)=\"onTextAreaInputChange()\"\r\n          (keyup)=\"update($event)\" [attr.data-automation-id]=\"'card-textitem-edittextarea-' \"></textarea>\r\n        <mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\"\r\n          *ngIf=\"hasErrors()\">\r\n          <ul>\r\n            <li *ngIf=\"control.errors.required\">\r\n              {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n            </li>\r\n          </ul>\r\n        </mat-error>\r\n      </ng-container>\r\n      <ng-template #readOnly>\r\n        {{editedValue}}\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n\r\n</div>\r\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-textarea.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textarea/dynamic-form-textarea.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textarea/dynamic-form-textarea.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  Optional,\r\n  Self,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { DynamicFormTextItemModel } from '../../models/dynamic-form.models';\r\nimport { DynamicFormUpdateService } from '../../services/dynamic-form-update.service';\r\n\r\n/**\r\n * A textarea input that can be used inside reactive or template driven forms\r\n * @title\r\n * Textarea\r\n * @example\r\n * <app-dynamic-form-textarea\r\n *    [horizontalAlign]=\"false\"\r\n *    formControlName=\"controlName\"\r\n *    [placeholder]=\"'PATH.TO.PLACEHOLDER.STRING'\"\r\n * ></app-dynamic-form-textarea>\r\n */\r\n@Component({\r\n  selector: 'app-dynamic-form-textarea',\r\n  templateUrl: './dynamic-form-textarea.component.html',\r\n  styleUrls: ['./dynamic-form-textarea.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormTextareaComponent\r\n  implements OnChanges, ControlValueAccessor\r\n{\r\n  static DEFAULT_SEPARATOR = ', ';\r\n  /** @deprecated */\r\n  @Input()\r\n  property: DynamicFormTextItemModel;\r\n\r\n  /** Field Label */\r\n  @Input()\r\n  label;\r\n  /** is editable */\r\n  @Input()\r\n  editable = true;\r\n  /** is dsisabled */\r\n  @Input()\r\n  disabled = false;\r\n  /** DOM element Id */\r\n  @Input()\r\n  id;\r\n  /** Input placeholder */\r\n  @Input() placeholder = '';\r\n  /** @deprecated */\r\n  @Input()\r\n  displayEmpty = true;\r\n\r\n  /**  make label and control side by side not vertical */\r\n  @Input() horizontalAlign = true;\r\n\r\n  @ViewChild('editorInput')\r\n  private editorInput: any;\r\n\r\n  inEdit = false;\r\n  editedValue: string;\r\n  errorMessages: string[];\r\n  valueSeparator: string;\r\n\r\n  constructor(\r\n    private dynamicFormUpdateService: DynamicFormUpdateService,\r\n    public translate: TranslateService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    this.control.valueAccessor = this;\r\n    this.valueSeparator = DynamicFormTextareaComponent.DEFAULT_SEPARATOR;\r\n  }\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n\r\n  isRequired() {\r\n    if (!this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  writeValue(obj: any): void {\r\n    this.editedValue = obj;\r\n    // this.property.value = obj;\r\n\r\n    //  throw new Error('Method not implemented.');\r\n  }\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    // this.editedValue = this.property.multiline\r\n    //  ? this.property.displayValue\r\n    // : this.property.value;\r\n  }\r\n\r\n  showProperty(): boolean {\r\n    return this.displayEmpty || !this.property.isEmpty();\r\n  }\r\n\r\n  showClickableIcon(): boolean {\r\n    return this.hasIcon() && this.editable;\r\n  }\r\n\r\n  isEditable(): boolean {\r\n    return this.editable;\r\n  }\r\n  isDisabled(): boolean {\r\n    return this.disabled;\r\n  }\r\n\r\n  isClickable(): boolean {\r\n    return !!this.property.clickable;\r\n  }\r\n\r\n  hasIcon(): boolean {\r\n    return !!this.property.icon;\r\n  }\r\n\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n\r\n  setEditMode(editStatus: boolean): void {\r\n    this.inEdit = editStatus;\r\n    setTimeout(() => {\r\n      if (this.editorInput) {\r\n        this.editorInput.nativeElement.click();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  reset(event: MouseEvent | KeyboardEvent): void {\r\n    event.stopPropagation();\r\n\r\n    /*\r\n     this.editedValue = this.property.multiline\r\n       ? this.property.displayValue\r\n       : this.property.value; */\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  private resetErrorMessages() {\r\n    this.errorMessages = [];\r\n  }\r\n\r\n  update(event: MouseEvent | KeyboardEvent): void {\r\n    event.stopPropagation();\r\n    const updatedValue = this.prepareValueForUpload(\r\n      this.property,\r\n      this.editedValue\r\n    );\r\n    // this.property.value = updatedValue;\r\n    this.onChange(updatedValue);\r\n    this.onTouched();\r\n    // this.dynamicFormUpdateService.update(this.property, updatedValue);\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  prepareValueForUpload(\r\n    property: DynamicFormTextItemModel,\r\n    value: string\r\n  ): string | string[] {\r\n    return value;\r\n  }\r\n\r\n  onTextAreaInputChange() {\r\n    if (this.property) {\r\n      this.errorMessages = this.property.getValidationErrors(this.editedValue);\r\n    }\r\n  }\r\n\r\n  clicked(): void {\r\n    if (typeof this.property.clickCallBack === 'function') {\r\n      this.property.clickCallBack();\r\n    } else {\r\n      this.dynamicFormUpdateService.clicked(this.property);\r\n    }\r\n  }\r\n}\r\n","<div class=\"app-property-value\">\r\n  <div class=\"app-input-wrapper\" [ngClass]=\"{'row' : horizontalAlign}\">\r\n\r\n    <label *ngIf=\"label\" for=\"formGroupInputSmall\" [ngClass]=\"{'col-3' : horizontalAlign}\">{{\r\n      label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger\">*</span></label>\r\n    <div [ngClass]=\"{'col-9' : horizontalAlign}\">\r\n      <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n        <textarea [id]='id' class=\"form-control \" placeholder=\"{{placeholder | translate}}\" [attr.disabled]=\"isDisabled() || null\" #editorInput matTextareaAutosize\r\n          matAutosizeMinRows=\"3\" matAutosizeMaxRows=\"5\" [(ngModel)]=\"editedValue\" (input)=\"onTextAreaInputChange()\"\r\n          (keyup)=\"update($event)\" [attr.data-automation-id]=\"'card-textitem-edittextarea-' \"></textarea>\r\n        <mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\"\r\n          *ngIf=\"hasErrors()\">\r\n          <ul>\r\n            <li *ngIf=\"control.errors.required\">\r\n              {{ 'VALIDATORS.REQUIRED' | translate }}\r\n            </li>\r\n          </ul>\r\n        </mat-error>\r\n      </ng-container>\r\n      <ng-template #readOnly>\r\n        {{editedValue}}\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n\r\n</div>\r\n"]}
@@ -23,7 +23,6 @@ export class DynamicFormTextItemComponent {
23
23
  this.translate = translate;
24
24
  this.control = control;
25
25
  this.autoComplete = false; // to get suggestions from backend when user type some letters
26
- this.nativeAutoComplete = false; // to get suggestions from browser natively
27
26
  this.autoComplete_pageProvider = '';
28
27
  this.autoComplete_propertyName = '';
29
28
  this.autoComplete_propertyKey = '';
@@ -169,20 +168,23 @@ export class DynamicFormTextItemComponent {
169
168
  }
170
169
  else {
171
170
  this.delayedAction = setTimeout(() => {
172
- this.onSearchInputChange();
171
+ this.onSearchInputChange;
173
172
  }, 1500);
174
173
  }
175
174
  }
176
175
  onSearchInputChange() {
177
176
  if (this.autoComplete) {
178
177
  let val = this.editorInput.nativeElement.value;
178
+ if ((val === null || val === void 0 ? void 0 : val.length) == 0) {
179
+ return;
180
+ }
179
181
  let params = {
180
182
  currentPageIndex: 0,
181
183
  offset: 0,
182
184
  pageSize: 40,
183
185
  pageProvider: this.autoComplete_pageProvider,
184
186
  };
185
- params[this.autoComplete_propertyName] = (val) ? `%${val}%` : '';
187
+ params[this.autoComplete_propertyName] = val;
186
188
  this.dynamicFormUpdateService
187
189
  .getTextBoxSuggestionResults(this.autoComplete_pageProvider, params, this.autoComplete_propertyKey, this.autoCompleteValueKey)
188
190
  .subscribe((data) => {
@@ -195,15 +197,12 @@ export class DynamicFormTextItemComponent {
195
197
  openOptions(value) {
196
198
  if (this.autoComplete) {
197
199
  this.showsuggestedOptions = value;
198
- if (!this.documentList.length && value) {
199
- this.onSearchInputChange();
200
- }
201
200
  }
202
201
  }
203
202
  }
204
203
  DynamicFormTextItemComponent.DEFAULT_SEPARATOR = ', ';
205
204
  DynamicFormTextItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicFormTextItemComponent, deps: [{ token: i1.DynamicFormUpdateService }, { token: i2.TranslateService }, { token: i3.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
206
- DynamicFormTextItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DynamicFormTextItemComponent, selector: "app-dynamic-form-textitem", inputs: { autoComplete: "autoComplete", nativeAutoComplete: "nativeAutoComplete", autoComplete_pageProvider: "autoComplete_pageProvider", autoComplete_propertyName: "autoComplete_propertyName", autoComplete_propertyKey: "autoComplete_propertyKey", autoCompleteValueKey: "autoCompleteValueKey", type: "type", property: "property", label: "label", editable: "editable", placeholder: "placeholder", disabled: "disabled", displayEmpty: "displayEmpty", preventSpace: "preventSpace", id: "id" }, viewQueries: [{ propertyName: "editorInput", first: true, predicate: ["editorInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"app-property-value\">\r\n <div class=\"app-input-wrapper\">\r\n <label *ngIf=\"label\" for=\"formGroupInputSmall\"\r\n >{{ label | translate\r\n }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n >\r\n <div class=\"\">\r\n <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n <div class=\"new-one\" (clickOutside)=\"openOptions(false)\">\r\n <input\r\n [id]=\"id\"\r\n [attr.disabled]=\"isDisabled() || null\"\r\n [type]=\"type\"\r\n class=\"form-control\"\r\n [ngClass]=\"{'input-filled' : editedValue }\"\r\n (keydown.space)=\"allowSpace($event)\"\r\n #editorInput\r\n [required]=\"isRequired()\"\r\n [(ngModel)]=\"editedValue\"\r\n [autocomplete]=\"nativeAutoComplete\"\r\n (ngModelChange)=\"update($event)\"\r\n (keyup)=\"waitUntilUserFinishTyping()\"\r\n [attr.data-automation-id]=\"'card-textitem-editinput-'\"\r\n placeholder=\"{{ placeholder | translate }}\"\r\n (focus)=\"openOptions(true)\"\r\n />\r\n <div *ngIf=\"documentList.length !== 0\" id=\"suggestedoptions\">\r\n <div\r\n class=\"suggestions-wrapper\"\r\n [ngClass]=\"{ 'd-block': showsuggestedOptions }\"\r\n >\r\n <div\r\n class=\"option\"\r\n id=\"suggestedoptions\"\r\n *ngFor=\"let option of documentList\"\r\n (click)=\"selectItem(option.title)\"\r\n >\r\n {{ option.title }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mat-error\r\n [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n class=\"app-textitem-editable-error\"\r\n *ngIf=\"hasErrors()\"\r\n >\r\n <ul>\r\n <li *ngIf=\"control.errors.required\">\r\n {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n </li>\r\n <li *ngIf=\"control.errors.pattern\">\r\n {{ \"wrong pattern\" | translate }}\r\n </li>\r\n <li *ngIf=\"control.errors.min\">\r\n {{ \"VALIDATORS.MIN\" | translate }} {{ control.errors.min.min }}\r\n </li>\r\n </ul>\r\n </mat-error>\r\n </ng-container>\r\n <ng-template #readOnly>\r\n {{ editedValue }}\r\n </ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-property-value .input-filled{border-color:#1a96c6!important}.app-property-value .app-input-wrapper label{color:#8f98aa;font-size:12px;margin-bottom:0}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;background-color:#8f98aa1a;border-radius:0;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .app-textitem-editable-error ul{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error ul li{margin-top:5px}.app-property-value .app-input-wrapper .new-one{position:relative}.app-property-value .app-input-wrapper .suggestions-wrapper{border-radius:3px;height:auto;max-height:240px;border:1px solid #ccc;box-shadow:2px 2px 2px #0000000f;overflow:auto;display:none;position:absolute;width:100%;background-color:#fff;z-index:99}.app-property-value .app-input-wrapper .suggestions-wrapper .option{margin-bottom:5px;padding:5px 10px;cursor:pointer}.app-property-value .app-input-wrapper .suggestions-wrapper .option:hover{background-color:#f5faff}\n"], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.ClickOutsideDirective, selector: "[clickOutside]", outputs: ["clickOutside"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "translate": i2.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
205
+ DynamicFormTextItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DynamicFormTextItemComponent, selector: "app-dynamic-form-textitem", inputs: { autoComplete: "autoComplete", autoComplete_pageProvider: "autoComplete_pageProvider", autoComplete_propertyName: "autoComplete_propertyName", autoComplete_propertyKey: "autoComplete_propertyKey", autoCompleteValueKey: "autoCompleteValueKey", type: "type", property: "property", label: "label", editable: "editable", placeholder: "placeholder", disabled: "disabled", displayEmpty: "displayEmpty", preventSpace: "preventSpace", id: "id" }, viewQueries: [{ propertyName: "editorInput", first: true, predicate: ["editorInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"app-property-value\">\r\n <div class=\"app-input-wrapper\">\r\n <label *ngIf=\"label\" for=\"formGroupInputSmall\"\r\n >{{ label | translate\r\n }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n >\r\n <div class=\"\">\r\n <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n <div class=\"new-one\" (clickOutside)=\"openOptions(false)\">\r\n <input\r\n [id]=\"id\"\r\n [attr.disabled]=\"isDisabled() || null\"\r\n [type]=\"type\"\r\n class=\"form-control\"\r\n [ngClass]=\"{'input-filled' : editedValue }\"\r\n (keydown.space)=\"allowSpace($event)\"\r\n #editorInput\r\n [required]=\"isRequired()\"\r\n [(ngModel)]=\"editedValue\"\r\n (ngModelChange)=\"update($event)\"\r\n (keyup)=\"waitUntilUserFinishTyping()\"\r\n [attr.data-automation-id]=\"'card-textitem-editinput-'\"\r\n placeholder=\"{{ placeholder | translate }}\"\r\n (focus)=\"openOptions(true)\"\r\n />\r\n <div *ngIf=\"documentList.length !== 0\" id=\"suggestedoptions\">\r\n <div\r\n class=\"suggestions-wrapper\"\r\n [ngClass]=\"{ 'd-block': showsuggestedOptions }\"\r\n >\r\n <div\r\n class=\"option\"\r\n id=\"suggestedoptions\"\r\n *ngFor=\"let option of documentList\"\r\n (click)=\"selectItem(option.title)\"\r\n >\r\n {{ option.title }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mat-error\r\n [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n class=\"app-textitem-editable-error\"\r\n *ngIf=\"hasErrors()\"\r\n >\r\n <ul>\r\n <li *ngIf=\"control.errors.required\">\r\n {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n </li>\r\n <li *ngIf=\"control.errors.pattern\">\r\n {{ \"wrong pattern\" | translate }}\r\n </li>\r\n </ul>\r\n </mat-error>\r\n </ng-container>\r\n <ng-template #readOnly>\r\n {{ editedValue }}\r\n </ng-template>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-property-value .input-filled{border-color:#1a96c6!important}.app-property-value .app-input-wrapper label{color:#8f98aa;font-size:12px;margin-bottom:0}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;background-color:#8f98aa1a;border-radius:0;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .app-textitem-editable-error ul{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error ul li{margin-top:5px}.app-property-value .app-input-wrapper .new-one{position:relative}.app-property-value .app-input-wrapper .suggestions-wrapper{border-radius:3px;height:auto;max-height:240px;border:1px solid #ccc;box-shadow:2px 2px 2px #0000000f;overflow:auto;display:none;position:absolute;width:100%;background-color:#fff;z-index:99}.app-property-value .app-input-wrapper .suggestions-wrapper .option{margin-bottom:5px;padding:5px 10px;cursor:pointer}.app-property-value .app-input-wrapper .suggestions-wrapper .option:hover{background-color:#f5faff}\n"], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.ClickOutsideDirective, selector: "[clickOutside]", outputs: ["clickOutside"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "translate": i2.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
207
206
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicFormTextItemComponent, decorators: [{
208
207
  type: Component,
209
208
  args: [{
@@ -218,8 +217,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
218
217
  type: Optional
219
218
  }] }]; }, propDecorators: { autoComplete: [{
220
219
  type: Input
221
- }], nativeAutoComplete: [{
222
- type: Input
223
220
  }], autoComplete_pageProvider: [{
224
221
  type: Input
225
222
  }], autoComplete_propertyName: [{
@@ -250,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
250
247
  type: ViewChild,
251
248
  args: ['editorInput']
252
249
  }] } });
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-textitem.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  Optional,\r\n  Self,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { DynamicFormTextItemModel } from '../../models/dynamic-form.models';\r\nimport { DynamicFormUpdateService } from '../../services/dynamic-form-update.service';\r\n\r\n/**\r\n * A text field input that can be used inside reactive or template driven forms\r\n * @title\r\n * Text Field\r\n * @example\r\n * <app-dynamic-form-textitem\r\n *    [horizontalAlign]=\"false\"\r\n *    formControlName=\"controlName\"\r\n *    [placeholder]=\"'PATH.TO.PLACEHOLDER.STRING'\"\r\n * ></app-dynamic-form-textitem>\r\n */\r\n\r\n@Component({\r\n  selector: 'app-dynamic-form-textitem',\r\n  templateUrl: './dynamic-form-textitem.component.html',\r\n  styleUrls: ['./dynamic-form-textitem.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormTextItemComponent\r\n  implements OnChanges, ControlValueAccessor {\r\n  static DEFAULT_SEPARATOR = ', ';\r\n\r\n  @Input() autoComplete = false; // to get suggestions from backend when user type some letters\r\n  @Input() nativeAutoComplete = false; // to get suggestions from browser natively\r\n  @Input() autoComplete_pageProvider = '';\r\n  @Input() autoComplete_propertyName = '';\r\n  @Input() autoComplete_propertyKey = '';\r\n  @Input() autoCompleteValueKey = '';\r\n\r\n  /** input type */\r\n  @Input()\r\n  type = 'text';\r\n  /** @deprecated */\r\n  @Input()\r\n  property: DynamicFormTextItemModel;\r\n  /** Field Label */\r\n  @Input()\r\n  label;\r\n  /** is Editable */\r\n  @Input()\r\n  editable = true;\r\n  /** Placeholder string */\r\n  @Input() placeholder = '';\r\n  /** is disabled */\r\n  @Input()\r\n  disabled = false;\r\n  /** @deprecated */\r\n  @Input()\r\n  displayEmpty = true;\r\n  /** should prevent space */\r\n  @Input()\r\n  preventSpace = false;\r\n  /** DOM element Id */\r\n  @Input()\r\n  id;\r\n\r\n  @ViewChild('editorInput')\r\n  private editorInput: any;\r\n\r\n  inEdit = false;\r\n  editedValue: string;\r\n  errorMessages: string[];\r\n  valueSeparator: string;\r\n  showsuggestedOptions = false;\r\n\r\n  constructor(\r\n    private dynamicFormUpdateService: DynamicFormUpdateService,\r\n    public translate: TranslateService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    this.control.valueAccessor = this;\r\n    this.valueSeparator = DynamicFormTextItemComponent.DEFAULT_SEPARATOR;\r\n  }\r\n  onChange: any = () => { };\r\n  onTouched: any = () => { };\r\n\r\n  isRequired() {\r\n    if (!this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  writeValue(obj: any): void {\r\n    this.editedValue = obj;\r\n    //this.property.value = obj;\r\n\r\n    //  throw new Error('Method not implemented.');\r\n  }\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    /*this.editedValue = this.property.multiline\r\n      ? this.property.displayValue\r\n      : this.property.value;*/\r\n  }\r\n\r\n  showProperty(): boolean {\r\n    return this.displayEmpty || !this.property.isEmpty();\r\n  }\r\n\r\n  showClickableIcon(): boolean {\r\n    return this.hasIcon() && this.editable;\r\n  }\r\n\r\n  isEditable(): boolean {\r\n    return this.editable;\r\n  }\r\n  isDisabled(): boolean {\r\n    return this.disabled;\r\n  }\r\n\r\n  isClickable(): boolean {\r\n    return !!this.property.clickable;\r\n  }\r\n\r\n  hasIcon(): boolean {\r\n    return !!this.property.icon;\r\n  }\r\n\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n  allowSpace(e) {\r\n    if (this.preventSpace) {\r\n      e.preventDefault();\r\n    }\r\n  }\r\n  setEditMode(editStatus: boolean): void {\r\n    this.inEdit = editStatus;\r\n    setTimeout(() => {\r\n      if (this.editorInput) {\r\n        this.editorInput?.nativeElement?.click();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  reset(event: MouseEvent | KeyboardEvent): void {\r\n    // event.stopPropagation();\r\n\r\n    /*this.editedValue = this.property.multiline\r\n      ? this.property.displayValue\r\n      : this.property.value;*/\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  private resetErrorMessages() {\r\n    this.errorMessages = [];\r\n  }\r\n\r\n  update(event: MouseEvent | KeyboardEvent): void {\r\n    // event.stopPropagation();\r\n    const updatedValue = this.prepareValueForUpload(\r\n      this.property,\r\n      this.editedValue\r\n    );\r\n    // this.property.value = updatedValue;\r\n    this.onChange(updatedValue);\r\n    this.onTouched();\r\n    // this.dynamicFormUpdateService.update(this.property, updatedValue);\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  prepareValueForUpload(\r\n    property: DynamicFormTextItemModel,\r\n    value: string\r\n  ): string | string[] {\r\n    return value;\r\n  }\r\n\r\n  onTextAreaInputChange() {\r\n    this.errorMessages = this.property.getValidationErrors(this.editedValue);\r\n  }\r\n\r\n  clicked(): void {\r\n    if (typeof this.property.clickCallBack === 'function') {\r\n      this.property.clickCallBack();\r\n    } else {\r\n      this.dynamicFormUpdateService.clicked(this.property);\r\n    }\r\n  }\r\n\r\n  selectItem(title) {\r\n    this.editedValue = title;\r\n    this.update(null);\r\n    this.showsuggestedOptions = false;\r\n    this.documentList = [];\r\n  }\r\n\r\n  documentList: any[] = [];\r\n  delayedAction;\r\n  waitUntilUserFinishTyping() {\r\n    if (this.delayedAction) {\r\n      clearTimeout(this.delayedAction);\r\n      this.delayedAction = setTimeout(() => {\r\n        this.onSearchInputChange();\r\n      }, 1500);\r\n    } else {\r\n      this.delayedAction = setTimeout(() => {\r\n        this.onSearchInputChange();\r\n      }, 1500);\r\n    }\r\n  }\r\n\r\n  onSearchInputChange() {\r\n    if (this.autoComplete) {\r\n      let val = this.editorInput.nativeElement.value;\r\n      let params = {\r\n        currentPageIndex: 0,\r\n        offset: 0,\r\n        pageSize: 40,\r\n        pageProvider: this.autoComplete_pageProvider,\r\n      };\r\n      params[this.autoComplete_propertyName] = (val) ? `%${val}%` : '';\r\n      this.dynamicFormUpdateService\r\n        .getTextBoxSuggestionResults(\r\n          this.autoComplete_pageProvider,\r\n          params,\r\n          this.autoComplete_propertyKey,\r\n          this.autoCompleteValueKey\r\n        )\r\n        .subscribe((data) => {\r\n          this.documentList = data.filter((option) =>\r\n            option.title.toLowerCase().includes(val.toLowerCase())\r\n          );\r\n          this.showsuggestedOptions = true;\r\n          return this.documentList;\r\n        });\r\n    }\r\n  }\r\n\r\n  openOptions(value) {\r\n    if (this.autoComplete) {\r\n      this.showsuggestedOptions = value;\r\n      if (!this.documentList.length && value) {\r\n        this.onSearchInputChange()\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div class=\"app-property-value\">\r\n  <div class=\"app-input-wrapper\">\r\n    <label *ngIf=\"label\" for=\"formGroupInputSmall\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n    >\r\n    <div class=\"\">\r\n      <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n        <div class=\"new-one\" (clickOutside)=\"openOptions(false)\">\r\n          <input\r\n            [id]=\"id\"\r\n            [attr.disabled]=\"isDisabled() || null\"\r\n            [type]=\"type\"\r\n            class=\"form-control\"\r\n            [ngClass]=\"{'input-filled' : editedValue }\"\r\n            (keydown.space)=\"allowSpace($event)\"\r\n            #editorInput\r\n            [required]=\"isRequired()\"\r\n            [(ngModel)]=\"editedValue\"\r\n            [autocomplete]=\"nativeAutoComplete\"\r\n            (ngModelChange)=\"update($event)\"\r\n            (keyup)=\"waitUntilUserFinishTyping()\"\r\n            [attr.data-automation-id]=\"'card-textitem-editinput-'\"\r\n            placeholder=\"{{ placeholder | translate }}\"\r\n            (focus)=\"openOptions(true)\"\r\n          />\r\n          <div *ngIf=\"documentList.length !== 0\" id=\"suggestedoptions\">\r\n            <div\r\n              class=\"suggestions-wrapper\"\r\n              [ngClass]=\"{ 'd-block': showsuggestedOptions }\"\r\n            >\r\n              <div\r\n                class=\"option\"\r\n                id=\"suggestedoptions\"\r\n                *ngFor=\"let option of documentList\"\r\n                (click)=\"selectItem(option.title)\"\r\n              >\r\n                {{ option.title }}\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <mat-error\r\n          [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n          class=\"app-textitem-editable-error\"\r\n          *ngIf=\"hasErrors()\"\r\n        >\r\n          <ul>\r\n            <li *ngIf=\"control.errors.required\">\r\n              {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n            </li>\r\n            <li *ngIf=\"control.errors.pattern\">\r\n              {{ \"wrong pattern\" | translate }}\r\n            </li>\r\n            <li *ngIf=\"control.errors.min\">\r\n              {{ \"VALIDATORS.MIN\" | translate }} {{ control.errors.min.min }}\r\n            </li>\r\n          </ul>\r\n        </mat-error>\r\n      </ng-container>\r\n      <ng-template #readOnly>\r\n        {{ editedValue }}\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
250
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-textitem.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-textitem/dynamic-form-textitem.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  Optional,\r\n  Self,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { DynamicFormTextItemModel } from '../../models/dynamic-form.models';\r\nimport { DynamicFormUpdateService } from '../../services/dynamic-form-update.service';\r\n\r\n/**\r\n * A text field input that can be used inside reactive or template driven forms\r\n * @title\r\n * Text Field\r\n * @example\r\n * <app-dynamic-form-textitem\r\n *    [horizontalAlign]=\"false\"\r\n *    formControlName=\"controlName\"\r\n *    [placeholder]=\"'PATH.TO.PLACEHOLDER.STRING'\"\r\n * ></app-dynamic-form-textitem>\r\n */\r\n\r\n@Component({\r\n  selector: 'app-dynamic-form-textitem',\r\n  templateUrl: './dynamic-form-textitem.component.html',\r\n  styleUrls: ['./dynamic-form-textitem.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormTextItemComponent\r\n  implements OnChanges, ControlValueAccessor\r\n{\r\n  static DEFAULT_SEPARATOR = ', ';\r\n\r\n  @Input() autoComplete = false; // to get suggestions from backend when user type some letters\r\n  @Input() autoComplete_pageProvider = '';\r\n  @Input() autoComplete_propertyName = '';\r\n  @Input() autoComplete_propertyKey = '';\r\n  @Input() autoCompleteValueKey = '';\r\n\r\n  /** input type */\r\n  @Input()\r\n  type = 'text';\r\n  /** @deprecated */\r\n  @Input()\r\n  property: DynamicFormTextItemModel;\r\n  /** Field Label */\r\n  @Input()\r\n  label;\r\n  /** is Editable */\r\n  @Input()\r\n  editable = true;\r\n  /** Placeholder string */\r\n  @Input() placeholder = '';\r\n  /** is disabled */\r\n  @Input()\r\n  disabled = false;\r\n  /** @deprecated */\r\n  @Input()\r\n  displayEmpty = true;\r\n  /** should prevent space */\r\n  @Input()\r\n  preventSpace = false;\r\n  /** DOM element Id */\r\n  @Input()\r\n  id;\r\n\r\n  @ViewChild('editorInput')\r\n  private editorInput: any;\r\n\r\n  inEdit = false;\r\n  editedValue: string;\r\n  errorMessages: string[];\r\n  valueSeparator: string;\r\n  showsuggestedOptions = false;\r\n\r\n  constructor(\r\n    private dynamicFormUpdateService: DynamicFormUpdateService,\r\n    public translate: TranslateService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    this.control.valueAccessor = this;\r\n    this.valueSeparator = DynamicFormTextItemComponent.DEFAULT_SEPARATOR;\r\n  }\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n\r\n  isRequired() {\r\n    if (!this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  writeValue(obj: any): void {\r\n    this.editedValue = obj;\r\n    //this.property.value = obj;\r\n\r\n    //  throw new Error('Method not implemented.');\r\n  }\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  ngOnChanges(): void {\r\n    /*this.editedValue = this.property.multiline\r\n      ? this.property.displayValue\r\n      : this.property.value;*/\r\n  }\r\n\r\n  showProperty(): boolean {\r\n    return this.displayEmpty || !this.property.isEmpty();\r\n  }\r\n\r\n  showClickableIcon(): boolean {\r\n    return this.hasIcon() && this.editable;\r\n  }\r\n\r\n  isEditable(): boolean {\r\n    return this.editable;\r\n  }\r\n  isDisabled(): boolean {\r\n    return this.disabled;\r\n  }\r\n\r\n  isClickable(): boolean {\r\n    return !!this.property.clickable;\r\n  }\r\n\r\n  hasIcon(): boolean {\r\n    return !!this.property.icon;\r\n  }\r\n\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n  allowSpace(e) {\r\n    if (this.preventSpace) {\r\n      e.preventDefault();\r\n    }\r\n  }\r\n  setEditMode(editStatus: boolean): void {\r\n    this.inEdit = editStatus;\r\n    setTimeout(() => {\r\n      if (this.editorInput) {\r\n        this.editorInput?.nativeElement?.click();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  reset(event: MouseEvent | KeyboardEvent): void {\r\n    // event.stopPropagation();\r\n\r\n    /*this.editedValue = this.property.multiline\r\n      ? this.property.displayValue\r\n      : this.property.value;*/\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  private resetErrorMessages() {\r\n    this.errorMessages = [];\r\n  }\r\n\r\n  update(event: MouseEvent | KeyboardEvent): void {\r\n    // event.stopPropagation();\r\n    const updatedValue = this.prepareValueForUpload(\r\n      this.property,\r\n      this.editedValue\r\n    );\r\n    // this.property.value = updatedValue;\r\n    this.onChange(updatedValue);\r\n    this.onTouched();\r\n    // this.dynamicFormUpdateService.update(this.property, updatedValue);\r\n    this.setEditMode(false);\r\n    this.resetErrorMessages();\r\n  }\r\n\r\n  prepareValueForUpload(\r\n    property: DynamicFormTextItemModel,\r\n    value: string\r\n  ): string | string[] {\r\n    return value;\r\n  }\r\n\r\n  onTextAreaInputChange() {\r\n    this.errorMessages = this.property.getValidationErrors(this.editedValue);\r\n  }\r\n\r\n  clicked(): void {\r\n    if (typeof this.property.clickCallBack === 'function') {\r\n      this.property.clickCallBack();\r\n    } else {\r\n      this.dynamicFormUpdateService.clicked(this.property);\r\n    }\r\n  }\r\n\r\n  selectItem(title) {\r\n    this.editedValue = title;\r\n    this.update(null);\r\n    this.showsuggestedOptions = false;\r\n    this.documentList = [];\r\n  }\r\n\r\n  documentList: any[] = [];\r\n  delayedAction;\r\n  waitUntilUserFinishTyping() {\r\n    if (this.delayedAction) {\r\n      clearTimeout(this.delayedAction);\r\n      this.delayedAction = setTimeout(() => {\r\n        this.onSearchInputChange();\r\n      }, 1500);\r\n    } else {\r\n      this.delayedAction = setTimeout(() => {\r\n        this.onSearchInputChange;\r\n      }, 1500);\r\n    }\r\n  }\r\n\r\n  onSearchInputChange() {\r\n    if (this.autoComplete) {\r\n      let val = this.editorInput.nativeElement.value;\r\n      if (val?.length == 0) {\r\n        return;\r\n      }\r\n      let params = {\r\n        currentPageIndex: 0,\r\n        offset: 0,\r\n        pageSize: 40,\r\n        pageProvider: this.autoComplete_pageProvider,\r\n      };\r\n      params[this.autoComplete_propertyName] = val;\r\n      this.dynamicFormUpdateService\r\n        .getTextBoxSuggestionResults(\r\n          this.autoComplete_pageProvider,\r\n          params,\r\n          this.autoComplete_propertyKey,\r\n          this.autoCompleteValueKey\r\n        )\r\n        .subscribe((data) => {\r\n          this.documentList = data.filter((option) =>\r\n            option.title.toLowerCase().includes(val.toLowerCase())\r\n          );\r\n          this.showsuggestedOptions = true;\r\n          return this.documentList;\r\n        });\r\n    }\r\n  }\r\n\r\n  openOptions(value) {\r\n    if (this.autoComplete) {\r\n      this.showsuggestedOptions = value;\r\n    }\r\n  }\r\n}\r\n","<div class=\"app-property-value\">\r\n  <div class=\"app-input-wrapper\">\r\n    <label *ngIf=\"label\" for=\"formGroupInputSmall\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n    >\r\n    <div class=\"\">\r\n      <ng-container *ngIf=\"isEditable(); else readOnly\">\r\n        <div class=\"new-one\" (clickOutside)=\"openOptions(false)\">\r\n          <input\r\n            [id]=\"id\"\r\n            [attr.disabled]=\"isDisabled() || null\"\r\n            [type]=\"type\"\r\n            class=\"form-control\"\r\n            [ngClass]=\"{'input-filled' : editedValue }\"\r\n            (keydown.space)=\"allowSpace($event)\"\r\n            #editorInput\r\n            [required]=\"isRequired()\"\r\n            [(ngModel)]=\"editedValue\"\r\n            (ngModelChange)=\"update($event)\"\r\n            (keyup)=\"waitUntilUserFinishTyping()\"\r\n            [attr.data-automation-id]=\"'card-textitem-editinput-'\"\r\n            placeholder=\"{{ placeholder | translate }}\"\r\n            (focus)=\"openOptions(true)\"\r\n          />\r\n          <div *ngIf=\"documentList.length !== 0\" id=\"suggestedoptions\">\r\n            <div\r\n              class=\"suggestions-wrapper\"\r\n              [ngClass]=\"{ 'd-block': showsuggestedOptions }\"\r\n            >\r\n              <div\r\n                class=\"option\"\r\n                id=\"suggestedoptions\"\r\n                *ngFor=\"let option of documentList\"\r\n                (click)=\"selectItem(option.title)\"\r\n              >\r\n                {{ option.title }}\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <mat-error\r\n          [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n          class=\"app-textitem-editable-error\"\r\n          *ngIf=\"hasErrors()\"\r\n        >\r\n          <ul>\r\n            <li *ngIf=\"control.errors.required\">\r\n              {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n            </li>\r\n            <li *ngIf=\"control.errors.pattern\">\r\n              {{ \"wrong pattern\" | translate }}\r\n            </li>\r\n          </ul>\r\n        </mat-error>\r\n      </ng-container>\r\n      <ng-template #readOnly>\r\n        {{ editedValue }}\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -21,18 +21,13 @@ export class DropdownTreeviewSelectI18n extends DefaultTreeviewI18n {
21
21
  get selectionLength() {
22
22
  return this.internalSelectionLength;
23
23
  }
24
- getFilterPlaceholder(val = null) {
24
+ getFilterPlaceholder() {
25
25
  let placeHolder;
26
- if (!val) {
27
- this.translation.isArabic.subscribe((arabic) => {
28
- arabic
29
- ? (placeHolder = 'أدخل رمز القسم للتصفية')
30
- : (placeHolder = 'Type Department Code To Filter ');
31
- });
32
- }
33
- else {
34
- placeHolder = this.translation.instant(val);
35
- }
26
+ this.translation.isArabic.subscribe((arabic) => {
27
+ arabic
28
+ ? (placeHolder = 'أدخل رمز القسم للتصفية')
29
+ : (placeHolder = 'Type Department Code To Filter ');
30
+ });
36
31
  return placeHolder;
37
32
  }
38
33
  getText(selection) {
@@ -50,12 +45,12 @@ export class DropdownTreeviewSelectI18n extends DefaultTreeviewI18n {
50
45
  ? `${this.internalSelectionLength} ${suffix}`
51
46
  : placeHolder;
52
47
  }
53
- getFilterNoItemsFoundText(val = null) {
48
+ getFilterNoItemsFoundText() {
54
49
  let noItemText;
55
50
  this.translation.isArabic.subscribe((arabic) => {
56
51
  arabic
57
- ? (noItemText = 'لم يتم العثور على نتائج')
58
- : (noItemText = 'No items were found');
52
+ ? (noItemText = 'لايوجد أقسام للعرض')
53
+ : (noItemText = 'No Departments Found');
59
54
  });
60
55
  return noItemText;
61
56
  }
@@ -65,4 +60,4 @@ DropdownTreeviewSelectI18n.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12
65
60
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DropdownTreeviewSelectI18n, decorators: [{
66
61
  type: Injectable
67
62
  }], ctorParameters: function () { return [{ type: i1.TranslationService }]; } });
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tdHJlZXZpZXctc2VsZWN0LWkxOG4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS10cmVldmlldy1zZWxlY3QvZHJvcGRvd24tdHJlZXZpZXctc2VsZWN0LWkxOG4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBR0wsbUJBQW1CLEdBQ3BCLE1BQU0sY0FBYyxDQUFDOzs7QUFHdEIsY0FBYztBQUVkLE1BQU0sT0FBTywwQkFBMkIsU0FBUSxtQkFBbUI7SUFDakUsWUFBb0IsV0FBK0I7UUFDakQsS0FBSyxFQUFFLENBQUM7UUFEVSxnQkFBVyxHQUFYLFdBQVcsQ0FBb0I7SUFFbkQsQ0FBQztJQUlELElBQUksWUFBWSxDQUFDLEtBQW1CO1FBQ2xDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDO0lBQ25DLENBQUM7SUFFRCxlQUFlO0lBQ2YsSUFBSSxlQUFlLENBQUMsS0FBYTtRQUMvQixJQUFJLENBQUMsdUJBQXVCLEdBQUcsS0FBSyxDQUFDO0lBQ3ZDLENBQUM7SUFDRCxJQUFJLGVBQWU7UUFDakIsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUM7SUFDdEMsQ0FBQztJQUNELG9CQUFvQixDQUFDLEdBQUcsR0FBRyxJQUFJO1FBQzdCLElBQUksV0FBVyxDQUFDO1FBQ2hCLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDUixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtnQkFDN0MsTUFBTTtvQkFDSixDQUFDLENBQUMsQ0FBQyxXQUFXLEdBQUcsd0JBQXdCLENBQUM7b0JBQzFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsR0FBRyxpQ0FBaUMsQ0FBQyxDQUFDO1lBQ3hELENBQUMsQ0FBQyxDQUFDO1NBQ0o7YUFBTTtZQUNMLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUM3QztRQUNELE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7SUFDRCxPQUFPLENBQUMsU0FBNEI7UUFDbEMsSUFBSSxXQUFXLENBQUM7UUFDaEIsSUFBSSxNQUFNLENBQUM7UUFDWCxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUM3QyxNQUFNO2dCQUNKLENBQUMsQ0FBQyxDQUFDLFdBQVcsR0FBRyxxQkFBcUIsQ0FBQztnQkFDdkMsQ0FBQyxDQUFDLENBQUMsV0FBVyxHQUFHLDBCQUEwQixDQUFDLENBQUM7WUFFL0MsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsc0JBQXNCLENBQUMsQ0FBQztRQUN6RSxDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sSUFBSSxDQUFDLG9CQUFvQjtZQUM5QixDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLElBQUk7WUFDaEMsQ0FBQyxDQUFDLElBQUksQ0FBQyx1QkFBdUI7Z0JBQzVCLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyx1QkFBdUIsSUFBSSxNQUFNLEVBQUU7Z0JBQzdDLENBQUMsQ0FBQyxXQUFXLENBQUM7SUFDcEIsQ0FBQztJQUNELHlCQUF5QixDQUFDLEdBQUcsR0FBRyxJQUFJO1FBQ2xDLElBQUksVUFBa0IsQ0FBQztRQUV2QixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUM3QyxNQUFNO2dCQUNKLENBQUMsQ0FBQyxDQUFDLFVBQVUsR0FBRyx5QkFBeUIsQ0FBQztnQkFDMUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxHQUFHLHFCQUFxQixDQUFDLENBQUM7UUFDM0MsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLFVBQVUsQ0FBQztJQUNwQixDQUFDOzt1SEE3RFUsMEJBQTBCOzJIQUExQiwwQkFBMEI7MkZBQTFCLDBCQUEwQjtrQkFEdEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtcclxuICBUcmVldmlld0l0ZW0sXHJcbiAgVHJlZXZpZXdTZWxlY3Rpb24sXHJcbiAgRGVmYXVsdFRyZWV2aWV3STE4bixcclxufSBmcm9tICduZ3gtdHJlZXZpZXcnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9Db3JlL3NlcnZpY2VzL3RyYW5zbGF0aW9uL3RyYW5zbGF0aW9uLnNlcnZpY2UnO1xyXG5cclxuLyoqIEBpZ25vcmUgKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRHJvcGRvd25UcmVldmlld1NlbGVjdEkxOG4gZXh0ZW5kcyBEZWZhdWx0VHJlZXZpZXdJMThuIHtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyYW5zbGF0aW9uOiBUcmFuc2xhdGlvblNlcnZpY2UpIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgfVxyXG4gIHByaXZhdGUgaW50ZXJuYWxTZWxlY3RlZEl0ZW06IFRyZWV2aWV3SXRlbTtcclxuICBwcml2YXRlIGludGVybmFsU2VsZWN0aW9uTGVuZ3RoOiBudW1iZXI7XHJcblxyXG4gIHNldCBzZWxlY3RlZEl0ZW0odmFsdWU6IFRyZWV2aWV3SXRlbSkge1xyXG4gICAgdGhpcy5pbnRlcm5hbFNlbGVjdGVkSXRlbSA9IHZhbHVlO1xyXG4gIH1cclxuXHJcbiAgZ2V0IHNlbGVjdGVkSXRlbSgpOiBUcmVldmlld0l0ZW0ge1xyXG4gICAgcmV0dXJuIHRoaXMuaW50ZXJuYWxTZWxlY3RlZEl0ZW07XHJcbiAgfVxyXG5cclxuICAvLyBmb3IgbXVsdGlwbGVcclxuICBzZXQgc2VsZWN0aW9uTGVuZ3RoKHZhbHVlOiBudW1iZXIpIHtcclxuICAgIHRoaXMuaW50ZXJuYWxTZWxlY3Rpb25MZW5ndGggPSB2YWx1ZTtcclxuICB9XHJcbiAgZ2V0IHNlbGVjdGlvbkxlbmd0aCgpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIHRoaXMuaW50ZXJuYWxTZWxlY3Rpb25MZW5ndGg7XHJcbiAgfVxyXG4gIGdldEZpbHRlclBsYWNlaG9sZGVyKHZhbCA9IG51bGwpOiBzdHJpbmcge1xyXG4gICAgbGV0IHBsYWNlSG9sZGVyO1xyXG4gICAgaWYgKCF2YWwpIHtcclxuICAgICAgdGhpcy50cmFuc2xhdGlvbi5pc0FyYWJpYy5zdWJzY3JpYmUoKGFyYWJpYykgPT4ge1xyXG4gICAgICAgIGFyYWJpY1xyXG4gICAgICAgICAgPyAocGxhY2VIb2xkZXIgPSAn2KPYr9iu2YQg2LHZhdiyINin2YTZgtiz2YUg2YTZhNiq2LXZgdmK2KknKVxyXG4gICAgICAgICAgOiAocGxhY2VIb2xkZXIgPSAnVHlwZSBEZXBhcnRtZW50IENvZGUgVG8gRmlsdGVyICcpO1xyXG4gICAgICB9KTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHBsYWNlSG9sZGVyID0gdGhpcy50cmFuc2xhdGlvbi5pbnN0YW50KHZhbCk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcGxhY2VIb2xkZXI7XHJcbiAgfVxyXG4gIGdldFRleHQoc2VsZWN0aW9uOiBUcmVldmlld1NlbGVjdGlvbik6IHN0cmluZyB7XHJcbiAgICBsZXQgcGxhY2VIb2xkZXI7XHJcbiAgICBsZXQgc3VmZml4O1xyXG4gICAgdGhpcy50cmFuc2xhdGlvbi5pc0FyYWJpYy5zdWJzY3JpYmUoKGFyYWJpYykgPT4ge1xyXG4gICAgICBhcmFiaWNcclxuICAgICAgICA/IChwbGFjZUhvbGRlciA9ICfYp9mE2LHYrNin2KEg2KXYrtiq2YrYp9ixINin2YTZgtiz2YUnKVxyXG4gICAgICAgIDogKHBsYWNlSG9sZGVyID0gJ1BsZWFzZSBzZWxlY3QgRGVwYXJ0bWVudCcpO1xyXG5cclxuICAgICAgYXJhYmljID8gKHN1ZmZpeCA9ICfYo9mC2LPYp9mFINmF2K7Yqtin2LHYqScpIDogKHN1ZmZpeCA9ICdEZXBhcnRtZW50cyBTZWxlY3RlZCcpO1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gdGhpcy5pbnRlcm5hbFNlbGVjdGVkSXRlbVxyXG4gICAgICA/IHRoaXMuaW50ZXJuYWxTZWxlY3RlZEl0ZW0udGV4dFxyXG4gICAgICA6IHRoaXMuaW50ZXJuYWxTZWxlY3Rpb25MZW5ndGhcclxuICAgICAgICA/IGAke3RoaXMuaW50ZXJuYWxTZWxlY3Rpb25MZW5ndGh9ICR7c3VmZml4fWBcclxuICAgICAgICA6IHBsYWNlSG9sZGVyO1xyXG4gIH1cclxuICBnZXRGaWx0ZXJOb0l0ZW1zRm91bmRUZXh0KHZhbCA9IG51bGwpOiBzdHJpbmcge1xyXG4gICAgbGV0IG5vSXRlbVRleHQ6IHN0cmluZztcclxuXHJcbiAgICB0aGlzLnRyYW5zbGF0aW9uLmlzQXJhYmljLnN1YnNjcmliZSgoYXJhYmljKSA9PiB7XHJcbiAgICAgIGFyYWJpY1xyXG4gICAgICAgID8gKG5vSXRlbVRleHQgPSAn2YTZhSDZitiq2YUg2KfZhNi52KvZiNixINi52YTZiSDZhtiq2KfYptisJylcclxuICAgICAgICA6IChub0l0ZW1UZXh0ID0gJ05vIGl0ZW1zIHdlcmUgZm91bmQnKTtcclxuICAgIH0pO1xyXG5cclxuICAgIHJldHVybiBub0l0ZW1UZXh0O1xyXG4gIH1cclxufVxyXG4iXX0=
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tdHJlZXZpZXctc2VsZWN0LWkxOG4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS10cmVldmlldy1zZWxlY3QvZHJvcGRvd24tdHJlZXZpZXctc2VsZWN0LWkxOG4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBR0wsbUJBQW1CLEdBQ3BCLE1BQU0sY0FBYyxDQUFDOzs7QUFHdEIsY0FBYztBQUVkLE1BQU0sT0FBTywwQkFBMkIsU0FBUSxtQkFBbUI7SUFDakUsWUFBb0IsV0FBK0I7UUFDakQsS0FBSyxFQUFFLENBQUM7UUFEVSxnQkFBVyxHQUFYLFdBQVcsQ0FBb0I7SUFFbkQsQ0FBQztJQUlELElBQUksWUFBWSxDQUFDLEtBQW1CO1FBQ2xDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDO0lBQ25DLENBQUM7SUFFRCxlQUFlO0lBQ2YsSUFBSSxlQUFlLENBQUMsS0FBYTtRQUMvQixJQUFJLENBQUMsdUJBQXVCLEdBQUcsS0FBSyxDQUFDO0lBQ3ZDLENBQUM7SUFDRCxJQUFJLGVBQWU7UUFDakIsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUM7SUFDdEMsQ0FBQztJQUNELG9CQUFvQjtRQUNsQixJQUFJLFdBQVcsQ0FBQztRQUNoQixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUM3QyxNQUFNO2dCQUNKLENBQUMsQ0FBQyxDQUFDLFdBQVcsR0FBRyx3QkFBd0IsQ0FBQztnQkFDMUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxHQUFHLGlDQUFpQyxDQUFDLENBQUM7UUFDeEQsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBQ0QsT0FBTyxDQUFDLFNBQTRCO1FBQ2xDLElBQUksV0FBVyxDQUFDO1FBQ2hCLElBQUksTUFBTSxDQUFDO1FBQ1gsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDN0MsTUFBTTtnQkFDSixDQUFDLENBQUMsQ0FBQyxXQUFXLEdBQUcscUJBQXFCLENBQUM7Z0JBQ3ZDLENBQUMsQ0FBQyxDQUFDLFdBQVcsR0FBRywwQkFBMEIsQ0FBQyxDQUFDO1lBRS9DLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLHNCQUFzQixDQUFDLENBQUM7UUFDekUsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksQ0FBQyxvQkFBb0I7WUFDOUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJO1lBQ2hDLENBQUMsQ0FBQyxJQUFJLENBQUMsdUJBQXVCO2dCQUM5QixDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsdUJBQXVCLElBQUksTUFBTSxFQUFFO2dCQUM3QyxDQUFDLENBQUMsV0FBVyxDQUFDO0lBQ2xCLENBQUM7SUFDRCx5QkFBeUI7UUFDdkIsSUFBSSxVQUFrQixDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQzdDLE1BQU07Z0JBQ0osQ0FBQyxDQUFDLENBQUMsVUFBVSxHQUFHLG9CQUFvQixDQUFDO2dCQUNyQyxDQUFDLENBQUMsQ0FBQyxVQUFVLEdBQUcsc0JBQXNCLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sVUFBVSxDQUFDO0lBQ3BCLENBQUM7O3VIQXZEVSwwQkFBMEI7MkhBQTFCLDBCQUEwQjsyRkFBMUIsMEJBQTBCO2tCQUR0QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1xyXG4gIFRyZWV2aWV3SXRlbSxcclxuICBUcmVldmlld1NlbGVjdGlvbixcclxuICBEZWZhdWx0VHJlZXZpZXdJMThuLFxyXG59IGZyb20gJ25neC10cmVldmlldyc7XHJcbmltcG9ydCB7IFRyYW5zbGF0aW9uU2VydmljZSB9IGZyb20gJy4uLy4uLy4uLy4uL0NvcmUvc2VydmljZXMvdHJhbnNsYXRpb24vdHJhbnNsYXRpb24uc2VydmljZSc7XHJcblxyXG4vKiogQGlnbm9yZSAqL1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBEcm9wZG93blRyZWV2aWV3U2VsZWN0STE4biBleHRlbmRzIERlZmF1bHRUcmVldmlld0kxOG4ge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRpb246IFRyYW5zbGF0aW9uU2VydmljZSkge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcbiAgcHJpdmF0ZSBpbnRlcm5hbFNlbGVjdGVkSXRlbTogVHJlZXZpZXdJdGVtO1xyXG4gIHByaXZhdGUgaW50ZXJuYWxTZWxlY3Rpb25MZW5ndGg6IG51bWJlcjtcclxuXHJcbiAgc2V0IHNlbGVjdGVkSXRlbSh2YWx1ZTogVHJlZXZpZXdJdGVtKSB7XHJcbiAgICB0aGlzLmludGVybmFsU2VsZWN0ZWRJdGVtID0gdmFsdWU7XHJcbiAgfVxyXG5cclxuICBnZXQgc2VsZWN0ZWRJdGVtKCk6IFRyZWV2aWV3SXRlbSB7XHJcbiAgICByZXR1cm4gdGhpcy5pbnRlcm5hbFNlbGVjdGVkSXRlbTtcclxuICB9XHJcblxyXG4gIC8vIGZvciBtdWx0aXBsZVxyXG4gIHNldCBzZWxlY3Rpb25MZW5ndGgodmFsdWU6IG51bWJlcikge1xyXG4gICAgdGhpcy5pbnRlcm5hbFNlbGVjdGlvbkxlbmd0aCA9IHZhbHVlO1xyXG4gIH1cclxuICBnZXQgc2VsZWN0aW9uTGVuZ3RoKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gdGhpcy5pbnRlcm5hbFNlbGVjdGlvbkxlbmd0aDtcclxuICB9XHJcbiAgZ2V0RmlsdGVyUGxhY2Vob2xkZXIoKTogc3RyaW5nIHtcclxuICAgIGxldCBwbGFjZUhvbGRlcjtcclxuICAgIHRoaXMudHJhbnNsYXRpb24uaXNBcmFiaWMuc3Vic2NyaWJlKChhcmFiaWMpID0+IHtcclxuICAgICAgYXJhYmljXHJcbiAgICAgICAgPyAocGxhY2VIb2xkZXIgPSAn2KPYr9iu2YQg2LHZhdiyINin2YTZgtiz2YUg2YTZhNiq2LXZgdmK2KknKVxyXG4gICAgICAgIDogKHBsYWNlSG9sZGVyID0gJ1R5cGUgRGVwYXJ0bWVudCBDb2RlIFRvIEZpbHRlciAnKTtcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIHBsYWNlSG9sZGVyO1xyXG4gIH1cclxuICBnZXRUZXh0KHNlbGVjdGlvbjogVHJlZXZpZXdTZWxlY3Rpb24pOiBzdHJpbmcge1xyXG4gICAgbGV0IHBsYWNlSG9sZGVyO1xyXG4gICAgbGV0IHN1ZmZpeDtcclxuICAgIHRoaXMudHJhbnNsYXRpb24uaXNBcmFiaWMuc3Vic2NyaWJlKChhcmFiaWMpID0+IHtcclxuICAgICAgYXJhYmljXHJcbiAgICAgICAgPyAocGxhY2VIb2xkZXIgPSAn2KfZhNix2KzYp9ihINil2K7YqtmK2KfYsSDYp9mE2YLYs9mFJylcclxuICAgICAgICA6IChwbGFjZUhvbGRlciA9ICdQbGVhc2Ugc2VsZWN0IERlcGFydG1lbnQnKTtcclxuXHJcbiAgICAgIGFyYWJpYyA/IChzdWZmaXggPSAn2KPZgtiz2KfZhSDZhdiu2KrYp9ix2KknKSA6IChzdWZmaXggPSAnRGVwYXJ0bWVudHMgU2VsZWN0ZWQnKTtcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIHRoaXMuaW50ZXJuYWxTZWxlY3RlZEl0ZW1cclxuICAgICAgPyB0aGlzLmludGVybmFsU2VsZWN0ZWRJdGVtLnRleHRcclxuICAgICAgOiB0aGlzLmludGVybmFsU2VsZWN0aW9uTGVuZ3RoXHJcbiAgICAgID8gYCR7dGhpcy5pbnRlcm5hbFNlbGVjdGlvbkxlbmd0aH0gJHtzdWZmaXh9YFxyXG4gICAgICA6IHBsYWNlSG9sZGVyO1xyXG4gIH1cclxuICBnZXRGaWx0ZXJOb0l0ZW1zRm91bmRUZXh0KCk6IHN0cmluZyB7XHJcbiAgICBsZXQgbm9JdGVtVGV4dDogc3RyaW5nO1xyXG4gICAgdGhpcy50cmFuc2xhdGlvbi5pc0FyYWJpYy5zdWJzY3JpYmUoKGFyYWJpYykgPT4ge1xyXG4gICAgICBhcmFiaWNcclxuICAgICAgICA/IChub0l0ZW1UZXh0ID0gJ9mE2KfZitmI2KzYryDYo9mC2LPYp9mFINmE2YTYudix2LYnKVxyXG4gICAgICAgIDogKG5vSXRlbVRleHQgPSAnTm8gRGVwYXJ0bWVudHMgRm91bmQnKTtcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIG5vSXRlbVRleHQ7XHJcbiAgfVxyXG59XHJcbiJdfQ==