nuxeo-development-framework 3.3.2 → 3.3.3-snapshot

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 (26) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +214 -224
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/components/cts-tags/components/correspondence-tags/correspondence-tags.component.js +2 -2
  4. package/esm2015/lib/components/custom-toastr/components/custom-toastr/custom-toastr.component.js +22 -2
  5. package/esm2015/lib/components/documents/components/document-scan/document-scan.service.js +1 -1
  6. package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.js +14 -3
  7. package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/services/department-api.service.js +18 -55
  8. package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.js +5 -2
  9. package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.js +2 -2
  10. package/esm2015/lib/components/dynamic-form/components/form-wrappers/user-selector-wrapper/user-selector-wrapper.component.js +2 -2
  11. package/esm2015/lib/components/dynamic-search/dynamic-search/dynamic-search.component.js +7 -1
  12. package/esm2015/lib/components/filter/filter/filter.component.js +1 -1
  13. package/esm2015/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.js +1 -1
  14. package/esm2015/lib/directive/app-has-role/app-has-role.directive.js +1 -1
  15. package/esm2015/public-api.js +1 -2
  16. package/fesm2015/nuxeo-development-framework.js +98 -114
  17. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  18. package/lib/components/custom-toastr/components/custom-toastr/custom-toastr.component.d.ts +11 -0
  19. package/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.d.ts +6 -3
  20. package/lib/components/dynamic-form/components/dynamic-form-department/services/department-api.service.d.ts +2 -4
  21. package/lib/components/dynamic-form/components/dynamic-form-select-tag/dynamic-form-select-tag.component.d.ts +2 -1
  22. package/lib/components/dynamic-search/dynamic-search/dynamic-search.component.d.ts +1 -0
  23. package/package.json +1 -1
  24. package/public-api.d.ts +0 -1
  25. package/esm2015/lib/shared-services/global-admin.service.js +0 -24
  26. package/lib/shared-services/global-admin.service.d.ts +0 -13
@@ -54,7 +54,7 @@ export class UserSelectorWrapperComponent {
54
54
  }
55
55
  }
56
56
  UserSelectorWrapperComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: UserSelectorWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
57
- UserSelectorWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: UserSelectorWrapperComponent, selector: "lib-user-selector-wrapper", inputs: { value: "value", multipleMode: "multipleMode", customOptions: "customOptions" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<cts-dynamic-form-select-users placeholder=\"{{ 'CREATE.PLACE_HOLDER' | translate }} {{'CREATE.USER' | translate}}\"\n [multiple]=\"multipleMode\"\n [searchable]=\"true\"\n [bindLabel]=\"'fullName'\"\n [closeOnSelect]=\"!multipleMode\"\n [searchable]=\"true\"\n [deptTitle]=\"'all'\"\n [preSelectedValues]=\"[]\"\n [usePreSelectedValue]=\"true\"\n (onSelectItems)=\"executeFunction($event)\"\n (ngModelChange)=\"checkChange($event)\"\n [(ngModel)]=\"bindedValue\" >\n</cts-dynamic-form-select-users>\n <!-- -->\n\n<!-- <div>{{customOptions | json}}</div>\n<div>{{multipleMode}}</div> -->", styles: [""], components: [{ type: i1.DynamicFormSelectUsersComponent, selector: "cts-dynamic-form-select-users", inputs: ["deptTitle", "label", "bindValue", "bindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "preSelectedValues", "usePreSelectedValue", "disabled", "filter"], outputs: ["onSelectItems"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i3.TranslatePipe } });
57
+ UserSelectorWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: UserSelectorWrapperComponent, selector: "lib-user-selector-wrapper", inputs: { value: "value", multipleMode: "multipleMode", customOptions: "customOptions" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<cts-dynamic-form-select-users placeholder=\"{{ 'CREATE.PLACE_HOLDER' | translate }} {{'CREATE.USER' | translate}}\"\r\n [multiple]=\"multipleMode\"\r\n [searchable]=\"true\"\r\n [bindLabel]=\"'fullName'\"\r\n [closeOnSelect]=\"!multipleMode\"\r\n [searchable]=\"true\"\r\n [deptTitle]=\"'all'\"\r\n [preSelectedValues]=\"[]\"\r\n [usePreSelectedValue]=\"true\"\r\n (onSelectItems)=\"executeFunction($event)\"\r\n (ngModelChange)=\"checkChange($event)\"\r\n [(ngModel)]=\"bindedValue\" >\r\n</cts-dynamic-form-select-users>\r\n <!-- -->\r\n\r\n<!-- <div>{{customOptions | json}}</div>\r\n<div>{{multipleMode}}</div> -->", styles: [""], components: [{ type: i1.DynamicFormSelectUsersComponent, selector: "cts-dynamic-form-select-users", inputs: ["deptTitle", "label", "bindValue", "bindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "preSelectedValues", "usePreSelectedValue", "disabled", "filter"], outputs: ["onSelectItems"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i3.TranslatePipe } });
58
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: UserSelectorWrapperComponent, decorators: [{
59
59
  type: Component,
60
60
  args: [{
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
71
71
  }], valueChange: [{
72
72
  type: Output
73
73
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvZm9ybS13cmFwcGVycy91c2VyLXNlbGVjdG9yLXdyYXBwZXIvdXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvZm9ybS13cmFwcGVycy91c2VyLXNlbGVjdG9yLXdyYXBwZXIvdXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBTy9FLE1BQU0sT0FBTyw0QkFBNEI7SUFjdkM7UUFUQSxpQkFBWSxHQUFXLEtBQUssQ0FBQztRQU83QixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFDekMsVUFBSyxHQUFHLENBQUMsQ0FBQztJQUNNLENBQUM7SUFFakIsUUFBUTtRQUNOLG9GQUFvRjtRQUNwRixJQUFJLGFBQWEsR0FBRyxXQUFXLENBQUMsR0FBRyxFQUFFO1lBQ25DLElBQUcsSUFBSSxDQUFDLEtBQUssS0FBSyxFQUFFLEVBQUM7Z0JBQ25CLGFBQWEsQ0FBQyxhQUFhLENBQUMsQ0FBQzthQUM5QjtpQkFBSTtnQkFDSCxJQUFHLElBQUksQ0FBQyxLQUFLLEVBQUM7b0JBQ1osSUFBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxFQUFDO3dCQUM1QixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7cUJBQ3hDO3lCQUFJO3dCQUNILElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztxQkFDL0I7b0JBQ0QsYUFBYSxDQUFDLGFBQWEsQ0FBQyxDQUFDO2lCQUM5QjtxQkFBSTtvQkFDSCxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQztpQkFDakI7YUFDRjtRQUNILENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUNWLENBQUM7SUFFRCxlQUFlLENBQUMsS0FBSztRQUNuQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsMENBQTBDO0lBQzVDLDZDQUE2QztJQUMzQyxXQUFXLENBQUMsS0FBSztRQUNmLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbkIsSUFBSSxDQUFDLEtBQUssR0FBRztZQUNYLFlBQVksRUFBRyxJQUFJO1lBQ25CLEtBQUssRUFBRyxLQUFLO1NBQ2QsQ0FBQTtRQUNELHlCQUF5QjtRQUN6QixvQkFBb0I7UUFDcEIsd0JBQXdCO1FBQ3hCLDZDQUE2QztRQUM3QyxPQUFPO1FBQ1AsdUJBQXVCO1FBQ3ZCLFNBQVM7UUFDVCw2Q0FBNkM7UUFDN0MsSUFBSTtJQUNOLENBQUM7O3lIQXhEVSw0QkFBNEI7NkdBQTVCLDRCQUE0QixvTUNQekMsMGxCQWdCK0I7MkZEVGxCLDRCQUE0QjtrQkFMeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMkJBQTJCO29CQUNyQyxXQUFXLEVBQUUsd0NBQXdDO29CQUNyRCxTQUFTLEVBQUUsQ0FBQyx1Q0FBdUMsQ0FBQztpQkFDckQ7MEVBR0MsS0FBSztzQkFESixLQUFLO2dCQUlOLFlBQVk7c0JBRFgsS0FBSztnQkFHRyxhQUFhO3NCQUFyQixLQUFLO2dCQUtOLFdBQVc7c0JBRFYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLXVzZXItc2VsZWN0b3Itd3JhcHBlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi91c2VyLXNlbGVjdG9yLXdyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi91c2VyLXNlbGVjdG9yLXdyYXBwZXIuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJTZWxlY3RvcldyYXBwZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICB2YWx1ZTtcblxuICBASW5wdXQoKSBcbiAgbXVsdGlwbGVNb2RlOmJvb2xlYW4gPSBmYWxzZTtcblxuICBASW5wdXQoKSBjdXN0b21PcHRpb25zO1xuXG4gIGJpbmRlZFZhbHVlOyAvLyB0byBiaW5kIHZhbHVlIGVtaXR0ZWQgdGVtcG9yYXJ5IHVudGlsIG1hcHBpbmcgaXQgaW4gY2hlY2tjaGFuZyBmdW5jdGlvblxuXG4gIEBPdXRwdXQoKVxuICB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xuICB0aW1lciA9IDA7XG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgLy8gY2hlY2sgZm9yIHNlbGVjdGVkIHZhbHVlcyB0byBiZSBwYXNzZWQgZnJvbSBvdXRzaWRlIGZvciAxMCBzZWMgdGhlbiBzdG9wIGNoZWNraW5nXG4gICAgbGV0IGNoZWNrZm9yVmFsdWUgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICBpZih0aGlzLnRpbWVyID09PSAxMCl7XG4gICAgICAgIGNsZWFySW50ZXJ2YWwoY2hlY2tmb3JWYWx1ZSk7XG4gICAgICB9ZWxzZXtcbiAgICAgICAgaWYodGhpcy52YWx1ZSl7XG4gICAgICAgICAgaWYodGhpcy52YWx1ZVsndXNlclNlbGVjdG9yJ10pe1xuICAgICAgICAgICAgdGhpcy5iaW5kZWRWYWx1ZSA9IHRoaXMudmFsdWVbJ3ZhbHVlJ107XG4gICAgICAgICAgfWVsc2V7XG4gICAgICAgICAgICB0aGlzLmJpbmRlZFZhbHVlID0gdGhpcy52YWx1ZTtcbiAgICAgICAgICB9XG4gICAgICAgICAgY2xlYXJJbnRlcnZhbChjaGVja2ZvclZhbHVlKTtcbiAgICAgICAgfWVsc2V7XG4gICAgICAgICAgdGhpcy50aW1lciArPSAxO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSwgMTAwMClcbiAgfVxuXG4gIGV4ZWN1dGVGdW5jdGlvbihldmVudCl7XG4gICAgdGhpcy52YWx1ZUNoYW5nZS5lbWl0KGV2ZW50KTtcbiAgfVxuICAvLyBzaGFwZSBvZiBlbWl0ZWQgdmFsdWUgZnJvbSB0aGUgd3JhcHBlciBcbi8vIHt1c2VyU2VsZWN0b3IgOiB0cnVlICwgdmFsdWUgOiB7fSB8fCBbe31dfVxuICBjaGVja0NoYW5nZShldmVudCl7XG4gICAgY29uc29sZS5sb2coZXZlbnQpO1xuICAgIHRoaXMudmFsdWUgPSB7XG4gICAgICB1c2VyU2VsZWN0b3IgOiB0cnVlLFxuICAgICAgdmFsdWUgOiBldmVudFxuICAgIH1cbiAgICAvLyBpZih0aGlzLm11bHRpcGxlTW9kZSl7XG4gICAgLy8gICBsZXQgbmFtZXMgPSBbXTtcbiAgICAvLyAgIGV2ZW50Lm1hcChpdGVtID0+IHtcbiAgICAvLyAgICAgbmFtZXMucHVzaChpdGVtPy5wcm9wZXJ0aWVzPy51c2VybmFtZSlcbiAgICAvLyAgIH0pXG4gICAgLy8gICB0aGlzLnZhbHVlID0gbmFtZXNcbiAgICAvLyB9ZWxzZXtcbiAgICAvLyAgIHRoaXMudmFsdWUgPSBldmVudD8ucHJvcGVydGllcz8udXNlcm5hbWVcbiAgICAvLyB9XG4gIH1cbn1cbiIsIjxjdHMtZHluYW1pYy1mb3JtLXNlbGVjdC11c2VycyBwbGFjZWhvbGRlcj1cInt7ICdDUkVBVEUuUExBQ0VfSE9MREVSJyB8IHRyYW5zbGF0ZSB9fSB7eydDUkVBVEUuVVNFUicgfCB0cmFuc2xhdGV9fVwiXG4gIFttdWx0aXBsZV09XCJtdWx0aXBsZU1vZGVcIlxuICBbc2VhcmNoYWJsZV09XCJ0cnVlXCJcbiAgW2JpbmRMYWJlbF09XCInZnVsbE5hbWUnXCJcbiAgW2Nsb3NlT25TZWxlY3RdPVwiIW11bHRpcGxlTW9kZVwiXG4gIFtzZWFyY2hhYmxlXT1cInRydWVcIlxuICBbZGVwdFRpdGxlXT1cIidhbGwnXCJcbiAgW3ByZVNlbGVjdGVkVmFsdWVzXT1cIltdXCJcbiAgW3VzZVByZVNlbGVjdGVkVmFsdWVdPVwidHJ1ZVwiXG4gIChvblNlbGVjdEl0ZW1zKT1cImV4ZWN1dGVGdW5jdGlvbigkZXZlbnQpXCJcbiAgKG5nTW9kZWxDaGFuZ2UpPVwiY2hlY2tDaGFuZ2UoJGV2ZW50KVwiXG4gIFsobmdNb2RlbCldPVwiYmluZGVkVmFsdWVcIiA+XG48L2N0cy1keW5hbWljLWZvcm0tc2VsZWN0LXVzZXJzPlxuICA8IS0tICAtLT5cblxuPCEtLSA8ZGl2Pnt7Y3VzdG9tT3B0aW9ucyB8IGpzb259fTwvZGl2PlxuPGRpdj57e211bHRpcGxlTW9kZX19PC9kaXY+IC0tPiJdfQ==
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvZm9ybS13cmFwcGVycy91c2VyLXNlbGVjdG9yLXdyYXBwZXIvdXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvZm9ybS13cmFwcGVycy91c2VyLXNlbGVjdG9yLXdyYXBwZXIvdXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBTy9FLE1BQU0sT0FBTyw0QkFBNEI7SUFjdkM7UUFUQSxpQkFBWSxHQUFXLEtBQUssQ0FBQztRQU83QixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFDekMsVUFBSyxHQUFHLENBQUMsQ0FBQztJQUNNLENBQUM7SUFFakIsUUFBUTtRQUNOLG9GQUFvRjtRQUNwRixJQUFJLGFBQWEsR0FBRyxXQUFXLENBQUMsR0FBRyxFQUFFO1lBQ25DLElBQUcsSUFBSSxDQUFDLEtBQUssS0FBSyxFQUFFLEVBQUM7Z0JBQ25CLGFBQWEsQ0FBQyxhQUFhLENBQUMsQ0FBQzthQUM5QjtpQkFBSTtnQkFDSCxJQUFHLElBQUksQ0FBQyxLQUFLLEVBQUM7b0JBQ1osSUFBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxFQUFDO3dCQUM1QixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7cUJBQ3hDO3lCQUFJO3dCQUNILElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztxQkFDL0I7b0JBQ0QsYUFBYSxDQUFDLGFBQWEsQ0FBQyxDQUFDO2lCQUM5QjtxQkFBSTtvQkFDSCxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQztpQkFDakI7YUFDRjtRQUNILENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUNWLENBQUM7SUFFRCxlQUFlLENBQUMsS0FBSztRQUNuQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsMENBQTBDO0lBQzVDLDZDQUE2QztJQUMzQyxXQUFXLENBQUMsS0FBSztRQUNmLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbkIsSUFBSSxDQUFDLEtBQUssR0FBRztZQUNYLFlBQVksRUFBRyxJQUFJO1lBQ25CLEtBQUssRUFBRyxLQUFLO1NBQ2QsQ0FBQTtRQUNELHlCQUF5QjtRQUN6QixvQkFBb0I7UUFDcEIsd0JBQXdCO1FBQ3hCLDZDQUE2QztRQUM3QyxPQUFPO1FBQ1AsdUJBQXVCO1FBQ3ZCLFNBQVM7UUFDVCw2Q0FBNkM7UUFDN0MsSUFBSTtJQUNOLENBQUM7O3lIQXhEVSw0QkFBNEI7NkdBQTVCLDRCQUE0QixvTUNQekMsMG5CQWdCK0I7MkZEVGxCLDRCQUE0QjtrQkFMeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMkJBQTJCO29CQUNyQyxXQUFXLEVBQUUsd0NBQXdDO29CQUNyRCxTQUFTLEVBQUUsQ0FBQyx1Q0FBdUMsQ0FBQztpQkFDckQ7MEVBR0MsS0FBSztzQkFESixLQUFLO2dCQUlOLFlBQVk7c0JBRFgsS0FBSztnQkFHRyxhQUFhO3NCQUFyQixLQUFLO2dCQUtOLFdBQVc7c0JBRFYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLXVzZXItc2VsZWN0b3Itd3JhcHBlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3VzZXItc2VsZWN0b3Itd3JhcHBlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdXNlci1zZWxlY3Rvci13cmFwcGVyLmNvbXBvbmVudC5jc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVXNlclNlbGVjdG9yV3JhcHBlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KClcclxuICB2YWx1ZTtcclxuXHJcbiAgQElucHV0KCkgXHJcbiAgbXVsdGlwbGVNb2RlOmJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KCkgY3VzdG9tT3B0aW9ucztcclxuXHJcbiAgYmluZGVkVmFsdWU7IC8vIHRvIGJpbmQgdmFsdWUgZW1pdHRlZCB0ZW1wb3JhcnkgdW50aWwgbWFwcGluZyBpdCBpbiBjaGVja2NoYW5nIGZ1bmN0aW9uXHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcbiAgdGltZXIgPSAwO1xyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgLy8gY2hlY2sgZm9yIHNlbGVjdGVkIHZhbHVlcyB0byBiZSBwYXNzZWQgZnJvbSBvdXRzaWRlIGZvciAxMCBzZWMgdGhlbiBzdG9wIGNoZWNraW5nXHJcbiAgICBsZXQgY2hlY2tmb3JWYWx1ZSA9IHNldEludGVydmFsKCgpID0+IHtcclxuICAgICAgaWYodGhpcy50aW1lciA9PT0gMTApe1xyXG4gICAgICAgIGNsZWFySW50ZXJ2YWwoY2hlY2tmb3JWYWx1ZSk7XHJcbiAgICAgIH1lbHNle1xyXG4gICAgICAgIGlmKHRoaXMudmFsdWUpe1xyXG4gICAgICAgICAgaWYodGhpcy52YWx1ZVsndXNlclNlbGVjdG9yJ10pe1xyXG4gICAgICAgICAgICB0aGlzLmJpbmRlZFZhbHVlID0gdGhpcy52YWx1ZVsndmFsdWUnXTtcclxuICAgICAgICAgIH1lbHNle1xyXG4gICAgICAgICAgICB0aGlzLmJpbmRlZFZhbHVlID0gdGhpcy52YWx1ZTtcclxuICAgICAgICAgIH1cclxuICAgICAgICAgIGNsZWFySW50ZXJ2YWwoY2hlY2tmb3JWYWx1ZSk7XHJcbiAgICAgICAgfWVsc2V7XHJcbiAgICAgICAgICB0aGlzLnRpbWVyICs9IDE7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9LCAxMDAwKVxyXG4gIH1cclxuXHJcbiAgZXhlY3V0ZUZ1bmN0aW9uKGV2ZW50KXtcclxuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdChldmVudCk7XHJcbiAgfVxyXG4gIC8vIHNoYXBlIG9mIGVtaXRlZCB2YWx1ZSBmcm9tIHRoZSB3cmFwcGVyIFxyXG4vLyB7dXNlclNlbGVjdG9yIDogdHJ1ZSAsIHZhbHVlIDoge30gfHwgW3t9XX1cclxuICBjaGVja0NoYW5nZShldmVudCl7XHJcbiAgICBjb25zb2xlLmxvZyhldmVudCk7XHJcbiAgICB0aGlzLnZhbHVlID0ge1xyXG4gICAgICB1c2VyU2VsZWN0b3IgOiB0cnVlLFxyXG4gICAgICB2YWx1ZSA6IGV2ZW50XHJcbiAgICB9XHJcbiAgICAvLyBpZih0aGlzLm11bHRpcGxlTW9kZSl7XHJcbiAgICAvLyAgIGxldCBuYW1lcyA9IFtdO1xyXG4gICAgLy8gICBldmVudC5tYXAoaXRlbSA9PiB7XHJcbiAgICAvLyAgICAgbmFtZXMucHVzaChpdGVtPy5wcm9wZXJ0aWVzPy51c2VybmFtZSlcclxuICAgIC8vICAgfSlcclxuICAgIC8vICAgdGhpcy52YWx1ZSA9IG5hbWVzXHJcbiAgICAvLyB9ZWxzZXtcclxuICAgIC8vICAgdGhpcy52YWx1ZSA9IGV2ZW50Py5wcm9wZXJ0aWVzPy51c2VybmFtZVxyXG4gICAgLy8gfVxyXG4gIH1cclxufVxyXG4iLCI8Y3RzLWR5bmFtaWMtZm9ybS1zZWxlY3QtdXNlcnMgcGxhY2Vob2xkZXI9XCJ7eyAnQ1JFQVRFLlBMQUNFX0hPTERFUicgfCB0cmFuc2xhdGUgfX0ge3snQ1JFQVRFLlVTRVInIHwgdHJhbnNsYXRlfX1cIlxyXG4gIFttdWx0aXBsZV09XCJtdWx0aXBsZU1vZGVcIlxyXG4gIFtzZWFyY2hhYmxlXT1cInRydWVcIlxyXG4gIFtiaW5kTGFiZWxdPVwiJ2Z1bGxOYW1lJ1wiXHJcbiAgW2Nsb3NlT25TZWxlY3RdPVwiIW11bHRpcGxlTW9kZVwiXHJcbiAgW3NlYXJjaGFibGVdPVwidHJ1ZVwiXHJcbiAgW2RlcHRUaXRsZV09XCInYWxsJ1wiXHJcbiAgW3ByZVNlbGVjdGVkVmFsdWVzXT1cIltdXCJcclxuICBbdXNlUHJlU2VsZWN0ZWRWYWx1ZV09XCJ0cnVlXCJcclxuICAob25TZWxlY3RJdGVtcyk9XCJleGVjdXRlRnVuY3Rpb24oJGV2ZW50KVwiXHJcbiAgKG5nTW9kZWxDaGFuZ2UpPVwiY2hlY2tDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgWyhuZ01vZGVsKV09XCJiaW5kZWRWYWx1ZVwiID5cclxuPC9jdHMtZHluYW1pYy1mb3JtLXNlbGVjdC11c2Vycz5cclxuICA8IS0tICAtLT5cclxuXHJcbjwhLS0gPGRpdj57e2N1c3RvbU9wdGlvbnMgfCBqc29ufX08L2Rpdj5cclxuPGRpdj57e211bHRpcGxlTW9kZX19PC9kaXY+IC0tPiJdfQ==
@@ -85,6 +85,9 @@ export class DynamicSearchComponent {
85
85
  if (changes.openCloseFilterFromOutside) {
86
86
  this.openFilter = changes.openCloseFilterFromOutside.currentValue;
87
87
  }
88
+ else if (!changes.sortingArray.firstChange) {
89
+ this.getTableData({ aggregations: this.originalAggregations });
90
+ }
88
91
  }
89
92
  ngOnInit() {
90
93
  this.updateQueryParams(this.constructParamsFunction(this.route.snapshot.queryParams));
@@ -148,6 +151,9 @@ export class DynamicSearchComponent {
148
151
  }
149
152
  paginationChange(event) { }
150
153
  getTableData(data) {
154
+ if (!this.originalAggregations) {
155
+ this.originalAggregations = data.aggregations;
156
+ }
151
157
  this.loading = false;
152
158
  this.aggregations = Object.entries(data.aggregations || {}).map((item) => {
153
159
  return item[1];
@@ -320,4 +326,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
320
326
  }], theme: [{
321
327
  type: Input
322
328
  }] } });
323
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-search/dynamic-search/dynamic-search.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-search/dynamic-search/dynamic-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation, OnChanges, SimpleChanges, Inject } from '@angular/core';\r\nimport { FormGroup, FormControl } from '@angular/forms';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { DocumentsConstants } from '../../../components/documents/constants/documents';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\nimport * as _ from 'lodash';\r\nimport { animate, AUTO_STYLE, state, style, transition, trigger } from '@angular/animations';\r\nimport { threadId } from 'worker_threads';\r\nimport { EvaluatorsService } from '../../../directive/permissions/evaluators.service';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { from, Observable } from 'rxjs';\r\nimport { NuxeoService } from '../../../Core/services/nuxeo/nuxeo.service';\r\n\r\n/**\r\n * Dynamic search component uses [Dynamic Table]{@link DynamicTableComponent} & [Dynamic Filter]{@link DynamicFilterComponent} internally,\r\n * and utilizes its inputs to perform advanced search and filtering on any nuxeo Provider\r\n * @title\r\n * Dynamic Search\r\n *\r\n * @example\r\n * <cts-dynamic-search\r\n *   [pageProvider]=\"'pageProviderName'\"\r\n *   [columns]=\"columnsArray\"\r\n *   [responsiveColumns]=\"responsiveColumnsArray\"\r\n *   [entityType]=\"'documents'\"\r\n *   [prefix]=\"prefix\"\r\n *   [fields]=\"fields\"\r\n *   [headers]=\"headers\"\r\n *   [sortingBy]=\"sortingBy\"\r\n *   [pageSize]=\"PageSize\"\r\n*    [customResponsiveStyle]=\"false or true\"\r\n     [openCloseFilterFromOutside]=\"pass Filter state from parent component\"\r\n     [theme] = \"to  set background depened on theme\"\r\n * >\r\n * </cts-dynamic-search>\r\n */\r\n@Component({\r\n  selector: 'cts-dynamic-search',\r\n  templateUrl: './dynamic-search.component.html',\r\n  styleUrls: ['./dynamic-search.component.scss'],\r\n  animations: [\r\n    trigger('collapse', [\r\n      state('false', style({ height: AUTO_STYLE, visibility: AUTO_STYLE })),\r\n      state('true', style({ height: '0', visibility: 'hidden' })),\r\n      transition('false => true', animate(300)),\r\n      transition('true => false', animate(300))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DynamicSearchComponent implements OnInit,OnChanges {\r\n  text: string;\r\n  aggregations;\r\n  /** Array of columns */\r\n  @Input() columns;\r\n  /** Array of columns on smaller screens */\r\n  @Input() responsiveColumns?;\r\n  /** Defines the page in which table is being used */\r\n  @Input() entityType: string;\r\n  /** Translations prefix */\r\n  @Input() prefix = '';\r\n  /** Headers to be sent with API Request */\r\n  @Input() headers;\r\n  /** Fields keymap to be mapped in the adapter */\r\n  @Input() fields;\r\n  /** Page Provider name that will be used to retrieve data */\r\n  @Input() pageProvider;\r\n  /** Controls number of items per page in table */\r\n  @Input() pageSize;\r\n  /** Sorting column */\r\n  @Input() sortingBy?= {};\r\n  @Input() fullTextParamName = 'system_fulltext';\r\n  @Input() filter; // used to pass params from outside to params of dynamic table directly\r\n\r\n  @Input() \r\n  onRowSelected = (row) => {\r\n    this.router.navigate([{ outlets: { viewer: ['view', row['uid']] } }], {\r\n      queryParams: { location: this.router.url },\r\n    });\r\n  }\r\n  /** used to emit any actions to outside */\r\n  @Output() actionOnRow = new EventEmitter();\r\n  queryParams = {};\r\n  filters;\r\n  searchForm = new FormGroup({\r\n    text: new FormControl(null),\r\n    personalFiles : new FormControl(false),\r\n    depFiles : new FormControl(false),\r\n    workSpaceFiles : new FormControl(false)\r\n  });\r\n  loading = false;\r\n  totalRecords;\r\n  openFilter: boolean;\r\n  @Input()\r\n  sortingArray;\r\n  @Input() customResponsiveStyle: boolean = false;\r\n  @Input() openCloseFilterFromOutside: boolean = false;\r\n  @Input() theme :any;\r\n  useToggleFilters;\r\n\r\n  quickFilters = '';\r\n  savedPersFilterValue = null;\r\n  savedDepFilterValue = null;\r\n  savedworkSpaceFilterValue = null;\r\n\r\n  resultSets = [];\r\n  constructor(\r\n    private route: ActivatedRoute,\r\n    private router: Router,\r\n    private evaluatorService : EvaluatorsService,\r\n    private nuxeoService : NuxeoService,\r\n    @Inject('environment') private environment,\r\n    public breakpointObserver: BreakpointObserver\r\n  ) { \r\n    this.evaluatorService.evaluateRule('enableSearchToggles' , {}).then(res => {\r\n      this.useToggleFilters = res;\r\n    })\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes.openCloseFilterFromOutside) {\r\n      this.openFilter = changes.openCloseFilterFromOutside.currentValue;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    \r\n    this.updateQueryParams(this.constructParamsFunction(this.route.snapshot.queryParams));\r\n    this.searchInputPopulate();\r\n    this.route.queryParams.subscribe((params) => {\r\n      if (\r\n        (this.text !== params['search_query'] && params['search_query']) ||\r\n        (params['search_query']?.length == 0 && this.text !== params['search_query'] || \r\n        (this.useToggleFilters && this.quickFilters !== params['quickFilters'])) \r\n      ) {\r\n        this.updateQueryParams(this.constructParamsFunction(params));\r\n        this.searchInputPopulate();\r\n      }\r\n    });\r\n    this.breakpoint();\r\n    \r\n   this.searchForm.get('text').valueChanges.pipe(\r\n    debounceTime(500)).subscribe(res => {\r\n      this.search(res).subscribe(results => {\r\n        this.resultSets = results;\r\n      })\r\n   })\r\n  }\r\n\r\n  constructParamsFunction(params){\r\n    let contructedParms = {};\r\n    this.text = params['search_query'];\r\n    if(this.useToggleFilters){\r\n      if(params['quickFilters']){\r\n        this.quickFilters = params['quickFilters'] ;\r\n        contructedParms = { [this.fullTextParamName] : this.text , quickFilters : this.quickFilters}\r\n      }else{\r\n        this.quickFilters = '';\r\n        contructedParms = { [this.fullTextParamName] : this.text , quickFilters : ''}\r\n      }\r\n    }else{\r\n      contructedParms = { [this.fullTextParamName] : this.text}\r\n    }\r\n\r\n    return contructedParms;\r\n  }\r\n  updateQueryParams(newQueryparams: object) {\r\n    this.queryParams = {\r\n      ...this.queryParams,\r\n      ...newQueryparams,\r\n    };\r\n  }\r\n  \r\n  searchInputPopulate() {\r\n    if(this.useToggleFilters){\r\n      this.searchForm.patchValue({\r\n        text: this.text,\r\n        personalFiles : (this.quickFilters === 'personalFilter' ) ? true : (this.savedPersFilterValue !== null) ? this.savedPersFilterValue : false,\r\n        depFiles : (this.quickFilters === 'departmentFilter') ? true : (this.savedDepFilterValue !== null) ? this.savedDepFilterValue : false ,\r\n        workSpaceFiles : (this.quickFilters === 'departmentWorkSpaceFilter') ? true : (this.savedworkSpaceFilterValue !== null) ? this.savedworkSpaceFilterValue : false \r\n\r\n      });\r\n    }else{\r\n      this.searchForm.patchValue({\r\n        text: this.text,\r\n      });\r\n    }\r\n  }\r\n\r\n  FilterSelected(val: any) {\r\n    this.loading = true;\r\n    this.filters = { ...this.filters, ...val.filter }; //store filters\r\n    this.updateQueryParams(this.filters);\r\n  }\r\n\r\n  paginationChange(event) { }\r\n\r\n  getTableData(data) {\r\n    this.loading = false;\r\n    this.aggregations = Object.entries(data.aggregations || {}).map((item) => {\r\n      return item[1];\r\n    });\r\n    // this.aggregations = this.aggregations.filter((item) =>\r\n    //   this.sortingArray.includes(item.id)\r\n    // );\r\n    let updatedAggregation = [];\r\n    this.aggregations.map(aggreg => {\r\n      this.sortingArray.map(sortType => {\r\n        if(sortType.id === aggreg.id){\r\n          aggreg['componentType'] = sortType.compoenentType;\r\n          // in case of custom component need to call page provider to get data \r\n          if(sortType.compoenentType === 'custom-pp' || sortType.compoenentType === 'custom-document' || sortType.compoenentType === 'custom-department'){\r\n            aggreg['customPageProvider'] = sortType.pageProvider,\r\n            aggreg['config'] = sortType.config\r\n          }\r\n          updatedAggregation.push(aggreg)\r\n        }\r\n      })\r\n    })\r\n    this.aggregations = _.sortBy(updatedAggregation, (item) => {\r\n      let i = -1;\r\n       this.sortingArray.map((sortType , index) => {\r\n         if(sortType.id === item.id){\r\n           i = index;\r\n         }\r\n       });\r\n       return i;\r\n    });\r\n    console.log('aggregations', this.aggregations);\r\n    this.totalRecords = data.totalSize;\r\n  }\r\n\r\n  submitForm() {\r\n    let params = {} ;\r\n    if(this.useToggleFilters){\r\n      params = {\r\n        search_query: this.searchForm.controls.text.value,\r\n        quickFilters : this.getToggleFilters()\r\n      }\r\n    }else{\r\n      params = {\r\n        search_query: this.searchForm.controls.text.value,\r\n      }\r\n    }\r\n    this.router.navigate(['.'], {\r\n      relativeTo: this.route,\r\n      queryParams: params,\r\n    });\r\n  }\r\n\r\n  getToggleFilters() {\r\n    this.savedDepFilterValue = this.searchForm.controls.depFiles.value;\r\n    this.savedPersFilterValue = this.searchForm.controls.personalFiles.value;\r\n    this.savedworkSpaceFilterValue = this.searchForm.controls.workSpaceFiles.value;\r\n    if ((this.savedPersFilterValue && this.savedDepFilterValue && this.savedworkSpaceFilterValue)\r\n      || (!this.savedPersFilterValue && !this.savedDepFilterValue && !this.savedworkSpaceFilterValue)) {\r\n      return '';\r\n    } else if (this.savedPersFilterValue && !this.savedDepFilterValue && !this.savedworkSpaceFilterValue) {\r\n      return \"personalFilter\";\r\n\r\n    } else if (!this.savedPersFilterValue && this.savedDepFilterValue && !this.savedworkSpaceFilterValue) {\r\n      return \"departmentFilter\";\r\n\r\n    } else if (!this.savedPersFilterValue && !this.savedDepFilterValue && this.savedworkSpaceFilterValue) {\r\n      return \"departmentWorkSpaceFilter\";\r\n    }\r\n    else if (this.savedPersFilterValue && this.savedDepFilterValue && !this.savedworkSpaceFilterValue) {\r\n      return \"departmentPersonalFilter\";\r\n\r\n    }\r\n    else if (this.savedPersFilterValue && !this.savedDepFilterValue && this.savedworkSpaceFilterValue) {\r\n      return \"personalDepartmentWorkSpaceFilter\";\r\n\r\n    }\r\n    else if (!this.savedPersFilterValue && this.savedDepFilterValue && this.savedworkSpaceFilterValue) {\r\n      return \"deptDepatmentWorkSpaceFilter\";\r\n\r\n    }\r\n  }\r\n\r\n  setOptionValue(searchedText){\r\n    this.searchForm.get('text').setValue(searchedText);\r\n    this.submitForm();\r\n  }\r\n  onOpenFilter() {\r\n    this.openFilter = !this.openFilter;\r\n  }\r\n\r\n  breakpoint() {\r\n    this.breakpointObserver\r\n      .observe(['(min-width: 1200px)'])\r\n      .subscribe((result) => {\r\n        if (result.matches) {\r\n          this.openFilter = false;\r\n        }\r\n      });\r\n  }\r\n\r\n  performAction(action){\r\n    this.actionOnRow.emit(action);\r\n  }\r\n\r\n  search(term: string): Observable<any> {\r\n    return from(\r\n        this.nuxeoService.nuxeoClient\r\n            .operation('Search.CustomSuggestersLauncher', {\r\n                url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n            })\r\n            .params({\r\n                searchTerm: term\r\n            })\r\n            .context({})\r\n            .execute()\r\n    );\r\n}\r\n}\r\n","<ng-container *ngIf=\"!customResponsiveStyle\">\r\n  <div class=\"search-toolbar d-md-flex d-xl-none mx-3\">\r\n    <button (click)=\"onOpenFilter()\" class=\"my-button\">\r\n      <span> {{ \"FILTER\" | translate }}</span>\r\n      <i class=\"bi bi-filter\" *ngIf=\"!openFilter\"></i>\r\n      <i class=\"bi bi-x\" *ngIf=\"openFilter\"></i>\r\n    </button>\r\n    <div *ngIf=\"openFilter\">\r\n      <i class=\"bi bi-caret-up-fill arrow-up\"></i>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"customResponsiveStyle\">\r\n  <div class=\"customStyle -mt-12 px-8 flex flex-col\"\r\n    [ngClass]=\"{'bg-accent-200': theme === 'dgda','bg-accent-100': theme === 'ksreleif' || theme === 'comptechco'}\"\r\n    [@collapse]=\"!openFilter\">\r\n    <!-- <form\r\n        [formGroup]=\"searchForm\"\r\n        class=\"search-form\"\r\n        (ngSubmit)=\"submitForm()\"\r\n      >\r\n        <input\r\n          class=\"search-input\"\r\n          type=\"text\"\r\n          formControlName=\"text\"\r\n          [placeholder]=\"'search.search' | translate\"\r\n        />\r\n        <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n      </form> -->\r\n    <div class=\"flex gap-x-18 flex-row mt-5 pb-3 overflow-x-auto\">\r\n      <ng-container *ngIf=\"aggregations; else progressSpinner\">\r\n        <ng-container *ngIf=\"aggregations.length; else noAggregations\">\r\n          <ng-container *ngFor=\"let aggregation of aggregations\">\r\n            <ng-container *ngIf=\"aggregation.buckets.length > 0\">\r\n              <cts-dynamic-filter [entityType]=\"entityType\" [filters]=\"aggregation.buckets\" [id]=\"aggregation.id\"\r\n                [selections]=\"aggregation.selection\" [title]=\"aggregation.field\" [prefix]=\"'search'\" [department]=\"\r\n                    aggregation.field === 'corr:to' ||\r\n                    aggregation.field === 'corr:from'\r\n                  \" [componentType]=\"aggregation.componentType ? aggregation.componentType : 'defult'\"\r\n                [customPageProvider]=\"aggregation.customPageProvider ? aggregation.customPageProvider : ''\"\r\n                [config]=\"aggregation.config ? aggregation.config : {}\" (onFilterSelected)=\"FilterSelected($event)\">\r\n              </cts-dynamic-filter>\r\n            </ng-container>\r\n          </ng-container>\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n\r\n<div class=\"row wrapper\">\r\n  <ng-container *ngIf=\"!customResponsiveStyle\">\r\n    <div class=\"popup-filter px-3 d-flex d-xl-none\" *ngIf=\"openFilter\">\r\n      <form [formGroup]=\"searchForm\" class=\"search-form\" (ngSubmit)=\"submitForm()\">\r\n        <input class=\"search-input\" type=\"text\" formControlName=\"text\" [matAutocomplete]=\"matAutocomplete1\" [placeholder]=\"'search.search' | translate\" />\r\n        <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n      </form>\r\n      <mat-autocomplete\r\n      class=\"\r\n         auto-complete-iner-wrapper\r\n          auto-complete-wrapper\r\n      \"\r\n      [disableRipple]=\"true\"\r\n      #matAutocomplete1=\"matAutocomplete\"\r\n  >\r\n      <mat-option\r\n          class=\"no-text\"\r\n          *ngIf=\"resultSets && !resultSets.length\"\r\n      >\r\n          No results found!\r\n      </mat-option>\r\n      <ng-container *ngFor=\"let resultSet of resultSets\">\r\n          <mat-option  (click)=\"setOptionValue(resultSet.label)\">\r\n              <span\r\n                  class=\"option-iner-text\"\r\n                  >{{ resultSet.label }}</span\r\n              >\r\n          </mat-option >\r\n      </ng-container>\r\n      </mat-autocomplete>\r\n      <ng-container *ngIf=\"aggregations; else progressSpinner\">\r\n        <ng-container *ngIf=\"aggregations.length; else noAggregations\">\r\n          <div *ngFor=\"let aggregation of aggregations\">\r\n            <ng-container *ngIf=\"aggregation.buckets.length > 0\">\r\n              <cts-dynamic-filter [entityType]=\"entityType\" [filters]=\"aggregation.buckets\" [id]=\"aggregation.id\"\r\n                [selections]=\"aggregation.selection\" [title]=\"aggregation.field\" [prefix]=\"'search'\" [department]=\"\r\n                aggregation.field === 'corr:to' ||\r\n                aggregation.field === 'corr:from'\r\n              \" [componentType]=\"aggregation.componentType ? aggregation.componentType : 'defult'\"\r\n                [customPageProvider]=\"aggregation.customPageProvider ? aggregation.customPageProvider : ''\"\r\n                [config]=\"aggregation.config ? aggregation.config : {}\" (onFilterSelected)=\"FilterSelected($event)\">\r\n              </cts-dynamic-filter>\r\n            </ng-container>\r\n          </div>\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <div class=\"col-xl-3 search-sideMenu d-none d-xl-block\">\r\n    <form [formGroup]=\"searchForm\" class=\"search-form\" (ngSubmit)=\"submitForm()\">\r\n      <input class=\"search-input\" type=\"text\" formControlName=\"text\" [matAutocomplete]=\"matAutocomplete2\"\r\n        [placeholder]=\"'search.search' | translate\" />\r\n      <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n    </form>\r\n    <mat-autocomplete class=\"\r\n       auto-complete-iner-wrapper\r\n        auto-complete-wrapper\r\n    \" [disableRipple]=\"true\" #matAutocomplete2=\"matAutocomplete\">\r\n      <mat-option class=\"no-text\" *ngIf=\"resultSets && !resultSets.length\">\r\n        No results found!\r\n      </mat-option>\r\n      <ng-container *ngFor=\"let resultSet of resultSets\">\r\n        <mat-option (click)=\"setOptionValue(resultSet.label)\">\r\n          <span class=\"option-iner-text\">{{ resultSet.label }}</span>\r\n        </mat-option>\r\n      </ng-container>\r\n    </mat-autocomplete>\r\n    <ng-container *ngIf=\"aggregations; else progressSpinner\">\r\n      <div *ngFor=\"let aggregation of aggregations\">\r\n        <ng-container *ngIf=\"aggregation.buckets.length > 0\">\r\n          <cts-dynamic-filter [entityType]=\"entityType\" [filters]=\"aggregation.buckets\" [id]=\"aggregation.id\"\r\n            [selections]=\"aggregation.selection\" [title]=\"aggregation.field\" [prefix]=\"'search'\" [department]=\"\r\n              aggregation.field === 'corr:to' ||\r\n              aggregation.field === 'corr:from'\r\n            \" [componentType]=\"aggregation.componentType ? aggregation.componentType : 'defult'\"\r\n            [customPageProvider]=\"aggregation.customPageProvider ? aggregation.customPageProvider : ''\"\r\n            [config]=\"aggregation.config ? aggregation.config : {}\" (onFilterSelected)=\"FilterSelected($event)\">\r\n          </cts-dynamic-filter>\r\n        </ng-container>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n  <div class=\"col-12 col-xl-9\">\r\n    <app-card>\r\n      <div class=\"title\">\r\n        <h3>\r\n          {{ \"search.header\" | translate }}\r\n        </h3>\r\n      </div>\r\n      <div class=\"body\">\r\n        <div *ngIf=\"aggregations\" class=\"table-toolbar\">\r\n          <div class=\"result-count\">\r\n            <span>\r\n              {{\r\n              \"search.\" + \"resultsNumber\"\r\n              | translate: { value: totalRecords ? totalRecords : 0 }\r\n              }}\r\n            </span>\r\n          </div>\r\n          <div>\r\n            <form class=\"d-flex justify-between\" [formGroup]=\"searchForm\" (ngSubmit)=\"submitForm()\">\r\n              <div *ngIf=\"useToggleFilters && !customResponsiveStyle\"></div>\r\n              <div *ngIf=\"customResponsiveStyle\">\r\n                <div class=\"search-form custom-responsive-search\">\r\n                  <input class=\"search-input\" type=\"text\" formControlName=\"text\" [matAutocomplete]=\"matAutocomplete\"\r\n                    [placeholder]=\"'search.search' | translate\" />\r\n                  <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n                </div>\r\n                <mat-autocomplete\r\n                class=\"\r\n                   auto-complete-iner-wrapper\r\n                    auto-complete-wrapper\r\n                \"\r\n                [disableRipple]=\"true\"\r\n                #matAutocomplete=\"matAutocomplete\"\r\n            >\r\n                <mat-option\r\n                    class=\"no-text\"\r\n                    *ngIf=\"resultSets && !resultSets.length\"\r\n                >\r\n                    {{no_result_found | translate}}\r\n                </mat-option>\r\n                <ng-container *ngFor=\"let resultSet of resultSets\">\r\n                    <mat-option  (click)=\"setOptionValue(resultSet.label)\">\r\n                        <span\r\n                            class=\"option-iner-text\"\r\n                            >{{ resultSet.label }}</span\r\n                        >\r\n                    </mat-option >\r\n                </ng-container>\r\n                </mat-autocomplete>\r\n              </div>\r\n              <div class=\"d-flex\" *ngIf=\"useToggleFilters\">\r\n                <cts-dynamic-form-slide-toggleitem class=\"mx-2 small-font\" [label]=\"'search.PERSONAL_FILES'\"\r\n                  (onToggle)=\"submitForm()\" formControlName=\"personalFiles\">\r\n                </cts-dynamic-form-slide-toggleitem>\r\n                <cts-dynamic-form-slide-toggleitem class=\"mx-2 small-font\" [label]=\"'search.DEP_FILES'\"\r\n                  formControlName=\"depFiles\" (onToggle)=\"submitForm()\">\r\n                </cts-dynamic-form-slide-toggleitem>\r\n                <cts-dynamic-form-slide-toggleitem class=\"mx-2 small-font\" [label]=\"'search.WORKSPACE_FILES'\"\r\n                formControlName=\"workSpaceFiles\" (onToggle)=\"submitForm()\">\r\n              </cts-dynamic-form-slide-toggleitem>\r\n              </div>\r\n            </form>\r\n          </div>\r\n        </div>\r\n        <cts-dynamic-table [pageSize]=\"pageSize\" [columns]=\"columns\" [responsiveColumns]=\"responsiveColumns\"\r\n          [pageProvider]=\"pageProvider\" [quickFilter]=\"filter\" [entityType]=\"entityType\" [fields]=\"fields\"\r\n          [queryParam]=\"queryParams\" [headers]=\"headers\" [prefix]=\"prefix\" [sortingBy]=\"sortingBy\" [isSearchPage]=\"true\"\r\n          (onRowSelected)=\"onRowSelected($event)\" (actionOnRow)=\"performAction($event)\"\r\n          (onGettingData)=\"getTableData($event)\"></cts-dynamic-table>\r\n      </div>\r\n    </app-card>\r\n  </div>\r\n\r\n  <ng-template #progressSpinner>\r\n    <div class=\"progress-spinner\">\r\n      <mat-spinner color=\"warn\" [diameter]=\"25\"></mat-spinner>\r\n    </div>\r\n  </ng-template>\r\n  <ng-template #noAggregations>\r\n    <div class=\"progress-spinner\">\r\n      {{ \"search.noAggregations\" | translate }}\r\n    </div>\r\n  </ng-template>\r\n</div>"]}
329
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-search/dynamic-search/dynamic-search.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-search/dynamic-search/dynamic-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation, OnChanges, SimpleChanges, Inject } from '@angular/core';\r\nimport { FormGroup, FormControl } from '@angular/forms';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { DocumentsConstants } from '../../../components/documents/constants/documents';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\nimport * as _ from 'lodash';\r\nimport { animate, AUTO_STYLE, state, style, transition, trigger } from '@angular/animations';\r\nimport { threadId } from 'worker_threads';\r\nimport { EvaluatorsService } from '../../../directive/permissions/evaluators.service';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { from, Observable } from 'rxjs';\r\nimport { NuxeoService } from '../../../Core/services/nuxeo/nuxeo.service';\r\n\r\n/**\r\n * Dynamic search component uses [Dynamic Table]{@link DynamicTableComponent} & [Dynamic Filter]{@link DynamicFilterComponent} internally,\r\n * and utilizes its inputs to perform advanced search and filtering on any nuxeo Provider\r\n * @title\r\n * Dynamic Search\r\n *\r\n * @example\r\n * <cts-dynamic-search\r\n *   [pageProvider]=\"'pageProviderName'\"\r\n *   [columns]=\"columnsArray\"\r\n *   [responsiveColumns]=\"responsiveColumnsArray\"\r\n *   [entityType]=\"'documents'\"\r\n *   [prefix]=\"prefix\"\r\n *   [fields]=\"fields\"\r\n *   [headers]=\"headers\"\r\n *   [sortingBy]=\"sortingBy\"\r\n *   [pageSize]=\"PageSize\"\r\n*    [customResponsiveStyle]=\"false or true\"\r\n     [openCloseFilterFromOutside]=\"pass Filter state from parent component\"\r\n     [theme] = \"to  set background depened on theme\"\r\n * >\r\n * </cts-dynamic-search>\r\n */\r\n@Component({\r\n  selector: 'cts-dynamic-search',\r\n  templateUrl: './dynamic-search.component.html',\r\n  styleUrls: ['./dynamic-search.component.scss'],\r\n  animations: [\r\n    trigger('collapse', [\r\n      state('false', style({ height: AUTO_STYLE, visibility: AUTO_STYLE })),\r\n      state('true', style({ height: '0', visibility: 'hidden' })),\r\n      transition('false => true', animate(300)),\r\n      transition('true => false', animate(300))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DynamicSearchComponent implements OnInit,OnChanges {\r\n  text: string;\r\n  aggregations;\r\n  /** Array of columns */\r\n  @Input() columns;\r\n  /** Array of columns on smaller screens */\r\n  @Input() responsiveColumns?;\r\n  /** Defines the page in which table is being used */\r\n  @Input() entityType: string;\r\n  /** Translations prefix */\r\n  @Input() prefix = '';\r\n  /** Headers to be sent with API Request */\r\n  @Input() headers;\r\n  /** Fields keymap to be mapped in the adapter */\r\n  @Input() fields;\r\n  /** Page Provider name that will be used to retrieve data */\r\n  @Input() pageProvider;\r\n  /** Controls number of items per page in table */\r\n  @Input() pageSize;\r\n  /** Sorting column */\r\n  @Input() sortingBy?= {};\r\n  @Input() fullTextParamName = 'system_fulltext';\r\n  @Input() filter; // used to pass params from outside to params of dynamic table directly\r\n\r\n  @Input() \r\n  onRowSelected = (row) => {\r\n    this.router.navigate([{ outlets: { viewer: ['view', row['uid']] } }], {\r\n      queryParams: { location: this.router.url },\r\n    });\r\n  }\r\n  /** used to emit any actions to outside */\r\n  @Output() actionOnRow = new EventEmitter();\r\n  queryParams = {};\r\n  filters;\r\n  searchForm = new FormGroup({\r\n    text: new FormControl(null),\r\n    personalFiles : new FormControl(false),\r\n    depFiles : new FormControl(false),\r\n    workSpaceFiles : new FormControl(false)\r\n  });\r\n  loading = false;\r\n  totalRecords;\r\n  openFilter: boolean;\r\n  @Input()\r\n  sortingArray;\r\n  @Input() customResponsiveStyle: boolean = false;\r\n  @Input() openCloseFilterFromOutside: boolean = false;\r\n  @Input() theme :any;\r\n  useToggleFilters;\r\n\r\n  quickFilters = '';\r\n  savedPersFilterValue = null;\r\n  savedDepFilterValue = null;\r\n  savedworkSpaceFilterValue = null;\r\n  resultSets = [];\r\n  originalAggregations;\r\n  constructor(\r\n    private route: ActivatedRoute,\r\n    private router: Router,\r\n    private evaluatorService : EvaluatorsService,\r\n    private nuxeoService : NuxeoService,\r\n    @Inject('environment') private environment,\r\n    public breakpointObserver: BreakpointObserver\r\n  ) { \r\n    this.evaluatorService.evaluateRule('enableSearchToggles' , {}).then(res => {\r\n      this.useToggleFilters = res;\r\n    })\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes.openCloseFilterFromOutside) {\r\n      this.openFilter = changes.openCloseFilterFromOutside.currentValue;\r\n    } else if(!changes.sortingArray.firstChange) {\r\n      this.getTableData({aggregations:this.originalAggregations})\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    \r\n    this.updateQueryParams(this.constructParamsFunction(this.route.snapshot.queryParams));\r\n    this.searchInputPopulate();\r\n    this.route.queryParams.subscribe((params) => {\r\n      if (\r\n        (this.text !== params['search_query'] && params['search_query']) ||\r\n        (params['search_query']?.length == 0 && this.text !== params['search_query'] || \r\n        (this.useToggleFilters && this.quickFilters !== params['quickFilters'])) \r\n      ) {\r\n        this.updateQueryParams(this.constructParamsFunction(params));\r\n        this.searchInputPopulate();\r\n      }\r\n    });\r\n    this.breakpoint();\r\n    \r\n   this.searchForm.get('text').valueChanges.pipe(\r\n    debounceTime(500)).subscribe(res => {\r\n      this.search(res).subscribe(results => {\r\n        this.resultSets = results;\r\n      })\r\n   })\r\n  }\r\n\r\n  constructParamsFunction(params){\r\n    let contructedParms = {};\r\n    this.text = params['search_query'];\r\n    if(this.useToggleFilters){\r\n      if(params['quickFilters']){\r\n        this.quickFilters = params['quickFilters'] ;\r\n        contructedParms = { [this.fullTextParamName] : this.text , quickFilters : this.quickFilters}\r\n      }else{\r\n        this.quickFilters = '';\r\n        contructedParms = { [this.fullTextParamName] : this.text , quickFilters : ''}\r\n      }\r\n    }else{\r\n      contructedParms = { [this.fullTextParamName] : this.text}\r\n    }\r\n\r\n    return contructedParms;\r\n  }\r\n  updateQueryParams(newQueryparams: object) {\r\n    this.queryParams = {\r\n      ...this.queryParams,\r\n      ...newQueryparams,\r\n    };\r\n  }\r\n  \r\n  searchInputPopulate() {\r\n    if(this.useToggleFilters){\r\n      this.searchForm.patchValue({\r\n        text: this.text,\r\n        personalFiles : (this.quickFilters === 'personalFilter' ) ? true : (this.savedPersFilterValue !== null) ? this.savedPersFilterValue : false,\r\n        depFiles : (this.quickFilters === 'departmentFilter') ? true : (this.savedDepFilterValue !== null) ? this.savedDepFilterValue : false ,\r\n        workSpaceFiles : (this.quickFilters === 'departmentWorkSpaceFilter') ? true : (this.savedworkSpaceFilterValue !== null) ? this.savedworkSpaceFilterValue : false \r\n\r\n      });\r\n    }else{\r\n      this.searchForm.patchValue({\r\n        text: this.text,\r\n      });\r\n    }\r\n  }\r\n\r\n  FilterSelected(val: any) {\r\n    this.loading = true;\r\n    this.filters = { ...this.filters, ...val.filter }; //store filters\r\n    this.updateQueryParams(this.filters);\r\n  }\r\n\r\n  paginationChange(event) { }\r\n\r\n  getTableData(data) {\r\n    if(!this.originalAggregations) {\r\n      this.originalAggregations = data.aggregations;\r\n    }\r\n    this.loading = false;\r\n    this.aggregations = Object.entries(data.aggregations || {}).map((item) => {\r\n      return item[1];\r\n    });\r\n    // this.aggregations = this.aggregations.filter((item) =>\r\n    //   this.sortingArray.includes(item.id)\r\n    // );\r\n    let updatedAggregation = [];\r\n    this.aggregations.map(aggreg => {\r\n      this.sortingArray.map(sortType => {\r\n        if(sortType.id === aggreg.id){\r\n          aggreg['componentType'] = sortType.compoenentType;\r\n          // in case of custom component need to call page provider to get data \r\n          if(sortType.compoenentType === 'custom-pp' || sortType.compoenentType === 'custom-document' || sortType.compoenentType === 'custom-department'){\r\n            aggreg['customPageProvider'] = sortType.pageProvider,\r\n            aggreg['config'] = sortType.config\r\n          }\r\n          updatedAggregation.push(aggreg)\r\n        }\r\n      })\r\n    })\r\n    this.aggregations = _.sortBy(updatedAggregation, (item) => {\r\n      let i = -1;\r\n       this.sortingArray.map((sortType , index) => {\r\n         if(sortType.id === item.id){\r\n           i = index;\r\n         }\r\n       });\r\n       return i;\r\n    });\r\n    console.log('aggregations', this.aggregations);\r\n    this.totalRecords = data.totalSize;\r\n  }\r\n\r\n  submitForm() {\r\n    let params = {} ;\r\n    if(this.useToggleFilters){\r\n      params = {\r\n        search_query: this.searchForm.controls.text.value,\r\n        quickFilters : this.getToggleFilters()\r\n      }\r\n    }else{\r\n      params = {\r\n        search_query: this.searchForm.controls.text.value,\r\n      }\r\n    }\r\n    this.router.navigate(['.'], {\r\n      relativeTo: this.route,\r\n      queryParams: params,\r\n    });\r\n  }\r\n\r\n  getToggleFilters() {\r\n    this.savedDepFilterValue = this.searchForm.controls.depFiles.value;\r\n    this.savedPersFilterValue = this.searchForm.controls.personalFiles.value;\r\n    this.savedworkSpaceFilterValue = this.searchForm.controls.workSpaceFiles.value;\r\n    if ((this.savedPersFilterValue && this.savedDepFilterValue && this.savedworkSpaceFilterValue)\r\n      || (!this.savedPersFilterValue && !this.savedDepFilterValue && !this.savedworkSpaceFilterValue)) {\r\n      return '';\r\n    } else if (this.savedPersFilterValue && !this.savedDepFilterValue && !this.savedworkSpaceFilterValue) {\r\n      return \"personalFilter\";\r\n\r\n    } else if (!this.savedPersFilterValue && this.savedDepFilterValue && !this.savedworkSpaceFilterValue) {\r\n      return \"departmentFilter\";\r\n\r\n    } else if (!this.savedPersFilterValue && !this.savedDepFilterValue && this.savedworkSpaceFilterValue) {\r\n      return \"departmentWorkSpaceFilter\";\r\n    }\r\n    else if (this.savedPersFilterValue && this.savedDepFilterValue && !this.savedworkSpaceFilterValue) {\r\n      return \"departmentPersonalFilter\";\r\n\r\n    }\r\n    else if (this.savedPersFilterValue && !this.savedDepFilterValue && this.savedworkSpaceFilterValue) {\r\n      return \"personalDepartmentWorkSpaceFilter\";\r\n\r\n    }\r\n    else if (!this.savedPersFilterValue && this.savedDepFilterValue && this.savedworkSpaceFilterValue) {\r\n      return \"deptDepatmentWorkSpaceFilter\";\r\n\r\n    }\r\n  }\r\n\r\n  setOptionValue(searchedText){\r\n    this.searchForm.get('text').setValue(searchedText);\r\n    this.submitForm();\r\n  }\r\n  onOpenFilter() {\r\n    this.openFilter = !this.openFilter;\r\n  }\r\n\r\n  breakpoint() {\r\n    this.breakpointObserver\r\n      .observe(['(min-width: 1200px)'])\r\n      .subscribe((result) => {\r\n        if (result.matches) {\r\n          this.openFilter = false;\r\n        }\r\n      });\r\n  }\r\n\r\n  performAction(action){\r\n    this.actionOnRow.emit(action);\r\n  }\r\n\r\n  search(term: string): Observable<any> {\r\n    return from(\r\n        this.nuxeoService.nuxeoClient\r\n            .operation('Search.CustomSuggestersLauncher', {\r\n                url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n            })\r\n            .params({\r\n                searchTerm: term\r\n            })\r\n            .context({})\r\n            .execute()\r\n    );\r\n}\r\n}\r\n","<ng-container *ngIf=\"!customResponsiveStyle\">\r\n  <div class=\"search-toolbar d-md-flex d-xl-none mx-3\">\r\n    <button (click)=\"onOpenFilter()\" class=\"my-button\">\r\n      <span> {{ \"FILTER\" | translate }}</span>\r\n      <i class=\"bi bi-filter\" *ngIf=\"!openFilter\"></i>\r\n      <i class=\"bi bi-x\" *ngIf=\"openFilter\"></i>\r\n    </button>\r\n    <div *ngIf=\"openFilter\">\r\n      <i class=\"bi bi-caret-up-fill arrow-up\"></i>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"customResponsiveStyle\">\r\n  <div class=\"customStyle -mt-12 px-8 flex flex-col\"\r\n    [ngClass]=\"{'bg-accent-200': theme === 'dgda','bg-accent-100': theme === 'ksreleif' || theme === 'comptechco'}\"\r\n    [@collapse]=\"!openFilter\">\r\n    <!-- <form\r\n        [formGroup]=\"searchForm\"\r\n        class=\"search-form\"\r\n        (ngSubmit)=\"submitForm()\"\r\n      >\r\n        <input\r\n          class=\"search-input\"\r\n          type=\"text\"\r\n          formControlName=\"text\"\r\n          [placeholder]=\"'search.search' | translate\"\r\n        />\r\n        <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n      </form> -->\r\n    <div class=\"flex gap-x-18 flex-row mt-5 pb-3 overflow-x-auto\">\r\n      <ng-container *ngIf=\"aggregations; else progressSpinner\">\r\n        <ng-container *ngIf=\"aggregations.length; else noAggregations\">\r\n          <ng-container *ngFor=\"let aggregation of aggregations\">\r\n            <ng-container *ngIf=\"aggregation.buckets.length > 0\">\r\n              <cts-dynamic-filter [entityType]=\"entityType\" [filters]=\"aggregation.buckets\" [id]=\"aggregation.id\"\r\n                [selections]=\"aggregation.selection\" [title]=\"aggregation.field\" [prefix]=\"'search'\" [department]=\"\r\n                    aggregation.field === 'corr:to' ||\r\n                    aggregation.field === 'corr:from'\r\n                  \" [componentType]=\"aggregation.componentType ? aggregation.componentType : 'defult'\"\r\n                [customPageProvider]=\"aggregation.customPageProvider ? aggregation.customPageProvider : ''\"\r\n                [config]=\"aggregation.config ? aggregation.config : {}\" (onFilterSelected)=\"FilterSelected($event)\">\r\n              </cts-dynamic-filter>\r\n            </ng-container>\r\n          </ng-container>\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n\r\n<div class=\"row wrapper\">\r\n  <ng-container *ngIf=\"!customResponsiveStyle\">\r\n    <div class=\"popup-filter px-3 d-flex d-xl-none\" *ngIf=\"openFilter\">\r\n      <form [formGroup]=\"searchForm\" class=\"search-form\" (ngSubmit)=\"submitForm()\">\r\n        <input class=\"search-input\" type=\"text\" formControlName=\"text\" [matAutocomplete]=\"matAutocomplete1\" [placeholder]=\"'search.search' | translate\" />\r\n        <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n      </form>\r\n      <mat-autocomplete\r\n      class=\"\r\n         auto-complete-iner-wrapper\r\n          auto-complete-wrapper\r\n      \"\r\n      [disableRipple]=\"true\"\r\n      #matAutocomplete1=\"matAutocomplete\"\r\n  >\r\n      <mat-option\r\n          class=\"no-text\"\r\n          *ngIf=\"resultSets && !resultSets.length\"\r\n      >\r\n          No results found!\r\n      </mat-option>\r\n      <ng-container *ngFor=\"let resultSet of resultSets\">\r\n          <mat-option  (click)=\"setOptionValue(resultSet.label)\">\r\n              <span\r\n                  class=\"option-iner-text\"\r\n                  >{{ resultSet.label }}</span\r\n              >\r\n          </mat-option >\r\n      </ng-container>\r\n      </mat-autocomplete>\r\n      <ng-container *ngIf=\"aggregations; else progressSpinner\">\r\n        <ng-container *ngIf=\"aggregations.length; else noAggregations\">\r\n          <div *ngFor=\"let aggregation of aggregations\">\r\n            <ng-container *ngIf=\"aggregation.buckets.length > 0\">\r\n              <cts-dynamic-filter [entityType]=\"entityType\" [filters]=\"aggregation.buckets\" [id]=\"aggregation.id\"\r\n                [selections]=\"aggregation.selection\" [title]=\"aggregation.field\" [prefix]=\"'search'\" [department]=\"\r\n                aggregation.field === 'corr:to' ||\r\n                aggregation.field === 'corr:from'\r\n              \" [componentType]=\"aggregation.componentType ? aggregation.componentType : 'defult'\"\r\n                [customPageProvider]=\"aggregation.customPageProvider ? aggregation.customPageProvider : ''\"\r\n                [config]=\"aggregation.config ? aggregation.config : {}\" (onFilterSelected)=\"FilterSelected($event)\">\r\n              </cts-dynamic-filter>\r\n            </ng-container>\r\n          </div>\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <div class=\"col-xl-3 search-sideMenu d-none d-xl-block\">\r\n    <form [formGroup]=\"searchForm\" class=\"search-form\" (ngSubmit)=\"submitForm()\">\r\n      <input class=\"search-input\" type=\"text\" formControlName=\"text\" [matAutocomplete]=\"matAutocomplete2\"\r\n        [placeholder]=\"'search.search' | translate\" />\r\n      <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n    </form>\r\n    <mat-autocomplete class=\"\r\n       auto-complete-iner-wrapper\r\n        auto-complete-wrapper\r\n    \" [disableRipple]=\"true\" #matAutocomplete2=\"matAutocomplete\">\r\n      <mat-option class=\"no-text\" *ngIf=\"resultSets && !resultSets.length\">\r\n        No results found!\r\n      </mat-option>\r\n      <ng-container *ngFor=\"let resultSet of resultSets\">\r\n        <mat-option (click)=\"setOptionValue(resultSet.label)\">\r\n          <span class=\"option-iner-text\">{{ resultSet.label }}</span>\r\n        </mat-option>\r\n      </ng-container>\r\n    </mat-autocomplete>\r\n    <ng-container *ngIf=\"aggregations; else progressSpinner\">\r\n      <div *ngFor=\"let aggregation of aggregations\">\r\n        <ng-container *ngIf=\"aggregation.buckets.length > 0\">\r\n          <cts-dynamic-filter [entityType]=\"entityType\" [filters]=\"aggregation.buckets\" [id]=\"aggregation.id\"\r\n            [selections]=\"aggregation.selection\" [title]=\"aggregation.field\" [prefix]=\"'search'\" [department]=\"\r\n              aggregation.field === 'corr:to' ||\r\n              aggregation.field === 'corr:from'\r\n            \" [componentType]=\"aggregation.componentType ? aggregation.componentType : 'defult'\"\r\n            [customPageProvider]=\"aggregation.customPageProvider ? aggregation.customPageProvider : ''\"\r\n            [config]=\"aggregation.config ? aggregation.config : {}\" (onFilterSelected)=\"FilterSelected($event)\">\r\n          </cts-dynamic-filter>\r\n        </ng-container>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n  <div class=\"col-12 col-xl-9\">\r\n    <app-card>\r\n      <div class=\"title\">\r\n        <h3>\r\n          {{ \"search.header\" | translate }}\r\n        </h3>\r\n      </div>\r\n      <div class=\"body\">\r\n        <div *ngIf=\"aggregations\" class=\"table-toolbar\">\r\n          <div class=\"result-count\">\r\n            <span>\r\n              {{\r\n              \"search.\" + \"resultsNumber\"\r\n              | translate: { value: totalRecords ? totalRecords : 0 }\r\n              }}\r\n            </span>\r\n          </div>\r\n          <div>\r\n            <form class=\"d-flex justify-between\" [formGroup]=\"searchForm\" (ngSubmit)=\"submitForm()\">\r\n              <div *ngIf=\"useToggleFilters && !customResponsiveStyle\"></div>\r\n              <div *ngIf=\"customResponsiveStyle\">\r\n                <div class=\"search-form custom-responsive-search\">\r\n                  <input class=\"search-input\" type=\"text\" formControlName=\"text\" [matAutocomplete]=\"matAutocomplete\"\r\n                    [placeholder]=\"'search.search' | translate\" />\r\n                  <div (click)=\"submitForm()\" class=\"search-icon bi bi-search\"></div>\r\n                </div>\r\n                <mat-autocomplete\r\n                class=\"\r\n                   auto-complete-iner-wrapper\r\n                    auto-complete-wrapper\r\n                \"\r\n                [disableRipple]=\"true\"\r\n                #matAutocomplete=\"matAutocomplete\"\r\n            >\r\n                <mat-option\r\n                    class=\"no-text\"\r\n                    *ngIf=\"resultSets && !resultSets.length\"\r\n                >\r\n                    {{no_result_found | translate}}\r\n                </mat-option>\r\n                <ng-container *ngFor=\"let resultSet of resultSets\">\r\n                    <mat-option  (click)=\"setOptionValue(resultSet.label)\">\r\n                        <span\r\n                            class=\"option-iner-text\"\r\n                            >{{ resultSet.label }}</span\r\n                        >\r\n                    </mat-option >\r\n                </ng-container>\r\n                </mat-autocomplete>\r\n              </div>\r\n              <div class=\"d-flex\" *ngIf=\"useToggleFilters\">\r\n                <cts-dynamic-form-slide-toggleitem class=\"mx-2 small-font\" [label]=\"'search.PERSONAL_FILES'\"\r\n                  (onToggle)=\"submitForm()\" formControlName=\"personalFiles\">\r\n                </cts-dynamic-form-slide-toggleitem>\r\n                <cts-dynamic-form-slide-toggleitem class=\"mx-2 small-font\" [label]=\"'search.DEP_FILES'\"\r\n                  formControlName=\"depFiles\" (onToggle)=\"submitForm()\">\r\n                </cts-dynamic-form-slide-toggleitem>\r\n                <cts-dynamic-form-slide-toggleitem class=\"mx-2 small-font\" [label]=\"'search.WORKSPACE_FILES'\"\r\n                formControlName=\"workSpaceFiles\" (onToggle)=\"submitForm()\">\r\n              </cts-dynamic-form-slide-toggleitem>\r\n              </div>\r\n            </form>\r\n          </div>\r\n        </div>\r\n        <cts-dynamic-table [pageSize]=\"pageSize\" [columns]=\"columns\" [responsiveColumns]=\"responsiveColumns\"\r\n          [pageProvider]=\"pageProvider\" [quickFilter]=\"filter\" [entityType]=\"entityType\" [fields]=\"fields\"\r\n          [queryParam]=\"queryParams\" [headers]=\"headers\" [prefix]=\"prefix\" [sortingBy]=\"sortingBy\" [isSearchPage]=\"true\"\r\n          (onRowSelected)=\"onRowSelected($event)\" (actionOnRow)=\"performAction($event)\"\r\n          (onGettingData)=\"getTableData($event)\"></cts-dynamic-table>\r\n      </div>\r\n    </app-card>\r\n  </div>\r\n\r\n  <ng-template #progressSpinner>\r\n    <div class=\"progress-spinner\">\r\n      <mat-spinner color=\"warn\" [diameter]=\"25\"></mat-spinner>\r\n    </div>\r\n  </ng-template>\r\n  <ng-template #noAggregations>\r\n    <div class=\"progress-spinner\">\r\n      {{ \"search.noAggregations\" | translate }}\r\n    </div>\r\n  </ng-template>\r\n</div>"]}
@@ -76,7 +76,7 @@ export class FilterComponent {
76
76
  }
77
77
  }
78
78
  FilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FilterComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
79
- FilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: FilterComponent, selector: "cts-filter", inputs: { fields: "fields", filterTitle: "filterTitle" }, outputs: { onFiltering: "onFiltering" }, ngImport: i0, template: "<div class=\"filter-wrapper\">\r\n <div class=\"filter-title\">\r\n <!-- {{filterTitle | translate}} -->\r\n </div>\r\n <div class=\"iner-filter-wrapper\" *ngIf=\"filterForm\">\r\n <form [formGroup]=\"filterForm\">\r\n <div class=\"single-control-wrapper\" *ngFor=\"let field of fields\">\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'text'\">\r\n <app-dynamic-form-textitem\r\n [label]=\"field.label\"\r\n [formControlName]=\"field.formControlName\"\r\n placeholder=\"{{ 'CREATE.PLACE_HOLDER' | translate }} {{\r\n field.placeholder | translate\r\n }}\"\r\n >\r\n </app-dynamic-form-textitem>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'dropdown'\">\r\n <app-dynamic-form-vocabulary-item\r\n [shwoAllValues]=\"false\"\r\n [label]=\"field.label\"\r\n [bindLabel]=\"field.bindLabel\"\r\n [bindValue]=\"field.bindValue\"\r\n [placeholder]=\"field.placeholder | translate\"\r\n [multiple]=\"field.multiple\"\r\n [searchable]=\"field.searchable\"\r\n [closeOnSelect]=\"field.closeOnSelect\"\r\n [hideSelectedItems]=\"field.hideSelectedItems\"\r\n [vocabularyType]=\"field.vocabularyType\"\r\n [formControlName]=\"field.formControlName\"\r\n >\r\n </app-dynamic-form-vocabulary-item>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'rang'\">\r\n <cts-dynamic-form-hijri-dateitem [label]=\"field.label\" [formControlName]=\"field.formControlName\"[range]=\"true\" [vertical]=\"false\" >\r\n </cts-dynamic-form-hijri-dateitem>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'department'\">\r\n <app-dynamic-form-department\r\n [label]=\"field.label\"\r\n placeholder=\"{{ 'CREATE.PLACE_HOLDER' | translate }} {{\r\n field.placeholder | translate\r\n }}\"\r\n [formControlName]=\"field.formControlName\"\r\n >\r\n </app-dynamic-form-department>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'toggle'\">\r\n <cts-dynamic-form-slide-toggleitem\r\n [label]=\"field.label\"\r\n [formControlName]=\"field.formControlName\"\r\n ></cts-dynamic-form-slide-toggleitem>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'date'\">\r\n <cts-dynamic-form-hijri-dateitem\r\n [formControlName]=\"field.formControlName\"\r\n [label]=\"field.label\"\r\n >\r\n </cts-dynamic-form-hijri-dateitem>\r\n </div>\r\n \r\n\r\n </div>\r\n\r\n </form>\r\n \r\n </div>\r\n <div class=\"form-actions\">\r\n <button class=\"my-button mx-2\" type=\"button\" (click)=\"filter()\"> {{'FILTER' | translate}}</button>\r\n <button class=\"my-button reset mx-2\" type=\"button\" (click)=\"reset()\"> {{'reset' | translate}}</button>\r\n </div>\r\n</div>\r\n\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.filter-wrapper .filter-title{font-size:18px;font-weight:bold;margin-bottom:15px}.filter-wrapper .iner-filter-wrapper{height:320px;overflow:auto;scrollbar-color:#b4bac6 transparent!important;scrollbar-width:thin!important;padding:15px 15px 0}.filter-wrapper .iner-filter-wrapper .single-control-wrapper{margin-bottom:15px}.filter-wrapper .form-actions{display:flex;justify-content:flex-start;align-content:center;padding:10px 15px}.filter-wrapper .form-actions .filter{border:none;background-color:transparent;font-weight:bold;width:80px;height:40px;background-image:linear-gradient(to bottom,#0dbab5,#2e62df);color:#fff;border-radius:5px}\n"], components: [{ type: i2.DynamicFormTextItemComponent, selector: "app-dynamic-form-textitem", inputs: ["autoComplete", "nativeAutoComplete", "autoComplete_pageProvider", "autoComplete_propertyName", "autoComplete_propertyKey", "autoCompleteValueKey", "autoCompleteType", "type", "property", "label", "editable", "placeholder", "disabled", "displayEmpty", "preventSpace", "id", "maxCharsNum"] }, { type: i3.DynamicFormVocabularyItemComponent, selector: "app-dynamic-form-vocabulary-item", inputs: ["bindValue", "bindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "disabled", "vocabularyType", "label", "cacheable", "shwoAllValues"], outputs: ["onSelecting"] }, { type: i4.DynamicFormHijriDateitemComponent, selector: "cts-dynamic-form-hijri-dateitem", inputs: ["minHijri", "maxHijri", "minGreg", "maxGreg", "label", "isDisabled", "range", "vertical", "isReadOnly", "placeholder"], outputs: ["valueChanged"] }, { type: i5.DynamicFormDepartmentComponent, selector: "app-dynamic-form-department", inputs: ["treeview", "treeViewAsFormControl", "placeholder", "multiple", "searchable", "label", "defaultSelect", "pp_departmentNestedTree", "pp_departmentTree", "customPrefix", "useCustomAddEditAction", "customParentProperty"], outputs: ["onSelecting", "actionClicked"] }, { type: i6.DynamicFormSlideToggleitemComponent, selector: "cts-dynamic-form-slide-toggleitem", inputs: ["label", "disabled", "checked", "theme"], outputs: ["onToggle"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }], pipes: { "translate": i8.TranslatePipe } });
79
+ FilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: FilterComponent, selector: "cts-filter", inputs: { fields: "fields", filterTitle: "filterTitle" }, outputs: { onFiltering: "onFiltering" }, ngImport: i0, template: "<div class=\"filter-wrapper\">\r\n <div class=\"filter-title\">\r\n <!-- {{filterTitle | translate}} -->\r\n </div>\r\n <div class=\"iner-filter-wrapper\" *ngIf=\"filterForm\">\r\n <form [formGroup]=\"filterForm\">\r\n <div class=\"single-control-wrapper\" *ngFor=\"let field of fields\">\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'text'\">\r\n <app-dynamic-form-textitem\r\n [label]=\"field.label\"\r\n [formControlName]=\"field.formControlName\"\r\n placeholder=\"{{ 'CREATE.PLACE_HOLDER' | translate }} {{\r\n field.placeholder | translate\r\n }}\"\r\n >\r\n </app-dynamic-form-textitem>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'dropdown'\">\r\n <app-dynamic-form-vocabulary-item\r\n [shwoAllValues]=\"false\"\r\n [label]=\"field.label\"\r\n [bindLabel]=\"field.bindLabel\"\r\n [bindValue]=\"field.bindValue\"\r\n [placeholder]=\"field.placeholder | translate\"\r\n [multiple]=\"field.multiple\"\r\n [searchable]=\"field.searchable\"\r\n [closeOnSelect]=\"field.closeOnSelect\"\r\n [hideSelectedItems]=\"field.hideSelectedItems\"\r\n [vocabularyType]=\"field.vocabularyType\"\r\n [formControlName]=\"field.formControlName\"\r\n >\r\n </app-dynamic-form-vocabulary-item>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'rang'\">\r\n <cts-dynamic-form-hijri-dateitem [label]=\"field.label\" [formControlName]=\"field.formControlName\"[range]=\"true\" [vertical]=\"false\" >\r\n </cts-dynamic-form-hijri-dateitem>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'department'\">\r\n <app-dynamic-form-department\r\n [label]=\"field.label\"\r\n placeholder=\"{{ 'CREATE.PLACE_HOLDER' | translate }} {{\r\n field.placeholder | translate\r\n }}\"\r\n [formControlName]=\"field.formControlName\"\r\n >\r\n </app-dynamic-form-department>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'toggle'\">\r\n <cts-dynamic-form-slide-toggleitem\r\n [label]=\"field.label\"\r\n [formControlName]=\"field.formControlName\"\r\n ></cts-dynamic-form-slide-toggleitem>\r\n </div>\r\n\r\n <div class=\"control\" *ngIf=\"field.type === 'date'\">\r\n <cts-dynamic-form-hijri-dateitem\r\n [formControlName]=\"field.formControlName\"\r\n [label]=\"field.label\"\r\n >\r\n </cts-dynamic-form-hijri-dateitem>\r\n </div>\r\n \r\n\r\n </div>\r\n\r\n </form>\r\n \r\n </div>\r\n <div class=\"form-actions\">\r\n <button class=\"my-button mx-2\" type=\"button\" (click)=\"filter()\"> {{'FILTER' | translate}}</button>\r\n <button class=\"my-button reset mx-2\" type=\"button\" (click)=\"reset()\"> {{'reset' | translate}}</button>\r\n </div>\r\n</div>\r\n\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}.filter-wrapper .filter-title{font-size:18px;font-weight:bold;margin-bottom:15px}.filter-wrapper .iner-filter-wrapper{height:320px;overflow:auto;scrollbar-color:#b4bac6 transparent!important;scrollbar-width:thin!important;padding:15px 15px 0}.filter-wrapper .iner-filter-wrapper .single-control-wrapper{margin-bottom:15px}.filter-wrapper .form-actions{display:flex;justify-content:flex-start;align-content:center;padding:10px 15px}.filter-wrapper .form-actions .filter{border:none;background-color:transparent;font-weight:bold;width:80px;height:40px;background-image:linear-gradient(to bottom,#0dbab5,#2e62df);color:#fff;border-radius:5px}\n"], components: [{ type: i2.DynamicFormTextItemComponent, selector: "app-dynamic-form-textitem", inputs: ["autoComplete", "nativeAutoComplete", "autoComplete_pageProvider", "autoComplete_propertyName", "autoComplete_propertyKey", "autoCompleteValueKey", "autoCompleteType", "type", "property", "label", "editable", "placeholder", "disabled", "displayEmpty", "preventSpace", "id", "maxCharsNum"] }, { type: i3.DynamicFormVocabularyItemComponent, selector: "app-dynamic-form-vocabulary-item", inputs: ["bindValue", "bindLabel", "placeholder", "multiple", "searchable", "closeOnSelect", "hideSelectedItems", "disabled", "vocabularyType", "label", "cacheable", "shwoAllValues"], outputs: ["onSelecting"] }, { type: i4.DynamicFormHijriDateitemComponent, selector: "cts-dynamic-form-hijri-dateitem", inputs: ["minHijri", "maxHijri", "minGreg", "maxGreg", "label", "isDisabled", "range", "vertical", "isReadOnly", "placeholder"], outputs: ["valueChanged"] }, { type: i5.DynamicFormDepartmentComponent, selector: "app-dynamic-form-department", inputs: ["treeview", "treeViewAsFormControl", "placeholder", "multiple", "searchable", "label", "defaultSelect", "pp_departmentNestedTree", "pp_departmentTree", "customPrefix", "useCustomAddEditAction", "customParentProperty", "customParams"], outputs: ["onSelecting", "actionClicked"] }, { type: i6.DynamicFormSlideToggleitemComponent, selector: "cts-dynamic-form-slide-toggleitem", inputs: ["label", "disabled", "checked", "theme"], outputs: ["onToggle"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }], pipes: { "translate": i8.TranslatePipe } });
80
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FilterComponent, decorators: [{
81
81
  type: Component,
82
82
  args: [{
@@ -88,7 +88,7 @@ export class SelectUsersByDepartmentsComponent {
88
88
  }
89
89
  }
90
90
  SelectUsersByDepartmentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectUsersByDepartmentsComponent, deps: [{ token: i1.DepartmentManagementService }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
91
- SelectUsersByDepartmentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: SelectUsersByDepartmentsComponent, selector: "app-select-users-by-departments", inputs: { display: "display", depLabel: "depLabel", userLabel: "userLabel", allowMultipleUsers: "allowMultipleUsers" }, outputs: { formChanged: "formChanged" }, host: { classAttribute: "userByDepSelectors" }, ngImport: i0, template: "<form [formGroup]=\"depAnditsUsers\">\r\n <div class=\"w-full flex justify-between\"\r\n [ngClass]=\"{'flex-row': display === 'row', 'flex-col': display === 'column'}\">\r\n <div class=\"flex flex-col w-full flex-1 depWrapper\">\r\n <label class=\"dep-label\">\r\n {{depLabel}}\r\n <span class=\"text-danger\" *ngIf=\"isRequired()\">*</span>\r\n </label>\r\n <ng-container *ngIf=\"!reseting\">\r\n <app-dynamic-form-department \r\n #depRef\r\n formControlName=\"dep\"\r\n placeholder=\"placeholder\"\r\n [treeview]=\"false\"\r\n [pp_departmentNestedTree]=\"'PP_OS_Departments'\"\r\n [pp_departmentTree]=\"'PP_OS_Departments'\"\r\n [customPrefix]=\"'osdept'\"\r\n [customParentProperty]=\"'osdepartment_parentDepartmentCode'\"\r\n [useCustomAddEditAction]=\"true\"\r\n (onSelecting)=\"getDepMembers($event)\"\r\n >\r\n </app-dynamic-form-department>\r\n </ng-container>\r\n <ng-container *ngIf=\"reseting\">\r\n <app-dynamic-form-department\r\n #depRef\r\n formControlName=\"dep\"\r\n placeholder=\"placeholder\"\r\n [treeview]=\"false\"\r\n [pp_departmentNestedTree]=\"'PP_OS_Departments'\"\r\n [pp_departmentTree]=\"'PP_OS_Departments'\"\r\n [customPrefix]=\"'osdept'\"\r\n [customParentProperty]=\"'osdepartment_parentDepartmentCode'\"\r\n [useCustomAddEditAction]=\"true\"\r\n (onSelecting)=\"getDepMembers($event)\"\r\n >\r\n </app-dynamic-form-department>\r\n </ng-container>\r\n </div>\r\n <div class=\"flex flex-col w-full flex-1 usersWrapper\"\r\n [ngClass]=\"{'mt-4': display === 'column'}\">\r\n <label class=\"users-label\">\r\n {{userLabel}}\r\n <span class=\"text-danger\" *ngIf=\"isRequired()\">*</span>\r\n </label>\r\n <ng-select \r\n formControlName=\"users\"\r\n #ngSelectComponent \r\n [items]=\"depUsers\" \r\n bindLabel=\"properties.fullName\" \r\n bindValue=\"properties.username\" \r\n [multiple]=\"allowMultipleUsers\"\r\n [placeholder]=\"'share.placeholder' | translate\"\r\n (change)=\"setUser()\"\r\n >\r\n <ng-template ng-notfound-tmp let-searchTerm=\"searchTerm\">\r\n <div class=\"ng-option disabled\" *ngIf=\"!depAnditsUsers?.get('dep').value;else notFound\">\r\n {{'archiveSearch.select_dep' | translate}}\r\n </div>\r\n <ng-template #notFound>\r\n <div class=\"ng-option disabled\">\r\n {{'archiveSearch.noUsers' | translate}}\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\r\n <div class=\"flex flex-col h-full\">\r\n <div *ngIf=\"item\" class=\"flex flex-row\">\r\n <div class=\"flex-0 w-8 h-8 rounded-full overflow-hidden\">\r\n <cts-avatar [user]=\"{\r\n properties: {\r\n firstName: item.properties?.firstName,\r\n lastName: item.properties?.lastName\r\n }\r\n }\">\r\n </cts-avatar>\r\n </div>\r\n <div class=\"flex flex-col pt-0 px-2\">\r\n <span>{{item.properties?.fullName}}</span>\r\n <span>{{item.properties?.email}}</span>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n</form>", styles: [".userByDepSelectors ngx-dropdown-treeview>.dropdown{@apply bg-primary-50 border-primary-100 !important;}.userByDepSelectors .ng-select .ng-select-container .ng-value-container .ng-placeholder{font-size:12px!important;margin-top:4px!important}\n"], components: [{ type: i3.DynamicFormDepartmentComponent, selector: "app-dynamic-form-department", inputs: ["treeview", "treeViewAsFormControl", "placeholder", "multiple", "searchable", "label", "defaultSelect", "pp_departmentNestedTree", "pp_departmentTree", "customPrefix", "useCustomAddEditAction", "customParentProperty"], outputs: ["onSelecting", "actionClicked"] }, { type: i4.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i5.AvatarComponent, selector: "cts-avatar", inputs: ["user"] }], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i4.ɵl, selector: "[ng-notfound-tmp]" }, { type: i4.ɵf, selector: "[ng-option-tmp]" }], pipes: { "translate": i7.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
91
+ SelectUsersByDepartmentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: SelectUsersByDepartmentsComponent, selector: "app-select-users-by-departments", inputs: { display: "display", depLabel: "depLabel", userLabel: "userLabel", allowMultipleUsers: "allowMultipleUsers" }, outputs: { formChanged: "formChanged" }, host: { classAttribute: "userByDepSelectors" }, ngImport: i0, template: "<form [formGroup]=\"depAnditsUsers\">\r\n <div class=\"w-full flex justify-between\"\r\n [ngClass]=\"{'flex-row': display === 'row', 'flex-col': display === 'column'}\">\r\n <div class=\"flex flex-col w-full flex-1 depWrapper\">\r\n <label class=\"dep-label\">\r\n {{depLabel}}\r\n <span class=\"text-danger\" *ngIf=\"isRequired()\">*</span>\r\n </label>\r\n <ng-container *ngIf=\"!reseting\">\r\n <app-dynamic-form-department \r\n #depRef\r\n formControlName=\"dep\"\r\n placeholder=\"placeholder\"\r\n [treeview]=\"false\"\r\n [pp_departmentNestedTree]=\"'PP_OS_Departments'\"\r\n [pp_departmentTree]=\"'PP_OS_Departments'\"\r\n [customPrefix]=\"'osdept'\"\r\n [customParentProperty]=\"'osdepartment_parentDepartmentCode'\"\r\n [useCustomAddEditAction]=\"true\"\r\n (onSelecting)=\"getDepMembers($event)\"\r\n >\r\n </app-dynamic-form-department>\r\n </ng-container>\r\n <ng-container *ngIf=\"reseting\">\r\n <app-dynamic-form-department\r\n #depRef\r\n formControlName=\"dep\"\r\n placeholder=\"placeholder\"\r\n [treeview]=\"false\"\r\n [pp_departmentNestedTree]=\"'PP_OS_Departments'\"\r\n [pp_departmentTree]=\"'PP_OS_Departments'\"\r\n [customPrefix]=\"'osdept'\"\r\n [customParentProperty]=\"'osdepartment_parentDepartmentCode'\"\r\n [useCustomAddEditAction]=\"true\"\r\n (onSelecting)=\"getDepMembers($event)\"\r\n >\r\n </app-dynamic-form-department>\r\n </ng-container>\r\n </div>\r\n <div class=\"flex flex-col w-full flex-1 usersWrapper\"\r\n [ngClass]=\"{'mt-4': display === 'column'}\">\r\n <label class=\"users-label\">\r\n {{userLabel}}\r\n <span class=\"text-danger\" *ngIf=\"isRequired()\">*</span>\r\n </label>\r\n <ng-select \r\n formControlName=\"users\"\r\n #ngSelectComponent \r\n [items]=\"depUsers\" \r\n bindLabel=\"properties.fullName\" \r\n bindValue=\"properties.username\" \r\n [multiple]=\"allowMultipleUsers\"\r\n [placeholder]=\"'share.placeholder' | translate\"\r\n (change)=\"setUser()\"\r\n >\r\n <ng-template ng-notfound-tmp let-searchTerm=\"searchTerm\">\r\n <div class=\"ng-option disabled\" *ngIf=\"!depAnditsUsers?.get('dep').value;else notFound\">\r\n {{'archiveSearch.select_dep' | translate}}\r\n </div>\r\n <ng-template #notFound>\r\n <div class=\"ng-option disabled\">\r\n {{'archiveSearch.noUsers' | translate}}\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\">\r\n <div class=\"flex flex-col h-full\">\r\n <div *ngIf=\"item\" class=\"flex flex-row\">\r\n <div class=\"flex-0 w-8 h-8 rounded-full overflow-hidden\">\r\n <cts-avatar [user]=\"{\r\n properties: {\r\n firstName: item.properties?.firstName,\r\n lastName: item.properties?.lastName\r\n }\r\n }\">\r\n </cts-avatar>\r\n </div>\r\n <div class=\"flex flex-col pt-0 px-2\">\r\n <span>{{item.properties?.fullName}}</span>\r\n <span>{{item.properties?.email}}</span>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n</form>", styles: [".userByDepSelectors ngx-dropdown-treeview>.dropdown{@apply bg-primary-50 border-primary-100 !important;}.userByDepSelectors .ng-select .ng-select-container .ng-value-container .ng-placeholder{font-size:12px!important;margin-top:4px!important}\n"], components: [{ type: i3.DynamicFormDepartmentComponent, selector: "app-dynamic-form-department", inputs: ["treeview", "treeViewAsFormControl", "placeholder", "multiple", "searchable", "label", "defaultSelect", "pp_departmentNestedTree", "pp_departmentTree", "customPrefix", "useCustomAddEditAction", "customParentProperty", "customParams"], outputs: ["onSelecting", "actionClicked"] }, { type: i4.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i5.AvatarComponent, selector: "cts-avatar", inputs: ["user"] }], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i4.ɵl, selector: "[ng-notfound-tmp]" }, { type: i4.ɵf, selector: "[ng-option-tmp]" }], pipes: { "translate": i7.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
92
92
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: SelectUsersByDepartmentsComponent, decorators: [{
93
93
  type: Component,
94
94
  args: [{
@@ -58,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
58
58
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i1.NuxeoService }]; }, propDecorators: { appHasRole: [{
59
59
  type: Input
60
60
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLWhhcy1yb2xlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2RpcmVjdGl2ZS9hcHAtaGFzLXJvbGUvYXBwLWhhcy1yb2xlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULEtBQUssRUFLTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFLL0IsTUFBTSxPQUFPLG1CQUFtQjtJQVE5QixZQUNVLGdCQUFrQyxFQUNsQyxXQUE2QixFQUM3QixZQUEwQjtRQUYxQixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQ2xDLGdCQUFXLEdBQVgsV0FBVyxDQUFrQjtRQUM3QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQVBwQyxVQUFLLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUV0QixjQUFTLEdBQUcsS0FBSyxDQUFDO0lBTWQsQ0FBQztJQUVMLFFBQVE7O1FBQ04sSUFBSSxNQUFBLElBQUksQ0FBQyxVQUFVLDBDQUFFLElBQUksRUFBRTtZQUN6QixJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDMUYsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO29CQUM1QixnREFBZ0Q7b0JBQ2hELDREQUE0RDtvQkFDNUQsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7d0JBQ25CLGlEQUFpRDt3QkFDakQsb0NBQW9DO3dCQUNwQyxzREFBc0Q7d0JBQ3RELElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO3dCQUN0QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO3FCQUM1RDtpQkFDRjtxQkFBTTtvQkFDTCxzQ0FBc0M7b0JBQ3RDLCtDQUErQztvQkFDL0MsdUNBQXVDO29CQUN2QyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztvQkFDdkIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRSxDQUFDO2lCQUMvQjtZQUNILENBQUMsQ0FBQyxDQUFDO1NBQ0o7YUFBTTtZQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFO2dCQUNuQixpREFBaUQ7Z0JBQ2pELG9DQUFvQztnQkFDcEMsc0RBQXNEO2dCQUN0RCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztnQkFDdEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQzthQUM1RDtTQUNGO0lBQ0gsQ0FBQztJQUNELFdBQVc7UUFDVCxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbEIsQ0FBQzs7Z0hBL0NVLG1CQUFtQjtvR0FBbkIsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBSC9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7aUJBQ3pCOzRKQUdVLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBOdXhlb1NlcnZpY2UgfSBmcm9tICcuLi8uLi9Db3JlL3NlcnZpY2VzL251eGVvL251eGVvLnNlcnZpY2UnO1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2FwcEhhc1JvbGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBBcHBIYXNSb2xlRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICAvKiogdGhlIHJvbGUgdGhlIHVzZXIgbXVzdCBoYXZlICovXG4gIEBJbnB1dCgpIGFwcEhhc1JvbGU7XG5cbiAgc3RvcCQgPSBuZXcgU3ViamVjdCgpO1xuXG4gIGlzVmlzaWJsZSA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICBwcml2YXRlIHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+LFxuICAgIHByaXZhdGUgbnV4ZW9TZXJ2aWNlOiBOdXhlb1NlcnZpY2VcbiAgKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5hcHBIYXNSb2xlPy5yb2xlKSB7XG4gICAgICB0aGlzLm51eGVvU2VydmljZS5pc1VzZXJJblJvbGUodGhpcy5hcHBIYXNSb2xlLnJvbGUsIHRoaXMuYXBwSGFzUm9sZS5jb2RlKS5zdWJzY3JpYmUoZGF0YSA9PiB7XG4gICAgICAgIGlmIChkYXRhIHx8ICF0aGlzLmFwcEhhc1JvbGUpIHtcbiAgICAgICAgICAvLyBJZiBpdCBpcyBhbHJlYWR5IHZpc2libGUgKHdoaWNoIGNhbiBoYXBwZW4gaWZcbiAgICAgICAgICAvLyBoaXMgcm9sZXMgY2hhbmdlZCkgd2UgZG8gbm90IG5lZWQgdG8gYWRkIGl0IGEgc2Vjb25kIHRpbWVcbiAgICAgICAgICBpZiAoIXRoaXMuaXNWaXNpYmxlKSB7XG4gICAgICAgICAgICAvLyBXZSB1cGRhdGUgdGhlIGBpc1Zpc2libGVgIHByb3BlcnR5IGFuZCBhZGQgdGhlXG4gICAgICAgICAgICAvLyB0ZW1wbGF0ZVJlZiB0byB0aGUgdmlldyB1c2luZyB0aGVcbiAgICAgICAgICAgIC8vICdjcmVhdGVFbWJlZGRlZFZpZXcnIG1ldGhvZCBvZiB0aGUgdmlld0NvbnRhaW5lclJlZlxuICAgICAgICAgICAgdGhpcy5pc1Zpc2libGUgPSB0cnVlO1xuICAgICAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgLy8gSWYgdGhlIHVzZXIgZG9lcyBub3QgaGF2ZSB0aGUgcm9sZSxcbiAgICAgICAgICAvLyB3ZSB1cGRhdGUgdGhlIGBpc1Zpc2libGVgIHByb3BlcnR5IGFuZCBjbGVhclxuICAgICAgICAgIC8vIHRoZSBjb250ZW50cyBvZiB0aGUgdmlld0NvbnRhaW5lclJlZlxuICAgICAgICAgIHRoaXMuaXNWaXNpYmxlID0gZmFsc2U7XG4gICAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoIXRoaXMuaXNWaXNpYmxlKSB7XG4gICAgICAgIC8vIFdlIHVwZGF0ZSB0aGUgYGlzVmlzaWJsZWAgcHJvcGVydHkgYW5kIGFkZCB0aGVcbiAgICAgICAgLy8gdGVtcGxhdGVSZWYgdG8gdGhlIHZpZXcgdXNpbmcgdGhlXG4gICAgICAgIC8vICdjcmVhdGVFbWJlZGRlZFZpZXcnIG1ldGhvZCBvZiB0aGUgdmlld0NvbnRhaW5lclJlZlxuICAgICAgICB0aGlzLmlzVmlzaWJsZSA9IHRydWU7XG4gICAgICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIG5nT25DaGFuZ2VzKCl7XG4gICAgdGhpcy5uZ09uSW5pdCgpO1xuICB9XG59XG4iXX0=
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLWhhcy1yb2xlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2RpcmVjdGl2ZS9hcHAtaGFzLXJvbGUvYXBwLWhhcy1yb2xlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULEtBQUssRUFLTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFLL0IsTUFBTSxPQUFPLG1CQUFtQjtJQVE5QixZQUNVLGdCQUFrQyxFQUNsQyxXQUE2QixFQUM3QixZQUEwQjtRQUYxQixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQ2xDLGdCQUFXLEdBQVgsV0FBVyxDQUFrQjtRQUM3QixpQkFBWSxHQUFaLFlBQVksQ0FBYztRQVBwQyxVQUFLLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUV0QixjQUFTLEdBQUcsS0FBSyxDQUFDO0lBTWQsQ0FBQztJQUVMLFFBQVE7O1FBQ04sSUFBSSxNQUFBLElBQUksQ0FBQyxVQUFVLDBDQUFFLElBQUksRUFBRTtZQUN6QixJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDMUYsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO29CQUM1QixnREFBZ0Q7b0JBQ2hELDREQUE0RDtvQkFDNUQsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7d0JBQ25CLGlEQUFpRDt3QkFDakQsb0NBQW9DO3dCQUNwQyxzREFBc0Q7d0JBQ3RELElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO3dCQUN0QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO3FCQUM1RDtpQkFDRjtxQkFBTTtvQkFDTCxzQ0FBc0M7b0JBQ3RDLCtDQUErQztvQkFDL0MsdUNBQXVDO29CQUN2QyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztvQkFDdkIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRSxDQUFDO2lCQUMvQjtZQUNILENBQUMsQ0FBQyxDQUFDO1NBQ0o7YUFBTTtZQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFO2dCQUNuQixpREFBaUQ7Z0JBQ2pELG9DQUFvQztnQkFDcEMsc0RBQXNEO2dCQUN0RCxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztnQkFDdEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQzthQUM1RDtTQUNGO0lBQ0gsQ0FBQztJQUNELFdBQVc7UUFDVCxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbEIsQ0FBQzs7Z0hBL0NVLG1CQUFtQjtvR0FBbkIsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBSC9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7aUJBQ3pCOzRKQUdVLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIERpcmVjdGl2ZSxcclxuICBJbnB1dCxcclxuICBPbkNoYW5nZXMsXHJcbiAgT25Jbml0LFxyXG4gIFRlbXBsYXRlUmVmLFxyXG4gIFZpZXdDb250YWluZXJSZWZcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBOdXhlb1NlcnZpY2UgfSBmcm9tICcuLi8uLi9Db3JlL3NlcnZpY2VzL251eGVvL251eGVvLnNlcnZpY2UnO1xyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1thcHBIYXNSb2xlXSdcclxufSlcclxuZXhwb3J0IGNsYXNzIEFwcEhhc1JvbGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XHJcbiAgLyoqIHRoZSByb2xlIHRoZSB1c2VyIG11c3QgaGF2ZSAqL1xyXG4gIEBJbnB1dCgpIGFwcEhhc1JvbGU7XHJcblxyXG4gIHN0b3AkID0gbmV3IFN1YmplY3QoKTtcclxuXHJcbiAgaXNWaXNpYmxlID0gZmFsc2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxyXG4gICAgcHJpdmF0ZSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcclxuICAgIHByaXZhdGUgbnV4ZW9TZXJ2aWNlOiBOdXhlb1NlcnZpY2VcclxuICApIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLmFwcEhhc1JvbGU/LnJvbGUpIHtcclxuICAgICAgdGhpcy5udXhlb1NlcnZpY2UuaXNVc2VySW5Sb2xlKHRoaXMuYXBwSGFzUm9sZS5yb2xlLCB0aGlzLmFwcEhhc1JvbGUuY29kZSkuc3Vic2NyaWJlKGRhdGEgPT4ge1xyXG4gICAgICAgIGlmIChkYXRhIHx8ICF0aGlzLmFwcEhhc1JvbGUpIHtcclxuICAgICAgICAgIC8vIElmIGl0IGlzIGFscmVhZHkgdmlzaWJsZSAod2hpY2ggY2FuIGhhcHBlbiBpZlxyXG4gICAgICAgICAgLy8gaGlzIHJvbGVzIGNoYW5nZWQpIHdlIGRvIG5vdCBuZWVkIHRvIGFkZCBpdCBhIHNlY29uZCB0aW1lXHJcbiAgICAgICAgICBpZiAoIXRoaXMuaXNWaXNpYmxlKSB7XHJcbiAgICAgICAgICAgIC8vIFdlIHVwZGF0ZSB0aGUgYGlzVmlzaWJsZWAgcHJvcGVydHkgYW5kIGFkZCB0aGVcclxuICAgICAgICAgICAgLy8gdGVtcGxhdGVSZWYgdG8gdGhlIHZpZXcgdXNpbmcgdGhlXHJcbiAgICAgICAgICAgIC8vICdjcmVhdGVFbWJlZGRlZFZpZXcnIG1ldGhvZCBvZiB0aGUgdmlld0NvbnRhaW5lclJlZlxyXG4gICAgICAgICAgICB0aGlzLmlzVmlzaWJsZSA9IHRydWU7XHJcbiAgICAgICAgICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIC8vIElmIHRoZSB1c2VyIGRvZXMgbm90IGhhdmUgdGhlIHJvbGUsXHJcbiAgICAgICAgICAvLyB3ZSB1cGRhdGUgdGhlIGBpc1Zpc2libGVgIHByb3BlcnR5IGFuZCBjbGVhclxyXG4gICAgICAgICAgLy8gdGhlIGNvbnRlbnRzIG9mIHRoZSB2aWV3Q29udGFpbmVyUmVmXHJcbiAgICAgICAgICB0aGlzLmlzVmlzaWJsZSA9IGZhbHNlO1xyXG4gICAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIGlmICghdGhpcy5pc1Zpc2libGUpIHtcclxuICAgICAgICAvLyBXZSB1cGRhdGUgdGhlIGBpc1Zpc2libGVgIHByb3BlcnR5IGFuZCBhZGQgdGhlXHJcbiAgICAgICAgLy8gdGVtcGxhdGVSZWYgdG8gdGhlIHZpZXcgdXNpbmcgdGhlXHJcbiAgICAgICAgLy8gJ2NyZWF0ZUVtYmVkZGVkVmlldycgbWV0aG9kIG9mIHRoZSB2aWV3Q29udGFpbmVyUmVmXHJcbiAgICAgICAgdGhpcy5pc1Zpc2libGUgPSB0cnVlO1xyXG4gICAgICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcbiAgbmdPbkNoYW5nZXMoKXtcclxuICAgIHRoaXMubmdPbkluaXQoKTtcclxuICB9XHJcbn1cclxuIl19