| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289 |
- /**
- * @fileoverview added by tsickle
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
- */
- import * as tslib_1 from "tslib";
- import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
- import { SelectionType } from '../../types/selection.type';
- import { selectRowsBetween, selectRows } from '../../utils/selection';
- import { Keys } from '../../utils/keys';
- /**
- * @record
- */
- export function Model() { }
- if (false) {
- /** @type {?} */
- Model.prototype.type;
- /** @type {?} */
- Model.prototype.event;
- /** @type {?} */
- Model.prototype.row;
- /** @type {?} */
- Model.prototype.rowElement;
- /** @type {?} */
- Model.prototype.cellElement;
- /** @type {?} */
- Model.prototype.cellIndex;
- }
- var DataTableSelectionComponent = /** @class */ (function () {
- function DataTableSelectionComponent() {
- this.activate = new EventEmitter();
- this.select = new EventEmitter();
- }
- /**
- * @param {?} event
- * @param {?} index
- * @param {?} row
- * @return {?}
- */
- DataTableSelectionComponent.prototype.selectRow = /**
- * @param {?} event
- * @param {?} index
- * @param {?} row
- * @return {?}
- */
- function (event, index, row) {
- var _a;
- if (!this.selectEnabled)
- return;
- /** @type {?} */
- var chkbox = this.selectionType === SelectionType.checkbox;
- /** @type {?} */
- var multi = this.selectionType === SelectionType.multi;
- /** @type {?} */
- var multiClick = this.selectionType === SelectionType.multiClick;
- /** @type {?} */
- var selected = [];
- if (multi || chkbox || multiClick) {
- if (event.shiftKey) {
- selected = selectRowsBetween([], this.rows, index, this.prevIndex, this.getRowSelectedIdx.bind(this));
- }
- else if (event.ctrlKey || event.metaKey || multiClick || chkbox) {
- selected = selectRows(tslib_1.__spread(this.selected), row, this.getRowSelectedIdx.bind(this));
- }
- else {
- selected = selectRows([], row, this.getRowSelectedIdx.bind(this));
- }
- }
- else {
- selected = selectRows([], row, this.getRowSelectedIdx.bind(this));
- }
- if (typeof this.selectCheck === 'function') {
- selected = selected.filter(this.selectCheck.bind(this));
- }
- this.selected.splice(0, this.selected.length);
- (_a = this.selected).push.apply(_a, tslib_1.__spread(selected));
- this.prevIndex = index;
- this.select.emit({
- selected: selected
- });
- };
- /**
- * @param {?} model
- * @param {?} index
- * @return {?}
- */
- DataTableSelectionComponent.prototype.onActivate = /**
- * @param {?} model
- * @param {?} index
- * @return {?}
- */
- function (model, index) {
- var type = model.type, event = model.event, row = model.row;
- /** @type {?} */
- var chkbox = this.selectionType === SelectionType.checkbox;
- /** @type {?} */
- var select = (!chkbox && (type === 'click' || type === 'dblclick')) || (chkbox && type === 'checkbox');
- if (select) {
- this.selectRow(event, index, row);
- }
- else if (type === 'keydown') {
- if (((/** @type {?} */ (event))).keyCode === Keys.return) {
- this.selectRow(event, index, row);
- }
- else {
- this.onKeyboardFocus(model);
- }
- }
- this.activate.emit(model);
- };
- /**
- * @param {?} model
- * @return {?}
- */
- DataTableSelectionComponent.prototype.onKeyboardFocus = /**
- * @param {?} model
- * @return {?}
- */
- function (model) {
- var keyCode = (/** @type {?} */ (model.event)).keyCode;
- /** @type {?} */
- var shouldFocus = keyCode === Keys.up || keyCode === Keys.down || keyCode === Keys.right || keyCode === Keys.left;
- if (shouldFocus) {
- /** @type {?} */
- var isCellSelection = this.selectionType === SelectionType.cell;
- if (!model.cellElement || !isCellSelection) {
- this.focusRow(model.rowElement, keyCode);
- }
- else if (isCellSelection) {
- this.focusCell(model.cellElement, model.rowElement, keyCode, model.cellIndex);
- }
- }
- };
- /**
- * @param {?} rowElement
- * @param {?} keyCode
- * @return {?}
- */
- DataTableSelectionComponent.prototype.focusRow = /**
- * @param {?} rowElement
- * @param {?} keyCode
- * @return {?}
- */
- function (rowElement, keyCode) {
- /** @type {?} */
- var nextRowElement = this.getPrevNextRow(rowElement, keyCode);
- if (nextRowElement)
- nextRowElement.focus();
- };
- /**
- * @param {?} rowElement
- * @param {?} keyCode
- * @return {?}
- */
- DataTableSelectionComponent.prototype.getPrevNextRow = /**
- * @param {?} rowElement
- * @param {?} keyCode
- * @return {?}
- */
- function (rowElement, keyCode) {
- /** @type {?} */
- var parentElement = rowElement.parentElement;
- if (parentElement) {
- /** @type {?} */
- var focusElement = void 0;
- if (keyCode === Keys.up) {
- focusElement = parentElement.previousElementSibling;
- }
- else if (keyCode === Keys.down) {
- focusElement = parentElement.nextElementSibling;
- }
- if (focusElement && focusElement.children.length) {
- return focusElement.children[0];
- }
- }
- };
- /**
- * @param {?} cellElement
- * @param {?} rowElement
- * @param {?} keyCode
- * @param {?} cellIndex
- * @return {?}
- */
- DataTableSelectionComponent.prototype.focusCell = /**
- * @param {?} cellElement
- * @param {?} rowElement
- * @param {?} keyCode
- * @param {?} cellIndex
- * @return {?}
- */
- function (cellElement, rowElement, keyCode, cellIndex) {
- /** @type {?} */
- var nextCellElement;
- if (keyCode === Keys.left) {
- nextCellElement = cellElement.previousElementSibling;
- }
- else if (keyCode === Keys.right) {
- nextCellElement = cellElement.nextElementSibling;
- }
- else if (keyCode === Keys.up || keyCode === Keys.down) {
- /** @type {?} */
- var nextRowElement = this.getPrevNextRow(rowElement, keyCode);
- if (nextRowElement) {
- /** @type {?} */
- var children = nextRowElement.getElementsByClassName('datatable-body-cell');
- if (children.length)
- nextCellElement = children[cellIndex];
- }
- }
- if (nextCellElement)
- nextCellElement.focus();
- };
- /**
- * @param {?} row
- * @return {?}
- */
- DataTableSelectionComponent.prototype.getRowSelected = /**
- * @param {?} row
- * @return {?}
- */
- function (row) {
- return this.getRowSelectedIdx(row, this.selected) > -1;
- };
- /**
- * @param {?} row
- * @param {?} selected
- * @return {?}
- */
- DataTableSelectionComponent.prototype.getRowSelectedIdx = /**
- * @param {?} row
- * @param {?} selected
- * @return {?}
- */
- function (row, selected) {
- var _this = this;
- if (!selected || !selected.length)
- return -1;
- /** @type {?} */
- var rowId = this.rowIdentity(row);
- return selected.findIndex((/**
- * @param {?} r
- * @return {?}
- */
- function (r) {
- /** @type {?} */
- var id = _this.rowIdentity(r);
- return id === rowId;
- }));
- };
- DataTableSelectionComponent.decorators = [
- { type: Component, args: [{
- selector: 'datatable-selection',
- template: "\n <ng-content></ng-content>\n ",
- changeDetection: ChangeDetectionStrategy.OnPush
- }] }
- ];
- DataTableSelectionComponent.propDecorators = {
- rows: [{ type: Input }],
- selected: [{ type: Input }],
- selectEnabled: [{ type: Input }],
- selectionType: [{ type: Input }],
- rowIdentity: [{ type: Input }],
- selectCheck: [{ type: Input }],
- activate: [{ type: Output }],
- select: [{ type: Output }]
- };
- return DataTableSelectionComponent;
- }());
- export { DataTableSelectionComponent };
- if (false) {
- /** @type {?} */
- DataTableSelectionComponent.prototype.rows;
- /** @type {?} */
- DataTableSelectionComponent.prototype.selected;
- /** @type {?} */
- DataTableSelectionComponent.prototype.selectEnabled;
- /** @type {?} */
- DataTableSelectionComponent.prototype.selectionType;
- /** @type {?} */
- DataTableSelectionComponent.prototype.rowIdentity;
- /** @type {?} */
- DataTableSelectionComponent.prototype.selectCheck;
- /** @type {?} */
- DataTableSelectionComponent.prototype.activate;
- /** @type {?} */
- DataTableSelectionComponent.prototype.select;
- /** @type {?} */
- DataTableSelectionComponent.prototype.prevIndex;
- }
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/body/selection.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';\nimport { SelectionType } from '../../types/selection.type';\nimport { selectRowsBetween, selectRows } from '../../utils/selection';\nimport { Keys } from '../../utils/keys';\n\nexport interface Model {\n  type: string;\n  event: MouseEvent | KeyboardEvent;\n  row: any;\n  rowElement: any;\n  cellElement: any;\n  cellIndex: number;\n}\n\n@Component({\n  selector: 'datatable-selection',\n  template: `\n    <ng-content></ng-content>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataTableSelectionComponent {\n  @Input() rows: any[];\n  @Input() selected: any[];\n  @Input() selectEnabled: boolean;\n  @Input() selectionType: SelectionType;\n  @Input() rowIdentity: any;\n  @Input() selectCheck: any;\n\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n  @Output() select: EventEmitter<any> = new EventEmitter();\n\n  prevIndex: number;\n\n  selectRow(event: KeyboardEvent | MouseEvent, index: number, row: any): void {\n    if (!this.selectEnabled) return;\n\n    const chkbox = this.selectionType === SelectionType.checkbox;\n    const multi = this.selectionType === SelectionType.multi;\n    const multiClick = this.selectionType === SelectionType.multiClick;\n    let selected: any[] = [];\n\n    if (multi || chkbox || multiClick) {\n      if (event.shiftKey) {\n        selected = selectRowsBetween([], this.rows, index, this.prevIndex, this.getRowSelectedIdx.bind(this));\n      } else if (event.ctrlKey || event.metaKey || multiClick || chkbox) {\n        selected = selectRows([...this.selected], row, this.getRowSelectedIdx.bind(this));\n      } else {\n        selected = selectRows([], row, this.getRowSelectedIdx.bind(this));\n      }\n    } else {\n      selected = selectRows([], row, this.getRowSelectedIdx.bind(this));\n    }\n\n    if (typeof this.selectCheck === 'function') {\n      selected = selected.filter(this.selectCheck.bind(this));\n    }\n\n    this.selected.splice(0, this.selected.length);\n    this.selected.push(...selected);\n\n    this.prevIndex = index;\n\n    this.select.emit({\n      selected\n    });\n  }\n\n  onActivate(model: Model, index: number): void {\n    const { type, event, row } = model;\n    const chkbox = this.selectionType === SelectionType.checkbox;\n    const select = (!chkbox && (type === 'click' || type === 'dblclick')) || (chkbox && type === 'checkbox');\n\n    if (select) {\n      this.selectRow(event, index, row);\n    } else if (type === 'keydown') {\n      if ((<KeyboardEvent>event).keyCode === Keys.return) {\n        this.selectRow(event, index, row);\n      } else {\n        this.onKeyboardFocus(model);\n      }\n    }\n    this.activate.emit(model);\n  }\n\n  onKeyboardFocus(model: Model): void {\n    const { keyCode } = <KeyboardEvent>model.event;\n    const shouldFocus = keyCode === Keys.up || keyCode === Keys.down || keyCode === Keys.right || keyCode === Keys.left;\n\n    if (shouldFocus) {\n      const isCellSelection = this.selectionType === SelectionType.cell;\n\n      if (!model.cellElement || !isCellSelection) {\n        this.focusRow(model.rowElement, keyCode);\n      } else if (isCellSelection) {\n        this.focusCell(model.cellElement, model.rowElement, keyCode, model.cellIndex);\n      }\n    }\n  }\n\n  focusRow(rowElement: any, keyCode: number): void {\n    const nextRowElement = this.getPrevNextRow(rowElement, keyCode);\n    if (nextRowElement) nextRowElement.focus();\n  }\n\n  getPrevNextRow(rowElement: any, keyCode: number): any {\n    const parentElement = rowElement.parentElement;\n\n    if (parentElement) {\n      let focusElement: HTMLElement;\n      if (keyCode === Keys.up) {\n        focusElement = parentElement.previousElementSibling;\n      } else if (keyCode === Keys.down) {\n        focusElement = parentElement.nextElementSibling;\n      }\n\n      if (focusElement && focusElement.children.length) {\n        return focusElement.children[0];\n      }\n    }\n  }\n\n  focusCell(cellElement: any, rowElement: any, keyCode: number, cellIndex: number): void {\n    let nextCellElement: HTMLElement;\n\n    if (keyCode === Keys.left) {\n      nextCellElement = cellElement.previousElementSibling;\n    } else if (keyCode === Keys.right) {\n      nextCellElement = cellElement.nextElementSibling;\n    } else if (keyCode === Keys.up || keyCode === Keys.down) {\n      const nextRowElement = this.getPrevNextRow(rowElement, keyCode);\n      if (nextRowElement) {\n        const children = nextRowElement.getElementsByClassName('datatable-body-cell');\n        if (children.length) nextCellElement = children[cellIndex];\n      }\n    }\n\n    if (nextCellElement) nextCellElement.focus();\n  }\n\n  getRowSelected(row: any): boolean {\n    return this.getRowSelectedIdx(row, this.selected) > -1;\n  }\n\n  getRowSelectedIdx(row: any, selected: any[]): number {\n    if (!selected || !selected.length) return -1;\n\n    const rowId = this.rowIdentity(row);\n    return selected.findIndex(r => {\n      const id = this.rowIdentity(r);\n      return id === rowId;\n    });\n  }\n}\n"]}
|