body-row.component.js 26 KB

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