nuxeo-development-framework 3.5.3 → 3.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +37 -24
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/correspondence-relation/services/correspondence-realation.service.js +3 -3
- package/esm2015/lib/components/documents/components/attachments-page-provider/attachments-page-provider.component.js +3 -2
- package/esm2015/lib/components/dynamic-form/components/department-form/department-form.component.js +3 -3
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-dateitem/dynamic-form-dateitem.component.js +2 -2
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.js +8 -2
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-department/services/department-management.service.js +4 -3
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.js +8 -4
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.js +2 -2
- package/esm2015/lib/components/dynamic-search/dynamic-search/dynamic-search.component.js +12 -10
- package/esm2015/lib/components/filter/filter/filter.component.js +1 -1
- package/esm2015/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.js +1 -1
- package/esm2015/lib/shared/components/button/button.component.js +1 -1
- package/fesm2015/nuxeo-development-framework.js +37 -24
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/dynamic-form/components/dynamic-form-department/dynamic-form-department.component.d.ts +3 -1
- package/lib/components/dynamic-form/components/dynamic-form-department/services/department-management.service.d.ts +1 -1
- package/lib/components/dynamic-form/components/dynamic-form-treeview-select/dropdown-treeview-select.component.d.ts +4 -1
- package/package.json +1 -1
|
@@ -82,7 +82,7 @@ export class DynamicFormVocabularyItemComponent {
|
|
|
82
82
|
: this.getVocabularyList(type);
|
|
83
83
|
callApi.subscribe((res) => {
|
|
84
84
|
this.loading = false;
|
|
85
|
-
this.data = !this.shwoAllValues ? res.filter(item => !item.id.includes('archived') && !item.id.includes('draft')) : res;
|
|
85
|
+
this.data = !this.shwoAllValues ? res.filter(item => !item.id.includes('archived') && !item.id.includes('draft')) : res.filter(item => item.obsolete === 0);
|
|
86
86
|
this.cdRef.detectChanges();
|
|
87
87
|
});
|
|
88
88
|
}
|
|
@@ -175,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
175
175
|
}], onSelecting: [{
|
|
176
176
|
type: Output
|
|
177
177
|
}], getCacheableVocabularyList: [] } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-vocabulary-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { Observable } from 'rxjs';\r\nimport { VocabularyApiService } from '../../../vocabulary/services/vocabulary-api.service';\r\nimport { Cacheable, LocalStorageStrategy } from 'ts-cacheable';\r\nimport { DynamicFormSelectItemComponent } from '../dynamic-form-selectitem/dynamic-form-selectitem.component';\r\n\r\n/**\r\n * A vocabulary dropdown input integrated with nuxeo vocabulary API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * vocabulary dropdown\r\n * @example\r\n * <app-dynamic-form-vocabulary-item\r\n *   [label]=\"'PATH.TO.LABEL.TRANSLATION'\"\r\n *   [bindLabel]=\"'bindLabelPropertyName'\"\r\n *   [bindValue]=\"'bindValuePropertyName'\"\r\n *   placeholder=\"'PATH.TO.PLACEHOLDER.TRANSLATION'\"\r\n *   [multiple]=\"false\"\r\n *   [searchable]=\"false\"\r\n *   [closeOnSelect]=\"true\"\r\n *   [hideSelectedItems]=\"false\"\r\n *   [vocabularyType]=\"'VocabularyKey'\"\r\n *   formControlName=\"controlName\"\r\n * >\r\n * </app-dynamic-form-vocabulary-item>\r\n */\r\n@Component({\r\n  selector: 'app-dynamic-form-vocabulary-item',\r\n  templateUrl: './dynamic-form-vocabulary-item.component.html',\r\n  styleUrls: ['./dynamic-form-vocabulary-item.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormVocabularyItemComponent\r\n  implements ControlValueAccessor {\r\n  @ViewChild(DynamicFormSelectItemComponent)\r\n  DynamicFormSelectItemComponent: DynamicFormSelectItemComponent;\r\n\r\n  data = [];\r\n  /** Bind value to property name */\r\n  @Input() bindValue;\r\n  /** Bind label to property name */\r\n  @Input() bindLabel;\r\n  /** Placeholder string */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** Is searchable */\r\n  @Input() searchable = true;\r\n  /** Should close on select */\r\n  @Input() closeOnSelect = true;\r\n  /** Should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n    /** is disabled */\r\n    @Input() disabled = false;\r\n  /** Vocabulary list API Key */\r\n  @Input() vocabularyType = '';\r\n  /** Field Label */\r\n  @Input() label;\r\n  @Input() cacheable = true;\r\n  @Input() shwoAllValues = true\r\n  /** Event emitted on value is selected */\r\n  @Output() onSelecting = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n\r\n  // function related to value accessor\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  constructor(\r\n    private vocabularyApi: VocabularyApiService,\r\n    private cdRef : ChangeDetectorRef,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    this.control.valueAccessor = this;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.vocabularyType) {\r\n      this.getLisOfOptions(this.vocabularyType);\r\n    }\r\n  }\r\n\r\n  getLisOfOptions(type) {\r\n    this.loading = true;\r\n    const callApi = this.cacheable\r\n      ? this.getCacheableVocabularyList(type)\r\n      : this.getVocabularyList(type);\r\n    callApi.subscribe((res) => {\r\n      this.loading = false;\r\n      this.data = !this.shwoAllValues ? res.filter(item => !item.id.includes('archived') && !item.id.includes('draft')) : res;\r\n      this.cdRef.detectChanges();\r\n    });\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    storageStrategy: LocalStorageStrategy,\r\n    maxAge: 20000,\r\n  })\r\n  getCacheableVocabularyList(type) {\r\n    return this.vocabularyApi.getVocabularyList(type);\r\n  }\r\n  \r\n  getVocabularyList(type) {\r\n    return this.vocabularyApi.getVocabularyList(type);\r\n  }\r\n  getSelecteditems(selectedItems) {\r\n    this.propagateChange(this.selection);\r\n    this.onSelecting.emit(this.selection);\r\n  }\r\n\r\n  writeValue(value) {\r\n    // if (value) { removed to allow reseting ui when resetting form\r\n      this.selection = value;\r\n    // }\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  validate(c: FormControl) {\r\n    return this.validateFn(c);\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n  reset() {\r\n    this.DynamicFormSelectItemComponent.reset();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n  <div>\r\n    <label class=\"select-label\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n    >\r\n  </div>\r\n</ng-container>\r\n<app-dynamic-form-selectitem\r\n  [voc]=\"true\"\r\n  [vocId]=\"vocabularyType\"\r\n  [data]=\"data\"\r\n  [bindLabel]=\"bindLabel\"\r\n  [bindValue]=\"bindValue\"\r\n  [placeholder]=\"placeholder\"\r\n  [multiple]=\"multiple\"\r\n  [searchable]=\"searchable\"\r\n  [closeOnSelect]=\"closeOnSelect\"\r\n  [disabled]=\"disabled\"\r\n  [hideSelectedItems]=\"hideSelectedItems\"\r\n  [loading]=\"loading\"\r\n  (onSelectItems)=\"getSelecteditems($event)\"\r\n  [(ngModel)]=\"selection\"\r\n></app-dynamic-form-selectitem>\r\n<mat-error\r\n  [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n  class=\"app-textitem-editable-error\"\r\n  *ngIf=\"hasErrors()\"\r\n>\r\n  <ul>\r\n    <li *ngIf=\"control.errors.required\">\r\n      {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n    </li>\r\n  </ul>\r\n</mat-error>\r\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-vocabulary-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-vocabulary-item/dynamic-form-vocabulary-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { Observable } from 'rxjs';\r\nimport { VocabularyApiService } from '../../../vocabulary/services/vocabulary-api.service';\r\nimport { Cacheable, LocalStorageStrategy } from 'ts-cacheable';\r\nimport { DynamicFormSelectItemComponent } from '../dynamic-form-selectitem/dynamic-form-selectitem.component';\r\n\r\n/**\r\n * A vocabulary dropdown input integrated with nuxeo vocabulary API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * vocabulary dropdown\r\n * @example\r\n * <app-dynamic-form-vocabulary-item\r\n *   [label]=\"'PATH.TO.LABEL.TRANSLATION'\"\r\n *   [bindLabel]=\"'bindLabelPropertyName'\"\r\n *   [bindValue]=\"'bindValuePropertyName'\"\r\n *   placeholder=\"'PATH.TO.PLACEHOLDER.TRANSLATION'\"\r\n *   [multiple]=\"false\"\r\n *   [searchable]=\"false\"\r\n *   [closeOnSelect]=\"true\"\r\n *   [hideSelectedItems]=\"false\"\r\n *   [vocabularyType]=\"'VocabularyKey'\"\r\n *   formControlName=\"controlName\"\r\n * >\r\n * </app-dynamic-form-vocabulary-item>\r\n */\r\n@Component({\r\n  selector: 'app-dynamic-form-vocabulary-item',\r\n  templateUrl: './dynamic-form-vocabulary-item.component.html',\r\n  styleUrls: ['./dynamic-form-vocabulary-item.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormVocabularyItemComponent\r\n  implements ControlValueAccessor {\r\n  @ViewChild(DynamicFormSelectItemComponent)\r\n  DynamicFormSelectItemComponent: DynamicFormSelectItemComponent;\r\n\r\n  data = [];\r\n  /** Bind value to property name */\r\n  @Input() bindValue;\r\n  /** Bind label to property name */\r\n  @Input() bindLabel;\r\n  /** Placeholder string */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** Is searchable */\r\n  @Input() searchable = true;\r\n  /** Should close on select */\r\n  @Input() closeOnSelect = true;\r\n  /** Should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n    /** is disabled */\r\n    @Input() disabled = false;\r\n  /** Vocabulary list API Key */\r\n  @Input() vocabularyType = '';\r\n  /** Field Label */\r\n  @Input() label;\r\n  @Input() cacheable = true;\r\n  @Input() shwoAllValues = true\r\n  /** Event emitted on value is selected */\r\n  @Output() onSelecting = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n\r\n  // function related to value accessor\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  constructor(\r\n    private vocabularyApi: VocabularyApiService,\r\n    private cdRef : ChangeDetectorRef,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    this.control.valueAccessor = this;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.vocabularyType) {\r\n      this.getLisOfOptions(this.vocabularyType);\r\n    }\r\n  }\r\n\r\n  getLisOfOptions(type) {\r\n    this.loading = true;\r\n    const callApi = this.cacheable\r\n      ? this.getCacheableVocabularyList(type)\r\n      : this.getVocabularyList(type);\r\n    callApi.subscribe((res) => {\r\n      this.loading = false;\r\n      this.data = !this.shwoAllValues ? res.filter(item => !item.id.includes('archived') && !item.id.includes('draft')) : res.filter(item => item.obsolete === 0);\r\n      this.cdRef.detectChanges();\r\n    });\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    storageStrategy: LocalStorageStrategy,\r\n    maxAge: 20000,\r\n  })\r\n  getCacheableVocabularyList(type) {\r\n    return this.vocabularyApi.getVocabularyList(type);\r\n  }\r\n  \r\n  getVocabularyList(type) {\r\n    return this.vocabularyApi.getVocabularyList(type);\r\n  }\r\n  getSelecteditems(selectedItems) {\r\n    this.propagateChange(this.selection);\r\n    this.onSelecting.emit(this.selection);\r\n  }\r\n\r\n  writeValue(value) {\r\n    // if (value) { removed to allow reseting ui when resetting form\r\n      this.selection = value;\r\n    // }\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  validate(c: FormControl) {\r\n    return this.validateFn(c);\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n  reset() {\r\n    this.DynamicFormSelectItemComponent.reset();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n  <div>\r\n    <label class=\"select-label\"\r\n      >{{ label | translate\r\n      }}<span *ngIf=\"isRequired()\" class=\"text-danger m-1\">*</span></label\r\n    >\r\n  </div>\r\n</ng-container>\r\n<app-dynamic-form-selectitem\r\n  [voc]=\"true\"\r\n  [vocId]=\"vocabularyType\"\r\n  [data]=\"data\"\r\n  [bindLabel]=\"bindLabel\"\r\n  [bindValue]=\"bindValue\"\r\n  [placeholder]=\"placeholder\"\r\n  [multiple]=\"multiple\"\r\n  [searchable]=\"searchable\"\r\n  [closeOnSelect]=\"closeOnSelect\"\r\n  [disabled]=\"disabled\"\r\n  [hideSelectedItems]=\"hideSelectedItems\"\r\n  [loading]=\"loading\"\r\n  (onSelectItems)=\"getSelecteditems($event)\"\r\n  [(ngModel)]=\"selection\"\r\n></app-dynamic-form-selectitem>\r\n<mat-error\r\n  [attr.data-automation-id]=\"'card-textitem-error-'\"\r\n  class=\"app-textitem-editable-error\"\r\n  *ngIf=\"hasErrors()\"\r\n>\r\n  <ul>\r\n    <li *ngIf=\"control.errors.required\">\r\n      {{ label | translate }} {{ \"VALIDATORS.REQUIRED\" | translate }}\r\n    </li>\r\n  </ul>\r\n</mat-error>\r\n"]}
|
|
@@ -110,19 +110,21 @@ export class DynamicSearchComponent {
|
|
|
110
110
|
constructParamsFunction(params) {
|
|
111
111
|
let contructedParms = {};
|
|
112
112
|
this.text = params['search_query'];
|
|
113
|
-
if (this.
|
|
114
|
-
if (
|
|
115
|
-
|
|
116
|
-
|
|
113
|
+
if (this.text && this.text.trim()) {
|
|
114
|
+
if (this.useToggleFilters) {
|
|
115
|
+
if (params['quickFilters']) {
|
|
116
|
+
this.quickFilters = params['quickFilters'];
|
|
117
|
+
contructedParms = { [this.fullTextParamName]: this.text + '*', quickFilters: this.quickFilters };
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
this.quickFilters = '';
|
|
121
|
+
contructedParms = { [this.fullTextParamName]: this.text + '*', quickFilters: '' };
|
|
122
|
+
}
|
|
117
123
|
}
|
|
118
124
|
else {
|
|
119
|
-
this.
|
|
120
|
-
contructedParms = { [this.fullTextParamName]: this.text + '*', quickFilters: '' };
|
|
125
|
+
contructedParms = { [this.fullTextParamName]: this.text + '*' };
|
|
121
126
|
}
|
|
122
127
|
}
|
|
123
|
-
else {
|
|
124
|
-
contructedParms = { [this.fullTextParamName]: this.text + '*' };
|
|
125
|
-
}
|
|
126
128
|
return contructedParms;
|
|
127
129
|
}
|
|
128
130
|
updateQueryParams(newQueryparams) {
|
|
@@ -331,4 +333,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
331
333
|
}], theme: [{
|
|
332
334
|
type: Input
|
|
333
335
|
}] } });
|
|
334
|
-
//# 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\nimport { GlobalAdminService } from '../../../shared-services/global-admin.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() suggesterApi; // api to be used in the suggester input if sent will used it if not will use the defult once\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    private globalAdminService : GlobalAdminService,\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    let params= {\r\n      searchTerm: term\r\n    }\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      params['path'] = '/' + this.globalAdminService.activeTenant + '/'\r\n    }else if(!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId){\r\n      params['path'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId + '/'\r\n    }\r\n    return from(\r\n        this.nuxeoService.nuxeoClient\r\n            .operation((this.suggesterApi ? this.suggesterApi : 'Search.CustomSuggestersLauncher'), {\r\n                url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n            })\r\n            .params({\r\n                ...params\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_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      <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_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 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>"]}
|
|
336
|
+
//# 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\nimport { GlobalAdminService } from '../../../shared-services/global-admin.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() suggesterApi; // api to be used in the suggester input if sent will used it if not will use the defult once\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    private globalAdminService : GlobalAdminService,\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.text && this.text.trim()){\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\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    let params= {\r\n      searchTerm: term\r\n    }\r\n    if(this.globalAdminService.isGlobalAdmin){\r\n      params['path'] = '/' + this.globalAdminService.activeTenant + '/'\r\n    }else if(!this.globalAdminService.isGlobalAdmin && this.nuxeoService.nuxeoClient.user.properties.tenantId){\r\n      params['path'] = '/' + this.nuxeoService.nuxeoClient.user.properties.tenantId + '/'\r\n    }\r\n    return from(\r\n        this.nuxeoService.nuxeoClient\r\n            .operation((this.suggesterApi ? this.suggesterApi : 'Search.CustomSuggestersLauncher'), {\r\n                url: `${this.environment.nuxeo}${this.environment.customAutomation}`,\r\n            })\r\n            .params({\r\n                ...params\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_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      <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_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 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", "tenantId", "emitFullObject", "outsideParams", "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 } });
|
|
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", "tenantId", "emitFullObject", "outsideParams", "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", "displayDepTypee", "displayIsAllowRecExternal", "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", "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 });
|
|
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", "displayDepTypee", "displayIsAllowRecExternal", "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: [{
|
|
@@ -87,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
87
87
|
}], onClick: [{
|
|
88
88
|
type: Output
|
|
89
89
|
}] } });
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL3NoYXJlZC9jb21wb25lbnRzL2J1dHRvbi9idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvc2hhcmVkL2NvbXBvbmVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxFQUVOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7OztBQUV2Qjs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFPSCxNQUFNLE9BQU8sZUFBZTtJQW1CMUI7UUFaQSw0Q0FBNEM7UUFFNUMsU0FBSSxHQUFHLFNBQVMsQ0FBQztRQUVqQix3RkFBd0Y7UUFDeEYsVUFBSyxHQUFHLFNBQVMsQ0FBQztRQUVULG1CQUFjLEdBQUcsU0FBUyxDQUFFLENBQUMseUNBQXlDO1FBRS9FLHlCQUF5QjtRQUV6QixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUNiLENBQUM7SUFFakIsU0FBUztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUNELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyx5R0FBeUc7UUFDekcsNkNBQTZDO1FBQzdDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBQ0QsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksT0FBTyxHQUFHO1lBQ1osT0FBTztZQUNQLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSyxLQUFLLFNBQVM7WUFDakMsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLEtBQUssTUFBTTtZQUMzQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssS0FBSyxPQUFPO1lBQzdCLE1BQU0sRUFBRSxJQUFJLENBQUMsS0FBSyxLQUFLLFFBQVE7WUFDL0IsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLEtBQUssTUFBTTtZQUMzQixJQUFJLEVBQUUsSUFBSSxDQUFDLEtBQUssS0FBSyxNQUFNO1lBQzNCLFlBQVksRUFBRSxJQUFJLENBQUMsS0FBSyxLQUFLLFlBQVk7WUFDekMsY0FBYyxFQUFFLElBQUksQ0FBQyxLQUFLLEtBQUssY0FBYztZQUM3QyxPQUFPO1lBQ1AsS0FBSyxFQUFFLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTztZQUM1QixPQUFPLEVBQUUsSUFBSSxDQUFDLElBQUksS0FBSyxTQUFTO1lBQ2hDLEtBQUssRUFBRSxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU87WUFDNUIsU0FBUztZQUNULFVBQVUsRUFBRSxJQUFJLENBQUMsT0FBTztZQUN4QixTQUFTO1lBQ1QsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1NBQ3hCLENBQUM7UUFDRixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztJQUN6QixDQUFDOzs0R0F0RFUsZUFBZTtnR0FBZixlQUFlLDhOQ2pDNUIsMFlBYUE7MkZEb0JhLGVBQWU7a0JBTjNCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLFdBQVcsRUFBRSx5QkFBeUI7b0JBQ3RDLFNBQVMsRUFBRSxDQUFDLHlCQUF5QixDQUFDO29CQUN0QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEM7MEVBSUMsUUFBUTtzQkFEUCxLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7O1FBR04sd0ZBQXdGO1FBQ3hGLEtBQUs7c0JBRkosS0FBSztnQkFJRyxjQUFjO3NCQUF0QixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbnB1dCxcclxuICBPbkNoYW5nZXMsXHJcbiAgT25Jbml0LFxyXG4gIE91dHB1dCxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIHJldXNhYmxlIGJ1dHRvbiB3aXRoIHNwaW5uZXIgY29tcG9uZW50XHJcbiAqIEB0aXRsZVxyXG4gKiBCdXR0b24gd2l0aCBzcGlubmVyXHJcbiAqIEBleGFtcGxlXHJcbiAqXHJcbiAqIDxjdHMtYnV0dG9uXHJcbiAqICAgICBbdGhlbWVdPVwiJ2RhbmdlcidcIlxyXG4gKiAgICAgW3NpemVdPVwiJ3JlZ3VsYXInXCJcclxuICogICAgIFtsb2FkaW5nXT1cImZhbHNlXCJcclxuICogICAgIFtkaXNhYmxlZF09XCJmYWxzZVwiXHJcbiAqICAgICAob25DbGljayk9XCJleGVjdXRlQWN0aW9uKClcIlxyXG4gKiAgID5cclxuICogICAgIEJ1dHRvbiBUZXh0XHJcbiAqICAgPC9jdHMtYnV0dG9uPlxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjdHMtYnV0dG9uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9idXR0b24uY29tcG9uZW50LnNjc3MnXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xyXG4gIC8qKiBpcyBidXR0b24gZGlzYWJsZWQgKi9cclxuICBASW5wdXQoKVxyXG4gIGRpc2FibGVkPztcclxuICAvKiogaXMgYnV0dG9uIGxvYWRpbmcgKi9cclxuICBASW5wdXQoKVxyXG4gIGxvYWRpbmc/
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL3NoYXJlZC9jb21wb25lbnRzL2J1dHRvbi9idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvc2hhcmVkL2NvbXBvbmVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxFQUVOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7OztBQUV2Qjs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFPSCxNQUFNLE9BQU8sZUFBZTtJQW1CMUI7UUFaQSw0Q0FBNEM7UUFFNUMsU0FBSSxHQUFHLFNBQVMsQ0FBQztRQUVqQix3RkFBd0Y7UUFDeEYsVUFBSyxHQUFHLFNBQVMsQ0FBQztRQUVULG1CQUFjLEdBQUcsU0FBUyxDQUFFLENBQUMseUNBQXlDO1FBRS9FLHlCQUF5QjtRQUV6QixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUNiLENBQUM7SUFFakIsU0FBUztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUNELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyx5R0FBeUc7UUFDekcsNkNBQTZDO1FBQzdDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBQ0QsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksT0FBTyxHQUFHO1lBQ1osT0FBTztZQUNQLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSyxLQUFLLFNBQVM7WUFDakMsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLEtBQUssTUFBTTtZQUMzQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssS0FBSyxPQUFPO1lBQzdCLE1BQU0sRUFBRSxJQUFJLENBQUMsS0FBSyxLQUFLLFFBQVE7WUFDL0IsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLEtBQUssTUFBTTtZQUMzQixJQUFJLEVBQUUsSUFBSSxDQUFDLEtBQUssS0FBSyxNQUFNO1lBQzNCLFlBQVksRUFBRSxJQUFJLENBQUMsS0FBSyxLQUFLLFlBQVk7WUFDekMsY0FBYyxFQUFFLElBQUksQ0FBQyxLQUFLLEtBQUssY0FBYztZQUM3QyxPQUFPO1lBQ1AsS0FBSyxFQUFFLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTztZQUM1QixPQUFPLEVBQUUsSUFBSSxDQUFDLElBQUksS0FBSyxTQUFTO1lBQ2hDLEtBQUssRUFBRSxJQUFJLENBQUMsSUFBSSxLQUFLLE9BQU87WUFDNUIsU0FBUztZQUNULFVBQVUsRUFBRSxJQUFJLENBQUMsT0FBTztZQUN4QixTQUFTO1lBQ1QsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1NBQ3hCLENBQUM7UUFDRixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztJQUN6QixDQUFDOzs0R0F0RFUsZUFBZTtnR0FBZixlQUFlLDhOQ2pDNUIsMFlBYUE7MkZEb0JhLGVBQWU7a0JBTjNCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLFdBQVcsRUFBRSx5QkFBeUI7b0JBQ3RDLFNBQVMsRUFBRSxDQUFDLHlCQUF5QixDQUFDO29CQUN0QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEM7MEVBSUMsUUFBUTtzQkFEUCxLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7O1FBR04sd0ZBQXdGO1FBQ3hGLEtBQUs7c0JBRkosS0FBSztnQkFJRyxjQUFjO3NCQUF0QixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbnB1dCxcclxuICBPbkNoYW5nZXMsXHJcbiAgT25Jbml0LFxyXG4gIE91dHB1dCxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIHJldXNhYmxlIGJ1dHRvbiB3aXRoIHNwaW5uZXIgY29tcG9uZW50XHJcbiAqIEB0aXRsZVxyXG4gKiBCdXR0b24gd2l0aCBzcGlubmVyXHJcbiAqIEBleGFtcGxlXHJcbiAqXHJcbiAqIDxjdHMtYnV0dG9uXHJcbiAqICAgICBbdGhlbWVdPVwiJ2RhbmdlcidcIlxyXG4gKiAgICAgW3NpemVdPVwiJ3JlZ3VsYXInXCJcclxuICogICAgIFtsb2FkaW5nXT1cImZhbHNlXCJcclxuICogICAgIFtkaXNhYmxlZF09XCJmYWxzZVwiXHJcbiAqICAgICAob25DbGljayk9XCJleGVjdXRlQWN0aW9uKClcIlxyXG4gKiAgID5cclxuICogICAgIEJ1dHRvbiBUZXh0XHJcbiAqICAgPC9jdHMtYnV0dG9uPlxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjdHMtYnV0dG9uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9idXR0b24uY29tcG9uZW50LnNjc3MnXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xyXG4gIC8qKiBpcyBidXR0b24gZGlzYWJsZWQgKi9cclxuICBASW5wdXQoKVxyXG4gIGRpc2FibGVkPztcclxuICAvKiogaXMgYnV0dG9uIGxvYWRpbmcgKi9cclxuICBASW5wdXQoKVxyXG4gIGxvYWRpbmc/O1xyXG4gIC8qKiBidXR0b24gc2l6ZSBsYXJnZSB8fCByZWd1bGFyIHx8IHNtYWxsICovXHJcbiAgQElucHV0KClcclxuICBzaXplPz0gJ3JlZ3VsYXInO1xyXG4gIEBJbnB1dCgpXHJcbiAgLyoqIGF2YWlsYWJsZSB0aGVtZXM6IHByaW1hcnkgLCBibHVlICwgZ3JlZW4gLCBkYW5nZXIsIGRhcmssIGxpZ2h0LWdyYXksIG91dGxpbmUtZGFyayAqL1xyXG4gIHRoZW1lPz0gJ3ByaW1hcnknO1xyXG5cclxuICBASW5wdXQoKSBzcGlubmVyVGhlbWluZyA9ICdwcmltYXJ5JyA7IC8vIHZhbHVlIGNvdWxkIGJlIHByaW1hcnkgLCBhY2NlbnQgLCB3YXJuXHJcbiAgY2xhc3NlcztcclxuICAvKiogYnV0dG9uIGNsaWNrIGV2ZW50ICovXHJcbiAgQE91dHB1dCgpXHJcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBlbWl0Q2xpY2soKTogdm9pZCB7XHJcbiAgICB0aGlzLm9uQ2xpY2submV4dCgpO1xyXG4gIH1cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICAvL0NhbGxlZCBiZWZvcmUgYW55IG90aGVyIGxpZmVjeWNsZSBob29rLiBVc2UgaXQgdG8gaW5qZWN0IGRlcGVuZGVuY2llcywgYnV0IGF2b2lkIGFueSBzZXJpb3VzIHdvcmsgaGVyZS5cclxuICAgIC8vQWRkICcke2ltcGxlbWVudHMgT25DaGFuZ2VzfScgdG8gdGhlIGNsYXNzLlxyXG4gICAgdGhpcy5zZXRDbGFzc2VzKCk7XHJcbiAgfVxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5zZXRDbGFzc2VzKCk7XHJcbiAgfVxyXG5cclxuICBzZXRDbGFzc2VzKCkge1xyXG4gICAgbGV0IGNsYXNzZXMgPSB7XHJcbiAgICAgIC8vdGhlbWVcclxuICAgICAgcHJpbWFyeTogdGhpcy50aGVtZSA9PT0gJ3ByaW1hcnknLFxyXG4gICAgICBibHVlOiB0aGlzLnRoZW1lID09PSAnYmx1ZScsXHJcbiAgICAgIGdyZWVuOiB0aGlzLnRoZW1lID09PSAnZ3JlZW4nLFxyXG4gICAgICBkYW5nZXI6IHRoaXMudGhlbWUgPT09ICdkYW5nZXInLFxyXG4gICAgICBkYXJrOiB0aGlzLnRoZW1lID09PSAnZGFyaycsXHJcbiAgICAgIGdyYXk6IHRoaXMudGhlbWUgPT09ICdncmF5JyxcclxuICAgICAgJ2xpZ2h0LWdyYXknOiB0aGlzLnRoZW1lID09PSAnbGlnaHQtZ3JheScsXHJcbiAgICAgICdvdXRsaW5lLWRhcmsnOiB0aGlzLnRoZW1lID09PSAnb3V0bGluZS1kYXJrJyxcclxuICAgICAgLy9zaXplc1xyXG4gICAgICBsYXJnZTogdGhpcy5zaXplID09PSAnbGFyZ2UnLFxyXG4gICAgICByZWd1bGFyOiB0aGlzLnNpemUgPT09ICdyZWd1bGFyJywgXHJcbiAgICAgIHNtYWxsOiB0aGlzLnNpemUgPT09ICdzbWFsbCcsXHJcbiAgICAgIC8vbG9hZGluZ1xyXG4gICAgICBzdWJtaXR0aW5nOiB0aGlzLmxvYWRpbmcsXHJcbiAgICAgIC8vYWN0aW9uc1xyXG4gICAgICBkaXNhYmxlZDogdGhpcy5kaXNhYmxlZCxcclxuICAgIH07XHJcbiAgICB0aGlzLmNsYXNzZXMgPSBjbGFzc2VzO1xyXG4gIH1cclxufVxyXG4iLCI8YnV0dG9uXHJcbnR5cGU9XCJidXR0b25cIlxyXG5jbGFzcz1cImJ0blwiXHJcbiAgbWF0LWJ1dHRvblxyXG4gIFtkaXNhYmxlZF09XCJkaXNhYmxlZCB8fCBsb2FkaW5nXCJcclxuICAoY2xpY2spPVwiZW1pdENsaWNrKClcIlxyXG4gIFtuZ0NsYXNzXT1cInRoaXMuY2xhc3Nlc1wiXHJcbj5cclxuICA8bmctY29udGVudCAqbmdJZj1cIiFsb2FkaW5nOyBlbHNlIHNwaW5uZXJcIj48L25nLWNvbnRlbnQ+XHJcbiAgPG5nLXRlbXBsYXRlICNzcGlubmVyPlxyXG4gICAgPG1hdC1zcGlubmVyIGNsYXNzPVwic3Bpbm5lclwiIFtkaWFtZXRlcl09XCIyNVwiIFtjb2xvcl09XCJzcGlubmVyVGhlbWluZ1wiPjwvbWF0LXNwaW5uZXI+XHJcbiAgPC9uZy10ZW1wbGF0ZT5cclxuPC9idXR0b24+XHJcbiJdfQ==
|