@tsi-developpement/tsi-shared-ui 1.8.9 → 1.8.10

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.
@@ -40,9 +40,9 @@ export class EditableGridComponent extends TsiInputBase {
40
40
  set columns(value) {
41
41
  value.forEach(el => el.translatedHeader = this._localizePipe.transform(el.header ?? ""));
42
42
  this._columns = value;
43
- if (this.selectedColumns.length == 0) {
44
- this.selectedColumns = this._columns;
45
- }
43
+ this.selectedColumns = this._columns;
44
+ this._verifyGridRequirements();
45
+ this._initCurrentRowNumberAndOrderByRowNumber();
46
46
  }
47
47
  set gridData(data) {
48
48
  this._gridData = data;
@@ -161,7 +161,6 @@ export class EditableGridComponent extends TsiInputBase {
161
161
  let columnOrder = state.columnOrder;
162
162
  if (columnOrder) {
163
163
  let reorderedColumns = this.getReorderedColumns(columnOrder);
164
- this.selectedColumns = reorderedColumns;
165
164
  this.columns = reorderedColumns;
166
165
  }
167
166
  }
@@ -184,9 +183,9 @@ export class EditableGridComponent extends TsiInputBase {
184
183
  this.dt.tableWidthState = state.tableWidth;
185
184
  let columnOrder = state.columnOrder;
186
185
  if (columnOrder) {
186
+ this.columns = this._tempColumns;
187
187
  let reorderedColumns = this.getReorderedColumns(columnOrder);
188
188
  this.selectedColumns = reorderedColumns;
189
- this.columns = this._tempColumns;
190
189
  }
191
190
  }
192
191
  }
@@ -253,14 +252,6 @@ export class EditableGridComponent extends TsiInputBase {
253
252
  this.gridData = [...this.gridData];
254
253
  }
255
254
  }
256
- addRowOnLastElement(item, col) {
257
- this._verifyAddRowOnLastElementRequirements();
258
- let itemPosition = this.gridData.indexOf(item);
259
- let colPosition = this.columns.indexOf(col);
260
- if (itemPosition == this.gridData.length - 1 && colPosition == this.columns.length - 1) {
261
- this.addRow();
262
- }
263
- }
264
255
  delete(item) {
265
256
  if (this.editableTable?.sortField && this.editableTable.sortMode) {
266
257
  const index = this.editableTable.value.indexOf(item, 0);
@@ -429,64 +420,31 @@ export class EditableGridComponent extends TsiInputBase {
429
420
  _initSaveEventSubscription() {
430
421
  this.saveEventSubscription = this.events?.subscribe(() => this.saveItems());
431
422
  }
432
- _verifyAddRowOnLastElementRequirements() {
433
- if (this.gridData == null
434
- || this.gridData == undefined) {
435
- throw new Error('gridData can\'t be null');
436
- }
437
- if (this.columns == null
438
- || this.columns == undefined) {
439
- throw new Error('grid columns can\'t be null');
440
- }
441
- else {
442
- let rowNumberColumns = this.columns.filter(c => c.isAutoRowNumberColumn === true);
443
- if (rowNumberColumns.length > 1) {
444
- throw new Error('grid columns can\'t have more than one RowNumberColumn');
445
- }
446
- else if (rowNumberColumns.length == 1) {
447
- this._isAutoRowNumber = true;
448
- this._autoRowNumberField = rowNumberColumns[0].field;
449
- }
450
- }
451
- }
452
423
  _verifyGridRequirements() {
453
424
  if (this.columns == null
454
425
  || this.columns == undefined) {
455
426
  throw new Error('grid columns can\'t be null');
456
427
  }
457
- else {
458
- let rowNumberColumns = this.columns.filter(c => c.isAutoRowNumberColumn === true);
459
- //console.log('rowNumberColumns : ', rowNumberColumns);
460
- if (rowNumberColumns.length > 1) {
461
- throw new Error('grid columns can\'t have more than one RowNumberColumn');
462
- }
463
- else if (rowNumberColumns.length == 1) {
464
- this._isAutoRowNumber = true;
465
- this._autoRowNumberField = rowNumberColumns[0].field;
466
- //console.log('_isAutoRowNumber : ', this._isAutoRowNumber);
467
- //console.log('_autoRowNumberField : ', this._autoRowNumberField);
468
- }
428
+ let rowNumberColumns = this.columns.filter(c => c.isAutoRowNumberColumn === true);
429
+ if (rowNumberColumns.length > 1) {
430
+ throw new Error('grid columns can\'t have more than one RowNumberColumn');
431
+ }
432
+ if (rowNumberColumns.length == 1) {
433
+ this._isAutoRowNumber = true;
434
+ this._autoRowNumberField = rowNumberColumns[0].field;
469
435
  }
470
436
  }
471
437
  _initCurrentRowNumberAndOrderByRowNumber() {
472
- // console.log('_initCurrentRowNumber :: _isAutoRowNumber : ', this._isAutoRowNumber);
473
- // console.log('_initCurrentRowNumber :: _autoRowNumberField : ', this._autoRowNumberField);
474
- // console.log('_initCurrentRowNumber :: gridData : ', this.gridData);
475
438
  if (this._isAutoRowNumber === true
476
439
  && this._autoRowNumberField != undefined
477
440
  && this._autoRowNumberField != null
478
441
  && this.gridData.length > 0) {
479
- // let aux = this.gridData.map(a => a[this._autoRowNumberField]);;
480
- // aux.sort((a, b) => { return -a + b ;});
481
442
  this._orderByRowNumber();
482
443
  this._currentRowNumber = this.gridData[this.gridData.length - 1][this._autoRowNumberField];
483
- //console.log('_initCurrentRowNumber : ',this._currentRowNumber);
484
444
  }
485
- //console.log('_initCurrentRowNumber : ',this._currentRowNumber);
486
445
  }
487
446
  _nextRowNumber() {
488
447
  this._currentRowNumber = this.gridData.length + 1;
489
- //console.log('_nextRowNumber : ', this._currentRowNumber);
490
448
  return this._currentRowNumber;
491
449
  }
492
450
  _onDeleteRow(row) {
@@ -503,7 +461,6 @@ export class EditableGridComponent extends TsiInputBase {
503
461
  this._equalityCheckOn = true;
504
462
  this._equatableFields = equatableColumns.map(c => c.field);
505
463
  }
506
- //console.log('equ fields : ', this._equatableFields);
507
464
  }
508
465
  _initSumAtFusionFields() {
509
466
  let sumAtFusionColumns = this.columns.filter(c => c.isSumAtFusion == true);
@@ -511,7 +468,6 @@ export class EditableGridComponent extends TsiInputBase {
511
468
  this._equalityCheckOn = true;
512
469
  this._sumAtFusionFields = sumAtFusionColumns.map(c => c.field);
513
470
  }
514
- //console.log('sum fields : ', this._sumAtFusionFields);
515
471
  }
516
472
  _tryFindEquatable(row) {
517
473
  let foundEqualRow = false;
@@ -643,4 +599,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
643
599
  }], id: [{
644
600
  type: Input
645
601
  }] } });
646
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editable-grid.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/editable-grid/editable-grid.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/editable-grid/editable-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { SortEvent, TableState } from 'primeng/api';\r\nimport { Table, TableRowSelectEvent, TableRowUnSelectEvent } from 'primeng/table';\r\nimport { Observable, Subscription } from 'rxjs';\r\nimport { rtlModeKeys } from '../../../consts/locals.const';\r\nimport { ButtonType, GridSelectionMode, InputTypes, ModalSizeEnum, TooltipPosition } from '../../../enums';\r\nimport { CellChangedResult, GridColumn, IGridConfiguration, RowAddedResult } from '../../../interfaces';\r\nimport { LocalizePipe } from '../../../pipes/localize.pipe';\r\nimport { EntityValidationsService } from '../../../services/validation/entity-validations.service';\r\nimport { GenericValidationStateService } from '../../../services';\r\nimport { FormState } from '../../../models/form/form-state';\r\nimport { TsiInputBase } from '../../../tsi-base/tsi-input-base/tsi-input-base.component';\r\n\r\n@Component({\r\n  selector: 'Tsi-Generic-Editable-Grid',\r\n  templateUrl: './editable-grid.component.html',\r\n  styleUrls: ['./editable-grid.component.scss'],\r\n  providers: [GenericValidationStateService]\r\n})\r\nexport class EditableGridComponent extends TsiInputBase implements OnInit, OnDestroy {\r\n\r\n  //#region local vars\r\n  //#region private local vars\r\n  private saveEventSubscription?: Subscription;\r\n  private _isAutoRowNumber: boolean = false;\r\n  private _autoRowNumberField: string = '';\r\n  private _currentRowNumber: number = 0;\r\n  tooltipPosition = TooltipPosition;\r\n  isAr: boolean = false;\r\n  private _gridData: Array<any> = [];\r\n  private _equatableFields: Array<string> | undefined;\r\n  private _sumAtFusionFields: Array<string> | undefined;\r\n  private _equalityCheckOn: boolean = false;\r\n  multipleGridSelectionMode = GridSelectionMode.Multiple;\r\n  //#endregion\r\n  inputTypes = InputTypes;\r\n  modalSize = ModalSizeEnum.ExtraLarge;\r\n  @ViewChild(\"editableTable\") editableTable?: Table\r\n\r\n  buttonType = ButtonType;\r\n\r\n  @Input() selectedItems: any = [];\r\n  selectedItem: any;\r\n\r\n  //#endregion\r\n\r\n  //#region Inputs\r\n  @Input('configuration') configuration?: IGridConfiguration;\r\n  @Input('key') key: string = 'uid';\r\n  @Input() items: Array<any> = [];\r\n  @Input('events') saveEvent?: Observable<void>;\r\n  @Input() showAddButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showDeleteButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showEditButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showRowSummary: boolean = false;//TO DO Save Button Option\r\n\r\n  @Input() scrollHeight: string = '500px';\r\n  @Input() rowPerPage: number[] = [5, 10, 20];\r\n  // @Input() isPaginator: boolean = true;\r\n  @Input() pageSize: number = 5\r\n\r\n  /**\r\n   *\r\n   */\r\n  selectedColumns: Array<GridColumn> = [];\r\n  private _columns: Array<GridColumn> = [];\r\n  private _tempColumns: Array<GridColumn> = [];\r\n  get columns(): Array<GridColumn> {\r\n    return this._columns;\r\n  }\r\n\r\n  @Input() set columns(value: Array<GridColumn>) {\r\n    value.forEach(el => el.translatedHeader = this._localizePipe.transform(el.header ?? \"\"));\r\n    this._columns = value\r\n    if (this.selectedColumns.length == 0) {\r\n      this.selectedColumns = this._columns\r\n    }\r\n  }\r\n  @Input() set gridData(data: Array<any>) {\r\n    this._gridData = data;\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n  }\r\n  get gridData() { return this._gridData; }\r\n\r\n  @Input() isTableLoading?: boolean;\r\n\r\n\r\n  @Input() parent: any;\r\n  @Input() events?: Observable<void>;//TO DO Save Button Option\r\n\r\n  @Input() showSaveButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showActionColumn: boolean = true;//TO DO Save Button Option\r\n\r\n\r\n  @Input() enableRowDisabling: boolean = false;\r\n\r\n  @Input() rowSummaryConfig: Array<string> = [];\r\n  @Input() showHaveSumary?: boolean = false;\r\n  @Input() showRowSumary?: boolean = false;\r\n\r\n  /**selection */\r\n  @Input() selectKeyOnly: boolean = true;\r\n  @Input() selectionMode: GridSelectionMode | any = GridSelectionMode.None;\r\n  @Input() showConsultButton: boolean = false;\r\n\r\n  private _editableGridBusinessClass: string = \"\";\r\n  get editableGridBusinessClass() {\r\n    return this._editableGridBusinessClass;\r\n  }\r\n  @Input() set editableGridBusinessClass(className: string) {\r\n    this._editableGridBusinessClass = className;\r\n    this.genericValidationStateService?.loadEntityValidationInfos(this._editableGridBusinessClass);\r\n  }\r\n\r\n\r\n  /**order */\r\n  @Input() orderColumn: string = 'uid';\r\n\r\n  @Input() deleteLineButtonDisabled!: (item: any) => any\r\n\r\n  //#endregion\r\n\r\n  //#region Outputs\r\n  @Output() itemsSave: EventEmitter<any[]> = new EventEmitter<any[]>();\r\n  /**\r\n   *\r\n   */\r\n\r\n\r\n  @Output() refreshEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  //@Output() actionEventEmitter: EventEmitter<GridActionEmitResult> = new EventEmitter<GridActionEmitResult>();\r\n\r\n  @Output() saveDataEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() rowChangedEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() selectedRowEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() addedRowEventEmitter: EventEmitter<RowAddedResult> = new EventEmitter<RowAddedResult>()\r\n\r\n  @Output() focusOutEventEmitter = new EventEmitter<string>();\r\n\r\n  @Output() cellChanged: EventEmitter<CellChangedResult> = new EventEmitter<CellChangedResult>();\r\n\r\n  @Output() rowDeletedEventEmitter = new EventEmitter<any>();\r\n\r\n  @Output() selectedItemsChange: EventEmitter<Array<any>> = new EventEmitter<Array<any>>();\r\n\r\n  @Output() onRowSelect: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() focusOutRow: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onConsultClicked: EventEmitter<any> = new EventEmitter<any>();\r\n  //#endregion\r\n\r\n  @ViewChild(\"dt\", { static: false }) public dt: Table | undefined;\r\n\r\n  @Input() id?: string;\r\n\r\n  private _entityValidationsService = inject(EntityValidationsService);\r\n\r\n  constructor(private _localizePipe: LocalizePipe) {\r\n    super()\r\n  }\r\n\r\n  override ngOnInit() {\r\n    super.ngOnInit()\r\n    this._initSaveEventSubscription();\r\n    this._verifyGridRequirements();\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n    this._initEquatableFields();\r\n    this._initSumAtFusionFields();\r\n    \r\n    let langue = localStorage.getItem(rtlModeKeys.rtlModeEnabled);\r\n    \r\n    if (langue && JSON.parse(langue)) {\r\n      this.isAr = true\r\n    }\r\n    else {\r\n      this.isAr = false\r\n    }\r\n\r\n    if (!this.selectedColumns || this.selectedColumns.length == 0) {\r\n      this.selectedColumns = this.columns\r\n    }\r\n    \r\n    this._tempColumns = this.columns;\r\n  }\r\n\r\n  findColumnByKey(key: any) {\r\n    if (this.columns) {\r\n      for (let col of this.columns) {\r\n        if (col.header === key || col.field === key) return col;\r\n        else continue;\r\n      }\r\n    }\r\n    return null\r\n  }\r\n\r\n\r\n  public restoreState(configuration: string) {\r\n    let state: TableState = JSON.parse(configuration)\r\n    if (this.dt) {\r\n      if (this.dt) {\r\n\r\n        this.dt.columnWidthsState = state.columnWidths;\r\n        this.dt.tableWidthState = state.tableWidth;\r\n\r\n        let columnOrder = state.columnOrder;\r\n\r\n        if (columnOrder) {\r\n          let reorderedColumns = this.getReorderedColumns(columnOrder);\r\n          this.selectedColumns = reorderedColumns;\r\n          this.columns = reorderedColumns;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  getReorderedColumns(columnOrder: string[]): any[] {\r\n    let reorderedColumns: any[] = [];\r\n\r\n    columnOrder.map((key) => {\r\n      let col = this.findColumnByKey(key);\r\n      if (col) {\r\n        reorderedColumns.push(col);\r\n      }\r\n    });\r\n\r\n    return reorderedColumns;\r\n  }\r\n\r\n  resetSelectedColumns(configuration: string) {\r\n    let state: TableState = JSON.parse(configuration)\r\n    if (this.dt) {\r\n\r\n      this.dt.columnWidthsState = state.columnWidths;\r\n      this.dt.tableWidthState = state.tableWidth;\r\n\r\n      let columnOrder = state.columnOrder;\r\n\r\n      if (columnOrder) {\r\n        let reorderedColumns = this.getReorderedColumns(columnOrder);\r\n        this.selectedColumns = reorderedColumns;\r\n        this.columns = this._tempColumns\r\n      }\r\n    }\r\n  }\r\n\r\n  getState() {\r\n    let state: TableState = {};\r\n\r\n    if (!this.dt) {\r\n      return\r\n    }\r\n\r\n    if (this.dt.resizableColumns) {\r\n      this.dt.saveColumnWidths(state);\r\n    }\r\n\r\n    this.dt.saveColumnOrder(state);\r\n\r\n    return state\r\n  }\r\n\r\n  isDeleteButtonDisabled(item: any) {\r\n    if (this.deleteLineButtonDisabled != undefined) {\r\n      return this.deleteLineButtonDisabled(item)\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    super.ngOnDestroy()\r\n    this.saveEventSubscription?.unsubscribe();\r\n  }\r\n\r\n  inputChanged(col: GridColumn) {\r\n    if (col.watchForChanges === true) {\r\n      this.saveDataEventEmitter.emit(this.gridData);\r\n    }\r\n  }\r\n\r\n  saveItems() {\r\n    this.itemsSave.emit(this.gridData);\r\n    this.saveDataEventEmitter.emit(this.gridData);\r\n  }\r\n\r\n  addRow(): void {\r\n    if (!this.gridData) {\r\n      this.gridData = [];\r\n    }\r\n    let newRow = this._initRow()\r\n    this.gridData.push(newRow)\r\n    this.isDirty = true\r\n    let rowAddedResult: RowAddedResult = {\r\n      rowNumber: this.gridData.length - 1,\r\n      data: newRow\r\n    }\r\n\r\n    if (this.editableTable?.sortField && this.editableTable.sortOrder) {\r\n      this.editableTable?.value.push(newRow)\r\n    }\r\n    this.refreshSort()\r\n    this.addedRowEventEmitter.emit(rowAddedResult)\r\n  }\r\n\r\n  refreshSort() {\r\n    if (this.editableTable?.sortField) {\r\n      const sortField = this.editableTable.sortField;\r\n      const sortOrder = this.editableTable.sortOrder;\r\n\r\n      this.gridData.sort((a, b) => {\r\n        const valueA = a[sortField];\r\n        const valueB = b[sortField];\r\n        let result = 0;\r\n\r\n        if (valueA < valueB) result = -1;\r\n        else if (valueA > valueB) result = 1;\r\n\r\n        return result * sortOrder;\r\n      });\r\n\r\n      this.gridData = [...this.gridData];\r\n    }\r\n  }\r\n\r\n  addRowOnLastElement(item: any, col: GridColumn) {\r\n    this._verifyAddRowOnLastElementRequirements();\r\n    let itemPosition = this.gridData.indexOf(item);\r\n    let colPosition = this.columns.indexOf(col);\r\n\r\n    if (itemPosition == this.gridData.length - 1 && colPosition == this.columns.length - 1) {\r\n      this.addRow();\r\n    }\r\n  }\r\n\r\n  delete(item: any) {\r\n    if (this.editableTable?.sortField && this.editableTable.sortMode) {\r\n      const index = this.editableTable.value.indexOf(item, 0);\r\n      if (index > -1) {\r\n        this.editableTable.value.splice(index, 1)\r\n      }\r\n    }\r\n    const index = this.gridData.indexOf(item, 0);\r\n    if (index > -1) {\r\n      this.gridData.splice(index, 1);\r\n      this.isDirty = true\r\n      this._onDeleteRow(item);\r\n      this.rowDeletedEventEmitter.emit(this.gridData)\r\n    }\r\n    this.refreshSort()\r\n  }\r\n\r\n  getSummary(col: GridColumn): number {\r\n    if (col.haveSummary == true) {\r\n\r\n      let sum = 0;\r\n      this.gridData.forEach((row: any) => {\r\n        sum += row[col.field];\r\n      })\r\n      return sum;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  rowSummary(row: any): number {\r\n    let sum = 0;\r\n    this.columns.forEach(col => {\r\n      if (col.rowSummary == true) {\r\n        sum += row[col.field];\r\n      }\r\n    });\r\n    return sum;\r\n\r\n  }\r\n\r\n  onRowSelected(event: TableRowSelectEvent) {\r\n    this.selectedItem = event.data\r\n    if (this.selectKeyOnly == true) {\r\n      let selectionKey: any;\r\n      selectionKey = this.selectedItem[this.key];\r\n      this.onRowSelect.emit(selectionKey);\r\n    }\r\n    else {\r\n      this.onRowSelect.emit(this.selectedItems);\r\n    }\r\n  }\r\n\r\n  onRowUnselect(event: TableRowUnSelectEvent) {\r\n    this.selectedItem = undefined\r\n  }\r\n\r\n  selectionChange(event: any) {\r\n\r\n    let selection: any[] = [];\r\n\r\n    if (this.selectionMode == GridSelectionMode.Multiple) {\r\n      if (this.selectedItems) {\r\n        if (this.selectKeyOnly) {\r\n          let keys: Array<any> = [];\r\n          this.selectedItems.forEach((v: any) => { keys.push(v[this.key]) });\r\n          selection = keys;\r\n        }\r\n        else {\r\n          selection = this.selectedItems;\r\n        }\r\n      }\r\n      else {\r\n        selection = [];\r\n      }\r\n    }\r\n    else if (this.selectionMode == GridSelectionMode.Single) {\r\n      if (this.selectKeyOnly) {\r\n        selection = this.selectedItems ? [this.selectedItems[this.key]] : [];\r\n      }\r\n      else {\r\n        selection = this.selectedItems ? [this.selectedItems] : [];\r\n      }\r\n    }\r\n\r\n    if (this.selectionMode != GridSelectionMode.None) {\r\n      this.selectedItemsChange.emit(selection)\r\n    }\r\n  }\r\n\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.code === 'Space') {\r\n      event.stopPropagation();\r\n    }\r\n  }\r\n\r\n  onFocusOutRow(item: any) {\r\n    this.focusOutRow.emit(item);\r\n  }\r\n\r\n  customSort(event: SortEvent) {\r\n    if (event.data != null && event.data != undefined) {\r\n      event.data.sort((data1, data2) => {\r\n        if (event.field != null && event.field != undefined && event.order) {\r\n          let value1 = data1[event.field];\r\n          let value2 = data2[event.field];\r\n          let result = null;\r\n\r\n          if (value1 == null && value2 != null)\r\n            result = -1;\r\n          else if (value1 != null && value2 == null)\r\n            result = 1;\r\n          else if (value1 == null && value2 == null)\r\n            result = 0;\r\n          else if (typeof value1 === 'string' && typeof value2 === 'string')\r\n            result = value1.localeCompare(value2);\r\n          else\r\n            result = (value1 < value2) ? -1 : (value1 > value2) ? 1 : 0;\r\n\r\n          return (event.order * result);\r\n        }\r\n        return 0;\r\n      });\r\n    }\r\n  }\r\n\r\n  consult(key: string): void {\r\n    this.onConsultClicked.emit(key);\r\n  }\r\n\r\n  onCellValueChanged(col: GridColumn, newValue: any, item: any): void {\r\n    // send events\r\n    if (col.watchForChanges === true) {\r\n\r\n      let cellChangedResult: CellChangedResult = {\r\n        key: item[this.key],\r\n        field: col.field,\r\n        newValue: newValue\r\n      }\r\n      this.cellChanged.emit(cellChangedResult);\r\n\r\n      this.saveDataEventEmitter.emit(this.gridData);\r\n    }\r\n\r\n    // recalculate currentRowNumber\r\n    if (col.field === this._autoRowNumberField) {\r\n      this._orderByRowNumber();\r\n    }\r\n\r\n    // check for duplicated rows\r\n    // if(this._equalityCheckOn && col.isEquatableCriteria){\r\n    //   console.log('found equatable : col:', col, 'row : ', item);\r\n    //   this._tryFindEquatable(item);\r\n    // }\r\n  }\r\n\r\n  public updateFormState(formState: FormState): void {\r\n    if (!this.genericValidationStateService)\r\n    {\r\n      return;\r\n    }\r\n\r\n    this.genericValidationStateService.updateFormState(formState);\r\n  }\r\n\r\n  //#region private methods\r\n\r\n  private _initRow() {\r\n    let newRow: any = {};\r\n    if (this.columns) {\r\n      this.columns.forEach(col => {\r\n        if (col.type == InputTypes.DECIMAL_INPUT\r\n          || col.type == InputTypes.RATE_INPUT\r\n          || col.type == InputTypes.INTEGER\r\n          || col.type == InputTypes.CURRENCY_SOCIETE_INPUT\r\n          || col.type == InputTypes.CURRENCY_OTHER_INPUT) {\r\n          newRow[col.field] = 0;\r\n        }\r\n        else if (col.type == InputTypes.CHECKBOX) {\r\n          newRow[col.field] = false;\r\n        }\r\n        else {\r\n          newRow[col.field] = undefined;\r\n        }\r\n      });\r\n\r\n      if (this._isAutoRowNumber === true) {\r\n        newRow[this._autoRowNumberField] = this._nextRowNumber();\r\n      }\r\n      return newRow\r\n    }\r\n    return newRow;\r\n  }\r\n\r\n  private _initSaveEventSubscription() {\r\n    this.saveEventSubscription = this.events?.subscribe(\r\n      () => this.saveItems()\r\n    );\r\n  }\r\n\r\n  private _verifyAddRowOnLastElementRequirements() {\r\n    if (this.gridData == null\r\n      || this.gridData == undefined) {\r\n      throw new Error('gridData can\\'t be null')\r\n    }\r\n\r\n    if (this.columns == null\r\n      || this.columns == undefined) {\r\n      throw new Error('grid columns can\\'t be null')\r\n    }\r\n    else {\r\n      let rowNumberColumns = this.columns.filter(c => c.isAutoRowNumberColumn === true);\r\n\r\n      if (rowNumberColumns.length > 1) {\r\n        throw new Error('grid columns can\\'t have more than one RowNumberColumn')\r\n      }\r\n      else if (rowNumberColumns.length == 1) {\r\n        this._isAutoRowNumber = true;\r\n        this._autoRowNumberField = rowNumberColumns[0].field;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _verifyGridRequirements() {\r\n    if (this.columns == null\r\n      || this.columns == undefined) {\r\n      throw new Error('grid columns can\\'t be null')\r\n    }\r\n    else {\r\n      let rowNumberColumns = this.columns.filter(c => c.isAutoRowNumberColumn === true);\r\n\r\n      //console.log('rowNumberColumns : ', rowNumberColumns);\r\n\r\n      if (rowNumberColumns.length > 1) {\r\n        throw new Error('grid columns can\\'t have more than one RowNumberColumn')\r\n      }\r\n      else if (rowNumberColumns.length == 1) {\r\n        this._isAutoRowNumber = true;\r\n        this._autoRowNumberField = rowNumberColumns[0].field;\r\n\r\n        //console.log('_isAutoRowNumber : ', this._isAutoRowNumber);\r\n        //console.log('_autoRowNumberField : ', this._autoRowNumberField);\r\n      }\r\n    }\r\n  }\r\n\r\n  private _initCurrentRowNumberAndOrderByRowNumber(): void {\r\n    // console.log('_initCurrentRowNumber :: _isAutoRowNumber : ', this._isAutoRowNumber);\r\n    // console.log('_initCurrentRowNumber :: _autoRowNumberField : ', this._autoRowNumberField);\r\n    // console.log('_initCurrentRowNumber :: gridData : ', this.gridData);\r\n    if (this._isAutoRowNumber === true\r\n      && this._autoRowNumberField != undefined\r\n      && this._autoRowNumberField != null\r\n      && this.gridData.length > 0) {\r\n      // let aux = this.gridData.map(a => a[this._autoRowNumberField]);;\r\n      // aux.sort((a, b) => { return -a + b ;});\r\n\r\n      this._orderByRowNumber();\r\n\r\n      this._currentRowNumber = this.gridData[this.gridData.length - 1][this._autoRowNumberField];\r\n\r\n      //console.log('_initCurrentRowNumber : ',this._currentRowNumber);\r\n    }\r\n    //console.log('_initCurrentRowNumber : ',this._currentRowNumber);\r\n  }\r\n\r\n  private _nextRowNumber(): number {\r\n    this._currentRowNumber = this.gridData.length + 1;\r\n    //console.log('_nextRowNumber : ', this._currentRowNumber);\r\n    return this._currentRowNumber;\r\n  }\r\n\r\n  private _onDeleteRow(row: any): void {\r\n    if (row[this._autoRowNumberField] === this._currentRowNumber) {\r\n      this._currentRowNumber--;\r\n    }\r\n  }\r\n\r\n  private _orderByRowNumber(): void {\r\n    this.gridData.sort((a, b) => { return a[this._autoRowNumberField] - b[this._autoRowNumberField]; });\r\n  }\r\n\r\n  private _initEquatableFields(): void {\r\n    let equatableColumns = this.columns.filter(c => c.isEquatableCriteria == true);\r\n    if (equatableColumns) {\r\n      this._equalityCheckOn = true;\r\n      this._equatableFields = equatableColumns.map(c => c.field);\r\n    }\r\n    //console.log('equ fields : ', this._equatableFields);\r\n  }\r\n\r\n  private _initSumAtFusionFields(): void {\r\n    let sumAtFusionColumns = this.columns.filter(c => c.isSumAtFusion == true);\r\n    if (sumAtFusionColumns) {\r\n      this._equalityCheckOn = true;\r\n      this._sumAtFusionFields = sumAtFusionColumns.map(c => c.field);\r\n    }\r\n    //console.log('sum fields : ', this._sumAtFusionFields);\r\n  }\r\n\r\n  private _tryFindEquatable(row: any): void {\r\n    let foundEqualRow: boolean = false;\r\n    for (let i: number = 0; i < this.gridData.length; i++) {\r\n      console.log('proc row : ', this.gridData[i]);\r\n      let isCurrentRowEqual: boolean = true;\r\n      this._equatableFields?.forEach(f => {\r\n        console.log('proc field : ', f);\r\n        if (this.gridData[i][f] != row[f]) {\r\n          console.log('not equal ', row, this.gridData[i]);\r\n          isCurrentRowEqual = false;\r\n        }\r\n      });\r\n      if (isCurrentRowEqual) {\r\n        this._fusionRows(this.gridData[i], row);\r\n        foundEqualRow = true;\r\n        break;\r\n      }\r\n    }\r\n    if (foundEqualRow) {\r\n      console.log('deleting : ', row);\r\n      this.delete(row);\r\n    }\r\n  }\r\n\r\n  private _fusionRows(row1: any, row2: any) {\r\n    this._sumAtFusionFields?.forEach(f => {\r\n      row1[f] += row2[f];\r\n    });\r\n  }\r\n  //#endregion\r\n}\r\n","<div class=\"card\">\r\n  <p-table #dt [selectionMode]=\"selectionMode\" [(selection)]=\"selectedItems\" editMode=\"row\"\r\n    [paginator]=\"gridData.length > pageSize\" [rowsPerPageOptions]=\"rowPerPage\" [rows]=\"pageSize\"\r\n    (onRowSelect)=\"onRowSelected($event)\" (onRowUnselect)=\"onRowUnselect($event)\" [scrollable]=\"true\"\r\n    [resizableColumns]=\"true\" columnResizeMode=\"expand\" appendTo=\"body\" styleClass=\"p-datatable-sm\" [value]=\"gridData\"\r\n    [columns]=\"selectedColumns\" [dataKey]=\"key\" [scrollHeight]=\"scrollHeight\" styleClass=\"p-datatable-gridlines\"\r\n    (selectionChange)=\"selectionChange($event)\" #editableTable [totalRecords]=\"gridData.length\">\r\n    <!-- [tableStyle]=\"{'min-width': '50rem','width': 'inherit'}\" -->\r\n\r\n    <ng-template pTemplate=\"caption\">\r\n      <p-multiSelect [options]=\"columns\" [(ngModel)]=\"selectedColumns\"\r\n        selectedItemsLabel=\"{0} {{ 'columns_selected' | localize }}\" optionLabel=\"translatedHeader\"\r\n        [style]=\"{'min-width': '180px'}\" placeholder=\"{{ 'choose_columns' | localize }}\">\r\n        <ng-template let-option pTemplate=\"item\">\r\n          <div class=\"flex items-center gap-2\">\r\n            <span>{{ option.header | localize }}</span>\r\n          </div>\r\n        </ng-template>\r\n      </p-multiSelect>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n\r\n      <tr>\r\n        <ng-container *ngIf=\"selectionMode != multipleGridSelectionMode\">\r\n          <th pResizableColumn pFrozenColumn style=\"min-width:2rem; left: 1rem !important; width:2rem !important;\"></th>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"selectionMode == multipleGridSelectionMode\">\r\n          <th pResizableColumn pFrozenColumn style=\"min-width:2rem; left: 1rem !important; width:2rem !important;\">\r\n            <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n          </th>\r\n        </ng-container>\r\n        \r\n        <th pResizableColumn pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n\r\n        <!-- <th pResizableColumn pFrozenColumn *ngIf=\"showEditButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th> -->\r\n        \r\n        <th pResizableColumn pFrozenColumn *ngIf=\"showConsultButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n        <th pResizableColumn pFrozenColumn *ngIf=\"showDeleteButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n\r\n        <th pResizableColumn pFrozenColumn [frozen]=\"col.isFrozen\" [style]=\"col.style\" scope=\"col\"\r\n          style=\"min-width:3rem;\" pSortableColumn=\"{{col.field}}\" *ngFor=\"let col of columns\"\r\n          pTooltip=\"{{col.toolTipText | localize }}\" tooltipPosition=\"top\" pReorderableColumn>{{ col.header | localize\r\n          }}\r\n          <p-sortIcon field=\"{{col.field}}\"></p-sortIcon>\r\n          <Tsi-Bubble-Info [infoText]=\"col.infoText | localize\"></Tsi-Bubble-Info>\r\n        </th>\r\n        <th style=\"min-width:3rem\" *ngIf=\"showRowSummary\" scope=\"col\">{{'RowSummary' | localize}}</th>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"body\" let-item let-editing=\"editing\" let-columns=\"columns\" let-rowIndex=\"rowIndex\">\r\n      \r\n      <tr [pEditableRow]=\"item\"\r\n        *ngIf=\"selectionMode == multipleGridSelectionMode || selectionMode == undefined; else selectionModeBlock\"\r\n        (focusOut)=\"onFocusOutRow(item)\">\r\n        \r\n        <td style=\"text-align: center;\">\r\n          <p-tableCheckbox [value]=\"item\" ></p-tableCheckbox>\r\n        </td>\r\n\r\n        <!-- <td pFrozenColumn style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1\"> -->\r\n\r\n\r\n        <!-- <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n        </td> -->\r\n\r\n        <!-- <td pFrozenColumn *ngIf=\"showEditButton\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n          <div class=\"flex align-items-center justify-content-center\">\r\n            <button *ngIf=\"!editing\" pButton pRipple type=\"button\" pInitEditableRow icon=\"pi pi-pencil\"\r\n              class=\"p-button-rounded p-button-text\">\r\n            </button>\r\n            <button *ngIf=\"editing\" pButton pRipple type=\"button\" pSaveEditableRow icon=\"pi pi-check\"\r\n              class=\"p-button-rounded p-button-text p-button-success -ml-1\">\r\n            </button>\r\n            <button *ngIf=\"editing\" pButton pRipple type=\"button\" pCancelEditableRow icon=\"pi pi-times\"\r\n              class=\"p-button-rounded p-button-text p-button-danger -ml-2\">\r\n            </button>\r\n          </div>\r\n        </td> -->\r\n        <td pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\" style=\"left: 1rem !important; width:3rem !important;\"></td>\r\n\r\n        <td pFrozenColumn *ngIf=\"showConsultButton\" style=\"left: -1rem !important; width:3rem !important;\"\r\n          class=\"p-1 btn-consult-style\">\r\n          <div class=\"p-0\">\r\n            <Tsi-Button [buttonType]=\"buttonType.Button\" icon=\"p-button-icon pi pi-eye\"\r\n              [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_consulter\"\r\n              styleClass=\"p-button-rounded p-button-text p-button-secondary\" (click)=\"consult(item)\"></Tsi-Button>\r\n          </div>\r\n        </td>\r\n\r\n        <td pFrozenColumn *ngIf=\"showDeleteButton\" \r\n          style=\"left: 1rem !important; width:3rem !important;\"\r\n          class=\"p-1 btn-delete-style\">\r\n          <div class=\"p-0\">\r\n            <Tsi-Button [disabled]=\"isDeleteButtonDisabled(item)\" type=\"button\" icon=\"p-button-icon pi pi-trash\"\r\n              [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_supprimer\"\r\n              styleClass=\"p-element p-button-rounded p-button-text p-button-danger p-button p-component p-button-icon-only\"\r\n              (click)=\"delete(item)\"></Tsi-Button>\r\n          </div>\r\n        </td>\r\n\r\n\r\n        <td class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\"\r\n          [ngStyle]=\"isAr ? {'text-align': 'start'} : {}\">\r\n          \r\n          \r\n          <div *ngIf=\"col.displayOnly || disabled; else ordinaryBloc\">\r\n\r\n                <!-- Tsi-Search-Combo -->\r\n                <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteOutputBlock\">\r\n                  <Tsi-Search-Combo [disabled]=\"true\" [elementSourceUrl]=\"col.elementSourceUrl\"\r\n                    [businessClass]=\"col.businessClass\" [currentRowItem]=\"item\" [(bind)]=\"item[col.field]\"\r\n                    id-field=\"{{col.idField}}\" [listSourceUrl]=\"col.listSourceUrl\" label-field=\"{{col.labelField}}\"\r\n                    [isFiltered]=\"col.isFiltered\" [datasource]=\"col.datasource\"\r\n                    [showSearchButton]=\"col.showSearchButton ?? true\" [showAddButton]=\"col.showAddButton ?? true\"\r\n                    [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                    [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                    [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                    [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n                </div>\r\n\r\n                <!-- Tsi-Currency-Societe-Display -->\r\n                <ng-template #currencySocieteOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherOutputBlock\">\r\n                    <Tsi-Currency-Societe-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Societe-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Currency-Other-Display -->\r\n                <ng-template #currencyOtherOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerOutputBlock\">\r\n                    <Tsi-Currency-Other-Display [currency]=\"col.currencyOtherCode\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Other-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Date-Display -->\r\n                <ng-template #datePickerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxOutputBlock\">\r\n                    <Tsi-Date-Display [showTime]=\"col.showTime\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Date-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-CheckBox-Display -->\r\n                <ng-template #checkBoxOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalOutputBlock\">\r\n                    <Tsi-Checkbox-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Checkbox-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Decimal-Display -->\r\n                <ng-template #decimalOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerOutputBlock\">\r\n                    <Tsi-Decimal-Display [formatDecimal]=\"col.formatDecimal\" [inputData]=\"item[col.field]\"\r\n                      [numOfDecimal]=\"col.numOfDecimal\">\r\n                    </Tsi-Decimal-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Integer-Display -->\r\n                <ng-template #integerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateOutputBlock\">\r\n                    <Tsi-Integer-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Integer-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Rate-Display -->\r\n                <ng-template #rateOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeOutputBlock\">\r\n                    <Tsi-Rate-Display [isFraction]=\"col.isFraction\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Rate-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Time-Display -->\r\n                <ng-template #timeOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.TIME; else formulaOutputBlock\">\r\n                    <tsi-time-display [inputData]=\"item[col.field]\"></tsi-time-display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Formula-Display -->\r\n                <ng-template #formulaOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextOutputBlock\">\r\n                    <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Text-Box -->\r\n                <ng-template #defaultTextOutputBlock>\r\n                  <ng-container>\r\n                    <span>\r\n                      {{item[col.field]}}\r\n                    </span>\r\n                  </ng-container>\r\n                </ng-template>\r\n          </div>\r\n\r\n          <ng-template #ordinaryBloc> \r\n            \r\n            <!-- Tsi-Search-Combo -->\r\n            <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteInputBlock\">\r\n              <Tsi-Search-Combo [elementSourceUrl]=\"col.elementSourceUrl\" (bindChange)=\"inputChanged(col)\"\r\n                [businessClass]=\"col.businessClass\" [listSourceUrl]=\"col.listSourceUrl\" [(bind)]=\"item[col.field]\"\r\n                id-field=\"{{col.idField}}\" label-field=\"{{col.labelField}}\" [isFiltered]=\"col.isFiltered\"\r\n                [currentRowItem]=\"item\" (bindChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                [datasource]=\"col.datasource\" [showSearchButton]=\"col.showSearchButton ?? true\"\r\n                [showAddButton]=\"col.showAddButton ?? true\" [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n            </div>\r\n\r\n            <!-- Tsi-Currency-Societe-Input -->\r\n            <ng-template #currencySocieteInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherInputBlock\">\r\n                <Tsi-Currency-Societe-Input [inputName]=\"col.inputName\" [disabled]=\"col.disabled\" [inputId]=\"col.field\"\r\n                  [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Currency-Societe-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Currency-Other-Input -->\r\n            <ng-template #currencyOtherInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerInputBlock\">\r\n                <Tsi-Currency-Other-Input [inputName]=\"col.inputName\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\" [inputId]=\"col.field\"\r\n                  [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [numOfDecimal]=\"col.numOfDecimal\" [disabled]=\"col.disabled\">\r\n                </Tsi-Currency-Other-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Date-Picker -->\r\n            <ng-template #datePickerInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxInputBlock\">\r\n                <Tsi-Date-Picker [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [showTime]=\"col.showTime\"\r\n                  [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Date-Picker>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-CheckBox -->\r\n            <ng-template #checkBoxInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalInputBlock\">\r\n                <Tsi-CheckBox [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-CheckBox>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Decimal-Input -->\r\n            <ng-template #decimalInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerInputBlock\">\r\n                <Tsi-Decimal-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                  [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Decimal-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Integer -->\r\n            <ng-template #integerInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateInputBlock\">\r\n                <Tsi-Integer [inputName]=\"col.inputName\" [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                  [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\">\r\n                </Tsi-Integer>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Rate-Input -->\r\n            <ng-template #rateInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeInputBloc\">\r\n                <Tsi-Rate-Input [inputName]=\"col.inputName\" [numOfDecimal]=\"col.numOfDecimal\" [inputId]=\"col.field\"\r\n                  [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Rate-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Time-picker bloc -->\r\n            <ng-template #timeInputBloc>\r\n              <ng-container *ngIf=\"col.type == inputTypes.TIME; else formulaInputBlock\">\r\n                <tsi-time-picker (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [inputName]=\"col.inputName\"\r\n                  [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\" [disabled]=\"col.disabled\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </tsi-time-picker>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <ng-template #formulaInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextInputBlock\">\r\n                <!--<Tsi-Bubble-Info\r\n                  [infoText]=\"['formula_explication',\r\n                  ]\"></Tsi-Bubble-Info> -->\r\n                <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Text-Box -->\r\n            <ng-template #defaultTextInputBlock>\r\n              <ng-container>\r\n                <Tsi-Text-Box [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\" (keydown)=\"handleKeydown($event)\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                  [inputName]=\"col.inputName\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Text-Box>\r\n              \r\n              </ng-container>\r\n            </ng-template>\r\n          </ng-template>\r\n\r\n        </td>\r\n\r\n        <td *ngIf=\"showRowSummary\" class=\"font-bold\">\r\n          {{rowSummary(item)}}\r\n        </td>\r\n      </tr>\r\n\r\n      <ng-template #selectionModeBlock>\r\n        <ng-container>\r\n          <tr [pEditableRow]=\"item\" [pSelectableRow]=\"item\" [pSelectableRowIndex]=\"rowIndex\"\r\n            (focusOut)=\"onFocusOutRow(item)\">\r\n\r\n       <!-- <td pFrozenColumn style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1\"> -->\r\n\r\n            <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n              </td>\r\n\r\n            <!-- <td *ngIf=\"selectionMode == multipleGridSelectionMode\" style=\"width: 2rem;\">\r\n              <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n            </td> -->\r\n\r\n            <!-- <td pFrozenColumn *ngIf=\"showEditButton\" style=\"min-width:3rem;left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n              <div class=\"flex align-items-center justify-content-center\">\r\n                <button *ngIf=\"!editing\" pButton pRipple type=\"button\" pInitEditableRow icon=\"pi pi-pencil\"\r\n                  class=\"p-button-rounded p-button-text\">\r\n                </button>\r\n                <button *ngIf=\"editing\" pButton pRipple type=\"button\" pSaveEditableRow icon=\"pi pi-check\"\r\n                  class=\"p-button-rounded p-button-text p-button-success -ml-1\">\r\n                </button>\r\n                <button *ngIf=\"editing\" pButton pRipple type=\"button\" pCancelEditableRow icon=\"pi pi-times\"\r\n                  class=\"p-button-rounded p-button-text p-button-danger -ml-2\">\r\n                </button>\r\n              </div>\r\n            </td> -->\r\n            \r\n            <td pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\" style=\"left: 1rem !important; width:3rem !important;\">\r\n            </td>\r\n            \r\n            <td pFrozenColumn pResizableColumn *ngIf=\"showConsultButton\"\r\n              style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1 btn-consult-style\">\r\n              <div class=\"p-0\">\r\n                <Tsi-Button [buttonType]=\"buttonType.Button\" icon=\"p-button-icon pi pi-eye\"\r\n                  [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_consulter\"\r\n                  styleClass=\"p-button-rounded p-button-text p-button-secondary\" (click)=\"consult(item)\"></Tsi-Button>\r\n              </div>\r\n            </td>\r\n\r\n            <td pFrozenColumn pResizableColumn *ngIf=\"showDeleteButton\" style=\"left: 1rem !important; width:3rem !important;\"\r\n              class=\"p-1 btn-delete-style\">\r\n              <div class=\"p-0\">\r\n                <Tsi-Button type=\"button\" icon=\"p-button-icon pi pi-trash\" [tooltipPosition]=\"tooltipPosition.Top\"\r\n                  tooltipText=\"shared_edittable_supprimer\"\r\n                  styleClass=\"p-element p-button-rounded p-button-text p-button-danger p-button p-component p-button-icon-only\"\r\n                  (click)=\"delete(item)\"></Tsi-Button>\r\n              </div>\r\n            </td>\r\n            \r\n            <td class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\">\r\n\r\n              <div *ngIf=\"col.displayOnly || disabled; else ordinaryBloc\">\r\n                <!-- Tsi-Search-Combo -->\r\n                <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteOutputBlock\">\r\n                  <Tsi-Search-Combo [disabled]=\"true\" [elementSourceUrl]=\"col.elementSourceUrl\"\r\n                    [businessClass]=\"col.businessClass\" [currentRowItem]=\"item\" [(bind)]=\"item[col.field]\"\r\n                    id-field=\"{{col.idField}}\" [listSourceUrl]=\"col.listSourceUrl\" label-field=\"{{col.labelField}}\"\r\n                    [isFiltered]=\"col.isFiltered\" [datasource]=\"col.datasource\"\r\n                    [showSearchButton]=\"col.showSearchButton ?? true\" [showAddButton]=\"col.showAddButton ?? true\"\r\n                    [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                    [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                    [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                    [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n                </div>\r\n\r\n                <!-- Tsi-Currency-Societe-Display -->\r\n                <ng-template #currencySocieteOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherOutputBlock\">\r\n                    <Tsi-Currency-Societe-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Societe-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Currency-Other-Display -->\r\n                <ng-template #currencyOtherOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerOutputBlock\">\r\n                    <Tsi-Currency-Other-Display [currency]=\"col.currencyOtherCode\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Other-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Date-Display -->\r\n                <ng-template #datePickerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxOutputBlock\">\r\n                    <Tsi-Date-Display [showTime]=\"col.showTime\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Date-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-CheckBox-Display -->\r\n                <ng-template #checkBoxOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalOutputBlock\">\r\n                    <Tsi-Checkbox-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Checkbox-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Decimal-Display -->\r\n                <ng-template #decimalOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerOutputBlock\">\r\n                    <Tsi-Decimal-Display [formatDecimal]=\"col.formatDecimal\" [inputData]=\"item[col.field]\"\r\n                      [numOfDecimal]=\"col.numOfDecimal\">\r\n                    </Tsi-Decimal-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Integer-Display -->\r\n                <ng-template #integerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateOutputBlock\">\r\n                    <Tsi-Integer-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Integer-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Rate-Display -->\r\n                <ng-template #rateOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeOutputBlock\">\r\n                    <Tsi-Rate-Display [isFraction]=\"col.isFraction\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Rate-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Time-Display -->\r\n                <ng-template #timeOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.TIME; else formulaOutputBlock\">\r\n                    <tsi-time-display [inputData]=\"item[col.field]\"></tsi-time-display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Formula-Display -->\r\n                <ng-template #formulaOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextOutputBlock\">\r\n                    <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Text-Box -->\r\n                <ng-template #defaultTextOutputBlock>\r\n                  <ng-container>\r\n                    <span>\r\n                      {{item[col.field]}}\r\n                    </span>\r\n                  </ng-container>\r\n                </ng-template>\r\n              </div>\r\n              \r\n              <ng-template #ordinaryBloc>\r\n                <!-- Tsi-Search-Combo -->\r\n                <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteInputBlock\">\r\n                  <Tsi-Search-Combo [elementSourceUrl]=\"col.elementSourceUrl\" (bindChange)=\"inputChanged(col)\"\r\n                    [listSourceUrl]=\"col.listSourceUrl\" [(bind)]=\"item[col.field]\" id-field=\"{{col.idField}}\"\r\n                    label-field=\"{{col.labelField}}\" [isFiltered]=\"col.isFiltered\" [businessClass]=\"col.businessClass\"\r\n                    (bindChange)=\"onCellValueChanged(col, $event, item)\" [currentRowItem]=\"item\"\r\n                    [datasource]=\"col.datasource\" [disabled]=\"col.disabled\"\r\n                    [showSearchButton]=\"col.showSearchButton ?? true\" [showAddButton]=\"col.showAddButton ?? true\"\r\n                    [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                    [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                    [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                    [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n                </div>\r\n\r\n                <!-- Tsi-Currency-Societe-Input -->\r\n                <ng-template #currencySocieteInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherInputBlock\">\r\n                    <Tsi-Currency-Societe-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Currency-Societe-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Currency-Other-Input -->\r\n                <ng-template #currencyOtherInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerInputBlock\">\r\n                    <Tsi-Currency-Other-Input [disabled]=\"col.disabled\" [inputName]=\"col.inputName\"\r\n                      [inputId]=\"col.field\" (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Currency-Other-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Date-Picker -->\r\n                <ng-template #datePickerInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxInputBlock\">\r\n                    <Tsi-Date-Picker [showTime]=\"col.showTime\" [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Date-Picker>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-CheckBox -->\r\n                <ng-template #checkBoxInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalInputBlock\">\r\n                    <Tsi-CheckBox [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-CheckBox>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Decimal-Input -->\r\n                <ng-template #decimalInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerInputBlock\">\r\n                    <Tsi-Decimal-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      [(inputField)]=\"item[col.field]\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\">\r\n                    </Tsi-Decimal-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Integer -->\r\n                <ng-template #integerInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateInputBlock\">\r\n                    <Tsi-Integer [class]=\"'max-w-4rem'\" [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\">\r\n                    </Tsi-Integer>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Rate-Input -->\r\n                <ng-template #rateInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeInputBloc\">\r\n                    <Tsi-Rate-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Rate-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Time-Picker -->\r\n                <ng-template #timeInputBloc>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.TIME else formulaInputBlock\">\r\n                    <tsi-time-picker (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                      [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </tsi-time-picker>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <ng-template #formulaInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextInputBlock\">\r\n                    <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Text-Box -->\r\n                <ng-template #defaultTextInputBlock>\r\n                  <ng-container>\r\n                    <Tsi-Text-Box [inputId]=\"col.field\" [disabled]=\"col.disabled\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      [(inputField)]=\"item[col.field]\" (keydown)=\"handleKeydown($event)\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [inputName]=\"col.inputName\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Text-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n              </ng-template>\r\n\r\n            </td>\r\n            <td *ngIf=\"showRowSummary\" class=\"font-bold\">\r\n              {{rowSummary(item)}}\r\n            </td>\r\n          </tr>\r\n        </ng-container>\r\n      </ng-template>\r\n\r\n    </ng-template>\r\n\r\n    <ng-template *ngIf=\"showHaveSumary\" pTemplate=\"footer\" let-columns>\r\n\r\n      <tr class=\"tfooter\">\r\n        <!-- <td pFrozenColumn scope=\"col\" style=\"left: 1rem !important; width:3rem !important;\"></td> -->\r\n        <td *ngIf=\"selectionMode == multipleGridSelectionMode\"\r\n          style=\"min-width:2rem; left: 1rem !important; width:2rem !important;\">\r\n          <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n        </td>\r\n        <td pFrozenColumn scope=\"col\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\">Total</td>\r\n        <td pFrozenColumn *ngIf=\"showDeleteButton\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"\r\n          class=\"p-1\">\r\n        <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n          <!--<td pFrozenColumn *ngIf=\"showEditButton\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"\r\n          class=\"p-1\"> -->\r\n        <td pFrozenColumn *ngIf=\"showConsultButton\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n        </td>\r\n        <td pFrozenColumn [frozen]=\"col.isFrozen\" [style]=\"col.style\" scope=\"col\" *ngFor=\"let col of columns\">\r\n          <div *ngIf=\"col.haveSummary\">\r\n            <!-- Tsi-Currency-Societe-Display -->\r\n            <div *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherOutputBlock\">\r\n              <Tsi-Currency-Societe-Display [inputData]=\"getSummary(col)\">\r\n              </Tsi-Currency-Societe-Display>\r\n            </div>\r\n\r\n            <!-- Tsi-Currency-Other-Display -->\r\n            <ng-template #currencyOtherOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else decimalOutputBlock\">\r\n                <Tsi-Currency-Other-Display [currency]=\"col.currencyCode\" [inputData]=\"getSummary(col)\">\r\n                </Tsi-Currency-Other-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Decimal-Display -->\r\n            <ng-template #decimalOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerOutputBlock\">\r\n                <Tsi-Decimal-Display [formatDecimal]=\"col.formatDecimal\" [inputData]=\"getSummary(col)\"\r\n                  [numOfDecimal]=\"col.numOfDecimal\">\r\n                </Tsi-Decimal-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Integer-Display -->\r\n            <ng-template #integerOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateOutputBlock\">\r\n                <Tsi-Integer-Display [inputData]=\"getSummary(col)\">\r\n                </Tsi-Integer-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Rate-Display -->\r\n            <ng-template #rateOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else defaultTextOutputBlock\">\r\n                <Tsi-Rate-Display [isFraction]=\"col.isFraction\" [inputData]=\"getSummary(col)\">\r\n                </Tsi-Rate-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Default -->\r\n            <ng-template #defaultTextOutputBlock>\r\n              <ng-container>\r\n                <span>\r\n                  {{getSummary(col)}}\r\n                </span>\r\n              </ng-container>\r\n            </ng-template>\r\n          </div>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"summary\">\r\n      <tr>\r\n        {{'TotalRecordsCount' | localize }} {{gridData.length}}\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n  <div>\r\n    <Tsi-Button *ngIf=\"showAddButton\" style=\"height: 20px;width: 20px;\" icon=\"p-button-icon pi pi-plus\" type=\"button\"\r\n      [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_ajouter\"\r\n      styleClass=\"p-element p-button-sm p-button-success p-button-text p-button p-component p-button-icon-only ng-star-inserted\"\r\n      (click)=\"addRow()\"></Tsi-Button>\r\n  </div>\r\n</div>"]}
602
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editable-grid.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/editable-grid/editable-grid.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/input-components/editable-grid/editable-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, inject, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { SortEvent, TableState } from 'primeng/api';\r\nimport { Table, TableRowSelectEvent, TableRowUnSelectEvent } from 'primeng/table';\r\nimport { Observable, Subscription } from 'rxjs';\r\nimport { rtlModeKeys } from '../../../consts/locals.const';\r\nimport { ButtonType, GridSelectionMode, InputTypes, ModalSizeEnum, TooltipPosition } from '../../../enums';\r\nimport { CellChangedResult, GridColumn, IGridConfiguration, RowAddedResult } from '../../../interfaces';\r\nimport { LocalizePipe } from '../../../pipes/localize.pipe';\r\nimport { EntityValidationsService } from '../../../services/validation/entity-validations.service';\r\nimport { GenericValidationStateService } from '../../../services';\r\nimport { FormState } from '../../../models/form/form-state';\r\nimport { TsiInputBase } from '../../../tsi-base/tsi-input-base/tsi-input-base.component';\r\n\r\n@Component({\r\n  selector: 'Tsi-Generic-Editable-Grid',\r\n  templateUrl: './editable-grid.component.html',\r\n  styleUrls: ['./editable-grid.component.scss'],\r\n  providers: [GenericValidationStateService]\r\n})\r\nexport class EditableGridComponent extends TsiInputBase implements OnInit, OnDestroy {\r\n\r\n  //#region local vars\r\n  //#region private local vars\r\n  private saveEventSubscription?: Subscription;\r\n  private _isAutoRowNumber: boolean = false;\r\n  private _autoRowNumberField: string = '';\r\n  private _currentRowNumber: number = 0;\r\n  tooltipPosition = TooltipPosition;\r\n  isAr: boolean = false;\r\n  private _gridData: Array<any> = [];\r\n  private _equatableFields: Array<string> | undefined;\r\n  private _sumAtFusionFields: Array<string> | undefined;\r\n  private _equalityCheckOn: boolean = false;\r\n  multipleGridSelectionMode = GridSelectionMode.Multiple;\r\n  //#endregion\r\n  inputTypes = InputTypes;\r\n  modalSize = ModalSizeEnum.ExtraLarge;\r\n  @ViewChild(\"editableTable\") editableTable?: Table\r\n\r\n  buttonType = ButtonType;\r\n\r\n  @Input() selectedItems: any = [];\r\n  selectedItem: any;\r\n\r\n  //#endregion\r\n\r\n  //#region Inputs\r\n  @Input('configuration') configuration?: IGridConfiguration;\r\n  @Input('key') key: string = 'uid';\r\n  @Input() items: Array<any> = [];\r\n  @Input('events') saveEvent?: Observable<void>;\r\n  @Input() showAddButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showDeleteButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showEditButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showRowSummary: boolean = false;//TO DO Save Button Option\r\n\r\n  @Input() scrollHeight: string = '500px';\r\n  @Input() rowPerPage: number[] = [5, 10, 20];\r\n  // @Input() isPaginator: boolean = true;\r\n  @Input() pageSize: number = 5\r\n\r\n  /**\r\n   *\r\n   */\r\n  selectedColumns: Array<GridColumn> = [];\r\n  private _columns: Array<GridColumn> = [];\r\n  private _tempColumns: Array<GridColumn> = [];\r\n  get columns(): Array<GridColumn> {\r\n    return this._columns;\r\n  }\r\n\r\n  @Input() set columns(value: Array<GridColumn>) {\r\n    value.forEach(el => el.translatedHeader = this._localizePipe.transform(el.header ?? \"\"));\r\n    this._columns = value;\r\n    this.selectedColumns = this._columns;\r\n\r\n    this._verifyGridRequirements();\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n  }\r\n  @Input() set gridData(data: Array<any>) {\r\n    this._gridData = data;\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n  }\r\n  get gridData() { return this._gridData; }\r\n\r\n  @Input() isTableLoading?: boolean;\r\n\r\n\r\n  @Input() parent: any;\r\n  @Input() events?: Observable<void>;//TO DO Save Button Option\r\n\r\n  @Input() showSaveButton: boolean = true;//TO DO Save Button Option\r\n  @Input() showActionColumn: boolean = true;//TO DO Save Button Option\r\n\r\n\r\n  @Input() enableRowDisabling: boolean = false;\r\n\r\n  @Input() rowSummaryConfig: Array<string> = [];\r\n  @Input() showHaveSumary?: boolean = false;\r\n  @Input() showRowSumary?: boolean = false;\r\n\r\n  /**selection */\r\n  @Input() selectKeyOnly: boolean = true;\r\n  @Input() selectionMode: GridSelectionMode | any = GridSelectionMode.None;\r\n  @Input() showConsultButton: boolean = false;\r\n\r\n  private _editableGridBusinessClass: string = \"\";\r\n  get editableGridBusinessClass() {\r\n    return this._editableGridBusinessClass;\r\n  }\r\n  @Input() set editableGridBusinessClass(className: string) {\r\n    this._editableGridBusinessClass = className;\r\n    this.genericValidationStateService?.loadEntityValidationInfos(this._editableGridBusinessClass);\r\n  }\r\n\r\n\r\n  /**order */\r\n  @Input() orderColumn: string = 'uid';\r\n\r\n  @Input() deleteLineButtonDisabled!: (item: any) => any\r\n\r\n  //#endregion\r\n\r\n  //#region Outputs\r\n  @Output() itemsSave: EventEmitter<any[]> = new EventEmitter<any[]>();\r\n  /**\r\n   *\r\n   */\r\n\r\n\r\n  @Output() refreshEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  //@Output() actionEventEmitter: EventEmitter<GridActionEmitResult> = new EventEmitter<GridActionEmitResult>();\r\n\r\n  @Output() saveDataEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() rowChangedEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() selectedRowEventEmitter: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() addedRowEventEmitter: EventEmitter<RowAddedResult> = new EventEmitter<RowAddedResult>()\r\n\r\n  @Output() focusOutEventEmitter = new EventEmitter<string>();\r\n\r\n  @Output() cellChanged: EventEmitter<CellChangedResult> = new EventEmitter<CellChangedResult>();\r\n\r\n  @Output() rowDeletedEventEmitter = new EventEmitter<any>();\r\n\r\n  @Output() selectedItemsChange: EventEmitter<Array<any>> = new EventEmitter<Array<any>>();\r\n\r\n  @Output() onRowSelect: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() focusOutRow: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onConsultClicked: EventEmitter<any> = new EventEmitter<any>();\r\n  //#endregion\r\n\r\n  @ViewChild(\"dt\", { static: false }) public dt: Table | undefined;\r\n\r\n  @Input() id?: string;\r\n\r\n  private _entityValidationsService = inject(EntityValidationsService);\r\n\r\n  constructor(private _localizePipe: LocalizePipe) {\r\n    super()\r\n  }\r\n\r\n  override ngOnInit() {\r\n    super.ngOnInit()\r\n    this._initSaveEventSubscription();\r\n    this._verifyGridRequirements();\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n    this._initEquatableFields();\r\n    this._initSumAtFusionFields();\r\n    \r\n    let langue = localStorage.getItem(rtlModeKeys.rtlModeEnabled);\r\n    \r\n    if (langue && JSON.parse(langue)) {\r\n      this.isAr = true\r\n    }\r\n    else {\r\n      this.isAr = false\r\n    }\r\n\r\n    if (!this.selectedColumns || this.selectedColumns.length == 0) {\r\n      this.selectedColumns = this.columns\r\n    }\r\n    \r\n    this._tempColumns = this.columns;\r\n  }\r\n\r\n  findColumnByKey(key: any) {\r\n    if (this.columns) {\r\n      for (let col of this.columns) {\r\n        if (col.header === key || col.field === key) return col;\r\n        else continue;\r\n      }\r\n    }\r\n    return null\r\n  }\r\n\r\n\r\n  public restoreState(configuration: string) {\r\n    let state: TableState = JSON.parse(configuration)\r\n    if (this.dt) {\r\n      if (this.dt) {\r\n\r\n        this.dt.columnWidthsState = state.columnWidths;\r\n        this.dt.tableWidthState = state.tableWidth;\r\n\r\n        let columnOrder = state.columnOrder;\r\n\r\n        if (columnOrder) {\r\n          let reorderedColumns = this.getReorderedColumns(columnOrder);\r\n          this.columns = reorderedColumns;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  getReorderedColumns(columnOrder: string[]): any[] {\r\n    let reorderedColumns: any[] = [];\r\n\r\n    columnOrder.map((key) => {\r\n      let col = this.findColumnByKey(key);\r\n      if (col) {\r\n        reorderedColumns.push(col);\r\n      }\r\n    });\r\n\r\n    return reorderedColumns;\r\n  }\r\n\r\n  resetSelectedColumns(configuration: string) {\r\n    let state: TableState = JSON.parse(configuration)\r\n    if (this.dt) {\r\n\r\n      this.dt.columnWidthsState = state.columnWidths;\r\n      this.dt.tableWidthState = state.tableWidth;\r\n\r\n      let columnOrder = state.columnOrder;\r\n\r\n      if (columnOrder) {\r\n        this.columns = this._tempColumns;\r\n        \r\n        let reorderedColumns = this.getReorderedColumns(columnOrder);\r\n        this.selectedColumns = reorderedColumns;\r\n      }\r\n    }\r\n  }\r\n\r\n  getState() {\r\n    let state: TableState = {};\r\n\r\n    if (!this.dt) {\r\n      return\r\n    }\r\n\r\n    if (this.dt.resizableColumns) {\r\n      this.dt.saveColumnWidths(state);\r\n    }\r\n\r\n    this.dt.saveColumnOrder(state);\r\n\r\n    return state\r\n  }\r\n\r\n  isDeleteButtonDisabled(item: any) {\r\n    if (this.deleteLineButtonDisabled != undefined) {\r\n      return this.deleteLineButtonDisabled(item)\r\n    }\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    super.ngOnDestroy()\r\n    this.saveEventSubscription?.unsubscribe();\r\n  }\r\n\r\n  inputChanged(col: GridColumn) {\r\n    if (col.watchForChanges === true) {\r\n      this.saveDataEventEmitter.emit(this.gridData);\r\n    }\r\n  }\r\n\r\n  saveItems() {\r\n    this.itemsSave.emit(this.gridData);\r\n    this.saveDataEventEmitter.emit(this.gridData);\r\n  }\r\n\r\n  addRow(): void {\r\n    if (!this.gridData) {\r\n      this.gridData = [];\r\n    }\r\n    let newRow = this._initRow()\r\n    this.gridData.push(newRow)\r\n    this.isDirty = true\r\n    let rowAddedResult: RowAddedResult = {\r\n      rowNumber: this.gridData.length - 1,\r\n      data: newRow\r\n    }\r\n\r\n    if (this.editableTable?.sortField && this.editableTable.sortOrder) {\r\n      this.editableTable?.value.push(newRow)\r\n    }\r\n    this.refreshSort()\r\n    this.addedRowEventEmitter.emit(rowAddedResult)\r\n  }\r\n\r\n  refreshSort() {\r\n    if (this.editableTable?.sortField) {\r\n      const sortField = this.editableTable.sortField;\r\n      const sortOrder = this.editableTable.sortOrder;\r\n\r\n      this.gridData.sort((a, b) => {\r\n        const valueA = a[sortField];\r\n        const valueB = b[sortField];\r\n        let result = 0;\r\n\r\n        if (valueA < valueB) result = -1;\r\n        else if (valueA > valueB) result = 1;\r\n\r\n        return result * sortOrder;\r\n      });\r\n\r\n      this.gridData = [...this.gridData];\r\n    }\r\n  }\r\n\r\n  delete(item: any) {\r\n    if (this.editableTable?.sortField && this.editableTable.sortMode) {\r\n      const index = this.editableTable.value.indexOf(item, 0);\r\n      if (index > -1) {\r\n        this.editableTable.value.splice(index, 1)\r\n      }\r\n    }\r\n    const index = this.gridData.indexOf(item, 0);\r\n    if (index > -1) {\r\n      this.gridData.splice(index, 1);\r\n      this.isDirty = true\r\n      this._onDeleteRow(item);\r\n      this.rowDeletedEventEmitter.emit(this.gridData)\r\n    }\r\n    this.refreshSort()\r\n  }\r\n\r\n  getSummary(col: GridColumn): number {\r\n    if (col.haveSummary == true) {\r\n\r\n      let sum = 0;\r\n      this.gridData.forEach((row: any) => {\r\n        sum += row[col.field];\r\n      })\r\n      return sum;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  rowSummary(row: any): number {\r\n    let sum = 0;\r\n    this.columns.forEach(col => {\r\n      if (col.rowSummary == true) {\r\n        sum += row[col.field];\r\n      }\r\n    });\r\n    return sum;\r\n\r\n  }\r\n\r\n  onRowSelected(event: TableRowSelectEvent) {\r\n    this.selectedItem = event.data\r\n    if (this.selectKeyOnly == true) {\r\n      let selectionKey: any;\r\n      selectionKey = this.selectedItem[this.key];\r\n      this.onRowSelect.emit(selectionKey);\r\n    }\r\n    else {\r\n      this.onRowSelect.emit(this.selectedItems);\r\n    }\r\n  }\r\n\r\n  onRowUnselect(event: TableRowUnSelectEvent) {\r\n    this.selectedItem = undefined\r\n  }\r\n\r\n  selectionChange(event: any) {\r\n\r\n    let selection: any[] = [];\r\n\r\n    if (this.selectionMode == GridSelectionMode.Multiple) {\r\n      if (this.selectedItems) {\r\n        if (this.selectKeyOnly) {\r\n          let keys: Array<any> = [];\r\n          this.selectedItems.forEach((v: any) => { keys.push(v[this.key]) });\r\n          selection = keys;\r\n        }\r\n        else {\r\n          selection = this.selectedItems;\r\n        }\r\n      }\r\n      else {\r\n        selection = [];\r\n      }\r\n    }\r\n    else if (this.selectionMode == GridSelectionMode.Single) {\r\n      if (this.selectKeyOnly) {\r\n        selection = this.selectedItems ? [this.selectedItems[this.key]] : [];\r\n      }\r\n      else {\r\n        selection = this.selectedItems ? [this.selectedItems] : [];\r\n      }\r\n    }\r\n\r\n    if (this.selectionMode != GridSelectionMode.None) {\r\n      this.selectedItemsChange.emit(selection)\r\n    }\r\n  }\r\n\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.code === 'Space') {\r\n      event.stopPropagation();\r\n    }\r\n  }\r\n\r\n  onFocusOutRow(item: any) {\r\n    this.focusOutRow.emit(item);\r\n  }\r\n\r\n  customSort(event: SortEvent) {\r\n    if (event.data != null && event.data != undefined) {\r\n      event.data.sort((data1, data2) => {\r\n        if (event.field != null && event.field != undefined && event.order) {\r\n          let value1 = data1[event.field];\r\n          let value2 = data2[event.field];\r\n          let result = null;\r\n\r\n          if (value1 == null && value2 != null)\r\n            result = -1;\r\n          else if (value1 != null && value2 == null)\r\n            result = 1;\r\n          else if (value1 == null && value2 == null)\r\n            result = 0;\r\n          else if (typeof value1 === 'string' && typeof value2 === 'string')\r\n            result = value1.localeCompare(value2);\r\n          else\r\n            result = (value1 < value2) ? -1 : (value1 > value2) ? 1 : 0;\r\n\r\n          return (event.order * result);\r\n        }\r\n        return 0;\r\n      });\r\n    }\r\n  }\r\n\r\n  consult(key: string): void {\r\n    this.onConsultClicked.emit(key);\r\n  }\r\n\r\n  onCellValueChanged(col: GridColumn, newValue: any, item: any): void {\r\n    // send events\r\n    if (col.watchForChanges === true) {\r\n\r\n      let cellChangedResult: CellChangedResult = {\r\n        key: item[this.key],\r\n        field: col.field,\r\n        newValue: newValue\r\n      }\r\n      this.cellChanged.emit(cellChangedResult);\r\n\r\n      this.saveDataEventEmitter.emit(this.gridData);\r\n    }\r\n\r\n    // recalculate currentRowNumber\r\n    if (col.field === this._autoRowNumberField) {\r\n      this._orderByRowNumber();\r\n    }\r\n\r\n    // check for duplicated rows\r\n    // if(this._equalityCheckOn && col.isEquatableCriteria){\r\n    //   console.log('found equatable : col:', col, 'row : ', item);\r\n    //   this._tryFindEquatable(item);\r\n    // }\r\n  }\r\n\r\n  public updateFormState(formState: FormState): void {\r\n    if (!this.genericValidationStateService)\r\n    {\r\n      return;\r\n    }\r\n\r\n    this.genericValidationStateService.updateFormState(formState);\r\n  }\r\n\r\n  //#region private methods\r\n\r\n  private _initRow() {\r\n    let newRow: any = {};\r\n    if (this.columns) {\r\n      this.columns.forEach(col => {\r\n        if (col.type == InputTypes.DECIMAL_INPUT\r\n          || col.type == InputTypes.RATE_INPUT\r\n          || col.type == InputTypes.INTEGER\r\n          || col.type == InputTypes.CURRENCY_SOCIETE_INPUT\r\n          || col.type == InputTypes.CURRENCY_OTHER_INPUT) {\r\n          newRow[col.field] = 0;\r\n        }\r\n        else if (col.type == InputTypes.CHECKBOX) {\r\n          newRow[col.field] = false;\r\n        }\r\n        else {\r\n          newRow[col.field] = undefined;\r\n        }\r\n      });\r\n\r\n      if (this._isAutoRowNumber === true) {\r\n        newRow[this._autoRowNumberField] = this._nextRowNumber();\r\n      }\r\n      return newRow\r\n    }\r\n    return newRow;\r\n  }\r\n\r\n  private _initSaveEventSubscription() {\r\n    this.saveEventSubscription = this.events?.subscribe(\r\n      () => this.saveItems()\r\n    );\r\n  }\r\n\r\n  private _verifyGridRequirements() {\r\n    if (this.columns == null\r\n      || this.columns == undefined) {\r\n      throw new Error('grid columns can\\'t be null')\r\n    }\r\n    \r\n    let rowNumberColumns = this.columns.filter(c => c.isAutoRowNumberColumn === true);\r\n\r\n    if (rowNumberColumns.length > 1) {\r\n      throw new Error('grid columns can\\'t have more than one RowNumberColumn')\r\n    }\r\n    \r\n    if (rowNumberColumns.length == 1) {\r\n      this._isAutoRowNumber = true;\r\n      this._autoRowNumberField = rowNumberColumns[0].field;\r\n    }\r\n  }\r\n\r\n  private _initCurrentRowNumberAndOrderByRowNumber(): void {\r\n    if (this._isAutoRowNumber === true\r\n      && this._autoRowNumberField != undefined\r\n      && this._autoRowNumberField != null\r\n      && this.gridData.length > 0) {\r\n      this._orderByRowNumber();\r\n\r\n      this._currentRowNumber = this.gridData[this.gridData.length - 1][this._autoRowNumberField];\r\n    }\r\n  }\r\n\r\n  private _nextRowNumber(): number {\r\n    this._currentRowNumber = this.gridData.length + 1;\r\n    return this._currentRowNumber;\r\n  }\r\n\r\n  private _onDeleteRow(row: any): void {\r\n    if (row[this._autoRowNumberField] === this._currentRowNumber) {\r\n      this._currentRowNumber--;\r\n    }\r\n  }\r\n\r\n  private _orderByRowNumber(): void {\r\n    this.gridData.sort((a, b) => { return a[this._autoRowNumberField] - b[this._autoRowNumberField]; });\r\n  }\r\n\r\n  private _initEquatableFields(): void {\r\n    let equatableColumns = this.columns.filter(c => c.isEquatableCriteria == true);\r\n    if (equatableColumns) {\r\n      this._equalityCheckOn = true;\r\n      this._equatableFields = equatableColumns.map(c => c.field);\r\n    }\r\n  }\r\n\r\n  private _initSumAtFusionFields(): void {\r\n    let sumAtFusionColumns = this.columns.filter(c => c.isSumAtFusion == true);\r\n    if (sumAtFusionColumns) {\r\n      this._equalityCheckOn = true;\r\n      this._sumAtFusionFields = sumAtFusionColumns.map(c => c.field);\r\n    }\r\n  }\r\n\r\n  private _tryFindEquatable(row: any): void {\r\n    let foundEqualRow: boolean = false;\r\n    for (let i: number = 0; i < this.gridData.length; i++) {\r\n      console.log('proc row : ', this.gridData[i]);\r\n      let isCurrentRowEqual: boolean = true;\r\n      this._equatableFields?.forEach(f => {\r\n        console.log('proc field : ', f);\r\n        if (this.gridData[i][f] != row[f]) {\r\n          console.log('not equal ', row, this.gridData[i]);\r\n          isCurrentRowEqual = false;\r\n        }\r\n      });\r\n      if (isCurrentRowEqual) {\r\n        this._fusionRows(this.gridData[i], row);\r\n        foundEqualRow = true;\r\n        break;\r\n      }\r\n    }\r\n    if (foundEqualRow) {\r\n      console.log('deleting : ', row);\r\n      this.delete(row);\r\n    }\r\n  }\r\n\r\n  private _fusionRows(row1: any, row2: any) {\r\n    this._sumAtFusionFields?.forEach(f => {\r\n      row1[f] += row2[f];\r\n    });\r\n  }\r\n  //#endregion\r\n}\r\n","<div class=\"card\">\r\n  <p-table #dt [selectionMode]=\"selectionMode\" [(selection)]=\"selectedItems\" editMode=\"row\"\r\n    [paginator]=\"gridData.length > pageSize\" [rowsPerPageOptions]=\"rowPerPage\" [rows]=\"pageSize\"\r\n    (onRowSelect)=\"onRowSelected($event)\" (onRowUnselect)=\"onRowUnselect($event)\" [scrollable]=\"true\"\r\n    [resizableColumns]=\"true\" columnResizeMode=\"expand\" appendTo=\"body\" styleClass=\"p-datatable-sm\" [value]=\"gridData\"\r\n    [columns]=\"selectedColumns\" [dataKey]=\"key\" [scrollHeight]=\"scrollHeight\" styleClass=\"p-datatable-gridlines\"\r\n    (selectionChange)=\"selectionChange($event)\" #editableTable [totalRecords]=\"gridData.length\">\r\n    <!-- [tableStyle]=\"{'min-width': '50rem','width': 'inherit'}\" -->\r\n\r\n    <ng-template pTemplate=\"caption\">\r\n      <p-multiSelect [options]=\"columns\" [(ngModel)]=\"selectedColumns\"\r\n        selectedItemsLabel=\"{0} {{ 'columns_selected' | localize }}\" optionLabel=\"translatedHeader\"\r\n        [style]=\"{'min-width': '180px'}\" placeholder=\"{{ 'choose_columns' | localize }}\">\r\n        <ng-template let-option pTemplate=\"item\">\r\n          <div class=\"flex items-center gap-2\">\r\n            <span>{{ option.header | localize }}</span>\r\n          </div>\r\n        </ng-template>\r\n      </p-multiSelect>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n\r\n      <tr>\r\n        <ng-container *ngIf=\"selectionMode != multipleGridSelectionMode\">\r\n          <th pResizableColumn pFrozenColumn style=\"min-width:2rem; left: 1rem !important; width:2rem !important;\"></th>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"selectionMode == multipleGridSelectionMode\">\r\n          <th pResizableColumn pFrozenColumn style=\"min-width:2rem; left: 1rem !important; width:2rem !important;\">\r\n            <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n          </th>\r\n        </ng-container>\r\n        \r\n        <th pResizableColumn pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n\r\n        <!-- <th pResizableColumn pFrozenColumn *ngIf=\"showEditButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th> -->\r\n        \r\n        <th pResizableColumn pFrozenColumn *ngIf=\"showConsultButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n        <th pResizableColumn pFrozenColumn *ngIf=\"showDeleteButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n\r\n        <th pResizableColumn pFrozenColumn [frozen]=\"col.isFrozen\" [style]=\"col.style\" scope=\"col\"\r\n          style=\"min-width:3rem;\" pSortableColumn=\"{{col.field}}\" *ngFor=\"let col of columns\"\r\n          pTooltip=\"{{col.toolTipText | localize }}\" tooltipPosition=\"top\" pReorderableColumn>{{ col.header | localize\r\n          }}\r\n          <p-sortIcon field=\"{{col.field}}\"></p-sortIcon>\r\n          <Tsi-Bubble-Info [infoText]=\"col.infoText | localize\"></Tsi-Bubble-Info>\r\n        </th>\r\n        <th style=\"min-width:3rem\" *ngIf=\"showRowSummary\" scope=\"col\">{{'RowSummary' | localize}}</th>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"body\" let-item let-editing=\"editing\" let-columns=\"columns\" let-rowIndex=\"rowIndex\">\r\n      \r\n      <tr [pEditableRow]=\"item\"\r\n        *ngIf=\"selectionMode == multipleGridSelectionMode || selectionMode == undefined; else selectionModeBlock\"\r\n        (focusOut)=\"onFocusOutRow(item)\">\r\n        \r\n        <td style=\"text-align: center;\">\r\n          <p-tableCheckbox [value]=\"item\" ></p-tableCheckbox>\r\n        </td>\r\n\r\n        <!-- <td pFrozenColumn style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1\"> -->\r\n\r\n\r\n        <!-- <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n        </td> -->\r\n\r\n        <!-- <td pFrozenColumn *ngIf=\"showEditButton\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n          <div class=\"flex align-items-center justify-content-center\">\r\n            <button *ngIf=\"!editing\" pButton pRipple type=\"button\" pInitEditableRow icon=\"pi pi-pencil\"\r\n              class=\"p-button-rounded p-button-text\">\r\n            </button>\r\n            <button *ngIf=\"editing\" pButton pRipple type=\"button\" pSaveEditableRow icon=\"pi pi-check\"\r\n              class=\"p-button-rounded p-button-text p-button-success -ml-1\">\r\n            </button>\r\n            <button *ngIf=\"editing\" pButton pRipple type=\"button\" pCancelEditableRow icon=\"pi pi-times\"\r\n              class=\"p-button-rounded p-button-text p-button-danger -ml-2\">\r\n            </button>\r\n          </div>\r\n        </td> -->\r\n        <td pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\" style=\"left: 1rem !important; width:3rem !important;\"></td>\r\n\r\n        <td pFrozenColumn *ngIf=\"showConsultButton\" style=\"left: -1rem !important; width:3rem !important;\"\r\n          class=\"p-1 btn-consult-style\">\r\n          <div class=\"p-0\">\r\n            <Tsi-Button [buttonType]=\"buttonType.Button\" icon=\"p-button-icon pi pi-eye\"\r\n              [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_consulter\"\r\n              styleClass=\"p-button-rounded p-button-text p-button-secondary\" (click)=\"consult(item)\"></Tsi-Button>\r\n          </div>\r\n        </td>\r\n\r\n        <td pFrozenColumn *ngIf=\"showDeleteButton\" \r\n          style=\"left: 1rem !important; width:3rem !important;\"\r\n          class=\"p-1 btn-delete-style\">\r\n          <div class=\"p-0\">\r\n            <Tsi-Button [disabled]=\"isDeleteButtonDisabled(item)\" type=\"button\" icon=\"p-button-icon pi pi-trash\"\r\n              [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_supprimer\"\r\n              styleClass=\"p-element p-button-rounded p-button-text p-button-danger p-button p-component p-button-icon-only\"\r\n              (click)=\"delete(item)\"></Tsi-Button>\r\n          </div>\r\n        </td>\r\n\r\n\r\n        <td class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\"\r\n          [ngStyle]=\"isAr ? {'text-align': 'start'} : {}\">\r\n          \r\n          \r\n          <div *ngIf=\"col.displayOnly || disabled; else ordinaryBloc\">\r\n\r\n                <!-- Tsi-Search-Combo -->\r\n                <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteOutputBlock\">\r\n                  <Tsi-Search-Combo [disabled]=\"true\" [elementSourceUrl]=\"col.elementSourceUrl\"\r\n                    [businessClass]=\"col.businessClass\" [currentRowItem]=\"item\" [(bind)]=\"item[col.field]\"\r\n                    id-field=\"{{col.idField}}\" [listSourceUrl]=\"col.listSourceUrl\" label-field=\"{{col.labelField}}\"\r\n                    [isFiltered]=\"col.isFiltered\" [datasource]=\"col.datasource\"\r\n                    [showSearchButton]=\"col.showSearchButton ?? true\" [showAddButton]=\"col.showAddButton ?? true\"\r\n                    [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                    [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                    [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                    [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n                </div>\r\n\r\n                <!-- Tsi-Currency-Societe-Display -->\r\n                <ng-template #currencySocieteOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherOutputBlock\">\r\n                    <Tsi-Currency-Societe-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Societe-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Currency-Other-Display -->\r\n                <ng-template #currencyOtherOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerOutputBlock\">\r\n                    <Tsi-Currency-Other-Display [currency]=\"col.currencyOtherCode\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Other-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Date-Display -->\r\n                <ng-template #datePickerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxOutputBlock\">\r\n                    <Tsi-Date-Display [showTime]=\"col.showTime\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Date-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-CheckBox-Display -->\r\n                <ng-template #checkBoxOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalOutputBlock\">\r\n                    <Tsi-Checkbox-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Checkbox-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Decimal-Display -->\r\n                <ng-template #decimalOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerOutputBlock\">\r\n                    <Tsi-Decimal-Display [formatDecimal]=\"col.formatDecimal\" [inputData]=\"item[col.field]\"\r\n                      [numOfDecimal]=\"col.numOfDecimal\">\r\n                    </Tsi-Decimal-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Integer-Display -->\r\n                <ng-template #integerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateOutputBlock\">\r\n                    <Tsi-Integer-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Integer-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Rate-Display -->\r\n                <ng-template #rateOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeOutputBlock\">\r\n                    <Tsi-Rate-Display [isFraction]=\"col.isFraction\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Rate-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Time-Display -->\r\n                <ng-template #timeOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.TIME; else formulaOutputBlock\">\r\n                    <tsi-time-display [inputData]=\"item[col.field]\"></tsi-time-display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Formula-Display -->\r\n                <ng-template #formulaOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextOutputBlock\">\r\n                    <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Text-Box -->\r\n                <ng-template #defaultTextOutputBlock>\r\n                  <ng-container>\r\n                    <span>\r\n                      {{item[col.field]}}\r\n                    </span>\r\n                  </ng-container>\r\n                </ng-template>\r\n          </div>\r\n\r\n          <ng-template #ordinaryBloc> \r\n            \r\n            <!-- Tsi-Search-Combo -->\r\n            <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteInputBlock\">\r\n              <Tsi-Search-Combo [elementSourceUrl]=\"col.elementSourceUrl\" (bindChange)=\"inputChanged(col)\"\r\n                [businessClass]=\"col.businessClass\" [listSourceUrl]=\"col.listSourceUrl\" [(bind)]=\"item[col.field]\"\r\n                id-field=\"{{col.idField}}\" label-field=\"{{col.labelField}}\" [isFiltered]=\"col.isFiltered\"\r\n                [currentRowItem]=\"item\" (bindChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                [datasource]=\"col.datasource\" [showSearchButton]=\"col.showSearchButton ?? true\"\r\n                [showAddButton]=\"col.showAddButton ?? true\" [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n            </div>\r\n\r\n            <!-- Tsi-Currency-Societe-Input -->\r\n            <ng-template #currencySocieteInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherInputBlock\">\r\n                <Tsi-Currency-Societe-Input [inputName]=\"col.inputName\" [disabled]=\"col.disabled\" [inputId]=\"col.field\"\r\n                  [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Currency-Societe-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Currency-Other-Input -->\r\n            <ng-template #currencyOtherInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerInputBlock\">\r\n                <Tsi-Currency-Other-Input [inputName]=\"col.inputName\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\" [inputId]=\"col.field\"\r\n                  [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [numOfDecimal]=\"col.numOfDecimal\" [disabled]=\"col.disabled\">\r\n                </Tsi-Currency-Other-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Date-Picker -->\r\n            <ng-template #datePickerInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxInputBlock\">\r\n                <Tsi-Date-Picker [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [showTime]=\"col.showTime\"\r\n                  [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Date-Picker>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-CheckBox -->\r\n            <ng-template #checkBoxInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalInputBlock\">\r\n                <Tsi-CheckBox [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-CheckBox>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Decimal-Input -->\r\n            <ng-template #decimalInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerInputBlock\">\r\n                <Tsi-Decimal-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                  [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Decimal-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Integer -->\r\n            <ng-template #integerInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateInputBlock\">\r\n                <Tsi-Integer [inputName]=\"col.inputName\" [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                  [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\">\r\n                </Tsi-Integer>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Rate-Input -->\r\n            <ng-template #rateInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeInputBloc\">\r\n                <Tsi-Rate-Input [inputName]=\"col.inputName\" [numOfDecimal]=\"col.numOfDecimal\" [inputId]=\"col.field\"\r\n                  [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Rate-Input>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Time-picker bloc -->\r\n            <ng-template #timeInputBloc>\r\n              <ng-container *ngIf=\"col.type == inputTypes.TIME; else formulaInputBlock\">\r\n                <tsi-time-picker (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [inputName]=\"col.inputName\"\r\n                  [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\" [disabled]=\"col.disabled\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </tsi-time-picker>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <ng-template #formulaInputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextInputBlock\">\r\n                <!--<Tsi-Bubble-Info\r\n                  [infoText]=\"['formula_explication',\r\n                  ]\"></Tsi-Bubble-Info> -->\r\n                <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                  [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Text-Box -->\r\n            <ng-template #defaultTextInputBlock>\r\n              <ng-container>\r\n                <Tsi-Text-Box [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\" (keydown)=\"handleKeydown($event)\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                  [inputName]=\"col.inputName\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                </Tsi-Text-Box>\r\n              \r\n              </ng-container>\r\n            </ng-template>\r\n          </ng-template>\r\n\r\n        </td>\r\n\r\n        <td *ngIf=\"showRowSummary\" class=\"font-bold\">\r\n          {{rowSummary(item)}}\r\n        </td>\r\n      </tr>\r\n\r\n      <ng-template #selectionModeBlock>\r\n        <ng-container>\r\n          <tr [pEditableRow]=\"item\" [pSelectableRow]=\"item\" [pSelectableRowIndex]=\"rowIndex\"\r\n            (focusOut)=\"onFocusOutRow(item)\">\r\n\r\n       <!-- <td pFrozenColumn style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1\"> -->\r\n\r\n            <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n              </td>\r\n\r\n            <!-- <td *ngIf=\"selectionMode == multipleGridSelectionMode\" style=\"width: 2rem;\">\r\n              <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n            </td> -->\r\n\r\n            <!-- <td pFrozenColumn *ngIf=\"showEditButton\" style=\"min-width:3rem;left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n              <div class=\"flex align-items-center justify-content-center\">\r\n                <button *ngIf=\"!editing\" pButton pRipple type=\"button\" pInitEditableRow icon=\"pi pi-pencil\"\r\n                  class=\"p-button-rounded p-button-text\">\r\n                </button>\r\n                <button *ngIf=\"editing\" pButton pRipple type=\"button\" pSaveEditableRow icon=\"pi pi-check\"\r\n                  class=\"p-button-rounded p-button-text p-button-success -ml-1\">\r\n                </button>\r\n                <button *ngIf=\"editing\" pButton pRipple type=\"button\" pCancelEditableRow icon=\"pi pi-times\"\r\n                  class=\"p-button-rounded p-button-text p-button-danger -ml-2\">\r\n                </button>\r\n              </div>\r\n            </td> -->\r\n            \r\n            <td pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\" style=\"left: 1rem !important; width:3rem !important;\">\r\n            </td>\r\n            \r\n            <td pFrozenColumn pResizableColumn *ngIf=\"showConsultButton\"\r\n              style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1 btn-consult-style\">\r\n              <div class=\"p-0\">\r\n                <Tsi-Button [buttonType]=\"buttonType.Button\" icon=\"p-button-icon pi pi-eye\"\r\n                  [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_consulter\"\r\n                  styleClass=\"p-button-rounded p-button-text p-button-secondary\" (click)=\"consult(item)\"></Tsi-Button>\r\n              </div>\r\n            </td>\r\n\r\n            <td pFrozenColumn pResizableColumn *ngIf=\"showDeleteButton\" style=\"left: 1rem !important; width:3rem !important;\"\r\n              class=\"p-1 btn-delete-style\">\r\n              <div class=\"p-0\">\r\n                <Tsi-Button type=\"button\" icon=\"p-button-icon pi pi-trash\" [tooltipPosition]=\"tooltipPosition.Top\"\r\n                  tooltipText=\"shared_edittable_supprimer\"\r\n                  styleClass=\"p-element p-button-rounded p-button-text p-button-danger p-button p-component p-button-icon-only\"\r\n                  (click)=\"delete(item)\"></Tsi-Button>\r\n              </div>\r\n            </td>\r\n            \r\n            <td class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\">\r\n\r\n              <div *ngIf=\"col.displayOnly || disabled; else ordinaryBloc\">\r\n                <!-- Tsi-Search-Combo -->\r\n                <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteOutputBlock\">\r\n                  <Tsi-Search-Combo [disabled]=\"true\" [elementSourceUrl]=\"col.elementSourceUrl\"\r\n                    [businessClass]=\"col.businessClass\" [currentRowItem]=\"item\" [(bind)]=\"item[col.field]\"\r\n                    id-field=\"{{col.idField}}\" [listSourceUrl]=\"col.listSourceUrl\" label-field=\"{{col.labelField}}\"\r\n                    [isFiltered]=\"col.isFiltered\" [datasource]=\"col.datasource\"\r\n                    [showSearchButton]=\"col.showSearchButton ?? true\" [showAddButton]=\"col.showAddButton ?? true\"\r\n                    [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                    [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                    [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                    [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n                </div>\r\n\r\n                <!-- Tsi-Currency-Societe-Display -->\r\n                <ng-template #currencySocieteOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherOutputBlock\">\r\n                    <Tsi-Currency-Societe-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Societe-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Currency-Other-Display -->\r\n                <ng-template #currencyOtherOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerOutputBlock\">\r\n                    <Tsi-Currency-Other-Display [currency]=\"col.currencyOtherCode\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Currency-Other-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Date-Display -->\r\n                <ng-template #datePickerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxOutputBlock\">\r\n                    <Tsi-Date-Display [showTime]=\"col.showTime\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Date-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-CheckBox-Display -->\r\n                <ng-template #checkBoxOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalOutputBlock\">\r\n                    <Tsi-Checkbox-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Checkbox-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Decimal-Display -->\r\n                <ng-template #decimalOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerOutputBlock\">\r\n                    <Tsi-Decimal-Display [formatDecimal]=\"col.formatDecimal\" [inputData]=\"item[col.field]\"\r\n                      [numOfDecimal]=\"col.numOfDecimal\">\r\n                    </Tsi-Decimal-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Integer-Display -->\r\n                <ng-template #integerOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateOutputBlock\">\r\n                    <Tsi-Integer-Display [inputData]=\"item[col.field]\">\r\n                    </Tsi-Integer-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Rate-Display -->\r\n                <ng-template #rateOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeOutputBlock\">\r\n                    <Tsi-Rate-Display [isFraction]=\"col.isFraction\" [inputData]=\"item[col.field]\">\r\n                    </Tsi-Rate-Display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Time-Display -->\r\n                <ng-template #timeOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.TIME; else formulaOutputBlock\">\r\n                    <tsi-time-display [inputData]=\"item[col.field]\"></tsi-time-display>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Formula-Display -->\r\n                <ng-template #formulaOutputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextOutputBlock\">\r\n                    <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Text-Box -->\r\n                <ng-template #defaultTextOutputBlock>\r\n                  <ng-container>\r\n                    <span>\r\n                      {{item[col.field]}}\r\n                    </span>\r\n                  </ng-container>\r\n                </ng-template>\r\n              </div>\r\n              \r\n              <ng-template #ordinaryBloc>\r\n                <!-- Tsi-Search-Combo -->\r\n                <div *ngIf=\"col.type == inputTypes.SEARCH_COMBO; else currencySocieteInputBlock\">\r\n                  <Tsi-Search-Combo [elementSourceUrl]=\"col.elementSourceUrl\" (bindChange)=\"inputChanged(col)\"\r\n                    [listSourceUrl]=\"col.listSourceUrl\" [(bind)]=\"item[col.field]\" id-field=\"{{col.idField}}\"\r\n                    label-field=\"{{col.labelField}}\" [isFiltered]=\"col.isFiltered\" [businessClass]=\"col.businessClass\"\r\n                    (bindChange)=\"onCellValueChanged(col, $event, item)\" [currentRowItem]=\"item\"\r\n                    [datasource]=\"col.datasource\" [disabled]=\"col.disabled\"\r\n                    [showSearchButton]=\"col.showSearchButton ?? true\" [showAddButton]=\"col.showAddButton ?? true\"\r\n                    [showUpdateButton]=\"col.showUpdateButton ?? undefined\"\r\n                    [showConsultButton]=\"col.showConsultButton ?? undefined\"\r\n                    [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                    [inputName]=\"col.inputName\"></Tsi-Search-Combo>\r\n                </div>\r\n\r\n                <!-- Tsi-Currency-Societe-Input -->\r\n                <ng-template #currencySocieteInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherInputBlock\">\r\n                    <Tsi-Currency-Societe-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Currency-Societe-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Currency-Other-Input -->\r\n                <ng-template #currencyOtherInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else datePickerInputBlock\">\r\n                    <Tsi-Currency-Other-Input [disabled]=\"col.disabled\" [inputName]=\"col.inputName\"\r\n                      [inputId]=\"col.field\" (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Currency-Other-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Date-Picker -->\r\n                <ng-template #datePickerInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DATE; else checkBoxInputBlock\">\r\n                    <Tsi-Date-Picker [showTime]=\"col.showTime\" [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Date-Picker>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-CheckBox -->\r\n                <ng-template #checkBoxInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.CHECKBOX; else decimalInputBlock\">\r\n                    <Tsi-CheckBox [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-CheckBox>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Decimal-Input -->\r\n                <ng-template #decimalInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerInputBlock\">\r\n                    <Tsi-Decimal-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      [(inputField)]=\"item[col.field]\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\">\r\n                    </Tsi-Decimal-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Integer -->\r\n                <ng-template #integerInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateInputBlock\">\r\n                    <Tsi-Integer [class]=\"'max-w-4rem'\" [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\">\r\n                    </Tsi-Integer>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Rate-Input -->\r\n                <ng-template #rateInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else timeInputBloc\">\r\n                    <Tsi-Rate-Input [inputName]=\"col.inputName\" [inputId]=\"col.field\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [disabled]=\"col.disabled\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Rate-Input>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Time-Picker -->\r\n                <ng-template #timeInputBloc>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.TIME else formulaInputBlock\">\r\n                    <tsi-time-picker (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [inputName]=\"col.inputName\" [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                      [disabled]=\"col.disabled\" [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </tsi-time-picker>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <ng-template #formulaInputBlock>\r\n                  <ng-container *ngIf=\"col.type == inputTypes.FORMULA_TEXT_BOX; else defaultTextInputBlock\">\r\n                    <Tsi-Formula-Box [inputName]=\"col.inputName\" [(value)]=\"item[col.field]\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\"></Tsi-Formula-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n\r\n                <!-- Tsi-Text-Box -->\r\n                <ng-template #defaultTextInputBlock>\r\n                  <ng-container>\r\n                    <Tsi-Text-Box [inputId]=\"col.field\" [disabled]=\"col.disabled\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      [(inputField)]=\"item[col.field]\" (keydown)=\"handleKeydown($event)\"\r\n                      (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [inputName]=\"col.inputName\"\r\n                      [validationStatusCssClass]=\"col.validationStatusCssClass\">\r\n                    </Tsi-Text-Box>\r\n                  </ng-container>\r\n                </ng-template>\r\n              </ng-template>\r\n\r\n            </td>\r\n            <td *ngIf=\"showRowSummary\" class=\"font-bold\">\r\n              {{rowSummary(item)}}\r\n            </td>\r\n          </tr>\r\n        </ng-container>\r\n      </ng-template>\r\n\r\n    </ng-template>\r\n\r\n    <ng-template *ngIf=\"showHaveSumary\" pTemplate=\"footer\" let-columns>\r\n\r\n      <tr class=\"tfooter\">\r\n        <!-- <td pFrozenColumn scope=\"col\" style=\"left: 1rem !important; width:3rem !important;\"></td> -->\r\n        <td *ngIf=\"selectionMode == multipleGridSelectionMode\"\r\n          style=\"min-width:2rem; left: 1rem !important; width:2rem !important;\">\r\n          <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n        </td>\r\n        <td pFrozenColumn scope=\"col\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\">Total</td>\r\n        <td pFrozenColumn *ngIf=\"showDeleteButton\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"\r\n          class=\"p-1\">\r\n        <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n          <!--<td pFrozenColumn *ngIf=\"showEditButton\" style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"\r\n          class=\"p-1\"> -->\r\n        <td pFrozenColumn *ngIf=\"showConsultButton\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n        </td>\r\n        <td pFrozenColumn [frozen]=\"col.isFrozen\" [style]=\"col.style\" scope=\"col\" *ngFor=\"let col of columns\">\r\n          <div *ngIf=\"col.haveSummary\">\r\n            <!-- Tsi-Currency-Societe-Display -->\r\n            <div *ngIf=\"col.type == inputTypes.CURRENCY_SOCIETE_INPUT; else currencyOtherOutputBlock\">\r\n              <Tsi-Currency-Societe-Display [inputData]=\"getSummary(col)\">\r\n              </Tsi-Currency-Societe-Display>\r\n            </div>\r\n\r\n            <!-- Tsi-Currency-Other-Display -->\r\n            <ng-template #currencyOtherOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.CURRENCY_OTHER_INPUT; else decimalOutputBlock\">\r\n                <Tsi-Currency-Other-Display [currency]=\"col.currencyCode\" [inputData]=\"getSummary(col)\">\r\n                </Tsi-Currency-Other-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Decimal-Display -->\r\n            <ng-template #decimalOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.DECIMAL_INPUT; else integerOutputBlock\">\r\n                <Tsi-Decimal-Display [formatDecimal]=\"col.formatDecimal\" [inputData]=\"getSummary(col)\"\r\n                  [numOfDecimal]=\"col.numOfDecimal\">\r\n                </Tsi-Decimal-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Integer-Display -->\r\n            <ng-template #integerOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.INTEGER; else rateOutputBlock\">\r\n                <Tsi-Integer-Display [inputData]=\"getSummary(col)\">\r\n                </Tsi-Integer-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Tsi-Rate-Display -->\r\n            <ng-template #rateOutputBlock>\r\n              <ng-container *ngIf=\"col.type == inputTypes.RATE_INPUT; else defaultTextOutputBlock\">\r\n                <Tsi-Rate-Display [isFraction]=\"col.isFraction\" [inputData]=\"getSummary(col)\">\r\n                </Tsi-Rate-Display>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <!-- Default -->\r\n            <ng-template #defaultTextOutputBlock>\r\n              <ng-container>\r\n                <span>\r\n                  {{getSummary(col)}}\r\n                </span>\r\n              </ng-container>\r\n            </ng-template>\r\n          </div>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"summary\">\r\n      <tr>\r\n        {{'TotalRecordsCount' | localize }} {{gridData.length}}\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n  <div>\r\n    <Tsi-Button *ngIf=\"showAddButton\" style=\"height: 20px;width: 20px;\" icon=\"p-button-icon pi pi-plus\" type=\"button\"\r\n      [tooltipPosition]=\"tooltipPosition.Top\" tooltipText=\"shared_edittable_ajouter\"\r\n      styleClass=\"p-element p-button-sm p-button-success p-button-text p-button p-component p-button-icon-only ng-star-inserted\"\r\n      (click)=\"addRow()\"></Tsi-Button>\r\n  </div>\r\n</div>"]}