ngx-histaff-alpha 0.4.3 → 0.4.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -148,7 +148,7 @@ export class CoreTableComponent extends CoreFormControlBaseComponent {
148
148
  if (this.columns?.filter((c) => c.field === 'id').length === 0 && isDevMode() && this.columns.length) {
149
149
  this.alertService.error(this.id + ": The columns must have one with 'field' property === 'id'", noneAutoClosedAlertOptions);
150
150
  }
151
- this.visibleColumns = this.columns.filter((c) => !!!c.hidden);
151
+ this.visibleColumns = this.columns?.filter((c) => !!!c.hidden);
152
152
  if (!!!this.visibleColumns.length && isDevMode() && this.columns.length) {
153
153
  this.alertService.error(this.id + ": No visible column defined.", noneAutoClosedAlertOptions);
154
154
  }
@@ -425,7 +425,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
425
425
  }], footer: [{
426
426
  type: Input
427
427
  }], columns: [{
428
- type: Input
428
+ type: Input,
429
+ args: [{ required: true }]
429
430
  }], data: [{
430
431
  type: Input
431
432
  }], selectedIds: [{
@@ -470,4 +471,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
470
471
  type: ViewChild,
471
472
  args: ['firstHeaderRow']
472
473
  }] } });
473
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, AfterViewInit, OnChanges, ViewChild, SimpleChanges, Output, EventEmitter, TemplateRef, isDevMode } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport enum ECoreTableToolCode {\r\n  edit = 'edit',\r\n  delete = 'delete',\r\n  complete = 'complete',\r\n  navigate = 'navigate',\r\n}\r\n\r\nexport enum ECoreTableToolClass {\r\n  edit = 'edit-icon',\r\n  delete = 'delete-icon',\r\n  repeat = 'repeat-icon',\r\n  navigate = 'navigate-icon'\r\n}\r\n\r\nexport interface ICoreTableToolItem {\r\n  code: ECoreTableToolCode;\r\n  class: ECoreTableToolClass;\r\n  caption?: EnumTranslateKey | string; // Later we will remove \"| string\"\r\n\r\n  /* callbacks to calculate disabled and hiden based on row*/\r\n  disabledFn?: (row: any) => boolean;\r\n  hiddenFn?: (row: any) => boolean;\r\n}\r\n\r\nexport interface ICoreTableToolClickEventEmitterData {\r\n  code: ECoreTableToolCode;\r\n  id: string | number;\r\n}\r\n\r\n/*\r\nexport interface ICoreTableRowDoubleClickEventEmitterData {\r\n  id: string | number;\r\n}\r\n*/\r\n\r\ninterface IDoubleTouchendData {\r\n  previous: number;\r\n  current: number;\r\n}\r\n\r\nimport { Subscription, BehaviorSubject, filter, debounceTime, Observable, fromEvent } from 'rxjs';\r\nimport { CorePageListService } from '../core-page-list/core-page-list.service';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { ICoreButtonVNS } from '../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { ISearchItem } from '../../interfaces/IQueryListRequest';\r\nimport { LayoutService } from '../../services/layout.service';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { AlertService } from '../alert/alert.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { noneAutoClosedAlertOptions } from '../../constants/alertOptions';\r\nimport { ICoreTableColumnItem } from './ICoreTableColumnItem';\r\nimport { EnumSortDirection } from '../../enum/EnumSortDirection';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreButtonGroupComponent } from '../core-button-group/core-button-group/core-button-group.component';\r\nimport { ThreedotsComponent } from '../threedots/threedots.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { CoreLoadingSurfaceComponent } from '../core-loading-surface/core-loading-surface/core-loading-surface.component';\r\nimport { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { TableCellPipe } from '../pipes/table-cell.pipe';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\n\r\n@Component({\r\n  selector: 'core-table',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CoreButtonGroupComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TableCellPipe,\r\n    TranslatePipe,\r\n    CoreLoadingSurfaceComponent,\r\n    CoreButtonGroupVnsComponent,\r\n  ],\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreTableComponent\r\n    }\r\n  ]\r\n})\r\nexport class CoreTableComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\r\n\r\n  /*\r\n  This component displays input data without pagination.\r\n  For paginating please organize from parents\r\n  */\r\n\r\n  @Input() id!: string; // for html id identifying\r\n  @Input() width!: string;\r\n  @Input() height!: number;\r\n  @Input() showCheckbox!: boolean;\r\n  @Input() checkboxSize!: number;\r\n  @Input() outerButtons!: ICoreButtonVNS[];\r\n  @Input() showTools!: boolean;\r\n  @Input() tools!: ICoreTableToolItem[];\r\n  @Input() checkingResetFlag!: boolean;\r\n\r\n  /* change these 2 props to wrap header texts */\r\n  @Input() headerWrap!: boolean;\r\n  @Input() headerFirstRowHeight!: number;\r\n  /** */\r\n  \r\n  @Input() headerSecondRowHeight!: number;\r\n  @Input() wrap!: boolean;\r\n  @Input() allowCellScrollY!: boolean;\r\n  @Input() loading!: boolean;\r\n  @Input() rowHeight!: string; // VERY IMPORTANT PROPERTY\r\n  @Input() frozen!: number;\r\n  @Input() footer!: any;\r\n  @Input() columns!: ICoreTableColumnItem[]; // required\r\n  @Input() data!: any[]; // required\r\n  @Input() selectedIds!: string[] | number[];\r\n  @Input() corePageListInstanceNumber!: number;\r\n  @Input() disableHighlightOnClick!: boolean;\r\n  @Input() freeMode!: boolean;\r\n  @Input() searchSwitchDisabled: boolean = false;\r\n  @Input() inlineToolItems!: EnumCoreButtonVNSCode[];\r\n  @Input() columnSearchDefaultOpen!: boolean;\r\n  @Input() lazyLoading!: boolean;\r\n\r\n  @Input() noPaddingCell!: boolean;\r\n\r\n  @Output() onSearching = new EventEmitter<ISearchItem[]>();\r\n  @Output() onToolClick = new EventEmitter<ICoreTableToolClickEventEmitterData>();\r\n  @Output() onRowClick = new EventEmitter();\r\n  @Output() onRowDoubleClick = new EventEmitter();\r\n  @Output() onSelectedIdsChange = new EventEmitter<string[] | number[]>();\r\n  @Output() onSelectedDataChange = new EventEmitter<any[]>();\r\n  @Output() onColumnCaptionClick = new EventEmitter<ICoreTableColumnItem>();\r\n\r\n  checkboxColumnWidth: number = 30; // (--checkbox-size)* 2 Please do not change this\r\n\r\n  searchActive!: boolean;\r\n  visibleColumns!: ICoreTableColumnItem[];\r\n  frozenLefts: number[] = [];\r\n  checkingModel: boolean[] = [];\r\n  headerCheckboxState!: boolean;\r\n  checkingState!: number; // 0=none; 1=all; 2=mixed\r\n  tbodyheight!: number;\r\n  visibleRowCount!: number;\r\n\r\n  rowTouchendStream$: BehaviorSubject<IDoubleTouchendData> = new BehaviorSubject<IDoubleTouchendData>({ previous: -2, current: -1 });\r\n  subscriptions: Subscription[] = [];\r\n\r\n  searchObject!: ISearchItem[];\r\n\r\n  lang!: string;\r\n\r\n  activeRow!: any; // number | string\r\n\r\n  mouseDown = false;\r\n  startX: any;\r\n  endX: any;\r\n\r\n  scrollStream$!: Observable<any>;\r\n\r\n  /* FOR LAZY UI LOADING */\r\n  renderAhread: number = 0;\r\n  hiddenTopHeight: number = 0;\r\n  hiddenBottomHeight: number = 0;\r\n  scrollTop: number = 0;\r\n  offsetY: number = 0;\r\n  visibleData!: any[];\r\n  startNode: number = 0;\r\n  /***********************/\r\n\r\n  @ViewChild('coreTable') coreTable!: ElementRef;\r\n  @ViewChild('table') table!: ElementRef;\r\n  @ViewChild('firstHeaderRow') firstHeaderRow!: ElementRef;\r\n\r\n  constructor(\r\n    private layoutService: LayoutService,\r\n    private corePageListService: CorePageListService,\r\n    private mls: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private authService: AuthService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  calculateScroll(): void {\r\n\r\n    try {\r\n\r\n      if (!!!this.coreTable) return;\r\n      if (!!!this.lazyLoading) return;\r\n\r\n      const height = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--height').replace('px', ''));\r\n      const rowHeight = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--row-height').split('px')[0]);\r\n\r\n      if (!!!rowHeight) throw new Error(\"Could not get --row-height property\");\r\n\r\n      let startNode = Math.floor(this.scrollTop / rowHeight) - this.renderAhread;\r\n      startNode = Math.max(0, startNode);\r\n      this.startNode = startNode || 0;\r\n      let visibleNodeCount = Math.ceil(height / rowHeight) + 2 * this.renderAhread;\r\n      visibleNodeCount = Math.min(this.data.length - startNode, visibleNodeCount);\r\n      this.offsetY = startNode * rowHeight;\r\n      const newVisibleData: any[] = [];\r\n\r\n      this.hiddenTopHeight = startNode * rowHeight;\r\n      this.hiddenBottomHeight = (this.data.length - startNode - visibleNodeCount) * rowHeight;\r\n      for (let i = startNode; i < startNode + visibleNodeCount; i++) {\r\n        newVisibleData.push(this.data[i])\r\n      }\r\n\r\n      this.visibleData = newVisibleData;\r\n\r\n      /* OPEN COMMENTS TO SEE CONTROL VALUES */\r\n      console.log(\"startNode\", startNode)\r\n      /*\r\n      console.log(\"this.offsetY\", this.offsetY)\r\n      console.log(\"this.hiddenTopHeight\", this.hiddenTopHeight)\r\n      console.log(\"this.hiddenBottomHeight\", this.hiddenBottomHeight)\r\n      console.log(\"this.visibleData.length\", this.visibleData.length)\r\n      const controlValue = (this.hiddenTopHeight + this.hiddenBottomHeight + this.visibleData.length * rowHeight) / rowHeight\r\n      console.log(\"controlValue\", controlValue) // Must equeal pageSize\r\n      */\r\n    } catch (error: any) {\r\n      if (isDevMode() && this.authService.data$.value?.id === '8c24683d-7d52-4f5a-8090-31c777e8869d') {\r\n        this.alertService.error(error.message, noneAutoClosedAlertOptions);\r\n      }\r\n\r\n      this.visibleData = JSON.parse(JSON.stringify(this.data));\r\n\r\n    }\r\n  }\r\n\r\n  startDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (e.buttons === 1) {\r\n      this.startX = e.pageX;\r\n      if (!!!this.mouseDown) {\r\n\r\n      }\r\n      this.mouseDown = true;\r\n    }\r\n  }\r\n\r\n  stopDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (!!this.mouseDown) {\r\n      this.endX = e.pageX;\r\n      let offset = this.endX - this.startX;\r\n      col.width! += offset;\r\n      this.mouseDown = false;\r\n      this.endX = 0;\r\n      this.startX = 0;\r\n    }\r\n  }\r\n\r\n  moveEvent(e: any, col: ICoreTableColumnItem) {\r\n    e.preventDefault();\r\n    if (!this.mouseDown) {\r\n      return;\r\n    }\r\n    const x = e.pageX;\r\n    console.log(\"moveEvent\", e.pageX)\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.showCheckbox) {\r\n      if (!this.checkboxSize) {\r\n        this.checkboxSize = 15;\r\n      }\r\n    }\r\n\r\n    if (this.headerFirstRowHeight === undefined) this.headerFirstRowHeight = 40;\r\n    if (this.headerSecondRowHeight === undefined) this.headerSecondRowHeight = 40;\r\n\r\n\r\n    /* Validate columns input to make sure one of fields is 'id' */\r\n    if (!!!this.columns) {\r\n      this.alertService.error(this.id + \": Columns are not defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    if (this.columns?.filter((c: ICoreTableColumnItem) => c.field === 'id').length === 0 && isDevMode() && this.columns.length) {\r\n      this.alertService.error(this.id + \": The columns must have one with 'field' property === 'id'\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    this.visibleColumns = this.columns.filter((c: ICoreTableColumnItem) => !!!c.hidden)\r\n    if (!!!this.visibleColumns.length && isDevMode() && this.columns.length) {\r\n      this.alertService.error(this.id + \": No visible column defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    // add default sort direction to visibleColumns\r\n    this.visibleColumns.map(c => c.sortDirection = EnumSortDirection.NONE)\r\n\r\n    /* START: Initializing searchObject */\r\n    const newSearchObject: ISearchItem[] = [];\r\n    this.visibleColumns.map(c => {\r\n      newSearchObject.push({\r\n        field: c.field,\r\n        searchFor: ''\r\n      })\r\n    })\r\n    this.searchObject = newSearchObject;\r\n    /* END: Initializing searchObject */\r\n\r\n    const frozenColumns = this.visibleColumns.filter((_, index) => index < this.frozen);\r\n\r\n    let left = this.checkboxSize! * 2 || 0; // the first size is for checkbox\r\n    frozenColumns.map(c => {\r\n      if (!!!c.width) console.error(this.id + \": Each frozen column must have its number property 'width'.\");\r\n      this.frozenLefts.push(left);\r\n      left = left + c.width!\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.rowTouchendStream$.pipe(\r\n        filter((x: any) => x.current === x.previous),\r\n        debounceTime(200),\r\n      ).subscribe((y: any) => {\r\n        this.onRowDoubleClick.emit({\r\n          id: this.data[y.current].id\r\n        })\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n    if (changes['checkingResetFlag']) {\r\n      if (!!this.data) {\r\n        this.toggleCheckAll(false)\r\n        this.headerCheckboxState = false;\r\n      }\r\n    }\r\n\r\n    if (changes['data']) {\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['data'].currentValue?.map((_: any) => {\r\n        newCheckingModel.push(false)\r\n      });\r\n      this.checkingModel = newCheckingModel;\r\n\r\n      if (!!this.lazyLoading) {\r\n        if (!!this.coreTable) {\r\n          this.calculateScroll();\r\n        }\r\n      } else {\r\n        this.visibleData = changes['data'].currentValue;\r\n      }\r\n    }\r\n\r\n    if (changes['checkedIds']) {\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['checkedIds'].currentValue?.map((checkedId: any) => {\r\n        this.data.map((item) => {\r\n          if (item['id'] === checkedId) {\r\n            newCheckingModel.push(true);\r\n          } else {\r\n            newCheckingModel.push(false);\r\n          }\r\n        })\r\n      })\r\n      this.checkingModel = newCheckingModel;\r\n    }\r\n    if (changes['loading']) {\r\n      this.loading = changes['loading'].currentValue;\r\n    }\r\n    if (changes['columns']) {\r\n      this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden) || []\r\n    }\r\n    if (changes['columnSearchDefaultOpen']) {\r\n      this.searchActive = !!changes['columnSearchDefaultOpen'].currentValue\r\n    }\r\n  }\r\n\r\n  private resetHeaderFirstRowHeight(): void {\r\n    setTimeout(() => {\r\n      const firstHeaderRowHeight = this.firstHeaderRow.nativeElement.getBoundingClientRect().height;\r\n      this.coreTable.nativeElement.style.setProperty('--header-1st-row-height',\r\n      firstHeaderRowHeight + 'px'\r\n      );\r\n    })\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (this.corePageListInstanceNumber) {\r\n      const callerFilter = this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber);\r\n      if (!!callerFilter.length) {\r\n        const caller = callerFilter[0];\r\n        caller.coreTableRef = this.coreTable;\r\n      }\r\n\r\n      if (!!!this.freeMode) {\r\n        this.subscriptions.push(\r\n          this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].id$.subscribe(x => {\r\n            this.activeRow = x;\r\n          })\r\n        )\r\n      }\r\n\r\n      this.subscriptions.push(\r\n        this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].tbodyHeight$.subscribe(x => {\r\n          if (!!x) {\r\n            this.tbodyheight = x;\r\n          }\r\n        })\r\n      )\r\n\r\n      const rect = this.coreTable.nativeElement.getBoundingClientRect();\r\n      this.coreTable.nativeElement.style.setProperty('--table-width', rect.width + 'px')\r\n\r\n    }\r\n\r\n    this.scrollStream$ = fromEvent(this.table.nativeElement, 'scroll');\r\n\r\n    setTimeout(() => {\r\n\r\n      if (!!this.width) this.coreTable.nativeElement.style.setProperty('--width', this.width + 'px');\r\n      if (!!this.rowHeight) this.coreTable.nativeElement.style.setProperty('--row-height', this.rowHeight + 'px');\r\n      if (!!this.height) this.coreTable.nativeElement.style.setProperty('--height', this.height + 'px');\r\n\r\n      // Chỉ subscride sau khi các lệnh trên đã được thực hiện\r\n      this.subscriptions.push(\r\n        this.scrollStream$\r\n          .pipe(\r\n            debounceTime(50)\r\n          )\r\n          .subscribe(event => {\r\n            this.scrollTop = event.srcElement.scrollTop;\r\n            this.calculateScroll();\r\n          })\r\n      )\r\n\r\n    }, 0)\r\n\r\n    this.resetHeaderFirstRowHeight();\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(_ => {\r\n        this.resetHeaderFirstRowHeight();\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  onToolClickLocal(rowIndex: number, toolIndex: number): void {\r\n    this.onToolClick.emit({\r\n      code: this.tools[toolIndex].code,\r\n      id: this.data[rowIndex].id\r\n    })\r\n  }\r\n\r\n  toggleCheckAll(args: boolean) {\r\n    const newCheckingModel: boolean[] = [];\r\n    const newSelectedIds: any[] = [];\r\n    const newSelectedData: any[] = [];\r\n\r\n    this.data.map(item => {\r\n      newCheckingModel.push(args);\r\n      if (args) {\r\n        newSelectedIds.push(item.id);\r\n        newSelectedData.push(item);\r\n      }\r\n    });\r\n\r\n    this.checkingModel = newCheckingModel;\r\n    this.checkingState = args ? 1 : 0;\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n  }\r\n\r\n  onCheckingNgModelChange() {\r\n    const newSelectedIds: number[] = [];\r\n    const newSelectedData: any[] = [];\r\n    this.data.filter((_: any, index: number) => !!this.checkingModel[index]).map(item => {\r\n      newSelectedIds.push(item.id)\r\n      newSelectedData.push(item)\r\n    })\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n\r\n    if (newSelectedIds.length === 0) {\r\n      this.checkingState = 0; // none\r\n    } else if (newSelectedIds.length === this.checkingModel.length) {\r\n      this.checkingState = 1; // all\r\n    } else {\r\n      this.checkingState = 2; // mixed\r\n    }\r\n\r\n  }\r\n\r\n  onDoubleClickLocal(rowIndex: number) {\r\n    this.onRowDoubleClick.emit(this.data[rowIndex])\r\n  }\r\n\r\n  onClickLocal(row: any, event: any) {\r\n\r\n    console.log(\"onClickLocal row\", row, \"event\", event)\r\n\r\n    if (event.detail === 1) {\r\n      this.activeRow = row.id;\r\n      this.onRowClick.emit(row);\r\n    } else if (event.detail === 2) {\r\n      this.onRowDoubleClick.emit(row)\r\n    }\r\n\r\n  }\r\n\r\n  onRowTouchend(rowIndex: number) {\r\n    this.rowTouchendStream$.next({\r\n      previous: this.rowTouchendStream$.value.current,\r\n      current: rowIndex\r\n    });\r\n  }\r\n\r\n  onSearch(e: string, searchColumnIndex: number): void {\r\n    this.searchObject.filter((_, i) => i === searchColumnIndex)[0].searchFor = e;\r\n    this.onSearching.emit(this.searchObject);\r\n  }\r\n\r\n  onColumnCaptionClickLocal(column: ICoreTableColumnItem) {\r\n\r\n    if (!!column.templateRef) return; // no action for templateRef type\r\n\r\n    this.onColumnCaptionClick.emit(column);\r\n\r\n    // update sort dicrection property of this column\r\n    // and clear up the property for the other visibleColumns\r\n    this.visibleColumns.map(vc => {\r\n      if (vc.field === column.field) {\r\n        vc.sortDirection = vc.sortDirection === EnumSortDirection.NONE ? EnumSortDirection.ASC : vc.sortDirection === EnumSortDirection.ASC ? EnumSortDirection.DESC : EnumSortDirection.NONE;\r\n      } else {\r\n        vc.sortDirection = EnumSortDirection.NONE\r\n      }\r\n    })\r\n  }\r\n\r\n  toggleAllowSearch(): void {\r\n    this.searchActive = !!!this.searchActive\r\n  }\r\n\r\n  onInlineToolClick(e: ICoreButtonVNS, row: any): void {\r\n    console.log(\"onInlineToolClick\", e, row)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n  }\r\n\r\n}\r\n","<div #coreTable class=\"core-table-container\" [class.hide-search]=\"!!!searchActive\">\r\n    <div class=\"search-toggler d-flex-center pointer\" (click)=\"toggleAllowSearch()\" *ngIf=\"!!!searchSwitchDisabled\">\r\n        <i class=\"feather-search\"></i>\r\n    </div>\r\n\r\n    <!-- \r\n        Cần truyền chính xác height của CoreTable\r\n        Tuy nhiên chiều cao của CoreTable cần được tính dựa vào chiều cao của các phần tử DOM lần lượt từ lớp ngoài vào lớp trong\r\n        Anh em chưa tính khi triển khai code, nên đang cần có con số default là 400px\r\n    -->\r\n    <table [class.wrap]=\"!!wrap\" #table [ngStyle]=\"{ height: (height || 400) + 'px' }\">\r\n        <colgroup>\r\n            <col *ngIf=\"showCheckbox\">\r\n            <col *ngFor=\"let col of visibleColumns; let col_index = index\">\r\n            <col *ngIf=\"showTools\">\r\n        </colgroup>\r\n        <thead>\r\n            <tr #firstHeaderRow data-row=\"1\" [ngStyle]=\"{\r\n                height: headerFirstRowHeight + 'px'\r\n            }\">\r\n                <th class=\"check-col-header check-cell frozen-col\" *ngIf=\"showCheckbox\" \r\n                    style=\"left: 0px\"\r\n                    [attr.rowspan]=\"searchActive ? 2 : 1\" [ngStyle]=\"{\r\n                        backgroundColor: '#666666',\r\n                        color: 'white'\r\n                    }\">\r\n                    <!-- please do not change -->\r\n                    <div [ngStyle]=\"{\r\n                        width: checkboxSize * 2 + 'px'\r\n                    }\">\r\n                        <label class=\"checkwrap\" [ngStyle]=\"{\r\n                            height: searchActive ? headerFirstRowHeight + headerSecondRowHeight + 'px' : headerFirstRowHeight + 'px'\r\n                        }\">\r\n                            <input type=\"checkbox\" [id]=\"'check-col-header' + id\" [(ngModel)]=\"headerCheckboxState\"\r\n                                (ngModelChange)=\"toggleCheckAll($event)\">\r\n                            <span class=\"checkmark\" [class.mixed]=\"checkingState===2\" [ngStyle]=\"{\r\n                                top: (headerFirstRowHeight/2 - checkboxSize/2) + 'px'\r\n                            }\"></span>\r\n                        </label>\r\n                    </div>\r\n                </th>\r\n                <th *ngFor=\"let col of visibleColumns; let col_index = index\" [class.frozen-col]=\"col_index < frozen\"\r\n                    [style]=\"col_index < frozen ? 'left: ' + frozenLefts[col_index] + 'px' : ''\" [ngStyle]=\"{\r\n                        backgroundColor: '#666666',\r\n                        color: 'white',\r\n                        padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                    }\">\r\n                    <!-- -1px for borderBottom of header first row -->\r\n                    <div class=\"column-caption\" [class.ascending]=\"col.sortDirection===-1\"\r\n                        [class.descending]=\"col.sortDirection===1\" \r\n                        (click)=\"onColumnCaptionClickLocal(col)\" [appTooltip]=\"col.caption | translate : lang\"\r\n                        [ngStyle]=\"{\r\n                            width: col.width + 'px',\r\n                            height: (headerFirstRowHeight - 1) + 'px',\r\n                            display: 'flex',\r\n                            alignItems: 'center',\r\n                            whiteSpace: !!headerWrap ? 'initial' : 'inherit',\r\n                            textAlign: 'center'\r\n                        }\"\r\n                        >{{\r\n                        col.caption | translate : lang }}</div>\r\n                    <div class=\"resizer\" (mousedown)=\"startDragging($event, col, false)\"\r\n                        (mouseup)=\"stopDragging($event, col, false)\" (mousemove)=\"moveEvent($event, col)\"></div>\r\n                </th>\r\n                <th class=\"check-col-header check-cell\" *ngIf=\"showTools && visibleColumns?.length\" [ngStyle]=\"{\r\n                    backgroundColor: '#666666',\r\n                    color: 'white'\r\n                }\">\r\n                    <div style=\"width: 100px;\"></div>\r\n                </th>\r\n            </tr>\r\n            <tr *ngIf=\"searchActive\" data-row=\"2\" [class.hiden]=\"!!!searchActive\">\r\n                <th *ngFor=\"let col of visibleColumns; let col_index = index\" [class.frozen-col]=\"col_index < frozen\"\r\n                    [style]=\"col_index < frozen ? 'left: ' + frozenLefts[col_index] + 'px' : ''\" [ngStyle]=\"{\r\n                        backgroundColor: '#666666',\r\n                        color: 'white'\r\n                    }\">\r\n                    <div [style]=\"'width: ' + col.width + 'px;'\" *ngIf=\"!!!col.hideSearchBox\">\r\n                        <input type=\"text\" class=\"form-control search\" [(ngModel)]=\"searchObject[col_index].searchFor\"\r\n                            (ngModelChange)=\"onSearch($event, col_index)\">\r\n                    </div>\r\n                </th>\r\n                <th [ngStyle]=\"{\r\n                    backgroundColor: '#666666',\r\n                    color: 'white'\r\n                }\"></th>\r\n            </tr>\r\n        </thead>\r\n\r\n        <tbody [class.loading]=\"loading\">\r\n            <core-loading-surface [loading]=\"loading\" [height]=\"tbodyheight || 500\"></core-loading-surface>\r\n\r\n            <ng-container>\r\n\r\n                    <tr [ngStyle]=\"{\r\n                        height: hiddenTopHeight + 'px'\r\n                    }\" *ngIf=\"!!lazyLoading\">\r\n                        <td>\r\n                            <div [ngStyle]=\"{\r\n                                height: hiddenTopHeight + 'px'\r\n                            }\">\r\n                            </div>\r\n                        </td>\r\n                    </tr>\r\n\r\n                    <!-- old approach: let row of data -->\r\n                    <tr *ngFor=\"let row of visibleData; let row_index=index\" (click)=\"onClickLocal(row, $event)\"\r\n                        (touchend)=\"onRowTouchend(row_index+startNode)\"\r\n                        [class.active]=\"row.id === activeRow && !!!disableHighlightOnClick\">\r\n\r\n                        <!-- <div class=\"row-item-tools\">\r\n                        <div class=\"row-item-tool\">\r\n                            <div class=\"row-item-tool-wrapper\">\r\n                                <core-button-group-vns [shownItems]=\"inlineToolItems\"\r\n                                    (buttonClick)=\"onInlineToolClick($event, row)\"></core-button-group-vns>\r\n                            </div>\r\n                        </div>\r\n                    </div> -->\r\n\r\n                        <td *ngIf=\"showCheckbox\" class=\"check-cell frozen-col\" style=\"left: 0px;\">\r\n                            <label class=\"checkwrap\">\r\n                                <input type=\"checkbox\" class=\"check-row\" [id]=\"'check-row' + (row_index + startNode)\"\r\n                                    [(ngModel)]=\"checkingModel[row_index+startNode]\" (ngModelChange)=\"onCheckingNgModelChange()\">\r\n                                <span class=\"checkmark\"></span>\r\n                            </label>\r\n                        </td>\r\n                        <td *ngFor=\"let col of visibleColumns; let col_index = index\"\r\n                            [class.frozen-col]=\"col_index < frozen\"\r\n                            [ngStyle]=\"{\r\n                                left: col_index < frozen ? frozenLefts[col_index] + 'px' : '0px',\r\n                                padding: !!noPaddingCell ? '0px 0px' : '2px 0px'\r\n                            }\">\r\n\r\n                            <!-- IN MOST CASES WE NEED TO RENDER THE CELL WITH PRIMITIVE TYPE -->\r\n                            <div [class.scroll-y]=\"allowCellScrollY\" [ngStyle]=\"{\r\n                                    width: !!col.width ? col.width + 'px' : 'unset',\r\n                                    textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                    lineHeight: rowHeight,\r\n                                    padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                }\" *ngIf=\"!!!col?.templateRef\" [appTooltip]=\"row[col.field] | tableCell: col.pipe : lang\">{{\r\n                                            row[col.field] | tableCell: col.pipe : lang }}</div>\r\n                            <!------------------------------------------------------------------>\r\n\r\n                            <!-- BUT SOME TIME WE NEED TO RENDER THE CELL WITH TEMPLATE -->\r\n                            <div *ngIf=\"!!col?.templateRef\" [ngStyle]=\"{\r\n                                        width: !!col.width ? col.width + 'px' : 'unset',\r\n                                        textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                        padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                    }\">\r\n                                <ng-container *ngIf=\"!!!col?.templateRefAllowEditOnRowActived\">\r\n                                    <ng-container\r\n                                        *ngTemplateOutlet=\"col?.templateRef!; context: { context: row }\"></ng-container>\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"!!col?.templateRefAllowEditOnRowActived\">\r\n                                    <ng-container\r\n                                        *ngTemplateOutlet=\"col?.templateRef!; context: { context: row, allowEdit: row.id === activeRow }\"></ng-container>\r\n                                </ng-container>\r\n                            </div>\r\n                            <!------------------------------------------------------------------>\r\n\r\n                        </td>\r\n                        <td *ngIf=\"showTools\">\r\n                            <div class=\"tools-group d-flex-center\">\r\n                                <div *ngFor=\"let tool of tools; let tool_index = index\"\r\n                                    [class]=\"'tools-icon ' + tool.class\"\r\n                                    [class.disabled]=\"tool.disabledFn ? tool.disabledFn!(row) : false\"\r\n                                    [class.hidden]=\"tool.hiddenFn ? tool.hiddenFn!(row) : false\"\r\n                                    (click)=\"onToolClickLocal(row_index+startNode, tool_index)\"></div>\r\n                            </div>\r\n                        </td>\r\n                    </tr>\r\n\r\n                    <tr [ngStyle]=\"{\r\n                        height: hiddenBottomHeight + 'px'\r\n                    }\" *ngIf=\"!!lazyLoading\">\r\n                        <td>\r\n                            <div [ngStyle]=\"{\r\n                                height: hiddenBottomHeight + 'px'\r\n                            }\">\r\n                            </div>\r\n                        </td>\r\n                    </tr>\r\n\r\n            </ng-container>\r\n\r\n        </tbody>\r\n        <tfoot *ngIf=\"!!footer\">\r\n            Footer\r\n        </tfoot>\r\n    </table>\r\n</div>"]}
474
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, AfterViewInit, OnChanges, ViewChild, SimpleChanges, Output, EventEmitter, TemplateRef, isDevMode } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport enum ECoreTableToolCode {\r\n  edit = 'edit',\r\n  delete = 'delete',\r\n  complete = 'complete',\r\n  navigate = 'navigate',\r\n}\r\n\r\nexport enum ECoreTableToolClass {\r\n  edit = 'edit-icon',\r\n  delete = 'delete-icon',\r\n  repeat = 'repeat-icon',\r\n  navigate = 'navigate-icon'\r\n}\r\n\r\nexport interface ICoreTableToolItem {\r\n  code: ECoreTableToolCode;\r\n  class: ECoreTableToolClass;\r\n  caption?: EnumTranslateKey | string; // Later we will remove \"| string\"\r\n\r\n  /* callbacks to calculate disabled and hiden based on row*/\r\n  disabledFn?: (row: any) => boolean;\r\n  hiddenFn?: (row: any) => boolean;\r\n}\r\n\r\nexport interface ICoreTableToolClickEventEmitterData {\r\n  code: ECoreTableToolCode;\r\n  id: string | number;\r\n}\r\n\r\n/*\r\nexport interface ICoreTableRowDoubleClickEventEmitterData {\r\n  id: string | number;\r\n}\r\n*/\r\n\r\ninterface IDoubleTouchendData {\r\n  previous: number;\r\n  current: number;\r\n}\r\n\r\nimport { Subscription, BehaviorSubject, filter, debounceTime, Observable, fromEvent } from 'rxjs';\r\nimport { CorePageListService } from '../core-page-list/core-page-list.service';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { ICoreButtonVNS } from '../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { ISearchItem } from '../../interfaces/IQueryListRequest';\r\nimport { LayoutService } from '../../services/layout.service';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { AlertService } from '../alert/alert.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { noneAutoClosedAlertOptions } from '../../constants/alertOptions';\r\nimport { ICoreTableColumnItem } from './ICoreTableColumnItem';\r\nimport { EnumSortDirection } from '../../enum/EnumSortDirection';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreButtonGroupComponent } from '../core-button-group/core-button-group/core-button-group.component';\r\nimport { ThreedotsComponent } from '../threedots/threedots.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { CoreLoadingSurfaceComponent } from '../core-loading-surface/core-loading-surface/core-loading-surface.component';\r\nimport { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { TableCellPipe } from '../pipes/table-cell.pipe';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\n\r\n@Component({\r\n  selector: 'core-table',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    CoreButtonGroupComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TableCellPipe,\r\n    TranslatePipe,\r\n    CoreLoadingSurfaceComponent,\r\n    CoreButtonGroupVnsComponent,\r\n  ],\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreTableComponent\r\n    }\r\n  ]\r\n})\r\nexport class CoreTableComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnChanges, OnDestroy {\r\n\r\n  /*\r\n  This component displays input data without pagination.\r\n  For paginating please organize from parents\r\n  */\r\n\r\n  @Input() id!: string; // for html id identifying\r\n  @Input() width!: string;\r\n  @Input() height!: number;\r\n  @Input() showCheckbox!: boolean;\r\n  @Input() checkboxSize!: number;\r\n  @Input() outerButtons!: ICoreButtonVNS[];\r\n  @Input() showTools!: boolean;\r\n  @Input() tools!: ICoreTableToolItem[];\r\n  @Input() checkingResetFlag!: boolean;\r\n\r\n  /* change these 2 props to wrap header texts */\r\n  @Input() headerWrap!: boolean;\r\n  @Input() headerFirstRowHeight!: number;\r\n  /** */\r\n  \r\n  @Input() headerSecondRowHeight!: number;\r\n  @Input() wrap!: boolean;\r\n  @Input() allowCellScrollY!: boolean;\r\n  @Input() loading!: boolean;\r\n  @Input() rowHeight!: string; // VERY IMPORTANT PROPERTY\r\n  @Input() frozen!: number;\r\n  @Input() footer!: any;\r\n  @Input({ required: true }) columns!: ICoreTableColumnItem[]; // required\r\n  @Input() data!: any[]; // required\r\n  @Input() selectedIds!: string[] | number[];\r\n  @Input() corePageListInstanceNumber!: number;\r\n  @Input() disableHighlightOnClick!: boolean;\r\n  @Input() freeMode!: boolean;\r\n  @Input() searchSwitchDisabled: boolean = false;\r\n  @Input() inlineToolItems!: EnumCoreButtonVNSCode[];\r\n  @Input() columnSearchDefaultOpen!: boolean;\r\n  @Input() lazyLoading!: boolean;\r\n\r\n  @Input() noPaddingCell!: boolean;\r\n\r\n  @Output() onSearching = new EventEmitter<ISearchItem[]>();\r\n  @Output() onToolClick = new EventEmitter<ICoreTableToolClickEventEmitterData>();\r\n  @Output() onRowClick = new EventEmitter();\r\n  @Output() onRowDoubleClick = new EventEmitter();\r\n  @Output() onSelectedIdsChange = new EventEmitter<string[] | number[]>();\r\n  @Output() onSelectedDataChange = new EventEmitter<any[]>();\r\n  @Output() onColumnCaptionClick = new EventEmitter<ICoreTableColumnItem>();\r\n\r\n  checkboxColumnWidth: number = 30; // (--checkbox-size)* 2 Please do not change this\r\n\r\n  searchActive!: boolean;\r\n  visibleColumns!: ICoreTableColumnItem[];\r\n  frozenLefts: number[] = [];\r\n  checkingModel: boolean[] = [];\r\n  headerCheckboxState!: boolean;\r\n  checkingState!: number; // 0=none; 1=all; 2=mixed\r\n  tbodyheight!: number;\r\n  visibleRowCount!: number;\r\n\r\n  rowTouchendStream$: BehaviorSubject<IDoubleTouchendData> = new BehaviorSubject<IDoubleTouchendData>({ previous: -2, current: -1 });\r\n  subscriptions: Subscription[] = [];\r\n\r\n  searchObject!: ISearchItem[];\r\n\r\n  lang!: string;\r\n\r\n  activeRow!: any; // number | string\r\n\r\n  mouseDown = false;\r\n  startX: any;\r\n  endX: any;\r\n\r\n  scrollStream$!: Observable<any>;\r\n\r\n  /* FOR LAZY UI LOADING */\r\n  renderAhread: number = 0;\r\n  hiddenTopHeight: number = 0;\r\n  hiddenBottomHeight: number = 0;\r\n  scrollTop: number = 0;\r\n  offsetY: number = 0;\r\n  visibleData!: any[];\r\n  startNode: number = 0;\r\n  /***********************/\r\n\r\n  @ViewChild('coreTable') coreTable!: ElementRef;\r\n  @ViewChild('table') table!: ElementRef;\r\n  @ViewChild('firstHeaderRow') firstHeaderRow!: ElementRef;\r\n\r\n  constructor(\r\n    private layoutService: LayoutService,\r\n    private corePageListService: CorePageListService,\r\n    private mls: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private authService: AuthService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  calculateScroll(): void {\r\n\r\n    try {\r\n\r\n      if (!!!this.coreTable) return;\r\n      if (!!!this.lazyLoading) return;\r\n\r\n      const height = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--height').replace('px', ''));\r\n      const rowHeight = Number(getComputedStyle(this.coreTable.nativeElement).getPropertyValue('--row-height').split('px')[0]);\r\n\r\n      if (!!!rowHeight) throw new Error(\"Could not get --row-height property\");\r\n\r\n      let startNode = Math.floor(this.scrollTop / rowHeight) - this.renderAhread;\r\n      startNode = Math.max(0, startNode);\r\n      this.startNode = startNode || 0;\r\n      let visibleNodeCount = Math.ceil(height / rowHeight) + 2 * this.renderAhread;\r\n      visibleNodeCount = Math.min(this.data.length - startNode, visibleNodeCount);\r\n      this.offsetY = startNode * rowHeight;\r\n      const newVisibleData: any[] = [];\r\n\r\n      this.hiddenTopHeight = startNode * rowHeight;\r\n      this.hiddenBottomHeight = (this.data.length - startNode - visibleNodeCount) * rowHeight;\r\n      for (let i = startNode; i < startNode + visibleNodeCount; i++) {\r\n        newVisibleData.push(this.data[i])\r\n      }\r\n\r\n      this.visibleData = newVisibleData;\r\n\r\n      /* OPEN COMMENTS TO SEE CONTROL VALUES */\r\n      console.log(\"startNode\", startNode)\r\n      /*\r\n      console.log(\"this.offsetY\", this.offsetY)\r\n      console.log(\"this.hiddenTopHeight\", this.hiddenTopHeight)\r\n      console.log(\"this.hiddenBottomHeight\", this.hiddenBottomHeight)\r\n      console.log(\"this.visibleData.length\", this.visibleData.length)\r\n      const controlValue = (this.hiddenTopHeight + this.hiddenBottomHeight + this.visibleData.length * rowHeight) / rowHeight\r\n      console.log(\"controlValue\", controlValue) // Must equeal pageSize\r\n      */\r\n    } catch (error: any) {\r\n      if (isDevMode() && this.authService.data$.value?.id === '8c24683d-7d52-4f5a-8090-31c777e8869d') {\r\n        this.alertService.error(error.message, noneAutoClosedAlertOptions);\r\n      }\r\n\r\n      this.visibleData = JSON.parse(JSON.stringify(this.data));\r\n\r\n    }\r\n  }\r\n\r\n  startDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (e.buttons === 1) {\r\n      this.startX = e.pageX;\r\n      if (!!!this.mouseDown) {\r\n\r\n      }\r\n      this.mouseDown = true;\r\n    }\r\n  }\r\n\r\n  stopDragging(e: any, col: ICoreTableColumnItem, flag: any) {\r\n    if (!!this.mouseDown) {\r\n      this.endX = e.pageX;\r\n      let offset = this.endX - this.startX;\r\n      col.width! += offset;\r\n      this.mouseDown = false;\r\n      this.endX = 0;\r\n      this.startX = 0;\r\n    }\r\n  }\r\n\r\n  moveEvent(e: any, col: ICoreTableColumnItem) {\r\n    e.preventDefault();\r\n    if (!this.mouseDown) {\r\n      return;\r\n    }\r\n    const x = e.pageX;\r\n    console.log(\"moveEvent\", e.pageX)\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.showCheckbox) {\r\n      if (!this.checkboxSize) {\r\n        this.checkboxSize = 15;\r\n      }\r\n    }\r\n\r\n    if (this.headerFirstRowHeight === undefined) this.headerFirstRowHeight = 40;\r\n    if (this.headerSecondRowHeight === undefined) this.headerSecondRowHeight = 40;\r\n\r\n\r\n    /* Validate columns input to make sure one of fields is 'id' */\r\n    if (!!!this.columns) {\r\n      this.alertService.error(this.id + \": Columns are not defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    if (this.columns?.filter((c: ICoreTableColumnItem) => c.field === 'id').length === 0 && isDevMode() && this.columns.length) {\r\n      this.alertService.error(this.id + \": The columns must have one with 'field' property === 'id'\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden)\r\n    if (!!!this.visibleColumns.length && isDevMode() && this.columns.length) {\r\n      this.alertService.error(this.id + \": No visible column defined.\", noneAutoClosedAlertOptions)\r\n    }\r\n\r\n    // add default sort direction to visibleColumns\r\n    this.visibleColumns.map(c => c.sortDirection = EnumSortDirection.NONE)\r\n\r\n    /* START: Initializing searchObject */\r\n    const newSearchObject: ISearchItem[] = [];\r\n    this.visibleColumns.map(c => {\r\n      newSearchObject.push({\r\n        field: c.field,\r\n        searchFor: ''\r\n      })\r\n    })\r\n    this.searchObject = newSearchObject;\r\n    /* END: Initializing searchObject */\r\n\r\n    const frozenColumns = this.visibleColumns.filter((_, index) => index < this.frozen);\r\n\r\n    let left = this.checkboxSize! * 2 || 0; // the first size is for checkbox\r\n    frozenColumns.map(c => {\r\n      if (!!!c.width) console.error(this.id + \": Each frozen column must have its number property 'width'.\");\r\n      this.frozenLefts.push(left);\r\n      left = left + c.width!\r\n    })\r\n\r\n    this.subscriptions.push(\r\n      this.rowTouchendStream$.pipe(\r\n        filter((x: any) => x.current === x.previous),\r\n        debounceTime(200),\r\n      ).subscribe((y: any) => {\r\n        this.onRowDoubleClick.emit({\r\n          id: this.data[y.current].id\r\n        })\r\n      })\r\n    )\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => this.lang = x)\r\n    )\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n    if (changes['checkingResetFlag']) {\r\n      if (!!this.data) {\r\n        this.toggleCheckAll(false)\r\n        this.headerCheckboxState = false;\r\n      }\r\n    }\r\n\r\n    if (changes['data']) {\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['data'].currentValue?.map((_: any) => {\r\n        newCheckingModel.push(false)\r\n      });\r\n      this.checkingModel = newCheckingModel;\r\n\r\n      if (!!this.lazyLoading) {\r\n        if (!!this.coreTable) {\r\n          this.calculateScroll();\r\n        }\r\n      } else {\r\n        this.visibleData = changes['data'].currentValue;\r\n      }\r\n    }\r\n\r\n    if (changes['checkedIds']) {\r\n      const newCheckingModel: boolean[] = [];\r\n      changes['checkedIds'].currentValue?.map((checkedId: any) => {\r\n        this.data.map((item) => {\r\n          if (item['id'] === checkedId) {\r\n            newCheckingModel.push(true);\r\n          } else {\r\n            newCheckingModel.push(false);\r\n          }\r\n        })\r\n      })\r\n      this.checkingModel = newCheckingModel;\r\n    }\r\n    if (changes['loading']) {\r\n      this.loading = changes['loading'].currentValue;\r\n    }\r\n    if (changes['columns']) {\r\n      this.visibleColumns = this.columns?.filter((c: ICoreTableColumnItem) => !!!c.hidden) || []\r\n    }\r\n    if (changes['columnSearchDefaultOpen']) {\r\n      this.searchActive = !!changes['columnSearchDefaultOpen'].currentValue\r\n    }\r\n  }\r\n\r\n  private resetHeaderFirstRowHeight(): void {\r\n    setTimeout(() => {\r\n      const firstHeaderRowHeight = this.firstHeaderRow.nativeElement.getBoundingClientRect().height;\r\n      this.coreTable.nativeElement.style.setProperty('--header-1st-row-height',\r\n      firstHeaderRowHeight + 'px'\r\n      );\r\n    })\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    if (this.corePageListInstanceNumber) {\r\n      const callerFilter = this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber);\r\n      if (!!callerFilter.length) {\r\n        const caller = callerFilter[0];\r\n        caller.coreTableRef = this.coreTable;\r\n      }\r\n\r\n      if (!!!this.freeMode) {\r\n        this.subscriptions.push(\r\n          this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].id$.subscribe(x => {\r\n            this.activeRow = x;\r\n          })\r\n        )\r\n      }\r\n\r\n      this.subscriptions.push(\r\n        this.corePageListService.instances.filter(x => x.instanceNumber === this.corePageListInstanceNumber)[0].tbodyHeight$.subscribe(x => {\r\n          if (!!x) {\r\n            this.tbodyheight = x;\r\n          }\r\n        })\r\n      )\r\n\r\n      const rect = this.coreTable.nativeElement.getBoundingClientRect();\r\n      this.coreTable.nativeElement.style.setProperty('--table-width', rect.width + 'px')\r\n\r\n    }\r\n\r\n    this.scrollStream$ = fromEvent(this.table.nativeElement, 'scroll');\r\n\r\n    setTimeout(() => {\r\n\r\n      if (!!this.width) this.coreTable.nativeElement.style.setProperty('--width', this.width + 'px');\r\n      if (!!this.rowHeight) this.coreTable.nativeElement.style.setProperty('--row-height', this.rowHeight + 'px');\r\n      if (!!this.height) this.coreTable.nativeElement.style.setProperty('--height', this.height + 'px');\r\n\r\n      // Chỉ subscride sau khi các lệnh trên đã được thực hiện\r\n      this.subscriptions.push(\r\n        this.scrollStream$\r\n          .pipe(\r\n            debounceTime(50)\r\n          )\r\n          .subscribe(event => {\r\n            this.scrollTop = event.srcElement.scrollTop;\r\n            this.calculateScroll();\r\n          })\r\n      )\r\n\r\n    }, 0)\r\n\r\n    this.resetHeaderFirstRowHeight();\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(_ => {\r\n        this.resetHeaderFirstRowHeight();\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  onToolClickLocal(rowIndex: number, toolIndex: number): void {\r\n    this.onToolClick.emit({\r\n      code: this.tools[toolIndex].code,\r\n      id: this.data[rowIndex].id\r\n    })\r\n  }\r\n\r\n  toggleCheckAll(args: boolean) {\r\n    const newCheckingModel: boolean[] = [];\r\n    const newSelectedIds: any[] = [];\r\n    const newSelectedData: any[] = [];\r\n\r\n    this.data.map(item => {\r\n      newCheckingModel.push(args);\r\n      if (args) {\r\n        newSelectedIds.push(item.id);\r\n        newSelectedData.push(item);\r\n      }\r\n    });\r\n\r\n    this.checkingModel = newCheckingModel;\r\n    this.checkingState = args ? 1 : 0;\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n  }\r\n\r\n  onCheckingNgModelChange() {\r\n    const newSelectedIds: number[] = [];\r\n    const newSelectedData: any[] = [];\r\n    this.data.filter((_: any, index: number) => !!this.checkingModel[index]).map(item => {\r\n      newSelectedIds.push(item.id)\r\n      newSelectedData.push(item)\r\n    })\r\n    this.onSelectedIdsChange.emit(newSelectedIds);\r\n    this.onSelectedDataChange.emit(newSelectedData);\r\n\r\n    if (newSelectedIds.length === 0) {\r\n      this.checkingState = 0; // none\r\n    } else if (newSelectedIds.length === this.checkingModel.length) {\r\n      this.checkingState = 1; // all\r\n    } else {\r\n      this.checkingState = 2; // mixed\r\n    }\r\n\r\n  }\r\n\r\n  onDoubleClickLocal(rowIndex: number) {\r\n    this.onRowDoubleClick.emit(this.data[rowIndex])\r\n  }\r\n\r\n  onClickLocal(row: any, event: any) {\r\n\r\n    console.log(\"onClickLocal row\", row, \"event\", event)\r\n\r\n    if (event.detail === 1) {\r\n      this.activeRow = row.id;\r\n      this.onRowClick.emit(row);\r\n    } else if (event.detail === 2) {\r\n      this.onRowDoubleClick.emit(row)\r\n    }\r\n\r\n  }\r\n\r\n  onRowTouchend(rowIndex: number) {\r\n    this.rowTouchendStream$.next({\r\n      previous: this.rowTouchendStream$.value.current,\r\n      current: rowIndex\r\n    });\r\n  }\r\n\r\n  onSearch(e: string, searchColumnIndex: number): void {\r\n    this.searchObject.filter((_, i) => i === searchColumnIndex)[0].searchFor = e;\r\n    this.onSearching.emit(this.searchObject);\r\n  }\r\n\r\n  onColumnCaptionClickLocal(column: ICoreTableColumnItem) {\r\n\r\n    if (!!column.templateRef) return; // no action for templateRef type\r\n\r\n    this.onColumnCaptionClick.emit(column);\r\n\r\n    // update sort dicrection property of this column\r\n    // and clear up the property for the other visibleColumns\r\n    this.visibleColumns.map(vc => {\r\n      if (vc.field === column.field) {\r\n        vc.sortDirection = vc.sortDirection === EnumSortDirection.NONE ? EnumSortDirection.ASC : vc.sortDirection === EnumSortDirection.ASC ? EnumSortDirection.DESC : EnumSortDirection.NONE;\r\n      } else {\r\n        vc.sortDirection = EnumSortDirection.NONE\r\n      }\r\n    })\r\n  }\r\n\r\n  toggleAllowSearch(): void {\r\n    this.searchActive = !!!this.searchActive\r\n  }\r\n\r\n  onInlineToolClick(e: ICoreButtonVNS, row: any): void {\r\n    console.log(\"onInlineToolClick\", e, row)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n  }\r\n\r\n}\r\n","<div #coreTable class=\"core-table-container\" [class.hide-search]=\"!!!searchActive\">\r\n    <div class=\"search-toggler d-flex-center pointer\" (click)=\"toggleAllowSearch()\" *ngIf=\"!!!searchSwitchDisabled\">\r\n        <i class=\"feather-search\"></i>\r\n    </div>\r\n\r\n    <!-- \r\n        Cần truyền chính xác height của CoreTable\r\n        Tuy nhiên chiều cao của CoreTable cần được tính dựa vào chiều cao của các phần tử DOM lần lượt từ lớp ngoài vào lớp trong\r\n        Anh em chưa tính khi triển khai code, nên đang cần có con số default là 400px\r\n    -->\r\n    <table [class.wrap]=\"!!wrap\" #table [ngStyle]=\"{ height: (height || 400) + 'px' }\">\r\n        <colgroup>\r\n            <col *ngIf=\"showCheckbox\">\r\n            <col *ngFor=\"let col of visibleColumns; let col_index = index\">\r\n            <col *ngIf=\"showTools\">\r\n        </colgroup>\r\n        <thead>\r\n            <tr #firstHeaderRow data-row=\"1\" [ngStyle]=\"{\r\n                height: headerFirstRowHeight + 'px'\r\n            }\">\r\n                <th class=\"check-col-header check-cell frozen-col\" *ngIf=\"showCheckbox\" \r\n                    style=\"left: 0px\"\r\n                    [attr.rowspan]=\"searchActive ? 2 : 1\" [ngStyle]=\"{\r\n                        backgroundColor: '#666666',\r\n                        color: 'white'\r\n                    }\">\r\n                    <!-- please do not change -->\r\n                    <div [ngStyle]=\"{\r\n                        width: checkboxSize * 2 + 'px'\r\n                    }\">\r\n                        <label class=\"checkwrap\" [ngStyle]=\"{\r\n                            height: searchActive ? headerFirstRowHeight + headerSecondRowHeight + 'px' : headerFirstRowHeight + 'px'\r\n                        }\">\r\n                            <input type=\"checkbox\" [id]=\"'check-col-header' + id\" [(ngModel)]=\"headerCheckboxState\"\r\n                                (ngModelChange)=\"toggleCheckAll($event)\">\r\n                            <span class=\"checkmark\" [class.mixed]=\"checkingState===2\" [ngStyle]=\"{\r\n                                top: (headerFirstRowHeight/2 - checkboxSize/2) + 'px'\r\n                            }\"></span>\r\n                        </label>\r\n                    </div>\r\n                </th>\r\n                <th *ngFor=\"let col of visibleColumns; let col_index = index\" [class.frozen-col]=\"col_index < frozen\"\r\n                    [style]=\"col_index < frozen ? 'left: ' + frozenLefts[col_index] + 'px' : ''\" [ngStyle]=\"{\r\n                        backgroundColor: '#666666',\r\n                        color: 'white',\r\n                        padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                    }\">\r\n                    <!-- -1px for borderBottom of header first row -->\r\n                    <div class=\"column-caption\" [class.ascending]=\"col.sortDirection===-1\"\r\n                        [class.descending]=\"col.sortDirection===1\" \r\n                        (click)=\"onColumnCaptionClickLocal(col)\" [appTooltip]=\"col.caption | translate : lang\"\r\n                        [ngStyle]=\"{\r\n                            width: col.width + 'px',\r\n                            height: (headerFirstRowHeight - 1) + 'px',\r\n                            display: 'flex',\r\n                            alignItems: 'center',\r\n                            whiteSpace: !!headerWrap ? 'initial' : 'inherit',\r\n                            textAlign: 'center'\r\n                        }\"\r\n                        >{{\r\n                        col.caption | translate : lang }}</div>\r\n                    <div class=\"resizer\" (mousedown)=\"startDragging($event, col, false)\"\r\n                        (mouseup)=\"stopDragging($event, col, false)\" (mousemove)=\"moveEvent($event, col)\"></div>\r\n                </th>\r\n                <th class=\"check-col-header check-cell\" *ngIf=\"showTools && visibleColumns?.length\" [ngStyle]=\"{\r\n                    backgroundColor: '#666666',\r\n                    color: 'white'\r\n                }\">\r\n                    <div style=\"width: 100px;\"></div>\r\n                </th>\r\n            </tr>\r\n            <tr *ngIf=\"searchActive\" data-row=\"2\" [class.hiden]=\"!!!searchActive\">\r\n                <th *ngFor=\"let col of visibleColumns; let col_index = index\" [class.frozen-col]=\"col_index < frozen\"\r\n                    [style]=\"col_index < frozen ? 'left: ' + frozenLefts[col_index] + 'px' : ''\" [ngStyle]=\"{\r\n                        backgroundColor: '#666666',\r\n                        color: 'white'\r\n                    }\">\r\n                    <div [style]=\"'width: ' + col.width + 'px;'\" *ngIf=\"!!!col.hideSearchBox\">\r\n                        <input type=\"text\" class=\"form-control search\" [(ngModel)]=\"searchObject[col_index].searchFor\"\r\n                            (ngModelChange)=\"onSearch($event, col_index)\">\r\n                    </div>\r\n                </th>\r\n                <th [ngStyle]=\"{\r\n                    backgroundColor: '#666666',\r\n                    color: 'white'\r\n                }\"></th>\r\n            </tr>\r\n        </thead>\r\n\r\n        <tbody [class.loading]=\"loading\">\r\n            <core-loading-surface [loading]=\"loading\" [height]=\"tbodyheight || 500\"></core-loading-surface>\r\n\r\n            <ng-container>\r\n\r\n                    <tr [ngStyle]=\"{\r\n                        height: hiddenTopHeight + 'px'\r\n                    }\" *ngIf=\"!!lazyLoading\">\r\n                        <td>\r\n                            <div [ngStyle]=\"{\r\n                                height: hiddenTopHeight + 'px'\r\n                            }\">\r\n                            </div>\r\n                        </td>\r\n                    </tr>\r\n\r\n                    <!-- old approach: let row of data -->\r\n                    <tr *ngFor=\"let row of visibleData; let row_index=index\" (click)=\"onClickLocal(row, $event)\"\r\n                        (touchend)=\"onRowTouchend(row_index+startNode)\"\r\n                        [class.active]=\"row.id === activeRow && !!!disableHighlightOnClick\">\r\n\r\n                        <!-- <div class=\"row-item-tools\">\r\n                        <div class=\"row-item-tool\">\r\n                            <div class=\"row-item-tool-wrapper\">\r\n                                <core-button-group-vns [shownItems]=\"inlineToolItems\"\r\n                                    (buttonClick)=\"onInlineToolClick($event, row)\"></core-button-group-vns>\r\n                            </div>\r\n                        </div>\r\n                    </div> -->\r\n\r\n                        <td *ngIf=\"showCheckbox\" class=\"check-cell frozen-col\" style=\"left: 0px;\">\r\n                            <label class=\"checkwrap\">\r\n                                <input type=\"checkbox\" class=\"check-row\" [id]=\"'check-row' + (row_index + startNode)\"\r\n                                    [(ngModel)]=\"checkingModel[row_index+startNode]\" (ngModelChange)=\"onCheckingNgModelChange()\">\r\n                                <span class=\"checkmark\"></span>\r\n                            </label>\r\n                        </td>\r\n                        <td *ngFor=\"let col of visibleColumns; let col_index = index\"\r\n                            [class.frozen-col]=\"col_index < frozen\"\r\n                            [ngStyle]=\"{\r\n                                left: col_index < frozen ? frozenLefts[col_index] + 'px' : '0px',\r\n                                padding: !!noPaddingCell ? '0px 0px' : '2px 0px'\r\n                            }\">\r\n\r\n                            <!-- IN MOST CASES WE NEED TO RENDER THE CELL WITH PRIMITIVE TYPE -->\r\n                            <div [class.scroll-y]=\"allowCellScrollY\" [ngStyle]=\"{\r\n                                    width: !!col.width ? col.width + 'px' : 'unset',\r\n                                    textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                    lineHeight: rowHeight,\r\n                                    padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                }\" *ngIf=\"!!!col?.templateRef\" [appTooltip]=\"row[col.field] | tableCell: col.pipe : lang\">{{\r\n                                            row[col.field] | tableCell: col.pipe : lang }}</div>\r\n                            <!------------------------------------------------------------------>\r\n\r\n                            <!-- BUT SOME TIME WE NEED TO RENDER THE CELL WITH TEMPLATE -->\r\n                            <div *ngIf=\"!!col?.templateRef\" [ngStyle]=\"{\r\n                                        width: !!col.width ? col.width + 'px' : 'unset',\r\n                                        textAlign: !!col.align ? col.align.toLowerCase() : 'unset',\r\n                                        padding: !!noPaddingCell ? '0px 0px' : '0px 12px'\r\n                                    }\">\r\n                                <ng-container *ngIf=\"!!!col?.templateRefAllowEditOnRowActived\">\r\n                                    <ng-container\r\n                                        *ngTemplateOutlet=\"col?.templateRef!; context: { context: row }\"></ng-container>\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"!!col?.templateRefAllowEditOnRowActived\">\r\n                                    <ng-container\r\n                                        *ngTemplateOutlet=\"col?.templateRef!; context: { context: row, allowEdit: row.id === activeRow }\"></ng-container>\r\n                                </ng-container>\r\n                            </div>\r\n                            <!------------------------------------------------------------------>\r\n\r\n                        </td>\r\n                        <td *ngIf=\"showTools\">\r\n                            <div class=\"tools-group d-flex-center\">\r\n                                <div *ngFor=\"let tool of tools; let tool_index = index\"\r\n                                    [class]=\"'tools-icon ' + tool.class\"\r\n                                    [class.disabled]=\"tool.disabledFn ? tool.disabledFn!(row) : false\"\r\n                                    [class.hidden]=\"tool.hiddenFn ? tool.hiddenFn!(row) : false\"\r\n                                    (click)=\"onToolClickLocal(row_index+startNode, tool_index)\"></div>\r\n                            </div>\r\n                        </td>\r\n                    </tr>\r\n\r\n                    <tr [ngStyle]=\"{\r\n                        height: hiddenBottomHeight + 'px'\r\n                    }\" *ngIf=\"!!lazyLoading\">\r\n                        <td>\r\n                            <div [ngStyle]=\"{\r\n                                height: hiddenBottomHeight + 'px'\r\n                            }\">\r\n                            </div>\r\n                        </td>\r\n                    </tr>\r\n\r\n            </ng-container>\r\n\r\n        </tbody>\r\n        <tfoot *ngIf=\"!!footer\">\r\n            Footer\r\n        </tfoot>\r\n    </table>\r\n</div>"]}
@@ -4705,7 +4705,7 @@ class CoreTableComponent extends CoreFormControlBaseComponent {
4705
4705
  if (this.columns?.filter((c) => c.field === 'id').length === 0 && isDevMode() && this.columns.length) {
4706
4706
  this.alertService.error(this.id + ": The columns must have one with 'field' property === 'id'", noneAutoClosedAlertOptions);
4707
4707
  }
4708
- this.visibleColumns = this.columns.filter((c) => !!!c.hidden);
4708
+ this.visibleColumns = this.columns?.filter((c) => !!!c.hidden);
4709
4709
  if (!!!this.visibleColumns.length && isDevMode() && this.columns.length) {
4710
4710
  this.alertService.error(this.id + ": No visible column defined.", noneAutoClosedAlertOptions);
4711
4711
  }
@@ -4982,7 +4982,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
4982
4982
  }], footer: [{
4983
4983
  type: Input
4984
4984
  }], columns: [{
4985
- type: Input
4985
+ type: Input,
4986
+ args: [{ required: true }]
4986
4987
  }], data: [{
4987
4988
  type: Input
4988
4989
  }], selectedIds: [{