nira-falcon 0.1.70 → 0.1.72

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.
@@ -82,9 +82,9 @@ export class CoreTableComponent {
82
82
  });
83
83
  }
84
84
  handleEnter(event) {
85
- const ke = event;
85
+ const key = event;
86
86
  if (document.activeElement === this.table.nativeElement) {
87
- if (ke.key === 'ArrowDown') {
87
+ if (key.key === 'ArrowDown') {
88
88
  if (this.selectedItemIndex === this.sortedTableData.length - 1)
89
89
  return;
90
90
  if (this.selectedItemIndex < this.sortedTableData.length - 1) {
@@ -97,7 +97,7 @@ export class CoreTableComponent {
97
97
  event.preventDefault();
98
98
  return;
99
99
  }
100
- else if (ke.key === 'ArrowUp') {
100
+ else if (key.key === 'ArrowUp') {
101
101
  if (this.selectedItemIndex === 0)
102
102
  return;
103
103
  if (this.selectedItemIndex > 0) {
@@ -110,9 +110,24 @@ export class CoreTableComponent {
110
110
  event.preventDefault();
111
111
  return;
112
112
  }
113
- else if (ke.key === 'Enter') {
114
- if (this.selectedItemIndex === 0)
115
- return;
113
+ else if (key.key === 'Enter') {
114
+ this.onItemSelected.emit(this.selectedItem);
115
+ event.preventDefault();
116
+ return;
117
+ }
118
+ else if (key.altKey) {
119
+ const actionButtons = this.columnsSchema.find((schema) => schema.type === COLUMNS_TYPES.ACTION_BUTTONS);
120
+ actionButtons.data.forEach((actionButton) => {
121
+ if (actionButton.keyboardShortcut) {
122
+ const regex = new RegExp('^(' + actionButton.keyboardShortcut + ')$', 'i');
123
+ if (regex.test(key.key)) {
124
+ this.columnClicked({
125
+ data: this.selectedItem,
126
+ key: actionButton.key,
127
+ });
128
+ }
129
+ }
130
+ });
116
131
  this.onItemSelected.emit(this.selectedItem);
117
132
  event.preventDefault();
118
133
  return;
@@ -266,4 +281,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
266
281
  type: HostListener,
267
282
  args: ['document:keydown', ['$event']]
268
283
  }] } });
269
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../projects/falcon-lib/src/lib/core-table/core-table/core-table.component.ts","../../../../../../projects/falcon-lib/src/lib/core-table/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\nimport { NgxIndexedDBService } from 'ngx-indexed-db';\r\nimport { find, orderBy } from 'lodash';\r\nimport { ACTIVE_OPTIONS, YES_NO_OPTIONS } from '../../../utils/constants';\r\nimport { Util } from '../../../utils/util';\r\nimport { ColumnsSchema } from './core-table.type';\r\nimport { COLUMNS_TYPES } from '../../falconTypes';\r\n\r\n@Component({\r\n  selector: 'core-table',\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n})\r\nexport class CoreTableComponent {\r\n  @Input({ required: false }) key: string | undefined;\r\n  @Input({ required: true }) columnsSchema: ColumnsSchema[] = [];\r\n  @Input({ required: true }) tableData: BehaviorSubject<any[]> =\r\n    new BehaviorSubject<any[]>([]);\r\n  @Input({ required: false }) responsive: boolean = true;\r\n  @Input({ required: false }) canSelectFirstItem: boolean = false;\r\n  @Input({ required: true }) loading: any;\r\n  @Input() canFilter: boolean = false;\r\n  @Input({ required: false }) styleFilter: ((data: any) => string) | undefined;\r\n  @Input({ required: false }) rowSelector: BehaviorSubject<any> | undefined =\r\n    undefined;\r\n  @Output() onColumnClicked: EventEmitter<any> = new EventEmitter();\r\n  @Output() onColumnValueChanged: EventEmitter<any> = new EventEmitter();\r\n  @Output() onItemSelected: EventEmitter<any> = new EventEmitter();\r\n  @ViewChild('table') table!: ElementRef<HTMLTableElement>;\r\n  ACTIVE_OPTIONS = ACTIVE_OPTIONS;\r\n  YES_NO_OPTIONS = YES_NO_OPTIONS;\r\n  sortDetail: { key: string; sort: 'asc' | 'desc' } | undefined;\r\n  selectedItem: any = undefined;\r\n  sortedTableData: any[] = [];\r\n  dbTableFilter: any;\r\n  index = 0;\r\n  salt = this.randomString(5);\r\n  selectedItemIndex = 0;\r\n  get columnsTypes() {\r\n    return COLUMNS_TYPES;\r\n  }\r\n  get isRunningOnSmallScreen() {\r\n    return Util.isRunningOnSmallScreen();\r\n  }\r\n  constructor(private dbService: NgxIndexedDBService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.tableData.subscribe((val: any) => {\r\n      this.sortedTableData = val;\r\n      if (\r\n        this.canSelectFirstItem &&\r\n        this.sortedTableData.length > 0 &&\r\n        this.selectedItem === undefined\r\n      ) {\r\n        this.selectedItem = this.sortedTableData[0];\r\n        this.selectedItemIndex = 0;\r\n        this.table.nativeElement.focus();\r\n      }\r\n    });\r\n    if (this.key) {\r\n      this.dbService\r\n        .getByIndex('tableFilter', 'key', this.key)\r\n        .subscribe((data: any) => {\r\n          this.dbTableFilter = data;\r\n          if (this.dbTableFilter) {\r\n            this.setTableFilter();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.table.nativeElement.focus();\r\n    if (this.canSelectFirstItem && this.sortedTableData.length > 0) {\r\n      this.selectedItem = this.sortedTableData[0];\r\n    }\r\n  }\r\n\r\n  setTableFilter() {\r\n    this.columnsSchema.map((column: any) => {\r\n      JSON.parse(this.dbTableFilter.columnsSchema).forEach(\r\n        (dbColumnsSchema: any) => {\r\n          if (dbColumnsSchema.key === column.key) {\r\n            column.active = dbColumnsSchema.active;\r\n          }\r\n        }\r\n      );\r\n      return column;\r\n    });\r\n  }\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleEnter(event: Event) {\r\n    const ke = event as KeyboardEvent;\r\n    if (document.activeElement === this.table.nativeElement) {\r\n      if (ke.key === 'ArrowDown') {\r\n        if (this.selectedItemIndex === this.sortedTableData.length - 1) return;\r\n        if (this.selectedItemIndex < this.sortedTableData.length - 1) {\r\n          this.selectedItemIndex++;\r\n          this.selectedItem = this.sortedTableData[this.selectedItemIndex];\r\n          document\r\n            .getElementById(\r\n              'tableRow_' + this.salt + '_' + this.selectedItemIndex\r\n            )\r\n            ?.scrollIntoView({ behavior: 'smooth', block: 'center' });\r\n        }\r\n        event.preventDefault();\r\n        return;\r\n      } else if (ke.key === 'ArrowUp') {\r\n        if (this.selectedItemIndex === 0) return;\r\n        if (this.selectedItemIndex > 0) {\r\n          this.selectedItemIndex--;\r\n          this.selectedItem = this.sortedTableData[this.selectedItemIndex];\r\n          document\r\n            .getElementById(\r\n              'tableRow_' + this.salt + '_' + this.selectedItemIndex\r\n            )\r\n            ?.scrollIntoView({ behavior: 'smooth', block: 'center' });\r\n        }\r\n        event.preventDefault();\r\n        return;\r\n      } else if (ke.key === 'Enter') {\r\n        if (this.selectedItemIndex === 0) return;\r\n        this.onItemSelected.emit(this.selectedItem);\r\n        event.preventDefault();\r\n        return;\r\n      }\r\n    }\r\n  }\r\n  onItemSelect(data: any, index: number, event: Event) {\r\n    event.preventDefault();\r\n    this.selectedItemIndex = index;\r\n    this.selectedItem = data;\r\n    this.onItemSelected.emit(this.selectedItem);\r\n  }\r\n\r\n  columnClicked(val: any) {\r\n    this.onColumnClicked.emit(val);\r\n  }\r\n  columnValueChanged(val: any) {\r\n    this.onColumnValueChanged.emit(val);\r\n  }\r\n  sortByHeader(column: any) {\r\n    if (this.sortDetail && this.sortDetail.key == column.key) {\r\n      if (this.sortDetail.sort == 'desc') {\r\n        this.sortDetail = { key: column.key, sort: 'asc' };\r\n      } else {\r\n        this.sortDetail = { key: column.key, sort: 'desc' };\r\n      }\r\n    } else {\r\n      this.sortDetail = { key: column.key, sort: 'asc' };\r\n    }\r\n    if (\r\n      column.type == COLUMNS_TYPES.TEXT ||\r\n      column.type == COLUMNS_TYPES.NUMBER\r\n    ) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [column.key],\r\n        [this.sortDetail.sort]\r\n      );\r\n    } else if (column.type == COLUMNS_TYPES.SELECTOR) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [(c) => c[column.key][column.data.key]],\r\n        [this.sortDetail.sort]\r\n      );\r\n    } else if (column.type == COLUMNS_TYPES.SHAMSI_DATE) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [(c) => new Date(c[column.key]).getTime()],\r\n        [this.sortDetail.sort]\r\n      );\r\n    }\r\n  }\r\n\r\n  activeColumnsSchema(): any[] {\r\n    return this.columnsSchema.filter(\r\n      (column: any) => column.active === undefined || column.active\r\n    );\r\n  }\r\n\r\n  tableDataFiltered(text: String | boolean, column: any) {\r\n    this.columnsSchema.map((columnSchema: any) => {\r\n      if (columnSchema.key === column.key) {\r\n        columnSchema.columnFilter = text;\r\n      }\r\n      return columnSchema;\r\n    });\r\n    this.tableData.subscribe((tableData) => {\r\n      this.sortedTableData = tableData.filter((data: any) => {\r\n        let result = true;\r\n        this.columnsSchema.forEach((columnSchema: any) => {\r\n          if (\r\n            columnSchema.type === this.columnsTypes.ROW_SELECTOR ||\r\n            columnSchema.type === this.columnsTypes.ACTION ||\r\n            columnSchema.type === this.columnsTypes.ACTION_BUTTONS ||\r\n            columnSchema.columnFilter === undefined ||\r\n            !result\r\n          ) {\r\n            return;\r\n          }\r\n          if (columnSchema.type === this.columnsTypes.SELECTOR) {\r\n            result = data[columnSchema.key][columnSchema.data.key]\r\n              .toLowerCase()\r\n              .includes(columnSchema.columnFilter.toString().toLowerCase());\r\n          } else if (columnSchema.type === this.columnsTypes.SHAMSI_DATE) {\r\n            if (columnSchema.columnFilter === '') {\r\n              result = true;\r\n            } else {\r\n              result = data[columnSchema.key]\r\n                .toLowerCase()\r\n                .includes(\r\n                  Util.shamsiToMiladi(\r\n                    columnSchema.columnFilter.toString(),\r\n                    'YYYY-MM-DD'\r\n                  )\r\n                );\r\n            }\r\n          } else if (columnSchema.type === this.columnsTypes.MULTI_COLUMN) {\r\n            result = columnSchema.columns.some((item: any) => {\r\n              return data[item.key][item.data.key]\r\n                .toLowerCase()\r\n                .includes(columnSchema.columnFilter?.toString()?.toLowerCase());\r\n            });\r\n          } else if (columnSchema.type === this.columnsTypes.STATUS) {\r\n            if (columnSchema.columnFilter === '') {\r\n              result = true;\r\n            } else {\r\n              result = data[columnSchema.key] === columnSchema.columnFilter;\r\n            }\r\n          } else {\r\n            result = data[columnSchema.key]\r\n              .toString()\r\n              .toLowerCase()\r\n              .includes(columnSchema.columnFilter?.toString()?.toLowerCase());\r\n          }\r\n        });\r\n        return result;\r\n      });\r\n    });\r\n  }\r\n\r\n  randomString(length: number): string {\r\n    return Math.random()\r\n      .toString(36)\r\n      .substring(2, 2 + length);\r\n  }\r\n}\r\n","<div class=\"p-2 overflow-x-auto\">\r\n  <table\r\n    #table\r\n    tabindex=\"0\"\r\n    *ngIf=\"!isRunningOnSmallScreen || !responsive; else smallDeviceCard\"\r\n  >\r\n    <tr>\r\n      <th\r\n        class=\"cursor-pointer text-center\"\r\n        *ngFor=\"let column of activeColumnsSchema()\"\r\n        [ngStyle]=\"{ width: column?.width + 'px' }\"\r\n      >\r\n        <div\r\n          class=\"grid\"\r\n          [ngClass]=\"[canFilter ? 'grid-rows-2' : 'grid-rows-1']\"\r\n        >\r\n          <span\r\n            class=\"p-2 relative\"\r\n            (click)=\"sortByHeader(column)\"\r\n            [ngStyle]=\"{\r\n              minWidth:\r\n                column.type === columnsTypes.ACTION_BUTTONS\r\n                  ? column.data.length * 30 + 'px'\r\n                  : '',\r\n              display:\r\n                column.type === columnsTypes.ACTION_BUTTONS\r\n                  ? 'inline-block'\r\n                  : ''\r\n            }\"\r\n            >{{ column.label }}\r\n            <app-sort-down-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"\r\n                sortDetail?.key == column.key && sortDetail?.sort === 'asc'\r\n              \"\r\n            ></app-sort-down-icon>\r\n            <app-sort-up-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"\r\n                sortDetail?.key == column.key && sortDetail?.sort === 'desc'\r\n              \"\r\n            ></app-sort-up-icon>\r\n            <app-sort-solid-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"sortDetail?.key !== column.key\"\r\n            ></app-sort-solid-icon>\r\n          </span>\r\n          <core-column-date-picker\r\n            *ngIf=\"canFilter && column.type == columnsTypes.SHAMSI_DATE\"\r\n            [canSelectToday]=\"true\"\r\n            (onChange)=\"tableDataFiltered($event, column)\"\r\n          >\r\n          </core-column-date-picker>\r\n          <core-column-input\r\n            *ngIf=\"\r\n              canFilter &&\r\n              column.type !== columnsTypes.ACTION &&\r\n              column.type !== columnsTypes.COLOR &&\r\n              column.type !== columnsTypes.STATUS &&\r\n              column.type !== columnsTypes.SHAMSI_DATE &&\r\n              column.type !== columnsTypes.ROW_SELECTOR &&\r\n              column.type !== columnsTypes.STATUS_ACTIVE &&\r\n              column.type !== columnsTypes.ACTION_BUTTONS\r\n            \"\r\n            (onChange)=\"tableDataFiltered($event, column)\"\r\n          ></core-column-input>\r\n          <core-column-selector\r\n            *ngIf=\"\r\n              (canFilter && column.type == columnsTypes.STATUS) ||\r\n              (canFilter && column.type == columnsTypes.STATUS_ACTIVE)\r\n            \"\r\n            [titleKey]=\"'title'\"\r\n            [valueKey]=\"'value'\"\r\n            [items]=\"\r\n              column.type == columnsTypes.STATUS\r\n                ? ACTIVE_OPTIONS\r\n                : YES_NO_OPTIONS\r\n            \"\r\n            (onItemSelected)=\"tableDataFiltered($event, column)\"\r\n          ></core-column-selector>\r\n        </div>\r\n      </th>\r\n    </tr>\r\n    <tr\r\n      *ngFor=\"let data of sortedTableData; let i = index\"\r\n      [id]=\"'tableRow_' + salt + '_' + i\"\r\n      [ngClass]=\"{ 'select-item': data.id === selectedItem?.id }\"\r\n      (click)=\"onItemSelect(data, i, $event)\"\r\n    >\r\n      <td\r\n        *ngFor=\"let column of activeColumnsSchema()\"\r\n        [class]=\"styleFilter ? styleFilter(data) : ''\"\r\n      >\r\n        <app-core-table-column-manager\r\n          *ngIf=\"column.type != columnsTypes.MULTI_COLUMN; else elseBlock\"\r\n          [rowSelector]=\"rowSelector\"\r\n          (onColumnClicked)=\"columnClicked($event)\"\r\n          (onColumnValueChanged)=\"columnValueChanged($event)\"\r\n          [allTableData]=\"sortedTableData\"\r\n          [data]=\"data\"\r\n          [column]=\"column\"\r\n        ></app-core-table-column-manager>\r\n        <ng-template #elseBlock>\r\n          <app-core-table-column-manager\r\n            *ngFor=\"let childColumn of column.columns; let i = index\"\r\n            [rowSelector]=\"rowSelector\"\r\n            (onColumnClicked)=\"columnClicked($event)\"\r\n            [data]=\"data\"\r\n            [allTableData]=\"sortedTableData\"\r\n            [column]=\"childColumn\"\r\n          >\r\n            <span *ngIf=\"i > 0\">-</span>\r\n          </app-core-table-column-manager>\r\n        </ng-template>\r\n      </td>\r\n    </tr>\r\n  </table>\r\n  <ng-template #smallDeviceCard>\r\n    <div>\r\n      <core-card\r\n        *ngFor=\"let data of sortedTableData\"\r\n        [cardClass]=\"'background-card m-4 p-4 relative'\"\r\n      >\r\n        <div\r\n          class=\"leading-8\"\r\n          *ngFor=\"let column of activeColumnsSchema()\"\r\n          [class]=\"\r\n            column.type === columnsTypes.ACTION_BUTTONS\r\n              ? 'actionButtons'\r\n              : column.type === columnsTypes.ROW_SELECTOR\r\n              ? 'selectRow'\r\n              : ''\r\n          \"\r\n        >\r\n          <span\r\n            *ngIf=\"\r\n              column.type !== columnsTypes.ACTION_BUTTONS &&\r\n              column.type !== columnsTypes.ROW_SELECTOR\r\n            \"\r\n            class=\"secondary-text-color\"\r\n          >\r\n            {{ column.label }} :\r\n          </span>\r\n          <span class=\"primary-text-color font-semibold\">\r\n            <app-core-table-card-manager\r\n              *ngIf=\"\r\n                column.type != columnsTypes.MULTI_COLUMN;\r\n                else cardManagerElseBlock\r\n              \"\r\n              [rowSelector]=\"rowSelector\"\r\n              (onColumnClicked)=\"columnClicked($event)\"\r\n              [data]=\"data\"\r\n              [allTableData]=\"sortedTableData\"\r\n              [column]=\"column\"\r\n            >\r\n            </app-core-table-card-manager>\r\n\r\n            <ng-template #cardManagerElseBlock>\r\n              <app-core-table-card-manager\r\n                *ngFor=\"let childColumn of column.columns; let i = index\"\r\n                [rowSelector]=\"rowSelector\"\r\n                (onColumnClicked)=\"columnClicked($event)\"\r\n                [data]=\"data\"\r\n                [allTableData]=\"sortedTableData\"\r\n                [column]=\"childColumn\"\r\n              >\r\n                <span *ngIf=\"i > 0\">-</span>\r\n              </app-core-table-card-manager>\r\n            </ng-template>\r\n          </span>\r\n        </div>\r\n      </core-card>\r\n    </div>\r\n  </ng-template>\r\n  <core-table-no-content\r\n    *ngIf=\"!loading\"\r\n    [tableData]=\"sortedTableData\"\r\n    [loading]=\"loading\"\r\n  ></core-table-no-content>\r\n</div>\r\n"]}
284
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../projects/falcon-lib/src/lib/core-table/core-table/core-table.component.ts","../../../../../../projects/falcon-lib/src/lib/core-table/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\nimport { NgxIndexedDBService } from 'ngx-indexed-db';\r\nimport { find, orderBy } from 'lodash';\r\nimport { ACTIVE_OPTIONS, YES_NO_OPTIONS } from '../../../utils/constants';\r\nimport { Util } from '../../../utils/util';\r\nimport { ColumnsSchema } from './core-table.type';\r\nimport { COLUMNS_TYPES } from '../../falconTypes';\r\n\r\n@Component({\r\n  selector: 'core-table',\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n})\r\nexport class CoreTableComponent {\r\n  @Input({ required: false }) key: string | undefined;\r\n  @Input({ required: true }) columnsSchema: ColumnsSchema[] = [];\r\n  @Input({ required: true }) tableData: BehaviorSubject<any[]> =\r\n    new BehaviorSubject<any[]>([]);\r\n  @Input({ required: false }) responsive: boolean = true;\r\n  @Input({ required: false }) canSelectFirstItem: boolean = false;\r\n  @Input({ required: true }) loading: any;\r\n  @Input() canFilter: boolean = false;\r\n  @Input({ required: false }) styleFilter: ((data: any) => string) | undefined;\r\n  @Input({ required: false }) rowSelector: BehaviorSubject<any> | undefined =\r\n    undefined;\r\n  @Output() onColumnClicked: EventEmitter<any> = new EventEmitter();\r\n  @Output() onColumnValueChanged: EventEmitter<any> = new EventEmitter();\r\n  @Output() onItemSelected: EventEmitter<any> = new EventEmitter();\r\n  @ViewChild('table') table!: ElementRef<HTMLTableElement>;\r\n  ACTIVE_OPTIONS = ACTIVE_OPTIONS;\r\n  YES_NO_OPTIONS = YES_NO_OPTIONS;\r\n  sortDetail: { key: string; sort: 'asc' | 'desc' } | undefined;\r\n  selectedItem: any = undefined;\r\n  sortedTableData: any[] = [];\r\n  dbTableFilter: any;\r\n  index = 0;\r\n  salt = this.randomString(5);\r\n  selectedItemIndex = 0;\r\n  get columnsTypes() {\r\n    return COLUMNS_TYPES;\r\n  }\r\n  get isRunningOnSmallScreen() {\r\n    return Util.isRunningOnSmallScreen();\r\n  }\r\n  constructor(private dbService: NgxIndexedDBService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.tableData.subscribe((val: any) => {\r\n      this.sortedTableData = val;\r\n      if (\r\n        this.canSelectFirstItem &&\r\n        this.sortedTableData.length > 0 &&\r\n        this.selectedItem === undefined\r\n      ) {\r\n        this.selectedItem = this.sortedTableData[0];\r\n        this.selectedItemIndex = 0;\r\n        this.table.nativeElement.focus();\r\n      }\r\n    });\r\n    if (this.key) {\r\n      this.dbService\r\n        .getByIndex('tableFilter', 'key', this.key)\r\n        .subscribe((data: any) => {\r\n          this.dbTableFilter = data;\r\n          if (this.dbTableFilter) {\r\n            this.setTableFilter();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.table.nativeElement.focus();\r\n    if (this.canSelectFirstItem && this.sortedTableData.length > 0) {\r\n      this.selectedItem = this.sortedTableData[0];\r\n    }\r\n  }\r\n\r\n  setTableFilter() {\r\n    this.columnsSchema.map((column: any) => {\r\n      JSON.parse(this.dbTableFilter.columnsSchema).forEach(\r\n        (dbColumnsSchema: any) => {\r\n          if (dbColumnsSchema.key === column.key) {\r\n            column.active = dbColumnsSchema.active;\r\n          }\r\n        }\r\n      );\r\n      return column;\r\n    });\r\n  }\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleEnter(event: Event) {\r\n    const key = event as KeyboardEvent;\r\n    if (document.activeElement === this.table.nativeElement) {\r\n      if (key.key === 'ArrowDown') {\r\n        if (this.selectedItemIndex === this.sortedTableData.length - 1) return;\r\n        if (this.selectedItemIndex < this.sortedTableData.length - 1) {\r\n          this.selectedItemIndex++;\r\n          this.selectedItem = this.sortedTableData[this.selectedItemIndex];\r\n          document\r\n            .getElementById(\r\n              'tableRow_' + this.salt + '_' + this.selectedItemIndex\r\n            )\r\n            ?.scrollIntoView({ behavior: 'smooth', block: 'center' });\r\n        }\r\n        event.preventDefault();\r\n        return;\r\n      } else if (key.key === 'ArrowUp') {\r\n        if (this.selectedItemIndex === 0) return;\r\n        if (this.selectedItemIndex > 0) {\r\n          this.selectedItemIndex--;\r\n          this.selectedItem = this.sortedTableData[this.selectedItemIndex];\r\n          document\r\n            .getElementById(\r\n              'tableRow_' + this.salt + '_' + this.selectedItemIndex\r\n            )\r\n            ?.scrollIntoView({ behavior: 'smooth', block: 'center' });\r\n        }\r\n        event.preventDefault();\r\n        return;\r\n      } else if (key.key === 'Enter') {\r\n        this.onItemSelected.emit(this.selectedItem);\r\n        event.preventDefault();\r\n        return;\r\n      } else if (key.altKey) {\r\n        const actionButtons: any = this.columnsSchema.find(\r\n          (schema: any) => schema.type === COLUMNS_TYPES.ACTION_BUTTONS\r\n        );\r\n\r\n        actionButtons.data.forEach((actionButton: any) => {\r\n          if (actionButton.keyboardShortcut) {\r\n            const regex = new RegExp(\r\n              '^(' + actionButton.keyboardShortcut + ')$',\r\n              'i'\r\n            );\r\n            if (regex.test(key.key)) {\r\n              this.columnClicked({\r\n                data: this.selectedItem,\r\n                key: actionButton.key,\r\n              });\r\n            }\r\n          }\r\n        });\r\n        this.onItemSelected.emit(this.selectedItem);\r\n        event.preventDefault();\r\n        return;\r\n      }\r\n    }\r\n  }\r\n  onItemSelect(data: any, index: number, event: Event) {\r\n    event.preventDefault();\r\n    this.selectedItemIndex = index;\r\n    this.selectedItem = data;\r\n    this.onItemSelected.emit(this.selectedItem);\r\n  }\r\n\r\n  columnClicked(val: any) {\r\n    this.onColumnClicked.emit(val);\r\n  }\r\n  columnValueChanged(val: any) {\r\n    this.onColumnValueChanged.emit(val);\r\n  }\r\n  sortByHeader(column: any) {\r\n    if (this.sortDetail && this.sortDetail.key == column.key) {\r\n      if (this.sortDetail.sort == 'desc') {\r\n        this.sortDetail = { key: column.key, sort: 'asc' };\r\n      } else {\r\n        this.sortDetail = { key: column.key, sort: 'desc' };\r\n      }\r\n    } else {\r\n      this.sortDetail = { key: column.key, sort: 'asc' };\r\n    }\r\n    if (\r\n      column.type == COLUMNS_TYPES.TEXT ||\r\n      column.type == COLUMNS_TYPES.NUMBER\r\n    ) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [column.key],\r\n        [this.sortDetail.sort]\r\n      );\r\n    } else if (column.type == COLUMNS_TYPES.SELECTOR) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [(c) => c[column.key][column.data.key]],\r\n        [this.sortDetail.sort]\r\n      );\r\n    } else if (column.type == COLUMNS_TYPES.SHAMSI_DATE) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [(c) => new Date(c[column.key]).getTime()],\r\n        [this.sortDetail.sort]\r\n      );\r\n    }\r\n  }\r\n\r\n  activeColumnsSchema(): any[] {\r\n    return this.columnsSchema.filter(\r\n      (column: any) => column.active === undefined || column.active\r\n    );\r\n  }\r\n\r\n  tableDataFiltered(text: String | boolean, column: any) {\r\n    this.columnsSchema.map((columnSchema: any) => {\r\n      if (columnSchema.key === column.key) {\r\n        columnSchema.columnFilter = text;\r\n      }\r\n      return columnSchema;\r\n    });\r\n    this.tableData.subscribe((tableData) => {\r\n      this.sortedTableData = tableData.filter((data: any) => {\r\n        let result = true;\r\n        this.columnsSchema.forEach((columnSchema: any) => {\r\n          if (\r\n            columnSchema.type === this.columnsTypes.ROW_SELECTOR ||\r\n            columnSchema.type === this.columnsTypes.ACTION ||\r\n            columnSchema.type === this.columnsTypes.ACTION_BUTTONS ||\r\n            columnSchema.columnFilter === undefined ||\r\n            !result\r\n          ) {\r\n            return;\r\n          }\r\n          if (columnSchema.type === this.columnsTypes.SELECTOR) {\r\n            result = data[columnSchema.key][columnSchema.data.key]\r\n              .toLowerCase()\r\n              .includes(columnSchema.columnFilter.toString().toLowerCase());\r\n          } else if (columnSchema.type === this.columnsTypes.SHAMSI_DATE) {\r\n            if (columnSchema.columnFilter === '') {\r\n              result = true;\r\n            } else {\r\n              result = data[columnSchema.key]\r\n                .toLowerCase()\r\n                .includes(\r\n                  Util.shamsiToMiladi(\r\n                    columnSchema.columnFilter.toString(),\r\n                    'YYYY-MM-DD'\r\n                  )\r\n                );\r\n            }\r\n          } else if (columnSchema.type === this.columnsTypes.MULTI_COLUMN) {\r\n            result = columnSchema.columns.some((item: any) => {\r\n              return data[item.key][item.data.key]\r\n                .toLowerCase()\r\n                .includes(columnSchema.columnFilter?.toString()?.toLowerCase());\r\n            });\r\n          } else if (columnSchema.type === this.columnsTypes.STATUS) {\r\n            if (columnSchema.columnFilter === '') {\r\n              result = true;\r\n            } else {\r\n              result = data[columnSchema.key] === columnSchema.columnFilter;\r\n            }\r\n          } else {\r\n            result = data[columnSchema.key]\r\n              .toString()\r\n              .toLowerCase()\r\n              .includes(columnSchema.columnFilter?.toString()?.toLowerCase());\r\n          }\r\n        });\r\n        return result;\r\n      });\r\n    });\r\n  }\r\n\r\n  randomString(length: number): string {\r\n    return Math.random()\r\n      .toString(36)\r\n      .substring(2, 2 + length);\r\n  }\r\n}\r\n","<div class=\"p-2 overflow-x-auto\">\r\n  <table\r\n    #table\r\n    tabindex=\"0\"\r\n    *ngIf=\"!isRunningOnSmallScreen || !responsive; else smallDeviceCard\"\r\n  >\r\n    <tr>\r\n      <th\r\n        class=\"cursor-pointer text-center\"\r\n        *ngFor=\"let column of activeColumnsSchema()\"\r\n        [ngStyle]=\"{ width: column?.width + 'px' }\"\r\n      >\r\n        <div\r\n          class=\"grid\"\r\n          [ngClass]=\"[canFilter ? 'grid-rows-2' : 'grid-rows-1']\"\r\n        >\r\n          <span\r\n            class=\"p-2 relative\"\r\n            (click)=\"sortByHeader(column)\"\r\n            [ngStyle]=\"{\r\n              minWidth:\r\n                column.type === columnsTypes.ACTION_BUTTONS\r\n                  ? column.data.length * 30 + 'px'\r\n                  : '',\r\n              display:\r\n                column.type === columnsTypes.ACTION_BUTTONS\r\n                  ? 'inline-block'\r\n                  : ''\r\n            }\"\r\n            >{{ column.label }}\r\n            <app-sort-down-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"\r\n                sortDetail?.key == column.key && sortDetail?.sort === 'asc'\r\n              \"\r\n            ></app-sort-down-icon>\r\n            <app-sort-up-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"\r\n                sortDetail?.key == column.key && sortDetail?.sort === 'desc'\r\n              \"\r\n            ></app-sort-up-icon>\r\n            <app-sort-solid-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"sortDetail?.key !== column.key\"\r\n            ></app-sort-solid-icon>\r\n          </span>\r\n          <core-column-date-picker\r\n            *ngIf=\"canFilter && column.type == columnsTypes.SHAMSI_DATE\"\r\n            [canSelectToday]=\"true\"\r\n            (onChange)=\"tableDataFiltered($event, column)\"\r\n          >\r\n          </core-column-date-picker>\r\n          <core-column-input\r\n            *ngIf=\"\r\n              canFilter &&\r\n              column.type !== columnsTypes.ACTION &&\r\n              column.type !== columnsTypes.COLOR &&\r\n              column.type !== columnsTypes.STATUS &&\r\n              column.type !== columnsTypes.SHAMSI_DATE &&\r\n              column.type !== columnsTypes.ROW_SELECTOR &&\r\n              column.type !== columnsTypes.STATUS_ACTIVE &&\r\n              column.type !== columnsTypes.ACTION_BUTTONS\r\n            \"\r\n            (onChange)=\"tableDataFiltered($event, column)\"\r\n          ></core-column-input>\r\n          <core-column-selector\r\n            *ngIf=\"\r\n              (canFilter && column.type == columnsTypes.STATUS) ||\r\n              (canFilter && column.type == columnsTypes.STATUS_ACTIVE)\r\n            \"\r\n            [titleKey]=\"'title'\"\r\n            [valueKey]=\"'value'\"\r\n            [items]=\"\r\n              column.type == columnsTypes.STATUS\r\n                ? ACTIVE_OPTIONS\r\n                : YES_NO_OPTIONS\r\n            \"\r\n            (onItemSelected)=\"tableDataFiltered($event, column)\"\r\n          ></core-column-selector>\r\n        </div>\r\n      </th>\r\n    </tr>\r\n    <tr\r\n      *ngFor=\"let data of sortedTableData; let i = index\"\r\n      [id]=\"'tableRow_' + salt + '_' + i\"\r\n      [ngClass]=\"{ 'select-item': data.id === selectedItem?.id }\"\r\n      (click)=\"onItemSelect(data, i, $event)\"\r\n    >\r\n      <td\r\n        *ngFor=\"let column of activeColumnsSchema()\"\r\n        [class]=\"styleFilter ? styleFilter(data) : ''\"\r\n      >\r\n        <app-core-table-column-manager\r\n          *ngIf=\"column.type != columnsTypes.MULTI_COLUMN; else elseBlock\"\r\n          [rowSelector]=\"rowSelector\"\r\n          (onColumnClicked)=\"columnClicked($event)\"\r\n          (onColumnValueChanged)=\"columnValueChanged($event)\"\r\n          [allTableData]=\"sortedTableData\"\r\n          [data]=\"data\"\r\n          [column]=\"column\"\r\n        ></app-core-table-column-manager>\r\n        <ng-template #elseBlock>\r\n          <app-core-table-column-manager\r\n            *ngFor=\"let childColumn of column.columns; let i = index\"\r\n            [rowSelector]=\"rowSelector\"\r\n            (onColumnClicked)=\"columnClicked($event)\"\r\n            [data]=\"data\"\r\n            [allTableData]=\"sortedTableData\"\r\n            [column]=\"childColumn\"\r\n          >\r\n            <span *ngIf=\"i > 0\">-</span>\r\n          </app-core-table-column-manager>\r\n        </ng-template>\r\n      </td>\r\n    </tr>\r\n  </table>\r\n  <ng-template #smallDeviceCard>\r\n    <div>\r\n      <core-card\r\n        *ngFor=\"let data of sortedTableData\"\r\n        [cardClass]=\"'background-card m-4 p-4 relative'\"\r\n      >\r\n        <div\r\n          class=\"leading-8\"\r\n          *ngFor=\"let column of activeColumnsSchema()\"\r\n          [class]=\"\r\n            column.type === columnsTypes.ACTION_BUTTONS\r\n              ? 'actionButtons'\r\n              : column.type === columnsTypes.ROW_SELECTOR\r\n              ? 'selectRow'\r\n              : ''\r\n          \"\r\n        >\r\n          <span\r\n            *ngIf=\"\r\n              column.type !== columnsTypes.ACTION_BUTTONS &&\r\n              column.type !== columnsTypes.ROW_SELECTOR\r\n            \"\r\n            class=\"secondary-text-color\"\r\n          >\r\n            {{ column.label }} :\r\n          </span>\r\n          <span class=\"primary-text-color font-semibold\">\r\n            <app-core-table-card-manager\r\n              *ngIf=\"\r\n                column.type != columnsTypes.MULTI_COLUMN;\r\n                else cardManagerElseBlock\r\n              \"\r\n              [rowSelector]=\"rowSelector\"\r\n              (onColumnClicked)=\"columnClicked($event)\"\r\n              [data]=\"data\"\r\n              [allTableData]=\"sortedTableData\"\r\n              [column]=\"column\"\r\n            >\r\n            </app-core-table-card-manager>\r\n\r\n            <ng-template #cardManagerElseBlock>\r\n              <app-core-table-card-manager\r\n                *ngFor=\"let childColumn of column.columns; let i = index\"\r\n                [rowSelector]=\"rowSelector\"\r\n                (onColumnClicked)=\"columnClicked($event)\"\r\n                [data]=\"data\"\r\n                [allTableData]=\"sortedTableData\"\r\n                [column]=\"childColumn\"\r\n              >\r\n                <span *ngIf=\"i > 0\">-</span>\r\n              </app-core-table-card-manager>\r\n            </ng-template>\r\n          </span>\r\n        </div>\r\n      </core-card>\r\n    </div>\r\n  </ng-template>\r\n  <core-table-no-content\r\n    *ngIf=\"!loading\"\r\n    [tableData]=\"sortedTableData\"\r\n    [loading]=\"loading\"\r\n  ></core-table-no-content>\r\n</div>\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS10YWJsZS50eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS9jb3JlLXRhYmxlLnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBDT0xVTU5TX1RZUEVTIH0gZnJvbSAnLi4vLi4vZmFsY29uVHlwZXMnO1xyXG5cclxudHlwZSBDb2x1bW5UeXBlVGV4dCA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLlRFWFQ7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBjb3B5VG9DbGlwYm9hcmQ/OiBib29sZWFuO1xyXG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGRhdGE/OiB7XHJcbiAgICAvKiogZGVmYXVsdCB2YWx1ZSBpcyAgdHJ1ZSBhbmQgbnVtYmVycyB0dXJuIHRvIHBlcnNpYW4gRGlnaXRzICovXHJcbiAgICBlbkRpZ2l0c1RvRmE6IGJvb2xlYW47XHJcbiAgfTtcclxufTtcclxudHlwZSBDb2x1bW5UeXBlU2hhbXNpRGF0ZSA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLlNIQU1TSV9EQVRFO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGJvb2xlYW47XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICBkYXRhPzoge1xyXG4gICAgZGF0ZUZvcm1hdDogc3RyaW5nO1xyXG4gIH07XHJcbn07XHJcbnR5cGUgQ29sdW1uVHlwZURhdGUgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5EQVRFO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGJvb2xlYW47XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICBkYXRhPzoge1xyXG4gICAgZGF0ZUZvcm1hdDogc3RyaW5nO1xyXG4gIH07XHJcbn07XHJcbnR5cGUgQ29sdW1uVHlwZVNlbGVjdG9yID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuU0VMRUNUT1I7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGRhdGE6IHtcclxuICAgIGtleTogc3RyaW5nO1xyXG4gIH07XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGZhbHNlO1xyXG59O1xyXG50eXBlIENvbHVtblR5cGVTZWxlY3RvckVkaXRhYmxlID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuU0VMRUNUT1I7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGRhdGE6IHtcclxuICAgIGtleTogc3RyaW5nO1xyXG4gICAgdmFsdWU6IHN0cmluZztcclxuICAgIGVkaXRhYmxlRGF0YTogT2JzZXJ2YWJsZTxhbnlbXT47XHJcbiAgfTtcclxuICBjb3B5VG9DbGlwYm9hcmQ/OiBib29sZWFuO1xyXG4gIGVkaXRhYmxlOiB0cnVlO1xyXG59O1xyXG50eXBlIENvbHVtblR5cGVTdGF0dXMgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5TVEFUVVMgfCBDT0xVTU5TX1RZUEVTLlNUQVRVU19BQ1RJVkU7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcclxufTtcclxudHlwZSBDb2x1bW5UeXBlQ29sb3IgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5DT0xPUjtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHdpZHRoPzogbnVtYmVyO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgZWRpdGFibGU/OiBib29sZWFuO1xyXG59O1xyXG5leHBvcnQgdHlwZSBDb2x1bW5UeXBlQWN0aW9uID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuQUNUSU9OO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICB0aXRsZTogc3RyaW5nO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgQ29sdW1uVHlwZUFjdGlvbkJ1dHRvbnMgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5BQ1RJT05fQlVUVE9OUztcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgZGF0YToge1xyXG4gICAga2V5OiBzdHJpbmc7XHJcbiAgICB0aXRsZTogc3RyaW5nO1xyXG4gICAgY29tcG9uZW50OiBhbnk7XHJcbiAgfVtdO1xyXG59O1xyXG5leHBvcnQgdHlwZSBDb2x1bW5UeXBlTnVtYmVyID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuTlVNQkVSO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGJvb2xlYW47XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICBjYW5Db2xvcmZ1bE51bWJlcj86IGJvb2xlYW47XHJcbiAgZGF0YT86IHtcclxuICAgIC8qKiBkZWZhdWx0IHZhbHVlIGlzICB0cnVlIGFuZCBudW1iZXJzIHR1cm4gdG8gcGVyc2lhbiBEaWdpdHMgKi9cclxuICAgIGVuRGlnaXRzVG9GYT86IGJvb2xlYW47XHJcbiAgICAvKiogZGVmYXVsdCB2YWx1ZSBpcyAgdHJ1ZSAgICovXHJcbiAgICBjYW5TaG93VG9tYW5JblRvb2xUaXA/OiBib29sZWFuO1xyXG4gICAgLyoqIGRlZmF1bHQgdmFsdWUgaXMgIGZhbHNlICAqL1xyXG4gICAgY2FuU2hvd0lSUj86IGJvb2xlYW47XHJcbiAgICAvKiogZGVmYXVsdCB2YWx1ZSBpcyAgdHJ1ZSAgICovXHJcbiAgICBjYW5TcGxpdE51bWJlcnM/OiBib29sZWFuO1xyXG4gICAgLyoqIGRlZmF1bHQgdmFsdWUgaXMgIHRydWUgICAqL1xyXG4gICAgY2FuU2hvd1dvcmRJblRvb2xUaXA/OiBib29sZWFuO1xyXG4gIH07XHJcbn07XHJcbmV4cG9ydCB0eXBlIENvbHVtblR5cGVQZWxhayA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLlBFTEFLO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxufTtcclxuZXhwb3J0IHR5cGUgQ29sdW1uVHlwZURldGFpbFZpZXdlckZvclJlcG9ydCA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLk5VTUJFUjtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgZGF0YT86IHtcclxuICAgIGRldGFpbFZpZXdlcnM6IHN0cmluZ1tdO1xyXG4gICAga2V5VHlwZTogc3RyaW5nO1xyXG4gICAgb25DbGljazogKGRhdGE6IGFueSkgPT4gdm9pZDtcclxuICB9O1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgQ29sdW1uVHlwZVJvd1NlbGVjdG9yID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuUk9XX1NFTEVDVE9SO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBkYXRhOiB7XHJcbiAgICBrZXk6IHN0cmluZztcclxuICB9O1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgQ29sdW1uVHlwZU11bHRpQ29sdW1uID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuTVVMVElfQ09MVU1OO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICBjb2x1bW5zOiB7XHJcbiAgICBrZXk6IHN0cmluZztcclxuICAgIHR5cGU6IENPTFVNTlNfVFlQRVMuU0VMRUNUT1I7XHJcbiAgICBsYWJlbDogc3RyaW5nO1xyXG4gICAgZGF0YToge1xyXG4gICAgICBrZXk6IHN0cmluZztcclxuICAgIH07XHJcbiAgfVtdO1xyXG59O1xyXG5leHBvcnQgdHlwZSBDb2x1bW5zU2NoZW1hID1cclxuICB8IENvbHVtblR5cGVUZXh0XHJcbiAgfCBDb2x1bW5UeXBlU2VsZWN0b3JcclxuICB8IENvbHVtblR5cGVTZWxlY3RvckVkaXRhYmxlXHJcbiAgfCBDb2x1bW5UeXBlU3RhdHVzXHJcbiAgfCBDb2x1bW5UeXBlQ29sb3JcclxuICB8IENvbHVtblR5cGVBY3Rpb25cclxuICB8IENvbHVtblR5cGVBY3Rpb25CdXR0b25zXHJcbiAgfCBDb2x1bW5UeXBlTnVtYmVyXHJcbiAgfCBDb2x1bW5UeXBlUm93U2VsZWN0b3JcclxuICB8IENvbHVtblR5cGVNdWx0aUNvbHVtblxyXG4gIHwgQ29sdW1uVHlwZVBlbGFrXHJcbiAgfCBDb2x1bW5UeXBlU2hhbXNpRGF0ZVxyXG4gIHwgQ29sdW1uVHlwZURhdGU7XHJcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS10YWJsZS50eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS9jb3JlLXRhYmxlLnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBDT0xVTU5TX1RZUEVTIH0gZnJvbSAnLi4vLi4vZmFsY29uVHlwZXMnO1xyXG5cclxudHlwZSBDb2x1bW5UeXBlVGV4dCA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLlRFWFQ7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBjb3B5VG9DbGlwYm9hcmQ/OiBib29sZWFuO1xyXG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGRhdGE/OiB7XHJcbiAgICAvKiogZGVmYXVsdCB2YWx1ZSBpcyAgdHJ1ZSBhbmQgbnVtYmVycyB0dXJuIHRvIHBlcnNpYW4gRGlnaXRzICovXHJcbiAgICBlbkRpZ2l0c1RvRmE6IGJvb2xlYW47XHJcbiAgfTtcclxufTtcclxudHlwZSBDb2x1bW5UeXBlU2hhbXNpRGF0ZSA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLlNIQU1TSV9EQVRFO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGJvb2xlYW47XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICBkYXRhPzoge1xyXG4gICAgZGF0ZUZvcm1hdDogc3RyaW5nO1xyXG4gIH07XHJcbn07XHJcbnR5cGUgQ29sdW1uVHlwZURhdGUgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5EQVRFO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGJvb2xlYW47XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICBkYXRhPzoge1xyXG4gICAgZGF0ZUZvcm1hdDogc3RyaW5nO1xyXG4gIH07XHJcbn07XHJcbnR5cGUgQ29sdW1uVHlwZVNlbGVjdG9yID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuU0VMRUNUT1I7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGRhdGE6IHtcclxuICAgIGtleTogc3RyaW5nO1xyXG4gIH07XHJcbiAgY29weVRvQ2xpcGJvYXJkPzogYm9vbGVhbjtcclxuICBlZGl0YWJsZT86IGZhbHNlO1xyXG59O1xyXG50eXBlIENvbHVtblR5cGVTZWxlY3RvckVkaXRhYmxlID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuU0VMRUNUT1I7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGRhdGE6IHtcclxuICAgIGtleTogc3RyaW5nO1xyXG4gICAgdmFsdWU6IHN0cmluZztcclxuICAgIGVkaXRhYmxlRGF0YTogT2JzZXJ2YWJsZTxhbnlbXT47XHJcbiAgfTtcclxuICBjb3B5VG9DbGlwYm9hcmQ/OiBib29sZWFuO1xyXG4gIGVkaXRhYmxlOiB0cnVlO1xyXG59O1xyXG50eXBlIENvbHVtblR5cGVTdGF0dXMgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5TVEFUVVMgfCBDT0xVTU5TX1RZUEVTLlNUQVRVU19BQ1RJVkU7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIGVkaXRhYmxlPzogYm9vbGVhbjtcclxufTtcclxudHlwZSBDb2x1bW5UeXBlQ29sb3IgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5DT0xPUjtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHdpZHRoPzogbnVtYmVyO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgZWRpdGFibGU/OiBib29sZWFuO1xyXG59O1xyXG5leHBvcnQgdHlwZSBDb2x1bW5UeXBlQWN0aW9uID0ge1xyXG4gIGtleTogc3RyaW5nO1xyXG4gIHR5cGU6IENPTFVNTlNfVFlQRVMuQUNUSU9OO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgYWN0aXZlPzogYm9vbGVhbjtcclxuICB0aXRsZTogc3RyaW5nO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgQ29sdW1uVHlwZUFjdGlvbkJ1dHRvbnMgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5BQ1RJT05fQlVUVE9OUztcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgZGF0YToge1xyXG4gICAga2V5OiBzdHJpbmc7XHJcbiAgICB0aXRsZTogc3RyaW5nO1xyXG4gICAgY29tcG9uZW50OiBhbnk7XHJcbiAgICBrZXlib2FyZFNob3J0Y3V0Pzogc3RyaW5nO1xyXG4gIH1bXTtcclxufTtcclxuZXhwb3J0IHR5cGUgQ29sdW1uVHlwZU51bWJlciA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLk5VTUJFUjtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHdpZHRoPzogbnVtYmVyO1xyXG4gIGNvcHlUb0NsaXBib2FyZD86IGJvb2xlYW47XHJcbiAgZWRpdGFibGU/OiBib29sZWFuO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgY2FuQ29sb3JmdWxOdW1iZXI/OiBib29sZWFuO1xyXG4gIGRhdGE/OiB7XHJcbiAgICAvKiogZGVmYXVsdCB2YWx1ZSBpcyAgdHJ1ZSBhbmQgbnVtYmVycyB0dXJuIHRvIHBlcnNpYW4gRGlnaXRzICovXHJcbiAgICBlbkRpZ2l0c1RvRmE/OiBib29sZWFuO1xyXG4gICAgLyoqIGRlZmF1bHQgdmFsdWUgaXMgIHRydWUgICAqL1xyXG4gICAgY2FuU2hvd1RvbWFuSW5Ub29sVGlwPzogYm9vbGVhbjtcclxuICAgIC8qKiBkZWZhdWx0IHZhbHVlIGlzICBmYWxzZSAgKi9cclxuICAgIGNhblNob3dJUlI/OiBib29sZWFuO1xyXG4gICAgLyoqIGRlZmF1bHQgdmFsdWUgaXMgIHRydWUgICAqL1xyXG4gICAgY2FuU3BsaXROdW1iZXJzPzogYm9vbGVhbjtcclxuICAgIC8qKiBkZWZhdWx0IHZhbHVlIGlzICB0cnVlICAgKi9cclxuICAgIGNhblNob3dXb3JkSW5Ub29sVGlwPzogYm9vbGVhbjtcclxuICB9O1xyXG59O1xyXG5leHBvcnQgdHlwZSBDb2x1bW5UeXBlUGVsYWsgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5QRUxBSztcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHdpZHRoPzogbnVtYmVyO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbn07XHJcbmV4cG9ydCB0eXBlIENvbHVtblR5cGVEZXRhaWxWaWV3ZXJGb3JSZXBvcnQgPSB7XHJcbiAga2V5OiBzdHJpbmc7XHJcbiAgdHlwZTogQ09MVU1OU19UWVBFUy5OVU1CRVI7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICBhY3RpdmU/OiBib29sZWFuO1xyXG4gIHdpZHRoPzogbnVtYmVyO1xyXG4gIGRhdGE/OiB7XHJcbiAgICBkZXRhaWxWaWV3ZXJzOiBzdHJpbmdbXTtcclxuICAgIGtleVR5cGU6IHN0cmluZztcclxuICAgIG9uQ2xpY2s6IChkYXRhOiBhbnkpID0+IHZvaWQ7XHJcbiAgfTtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIENvbHVtblR5cGVSb3dTZWxlY3RvciA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLlJPV19TRUxFQ1RPUjtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgd2lkdGg/OiBudW1iZXI7XHJcbiAgZGF0YToge1xyXG4gICAga2V5OiBzdHJpbmc7XHJcbiAgfTtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIENvbHVtblR5cGVNdWx0aUNvbHVtbiA9IHtcclxuICBrZXk6IHN0cmluZztcclxuICB0eXBlOiBDT0xVTU5TX1RZUEVTLk1VTFRJX0NPTFVNTjtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHdpZHRoPzogbnVtYmVyO1xyXG4gIGFjdGl2ZT86IGJvb2xlYW47XHJcbiAgY29sdW1uczoge1xyXG4gICAga2V5OiBzdHJpbmc7XHJcbiAgICB0eXBlOiBDT0xVTU5TX1RZUEVTLlNFTEVDVE9SO1xyXG4gICAgbGFiZWw6IHN0cmluZztcclxuICAgIGRhdGE6IHtcclxuICAgICAga2V5OiBzdHJpbmc7XHJcbiAgICB9O1xyXG4gIH1bXTtcclxufTtcclxuZXhwb3J0IHR5cGUgQ29sdW1uc1NjaGVtYSA9XHJcbiAgfCBDb2x1bW5UeXBlVGV4dFxyXG4gIHwgQ29sdW1uVHlwZVNlbGVjdG9yXHJcbiAgfCBDb2x1bW5UeXBlU2VsZWN0b3JFZGl0YWJsZVxyXG4gIHwgQ29sdW1uVHlwZVN0YXR1c1xyXG4gIHwgQ29sdW1uVHlwZUNvbG9yXHJcbiAgfCBDb2x1bW5UeXBlQWN0aW9uXHJcbiAgfCBDb2x1bW5UeXBlQWN0aW9uQnV0dG9uc1xyXG4gIHwgQ29sdW1uVHlwZU51bWJlclxyXG4gIHwgQ29sdW1uVHlwZVJvd1NlbGVjdG9yXHJcbiAgfCBDb2x1bW5UeXBlTXVsdGlDb2x1bW5cclxuICB8IENvbHVtblR5cGVQZWxha1xyXG4gIHwgQ29sdW1uVHlwZVNoYW1zaURhdGVcclxuICB8IENvbHVtblR5cGVEYXRlO1xyXG4iXX0=
@@ -2279,9 +2279,9 @@ class CoreTableComponent {
2279
2279
  });
2280
2280
  }
2281
2281
  handleEnter(event) {
2282
- const ke = event;
2282
+ const key = event;
2283
2283
  if (document.activeElement === this.table.nativeElement) {
2284
- if (ke.key === 'ArrowDown') {
2284
+ if (key.key === 'ArrowDown') {
2285
2285
  if (this.selectedItemIndex === this.sortedTableData.length - 1)
2286
2286
  return;
2287
2287
  if (this.selectedItemIndex < this.sortedTableData.length - 1) {
@@ -2294,7 +2294,7 @@ class CoreTableComponent {
2294
2294
  event.preventDefault();
2295
2295
  return;
2296
2296
  }
2297
- else if (ke.key === 'ArrowUp') {
2297
+ else if (key.key === 'ArrowUp') {
2298
2298
  if (this.selectedItemIndex === 0)
2299
2299
  return;
2300
2300
  if (this.selectedItemIndex > 0) {
@@ -2307,9 +2307,24 @@ class CoreTableComponent {
2307
2307
  event.preventDefault();
2308
2308
  return;
2309
2309
  }
2310
- else if (ke.key === 'Enter') {
2311
- if (this.selectedItemIndex === 0)
2312
- return;
2310
+ else if (key.key === 'Enter') {
2311
+ this.onItemSelected.emit(this.selectedItem);
2312
+ event.preventDefault();
2313
+ return;
2314
+ }
2315
+ else if (key.altKey) {
2316
+ const actionButtons = this.columnsSchema.find((schema) => schema.type === COLUMNS_TYPES.ACTION_BUTTONS);
2317
+ actionButtons.data.forEach((actionButton) => {
2318
+ if (actionButton.keyboardShortcut) {
2319
+ const regex = new RegExp('^(' + actionButton.keyboardShortcut + ')$', 'i');
2320
+ if (regex.test(key.key)) {
2321
+ this.columnClicked({
2322
+ data: this.selectedItem,
2323
+ key: actionButton.key,
2324
+ });
2325
+ }
2326
+ }
2327
+ });
2313
2328
  this.onItemSelected.emit(this.selectedItem);
2314
2329
  event.preventDefault();
2315
2330
  return;