@tsi-developpement/tsi-shared-ui 0.0.10 → 1.0.1

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.
@@ -405,7 +405,19 @@ export class EditableGridComponent {
405
405
  if (this.columns) {
406
406
  //console.log('_initRow :: configuration : ', this.configuration);
407
407
  this.columns.forEach(col => {
408
- newRow[col.field] = undefined;
408
+ if (col.type == InputTypes.DECIMAL_INPUT
409
+ || col.type == InputTypes.RATE_INPUT
410
+ || col.type == InputTypes.INTEGER
411
+ || col.type == InputTypes.CURRENCY_SOCIETE_INPUT
412
+ || col.type == InputTypes.CURRENCY_OTHER_INPUT) {
413
+ newRow[col.field] = 0;
414
+ }
415
+ else if (col.type == InputTypes.CHECKBOX) {
416
+ newRow[col.field] = false;
417
+ }
418
+ else {
419
+ newRow[col.field] = undefined;
420
+ }
409
421
  });
410
422
  if (this._isAutoRowNumber === true) {
411
423
  newRow[this._autoRowNumberField] = this._nextRowNumber();
@@ -634,4 +646,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
634
646
  }], id: [{
635
647
  type: Input
636
648
  }] } });
637
- //# 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 { GridSelectionMode, InputTypes, ModalSizeEnum, ButtonType, TooltipPosition} from '../../../enums';\r\nimport { CellChangedResult, GridColumn, IGridConfiguration, RowAddedResult } from '../../../interfaces';\r\nimport { rtlModeKeys } from '../../../consts/locals.const';\r\nimport { LocalizePipe } from '../../../pipes/localize.pipe';\r\nimport { EntityValidationsService } from '../../../services/validation/entity-validations.service';\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})\r\nexport class EditableGridComponent implements OnInit, OnDestroy {\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\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  @Input() disabled: 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._entityValidationsService.getEntityValidations(this.editableGridBusinessClass).subscribe({\r\n      next: (entityValidations) => {\r\n        entityValidations.forEach(el => {\r\n          let col = this.columns.find(c => c.labelField?.toLocaleLowerCase() === el.columnName.toLocaleLowerCase() || \r\n                                      c.field?.toLocaleLowerCase() === el.columnName.toLocaleLowerCase());\r\n          if(col){\r\n            col.validationStatusCssClass = el.isNullable !== true ? 'border-red-500 border-3' : '';\r\n          }\r\n        })\r\n      }\r\n    })\r\n  }\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\r\n  constructor(private _localizePipe: LocalizePipe) {\r\n   }\r\n\r\n  ngOnInit() {\r\n    this._initSaveEventSubscription();\r\n    this._verifyGridRequirements();\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n    this._initEquatableFields();\r\n    this._initSumAtFusionFields();\r\n    let langue = localStorage.getItem(rtlModeKeys.rtlModeEnabled);\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    if (!this.selectedColumns || this.selectedColumns.length == 0) {\r\n      this.selectedColumns = this.columns\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  ngOnDestroy(): void {\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    let rowAddedResult: RowAddedResult = {\r\n      rowNumber: this.gridData.length - 1,\r\n      data: newRow\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._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\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    let selection: any[] = [];\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    if (this.selectionMode != GridSelectionMode.None) {\r\n      this.selectedItemsChange.emit(selection)\r\n    }\r\n\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  //#region private methods\r\n  private _initRow() {\r\n    let newRow: any = {};\r\n    //console.log('start _initRow', this.configuration);\r\n    if (this.columns) {\r\n      //console.log('_initRow :: configuration : ', this.configuration);\r\n      this.columns.forEach(col => {\r\n        newRow[col.field] = undefined;\r\n      });\r\n\r\n      if (this._isAutoRowNumber === true) {\r\n        newRow[this._autoRowNumberField] = this._nextRowNumber();\r\n\r\n        //console.log('_initRow :: newRow : ', newRow);\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\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\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\" [paginator]=\"gridData.length > pageSize\"\r\n    [rowsPerPageOptions]=\"rowPerPage\" [rows]=\"pageSize\" (onRowSelect)=\"onRowSelected($event)\"\r\n    (onRowUnselect)=\"onRowUnselect($event)\" [scrollable]=\"true\" [resizableColumns]=\"true\" columnResizeMode=\"expand\"\r\n    appendTo=\"body\" styleClass=\"p-datatable-sm\" [value]=\"gridData\" [columns]=\"selectedColumns\" [dataKey]=\"key\"\r\n    [scrollHeight]=\"scrollHeight\" styleClass=\"p-datatable-gridlines\" (selectionChange)=\"selectionChange($event)\"\r\n    #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        <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        <th pResizableColumn pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n        <!-- <th pResizableColumn pFrozenColumn *ngIf=\"showEditButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th> -->\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        <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      <tr [pEditableRow]=\"item\"\r\n        *ngIf=\"selectionMode == multipleGridSelectionMode || selectionMode == undefined; else selectionModeBlock\"\r\n        (focusOut)=\"onFocusOutRow(item)\">\r\n        <td>\r\n          <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\r\n        </td>\r\n         <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n        </td>\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        <td pFrozenColumn *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 [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        <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 class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\"\r\n          [ngStyle]=\"isAr ? {'text-align': 'start'} : {}\">\r\n\r\n          <ng-template #ordinaryBloc>\r\n\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\"\r\n                [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                  [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]\"\r\n                  (keydown)=\"handleKeydown($event)\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [disabled]=\"col.disabled\" [inputName]=\"col.inputName\" [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-template #selectionModeBlock>\r\n        <ng-container>\r\n          <tr [pEditableRow]=\"item\" [pSelectableRow]=\"item\" [pSelectableRowIndex]=\"rowIndex\"\r\n            (focusOut)=\"onFocusOutRow(item)\">\r\n            <td pFrozenColumn style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n            <td *ngIf=\"selectionMode == multipleGridSelectionMode\" style=\"width: 2rem;\">\r\n              <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n            </td>\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;\">\r\n            </td>\r\n            <td pFrozenColumn *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            <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            <td class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\">\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              <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\" [inputId]=\"col.field\"\r\n                      (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\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [disabled]=\"col.disabled\" [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\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      [numOfDecimal]=\"col.numOfDecimal\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [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\" (inputFieldChange)=\"inputChanged(col)\"\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 -->\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-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\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (keydown)=\"handleKeydown($event)\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [inputName]=\"col.inputName\" [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    </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;\"\r\n          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>"]}
649
+ //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAI7G,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,eAAe,EAAC,MAAM,gBAAgB,CAAC;AAE1G,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAE3D,OAAO,EAAE,wBAAwB,EAAE,MAAM,yDAAyD,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOnG,MAAM,OAAO,qBAAqB;IAgDhC,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAa,OAAO,CAAC,KAAwB;QAC3C,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,CAAC;QACzF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAA;QACrB,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACrC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAA;QACtC,CAAC;IACH,CAAC;IACD,IAAa,QAAQ,CAAC,IAAgB;QACpC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,wCAAwC,EAAE,CAAC;IAClD,CAAC;IACD,IAAI,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAyBzC,IAAI,yBAAyB;QAC3B,OAAO,IAAI,CAAC,0BAA0B,CAAC;IACzC,CAAC;IACD,IAAa,yBAAyB,CAAC,SAAkB;QACvD,IAAI,CAAC,0BAA0B,GAAG,SAAS,CAAC;QAC5C,IAAI,CAAC,yBAAyB,CAAC,oBAAoB,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC,SAAS,CAAC;YAC5F,IAAI,EAAE,CAAC,iBAAiB,EAAE,EAAE;gBAC1B,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;oBAC7B,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC,UAAU,CAAC,iBAAiB,EAAE;wBAC5E,CAAC,CAAC,KAAK,EAAE,iBAAiB,EAAE,KAAK,EAAE,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC,CAAC;oBAChG,IAAG,GAAG,EAAC,CAAC;wBACN,GAAG,CAAC,wBAAwB,GAAG,EAAE,CAAC,UAAU,KAAK,IAAI,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,CAAC;oBACzF,CAAC;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC;SACF,CAAC,CAAA;IACJ,CAAC;IAkDD,YAAoB,aAA2B;QAA3B,kBAAa,GAAb,aAAa,CAAc;QAtJvC,qBAAgB,GAAY,KAAK,CAAC;QAClC,wBAAmB,GAAW,EAAE,CAAC;QACjC,sBAAiB,GAAW,CAAC,CAAC;QACtC,oBAAe,GAAG,eAAe,CAAC;QAClC,SAAI,GAAY,KAAK,CAAC;QACd,cAAS,GAAe,EAAE,CAAC;QAG3B,qBAAgB,GAAY,KAAK,CAAC;QAC1C,8BAAyB,GAAG,iBAAiB,CAAC,QAAQ,CAAC;QACvD,YAAY;QACZ,eAAU,GAAG,UAAU,CAAC;QACxB,cAAS,GAAG,aAAa,CAAC,UAAU,CAAC;QAGrC,eAAU,GAAG,UAAU,CAAC;QAEf,kBAAa,GAAQ,EAAE,CAAC;QAOnB,QAAG,GAAW,KAAK,CAAC;QACzB,UAAK,GAAe,EAAE,CAAC;QAEvB,kBAAa,GAAY,IAAI,CAAC,CAAA,0BAA0B;QACxD,qBAAgB,GAAY,IAAI,CAAC,CAAA,0BAA0B;QAC3D,mBAAc,GAAY,IAAI,CAAC,CAAA,0BAA0B;QACzD,mBAAc,GAAY,KAAK,CAAC,CAAA,0BAA0B;QAG1D,iBAAY,GAAW,OAAO,CAAC;QAC/B,eAAU,GAAa,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC5C,wCAAwC;QAC/B,aAAQ,GAAY,CAAC,CAAA;QAE9B;;WAEG;QACH,oBAAe,GAAsB,EAAE,CAAC;QAChC,aAAQ,GAAsB,EAAE,CAAC;QAChC,iBAAY,GAAuB,EAAE,CAAC;QAwBtC,mBAAc,GAAY,IAAI,CAAC,CAAA,0BAA0B;QACzD,qBAAgB,GAAY,IAAI,CAAC,CAAA,0BAA0B;QAG3D,uBAAkB,GAAY,KAAK,CAAC;QAEpC,qBAAgB,GAAkB,EAAE,CAAC;QACrC,mBAAc,GAAa,KAAK,CAAC;QACjC,kBAAa,GAAa,KAAK,CAAC;QAEzC,eAAe;QACN,kBAAa,GAAY,IAAI,CAAC;QAC9B,kBAAa,GAA4B,iBAAiB,CAAC,IAAI,CAAC;QAChE,sBAAiB,GAAY,KAAK,CAAC;QACnC,aAAQ,GAAY,KAAK,CAAC;QAE3B,+BAA0B,GAAW,EAAE,CAAC;QAqBhD,WAAW;QACF,gBAAW,GAAW,KAAK,CAAC;QAIrC,YAAY;QAEZ,iBAAiB;QACP,cAAS,GAAwB,IAAI,YAAY,EAAS,CAAC;QACrE;;WAEG;QAGO,wBAAmB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAEtE,8GAA8G;QAEpG,yBAAoB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAE7D,2BAAsB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAE/D,4BAAuB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAEhE,yBAAoB,GAAiC,IAAI,YAAY,EAAkB,CAAA;QAEvF,yBAAoB,GAAG,IAAI,YAAY,EAAU,CAAC;QAElD,gBAAW,GAAoC,IAAI,YAAY,EAAqB,CAAC;QAErF,2BAAsB,GAAG,IAAI,YAAY,EAAO,CAAC;QAEjD,wBAAmB,GAA6B,IAAI,YAAY,EAAc,CAAC;QAE/E,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,gBAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;QACzD,qBAAgB,GAAsB,IAAI,YAAY,EAAO,CAAC;QAOhE,8BAAyB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;IAIpE,CAAC;IAEF,QAAQ;QACN,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,wCAAwC,EAAE,CAAC;QAChD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,MAAM,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QAC9D,IAAI,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;QAClB,CAAC;aACI,CAAC;YACJ,IAAI,CAAC,IAAI,GAAG,KAAK,CAAA;QACnB,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC9D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAA;QACrC,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC;IACnC,CAAC;IAED,eAAe,CAAC,GAAQ;QACtB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,KAAK,IAAI,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBAC7B,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,KAAK,GAAG;oBAAE,OAAO,GAAG,CAAC;;oBACnD,SAAS;YAChB,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAA;IACb,CAAC;IAGM,YAAY,CAAC,aAAqB;QACvC,IAAI,KAAK,GAAe,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QACjD,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACZ,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;gBAEZ,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,KAAK,CAAC,YAAY,CAAC;gBAC/C,IAAI,CAAC,EAAE,CAAC,eAAe,GAAG,KAAK,CAAC,UAAU,CAAC;gBAE3C,IAAI,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;gBAEpC,IAAI,WAAW,EAAE,CAAC;oBAChB,IAAI,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC;oBAC7D,IAAI,CAAC,eAAe,GAAG,gBAAgB,CAAC;oBACxC,IAAI,CAAC,OAAO,GAAG,gBAAgB,CAAC;gBAClC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,mBAAmB,CAAC,WAAqB;QACvC,IAAI,gBAAgB,GAAU,EAAE,CAAC;QAEjC,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACtB,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;YACpC,IAAI,GAAG,EAAE,CAAC;gBACR,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED,oBAAoB,CAAC,aAAqB;QACxC,IAAI,KAAK,GAAe,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QACjD,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YAEZ,IAAI,CAAC,EAAE,CAAC,iBAAiB,GAAG,KAAK,CAAC,YAAY,CAAC;YAC/C,IAAI,CAAC,EAAE,CAAC,eAAe,GAAG,KAAK,CAAC,UAAU,CAAC;YAE3C,IAAI,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YAEpC,IAAI,WAAW,EAAE,CAAC;gBAChB,IAAI,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC;gBAC7D,IAAI,CAAC,eAAe,GAAG,gBAAgB,CAAC;gBACxC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAA;YAClC,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,KAAK,GAAe,EAAE,CAAC;QAE3B,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;YACb,OAAM;QACR,CAAC;QAED,IAAI,IAAI,CAAC,EAAE,CAAC,gBAAgB,EAAE,CAAC;YAC7B,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAClC,CAAC;QAED,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAE/B,OAAO,KAAK,CAAA;IACd,CAAC;IAED,sBAAsB,CAAC,IAAS;QAC9B,IAAI,IAAI,CAAC,wBAAwB,IAAI,SAAS,EAAE,CAAC;YAC/C,OAAO,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAA;QAC5C,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED,YAAY,CAAC,GAAe;QAC1B,IAAI,GAAG,CAAC,eAAe,KAAK,IAAI,EAAE,CAAC;YACjC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAED,SAAS;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACnC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChD,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACrB,CAAC;QACD,IAAI,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAA;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC1B,IAAI,cAAc,GAAmB;YACnC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;YACnC,IAAI,EAAE,MAAM;SACb,CAAA;QACD,IAAI,IAAI,CAAC,aAAa,EAAE,SAAS,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YAClE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QACxC,CAAC;QACD,IAAI,CAAC,WAAW,EAAE,CAAA;QAClB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IAChD,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,aAAa,EAAE,SAAS,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;YAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;YAE/C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC1B,MAAM,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC;gBAC5B,MAAM,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC;gBAC5B,IAAI,MAAM,GAAG,CAAC,CAAC;gBAEf,IAAI,MAAM,GAAG,MAAM;oBAAE,MAAM,GAAG,CAAC,CAAC,CAAC;qBAC5B,IAAI,MAAM,GAAG,MAAM;oBAAE,MAAM,GAAG,CAAC,CAAC;gBAErC,OAAO,MAAM,GAAG,SAAS,CAAC;YAC5B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAED,mBAAmB,CAAC,IAAS,EAAE,GAAe;QAC5C,IAAI,CAAC,sCAAsC,EAAE,CAAC;QAC9C,IAAI,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/C,IAAI,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAE5C,IAAI,YAAY,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACvF,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC;IACH,CAAC;IAED,MAAM,CAAC,IAAS;QACd,IAAI,IAAI,CAAC,aAAa,EAAE,SAAS,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YACjE,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACxD,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;gBACf,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;YAC3C,CAAC;QACH,CAAC;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC7C,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;YACf,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAC/B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QACjD,CAAC;QACD,IAAI,CAAC,WAAW,EAAE,CAAA;IACpB,CAAC;IAED,UAAU,CAAC,GAAe;QACxB,IAAI,GAAG,CAAC,WAAW,IAAI,IAAI,EAAE,CAAC;YAE5B,IAAI,GAAG,GAAG,CAAC,CAAC;YACZ,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACjC,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACxB,CAAC,CAAC,CAAA;YACF,OAAO,GAAG,CAAC;QACb,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAED,UAAU,CAAC,GAAQ;QACjB,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACzB,IAAI,GAAG,CAAC,UAAU,IAAI,IAAI,EAAE,CAAC;gBAC3B,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACxB,CAAC;QACH,CAAC,CAAC,CAAC;QACH,OAAO,GAAG,CAAC;IAEb,CAAC;IAGD,aAAa,CAAC,KAA0B;QACtC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAA;QAC9B,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,EAAE,CAAC;YAC/B,IAAI,YAAiB,CAAC;YACtB,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC3C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACtC,CAAC;aACI,CAAC;YACJ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IAED,aAAa,CAAC,KAA4B;QACxC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAA;IAC/B,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,SAAS,GAAU,EAAE,CAAC;QAC1B,IAAI,IAAI,CAAC,aAAa,IAAI,iBAAiB,CAAC,QAAQ,EAAE,CAAC;YACrD,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;oBACvB,IAAI,IAAI,GAAe,EAAE,CAAC;oBAC1B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAC;oBACnE,SAAS,GAAG,IAAI,CAAC;gBACnB,CAAC;qBACI,CAAC;oBACJ,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC;gBACjC,CAAC;YACH,CAAC;iBACI,CAAC;gBACJ,SAAS,GAAG,EAAE,CAAC;YACjB,CAAC;QACH,CAAC;aACI,IAAI,IAAI,CAAC,aAAa,IAAI,iBAAiB,CAAC,MAAM,EAAE,CAAC;YACxD,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACvE,CAAC;iBACI,CAAC;gBACJ,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7D,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,aAAa,IAAI,iBAAiB,CAAC,IAAI,EAAE,CAAC;YACjD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAC1C,CAAC;IAEH,CAAC;IAGD,aAAa,CAAC,KAAoB;QAChC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAC3B,KAAK,CAAC,eAAe,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,aAAa,CAAC,IAAS;QACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU,CAAC,KAAgB;QACzB,IAAI,KAAK,CAAC,IAAI,IAAI,IAAI,IAAI,KAAK,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;YAClD,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;gBAC/B,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,IAAI,KAAK,CAAC,KAAK,IAAI,SAAS,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;oBACnE,IAAI,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBAChC,IAAI,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBAChC,IAAI,MAAM,GAAG,IAAI,CAAC;oBAElB,IAAI,MAAM,IAAI,IAAI,IAAI,MAAM,IAAI,IAAI;wBAClC,MAAM,GAAG,CAAC,CAAC,CAAC;yBACT,IAAI,MAAM,IAAI,IAAI,IAAI,MAAM,IAAI,IAAI;wBACvC,MAAM,GAAG,CAAC,CAAC;yBACR,IAAI,MAAM,IAAI,IAAI,IAAI,MAAM,IAAI,IAAI;wBACvC,MAAM,GAAG,CAAC,CAAC;yBACR,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,OAAO,MAAM,KAAK,QAAQ;wBAC/D,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;;wBAEtC,MAAM,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBAE9D,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC;gBAChC,CAAC;gBACD,OAAO,CAAC,CAAC;YACX,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,CAAC,GAAW;QACjB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC;IAED,kBAAkB,CAAC,GAAe,EAAE,QAAa,EAAE,IAAS;QAC1D,cAAc;QACd,IAAI,GAAG,CAAC,eAAe,KAAK,IAAI,EAAE,CAAC;YAEjC,IAAI,iBAAiB,GAAsB;gBACzC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;gBACnB,KAAK,EAAE,GAAG,CAAC,KAAK;gBAChB,QAAQ,EAAE,QAAQ;aACnB,CAAA;YACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAEzC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChD,CAAC;QAED,+BAA+B;QAC/B,IAAI,GAAG,CAAC,KAAK,KAAK,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3C,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;QAED,4BAA4B;QAC5B,wDAAwD;QACxD,gEAAgE;QAChE,kCAAkC;QAClC,IAAI;IACN,CAAC;IAED,yBAAyB;IACjB,QAAQ;QACd,IAAI,MAAM,GAAQ,EAAE,CAAC;QACrB,oDAAoD;QACpD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,kEAAkE;YAClE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACzB,IAAG,GAAG,CAAC,IAAI,IAAI,UAAU,CAAC,aAAa;uBAClC,GAAG,CAAC,IAAI,IAAI,UAAU,CAAC,UAAU;uBACjC,GAAG,CAAC,IAAI,IAAI,UAAU,CAAC,OAAO;uBAC9B,GAAG,CAAC,IAAI,IAAI,UAAU,CAAC,sBAAsB;uBAC/C,GAAG,CAAC,IAAI,IAAI,UAAU,CAAC,oBAAoB,EAAC,CAAC;oBAC9C,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACxB,CAAC;qBACI,IAAG,GAAG,CAAC,IAAI,IAAI,UAAU,CAAC,QAAQ,EAAC,CAAC;oBACvC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;gBAC5B,CAAC;qBACG,CAAC;oBACH,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;gBAChC,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,IAAI,CAAC,gBAAgB,KAAK,IAAI,EAAE,CAAC;gBACnC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;gBAEzD,+CAA+C;YACjD,CAAC;YACD,OAAO,MAAM,CAAA;QACf,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,0BAA0B;QAChC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,MAAM,EAAE,SAAS,CACjD,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CACvB,CAAC;IACJ,CAAC;IAEO,sCAAsC;QAC5C,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI;eACpB,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAA;QAC5C,CAAC;QAGD,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI;eACnB,IAAI,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;QAChD,CAAC;aACI,CAAC;YACJ,IAAI,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,qBAAqB,KAAK,IAAI,CAAC,CAAC;YAElF,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAChC,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAA;YAC3E,CAAC;iBACI,IAAI,gBAAgB,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gBACtC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;gBAC7B,IAAI,CAAC,mBAAmB,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACvD,CAAC;QACH,CAAC;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI;eACnB,IAAI,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;QAChD,CAAC;aACI,CAAC;YACJ,IAAI,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,qBAAqB,KAAK,IAAI,CAAC,CAAC;YAElF,uDAAuD;YAEvD,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAChC,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAA;YAC3E,CAAC;iBACI,IAAI,gBAAgB,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gBACtC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;gBAC7B,IAAI,CAAC,mBAAmB,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBAErD,4DAA4D;gBAC5D,kEAAkE;YACpE,CAAC;QACH,CAAC;IACH,CAAC;IAEO,wCAAwC;QAC9C,sFAAsF;QACtF,4FAA4F;QAC5F,sEAAsE;QACtE,IAAI,IAAI,CAAC,gBAAgB,KAAK,IAAI;eAC7B,IAAI,CAAC,mBAAmB,IAAI,SAAS;eACrC,IAAI,CAAC,mBAAmB,IAAI,IAAI;eAChC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,kEAAkE;YAClE,0CAA0C;YAE1C,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAEzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAE3F,iEAAiE;QACnE,CAAC;QACD,iEAAiE;IACnE,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;QAClD,2DAA2D;QAC3D,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAEO,YAAY,CAAC,GAAQ;QAC3B,IAAI,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC7D,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACtG,CAAC;IAEO,oBAAoB;QAC1B,IAAI,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mBAAmB,IAAI,IAAI,CAAC,CAAC;QAC/E,IAAI,gBAAgB,EAAE,CAAC;YACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC7D,CAAC;QACD,sDAAsD;IAIxD,CAAC;IAEO,sBAAsB;QAC5B,IAAI,kBAAkB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC;QAC3E,IAAI,kBAAkB,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACjE,CAAC;QACD,wDAAwD;IAC1D,CAAC;IAEO,iBAAiB,CAAC,GAAQ;QAChC,IAAI,aAAa,GAAY,KAAK,CAAC;QACnC,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtD,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,IAAI,iBAAiB,GAAY,IAAI,CAAC;YACtC,IAAI,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE;gBACjC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC;gBAChC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;oBAClC,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;oBACjD,iBAAiB,GAAG,KAAK,CAAC;gBAC5B,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,iBAAiB,EAAE,CAAC;gBACtB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBACxC,aAAa,GAAG,IAAI,CAAC;gBACrB,MAAM;YACR,CAAC;QACH,CAAC;QACD,IAAI,aAAa,EAAE,CAAC;YAClB,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;YAChC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAEO,WAAW,CAAC,IAAS,EAAE,IAAS;QACtC,IAAI,CAAC,kBAAkB,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC;IACL,CAAC;+GApoBU,qBAAqB;mGAArB,qBAAqB,qtDCflC,iwkCAyjBM;;4FD1iBO,qBAAqB;kBALjC,SAAS;+BACE,2BAA2B;iFAqBT,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBAIjB,aAAa;sBAArB,KAAK;gBAMkB,aAAa;sBAApC,KAAK;uBAAC,eAAe;gBACR,GAAG;sBAAhB,KAAK;uBAAC,KAAK;gBACH,KAAK;sBAAb,KAAK;gBACW,SAAS;sBAAzB,KAAK;uBAAC,QAAQ;gBACN,aAAa;sBAArB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAYO,OAAO;sBAAnB,KAAK;gBAOO,QAAQ;sBAApB,KAAK;gBAMG,cAAc;sBAAtB,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAMO,yBAAyB;sBAArC,KAAK;gBAkBG,WAAW;sBAAnB,KAAK;gBAEG,wBAAwB;sBAAhC,KAAK;gBAKI,SAAS;sBAAlB,MAAM;gBAMG,mBAAmB;sBAA5B,MAAM;gBAIG,oBAAoB;sBAA7B,MAAM;gBAEG,sBAAsB;sBAA/B,MAAM;gBAEG,uBAAuB;sBAAhC,MAAM;gBAEG,oBAAoB;sBAA7B,MAAM;gBAEG,oBAAoB;sBAA7B,MAAM;gBAEG,WAAW;sBAApB,MAAM;gBAEG,sBAAsB;sBAA/B,MAAM;gBAEG,mBAAmB;sBAA5B,MAAM;gBAEG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBAGoC,EAAE;sBAA5C,SAAS;uBAAC,IAAI,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAEzB,EAAE;sBAAV,KAAK","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 { GridSelectionMode, InputTypes, ModalSizeEnum, ButtonType, TooltipPosition} from '../../../enums';\r\nimport { CellChangedResult, GridColumn, IGridConfiguration, RowAddedResult } from '../../../interfaces';\r\nimport { rtlModeKeys } from '../../../consts/locals.const';\r\nimport { LocalizePipe } from '../../../pipes/localize.pipe';\r\nimport { EntityValidationsService } from '../../../services/validation/entity-validations.service';\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})\r\nexport class EditableGridComponent implements OnInit, OnDestroy {\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\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  @Input() disabled: 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._entityValidationsService.getEntityValidations(this.editableGridBusinessClass).subscribe({\r\n      next: (entityValidations) => {\r\n        entityValidations.forEach(el => {\r\n          let col = this.columns.find(c => c.labelField?.toLocaleLowerCase() === el.columnName.toLocaleLowerCase() || \r\n                                      c.field?.toLocaleLowerCase() === el.columnName.toLocaleLowerCase());\r\n          if(col){\r\n            col.validationStatusCssClass = el.isNullable !== true ? 'border-red-500 border-3' : '';\r\n          }\r\n        })\r\n      }\r\n    })\r\n  }\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\r\n  constructor(private _localizePipe: LocalizePipe) {\r\n   }\r\n\r\n  ngOnInit() {\r\n    this._initSaveEventSubscription();\r\n    this._verifyGridRequirements();\r\n    this._initCurrentRowNumberAndOrderByRowNumber();\r\n    this._initEquatableFields();\r\n    this._initSumAtFusionFields();\r\n    let langue = localStorage.getItem(rtlModeKeys.rtlModeEnabled);\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    if (!this.selectedColumns || this.selectedColumns.length == 0) {\r\n      this.selectedColumns = this.columns\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  ngOnDestroy(): void {\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    let rowAddedResult: RowAddedResult = {\r\n      rowNumber: this.gridData.length - 1,\r\n      data: newRow\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._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\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    let selection: any[] = [];\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    if (this.selectionMode != GridSelectionMode.None) {\r\n      this.selectedItemsChange.emit(selection)\r\n    }\r\n\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  //#region private methods\r\n  private _initRow() {\r\n    let newRow: any = {};\r\n    //console.log('start _initRow', this.configuration);\r\n    if (this.columns) {\r\n      //console.log('_initRow :: configuration : ', this.configuration);\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        //console.log('_initRow :: newRow : ', newRow);\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\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\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\" [paginator]=\"gridData.length > pageSize\"\r\n    [rowsPerPageOptions]=\"rowPerPage\" [rows]=\"pageSize\" (onRowSelect)=\"onRowSelected($event)\"\r\n    (onRowUnselect)=\"onRowUnselect($event)\" [scrollable]=\"true\" [resizableColumns]=\"true\" columnResizeMode=\"expand\"\r\n    appendTo=\"body\" styleClass=\"p-datatable-sm\" [value]=\"gridData\" [columns]=\"selectedColumns\" [dataKey]=\"key\"\r\n    [scrollHeight]=\"scrollHeight\" styleClass=\"p-datatable-gridlines\" (selectionChange)=\"selectionChange($event)\"\r\n    #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        <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        <th pResizableColumn pFrozenColumn *ngIf=\"showHaveSumary\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th>\r\n        <!-- <th pResizableColumn pFrozenColumn *ngIf=\"showEditButton\" scope=\"col\"\r\n          style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\"></th> -->\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        <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      <tr [pEditableRow]=\"item\"\r\n        *ngIf=\"selectionMode == multipleGridSelectionMode || selectionMode == undefined; else selectionModeBlock\"\r\n        (focusOut)=\"onFocusOutRow(item)\">\r\n        <td>\r\n          <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\r\n        </td>\r\n         <td pFrozenColumn style=\"min-width:3rem; left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n        </td>\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        <td pFrozenColumn *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 [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        <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 class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\"\r\n          [ngStyle]=\"isAr ? {'text-align': 'start'} : {}\">\r\n\r\n          <ng-template #ordinaryBloc>\r\n\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\"\r\n                [inputId]=\"col.field\" [(inputField)]=\"item[col.field]\"\r\n                  (inputFieldChange)=\"onCellValueChanged(col, $event, item)\" [numOfDecimal]=\"col.numOfDecimal\"\r\n                  [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]\"\r\n                  (keydown)=\"handleKeydown($event)\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                  [disabled]=\"col.disabled\" [inputName]=\"col.inputName\" [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-template #selectionModeBlock>\r\n        <ng-container>\r\n          <tr [pEditableRow]=\"item\" [pSelectableRow]=\"item\" [pSelectableRowIndex]=\"rowIndex\"\r\n            (focusOut)=\"onFocusOutRow(item)\">\r\n            <td pFrozenColumn style=\"left: 1rem !important; width:3rem !important;\" class=\"p-1\">\r\n            <td *ngIf=\"selectionMode == multipleGridSelectionMode\" style=\"width: 2rem;\">\r\n              <p-tableHeaderCheckbox #tableHeaderCheckbox></p-tableHeaderCheckbox>\r\n            </td>\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;\">\r\n            </td>\r\n            <td pFrozenColumn *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            <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            <td class=\"ui-resizable-column\" pFrozenColumn [frozen]=\"col.isFrozen\" *ngFor=\"let col of columns\">\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              <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\" [inputId]=\"col.field\"\r\n                      (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\" (inputFieldChange)=\"inputChanged(col)\"\r\n                      [(inputField)]=\"item[col.field]\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [disabled]=\"col.disabled\" [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\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      [numOfDecimal]=\"col.numOfDecimal\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [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\" (inputFieldChange)=\"inputChanged(col)\"\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 -->\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-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\"\r\n                      (inputFieldChange)=\"inputChanged(col)\" [(inputField)]=\"item[col.field]\"\r\n                      (keydown)=\"handleKeydown($event)\" (inputFieldChange)=\"onCellValueChanged(col, $event, item)\"\r\n                      [inputName]=\"col.inputName\" [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    </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;\"\r\n          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>"]}
@@ -5,6 +5,7 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "../../../services/date-helper.service";
6
6
  import * as i2 from "@angular/forms";
7
7
  import * as i3 from "primeng/calendar";
8
+ import * as i4 from "../../tsi-bubble-info/tsi-bubble-info.component";
8
9
  export class TsiTimePickerComponent extends TsiInputBase {
9
10
  //#endregion
10
11
  //#region inputs
@@ -39,12 +40,10 @@ export class TsiTimePickerComponent extends TsiInputBase {
39
40
  //#endregion
40
41
  //#region handle events
41
42
  onFocusOut(event) {
42
- this._updateInputFieldFromStringDate();
43
- this.inputFieldChange.emit(this.inputField);
43
+ this._handleDateChange();
44
44
  }
45
45
  onSelect(event) {
46
- this._updateInputFieldFromStringDate();
47
- this.inputFieldChange.emit(this.inputField);
46
+ this._handleDateChange();
48
47
  }
49
48
  //#endregion
50
49
  //#region private methods
@@ -53,13 +52,17 @@ export class TsiTimePickerComponent extends TsiInputBase {
53
52
  ? this._dateHelperService.parseTimeString(this.timeOnlyString) : undefined;
54
53
  this._value = timeOnly;
55
54
  }
55
+ _handleDateChange() {
56
+ this._updateInputFieldFromStringDate();
57
+ this.inputFieldChange.emit(this.inputField);
58
+ }
56
59
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiTimePickerComponent, deps: [{ token: i1.DateHelperService }], target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiTimePickerComponent, selector: "tsi-time-picker", outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex\">\r\n <p-calendar [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n styleClass=\"{{myStyleClass}}\"\r\n inputStyleClass=\"{{myStyleClass}}\"\r\n [showTime]=\"true\"\r\n [showSeconds]=\"true\"\r\n [timeOnly]=\"true\"\r\n [(ngModel)]=\"timeOnlyString\"\r\n (onBlur)=\"onFocusOut($event)\"\r\n (onSelect)=\"onSelect($event)\">\r\n </p-calendar>\r\n <!-- <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info> -->\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }] }); }
60
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TsiTimePickerComponent, selector: "tsi-time-picker", outputs: { inputFieldChange: "inputFieldChange" }, usesInheritance: true, ngImport: i0, template: "<div class=\"flex\">\r\n <p-calendar [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n styleClass=\"{{myStyleClass}}\"\r\n inputStyleClass=\"{{myStyleClass}}\"\r\n [showTime]=\"true\"\r\n [showSeconds]=\"true\"\r\n [timeOnly]=\"true\"\r\n [(ngModel)]=\"timeOnlyString\"\r\n (onBlur)=\"onFocusOut($event)\"\r\n (onSelect)=\"onSelect($event)\">\r\n </p-calendar>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i4.TsiBubbleInfoComponent, selector: "Tsi-Bubble-Info", inputs: ["infoText"] }] }); }
58
61
  }
59
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TsiTimePickerComponent, decorators: [{
60
63
  type: Component,
61
- args: [{ selector: 'tsi-time-picker', template: "<div class=\"flex\">\r\n <p-calendar [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n styleClass=\"{{myStyleClass}}\"\r\n inputStyleClass=\"{{myStyleClass}}\"\r\n [showTime]=\"true\"\r\n [showSeconds]=\"true\"\r\n [timeOnly]=\"true\"\r\n [(ngModel)]=\"timeOnlyString\"\r\n (onBlur)=\"onFocusOut($event)\"\r\n (onSelect)=\"onSelect($event)\">\r\n </p-calendar>\r\n <!-- <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info> -->\r\n</div>" }]
64
+ args: [{ selector: 'tsi-time-picker', template: "<div class=\"flex\">\r\n <p-calendar [dataType]=\"'string'\"\r\n [appendTo]=\"'body'\"\r\n [disabled]=\"disabled\"\r\n [showIcon]=\"true\"\r\n [dateFormat]=\"datePickerFormat\"\r\n class=\"{{myStyleClass}} {{validationStatusCssClass}}\"\r\n styleClass=\"{{myStyleClass}}\"\r\n inputStyleClass=\"{{myStyleClass}}\"\r\n [showTime]=\"true\"\r\n [showSeconds]=\"true\"\r\n [timeOnly]=\"true\"\r\n [(ngModel)]=\"timeOnlyString\"\r\n (onBlur)=\"onFocusOut($event)\"\r\n (onSelect)=\"onSelect($event)\">\r\n </p-calendar>\r\n <Tsi-Bubble-Info [infoText]=\"infoText\"></Tsi-Bubble-Info>\r\n</div>" }]
62
65
  }], ctorParameters: () => [{ type: i1.DateHelperService }], propDecorators: { inputFieldChange: [{
63
66
  type: Output
64
67
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNpLXRpbWUtcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RzaS1zaGFyZWQtdWkvc3JjL2xpYi90c2ktY29tcG9uZW50cy9pbnB1dC1jb21wb25lbnRzL3RzaS10aW1lLXBpY2tlci90c2ktdGltZS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLXRpbWUtcGlja2VyL3RzaS10aW1lLXBpY2tlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBaUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyREFBMkQsQ0FBQztBQUV6RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7QUFRbEUsTUFBTSxPQUFPLHNCQUF1QixTQUFRLFlBQWtEO0lBTTVGLFlBQVk7SUFFWixnQkFBZ0I7SUFHaEIsNkVBQTZFO0lBQzdFLDZCQUE2QjtJQUM3QixJQUFJO0lBRUosSUFBYSxVQUFVLENBQUMsS0FBMkM7UUFDakUsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBRyxLQUFLLFlBQVcsQ0FBQyxJQUFJLENBQUMsRUFBQyxDQUFDO1lBQ3pCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQzFFLENBQUM7YUFDSSxDQUFDO1lBQ0osSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLEVBQUUsUUFBUSxFQUFFLENBQUM7UUFDMUMsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFhLFVBQVU7UUFDckIsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFLRCxZQUFZO0lBRVosY0FBYztJQUNkOztPQUVHO0lBQ0gsWUFBb0Isa0JBQXNDO1FBQ3hELEtBQUssRUFBRSxDQUFDO1FBRFUsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFvQjtRQWpDMUQscUJBQWdCLEdBQVcsb0JBQW9CLENBQUM7UUF1QmhELFlBQVk7UUFFWixpQkFBaUI7UUFDUCxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBd0MsQ0FBQztJQVV0RixDQUFDO0lBRUQsWUFBWTtJQUVaLHVCQUF1QjtJQUN2QixVQUFVLENBQUMsS0FBVTtRQUNuQixJQUFJLENBQUMsK0JBQStCLEVBQUUsQ0FBQztRQUN2QyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRUQsUUFBUSxDQUFDLEtBQVU7UUFDakIsSUFBSSxDQUFDLCtCQUErQixFQUFFLENBQUM7UUFDdkMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELFlBQVk7SUFFWix5QkFBeUI7SUFDekIsK0JBQStCO1FBQzdCLElBQUksUUFBUSxHQUF5QixJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxjQUFjLElBQUksRUFBRTtZQUNuRixDQUFDLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUM3RSxJQUFJLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQztJQUN6QixDQUFDOytHQS9EVSxzQkFBc0I7bUdBQXRCLHNCQUFzQixpSUNabkMsdW9CQWlCTTs7NEZETE8sc0JBQXNCO2tCQUxsQyxTQUFTOytCQUNFLGlCQUFpQjtzRkFtQ2pCLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERhdGVQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUc2lJbnB1dEJhc2UgfSBmcm9tICcuLi8uLi8uLi90c2ktYmFzZS90c2ktaW5wdXQtYmFzZS90c2ktaW5wdXQtYmFzZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBUaW1lT25seSB9IGZyb20gJy4uLy4uLy4uL3R5cGVzL3RpbWUtb25seSc7XHJcbmltcG9ydCB7IERhdGVQaWNrZXJEYXRlRm9ybWF0IH0gZnJvbSAnLi4vLi4vLi4vY29uc3RzL3RzaS1jb25zdHMnO1xyXG5pbXBvcnQgeyBEYXRlSGVscGVyU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2RhdGUtaGVscGVyLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0c2ktdGltZS1waWNrZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi90c2ktdGltZS1waWNrZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RzaS10aW1lLXBpY2tlci5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUc2lUaW1lUGlja2VyQ29tcG9uZW50IGV4dGVuZHMgVHNpSW5wdXRCYXNlPFRpbWVPbmx5IHwgRGF0ZSB8IHN0cmluZyB8IHVuZGVmaW5lZD57XHJcbiAgLy8jcmVnaW9uIGxvY2FsIHByb3BlcnRpZXNcclxuICBwcml2YXRlIF92YWx1ZTogVGltZU9ubHkgfCBEYXRlIHwgc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG5cclxuICB0aW1lT25seVN0cmluZzogc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG4gIGRhdGVQaWNrZXJGb3JtYXQ6IHN0cmluZyA9IERhdGVQaWNrZXJEYXRlRm9ybWF0O1xyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvLyNyZWdpb24gaW5wdXRzXHJcblxyXG5cclxuICAvLyBASW5wdXQoKSBvdmVycmlkZSBnZXQgaW5wdXRGaWVsZCgpOiBUaW1lT25seSB8IERhdGUgfCBzdHJpbmcgfCB1bmRlZmluZWQge1xyXG4gIC8vICAgcmV0dXJuIHRoaXMuX2lucHV0RmllbGQ7XHJcbiAgLy8gfVxyXG5cclxuICBvdmVycmlkZSBzZXQgaW5wdXRGaWVsZCh2YWx1ZTogVGltZU9ubHkgfCBEYXRlIHwgc3RyaW5nIHwgdW5kZWZpbmVkKSB7XHJcbiAgICB0aGlzLl92YWx1ZSA9IHZhbHVlO1xyXG4gICAgaWYodmFsdWUgaW5zdGFuY2VvZihEYXRlKSl7XHJcbiAgICAgIHRoaXMudGltZU9ubHlTdHJpbmcgPSB0aGlzLl9kYXRlSGVscGVyU2VydmljZS5leHRyYWN0VGltZUZyb21EYXRlKHZhbHVlKVxyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgIHRoaXMudGltZU9ubHlTdHJpbmcgPSB2YWx1ZT8udG9TdHJpbmcoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG92ZXJyaWRlIGdldCBpbnB1dEZpZWxkKCkge1xyXG4gICAgcmV0dXJuIHRoaXMuX3ZhbHVlO1xyXG4gIH1cclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIG91dHB1dHNcclxuICBAT3V0cHV0KCkgaW5wdXRGaWVsZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8VGltZU9ubHkgfCBEYXRlIHwgdW5kZWZpbmVkIHwgc3RyaW5nPigpO1xyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvLyNyZWdpb24gY3RvclxyXG4gIC8qKlxyXG4gICAqXHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfZGF0ZUhlbHBlclNlcnZpY2UgOiBEYXRlSGVscGVyU2VydmljZSkge1xyXG4gICAgc3VwZXIoKTtcclxuXHJcbiAgfVxyXG5cclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIGhhbmRsZSBldmVudHNcclxuICBvbkZvY3VzT3V0KGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMuX3VwZGF0ZUlucHV0RmllbGRGcm9tU3RyaW5nRGF0ZSgpO1xyXG4gICAgdGhpcy5pbnB1dEZpZWxkQ2hhbmdlLmVtaXQodGhpcy5pbnB1dEZpZWxkKTtcclxuICB9XHJcblxyXG4gIG9uU2VsZWN0KGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMuX3VwZGF0ZUlucHV0RmllbGRGcm9tU3RyaW5nRGF0ZSgpO1xyXG4gICAgdGhpcy5pbnB1dEZpZWxkQ2hhbmdlLmVtaXQodGhpcy5pbnB1dEZpZWxkKTtcclxuICB9XHJcblxyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvLyNyZWdpb24gcHJpdmF0ZSBtZXRob2RzXHJcbiAgX3VwZGF0ZUlucHV0RmllbGRGcm9tU3RyaW5nRGF0ZSgpOiB2b2lkIHtcclxuICAgIGxldCB0aW1lT25seTogVGltZU9ubHkgfCB1bmRlZmluZWQgPSB0aGlzLnRpbWVPbmx5U3RyaW5nICYmIHRoaXMudGltZU9ubHlTdHJpbmcgIT0gJydcclxuICAgICAgPyB0aGlzLl9kYXRlSGVscGVyU2VydmljZS5wYXJzZVRpbWVTdHJpbmcodGhpcy50aW1lT25seVN0cmluZykgOiB1bmRlZmluZWQ7XHJcbiAgICB0aGlzLl92YWx1ZSA9IHRpbWVPbmx5O1xyXG4gIH1cclxuICAvLyNlbmRyZWdpb25cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiZmxleFwiPlxyXG4gICAgPHAtY2FsZW5kYXIgW2RhdGFUeXBlXT1cIidzdHJpbmcnXCJcclxuICAgIFthcHBlbmRUb109XCInYm9keSdcIlxyXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgIFtzaG93SWNvbl09XCJ0cnVlXCJcclxuICAgIFtkYXRlRm9ybWF0XT1cImRhdGVQaWNrZXJGb3JtYXRcIlxyXG4gICAgY2xhc3M9XCJ7e215U3R5bGVDbGFzc319IHt7dmFsaWRhdGlvblN0YXR1c0Nzc0NsYXNzfX1cIlxyXG4gICAgc3R5bGVDbGFzcz1cInt7bXlTdHlsZUNsYXNzfX1cIlxyXG4gICAgaW5wdXRTdHlsZUNsYXNzPVwie3tteVN0eWxlQ2xhc3N9fVwiXHJcbiAgICBbc2hvd1RpbWVdPVwidHJ1ZVwiXHJcbiAgICBbc2hvd1NlY29uZHNdPVwidHJ1ZVwiXHJcbiAgICBbdGltZU9ubHldPVwidHJ1ZVwiXHJcbiAgICBbKG5nTW9kZWwpXT1cInRpbWVPbmx5U3RyaW5nXCJcclxuICAgIChvbkJsdXIpPVwib25Gb2N1c091dCgkZXZlbnQpXCJcclxuICAgIChvblNlbGVjdCk9XCJvblNlbGVjdCgkZXZlbnQpXCI+XHJcbiAgICA8L3AtY2FsZW5kYXI+XHJcbiAgICA8IS0tIDxUc2ktQnViYmxlLUluZm8gW2luZm9UZXh0XT1cImluZm9UZXh0XCI+PC9Uc2ktQnViYmxlLUluZm8+IC0tPlxyXG48L2Rpdj4iXX0=
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHNpLXRpbWUtcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RzaS1zaGFyZWQtdWkvc3JjL2xpYi90c2ktY29tcG9uZW50cy9pbnB1dC1jb21wb25lbnRzL3RzaS10aW1lLXBpY2tlci90c2ktdGltZS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHNpLXNoYXJlZC11aS9zcmMvbGliL3RzaS1jb21wb25lbnRzL2lucHV0LWNvbXBvbmVudHMvdHNpLXRpbWUtcGlja2VyL3RzaS10aW1lLXBpY2tlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBaUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyREFBMkQsQ0FBQztBQUV6RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7O0FBUWxFLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxZQUFrRDtJQU01RixZQUFZO0lBRVosZ0JBQWdCO0lBR2hCLDZFQUE2RTtJQUM3RSw2QkFBNkI7SUFDN0IsSUFBSTtJQUVKLElBQWEsVUFBVSxDQUFDLEtBQTJDO1FBQ2pFLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksS0FBSyxZQUFZLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUM1QixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUMxRSxDQUFDO2FBQ0ksQ0FBQztZQUNKLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxFQUFFLFFBQVEsRUFBRSxDQUFDO1FBQzFDLENBQUM7SUFDSCxDQUFDO0lBRUQsSUFBYSxVQUFVO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBS0QsWUFBWTtJQUVaLGNBQWM7SUFDZDs7T0FFRztJQUNILFlBQW9CLGtCQUFxQztRQUN2RCxLQUFLLEVBQUUsQ0FBQztRQURVLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBbUI7UUFqQ3pELHFCQUFnQixHQUFXLG9CQUFvQixDQUFDO1FBdUJoRCxZQUFZO1FBRVosaUJBQWlCO1FBQ1AscUJBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQXdDLENBQUM7SUFVdEYsQ0FBQztJQUVELFlBQVk7SUFFWix1QkFBdUI7SUFDdkIsVUFBVSxDQUFDLEtBQVU7UUFDbkIsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFFBQVEsQ0FBQyxLQUFVO1FBQ2pCLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxZQUFZO0lBRVoseUJBQXlCO0lBQ3pCLCtCQUErQjtRQUM3QixJQUFJLFFBQVEsR0FBeUIsSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsY0FBYyxJQUFJLEVBQUU7WUFDbkYsQ0FBQyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7UUFDN0UsSUFBSSxDQUFDLE1BQU0sR0FBRyxRQUFRLENBQUM7SUFDekIsQ0FBQztJQUVPLGlCQUFpQjtRQUN2QixJQUFJLENBQUMsK0JBQStCLEVBQUUsQ0FBQztRQUN2QyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QyxDQUFDOytHQWxFVSxzQkFBc0I7bUdBQXRCLHNCQUFzQixpSUNabkMsOG5CQWlCTTs7NEZETE8sc0JBQXNCO2tCQUxsQyxTQUFTOytCQUNFLGlCQUFpQjtzRkFtQ2pCLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERhdGVQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUc2lJbnB1dEJhc2UgfSBmcm9tICcuLi8uLi8uLi90c2ktYmFzZS90c2ktaW5wdXQtYmFzZS90c2ktaW5wdXQtYmFzZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBUaW1lT25seSB9IGZyb20gJy4uLy4uLy4uL3R5cGVzL3RpbWUtb25seSc7XHJcbmltcG9ydCB7IERhdGVQaWNrZXJEYXRlRm9ybWF0IH0gZnJvbSAnLi4vLi4vLi4vY29uc3RzL3RzaS1jb25zdHMnO1xyXG5pbXBvcnQgeyBEYXRlSGVscGVyU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2RhdGUtaGVscGVyLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0c2ktdGltZS1waWNrZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi90c2ktdGltZS1waWNrZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RzaS10aW1lLXBpY2tlci5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUc2lUaW1lUGlja2VyQ29tcG9uZW50IGV4dGVuZHMgVHNpSW5wdXRCYXNlPFRpbWVPbmx5IHwgRGF0ZSB8IHN0cmluZyB8IHVuZGVmaW5lZD4ge1xyXG4gIC8vI3JlZ2lvbiBsb2NhbCBwcm9wZXJ0aWVzXHJcbiAgcHJpdmF0ZSBfdmFsdWU6IFRpbWVPbmx5IHwgRGF0ZSB8IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuXHJcbiAgdGltZU9ubHlTdHJpbmc6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICBkYXRlUGlja2VyRm9ybWF0OiBzdHJpbmcgPSBEYXRlUGlja2VyRGF0ZUZvcm1hdDtcclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIGlucHV0c1xyXG5cclxuXHJcbiAgLy8gQElucHV0KCkgb3ZlcnJpZGUgZ2V0IGlucHV0RmllbGQoKTogVGltZU9ubHkgfCBEYXRlIHwgc3RyaW5nIHwgdW5kZWZpbmVkIHtcclxuICAvLyAgIHJldHVybiB0aGlzLl9pbnB1dEZpZWxkO1xyXG4gIC8vIH1cclxuXHJcbiAgb3ZlcnJpZGUgc2V0IGlucHV0RmllbGQodmFsdWU6IFRpbWVPbmx5IHwgRGF0ZSB8IHN0cmluZyB8IHVuZGVmaW5lZCkge1xyXG4gICAgdGhpcy5fdmFsdWUgPSB2YWx1ZTtcclxuICAgIGlmICh2YWx1ZSBpbnN0YW5jZW9mIChEYXRlKSkge1xyXG4gICAgICB0aGlzLnRpbWVPbmx5U3RyaW5nID0gdGhpcy5fZGF0ZUhlbHBlclNlcnZpY2UuZXh0cmFjdFRpbWVGcm9tRGF0ZSh2YWx1ZSlcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICB0aGlzLnRpbWVPbmx5U3RyaW5nID0gdmFsdWU/LnRvU3RyaW5nKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvdmVycmlkZSBnZXQgaW5wdXRGaWVsZCgpIHtcclxuICAgIHJldHVybiB0aGlzLl92YWx1ZTtcclxuICB9XHJcbiAgLy8jZW5kcmVnaW9uXHJcblxyXG4gIC8vI3JlZ2lvbiBvdXRwdXRzXHJcbiAgQE91dHB1dCgpIGlucHV0RmllbGRDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPFRpbWVPbmx5IHwgRGF0ZSB8IHVuZGVmaW5lZCB8IHN0cmluZz4oKTtcclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIGN0b3JcclxuICAvKipcclxuICAgKlxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgX2RhdGVIZWxwZXJTZXJ2aWNlOiBEYXRlSGVscGVyU2VydmljZSkge1xyXG4gICAgc3VwZXIoKTtcclxuXHJcbiAgfVxyXG5cclxuICAvLyNlbmRyZWdpb25cclxuXHJcbiAgLy8jcmVnaW9uIGhhbmRsZSBldmVudHNcclxuICBvbkZvY3VzT3V0KGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMuX2hhbmRsZURhdGVDaGFuZ2UoKTtcclxuICB9XHJcblxyXG4gIG9uU2VsZWN0KGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMuX2hhbmRsZURhdGVDaGFuZ2UoKTtcclxuICB9XHJcblxyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvLyNyZWdpb24gcHJpdmF0ZSBtZXRob2RzXHJcbiAgX3VwZGF0ZUlucHV0RmllbGRGcm9tU3RyaW5nRGF0ZSgpOiB2b2lkIHtcclxuICAgIGxldCB0aW1lT25seTogVGltZU9ubHkgfCB1bmRlZmluZWQgPSB0aGlzLnRpbWVPbmx5U3RyaW5nICYmIHRoaXMudGltZU9ubHlTdHJpbmcgIT0gJydcclxuICAgICAgPyB0aGlzLl9kYXRlSGVscGVyU2VydmljZS5wYXJzZVRpbWVTdHJpbmcodGhpcy50aW1lT25seVN0cmluZykgOiB1bmRlZmluZWQ7XHJcbiAgICB0aGlzLl92YWx1ZSA9IHRpbWVPbmx5O1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfaGFuZGxlRGF0ZUNoYW5nZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuX3VwZGF0ZUlucHV0RmllbGRGcm9tU3RyaW5nRGF0ZSgpO1xyXG4gICAgdGhpcy5pbnB1dEZpZWxkQ2hhbmdlLmVtaXQodGhpcy5pbnB1dEZpZWxkKTtcclxuICB9XHJcbiAgLy8jZW5kcmVnaW9uXHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImZsZXhcIj5cclxuICAgIDxwLWNhbGVuZGFyIFtkYXRhVHlwZV09XCInc3RyaW5nJ1wiXHJcbiAgICBbYXBwZW5kVG9dPVwiJ2JvZHknXCJcclxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXHJcbiAgICBbc2hvd0ljb25dPVwidHJ1ZVwiXHJcbiAgICBbZGF0ZUZvcm1hdF09XCJkYXRlUGlja2VyRm9ybWF0XCJcclxuICAgIGNsYXNzPVwie3tteVN0eWxlQ2xhc3N9fSB7e3ZhbGlkYXRpb25TdGF0dXNDc3NDbGFzc319XCJcclxuICAgIHN0eWxlQ2xhc3M9XCJ7e215U3R5bGVDbGFzc319XCJcclxuICAgIGlucHV0U3R5bGVDbGFzcz1cInt7bXlTdHlsZUNsYXNzfX1cIlxyXG4gICAgW3Nob3dUaW1lXT1cInRydWVcIlxyXG4gICAgW3Nob3dTZWNvbmRzXT1cInRydWVcIlxyXG4gICAgW3RpbWVPbmx5XT1cInRydWVcIlxyXG4gICAgWyhuZ01vZGVsKV09XCJ0aW1lT25seVN0cmluZ1wiXHJcbiAgICAob25CbHVyKT1cIm9uRm9jdXNPdXQoJGV2ZW50KVwiXHJcbiAgICAob25TZWxlY3QpPVwib25TZWxlY3QoJGV2ZW50KVwiPlxyXG4gICAgPC9wLWNhbGVuZGFyPlxyXG4gICAgPFRzaS1CdWJibGUtSW5mbyBbaW5mb1RleHRdPVwiaW5mb1RleHRcIj48L1RzaS1CdWJibGUtSW5mbz5cclxuPC9kaXY+Il19