body-row.component.js 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  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, HostBinding, ElementRef, Output, KeyValueDiffers, EventEmitter, HostListener, ChangeDetectionStrategy, ChangeDetectorRef, SkipSelf } from '@angular/core';
  7. import { columnsByPin, columnGroupWidths, columnsByPinArr } from '../../utils/column';
  8. import { Keys } from '../../utils/keys';
  9. import { ScrollbarHelper } from '../../services/scrollbar-helper.service';
  10. import { translateXY } from '../../utils/translate';
  11. var DataTableBodyRowComponent = /** @class */ (function () {
  12. function DataTableBodyRowComponent(differs, scrollbarHelper, cd, element) {
  13. this.differs = differs;
  14. this.scrollbarHelper = scrollbarHelper;
  15. this.cd = cd;
  16. this.treeStatus = 'collapsed';
  17. this.activate = new EventEmitter();
  18. this.treeAction = new EventEmitter();
  19. this._groupStyles = {
  20. left: {},
  21. center: {},
  22. right: {}
  23. };
  24. this._element = element.nativeElement;
  25. this._rowDiffer = differs.find({}).create();
  26. }
  27. Object.defineProperty(DataTableBodyRowComponent.prototype, "columns", {
  28. get: /**
  29. * @return {?}
  30. */
  31. function () {
  32. return this._columns;
  33. },
  34. set: /**
  35. * @param {?} val
  36. * @return {?}
  37. */
  38. function (val) {
  39. this._columns = val;
  40. this.recalculateColumns(val);
  41. this.buildStylesByGroup();
  42. },
  43. enumerable: true,
  44. configurable: true
  45. });
  46. Object.defineProperty(DataTableBodyRowComponent.prototype, "innerWidth", {
  47. get: /**
  48. * @return {?}
  49. */
  50. function () {
  51. return this._innerWidth;
  52. },
  53. set: /**
  54. * @param {?} val
  55. * @return {?}
  56. */
  57. function (val) {
  58. if (this._columns) {
  59. /** @type {?} */
  60. var colByPin = columnsByPin(this._columns);
  61. this._columnGroupWidths = columnGroupWidths(colByPin, this._columns);
  62. }
  63. this._innerWidth = val;
  64. this.recalculateColumns();
  65. this.buildStylesByGroup();
  66. },
  67. enumerable: true,
  68. configurable: true
  69. });
  70. Object.defineProperty(DataTableBodyRowComponent.prototype, "offsetX", {
  71. get: /**
  72. * @return {?}
  73. */
  74. function () {
  75. return this._offsetX;
  76. },
  77. set: /**
  78. * @param {?} val
  79. * @return {?}
  80. */
  81. function (val) {
  82. this._offsetX = val;
  83. this.buildStylesByGroup();
  84. },
  85. enumerable: true,
  86. configurable: true
  87. });
  88. Object.defineProperty(DataTableBodyRowComponent.prototype, "cssClass", {
  89. get: /**
  90. * @return {?}
  91. */
  92. function () {
  93. var e_1, _a;
  94. /** @type {?} */
  95. var cls = 'datatable-body-row';
  96. if (this.isSelected) {
  97. cls += ' active';
  98. }
  99. if (this.rowIndex % 2 !== 0) {
  100. cls += ' datatable-row-odd';
  101. }
  102. if (this.rowIndex % 2 === 0) {
  103. cls += ' datatable-row-even';
  104. }
  105. if (this.rowClass) {
  106. /** @type {?} */
  107. var res = this.rowClass(this.row);
  108. if (typeof res === 'string') {
  109. cls += " " + res;
  110. }
  111. else if (typeof res === 'object') {
  112. /** @type {?} */
  113. var keys = Object.keys(res);
  114. try {
  115. for (var keys_1 = tslib_1.__values(keys), keys_1_1 = keys_1.next(); !keys_1_1.done; keys_1_1 = keys_1.next()) {
  116. var k = keys_1_1.value;
  117. if (res[k] === true) {
  118. cls += " " + k;
  119. }
  120. }
  121. }
  122. catch (e_1_1) { e_1 = { error: e_1_1 }; }
  123. finally {
  124. try {
  125. if (keys_1_1 && !keys_1_1.done && (_a = keys_1.return)) _a.call(keys_1);
  126. }
  127. finally { if (e_1) throw e_1.error; }
  128. }
  129. }
  130. }
  131. return cls;
  132. },
  133. enumerable: true,
  134. configurable: true
  135. });
  136. Object.defineProperty(DataTableBodyRowComponent.prototype, "columnsTotalWidths", {
  137. get: /**
  138. * @return {?}
  139. */
  140. function () {
  141. return this._columnGroupWidths.total;
  142. },
  143. enumerable: true,
  144. configurable: true
  145. });
  146. /**
  147. * @return {?}
  148. */
  149. DataTableBodyRowComponent.prototype.ngDoCheck = /**
  150. * @return {?}
  151. */
  152. function () {
  153. if (this._rowDiffer.diff(this.row)) {
  154. this.cd.markForCheck();
  155. }
  156. };
  157. /**
  158. * @param {?} index
  159. * @param {?} colGroup
  160. * @return {?}
  161. */
  162. DataTableBodyRowComponent.prototype.trackByGroups = /**
  163. * @param {?} index
  164. * @param {?} colGroup
  165. * @return {?}
  166. */
  167. function (index, colGroup) {
  168. return colGroup.type;
  169. };
  170. /**
  171. * @param {?} index
  172. * @param {?} column
  173. * @return {?}
  174. */
  175. DataTableBodyRowComponent.prototype.columnTrackingFn = /**
  176. * @param {?} index
  177. * @param {?} column
  178. * @return {?}
  179. */
  180. function (index, column) {
  181. return column.$$id;
  182. };
  183. /**
  184. * @return {?}
  185. */
  186. DataTableBodyRowComponent.prototype.buildStylesByGroup = /**
  187. * @return {?}
  188. */
  189. function () {
  190. this._groupStyles.left = this.calcStylesByGroup('left');
  191. this._groupStyles.center = this.calcStylesByGroup('center');
  192. this._groupStyles.right = this.calcStylesByGroup('right');
  193. this.cd.markForCheck();
  194. };
  195. /**
  196. * @param {?} group
  197. * @return {?}
  198. */
  199. DataTableBodyRowComponent.prototype.calcStylesByGroup = /**
  200. * @param {?} group
  201. * @return {?}
  202. */
  203. function (group) {
  204. /** @type {?} */
  205. var widths = this._columnGroupWidths;
  206. /** @type {?} */
  207. var offsetX = this.offsetX;
  208. /** @type {?} */
  209. var styles = {
  210. width: widths[group] + "px"
  211. };
  212. if (group === 'left') {
  213. translateXY(styles, offsetX, 0);
  214. }
  215. else if (group === 'right') {
  216. /** @type {?} */
  217. var bodyWidth = parseInt(this.innerWidth + '', 0);
  218. /** @type {?} */
  219. var totalDiff = widths.total - bodyWidth;
  220. /** @type {?} */
  221. var offsetDiff = totalDiff - offsetX;
  222. /** @type {?} */
  223. var offset = (offsetDiff + this.scrollbarHelper.width) * -1;
  224. translateXY(styles, offset, 0);
  225. }
  226. return styles;
  227. };
  228. /**
  229. * @param {?} event
  230. * @param {?} index
  231. * @return {?}
  232. */
  233. DataTableBodyRowComponent.prototype.onActivate = /**
  234. * @param {?} event
  235. * @param {?} index
  236. * @return {?}
  237. */
  238. function (event, index) {
  239. event.cellIndex = index;
  240. event.rowElement = this._element;
  241. this.activate.emit(event);
  242. };
  243. /**
  244. * @param {?} event
  245. * @return {?}
  246. */
  247. DataTableBodyRowComponent.prototype.onKeyDown = /**
  248. * @param {?} event
  249. * @return {?}
  250. */
  251. function (event) {
  252. /** @type {?} */
  253. var keyCode = event.keyCode;
  254. /** @type {?} */
  255. var isTargetRow = event.target === this._element;
  256. /** @type {?} */
  257. var isAction = keyCode === Keys.return ||
  258. keyCode === Keys.down ||
  259. keyCode === Keys.up ||
  260. keyCode === Keys.left ||
  261. keyCode === Keys.right;
  262. if (isAction && isTargetRow) {
  263. event.preventDefault();
  264. event.stopPropagation();
  265. this.activate.emit({
  266. type: 'keydown',
  267. event: event,
  268. row: this.row,
  269. rowElement: this._element
  270. });
  271. }
  272. };
  273. /**
  274. * @param {?} event
  275. * @return {?}
  276. */
  277. DataTableBodyRowComponent.prototype.onMouseenter = /**
  278. * @param {?} event
  279. * @return {?}
  280. */
  281. function (event) {
  282. this.activate.emit({
  283. type: 'mouseenter',
  284. event: event,
  285. row: this.row,
  286. rowElement: this._element
  287. });
  288. };
  289. /**
  290. * @param {?=} val
  291. * @return {?}
  292. */
  293. DataTableBodyRowComponent.prototype.recalculateColumns = /**
  294. * @param {?=} val
  295. * @return {?}
  296. */
  297. function (val) {
  298. if (val === void 0) { val = this.columns; }
  299. this._columns = val;
  300. /** @type {?} */
  301. var colsByPin = columnsByPin(this._columns);
  302. this._columnsByPin = columnsByPinArr(this._columns);
  303. this._columnGroupWidths = columnGroupWidths(colsByPin, this._columns);
  304. };
  305. /**
  306. * @return {?}
  307. */
  308. DataTableBodyRowComponent.prototype.onTreeAction = /**
  309. * @return {?}
  310. */
  311. function () {
  312. this.treeAction.emit();
  313. };
  314. DataTableBodyRowComponent.decorators = [
  315. { type: Component, args: [{
  316. selector: 'datatable-body-row',
  317. changeDetection: ChangeDetectionStrategy.OnPush,
  318. template: "\n <div\n *ngFor=\"let colGroup of _columnsByPin; let i = index; trackBy: trackByGroups\"\n class=\"datatable-row-{{ colGroup.type }} datatable-row-group\"\n [ngStyle]=\"_groupStyles[colGroup.type]\"\n >\n <datatable-body-cell\n *ngFor=\"let column of colGroup.columns; let ii = index; trackBy: columnTrackingFn\"\n tabindex=\"-1\"\n [row]=\"row\"\n [group]=\"group\"\n [expanded]=\"expanded\"\n [isSelected]=\"isSelected\"\n [rowIndex]=\"rowIndex\"\n [column]=\"column\"\n [rowHeight]=\"rowHeight\"\n [displayCheck]=\"displayCheck\"\n [treeStatus]=\"treeStatus\"\n (activate)=\"onActivate($event, ii)\"\n (treeAction)=\"onTreeAction()\"\n >\n </datatable-body-cell>\n </div>\n "
  319. }] }
  320. ];
  321. /** @nocollapse */
  322. DataTableBodyRowComponent.ctorParameters = function () { return [
  323. { type: KeyValueDiffers },
  324. { type: ScrollbarHelper, decorators: [{ type: SkipSelf }] },
  325. { type: ChangeDetectorRef },
  326. { type: ElementRef }
  327. ]; };
  328. DataTableBodyRowComponent.propDecorators = {
  329. columns: [{ type: Input }],
  330. innerWidth: [{ type: Input }],
  331. expanded: [{ type: Input }],
  332. rowClass: [{ type: Input }],
  333. row: [{ type: Input }],
  334. group: [{ type: Input }],
  335. isSelected: [{ type: Input }],
  336. rowIndex: [{ type: Input }],
  337. displayCheck: [{ type: Input }],
  338. treeStatus: [{ type: Input }],
  339. offsetX: [{ type: Input }],
  340. cssClass: [{ type: HostBinding, args: ['class',] }],
  341. rowHeight: [{ type: HostBinding, args: ['style.height.px',] }, { type: Input }],
  342. columnsTotalWidths: [{ type: HostBinding, args: ['style.width.px',] }],
  343. activate: [{ type: Output }],
  344. treeAction: [{ type: Output }],
  345. onKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }],
  346. onMouseenter: [{ type: HostListener, args: ['mouseenter', ['$event'],] }]
  347. };
  348. return DataTableBodyRowComponent;
  349. }());
  350. export { DataTableBodyRowComponent };
  351. if (false) {
  352. /** @type {?} */
  353. DataTableBodyRowComponent.prototype.expanded;
  354. /** @type {?} */
  355. DataTableBodyRowComponent.prototype.rowClass;
  356. /** @type {?} */
  357. DataTableBodyRowComponent.prototype.row;
  358. /** @type {?} */
  359. DataTableBodyRowComponent.prototype.group;
  360. /** @type {?} */
  361. DataTableBodyRowComponent.prototype.isSelected;
  362. /** @type {?} */
  363. DataTableBodyRowComponent.prototype.rowIndex;
  364. /** @type {?} */
  365. DataTableBodyRowComponent.prototype.displayCheck;
  366. /** @type {?} */
  367. DataTableBodyRowComponent.prototype.treeStatus;
  368. /** @type {?} */
  369. DataTableBodyRowComponent.prototype.rowHeight;
  370. /** @type {?} */
  371. DataTableBodyRowComponent.prototype.activate;
  372. /** @type {?} */
  373. DataTableBodyRowComponent.prototype.treeAction;
  374. /** @type {?} */
  375. DataTableBodyRowComponent.prototype._element;
  376. /** @type {?} */
  377. DataTableBodyRowComponent.prototype._columnGroupWidths;
  378. /** @type {?} */
  379. DataTableBodyRowComponent.prototype._columnsByPin;
  380. /** @type {?} */
  381. DataTableBodyRowComponent.prototype._offsetX;
  382. /** @type {?} */
  383. DataTableBodyRowComponent.prototype._columns;
  384. /** @type {?} */
  385. DataTableBodyRowComponent.prototype._innerWidth;
  386. /** @type {?} */
  387. DataTableBodyRowComponent.prototype._groupStyles;
  388. /**
  389. * @type {?}
  390. * @private
  391. */
  392. DataTableBodyRowComponent.prototype._rowDiffer;
  393. /**
  394. * @type {?}
  395. * @private
  396. */
  397. DataTableBodyRowComponent.prototype.differs;
  398. /**
  399. * @type {?}
  400. * @private
  401. */
  402. DataTableBodyRowComponent.prototype.scrollbarHelper;
  403. /**
  404. * @type {?}
  405. * @private
  406. */
  407. DataTableBodyRowComponent.prototype.cd;
  408. }
  409. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"body-row.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/body/body-row.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostBinding,\n  ElementRef,\n  Output,\n  KeyValueDiffers,\n  KeyValueDiffer,\n  EventEmitter,\n  HostListener,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  DoCheck,\n  SkipSelf\n} from '@angular/core';\n\nimport { TreeStatus } from './body-cell.component';\nimport { columnsByPin, columnGroupWidths, columnsByPinArr } from '../../utils/column';\nimport { Keys } from '../../utils/keys';\nimport { ScrollbarHelper } from '../../services/scrollbar-helper.service';\nimport { translateXY } from '../../utils/translate';\n\n@Component({\n  selector: 'datatable-body-row',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: `\n    <div\n      *ngFor=\"let colGroup of _columnsByPin; let i = index; trackBy: trackByGroups\"\n      class=\"datatable-row-{{ colGroup.type }} datatable-row-group\"\n      [ngStyle]=\"_groupStyles[colGroup.type]\"\n    >\n      <datatable-body-cell\n        *ngFor=\"let column of colGroup.columns; let ii = index; trackBy: columnTrackingFn\"\n        tabindex=\"-1\"\n        [row]=\"row\"\n        [group]=\"group\"\n        [expanded]=\"expanded\"\n        [isSelected]=\"isSelected\"\n        [rowIndex]=\"rowIndex\"\n        [column]=\"column\"\n        [rowHeight]=\"rowHeight\"\n        [displayCheck]=\"displayCheck\"\n        [treeStatus]=\"treeStatus\"\n        (activate)=\"onActivate($event, ii)\"\n        (treeAction)=\"onTreeAction()\"\n      >\n      </datatable-body-cell>\n    </div>\n  `\n})\nexport class DataTableBodyRowComponent implements DoCheck {\n  @Input() set columns(val: any[]) {\n    this._columns = val;\n    this.recalculateColumns(val);\n    this.buildStylesByGroup();\n  }\n\n  get columns(): any[] {\n    return this._columns;\n  }\n\n  @Input() set innerWidth(val: number) {\n    if (this._columns) {\n      const colByPin = columnsByPin(this._columns);\n      this._columnGroupWidths = columnGroupWidths(colByPin, this._columns);\n    }\n\n    this._innerWidth = val;\n    this.recalculateColumns();\n    this.buildStylesByGroup();\n  }\n\n  get innerWidth(): number {\n    return this._innerWidth;\n  }\n\n  @Input() expanded: boolean;\n  @Input() rowClass: any;\n  @Input() row: any;\n  @Input() group: any;\n  @Input() isSelected: boolean;\n  @Input() rowIndex: number;\n  @Input() displayCheck: any;\n  @Input() treeStatus: TreeStatus = 'collapsed';\n\n  @Input()\n  set offsetX(val: number) {\n    this._offsetX = val;\n    this.buildStylesByGroup();\n  }\n  get offsetX() {\n    return this._offsetX;\n  }\n\n  @HostBinding('class')\n  get cssClass() {\n    let cls = 'datatable-body-row';\n    if (this.isSelected) {\n      cls += ' active';\n    }\n    if (this.rowIndex % 2 !== 0) {\n      cls += ' datatable-row-odd';\n    }\n    if (this.rowIndex % 2 === 0) {\n      cls += ' datatable-row-even';\n    }\n\n    if (this.rowClass) {\n      const res = this.rowClass(this.row);\n      if (typeof res === 'string') {\n        cls += ` ${res}`;\n      } else if (typeof res === 'object') {\n        const keys = Object.keys(res);\n        for (const k of keys) {\n          if (res[k] === true) {\n            cls += ` ${k}`;\n          }\n        }\n      }\n    }\n\n    return cls;\n  }\n\n  @HostBinding('style.height.px')\n  @Input()\n  rowHeight: number;\n\n  @HostBinding('style.width.px')\n  get columnsTotalWidths(): string {\n    return this._columnGroupWidths.total;\n  }\n\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n  @Output() treeAction: EventEmitter<any> = new EventEmitter();\n\n  _element: any;\n  _columnGroupWidths: any;\n  _columnsByPin: any;\n  _offsetX: number;\n  _columns: any[];\n  _innerWidth: number;\n  _groupStyles: { [prop: string]: {} } = {\n    left: {},\n    center: {},\n    right: {}\n  };\n\n  private _rowDiffer: KeyValueDiffer<{}, {}>;\n\n  constructor(\n    private differs: KeyValueDiffers,\n    @SkipSelf() private scrollbarHelper: ScrollbarHelper,\n    private cd: ChangeDetectorRef,\n    element: ElementRef\n  ) {\n    this._element = element.nativeElement;\n    this._rowDiffer = differs.find({}).create();\n  }\n\n  ngDoCheck(): void {\n    if (this._rowDiffer.diff(this.row)) {\n      this.cd.markForCheck();\n    }\n  }\n\n  trackByGroups(index: number, colGroup: any): any {\n    return colGroup.type;\n  }\n\n  columnTrackingFn(index: number, column: any): any {\n    return column.$$id;\n  }\n\n  buildStylesByGroup() {\n    this._groupStyles.left = this.calcStylesByGroup('left');\n    this._groupStyles.center = this.calcStylesByGroup('center');\n    this._groupStyles.right = this.calcStylesByGroup('right');\n    this.cd.markForCheck();\n  }\n\n  calcStylesByGroup(group: string) {\n    const widths = this._columnGroupWidths;\n    const offsetX = this.offsetX;\n\n    const styles = {\n      width: `${widths[group]}px`\n    };\n\n    if (group === 'left') {\n      translateXY(styles, offsetX, 0);\n    } else if (group === 'right') {\n      const bodyWidth = parseInt(this.innerWidth + '', 0);\n      const totalDiff = widths.total - bodyWidth;\n      const offsetDiff = totalDiff - offsetX;\n      const offset = (offsetDiff + this.scrollbarHelper.width) * -1;\n      translateXY(styles, offset, 0);\n    }\n\n    return styles;\n  }\n\n  onActivate(event: any, index: number): void {\n    event.cellIndex = index;\n    event.rowElement = this._element;\n    this.activate.emit(event);\n  }\n\n  @HostListener('keydown', ['$event'])\n  onKeyDown(event: KeyboardEvent): void {\n    const keyCode = event.keyCode;\n    const isTargetRow = event.target === this._element;\n\n    const isAction =\n      keyCode === Keys.return ||\n      keyCode === Keys.down ||\n      keyCode === Keys.up ||\n      keyCode === Keys.left ||\n      keyCode === Keys.right;\n\n    if (isAction && isTargetRow) {\n      event.preventDefault();\n      event.stopPropagation();\n\n      this.activate.emit({\n        type: 'keydown',\n        event,\n        row: this.row,\n        rowElement: this._element\n      });\n    }\n  }\n\n  @HostListener('mouseenter', ['$event'])\n  onMouseenter(event: any): void {\n    this.activate.emit({\n      type: 'mouseenter',\n      event,\n      row: this.row,\n      rowElement: this._element\n    });\n  }\n\n  recalculateColumns(val: any[] = this.columns): void {\n    this._columns = val;\n    const colsByPin = columnsByPin(this._columns);\n    this._columnsByPin = columnsByPinArr(this._columns);\n    this._columnGroupWidths = columnGroupWidths(colsByPin, this._columns);\n  }\n\n  onTreeAction() {\n    this.treeAction.emit();\n  }\n}\n"]}