selection.component.js 22 KB

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