nuxeo-development-framework 5.7.4 → 5.7.6
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 +8 -3
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.js +4 -1
- package/esm2015/lib/components/ndf-config-editor/components/info-dialog/info-dialog.component.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/models/report-data-source.js +1 -1
- package/esm2015/lib/components/reports/ndf-reports/services/base-chart-builder.service.js +4 -2
- package/esm2015/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.js +2 -2
- package/fesm2015/nuxeo-development-framework.js +8 -3
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/reports/ndf-reports/models/report-data-source.d.ts +5 -2
- package/package.json +1 -1
- package/src/docs/ndf-reports.doc.md +31 -25
|
@@ -168,6 +168,9 @@ export class DynamicFormSelectUsersComponent {
|
|
|
168
168
|
});
|
|
169
169
|
}
|
|
170
170
|
}
|
|
171
|
+
else {
|
|
172
|
+
this.loading = false;
|
|
173
|
+
}
|
|
171
174
|
}
|
|
172
175
|
getAllUsers(page = 0) {
|
|
173
176
|
return this.userApiService.getAllUsers({
|
|
@@ -353,4 +356,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
353
356
|
}], onSelectItems: [{
|
|
354
357
|
type: Output
|
|
355
358
|
}], getUsersSuggestions: [] } });
|
|
356
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-users.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  SimpleChanges,\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 { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  catchError,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  switchMap,\r\n  tap,\r\n} from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { UsersInDepartmentsApiService } from './services/user-api.service';\r\nimport * as _ from 'lodash';\r\nimport { Cacheable } from 'ts-cacheable';\r\n/**\r\n * Users dropdown input integrated with users API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * Users dropdown\r\n * @example\r\n * <cts-dynamic-form-select-users\r\n *     formControlName=\"controlName\"\r\n *     [bindValue]=\"bindToProperty\"\r\n *     [bindLabel]=\"'bindToLabel'\"\r\n *     [searchable]=\"true\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n *     [deptTitle]=\"'all'\"\r\n *   ></cts-dynamic-form-select-users>\r\n */\r\nconst minute = 60000;\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-users',\r\n  templateUrl: './dynamic-form-select-users.component.html',\r\n  styleUrls: ['./dynamic-form-select-users.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectUsersComponent\r\n  implements OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild('ngSelectComponent') ngSelectComponent: NgSelectComponent;\r\n  selectionstrg: string;\r\n  data = [];\r\n  allUsers: boolean;\r\n  userNameInput$ = new Subject<string>();\r\n  /** filter users by department (departmentName | all) */\r\n  @Input() deptTitle: string;\r\n  /** filter users by group name => this will replce dep title */\r\n  @Input() groupName: string;\r\n  /** Field Label */\r\n  @Input() label: string;\r\n  /** Bind value to object property */\r\n  @Input() bindValue;\r\n  /** Bind label to object property */\r\n  @Input() bindLabel;\r\n  @Input() arabicBindLabel;\r\n  /** Placeholder text */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** is dropdown searchable */\r\n  @Input() searchable = false;\r\n  /** should close dropdown on value selection */\r\n  @Input() closeOnSelect = true;\r\n  /** should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n  /** Pre Selected values */\r\n  @Input() preSelectedValues;\r\n  /** flage to use preselected values or not */\r\n  @Input() usePreSelectedValue = false;\r\n  /** is Disabled */\r\n  @Input() disabled = false;\r\n  /** List of usernames that should be exluded  */\r\n  @Input() filter: string[] = [];\r\n\r\n  /** flage to indicate if use full arabic name or not beside fullName  */\r\n  @Input() useArabicName = false;\r\n\r\n  /** event emitted when item is selected */\r\n  @Output() onSelectItems = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n  writedValue: any;\r\n  buffer = [];\r\n  bufferSize = 1000;\r\n  numberOfItemsFromEndBeforeFetchingMore = 10;\r\n  suffix;\r\n\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  isArabic = false;\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  pageIndex: number = 0;\r\n  isNextPageAvailable: boolean;\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 userApiService: UsersInDepartmentsApiService,\r\n    public translate: TranslateService,\r\n    private translation: TranslationService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.multiple) {\r\n      this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n    }\r\n    this.propagateChange(this.selection);\r\n    this.onSelectItems.emit(event);\r\n  }\r\n\r\n  onScrollToEnd() {\r\n    this.fetchMore();\r\n    ++this.pageIndex;\r\n    if (this.isNextPageAvailable && this.allUsers) {\r\n      this.getDepartments(this.pageIndex);\r\n    }\r\n  }\r\n\r\n  private fetchMore() {\r\n    this.loading = true;\r\n    const len = this.buffer.length;\r\n    const more = this.data.slice(len, this.bufferSize + len);\r\n    this.buffer = this.data.concat(more);\r\n    this.loading = false;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.deptTitle && !changes.deptTitle?.firstChange) || (changes.groupName && !changes.groupName?.firstChange)) {\r\n      this.data = [];\r\n      this.buffer = [];\r\n      this.getDepartments();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allUsers = this.deptTitle === 'all' ? true : false;\r\n    this.selection = (this.multiple ? [] : undefined);\r\n    if (this.allUsers) {\r\n      this.loadUsers();\r\n    }\r\n    this.getDepartments();\r\n    this.translation.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n      ar\r\n        ? (this.suffix = 'مستخدم تم إختياره')\r\n        : (this.suffix = 'Users Selected');\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    });\r\n  }\r\n\r\n  getDepartments(page = 0) {\r\n    this.loading = true;\r\n    if (this.groupName) {\r\n      this.userApiService.getUsersUnderCertainGroup(this.groupName).subscribe(data => {\r\n        let newData = this.constructUserArray(\r\n          data.users,\r\n          'properties.username'\r\n        );\r\n        this.data = this.data.concat(newData);\r\n        this.isNextPageAvailable = data.isNextPageAvailable;\r\n        this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n        this.buffer.map((item) => {\r\n          item.isSelected = false;\r\n        });\r\n        this.loading = false;\r\n      })\r\n    } else if (this.deptTitle) {\r\n      if (this.allUsers) {\r\n        this.getAllUsers(page).subscribe((data) => {\r\n          let newData = this.constructUserArray(data.entries, 'id');\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false; // for loading spinner\r\n        });\r\n      } else {\r\n        this.getCtsUsers(this.deptTitle).subscribe((data) => {\r\n          let newData = this.constructUserArray(\r\n            data.users,\r\n            'properties.username'\r\n          );\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false;\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getAllUsers(page = 0): Observable<any> {\r\n    return this.userApiService.getAllUsers({\r\n      currentPageIndex: page,\r\n      pageSize: 100,\r\n    });\r\n  }\r\n\r\n  private loadUsers() {\r\n    this.userNameInput$\r\n      .pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.loading = true)),\r\n        switchMap((term) => {\r\n          if (term && term.length) {\r\n            return this.getUsersSuggestions(term);\r\n          } else {\r\n            return this.getAllUsers();\r\n          }\r\n        })\r\n      )\r\n      .subscribe(\r\n        (data: any) => {\r\n          if (data.entries.length) {\r\n            let newData = this.constructUserArray(data.entries, 'id');\r\n            this.buffer = (newData || []).slice(0, this.bufferSize);\r\n            this.isNextPageAvailable = data.isNextPageAvailable;\r\n            this.loading = false;\r\n          } else {\r\n            this.buffer = [];\r\n            this.loading = false;\r\n          }\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.buffer = [];\r\n        }\r\n      );\r\n  }\r\n\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.writedValue = value;\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.writedValue.length} ${this.suffix}`;\r\n      }\r\n    } else {\r\n      this.writedValue = null;\r\n      this.selection = null;\r\n      this.selectionstrg = null\r\n    }\r\n  }\r\n\r\n  compareFn(item, selected) {\r\n    console.log(\"item 1\", item);\r\n    console.log(\"Item 2\", selected);\r\n    return item.id === selected.id;\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\r\n  // @Cacheable({\r\n  //   maxCacheCount: 1000,\r\n  //   maxAge: 20000,\r\n  // })\r\n\r\n  getCtsUsers(deptTitle): Observable<any> {\r\n    return this.userApiService.getCtsUsers(deptTitle);\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    maxAge: 5 * minute,\r\n  })\r\n  getUsersSuggestions(term): Observable<any> {\r\n    return this.userApiService.getUsersSuggestions(term);\r\n  }\r\n\r\n  private constructUserArray(data, filterValue: string) {\r\n    let ConstructedData: any[];\r\n    // if not using arabic name then construct full name here\r\n    if (!this.useArabicName) {\r\n      ConstructedData = this.insertFUllName(data);\r\n    }\r\n    ConstructedData = this.filterUsers(data, filterValue);\r\n    // Due to not using bindValue, we need to hold the selected value as the full user object, not just the username\r\n    if (this.writedValue) {\r\n      this.handleWrittedValue(ConstructedData);\r\n    }\r\n    return ConstructedData;\r\n  }\r\n\r\n  handleWrittedValue(users: Record<string, any>[]) {\r\n    const userId = (value) => {\r\n      return (typeof (value) === 'string') ? value : value.id;\r\n    }\r\n    this.selection = (this.multiple) ? users.filter(user => this.writedValue.some(value => user.properties.username === userId(value)))\r\n      : users.filter(user => user.properties.username === userId(this.writedValue))[0];\r\n    if (this.selection) {\r\n      this.writedValue = null;\r\n      this.emitSelection(this.selection);\r\n    }\r\n  }\r\n  private insertFUllName(data) {\r\n    return data.map((user) => {\r\n      user.fullName = `${user.properties?.firstName} ${user.properties?.lastName}`;\r\n    });\r\n  }\r\n  private filterUsers(data, path: string) {\r\n    let filterData = data.filter((user) => {\r\n      const includedInFilter =\r\n        this.filter.includes(_.get(user, path)) ||\r\n        _.get(user, path) === 'Administrator';\r\n      return !includedInFilter;\r\n    });\r\n    return filterData;\r\n  }\r\n\r\n  getUsersUnderCertainGroup() {\r\n\r\n  }\r\n  reset() {\r\n    this.ngSelectComponent.handleClearClick();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.userNameInput$.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n\t<div>\r\n\t\t<label class=\"select-label\"\r\n\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t>\r\n\t</div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t<ng-select\r\n\t\t#ngSelectComponent\r\n\t\t[items]=\"buffer\"\r\n\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t[multiple]=\"multiple\"\r\n\t\t[searchable]=\"searchable\"\r\n\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t[loading]=\"loading\"\r\n\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t[disabled]=\"disabled\"\r\n\t\t[typeahead]=\"userNameInput$\"\r\n\t\t[compareWith]=\"compareFn\"\r\n\t\t[(ngModel)]=\"selection\"\r\n\t\t(change)=\"emitSelection($event)\"\r\n\t>\r\n\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n\t\t\t\t</div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\r\n\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t></mat-checkbox>\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div></div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\t</ng-select>\r\n</div>\r\n<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t<ul>\r\n\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t</li>\r\n\t</ul>\r\n</mat-error>\r\n"]}
|
|
359
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-users.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  SimpleChanges,\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 { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  catchError,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  switchMap,\r\n  tap,\r\n} from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { UsersInDepartmentsApiService } from './services/user-api.service';\r\nimport * as _ from 'lodash';\r\nimport { Cacheable } from 'ts-cacheable';\r\n/**\r\n * Users dropdown input integrated with users API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * Users dropdown\r\n * @example\r\n * <cts-dynamic-form-select-users\r\n *     formControlName=\"controlName\"\r\n *     [bindValue]=\"bindToProperty\"\r\n *     [bindLabel]=\"'bindToLabel'\"\r\n *     [searchable]=\"true\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n *     [deptTitle]=\"'all'\"\r\n *   ></cts-dynamic-form-select-users>\r\n */\r\nconst minute = 60000;\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-users',\r\n  templateUrl: './dynamic-form-select-users.component.html',\r\n  styleUrls: ['./dynamic-form-select-users.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectUsersComponent\r\n  implements OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild('ngSelectComponent') ngSelectComponent: NgSelectComponent;\r\n  selectionstrg: string;\r\n  data = [];\r\n  allUsers: boolean;\r\n  userNameInput$ = new Subject<string>();\r\n  /** filter users by department (departmentName | all) */\r\n  @Input() deptTitle: string;\r\n  /** filter users by group name => this will replce dep title */\r\n  @Input() groupName: string;\r\n  /** Field Label */\r\n  @Input() label: string;\r\n  /** Bind value to object property */\r\n  @Input() bindValue;\r\n  /** Bind label to object property */\r\n  @Input() bindLabel;\r\n  @Input() arabicBindLabel;\r\n  /** Placeholder text */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** is dropdown searchable */\r\n  @Input() searchable = false;\r\n  /** should close dropdown on value selection */\r\n  @Input() closeOnSelect = true;\r\n  /** should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n  /** Pre Selected values */\r\n  @Input() preSelectedValues;\r\n  /** flage to use preselected values or not */\r\n  @Input() usePreSelectedValue = false;\r\n  /** is Disabled */\r\n  @Input() disabled = false;\r\n  /** List of usernames that should be exluded  */\r\n  @Input() filter: string[] = [];\r\n\r\n  /** flage to indicate if use full arabic name or not beside fullName  */\r\n  @Input() useArabicName = false;\r\n\r\n  /** event emitted when item is selected */\r\n  @Output() onSelectItems = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n  writedValue: any;\r\n  buffer = [];\r\n  bufferSize = 1000;\r\n  numberOfItemsFromEndBeforeFetchingMore = 10;\r\n  suffix;\r\n\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  isArabic = false;\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  pageIndex: number = 0;\r\n  isNextPageAvailable: boolean;\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 userApiService: UsersInDepartmentsApiService,\r\n    public translate: TranslateService,\r\n    private translation: TranslationService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.multiple) {\r\n      this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n    }\r\n    this.propagateChange(this.selection);\r\n    this.onSelectItems.emit(event);\r\n  }\r\n\r\n  onScrollToEnd() {\r\n    this.fetchMore();\r\n    ++this.pageIndex;\r\n    if (this.isNextPageAvailable && this.allUsers) {\r\n      this.getDepartments(this.pageIndex);\r\n    }\r\n  }\r\n\r\n  private fetchMore() {\r\n    this.loading = true;\r\n    const len = this.buffer.length;\r\n    const more = this.data.slice(len, this.bufferSize + len);\r\n    this.buffer = this.data.concat(more);\r\n    this.loading = false;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.deptTitle && !changes.deptTitle?.firstChange) || (changes.groupName && !changes.groupName?.firstChange)) {\r\n      this.data = [];\r\n      this.buffer = [];\r\n      this.getDepartments();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allUsers = this.deptTitle === 'all' ? true : false;\r\n    this.selection = (this.multiple ? [] : undefined);\r\n    if (this.allUsers) {\r\n      this.loadUsers();\r\n    }\r\n    this.getDepartments();\r\n    this.translation.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n      ar\r\n        ? (this.suffix = 'مستخدم تم إختياره')\r\n        : (this.suffix = 'Users Selected');\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    });\r\n  }\r\n\r\n  getDepartments(page = 0) {\r\n    this.loading = true;\r\n    if (this.groupName) {\r\n      this.userApiService.getUsersUnderCertainGroup(this.groupName).subscribe(data => {\r\n        let newData = this.constructUserArray(\r\n          data.users,\r\n          'properties.username'\r\n        );\r\n        this.data = this.data.concat(newData);\r\n        this.isNextPageAvailable = data.isNextPageAvailable;\r\n        this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n        this.buffer.map((item) => {\r\n          item.isSelected = false;\r\n        });\r\n        this.loading = false;\r\n      })\r\n    } else if (this.deptTitle) {\r\n      if (this.allUsers) {\r\n        this.getAllUsers(page).subscribe((data) => {\r\n          let newData = this.constructUserArray(data.entries, 'id');\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false; // for loading spinner\r\n        });\r\n      } else {\r\n        this.getCtsUsers(this.deptTitle).subscribe((data) => {\r\n          let newData = this.constructUserArray(\r\n            data.users,\r\n            'properties.username'\r\n          );\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false;\r\n        });\r\n      }\r\n    }else{\r\n      this.loading = false;\r\n    }\r\n  }\r\n\r\n  getAllUsers(page = 0): Observable<any> {\r\n    return this.userApiService.getAllUsers({\r\n      currentPageIndex: page,\r\n      pageSize: 100,\r\n    });\r\n  }\r\n\r\n  private loadUsers() {\r\n    this.userNameInput$\r\n      .pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.loading = true)),\r\n        switchMap((term) => {\r\n          if (term && term.length) {\r\n            return this.getUsersSuggestions(term);\r\n          } else {\r\n            return this.getAllUsers();\r\n          }\r\n        })\r\n      )\r\n      .subscribe(\r\n        (data: any) => {\r\n          if (data.entries.length) {\r\n            let newData = this.constructUserArray(data.entries, 'id');\r\n            this.buffer = (newData || []).slice(0, this.bufferSize);\r\n            this.isNextPageAvailable = data.isNextPageAvailable;\r\n            this.loading = false;\r\n          } else {\r\n            this.buffer = [];\r\n            this.loading = false;\r\n          }\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.buffer = [];\r\n        }\r\n      );\r\n  }\r\n\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.writedValue = value;\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.writedValue.length} ${this.suffix}`;\r\n      }\r\n    } else {\r\n      this.writedValue = null;\r\n      this.selection = null;\r\n      this.selectionstrg = null\r\n    }\r\n  }\r\n\r\n  compareFn(item, selected) {\r\n    console.log(\"item 1\", item);\r\n    console.log(\"Item 2\", selected);\r\n    return item.id === selected.id;\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\r\n  // @Cacheable({\r\n  //   maxCacheCount: 1000,\r\n  //   maxAge: 20000,\r\n  // })\r\n\r\n  getCtsUsers(deptTitle): Observable<any> {\r\n    return this.userApiService.getCtsUsers(deptTitle);\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    maxAge: 5 * minute,\r\n  })\r\n  getUsersSuggestions(term): Observable<any> {\r\n    return this.userApiService.getUsersSuggestions(term);\r\n  }\r\n\r\n  private constructUserArray(data, filterValue: string) {\r\n    let ConstructedData: any[];\r\n    // if not using arabic name then construct full name here\r\n    if (!this.useArabicName) {\r\n      ConstructedData = this.insertFUllName(data);\r\n    }\r\n    ConstructedData = this.filterUsers(data, filterValue);\r\n    // Due to not using bindValue, we need to hold the selected value as the full user object, not just the username\r\n    if (this.writedValue) {\r\n      this.handleWrittedValue(ConstructedData);\r\n    }\r\n    return ConstructedData;\r\n  }\r\n\r\n  handleWrittedValue(users: Record<string, any>[]) {\r\n    const userId = (value) => {\r\n      return (typeof (value) === 'string') ? value : value.id;\r\n    }\r\n    this.selection = (this.multiple) ? users.filter(user => this.writedValue.some(value => user.properties.username === userId(value)))\r\n      : users.filter(user => user.properties.username === userId(this.writedValue))[0];\r\n    if (this.selection) {\r\n      this.writedValue = null;\r\n      this.emitSelection(this.selection);\r\n    }\r\n  }\r\n  private insertFUllName(data) {\r\n    return data.map((user) => {\r\n      user.fullName = `${user.properties?.firstName} ${user.properties?.lastName}`;\r\n    });\r\n  }\r\n  private filterUsers(data, path: string) {\r\n    let filterData = data.filter((user) => {\r\n      const includedInFilter =\r\n        this.filter.includes(_.get(user, path)) ||\r\n        _.get(user, path) === 'Administrator';\r\n      return !includedInFilter;\r\n    });\r\n    return filterData;\r\n  }\r\n\r\n  getUsersUnderCertainGroup() {\r\n\r\n  }\r\n  reset() {\r\n    this.ngSelectComponent.handleClearClick();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.userNameInput$.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n\t<div>\r\n\t\t<label class=\"select-label\"\r\n\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t>\r\n\t</div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t<ng-select\r\n\t\t#ngSelectComponent\r\n\t\t[items]=\"buffer\"\r\n\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t[multiple]=\"multiple\"\r\n\t\t[searchable]=\"searchable\"\r\n\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t[loading]=\"loading\"\r\n\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t[disabled]=\"disabled\"\r\n\t\t[typeahead]=\"userNameInput$\"\r\n\t\t[compareWith]=\"compareFn\"\r\n\t\t[(ngModel)]=\"selection\"\r\n\t\t(change)=\"emitSelection($event)\"\r\n\t>\r\n\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n\t\t\t\t</div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\r\n\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t></mat-checkbox>\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div></div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\t</ng-select>\r\n</div>\r\n<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t<ul>\r\n\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t</li>\r\n\t</ul>\r\n</mat-error>\r\n"]}
|
package/esm2015/lib/components/ndf-config-editor/components/info-dialog/info-dialog.component.js
CHANGED
|
@@ -21,7 +21,7 @@ export class InfoDialogComponent extends BaseDialogComponent {
|
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
InfoDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: InfoDialogComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
24
|
-
InfoDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: InfoDialogComponent, selector: "app-info-dialog", usesInheritance: true, ngImport: i0, template: "<ndf-nuxeo-dialog [dialogTitle]=\"dialogData.title | translate\" bodyClass=\"gap-4 p-0\">\r\n\t<ng-template #contentTemplate>\r\n\t\t<div class=\"secondary-tabs flex gap-5 items-center self-stretch doc-tabs\">\r\n\t\t\t<div\r\n\t\t\t\t[class.selected-tab]=\"doc.name === activeDoc\"\r\n\t\t\t\tclass=\"tab-item relative flex py-5 px-3 justify-start items-center gap-2.5 cursor-pointer\"\r\n\t\t\t\t*ngFor=\"let doc of documentations\"\r\n\t\t\t\t(click)=\"activeDoc = doc.name\"\r\n\t\t\t>\r\n\t\t\t\t<h4>{{ doc?.name | translate }}</h4>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<ng-container *ngFor=\"let doc of documentations\">\r\n\t\t\t<markdown class=\"markdown-content\" [src]=\"baseAppUrl + doc.path\" *ngIf=\"doc.name === activeDoc\"> </markdown>\r\n\t\t</ng-container>\r\n\t</ng-template>\r\n\r\n\t<ng-template #actionsTemplate let-dialog=\"dialog\"> </ng-template>\r\n</ndf-nuxeo-dialog>\r\n", styles: ["::ng-deep .markdown-content{direction:var(--markdown-direction, ltr)!important;text-align:start;color:var(--markdonw-text-color, inherit);background:var(--markdonw-background-color, transparent);border:var(--markdonw-border, 0px solid transparent);border-radius:var(--markdonw-border-radius, 0)}::ng-deep .markdown-content code,::ng-deep .markdown-content kbd,::ng-deep .markdown-content samp,::ng-deep .markdown-content pre{font-family:ui-monospace,SFMono-Regular,Consolas,\"Liberation Mono\",Menlo,monospace;font-size:1em}::ng-deep .markdown-content hr{margin-block:1rem}::ng-deep .markdown-content table{border-spacing:0;border-collapse:collapse;display:block;width:max-content;max-width:100%;overflow:auto;font-variant:tabular-nums;margin-block:.5rem}::ng-deep .markdown-content table tr{border-top:1px solid var(--markdonw-table-tr-border-color, #d1d9e0b3)}::ng-deep .markdown-content table th,::ng-deep .markdown-content table td{padding:6px 13px;border:1px solid var(--markdonw-table-border-color, #d1d9e0)}.doc-tabs{position:sticky;top:0;background:var(--markdonw-background-color, #fff)}\n"], components: [{ type: i1.NdfNuxeoDialog, selector: "ndf-nuxeo-dialog", inputs: ["dialogTitle", "subTitle", "panelClass", "bodyClass", "loaderMode"] }, { type: i2.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "emoji", "katex", "katexOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start"], outputs: ["error", "load", "ready"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i4.TranslatePipe } });
|
|
24
|
+
InfoDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: InfoDialogComponent, selector: "app-info-dialog", usesInheritance: true, ngImport: i0, template: "<ndf-nuxeo-dialog [dialogTitle]=\"dialogData.title | translate\" bodyClass=\"gap-4 p-0\">\r\n\t<ng-template #contentTemplate>\r\n\t\t<div class=\"secondary-tabs flex gap-5 items-center self-stretch doc-tabs\">\r\n\t\t\t<div\r\n\t\t\t\t[class.selected-tab]=\"doc.name === activeDoc\"\r\n\t\t\t\tclass=\"tab-item relative flex py-5 px-3 justify-start items-center gap-2.5 cursor-pointer\"\r\n\t\t\t\t*ngFor=\"let doc of documentations\"\r\n\t\t\t\t(click)=\"activeDoc = doc.name\"\r\n\t\t\t>\r\n\t\t\t\t<h4>{{ doc?.name | translate }}</h4>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<ng-container *ngFor=\"let doc of documentations\">\r\n\t\t\t<markdown class=\"markdown-content\" [src]=\"baseAppUrl + doc.path\" *ngIf=\"doc.name === activeDoc\"> </markdown>\r\n\t\t</ng-container>\r\n\t</ng-template>\r\n\r\n\t<ng-template #actionsTemplate let-dialog=\"dialog\"> </ng-template>\r\n</ndf-nuxeo-dialog>\r\n", styles: ["::ng-deep .markdown-content{direction:var(--markdown-direction, ltr)!important;text-align:start;color:var(--markdonw-text-color, inherit);background:var(--markdonw-background-color, transparent);border:var(--markdonw-border, 0px solid transparent);border-radius:var(--markdonw-border-radius, 0);padding:var(--markdown-padding, 1rem)}::ng-deep .markdown-content em{background-color:transparent}::ng-deep .markdown-content code,::ng-deep .markdown-content kbd,::ng-deep .markdown-content samp,::ng-deep .markdown-content pre{font-family:ui-monospace,SFMono-Regular,Consolas,\"Liberation Mono\",Menlo,monospace;font-size:1em}::ng-deep .markdown-content hr{margin-block:1rem}::ng-deep .markdown-content table{border-spacing:0;border-collapse:collapse;display:block;width:max-content;max-width:100%;overflow:auto;font-variant:tabular-nums;margin-block:.5rem}::ng-deep .markdown-content table tr{border-top:1px solid var(--markdonw-table-tr-border-color, #d1d9e0b3)}::ng-deep .markdown-content table th,::ng-deep .markdown-content table td{padding:6px 13px;border:1px solid var(--markdonw-table-border-color, #d1d9e0)}.doc-tabs{position:sticky;top:0;background:var(--markdonw-tabs-background-color, #fff)}\n"], components: [{ type: i1.NdfNuxeoDialog, selector: "ndf-nuxeo-dialog", inputs: ["dialogTitle", "subTitle", "panelClass", "bodyClass", "loaderMode"] }, { type: i2.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "emoji", "katex", "katexOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start"], outputs: ["error", "load", "ready"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i4.TranslatePipe } });
|
|
25
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: InfoDialogComponent, decorators: [{
|
|
26
26
|
type: Component,
|
|
27
27
|
args: [{
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWRhdGEtc291cmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9yZXBvcnRzL25kZi1yZXBvcnRzL21vZGVscy9yZXBvcnQtZGF0YS1zb3VyY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBSZXByZXNlbnRzIGEgZGF0YSBzb3VyY2UgZm9yIGEgcmVwb3J0LlxyXG4gKiBAdHlwZWRlZiB7T2JqZWN0fSBSZXBvcnREYXRhU291cmNlXHJcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBwcm9wZXJ0eVBhdGggLSBUaGUgcGF0aCB0byB0aGUgcHJvcGVydHkgaW4gdGhlIGRhdGEgc291cmNlLlxyXG4gKiBAcHJvcGVydHkge09iamVjdH0gW2JpbmRMYWJlbF0gLSBPcHRpb25hbCBsYWJlbCB0byBiaW5kLlxyXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2JpbmRWYWx1ZV0gLSBPcHRpb25hbCB2YWx1ZSB0byBiaW5kLlxyXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2RhdGFGb3JtYXRdIC0gT3B0aW9uYWwgZm9ybWF0IGZvciB0aGUgZGF0YS5cclxuICogQHByb3BlcnR5IHtzdHJpbmd9IFt0cmFuc2Zvcm1lcl0gLSBPcHRpb25hbCB0cmFuc2Zvcm1lciB0byBhcHBseSB0byB0aGUgZGF0YS5cclxuICovXHJcbmV4cG9ydCB0eXBlIFJlcG9ydERhdGFTb3VyY2UgPSB7XHJcblx0cHJvcGVydHlQYXRoOiBzdHJpbmc7XHJcblx0YmluZExhYmVsPzogeyBhcjogc3RyaW5nOyBlbjogc3RyaW5nIH07XHJcblx0YmluZFZhbHVlPzogc3RyaW5nO1xyXG5cdGRhdGFGb3JtYXQ/OiBzdHJpbmc7XHJcblx0dHJhbnNmb3JtZXI/OiBzdHJpbmc7XHJcbn07XHJcbiJdfQ==
|
|
@@ -60,7 +60,9 @@ export class BaseChartBuilderService {
|
|
|
60
60
|
if ((config === null || config === void 0 ? void 0 : config.dataFormat) && ((_a = item === null || item === void 0 ? void 0 : item.localized) === null || _a === void 0 ? void 0 : _a[currentLang])) {
|
|
61
61
|
return item.localized[currentLang];
|
|
62
62
|
}
|
|
63
|
-
const label =
|
|
63
|
+
const label = config.bindLabel
|
|
64
|
+
? _.get(item, config === null || config === void 0 ? void 0 : config.bindLabel[this._translateService.currentLang])
|
|
65
|
+
: null;
|
|
64
66
|
return label || this._translateService.instant(`${this._translatePrefix}${item.key}`);
|
|
65
67
|
}
|
|
66
68
|
_getValue(item, source) {
|
|
@@ -100,4 +102,4 @@ BaseChartBuilderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.
|
|
|
100
102
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseChartBuilderService, decorators: [{
|
|
101
103
|
type: Injectable
|
|
102
104
|
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.ChartDataTransformers }]; } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-chart-builder.service.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/reports/ndf-reports/services/base-chart-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { forkJoin, Observable, of } from 'rxjs';\r\nimport _ from 'lodash';\r\nimport { catchError, map, switchMap } from 'rxjs/operators';\r\nimport { ChartDataset, ChartType } from 'chart.js';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Injectable } from '@angular/core';\r\n\r\nimport {\r\n\tCriteriaModel,\r\n\tDynamicLineChart,\r\n\tDynamicLineChartOptions,\r\n\tGraphChart,\r\n\tGraphChartOptions,\r\n\tReportDataSource,\r\n\tReportResponseModel\r\n} from '../models';\r\nimport { StatisticBucket } from '../../charts';\r\nimport { getCssVariable } from '../../charts/utility';\r\nimport { ChartDataTransformers } from './chart-data-transformers.service';\r\n\r\n@Injectable()\r\nexport class BaseChartBuilderService<TConfig extends DynamicLineChart | GraphChart = GraphChart> {\r\n\tprotected _translatePrefix: string = '';\r\n\r\n\tconstructor(\r\n\t\tprotected readonly _translateService: TranslateService,\r\n\t\tprivate readonly _dataTransformers: ChartDataTransformers\r\n\t) {}\r\n\r\n\tprepareChart(\r\n\t\tresponse: ReportResponseModel,\r\n\t\tconfig: TConfig,\r\n\t\tfilterCriteria?: CriteriaModel\r\n\t): Observable<{ data: any; config: GraphChartOptions | DynamicLineChartOptions }> {\r\n\t\tthis._translatePrefix = config?.prefix ?? '';\r\n\t\tif (!config.datasource) {\r\n\t\t\tconsole.warn('No datasource provided for chart configuration');\r\n\t\t\treturn of({\r\n\t\t\t\tdata: null,\r\n\t\t\t\tconfig: null\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\treturn of(config.datasource).pipe(\r\n\t\t\tswitchMap((sources) => {\r\n\t\t\t\tconst observables$ = sources.map((src) => this._prepareDataSource(src, response, filterCriteria));\r\n\r\n\t\t\t\treturn forkJoin(observables$).pipe(\r\n\t\t\t\t\tmap((results) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tdata: this._prepareChartData(results, config),\r\n\t\t\t\t\t\t\tconfig: config.chart\r\n\t\t\t\t\t\t};\r\n\t\t\t\t\t}),\r\n\t\t\t\t\tcatchError((error) => {\r\n\t\t\t\t\t\tconsole.error('Error processing chart data:', error);\r\n\t\t\t\t\t\treturn of({\r\n\t\t\t\t\t\t\tdata: null,\r\n\t\t\t\t\t\t\tconfig: null\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t})\r\n\t\t\t\t);\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tprotected _prepareDataSource(\r\n\t\tsourceConfig: ReportDataSource,\r\n\t\tresponse: ReportResponseModel,\r\n\t\tfilterCriteria?: CriteriaModel\r\n\t): Observable<any> {\r\n\t\tconst buckets = (_.get(response, sourceConfig.propertyPath) as StatisticBucket[]) || [];\r\n\t\treturn of(buckets).pipe(\r\n\t\t\tmap((rawData) => {\r\n\t\t\t\tif (this._dataTransformers.hasGraphTransformer(sourceConfig?.transformer)) {\r\n\t\t\t\t\tconst transformer = this._dataTransformers.getGraphTransformer(sourceConfig?.transformer);\r\n\t\t\t\t\tconst adaptedData = transformer(rawData, response, filterCriteria, this._translateService.currentLang);\r\n\t\t\t\t\tif (adaptedData) {\r\n\t\t\t\t\t\treturn adaptedData.map((row) => ({\r\n\t\t\t\t\t\t\t...row,\r\n\t\t\t\t\t\t\tkey: this._getLabel(row, sourceConfig)\r\n\t\t\t\t\t\t}));\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\treturn rawData.map((row) => ({\r\n\t\t\t\t\tkey: this._getLabel(row, sourceConfig),\r\n\t\t\t\t\tdocCount: this._getValue(row, sourceConfig)\r\n\t\t\t\t}));\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tprotected _getLabel(item: StatisticBucket, config: ReportDataSource): string {\r\n\t\tconst currentLang = this._translateService.currentLang;\r\n\t\tif (config?.dataFormat && item?.localized?.[currentLang]) {\r\n\t\t\treturn item.localized[currentLang];\r\n\t\t}\r\n\t\tconst label = config?.bindLabel ? _.get(item, config.bindLabel) : null;\r\n\t\treturn label || this._translateService.instant(`${this._translatePrefix}${item.key}`);\r\n\t}\r\n\r\n\tprotected _getValue(item: StatisticBucket, source: ReportDataSource): number {\r\n\t\treturn _.get(item, source?.bindValue, item.docCount);\r\n\t}\r\n\r\n\tprotected _prepareChartData(results: StatisticBucket[][], config: TConfig) {\r\n\t\tconst { chart } = config;\r\n\t\tconst _labels = new Set<string>();\r\n\t\tconst _datasets = results.map((bucket: StatisticBucket[], index: number) => {\r\n\t\t\tconst data = bucket.map((item) => {\r\n\t\t\t\t_labels.add(item.key);\r\n\t\t\t\treturn item.docCount;\r\n\t\t\t});\r\n\t\t\tconst dataSet: ChartDataset<ChartType> = {\r\n\t\t\t\tborderWidth: 1,\r\n\t\t\t\tborderColor: getCssVariable('--chart-dataset-border-color', `rgba(0, 0, 0, 0.1)`) as string,\r\n\t\t\t\tdata: !!data?.length ? data : [0]\r\n\t\t\t};\r\n\r\n\t\t\tif (config.chart?.colors) {\r\n\t\t\t\tdataSet.backgroundColor = config.chart?.colors;\r\n\t\t\t}\r\n\r\n\t\t\tconst overrides = chart?.datasets?.[index];\r\n\t\t\tif (overrides && typeof overrides === 'object') {\r\n\t\t\t\treturn Object.assign({}, dataSet, {\r\n\t\t\t\t\t...overrides,\r\n\t\t\t\t\tlabel: overrides?.label ? this._translateService.instant(overrides?.label) : ''\r\n\t\t\t\t});\r\n\t\t\t}\r\n\r\n\t\t\treturn dataSet;\r\n\t\t});\r\n\t\treturn {\r\n\t\t\tlabels: Array.from(_labels.values()),\r\n\t\t\tdatasets: _datasets\r\n\t\t};\r\n\t}\r\n}\r\n"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-chart-builder.service.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/reports/ndf-reports/services/base-chart-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { forkJoin, Observable, of } from 'rxjs';\r\nimport _ from 'lodash';\r\nimport { catchError, map, switchMap } from 'rxjs/operators';\r\nimport { ChartDataset, ChartType } from 'chart.js';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Injectable } from '@angular/core';\r\n\r\nimport {\r\n\tCriteriaModel,\r\n\tDynamicLineChart,\r\n\tDynamicLineChartOptions,\r\n\tGraphChart,\r\n\tGraphChartOptions,\r\n\tReportDataSource,\r\n\tReportResponseModel\r\n} from '../models';\r\nimport { StatisticBucket } from '../../charts';\r\nimport { getCssVariable } from '../../charts/utility';\r\nimport { ChartDataTransformers } from './chart-data-transformers.service';\r\n\r\n@Injectable()\r\nexport class BaseChartBuilderService<TConfig extends DynamicLineChart | GraphChart = GraphChart> {\r\n\tprotected _translatePrefix: string = '';\r\n\r\n\tconstructor(\r\n\t\tprotected readonly _translateService: TranslateService,\r\n\t\tprivate readonly _dataTransformers: ChartDataTransformers\r\n\t) {}\r\n\r\n\tprepareChart(\r\n\t\tresponse: ReportResponseModel,\r\n\t\tconfig: TConfig,\r\n\t\tfilterCriteria?: CriteriaModel\r\n\t): Observable<{ data: any; config: GraphChartOptions | DynamicLineChartOptions }> {\r\n\t\tthis._translatePrefix = config?.prefix ?? '';\r\n\t\tif (!config.datasource) {\r\n\t\t\tconsole.warn('No datasource provided for chart configuration');\r\n\t\t\treturn of({\r\n\t\t\t\tdata: null,\r\n\t\t\t\tconfig: null\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\treturn of(config.datasource).pipe(\r\n\t\t\tswitchMap((sources) => {\r\n\t\t\t\tconst observables$ = sources.map((src) => this._prepareDataSource(src, response, filterCriteria));\r\n\r\n\t\t\t\treturn forkJoin(observables$).pipe(\r\n\t\t\t\t\tmap((results) => {\r\n\t\t\t\t\t\treturn {\r\n\t\t\t\t\t\t\tdata: this._prepareChartData(results, config),\r\n\t\t\t\t\t\t\tconfig: config.chart\r\n\t\t\t\t\t\t};\r\n\t\t\t\t\t}),\r\n\t\t\t\t\tcatchError((error) => {\r\n\t\t\t\t\t\tconsole.error('Error processing chart data:', error);\r\n\t\t\t\t\t\treturn of({\r\n\t\t\t\t\t\t\tdata: null,\r\n\t\t\t\t\t\t\tconfig: null\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t})\r\n\t\t\t\t);\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tprotected _prepareDataSource(\r\n\t\tsourceConfig: ReportDataSource,\r\n\t\tresponse: ReportResponseModel,\r\n\t\tfilterCriteria?: CriteriaModel\r\n\t): Observable<any> {\r\n\t\tconst buckets = (_.get(response, sourceConfig.propertyPath) as StatisticBucket[]) || [];\r\n\t\treturn of(buckets).pipe(\r\n\t\t\tmap((rawData) => {\r\n\t\t\t\tif (this._dataTransformers.hasGraphTransformer(sourceConfig?.transformer)) {\r\n\t\t\t\t\tconst transformer = this._dataTransformers.getGraphTransformer(sourceConfig?.transformer);\r\n\t\t\t\t\tconst adaptedData = transformer(rawData, response, filterCriteria, this._translateService.currentLang);\r\n\t\t\t\t\tif (adaptedData) {\r\n\t\t\t\t\t\treturn adaptedData.map((row) => ({\r\n\t\t\t\t\t\t\t...row,\r\n\t\t\t\t\t\t\tkey: this._getLabel(row, sourceConfig)\r\n\t\t\t\t\t\t}));\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\treturn rawData.map((row) => ({\r\n\t\t\t\t\tkey: this._getLabel(row, sourceConfig),\r\n\t\t\t\t\tdocCount: this._getValue(row, sourceConfig)\r\n\t\t\t\t}));\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tprotected _getLabel(item: StatisticBucket, config: ReportDataSource): string {\r\n\t\tconst currentLang = this._translateService.currentLang;\r\n\t\tif (config?.dataFormat && item?.localized?.[currentLang]) {\r\n\t\t\treturn item.localized[currentLang];\r\n\t\t}\r\n\t\tconst label = config.bindLabel\r\n\t\t\t?  _.get(item, config?.bindLabel[this._translateService.currentLang])\r\n\t\t\t: null\r\n\t\treturn label || this._translateService.instant(`${this._translatePrefix}${item.key}`);\r\n\t}\r\n\r\n\r\n\tprotected _getValue(item: StatisticBucket, source: ReportDataSource): number {\r\n\t\treturn _.get(item, source?.bindValue, item.docCount);\r\n\t}\r\n\r\n\tprotected _prepareChartData(results: StatisticBucket[][], config: TConfig) {\r\n\t\tconst { chart } = config;\r\n\t\tconst _labels = new Set<string>();\r\n\t\tconst _datasets = results.map((bucket: StatisticBucket[], index: number) => {\r\n\t\t\tconst data = bucket.map((item) => {\r\n\t\t\t\t_labels.add(item.key);\r\n\t\t\t\treturn item.docCount;\r\n\t\t\t});\r\n\t\t\tconst dataSet: ChartDataset<ChartType> = {\r\n\t\t\t\tborderWidth: 1,\r\n\t\t\t\tborderColor: getCssVariable('--chart-dataset-border-color', `rgba(0, 0, 0, 0.1)`) as string,\r\n\t\t\t\tdata: !!data?.length ? data : [0]\r\n\t\t\t};\r\n\r\n\t\t\tif (config.chart?.colors) {\r\n\t\t\t\tdataSet.backgroundColor = config.chart?.colors;\r\n\t\t\t}\r\n\r\n\t\t\tconst overrides = chart?.datasets?.[index];\r\n\t\t\tif (overrides && typeof overrides === 'object') {\r\n\t\t\t\treturn Object.assign({}, dataSet, {\r\n\t\t\t\t\t...overrides,\r\n\t\t\t\t\tlabel: overrides?.label ? this._translateService.instant(overrides?.label) : ''\r\n\t\t\t\t});\r\n\t\t\t}\r\n\r\n\t\t\treturn dataSet;\r\n\t\t});\r\n\t\treturn {\r\n\t\t\tlabels: Array.from(_labels.values()),\r\n\t\t\tdatasets: _datasets\r\n\t\t};\r\n\t}\r\n}\r\n"]}
|
package/esm2015/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.js
CHANGED
|
@@ -83,7 +83,7 @@ export class DynamicTableComponent {
|
|
|
83
83
|
this.fullWidth = 'auto';
|
|
84
84
|
/** 'list' for noraml table 'card' for cards mode like in memos */
|
|
85
85
|
this.tableMode = 'list';
|
|
86
|
-
this.defultSort =
|
|
86
|
+
this.defultSort = { name: 'properties.createdAt', dir: 'desc' };
|
|
87
87
|
this.isSearchPage = false;
|
|
88
88
|
/** allow multiselect rows with checkbox */
|
|
89
89
|
this.multiSelectRows = false;
|
|
@@ -374,4 +374,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
374
374
|
}], pageSizes: [{
|
|
375
375
|
type: Input
|
|
376
376
|
}] } });
|
|
377
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tContentChild,\r\n\tEventEmitter,\r\n\tInput,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tOutput,\r\n\tSimpleChanges,\r\n\tTemplateRef,\r\n\tViewEncapsulation\r\n} from '@angular/core';\r\nimport _ from 'lodash';\r\nimport { Subscription } from 'rxjs';\r\nimport { catchError, map, startWith } from 'rxjs/operators';\r\nimport { AdapterService } from '../../../../core/adapters/adapter.service';\r\nimport { CallApiService } from '../../../../core/services/callApi/call-api.service';\r\nimport { EMPTY_TEMPLATE } from '../directives/empty-state.directive';\r\nimport { DynamicTableService } from '../services/dynamic-table.service';\r\nimport { PageEvent } from '@angular/material/paginator/paginator';\r\nimport { EvaluatedString, Evaluator } from '../../../../shared';\r\n\r\n/**\r\n * this component is an additional layer that uses [Table Component]{@link TableComponent} internally,\r\n * you can use this component to configure a page provider listing out of the box easily,\r\n * and it will handle all of the basic features such as getting data from API, Listing, Pagination, sorting and filtering\r\n * ![Screenshot-1](../screenshots/dynamicTable.png)\r\n * @title\r\n * Dynamic Table\r\n * @example\r\n *\r\n * <cts-dynamic-table\r\n *    [columns]=\"columns\"\r\n *    [responsiveColumns]=\"responsiveColumns\"\r\n *    [fullWidth]=\"fullWidth\"\r\n *    [pageSize]=\"PageSize\"\r\n *    [pageProvider]=\"pageProvider\"\r\n *    [quickFilter]=\"filter\"\r\n *    [sortingBy]=\"sortingBy\"\r\n *    [entityType]=\"'all'\"\r\n *    [fields]=\"fields\"\r\n *    [prefix]=\"prefix\"\r\n *    [rowCursor]=\"true\"\r\n *    [queryParam]=\"queryParam\"\r\n *    [headers]=\"headers\"\r\n *    (onRowSelected)=\"openViewer($event)\"\r\n *    (actionOnRow)=\"performAction($event)\">\r\n * </cts-dynamic-table>\r\n */\r\n@Component({\r\n\tselector: 'cts-dynamic-table',\r\n\ttemplateUrl: './dynamic-table.component.html',\r\n\tstyleUrls: ['./dynamic-table.component.scss'],\r\n\tencapsulation: ViewEncapsulation.None,\r\n\thost: {\r\n\t\t'[class.loading-results]': 'loading',\r\n\t\t'[class.no-data]': 'rows.length <= 0'\r\n\t}\r\n})\r\nexport class DynamicTableComponent implements OnInit, OnDestroy {\r\n\t/** event to emit when selecting single row  */\r\n\t@Output() onRowSelected = new EventEmitter();\r\n\t/** event to emit when selecting single row to catch index*/\r\n\t@Output() onRowIndexSelected = new EventEmitter();\r\n\t/** event to emit when perform action on row (delte, edit, ... ) */\r\n\t@Output() actionOnRow = new EventEmitter();\r\n\t/** event to emit to the higher level  when getting data from api is finished */\r\n\t@Output() onGettingData = new EventEmitter();\r\n\t/** event t emit when selecting multiple row */\r\n\t@Output() onMultiRowSelected = new EventEmitter();\r\n\t/** event t emit when start getting data and when finish */\r\n\t@Output() onLoading = new EventEmitter();\r\n\r\n\t@Output() sortChanged = new EventEmitter<{ sortBy: string; sortOrder: string }>();\r\n\t/**\r\n\t * @deprecated Use `onPage` instead.\r\n\t * @see onPage\r\n\t */\r\n\t@Output() onPageChange = new EventEmitter();\r\n\r\n\t@Output() onPage = new EventEmitter<PageEvent>();\r\n\r\n\t@Output() onLoad = new EventEmitter();\r\n\t@Output() onInitialize = new EventEmitter();\r\n\t/** Array of columns */\r\n\t@Input() columns;\r\n\t/** Array of columns on smaller screens */\r\n\t@Input() responsiveColumns?;\r\n\t/** Defines the page in which table is being used */\r\n\t@Input() entityType: string;\r\n\t/** Translations prefix */\r\n\t@Input() prefix = '';\r\n\t/** Headers to be sent with API Request */\r\n\t@Input() headers;\r\n\t/** Fields keymap to be mapped in the adapter */\r\n\t@Input() fields;\r\n\t/** Page Provider name that will be used to retrieve data */\r\n\t@Input() pageProvider;\r\n\t/** Controls number of items per page in table */\r\n\t@Input() pageSize = 10;\r\n\r\n\t@Input() isLegacyMode = true;\r\n\t@Input() showTotalRecord = false;\r\n\r\n\t@ContentChild(EMPTY_TEMPLATE, { read: TemplateRef, static: true })\r\n\temptyTemplate: TemplateRef<any> | undefined;\r\n\r\n\tprivate _pageNumber = 1;\r\n\t@Input() set pageNumber(value: string | number) {\r\n\t\tthis._pageNumber = isNaN(+value) ? 1 : +value;\r\n\t}\r\n\r\n\tget pageNum() {\r\n\t\treturn this._pageNumber;\r\n\t}\r\n\r\n\t/** Sorting column */\r\n\t@Input() sortingBy: {\r\n\t\tsortBy?: string;\r\n\t\tsortOrder?: string;\r\n\t} = {};\r\n\t@Input() queryParam? = {};\r\n\r\n\t@Input() customFilters: {\r\n\t\tparams?: Record<string, any>;\r\n\t\tpayload?: Record<string, any>;\r\n\t} = {};\r\n\r\n\t@Input() quickFilter?;\r\n\t/** Controls if it report page */\r\n\t@Input() report;\r\n\t/** to make cursor when hover on row or not */\r\n\t@Input() rowCursor?;\r\n\t@Input() fullWidth? = 'auto';\r\n\t/** 'list' for noraml table 'card' for cards mode like in memos */\r\n\t@Input() tableMode = 'list';\r\n\r\n\t@Input() componentName: string;\r\n\t/** action to be used in case of card mode */\r\n\t@Input() tableActions;\r\n\t@Input() defultSort: any = [{ prop: 'properties.createdAt', dir: 'desc' }];\r\n\t@Input() range;\r\n\t@Input() isSearchPage = false;\r\n\t/** allow multiselect rows with checkbox */\r\n\t@Input() multiSelectRows = false;\r\n\t/** to show 1st row with custom template in the table*/\r\n\t@Input() customFirstRow = false;\r\n\t@Input() highlightSelectedCard = false;\r\n\t@Input() showActionsAsMenu = false; // flage to show action in menu or side by side\r\n\t@Input()\r\n\tfilterParams = {};\r\n\r\n\t@Input() skipAggregation: 'never' | 'onPageChange' = 'onPageChange';\r\n\t@Input() customUrl: { url: string; method: 'POST' | 'GET' };\r\n\t@Input() format = 'MMMM d, y';\r\n\r\n\t@Input() requestActions?: {\r\n\t\tbeforeSubmit?: EvaluatedString<'payload'>;\r\n\t};\r\n\r\n\trows = [];\r\n\ttotalRecords = 0;\r\n\tmyDataSubscription: Subscription;\r\n\tloading;\r\n\tsorting = false;\r\n\t@Input() pageSizes: Array<{ label: string; size: number }> = [];\r\n\r\n\tinitialized = false;\r\n\r\n\tconstructor(\r\n\t\tprivate adapter: AdapterService,\r\n\t\tprivate callApi: CallApiService,\r\n\t\tprivate dynamicTableService: DynamicTableService,\r\n\t\tprivate cdr: ChangeDetectorRef\r\n\t) {}\r\n\r\n\tngOnInit(): void {\r\n\t\tthis.myDataSubscription = this.dynamicTableService.refreshData.pipe(startWith(null)).subscribe((filterData) => {\r\n\t\t\tif (filterData) {\r\n\t\t\t\tthis.filterParams = { ...filterData };\r\n\t\t\t\t// reset page number when start new filtering\r\n\t\t\t\tthis._resetPageNumber();\r\n\t\t\t}\r\n\t\t\tthis.getData();\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.myDataSubscription ? this.myDataSubscription.unsubscribe() : '';\r\n\t}\r\n\r\n\tngOnChanges(changes: SimpleChanges) {\r\n\t\tconst isFirstChange = Object.values(changes).some((c) => c.isFirstChange());\r\n\t\tif (isFirstChange) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst hasChanged = (items: string[]) =>\r\n\t\t\titems.some((key) => {\r\n\t\t\t\tconst isEqual = _.isEqual(changes[key]?.previousValue || null, changes[key]?.currentValue || null);\r\n\t\t\t\treturn !isEqual;\r\n\t\t\t});\r\n\r\n\t\tif (hasChanged(['queryParam', 'quickFilter', 'customFilters'])) {\r\n\t\t\tif (this.initialized) {\r\n\t\t\t\tthis._resetPageNumber(); // Reset page number before recalling API with filters\r\n\t\t\t}\r\n\t\t\tthis.getData();\r\n\t\t}\r\n\r\n\t\tif (hasChanged(['sortingBy'])) {\r\n\t\t\tthis.getData();\r\n\t\t}\r\n\t}\r\n\r\n\tprivate _resetPageNumber() {\r\n\t\tthis._pageNumber = 1;\r\n\t\tthis.onPageChange.emit(this._pageNumber);\r\n\t\tthis.onPage.emit({\r\n\t\t\tpageIndex: this._pageNumber,\r\n\t\t\tpageSize: this.pageSize,\r\n\t\t\tlength: this.totalRecords\r\n\t\t});\r\n\t}\r\n\r\n\tgetData(payload: Record<string, any> = {}, headers: Record<string, any> = {}) {\r\n\t\tthis.loading = true; // internal loading\r\n\t\tthis.onLoading.emit(true); // external loading\r\n\t\tlet params = {\r\n\t\t\t...(this.range ? { dublincore_created_agg: this.range } : {}),\r\n\t\t\t...this.filterParams, // used to get filter data and set it in our params\r\n\t\t\t...this.queryParam, // used to get params from our config\r\n\t\t\t...this.quickFilter,\r\n\t\t\t...(Object.keys(this.sortingBy || {}).length\r\n\t\t\t\t? {\r\n\t\t\t\t\t\tsortBy: this.sortingBy?.sortBy,\r\n\t\t\t\t\t\tsortOrder: this.sortingBy?.sortOrder\r\n\t\t\t\t\t}\r\n\t\t\t\t: {}),\r\n\t\t\tcurrentPageIndex: +this.pageNum - 1,\r\n\t\t\t...(this.pageSize ? { pageSize: this.pageSize } : {}),\r\n\t\t\toffset: 0,\r\n\t\t\t...payload\r\n\t\t};\r\n\r\n\t\t// don't refresh all table in case of sorting only\r\n\t\tif (!this.sorting && this.isLegacyMode) {\r\n\t\t\t// used to not refreshing all table in case of sorting since table lose sorting state when refresh all table\r\n\t\t\tthis.rows = []; // used to refresh table to feel changes in actions when perform action and need to refresh actions\r\n\t\t}\r\n\t\tthis.sorting = false; // reset sorting status to false and for next sorting func sorting set it to true again\r\n\r\n\t\tconst _headers = {\r\n\t\t\t...this.headers,\r\n\t\t\t...headers\r\n\t\t};\r\n\r\n\t\tlet _providerPayload = {\r\n\t\t\tquery: {\r\n\t\t\t\tpageProvider: this.pageProvider,\r\n\t\t\t\t...params\r\n\t\t\t},\r\n\t\t\toptions: {\r\n\t\t\t\theaders: _headers\r\n\t\t\t}\r\n\t\t};\r\n\r\n\t\tlet _customPayload = {\r\n\t\t\tparams: {\r\n\t\t\t\t...params,\r\n\t\t\t\t...(this.customFilters?.params || {})\r\n\t\t\t},\r\n\t\t\theaders: _headers,\r\n\t\t\tpayload: this.customFilters?.payload || {}\r\n\t\t};\r\n\r\n\t\tif (this.requestActions?.beforeSubmit && typeof this.requestActions?.beforeSubmit === 'string') {\r\n\t\t\ttry {\r\n\t\t\t\tif (this.customUrl) {\r\n\t\t\t\t\t_customPayload = Evaluator.evaluate(\r\n\t\t\t\t\t\tthis.requestActions?.beforeSubmit,\r\n\t\t\t\t\t\t{ criteria: _customPayload },\r\n\t\t\t\t\t\t'payload'\r\n\t\t\t\t\t);\r\n\t\t\t\t} else {\r\n\t\t\t\t\t_providerPayload = Evaluator.evaluate(\r\n\t\t\t\t\t\tthis.requestActions?.beforeSubmit,\r\n\t\t\t\t\t\t{ criteria: _providerPayload },\r\n\t\t\t\t\t\t'payload'\r\n\t\t\t\t\t);\r\n\t\t\t\t}\r\n\t\t\t} catch (e) {\r\n\t\t\t\tconsole.error(e);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tconst query$ = this.customUrl\r\n\t\t\t? this.callApi.customQuery(this.customUrl, _customPayload.params, _customPayload.headers, _customPayload.payload)\r\n\t\t\t: this.callApi.query(_providerPayload.query, _providerPayload.options);\r\n\r\n\t\tquery$\r\n\t\t\t.pipe(\r\n\t\t\t\tmap((data: any) => {\r\n\t\t\t\t\tdata.entries.map((item) => this.adapter.adaptIn(item, this.fields));\r\n\t\t\t\t\treturn data;\r\n\t\t\t\t}),\r\n\t\t\t\tcatchError((err) => {\r\n\t\t\t\t\tthrow err;\r\n\t\t\t\t})\r\n\t\t\t)\r\n\t\t\t.subscribe((res) => {\r\n\t\t\t\tthis.loading = false;\r\n\t\t\t\tthis.onLoading.emit(false);\r\n\t\t\t\tthis.onLoad.emit(res);\r\n\t\t\t\tif (!this.initialized) {\r\n\t\t\t\t\tthis.onInitialize.emit(res);\r\n\t\t\t\t\tthis.initialized = true;\r\n\t\t\t\t}\r\n\t\t\t\tres.entries.forEach((element) => {\r\n\t\t\t\t\tif (element.properties && element.properties?.creator && element.properties.creator?.properties) {\r\n\t\t\t\t\t\telement.properties['creatorFullObject'] = { ...element.properties.creator };\r\n\t\t\t\t\t\telement.properties.creator =\r\n\t\t\t\t\t\t\telement.properties.creator?.properties?.firstName +\r\n\t\t\t\t\t\t\t' ' +\r\n\t\t\t\t\t\t\telement.properties.creator?.properties?.lastName;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (element.properties && element.properties?.assignee) {\r\n\t\t\t\t\t\telement.properties.assignee = element.properties?.assignee.fullName;\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t\tthis.totalRecords = res.resultsCount;\r\n\t\t\t\tthis.rows = res.entries;\r\n\t\t\t\tthis.cdr.detectChanges();\r\n\t\t\t\t// emit data to outside in case of search page for the first time only to prevent refreshing aggregation with every page change\r\n\t\t\t\t// and for any other page type emit data directly in all page numbers\r\n\t\t\t\tif ((this.isSearchPage && this.pageNum === 1) || !this.isSearchPage) this.onGettingData.emit(res);\r\n\t\t\t});\r\n\t}\r\n\r\n\t// function to be executed when clicking on single row\r\n\trowDetails(event) {\r\n\t\tthis.onRowSelected.emit(event);\r\n\t}\r\n\r\n\tindexDetails(event) {\r\n\t\tthis.onRowIndexSelected.emit(event);\r\n\t}\r\n\r\n\t//function to handle all operations on single row (delete , edit , ...)\r\n\tperformAction(action) {\r\n\t\tthis.actionOnRow.emit(action);\r\n\t}\r\n\r\n\t// handle sorting functionality of the table\r\n\tonSort(sortObject) {\r\n\t\tthis.sortChanged.emit(sortObject);\r\n\t\tthis.sortingBy = sortObject;\r\n\t\tthis.sorting = true;\r\n\t\tthis.getData({}, this.skipAggregation === 'onPageChange' ? { skipAggregates: 'true' } : {});\r\n\t}\r\n\r\n\tonMultiRowSelectValue(event) {\r\n\t\tthis.onMultiRowSelected.emit(event);\r\n\t}\r\n\r\n\tpublic paginationChange(event) {\r\n\t\tthis._pageNumber = event;\r\n\t\tthis.onPageChange.emit(event);\r\n\t\tthis.onPage.emit({\r\n\t\t\tpageIndex: this._pageNumber,\r\n\t\t\tpageSize: this.pageSize,\r\n\t\t\tlength: this.totalRecords\r\n\t\t});\r\n\t\tthis.getData({}, this.skipAggregation === 'onPageChange' ? { skipAggregates: 'true' } : {});\r\n\t}\r\n\r\n\tonChangePageSize(pageSize: number) {\r\n\t\tthis.pageSize = pageSize;\r\n\t\tthis._resetPageNumber();\r\n\t\tthis.getData({}, this.skipAggregation === 'onPageChange' ? { skipAggregates: 'true' } : {});\r\n\t}\r\n}\r\n","<div class=\"wrapping table-wrapping\">\r\n\t<ng-container *ngIf=\"isLegacyMode\">\r\n\t\t<div class=\"table-reposition\">\r\n\t\t\t<ng-container *ngIf=\"rows.length\" [ngTemplateOutlet]=\"table\"></ng-container>\r\n\t\t</div>\r\n\t\t<ng-container *ngIf=\"loading\">\r\n\t\t\t<cts-spinner></cts-spinner>\r\n\t\t</ng-container>\r\n\t</ng-container>\r\n\r\n\t<div class=\"table-reposition\" *ngIf=\"!isLegacyMode\">\r\n\t\t<ng-container  [ngTemplateOutlet]=\"table\"></ng-container>\r\n\t\t<ng-container\r\n\t\t\t*ngIf=\"!initialized\"\r\n\t\t\t[ngTemplateOutlet]=\"skeleton\"\r\n\t\t\t[ngTemplateOutletContext]=\"{ $implicit: 10 }\"\r\n\t\t></ng-container>\r\n\t</div>\r\n\r\n\t<div\r\n\t\tclass=\"pagination-iner-wraper my-3\"\r\n\t\t[ngClass]=\"{ relative: pageSizes?.length }\"\r\n\t\t*ngIf=\"rows.length \"\r\n\t>\r\n\t\t<cts-pagination\r\n      *ngIf=\"totalRecords > pageSize\"\r\n\t\t\t[page]=\"pageNum\"\r\n\t\t\t(change)=\"paginationChange($event)\"\r\n\t\t\t[size]=\"pageSize\"\r\n\t\t\t[count]=\"totalRecords\"\r\n\t\t></cts-pagination>\r\n\t\t<div class=\"absolute ndfPageSizes flex gap-x-3 items-center mt-2\">\r\n\t\t\t<ndf-page-sizes-list\r\n\t\t\t\t*ngIf=\"pageSizes?.length\"\r\n\t\t\t\t[pageSizes]=\"pageSizes\"\r\n\t\t\t\t[selectedPageSize]=\"pageSize\"\r\n\t\t\t\t(onChangePageSize)=\"onChangePageSize($event)\"\r\n\t\t\t>\r\n\t\t\t</ndf-page-sizes-list>\r\n\r\n\t\t\t<span *ngIf=\"showTotalRecord\">{{ 'TABLE.totalRecords' | translate: { count: totalRecords } }}</span>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<ng-container\r\n\t\t*ngIf=\"isLegacyMode\"\r\n\t\t[ngTemplateOutlet]=\"emptyTemplate || legacyDefaultEmptyState\"\r\n\t\t[ngTemplateOutletContext]=\"{ $implicit: loading, rows: rows, initialized: initialized }\"\r\n\t></ng-container>\r\n\r\n\t<ng-container\r\n\t\t*ngIf=\"!isLegacyMode\"\r\n\t\t[ngTemplateOutlet]=\"emptyTemplate || defaultEmptyState\"\r\n\t\t[ngTemplateOutletContext]=\"{ $implicit: loading, rows: rows, initialized: initialized }\"\r\n\t></ng-container>\r\n</div>\r\n\r\n<ng-template #table>\r\n\t<cts-table\r\n\t\t[rows]=\"rows\"\r\n\t\t[columns]=\"columns\"\r\n\t\t[responsiveColumns]=\"responsiveColumns\"\r\n\t\t[rowCursor]=\"rowCursor\"\r\n\t\t[fullWidth]=\"fullWidth\"\r\n\t\t[entityType]=\"entityType\"\r\n\t\t[prefix]=\"prefix\"\r\n\t\t[totalRecords]=\"totalRecords\"\r\n\t\t[tableMode]=\"tableMode\"\r\n\t\t[componentName]=\"componentName\"\r\n\t\t[multiSelectRows]=\"multiSelectRows\"\r\n\t\t[tableActions]=\"tableActions\"\r\n\t\t[showActionsAsMenu]=\"showActionsAsMenu\"\r\n\t\t[defultSort]=\"defultSort\"\r\n\t\t[format]=\"format\"\r\n\t\t[highlightSelectedCard]=\"highlightSelectedCard\"\r\n\t\t[customFirstRow]=\"customFirstRow\"\r\n\t\t(onRowSelected)=\"rowDetails($event)\"\r\n\t\t(onRowIndexSelected)=\"indexDetails($event)\"\r\n\t\t(onMultiRowSelected)=\"onMultiRowSelectValue($event)\"\r\n\t\t(actionOnRow)=\"performAction($event)\"\r\n\t\t(onSorting)=\"onSort($event)\"\r\n\t></cts-table>\r\n</ng-template>\r\n\r\n<ng-template #legacyDefaultEmptyState>\r\n\t<div class=\"empty-state\" *ngIf=\"!loading && rows.length === 0\">\r\n\t\t<div class=\"text\">\r\n\t\t\t{{ (prefix ? prefix + 'noData' : 'noData') | translate }}\r\n\t\t</div>\r\n\t</div>\r\n\t<div class=\"empty-state\" *ngIf=\"loading && rows.length === 0\">\r\n\t\t<div class=\"text\">\r\n\t\t\t{{ (prefix ? prefix + 'gettingData' : 'gettingData') | translate }}\r\n\t\t</div>\r\n\t</div>\r\n</ng-template>\r\n\r\n<ng-template #defaultEmptyState>\r\n\t<div class=\"empty-state\" *ngIf=\"!loading && rows.length === 0\">\r\n\t\t<div class=\"text\">\r\n\t\t\t{{ (prefix ? prefix + 'noData' : 'noData') | translate }}\r\n\t\t</div>\r\n\t</div>\r\n\t<div *ngIf=\"loading && initialized\" class=\"loading-content\">\r\n\t\t<mat-spinner [diameter]=\"100\"></mat-spinner>\r\n\t</div>\r\n</ng-template>\r\n\r\n<ng-template #skeleton let-rows>\r\n\t<table class=\"w-full\">\r\n\t\t<thead *ngIf=\"false\">\r\n\t\t\t<tr class=\"border-b border-green-900\">\r\n\t\t\t\t<th *ngIf=\"multiSelectRows\" class=\"p-3 py-4\" style=\"width: 60px\">\r\n\t\t\t\t\t<app-skeleton width=\"60px\" height=\"1.3rem\"></app-skeleton>\r\n\t\t\t\t</th>\r\n\t\t\t\t<th *ngFor=\"let num of [].constructor(columns?.length || 4); let i = index\" class=\"px-3 py-4\">\r\n\t\t\t\t\t<app-skeleton [randomWidth]=\"true\" height=\"1.7rem\"></app-skeleton>\r\n\t\t\t\t</th>\r\n\t\t\t</tr>\r\n\t\t</thead>\r\n\t\t<tbody>\r\n\t\t\t<tr *ngFor=\"let row of [].constructor(rows || 10); let index = index\" class=\"border-b border-gray-200\">\r\n\t\t\t\t<td *ngIf=\"multiSelectRows\" class=\"p-3 py-4\" style=\"width: 50px\">\r\n\t\t\t\t\t<app-skeleton width=\"50px\" height=\"1.3rem\"></app-skeleton>\r\n\t\t\t\t</td>\r\n\t\t\t\t<td *ngFor=\"let col of [].constructor(columns?.length || 4); let i = index\" class=\"p-3 py-4\">\r\n\t\t\t\t\t<app-skeleton [randomWidth]=\"true\" height=\"1.3rem\"></app-skeleton>\r\n\t\t\t\t</td>\r\n\t\t\t</tr>\r\n\t\t</tbody>\r\n\t</table>\r\n</ng-template>\r\n"]}
|
|
377
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/tables/dynamic-table/dynamic-table/dynamic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tContentChild,\r\n\tEventEmitter,\r\n\tInput,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tOutput,\r\n\tSimpleChanges,\r\n\tTemplateRef,\r\n\tViewEncapsulation\r\n} from '@angular/core';\r\nimport _ from 'lodash';\r\nimport { Subscription } from 'rxjs';\r\nimport { catchError, map, startWith } from 'rxjs/operators';\r\nimport { AdapterService } from '../../../../core/adapters/adapter.service';\r\nimport { CallApiService } from '../../../../core/services/callApi/call-api.service';\r\nimport { EMPTY_TEMPLATE } from '../directives/empty-state.directive';\r\nimport { DynamicTableService } from '../services/dynamic-table.service';\r\nimport { PageEvent } from '@angular/material/paginator/paginator';\r\nimport { EvaluatedString, Evaluator } from '../../../../shared';\r\n\r\n/**\r\n * this component is an additional layer that uses [Table Component]{@link TableComponent} internally,\r\n * you can use this component to configure a page provider listing out of the box easily,\r\n * and it will handle all of the basic features such as getting data from API, Listing, Pagination, sorting and filtering\r\n * ![Screenshot-1](../screenshots/dynamicTable.png)\r\n * @title\r\n * Dynamic Table\r\n * @example\r\n *\r\n * <cts-dynamic-table\r\n *    [columns]=\"columns\"\r\n *    [responsiveColumns]=\"responsiveColumns\"\r\n *    [fullWidth]=\"fullWidth\"\r\n *    [pageSize]=\"PageSize\"\r\n *    [pageProvider]=\"pageProvider\"\r\n *    [quickFilter]=\"filter\"\r\n *    [sortingBy]=\"sortingBy\"\r\n *    [entityType]=\"'all'\"\r\n *    [fields]=\"fields\"\r\n *    [prefix]=\"prefix\"\r\n *    [rowCursor]=\"true\"\r\n *    [queryParam]=\"queryParam\"\r\n *    [headers]=\"headers\"\r\n *    (onRowSelected)=\"openViewer($event)\"\r\n *    (actionOnRow)=\"performAction($event)\">\r\n * </cts-dynamic-table>\r\n */\r\n@Component({\r\n\tselector: 'cts-dynamic-table',\r\n\ttemplateUrl: './dynamic-table.component.html',\r\n\tstyleUrls: ['./dynamic-table.component.scss'],\r\n\tencapsulation: ViewEncapsulation.None,\r\n\thost: {\r\n\t\t'[class.loading-results]': 'loading',\r\n\t\t'[class.no-data]': 'rows.length <= 0'\r\n\t}\r\n})\r\nexport class DynamicTableComponent implements OnInit, OnDestroy {\r\n\t/** event to emit when selecting single row  */\r\n\t@Output() onRowSelected = new EventEmitter();\r\n\t/** event to emit when selecting single row to catch index*/\r\n\t@Output() onRowIndexSelected = new EventEmitter();\r\n\t/** event to emit when perform action on row (delte, edit, ... ) */\r\n\t@Output() actionOnRow = new EventEmitter();\r\n\t/** event to emit to the higher level  when getting data from api is finished */\r\n\t@Output() onGettingData = new EventEmitter();\r\n\t/** event t emit when selecting multiple row */\r\n\t@Output() onMultiRowSelected = new EventEmitter();\r\n\t/** event t emit when start getting data and when finish */\r\n\t@Output() onLoading = new EventEmitter();\r\n\r\n\t@Output() sortChanged = new EventEmitter<{ sortBy: string; sortOrder: string }>();\r\n\t/**\r\n\t * @deprecated Use `onPage` instead.\r\n\t * @see onPage\r\n\t */\r\n\t@Output() onPageChange = new EventEmitter();\r\n\r\n\t@Output() onPage = new EventEmitter<PageEvent>();\r\n\r\n\t@Output() onLoad = new EventEmitter();\r\n\t@Output() onInitialize = new EventEmitter();\r\n\t/** Array of columns */\r\n\t@Input() columns;\r\n\t/** Array of columns on smaller screens */\r\n\t@Input() responsiveColumns?;\r\n\t/** Defines the page in which table is being used */\r\n\t@Input() entityType: string;\r\n\t/** Translations prefix */\r\n\t@Input() prefix = '';\r\n\t/** Headers to be sent with API Request */\r\n\t@Input() headers;\r\n\t/** Fields keymap to be mapped in the adapter */\r\n\t@Input() fields;\r\n\t/** Page Provider name that will be used to retrieve data */\r\n\t@Input() pageProvider;\r\n\t/** Controls number of items per page in table */\r\n\t@Input() pageSize = 10;\r\n\r\n\t@Input() isLegacyMode = true;\r\n\t@Input() showTotalRecord = false;\r\n\r\n\t@ContentChild(EMPTY_TEMPLATE, { read: TemplateRef, static: true })\r\n\temptyTemplate: TemplateRef<any> | undefined;\r\n\r\n\tprivate _pageNumber = 1;\r\n\t@Input() set pageNumber(value: string | number) {\r\n\t\tthis._pageNumber = isNaN(+value) ? 1 : +value;\r\n\t}\r\n\r\n\tget pageNum() {\r\n\t\treturn this._pageNumber;\r\n\t}\r\n\r\n\t/** Sorting column */\r\n\t@Input() sortingBy: {\r\n\t\tsortBy?: string;\r\n\t\tsortOrder?: string;\r\n\t} = {};\r\n\t@Input() queryParam? = {};\r\n\r\n\t@Input() customFilters: {\r\n\t\tparams?: Record<string, any>;\r\n\t\tpayload?: Record<string, any>;\r\n\t} = {};\r\n\r\n\t@Input() quickFilter?;\r\n\t/** Controls if it report page */\r\n\t@Input() report;\r\n\t/** to make cursor when hover on row or not */\r\n\t@Input() rowCursor?;\r\n\t@Input() fullWidth? = 'auto';\r\n\t/** 'list' for noraml table 'card' for cards mode like in memos */\r\n\t@Input() tableMode = 'list';\r\n\r\n\t@Input() componentName: string;\r\n\t/** action to be used in case of card mode */\r\n\t@Input() tableActions;\r\n\t@Input() defultSort: any = { name: 'properties.createdAt', dir: 'desc' };\r\n\t@Input() range;\r\n\t@Input() isSearchPage = false;\r\n\t/** allow multiselect rows with checkbox */\r\n\t@Input() multiSelectRows = false;\r\n\t/** to show 1st row with custom template in the table*/\r\n\t@Input() customFirstRow = false;\r\n\t@Input() highlightSelectedCard = false;\r\n\t@Input() showActionsAsMenu = false; // flage to show action in menu or side by side\r\n\t@Input()\r\n\tfilterParams = {};\r\n\r\n\t@Input() skipAggregation: 'never' | 'onPageChange' = 'onPageChange';\r\n\t@Input() customUrl: { url: string; method: 'POST' | 'GET' };\r\n\t@Input() format = 'MMMM d, y';\r\n\r\n\t@Input() requestActions?: {\r\n\t\tbeforeSubmit?: EvaluatedString<'payload'>;\r\n\t};\r\n\r\n\trows = [];\r\n\ttotalRecords = 0;\r\n\tmyDataSubscription: Subscription;\r\n\tloading;\r\n\tsorting = false;\r\n\t@Input() pageSizes: Array<{ label: string; size: number }> = [];\r\n\r\n\tinitialized = false;\r\n\r\n\tconstructor(\r\n\t\tprivate adapter: AdapterService,\r\n\t\tprivate callApi: CallApiService,\r\n\t\tprivate dynamicTableService: DynamicTableService,\r\n\t\tprivate cdr: ChangeDetectorRef\r\n\t) {}\r\n\r\n\tngOnInit(): void {\r\n\t\tthis.myDataSubscription = this.dynamicTableService.refreshData.pipe(startWith(null)).subscribe((filterData) => {\r\n\t\t\tif (filterData) {\r\n\t\t\t\tthis.filterParams = { ...filterData };\r\n\t\t\t\t// reset page number when start new filtering\r\n\t\t\t\tthis._resetPageNumber();\r\n\t\t\t}\r\n\t\t\tthis.getData();\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.myDataSubscription ? this.myDataSubscription.unsubscribe() : '';\r\n\t}\r\n\r\n\tngOnChanges(changes: SimpleChanges) {\r\n\t\tconst isFirstChange = Object.values(changes).some((c) => c.isFirstChange());\r\n\t\tif (isFirstChange) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst hasChanged = (items: string[]) =>\r\n\t\t\titems.some((key) => {\r\n\t\t\t\tconst isEqual = _.isEqual(changes[key]?.previousValue || null, changes[key]?.currentValue || null);\r\n\t\t\t\treturn !isEqual;\r\n\t\t\t});\r\n\r\n\t\tif (hasChanged(['queryParam', 'quickFilter', 'customFilters'])) {\r\n\t\t\tif (this.initialized) {\r\n\t\t\t\tthis._resetPageNumber(); // Reset page number before recalling API with filters\r\n\t\t\t}\r\n\t\t\tthis.getData();\r\n\t\t}\r\n\r\n\t\tif (hasChanged(['sortingBy'])) {\r\n\t\t\tthis.getData();\r\n\t\t}\r\n\t}\r\n\r\n\tprivate _resetPageNumber() {\r\n\t\tthis._pageNumber = 1;\r\n\t\tthis.onPageChange.emit(this._pageNumber);\r\n\t\tthis.onPage.emit({\r\n\t\t\tpageIndex: this._pageNumber,\r\n\t\t\tpageSize: this.pageSize,\r\n\t\t\tlength: this.totalRecords\r\n\t\t});\r\n\t}\r\n\r\n\tgetData(payload: Record<string, any> = {}, headers: Record<string, any> = {}) {\r\n\t\tthis.loading = true; // internal loading\r\n\t\tthis.onLoading.emit(true); // external loading\r\n\t\tlet params = {\r\n\t\t\t...(this.range ? { dublincore_created_agg: this.range } : {}),\r\n\t\t\t...this.filterParams, // used to get filter data and set it in our params\r\n\t\t\t...this.queryParam, // used to get params from our config\r\n\t\t\t...this.quickFilter,\r\n\t\t\t...(Object.keys(this.sortingBy || {}).length\r\n\t\t\t\t? {\r\n\t\t\t\t\t\tsortBy: this.sortingBy?.sortBy,\r\n\t\t\t\t\t\tsortOrder: this.sortingBy?.sortOrder\r\n\t\t\t\t\t}\r\n\t\t\t\t: {}),\r\n\t\t\tcurrentPageIndex: +this.pageNum - 1,\r\n\t\t\t...(this.pageSize ? { pageSize: this.pageSize } : {}),\r\n\t\t\toffset: 0,\r\n\t\t\t...payload\r\n\t\t};\r\n\r\n\t\t// don't refresh all table in case of sorting only\r\n\t\tif (!this.sorting && this.isLegacyMode) {\r\n\t\t\t// used to not refreshing all table in case of sorting since table lose sorting state when refresh all table\r\n\t\t\tthis.rows = []; // used to refresh table to feel changes in actions when perform action and need to refresh actions\r\n\t\t}\r\n\t\tthis.sorting = false; // reset sorting status to false and for next sorting func sorting set it to true again\r\n\r\n\t\tconst _headers = {\r\n\t\t\t...this.headers,\r\n\t\t\t...headers\r\n\t\t};\r\n\r\n\t\tlet _providerPayload = {\r\n\t\t\tquery: {\r\n\t\t\t\tpageProvider: this.pageProvider,\r\n\t\t\t\t...params\r\n\t\t\t},\r\n\t\t\toptions: {\r\n\t\t\t\theaders: _headers\r\n\t\t\t}\r\n\t\t};\r\n\r\n\t\tlet _customPayload = {\r\n\t\t\tparams: {\r\n\t\t\t\t...params,\r\n\t\t\t\t...(this.customFilters?.params || {})\r\n\t\t\t},\r\n\t\t\theaders: _headers,\r\n\t\t\tpayload: this.customFilters?.payload || {}\r\n\t\t};\r\n\r\n\t\tif (this.requestActions?.beforeSubmit && typeof this.requestActions?.beforeSubmit === 'string') {\r\n\t\t\ttry {\r\n\t\t\t\tif (this.customUrl) {\r\n\t\t\t\t\t_customPayload = Evaluator.evaluate(\r\n\t\t\t\t\t\tthis.requestActions?.beforeSubmit,\r\n\t\t\t\t\t\t{ criteria: _customPayload },\r\n\t\t\t\t\t\t'payload'\r\n\t\t\t\t\t);\r\n\t\t\t\t} else {\r\n\t\t\t\t\t_providerPayload = Evaluator.evaluate(\r\n\t\t\t\t\t\tthis.requestActions?.beforeSubmit,\r\n\t\t\t\t\t\t{ criteria: _providerPayload },\r\n\t\t\t\t\t\t'payload'\r\n\t\t\t\t\t);\r\n\t\t\t\t}\r\n\t\t\t} catch (e) {\r\n\t\t\t\tconsole.error(e);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tconst query$ = this.customUrl\r\n\t\t\t? this.callApi.customQuery(this.customUrl, _customPayload.params, _customPayload.headers, _customPayload.payload)\r\n\t\t\t: this.callApi.query(_providerPayload.query, _providerPayload.options);\r\n\r\n\t\tquery$\r\n\t\t\t.pipe(\r\n\t\t\t\tmap((data: any) => {\r\n\t\t\t\t\tdata.entries.map((item) => this.adapter.adaptIn(item, this.fields));\r\n\t\t\t\t\treturn data;\r\n\t\t\t\t}),\r\n\t\t\t\tcatchError((err) => {\r\n\t\t\t\t\tthrow err;\r\n\t\t\t\t})\r\n\t\t\t)\r\n\t\t\t.subscribe((res) => {\r\n\t\t\t\tthis.loading = false;\r\n\t\t\t\tthis.onLoading.emit(false);\r\n\t\t\t\tthis.onLoad.emit(res);\r\n\t\t\t\tif (!this.initialized) {\r\n\t\t\t\t\tthis.onInitialize.emit(res);\r\n\t\t\t\t\tthis.initialized = true;\r\n\t\t\t\t}\r\n\t\t\t\tres.entries.forEach((element) => {\r\n\t\t\t\t\tif (element.properties && element.properties?.creator && element.properties.creator?.properties) {\r\n\t\t\t\t\t\telement.properties['creatorFullObject'] = { ...element.properties.creator };\r\n\t\t\t\t\t\telement.properties.creator =\r\n\t\t\t\t\t\t\telement.properties.creator?.properties?.firstName +\r\n\t\t\t\t\t\t\t' ' +\r\n\t\t\t\t\t\t\telement.properties.creator?.properties?.lastName;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (element.properties && element.properties?.assignee) {\r\n\t\t\t\t\t\telement.properties.assignee = element.properties?.assignee.fullName;\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t\tthis.totalRecords = res.resultsCount;\r\n\t\t\t\tthis.rows = res.entries;\r\n\t\t\t\tthis.cdr.detectChanges();\r\n\t\t\t\t// emit data to outside in case of search page for the first time only to prevent refreshing aggregation with every page change\r\n\t\t\t\t// and for any other page type emit data directly in all page numbers\r\n\t\t\t\tif ((this.isSearchPage && this.pageNum === 1) || !this.isSearchPage) this.onGettingData.emit(res);\r\n\t\t\t});\r\n\t}\r\n\r\n\t// function to be executed when clicking on single row\r\n\trowDetails(event) {\r\n\t\tthis.onRowSelected.emit(event);\r\n\t}\r\n\r\n\tindexDetails(event) {\r\n\t\tthis.onRowIndexSelected.emit(event);\r\n\t}\r\n\r\n\t//function to handle all operations on single row (delete , edit , ...)\r\n\tperformAction(action) {\r\n\t\tthis.actionOnRow.emit(action);\r\n\t}\r\n\r\n\t// handle sorting functionality of the table\r\n\tonSort(sortObject) {\r\n\t\tthis.sortChanged.emit(sortObject);\r\n\t\tthis.sortingBy = sortObject;\r\n\t\tthis.sorting = true;\r\n\t\tthis.getData({}, this.skipAggregation === 'onPageChange' ? { skipAggregates: 'true' } : {});\r\n\t}\r\n\r\n\tonMultiRowSelectValue(event) {\r\n\t\tthis.onMultiRowSelected.emit(event);\r\n\t}\r\n\r\n\tpublic paginationChange(event) {\r\n\t\tthis._pageNumber = event;\r\n\t\tthis.onPageChange.emit(event);\r\n\t\tthis.onPage.emit({\r\n\t\t\tpageIndex: this._pageNumber,\r\n\t\t\tpageSize: this.pageSize,\r\n\t\t\tlength: this.totalRecords\r\n\t\t});\r\n\t\tthis.getData({}, this.skipAggregation === 'onPageChange' ? { skipAggregates: 'true' } : {});\r\n\t}\r\n\r\n\tonChangePageSize(pageSize: number) {\r\n\t\tthis.pageSize = pageSize;\r\n\t\tthis._resetPageNumber();\r\n\t\tthis.getData({}, this.skipAggregation === 'onPageChange' ? { skipAggregates: 'true' } : {});\r\n\t}\r\n}\r\n","<div class=\"wrapping table-wrapping\">\r\n\t<ng-container *ngIf=\"isLegacyMode\">\r\n\t\t<div class=\"table-reposition\">\r\n\t\t\t<ng-container *ngIf=\"rows.length\" [ngTemplateOutlet]=\"table\"></ng-container>\r\n\t\t</div>\r\n\t\t<ng-container *ngIf=\"loading\">\r\n\t\t\t<cts-spinner></cts-spinner>\r\n\t\t</ng-container>\r\n\t</ng-container>\r\n\r\n\t<div class=\"table-reposition\" *ngIf=\"!isLegacyMode\">\r\n\t\t<ng-container  [ngTemplateOutlet]=\"table\"></ng-container>\r\n\t\t<ng-container\r\n\t\t\t*ngIf=\"!initialized\"\r\n\t\t\t[ngTemplateOutlet]=\"skeleton\"\r\n\t\t\t[ngTemplateOutletContext]=\"{ $implicit: 10 }\"\r\n\t\t></ng-container>\r\n\t</div>\r\n\r\n\t<div\r\n\t\tclass=\"pagination-iner-wraper my-3\"\r\n\t\t[ngClass]=\"{ relative: pageSizes?.length }\"\r\n\t\t*ngIf=\"rows.length \"\r\n\t>\r\n\t\t<cts-pagination\r\n      *ngIf=\"totalRecords > pageSize\"\r\n\t\t\t[page]=\"pageNum\"\r\n\t\t\t(change)=\"paginationChange($event)\"\r\n\t\t\t[size]=\"pageSize\"\r\n\t\t\t[count]=\"totalRecords\"\r\n\t\t></cts-pagination>\r\n\t\t<div class=\"absolute ndfPageSizes flex gap-x-3 items-center mt-2\">\r\n\t\t\t<ndf-page-sizes-list\r\n\t\t\t\t*ngIf=\"pageSizes?.length\"\r\n\t\t\t\t[pageSizes]=\"pageSizes\"\r\n\t\t\t\t[selectedPageSize]=\"pageSize\"\r\n\t\t\t\t(onChangePageSize)=\"onChangePageSize($event)\"\r\n\t\t\t>\r\n\t\t\t</ndf-page-sizes-list>\r\n\r\n\t\t\t<span *ngIf=\"showTotalRecord\">{{ 'TABLE.totalRecords' | translate: { count: totalRecords } }}</span>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<ng-container\r\n\t\t*ngIf=\"isLegacyMode\"\r\n\t\t[ngTemplateOutlet]=\"emptyTemplate || legacyDefaultEmptyState\"\r\n\t\t[ngTemplateOutletContext]=\"{ $implicit: loading, rows: rows, initialized: initialized }\"\r\n\t></ng-container>\r\n\r\n\t<ng-container\r\n\t\t*ngIf=\"!isLegacyMode\"\r\n\t\t[ngTemplateOutlet]=\"emptyTemplate || defaultEmptyState\"\r\n\t\t[ngTemplateOutletContext]=\"{ $implicit: loading, rows: rows, initialized: initialized }\"\r\n\t></ng-container>\r\n</div>\r\n\r\n<ng-template #table>\r\n\t<cts-table\r\n\t\t[rows]=\"rows\"\r\n\t\t[columns]=\"columns\"\r\n\t\t[responsiveColumns]=\"responsiveColumns\"\r\n\t\t[rowCursor]=\"rowCursor\"\r\n\t\t[fullWidth]=\"fullWidth\"\r\n\t\t[entityType]=\"entityType\"\r\n\t\t[prefix]=\"prefix\"\r\n\t\t[totalRecords]=\"totalRecords\"\r\n\t\t[tableMode]=\"tableMode\"\r\n\t\t[componentName]=\"componentName\"\r\n\t\t[multiSelectRows]=\"multiSelectRows\"\r\n\t\t[tableActions]=\"tableActions\"\r\n\t\t[showActionsAsMenu]=\"showActionsAsMenu\"\r\n\t\t[defultSort]=\"defultSort\"\r\n\t\t[format]=\"format\"\r\n\t\t[highlightSelectedCard]=\"highlightSelectedCard\"\r\n\t\t[customFirstRow]=\"customFirstRow\"\r\n\t\t(onRowSelected)=\"rowDetails($event)\"\r\n\t\t(onRowIndexSelected)=\"indexDetails($event)\"\r\n\t\t(onMultiRowSelected)=\"onMultiRowSelectValue($event)\"\r\n\t\t(actionOnRow)=\"performAction($event)\"\r\n\t\t(onSorting)=\"onSort($event)\"\r\n\t></cts-table>\r\n</ng-template>\r\n\r\n<ng-template #legacyDefaultEmptyState>\r\n\t<div class=\"empty-state\" *ngIf=\"!loading && rows.length === 0\">\r\n\t\t<div class=\"text\">\r\n\t\t\t{{ (prefix ? prefix + 'noData' : 'noData') | translate }}\r\n\t\t</div>\r\n\t</div>\r\n\t<div class=\"empty-state\" *ngIf=\"loading && rows.length === 0\">\r\n\t\t<div class=\"text\">\r\n\t\t\t{{ (prefix ? prefix + 'gettingData' : 'gettingData') | translate }}\r\n\t\t</div>\r\n\t</div>\r\n</ng-template>\r\n\r\n<ng-template #defaultEmptyState>\r\n\t<div class=\"empty-state\" *ngIf=\"!loading && rows.length === 0\">\r\n\t\t<div class=\"text\">\r\n\t\t\t{{ (prefix ? prefix + 'noData' : 'noData') | translate }}\r\n\t\t</div>\r\n\t</div>\r\n\t<div *ngIf=\"loading && initialized\" class=\"loading-content\">\r\n\t\t<mat-spinner [diameter]=\"100\"></mat-spinner>\r\n\t</div>\r\n</ng-template>\r\n\r\n<ng-template #skeleton let-rows>\r\n\t<table class=\"w-full\">\r\n\t\t<thead *ngIf=\"false\">\r\n\t\t\t<tr class=\"border-b border-green-900\">\r\n\t\t\t\t<th *ngIf=\"multiSelectRows\" class=\"p-3 py-4\" style=\"width: 60px\">\r\n\t\t\t\t\t<app-skeleton width=\"60px\" height=\"1.3rem\"></app-skeleton>\r\n\t\t\t\t</th>\r\n\t\t\t\t<th *ngFor=\"let num of [].constructor(columns?.length || 4); let i = index\" class=\"px-3 py-4\">\r\n\t\t\t\t\t<app-skeleton [randomWidth]=\"true\" height=\"1.7rem\"></app-skeleton>\r\n\t\t\t\t</th>\r\n\t\t\t</tr>\r\n\t\t</thead>\r\n\t\t<tbody>\r\n\t\t\t<tr *ngFor=\"let row of [].constructor(rows || 10); let index = index\" class=\"border-b border-gray-200\">\r\n\t\t\t\t<td *ngIf=\"multiSelectRows\" class=\"p-3 py-4\" style=\"width: 50px\">\r\n\t\t\t\t\t<app-skeleton width=\"50px\" height=\"1.3rem\"></app-skeleton>\r\n\t\t\t\t</td>\r\n\t\t\t\t<td *ngFor=\"let col of [].constructor(columns?.length || 4); let i = index\" class=\"p-3 py-4\">\r\n\t\t\t\t\t<app-skeleton [randomWidth]=\"true\" height=\"1.3rem\"></app-skeleton>\r\n\t\t\t\t</td>\r\n\t\t\t</tr>\r\n\t\t</tbody>\r\n\t</table>\r\n</ng-template>\r\n"]}
|
|
@@ -11103,6 +11103,9 @@ class DynamicFormSelectUsersComponent {
|
|
|
11103
11103
|
});
|
|
11104
11104
|
}
|
|
11105
11105
|
}
|
|
11106
|
+
else {
|
|
11107
|
+
this.loading = false;
|
|
11108
|
+
}
|
|
11106
11109
|
}
|
|
11107
11110
|
getAllUsers(page = 0) {
|
|
11108
11111
|
return this.userApiService.getAllUsers({
|
|
@@ -20109,7 +20112,7 @@ class DynamicTableComponent {
|
|
|
20109
20112
|
this.fullWidth = 'auto';
|
|
20110
20113
|
/** 'list' for noraml table 'card' for cards mode like in memos */
|
|
20111
20114
|
this.tableMode = 'list';
|
|
20112
|
-
this.defultSort =
|
|
20115
|
+
this.defultSort = { name: 'properties.createdAt', dir: 'desc' };
|
|
20113
20116
|
this.isSearchPage = false;
|
|
20114
20117
|
/** allow multiselect rows with checkbox */
|
|
20115
20118
|
this.multiSelectRows = false;
|
|
@@ -42734,7 +42737,9 @@ class BaseChartBuilderService {
|
|
|
42734
42737
|
if ((config === null || config === void 0 ? void 0 : config.dataFormat) && ((_a = item === null || item === void 0 ? void 0 : item.localized) === null || _a === void 0 ? void 0 : _a[currentLang])) {
|
|
42735
42738
|
return item.localized[currentLang];
|
|
42736
42739
|
}
|
|
42737
|
-
const label =
|
|
42740
|
+
const label = config.bindLabel
|
|
42741
|
+
? ___default.get(item, config === null || config === void 0 ? void 0 : config.bindLabel[this._translateService.currentLang])
|
|
42742
|
+
: null;
|
|
42738
42743
|
return label || this._translateService.instant(`${this._translatePrefix}${item.key}`);
|
|
42739
42744
|
}
|
|
42740
42745
|
_getValue(item, source) {
|
|
@@ -45053,7 +45058,7 @@ class InfoDialogComponent extends BaseDialogComponent {
|
|
|
45053
45058
|
}
|
|
45054
45059
|
}
|
|
45055
45060
|
InfoDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: InfoDialogComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
45056
|
-
InfoDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: InfoDialogComponent, selector: "app-info-dialog", usesInheritance: true, ngImport: i0, template: "<ndf-nuxeo-dialog [dialogTitle]=\"dialogData.title | translate\" bodyClass=\"gap-4 p-0\">\r\n\t<ng-template #contentTemplate>\r\n\t\t<div class=\"secondary-tabs flex gap-5 items-center self-stretch doc-tabs\">\r\n\t\t\t<div\r\n\t\t\t\t[class.selected-tab]=\"doc.name === activeDoc\"\r\n\t\t\t\tclass=\"tab-item relative flex py-5 px-3 justify-start items-center gap-2.5 cursor-pointer\"\r\n\t\t\t\t*ngFor=\"let doc of documentations\"\r\n\t\t\t\t(click)=\"activeDoc = doc.name\"\r\n\t\t\t>\r\n\t\t\t\t<h4>{{ doc?.name | translate }}</h4>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<ng-container *ngFor=\"let doc of documentations\">\r\n\t\t\t<markdown class=\"markdown-content\" [src]=\"baseAppUrl + doc.path\" *ngIf=\"doc.name === activeDoc\"> </markdown>\r\n\t\t</ng-container>\r\n\t</ng-template>\r\n\r\n\t<ng-template #actionsTemplate let-dialog=\"dialog\"> </ng-template>\r\n</ndf-nuxeo-dialog>\r\n", styles: ["::ng-deep .markdown-content{direction:var(--markdown-direction, ltr)!important;text-align:start;color:var(--markdonw-text-color, inherit);background:var(--markdonw-background-color, transparent);border:var(--markdonw-border, 0px solid transparent);border-radius:var(--markdonw-border-radius, 0)}::ng-deep .markdown-content code,::ng-deep .markdown-content kbd,::ng-deep .markdown-content samp,::ng-deep .markdown-content pre{font-family:ui-monospace,SFMono-Regular,Consolas,\"Liberation Mono\",Menlo,monospace;font-size:1em}::ng-deep .markdown-content hr{margin-block:1rem}::ng-deep .markdown-content table{border-spacing:0;border-collapse:collapse;display:block;width:max-content;max-width:100%;overflow:auto;font-variant:tabular-nums;margin-block:.5rem}::ng-deep .markdown-content table tr{border-top:1px solid var(--markdonw-table-tr-border-color, #d1d9e0b3)}::ng-deep .markdown-content table th,::ng-deep .markdown-content table td{padding:6px 13px;border:1px solid var(--markdonw-table-border-color, #d1d9e0)}.doc-tabs{position:sticky;top:0;background:var(--markdonw-background-color, #fff)}\n"], components: [{ type: NdfNuxeoDialog, selector: "ndf-nuxeo-dialog", inputs: ["dialogTitle", "subTitle", "panelClass", "bodyClass", "loaderMode"] }, { type: i2$8.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "emoji", "katex", "katexOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start"], outputs: ["error", "load", "ready"] }], directives: [{ type: i4$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
45061
|
+
InfoDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: InfoDialogComponent, selector: "app-info-dialog", usesInheritance: true, ngImport: i0, template: "<ndf-nuxeo-dialog [dialogTitle]=\"dialogData.title | translate\" bodyClass=\"gap-4 p-0\">\r\n\t<ng-template #contentTemplate>\r\n\t\t<div class=\"secondary-tabs flex gap-5 items-center self-stretch doc-tabs\">\r\n\t\t\t<div\r\n\t\t\t\t[class.selected-tab]=\"doc.name === activeDoc\"\r\n\t\t\t\tclass=\"tab-item relative flex py-5 px-3 justify-start items-center gap-2.5 cursor-pointer\"\r\n\t\t\t\t*ngFor=\"let doc of documentations\"\r\n\t\t\t\t(click)=\"activeDoc = doc.name\"\r\n\t\t\t>\r\n\t\t\t\t<h4>{{ doc?.name | translate }}</h4>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<ng-container *ngFor=\"let doc of documentations\">\r\n\t\t\t<markdown class=\"markdown-content\" [src]=\"baseAppUrl + doc.path\" *ngIf=\"doc.name === activeDoc\"> </markdown>\r\n\t\t</ng-container>\r\n\t</ng-template>\r\n\r\n\t<ng-template #actionsTemplate let-dialog=\"dialog\"> </ng-template>\r\n</ndf-nuxeo-dialog>\r\n", styles: ["::ng-deep .markdown-content{direction:var(--markdown-direction, ltr)!important;text-align:start;color:var(--markdonw-text-color, inherit);background:var(--markdonw-background-color, transparent);border:var(--markdonw-border, 0px solid transparent);border-radius:var(--markdonw-border-radius, 0);padding:var(--markdown-padding, 1rem)}::ng-deep .markdown-content em{background-color:transparent}::ng-deep .markdown-content code,::ng-deep .markdown-content kbd,::ng-deep .markdown-content samp,::ng-deep .markdown-content pre{font-family:ui-monospace,SFMono-Regular,Consolas,\"Liberation Mono\",Menlo,monospace;font-size:1em}::ng-deep .markdown-content hr{margin-block:1rem}::ng-deep .markdown-content table{border-spacing:0;border-collapse:collapse;display:block;width:max-content;max-width:100%;overflow:auto;font-variant:tabular-nums;margin-block:.5rem}::ng-deep .markdown-content table tr{border-top:1px solid var(--markdonw-table-tr-border-color, #d1d9e0b3)}::ng-deep .markdown-content table th,::ng-deep .markdown-content table td{padding:6px 13px;border:1px solid var(--markdonw-table-border-color, #d1d9e0)}.doc-tabs{position:sticky;top:0;background:var(--markdonw-tabs-background-color, #fff)}\n"], components: [{ type: NdfNuxeoDialog, selector: "ndf-nuxeo-dialog", inputs: ["dialogTitle", "subTitle", "panelClass", "bodyClass", "loaderMode"] }, { type: i2$8.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "emoji", "katex", "katexOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start"], outputs: ["error", "load", "ready"] }], directives: [{ type: i4$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1.TranslatePipe } });
|
|
45057
45062
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: InfoDialogComponent, decorators: [{
|
|
45058
45063
|
type: Component,
|
|
45059
45064
|
args: [{
|