selection.component.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
  6. import { SelectionType } from '../../types/selection.type';
  7. import { selectRowsBetween, selectRows } from '../../utils/selection';
  8. import { Keys } from '../../utils/keys';
  9. /**
  10. * @record
  11. */
  12. export function Model() { }
  13. if (false) {
  14. /** @type {?} */
  15. Model.prototype.type;
  16. /** @type {?} */
  17. Model.prototype.event;
  18. /** @type {?} */
  19. Model.prototype.row;
  20. /** @type {?} */
  21. Model.prototype.rowElement;
  22. /** @type {?} */
  23. Model.prototype.cellElement;
  24. /** @type {?} */
  25. Model.prototype.cellIndex;
  26. }
  27. export class DataTableSelectionComponent {
  28. constructor() {
  29. this.activate = new EventEmitter();
  30. this.select = new EventEmitter();
  31. }
  32. /**
  33. * @param {?} event
  34. * @param {?} index
  35. * @param {?} row
  36. * @return {?}
  37. */
  38. selectRow(event, index, row) {
  39. if (!this.selectEnabled)
  40. return;
  41. /** @type {?} */
  42. const chkbox = this.selectionType === SelectionType.checkbox;
  43. /** @type {?} */
  44. const multi = this.selectionType === SelectionType.multi;
  45. /** @type {?} */
  46. const multiClick = this.selectionType === SelectionType.multiClick;
  47. /** @type {?} */
  48. let selected = [];
  49. if (multi || chkbox || multiClick) {
  50. if (event.shiftKey) {
  51. selected = selectRowsBetween([], this.rows, index, this.prevIndex, this.getRowSelectedIdx.bind(this));
  52. }
  53. else if (event.ctrlKey || event.metaKey || multiClick || chkbox) {
  54. selected = selectRows([...this.selected], row, this.getRowSelectedIdx.bind(this));
  55. }
  56. else {
  57. selected = selectRows([], row, this.getRowSelectedIdx.bind(this));
  58. }
  59. }
  60. else {
  61. selected = selectRows([], row, this.getRowSelectedIdx.bind(this));
  62. }
  63. if (typeof this.selectCheck === 'function') {
  64. selected = selected.filter(this.selectCheck.bind(this));
  65. }
  66. this.selected.splice(0, this.selected.length);
  67. this.selected.push(...selected);
  68. this.prevIndex = index;
  69. this.select.emit({
  70. selected
  71. });
  72. }
  73. /**
  74. * @param {?} model
  75. * @param {?} index
  76. * @return {?}
  77. */
  78. onActivate(model, index) {
  79. const { type, event, row } = model;
  80. /** @type {?} */
  81. const chkbox = this.selectionType === SelectionType.checkbox;
  82. /** @type {?} */
  83. const select = (!chkbox && (type === 'click' || type === 'dblclick')) || (chkbox && type === 'checkbox');
  84. if (select) {
  85. this.selectRow(event, index, row);
  86. }
  87. else if (type === 'keydown') {
  88. if (((/** @type {?} */ (event))).keyCode === Keys.return) {
  89. this.selectRow(event, index, row);
  90. }
  91. else {
  92. this.onKeyboardFocus(model);
  93. }
  94. }
  95. this.activate.emit(model);
  96. }
  97. /**
  98. * @param {?} model
  99. * @return {?}
  100. */
  101. onKeyboardFocus(model) {
  102. const { keyCode } = (/** @type {?} */ (model.event));
  103. /** @type {?} */
  104. const shouldFocus = keyCode === Keys.up || keyCode === Keys.down || keyCode === Keys.right || keyCode === Keys.left;
  105. if (shouldFocus) {
  106. /** @type {?} */
  107. const isCellSelection = this.selectionType === SelectionType.cell;
  108. if (!model.cellElement || !isCellSelection) {
  109. this.focusRow(model.rowElement, keyCode);
  110. }
  111. else if (isCellSelection) {
  112. this.focusCell(model.cellElement, model.rowElement, keyCode, model.cellIndex);
  113. }
  114. }
  115. }
  116. /**
  117. * @param {?} rowElement
  118. * @param {?} keyCode
  119. * @return {?}
  120. */
  121. focusRow(rowElement, keyCode) {
  122. /** @type {?} */
  123. const nextRowElement = this.getPrevNextRow(rowElement, keyCode);
  124. if (nextRowElement)
  125. nextRowElement.focus();
  126. }
  127. /**
  128. * @param {?} rowElement
  129. * @param {?} keyCode
  130. * @return {?}
  131. */
  132. getPrevNextRow(rowElement, keyCode) {
  133. /** @type {?} */
  134. const parentElement = rowElement.parentElement;
  135. if (parentElement) {
  136. /** @type {?} */
  137. let focusElement;
  138. if (keyCode === Keys.up) {
  139. focusElement = parentElement.previousElementSibling;
  140. }
  141. else if (keyCode === Keys.down) {
  142. focusElement = parentElement.nextElementSibling;
  143. }
  144. if (focusElement && focusElement.children.length) {
  145. return focusElement.children[0];
  146. }
  147. }
  148. }
  149. /**
  150. * @param {?} cellElement
  151. * @param {?} rowElement
  152. * @param {?} keyCode
  153. * @param {?} cellIndex
  154. * @return {?}
  155. */
  156. focusCell(cellElement, rowElement, keyCode, cellIndex) {
  157. /** @type {?} */
  158. let nextCellElement;
  159. if (keyCode === Keys.left) {
  160. nextCellElement = cellElement.previousElementSibling;
  161. }
  162. else if (keyCode === Keys.right) {
  163. nextCellElement = cellElement.nextElementSibling;
  164. }
  165. else if (keyCode === Keys.up || keyCode === Keys.down) {
  166. /** @type {?} */
  167. const nextRowElement = this.getPrevNextRow(rowElement, keyCode);
  168. if (nextRowElement) {
  169. /** @type {?} */
  170. const children = nextRowElement.getElementsByClassName('datatable-body-cell');
  171. if (children.length)
  172. nextCellElement = children[cellIndex];
  173. }
  174. }
  175. if (nextCellElement)
  176. nextCellElement.focus();
  177. }
  178. /**
  179. * @param {?} row
  180. * @return {?}
  181. */
  182. getRowSelected(row) {
  183. return this.getRowSelectedIdx(row, this.selected) > -1;
  184. }
  185. /**
  186. * @param {?} row
  187. * @param {?} selected
  188. * @return {?}
  189. */
  190. getRowSelectedIdx(row, selected) {
  191. if (!selected || !selected.length)
  192. return -1;
  193. /** @type {?} */
  194. const rowId = this.rowIdentity(row);
  195. return selected.findIndex((/**
  196. * @param {?} r
  197. * @return {?}
  198. */
  199. r => {
  200. /** @type {?} */
  201. const id = this.rowIdentity(r);
  202. return id === rowId;
  203. }));
  204. }
  205. }
  206. DataTableSelectionComponent.decorators = [
  207. { type: Component, args: [{
  208. selector: 'datatable-selection',
  209. template: `
  210. <ng-content></ng-content>
  211. `,
  212. changeDetection: ChangeDetectionStrategy.OnPush
  213. }] }
  214. ];
  215. DataTableSelectionComponent.propDecorators = {
  216. rows: [{ type: Input }],
  217. selected: [{ type: Input }],
  218. selectEnabled: [{ type: Input }],
  219. selectionType: [{ type: Input }],
  220. rowIdentity: [{ type: Input }],
  221. selectCheck: [{ type: Input }],
  222. activate: [{ type: Output }],
  223. select: [{ type: Output }]
  224. };
  225. if (false) {
  226. /** @type {?} */
  227. DataTableSelectionComponent.prototype.rows;
  228. /** @type {?} */
  229. DataTableSelectionComponent.prototype.selected;
  230. /** @type {?} */
  231. DataTableSelectionComponent.prototype.selectEnabled;
  232. /** @type {?} */
  233. DataTableSelectionComponent.prototype.selectionType;
  234. /** @type {?} */
  235. DataTableSelectionComponent.prototype.rowIdentity;
  236. /** @type {?} */
  237. DataTableSelectionComponent.prototype.selectCheck;
  238. /** @type {?} */
  239. DataTableSelectionComponent.prototype.activate;
  240. /** @type {?} */
  241. DataTableSelectionComponent.prototype.select;
  242. /** @type {?} */
  243. DataTableSelectionComponent.prototype.prevIndex;
  244. }
  245. //# 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"]}