body-cell.component.js 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, Input, HostBinding, ViewChild, ChangeDetectorRef, Output, EventEmitter, HostListener, ElementRef, ViewContainerRef, ChangeDetectionStrategy } from '@angular/core';
  6. import { MouseEvent, KeyboardEvent } from '../../events';
  7. import { SortDirection } from '../../types/sort-direction.type';
  8. import { Keys } from '../../utils/keys';
  9. export class DataTableBodyCellComponent {
  10. /**
  11. * @param {?} element
  12. * @param {?} cd
  13. */
  14. constructor(element, cd) {
  15. this.cd = cd;
  16. this.activate = new EventEmitter();
  17. this.treeAction = new EventEmitter();
  18. this.isFocused = false;
  19. this.onCheckboxChangeFn = this.onCheckboxChange.bind(this);
  20. this.activateFn = this.activate.emit.bind(this.activate);
  21. this.cellContext = {
  22. onCheckboxChangeFn: this.onCheckboxChangeFn,
  23. activateFn: this.activateFn,
  24. row: this.row,
  25. group: this.group,
  26. value: this.value,
  27. column: this.column,
  28. rowHeight: this.rowHeight,
  29. isSelected: this.isSelected,
  30. rowIndex: this.rowIndex,
  31. treeStatus: this.treeStatus,
  32. onTreeAction: this.onTreeAction.bind(this)
  33. };
  34. this._element = element.nativeElement;
  35. }
  36. /**
  37. * @param {?} group
  38. * @return {?}
  39. */
  40. set group(group) {
  41. this._group = group;
  42. this.cellContext.group = group;
  43. this.checkValueUpdates();
  44. this.cd.markForCheck();
  45. }
  46. /**
  47. * @return {?}
  48. */
  49. get group() {
  50. return this._group;
  51. }
  52. /**
  53. * @param {?} val
  54. * @return {?}
  55. */
  56. set rowHeight(val) {
  57. this._rowHeight = val;
  58. this.cellContext.rowHeight = val;
  59. this.checkValueUpdates();
  60. this.cd.markForCheck();
  61. }
  62. /**
  63. * @return {?}
  64. */
  65. get rowHeight() {
  66. return this._rowHeight;
  67. }
  68. /**
  69. * @param {?} val
  70. * @return {?}
  71. */
  72. set isSelected(val) {
  73. this._isSelected = val;
  74. this.cellContext.isSelected = val;
  75. this.cd.markForCheck();
  76. }
  77. /**
  78. * @return {?}
  79. */
  80. get isSelected() {
  81. return this._isSelected;
  82. }
  83. /**
  84. * @param {?} val
  85. * @return {?}
  86. */
  87. set expanded(val) {
  88. this._expanded = val;
  89. this.cellContext.expanded = val;
  90. this.cd.markForCheck();
  91. }
  92. /**
  93. * @return {?}
  94. */
  95. get expanded() {
  96. return this._expanded;
  97. }
  98. /**
  99. * @param {?} val
  100. * @return {?}
  101. */
  102. set rowIndex(val) {
  103. this._rowIndex = val;
  104. this.cellContext.rowIndex = val;
  105. this.checkValueUpdates();
  106. this.cd.markForCheck();
  107. }
  108. /**
  109. * @return {?}
  110. */
  111. get rowIndex() {
  112. return this._rowIndex;
  113. }
  114. /**
  115. * @param {?} column
  116. * @return {?}
  117. */
  118. set column(column) {
  119. this._column = column;
  120. this.cellContext.column = column;
  121. this.checkValueUpdates();
  122. this.cd.markForCheck();
  123. }
  124. /**
  125. * @return {?}
  126. */
  127. get column() {
  128. return this._column;
  129. }
  130. /**
  131. * @param {?} row
  132. * @return {?}
  133. */
  134. set row(row) {
  135. this._row = row;
  136. this.cellContext.row = row;
  137. this.checkValueUpdates();
  138. this.cd.markForCheck();
  139. }
  140. /**
  141. * @return {?}
  142. */
  143. get row() {
  144. return this._row;
  145. }
  146. /**
  147. * @param {?} val
  148. * @return {?}
  149. */
  150. set sorts(val) {
  151. this._sorts = val;
  152. this.calcSortDir = this.calcSortDir(val);
  153. }
  154. /**
  155. * @return {?}
  156. */
  157. get sorts() {
  158. return this._sorts;
  159. }
  160. /**
  161. * @param {?} status
  162. * @return {?}
  163. */
  164. set treeStatus(status) {
  165. if (status !== 'collapsed' && status !== 'expanded' && status !== 'loading' && status !== 'disabled') {
  166. this._treeStatus = 'collapsed';
  167. }
  168. else {
  169. this._treeStatus = status;
  170. }
  171. this.cellContext.treeStatus = this._treeStatus;
  172. this.checkValueUpdates();
  173. this.cd.markForCheck();
  174. }
  175. /**
  176. * @return {?}
  177. */
  178. get treeStatus() {
  179. return this._treeStatus;
  180. }
  181. /**
  182. * @return {?}
  183. */
  184. get columnCssClasses() {
  185. /** @type {?} */
  186. let cls = 'datatable-body-cell';
  187. if (this.column.cellClass) {
  188. if (typeof this.column.cellClass === 'string') {
  189. cls += ' ' + this.column.cellClass;
  190. }
  191. else if (typeof this.column.cellClass === 'function') {
  192. /** @type {?} */
  193. const res = this.column.cellClass({
  194. row: this.row,
  195. group: this.group,
  196. column: this.column,
  197. value: this.value,
  198. rowHeight: this.rowHeight
  199. });
  200. if (typeof res === 'string') {
  201. cls += res;
  202. }
  203. else if (typeof res === 'object') {
  204. /** @type {?} */
  205. const keys = Object.keys(res);
  206. for (const k of keys) {
  207. if (res[k] === true) {
  208. cls += ` ${k}`;
  209. }
  210. }
  211. }
  212. }
  213. }
  214. if (!this.sortDir) {
  215. cls += ' sort-active';
  216. }
  217. if (this.isFocused) {
  218. cls += ' active';
  219. }
  220. if (this.sortDir === SortDirection.asc) {
  221. cls += ' sort-asc';
  222. }
  223. if (this.sortDir === SortDirection.desc) {
  224. cls += ' sort-desc';
  225. }
  226. return cls;
  227. }
  228. /**
  229. * @return {?}
  230. */
  231. get width() {
  232. return this.column.width;
  233. }
  234. /**
  235. * @return {?}
  236. */
  237. get minWidth() {
  238. return this.column.minWidth;
  239. }
  240. /**
  241. * @return {?}
  242. */
  243. get maxWidth() {
  244. return this.column.maxWidth;
  245. }
  246. /**
  247. * @return {?}
  248. */
  249. get height() {
  250. /** @type {?} */
  251. const height = this.rowHeight;
  252. if (isNaN(height)) {
  253. return height;
  254. }
  255. return height + 'px';
  256. }
  257. /**
  258. * @return {?}
  259. */
  260. ngDoCheck() {
  261. this.checkValueUpdates();
  262. }
  263. /**
  264. * @return {?}
  265. */
  266. ngOnDestroy() {
  267. if (this.cellTemplate) {
  268. this.cellTemplate.clear();
  269. }
  270. }
  271. /**
  272. * @return {?}
  273. */
  274. checkValueUpdates() {
  275. /** @type {?} */
  276. let value = '';
  277. if (!this.row || !this.column) {
  278. value = '';
  279. }
  280. else {
  281. /** @type {?} */
  282. const val = this.column.$$valueGetter(this.row, this.column.prop);
  283. /** @type {?} */
  284. const userPipe = this.column.pipe;
  285. if (userPipe) {
  286. value = userPipe.transform(val);
  287. }
  288. else if (value !== undefined) {
  289. value = val;
  290. }
  291. }
  292. if (this.value !== value) {
  293. this.value = value;
  294. this.cellContext.value = value;
  295. this.sanitizedValue = value !== null && value !== undefined ? this.stripHtml(value) : value;
  296. this.cd.markForCheck();
  297. }
  298. }
  299. /**
  300. * @return {?}
  301. */
  302. onFocus() {
  303. this.isFocused = true;
  304. }
  305. /**
  306. * @return {?}
  307. */
  308. onBlur() {
  309. this.isFocused = false;
  310. }
  311. /**
  312. * @param {?} event
  313. * @return {?}
  314. */
  315. onClick(event) {
  316. this.activate.emit({
  317. type: 'click',
  318. event,
  319. row: this.row,
  320. group: this.group,
  321. rowHeight: this.rowHeight,
  322. column: this.column,
  323. value: this.value,
  324. cellElement: this._element
  325. });
  326. }
  327. /**
  328. * @param {?} event
  329. * @return {?}
  330. */
  331. onDblClick(event) {
  332. this.activate.emit({
  333. type: 'dblclick',
  334. event,
  335. row: this.row,
  336. group: this.group,
  337. rowHeight: this.rowHeight,
  338. column: this.column,
  339. value: this.value,
  340. cellElement: this._element
  341. });
  342. }
  343. /**
  344. * @param {?} event
  345. * @return {?}
  346. */
  347. onKeyDown(event) {
  348. /** @type {?} */
  349. const keyCode = event.keyCode;
  350. /** @type {?} */
  351. const isTargetCell = event.target === this._element;
  352. /** @type {?} */
  353. const isAction = keyCode === Keys.return ||
  354. keyCode === Keys.down ||
  355. keyCode === Keys.up ||
  356. keyCode === Keys.left ||
  357. keyCode === Keys.right;
  358. if (isAction && isTargetCell) {
  359. event.preventDefault();
  360. event.stopPropagation();
  361. this.activate.emit({
  362. type: 'keydown',
  363. event,
  364. row: this.row,
  365. group: this.group,
  366. rowHeight: this.rowHeight,
  367. column: this.column,
  368. value: this.value,
  369. cellElement: this._element
  370. });
  371. }
  372. }
  373. /**
  374. * @param {?} event
  375. * @return {?}
  376. */
  377. onCheckboxChange(event) {
  378. this.activate.emit({
  379. type: 'checkbox',
  380. event,
  381. row: this.row,
  382. group: this.group,
  383. rowHeight: this.rowHeight,
  384. column: this.column,
  385. value: this.value,
  386. cellElement: this._element,
  387. treeStatus: 'collapsed'
  388. });
  389. }
  390. /**
  391. * @param {?} sorts
  392. * @return {?}
  393. */
  394. calcSortDir(sorts) {
  395. if (!sorts) {
  396. return;
  397. }
  398. /** @type {?} */
  399. const sort = sorts.find((/**
  400. * @param {?} s
  401. * @return {?}
  402. */
  403. (s) => {
  404. return s.prop === this.column.prop;
  405. }));
  406. if (sort) {
  407. return sort.dir;
  408. }
  409. }
  410. /**
  411. * @param {?} html
  412. * @return {?}
  413. */
  414. stripHtml(html) {
  415. if (!html.replace) {
  416. return html;
  417. }
  418. return html.replace(/<\/?[^>]+(>|$)/g, '');
  419. }
  420. /**
  421. * @return {?}
  422. */
  423. onTreeAction() {
  424. this.treeAction.emit(this.row);
  425. }
  426. /**
  427. * @param {?} column
  428. * @param {?} row
  429. * @return {?}
  430. */
  431. calcLeftMargin(column, row) {
  432. /** @type {?} */
  433. const levelIndent = column.treeLevelIndent != null ? column.treeLevelIndent : 50;
  434. return column.isTreeColumn ? row.level * levelIndent : 0;
  435. }
  436. }
  437. DataTableBodyCellComponent.decorators = [
  438. { type: Component, args: [{
  439. selector: 'datatable-body-cell',
  440. changeDetection: ChangeDetectionStrategy.OnPush,
  441. template: `
  442. <div class="datatable-body-cell-label" [style.margin-left.px]="calcLeftMargin(column, row)">
  443. <label
  444. *ngIf="column.checkboxable && (!displayCheck || displayCheck(row, column, value))"
  445. class="datatable-checkbox"
  446. >
  447. <input type="checkbox" [checked]="isSelected" (click)="onCheckboxChange($event)" />
  448. </label>
  449. <ng-container *ngIf="column.isTreeColumn">
  450. <button
  451. *ngIf="!column.treeToggleTemplate"
  452. class="datatable-tree-button"
  453. [disabled]="treeStatus === 'disabled'"
  454. (click)="onTreeAction()"
  455. >
  456. <span>
  457. <i *ngIf="treeStatus === 'loading'" class="icon datatable-icon-collapse"></i>
  458. <i *ngIf="treeStatus === 'collapsed'" class="icon datatable-icon-up"></i>
  459. <i *ngIf="treeStatus === 'expanded' || treeStatus === 'disabled'" class="icon datatable-icon-down"></i>
  460. </span>
  461. </button>
  462. <ng-template
  463. *ngIf="column.treeToggleTemplate"
  464. [ngTemplateOutlet]="column.treeToggleTemplate"
  465. [ngTemplateOutletContext]="{ cellContext: cellContext }"
  466. >
  467. </ng-template>
  468. </ng-container>
  469. <span *ngIf="!column.cellTemplate" [title]="sanitizedValue" [innerHTML]="value"> </span>
  470. <ng-template
  471. #cellTemplate
  472. *ngIf="column.cellTemplate"
  473. [ngTemplateOutlet]="column.cellTemplate"
  474. [ngTemplateOutletContext]="cellContext"
  475. >
  476. </ng-template>
  477. </div>
  478. `
  479. }] }
  480. ];
  481. /** @nocollapse */
  482. DataTableBodyCellComponent.ctorParameters = () => [
  483. { type: ElementRef },
  484. { type: ChangeDetectorRef }
  485. ];
  486. DataTableBodyCellComponent.propDecorators = {
  487. displayCheck: [{ type: Input }],
  488. group: [{ type: Input }],
  489. rowHeight: [{ type: Input }],
  490. isSelected: [{ type: Input }],
  491. expanded: [{ type: Input }],
  492. rowIndex: [{ type: Input }],
  493. column: [{ type: Input }],
  494. row: [{ type: Input }],
  495. sorts: [{ type: Input }],
  496. treeStatus: [{ type: Input }],
  497. activate: [{ type: Output }],
  498. treeAction: [{ type: Output }],
  499. cellTemplate: [{ type: ViewChild, args: ['cellTemplate', { read: ViewContainerRef, static: true },] }],
  500. columnCssClasses: [{ type: HostBinding, args: ['class',] }],
  501. width: [{ type: HostBinding, args: ['style.width.px',] }],
  502. minWidth: [{ type: HostBinding, args: ['style.minWidth.px',] }],
  503. maxWidth: [{ type: HostBinding, args: ['style.maxWidth.px',] }],
  504. height: [{ type: HostBinding, args: ['style.height',] }],
  505. onFocus: [{ type: HostListener, args: ['focus',] }],
  506. onBlur: [{ type: HostListener, args: ['blur',] }],
  507. onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
  508. onDblClick: [{ type: HostListener, args: ['dblclick', ['$event'],] }],
  509. onKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }]
  510. };
  511. if (false) {
  512. /** @type {?} */
  513. DataTableBodyCellComponent.prototype.displayCheck;
  514. /** @type {?} */
  515. DataTableBodyCellComponent.prototype.activate;
  516. /** @type {?} */
  517. DataTableBodyCellComponent.prototype.treeAction;
  518. /** @type {?} */
  519. DataTableBodyCellComponent.prototype.cellTemplate;
  520. /** @type {?} */
  521. DataTableBodyCellComponent.prototype.sanitizedValue;
  522. /** @type {?} */
  523. DataTableBodyCellComponent.prototype.value;
  524. /** @type {?} */
  525. DataTableBodyCellComponent.prototype.sortDir;
  526. /** @type {?} */
  527. DataTableBodyCellComponent.prototype.isFocused;
  528. /** @type {?} */
  529. DataTableBodyCellComponent.prototype.onCheckboxChangeFn;
  530. /** @type {?} */
  531. DataTableBodyCellComponent.prototype.activateFn;
  532. /** @type {?} */
  533. DataTableBodyCellComponent.prototype.cellContext;
  534. /**
  535. * @type {?}
  536. * @private
  537. */
  538. DataTableBodyCellComponent.prototype._isSelected;
  539. /**
  540. * @type {?}
  541. * @private
  542. */
  543. DataTableBodyCellComponent.prototype._sorts;
  544. /**
  545. * @type {?}
  546. * @private
  547. */
  548. DataTableBodyCellComponent.prototype._column;
  549. /**
  550. * @type {?}
  551. * @private
  552. */
  553. DataTableBodyCellComponent.prototype._row;
  554. /**
  555. * @type {?}
  556. * @private
  557. */
  558. DataTableBodyCellComponent.prototype._group;
  559. /**
  560. * @type {?}
  561. * @private
  562. */
  563. DataTableBodyCellComponent.prototype._rowHeight;
  564. /**
  565. * @type {?}
  566. * @private
  567. */
  568. DataTableBodyCellComponent.prototype._rowIndex;
  569. /**
  570. * @type {?}
  571. * @private
  572. */
  573. DataTableBodyCellComponent.prototype._expanded;
  574. /**
  575. * @type {?}
  576. * @private
  577. */
  578. DataTableBodyCellComponent.prototype._element;
  579. /**
  580. * @type {?}
  581. * @private
  582. */
  583. DataTableBodyCellComponent.prototype._treeStatus;
  584. /**
  585. * @type {?}
  586. * @private
  587. */
  588. DataTableBodyCellComponent.prototype.cd;
  589. }
  590. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"body-cell.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/body/body-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  PipeTransform,\n  HostBinding,\n  ViewChild,\n  ChangeDetectorRef,\n  Output,\n  EventEmitter,\n  HostListener,\n  ElementRef,\n  ViewContainerRef,\n  OnDestroy,\n  DoCheck,\n  ChangeDetectionStrategy\n} from '@angular/core';\n\nimport { TableColumn } from '../../types/table-column.type';\nimport { MouseEvent, KeyboardEvent } from '../../events';\nimport { SortDirection } from '../../types/sort-direction.type';\nimport { Keys } from '../../utils/keys';\n\nexport type TreeStatus = 'collapsed' | 'expanded' | 'loading' | 'disabled';\n\n@Component({\n  selector: 'datatable-body-cell',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: `\n    <div class=\"datatable-body-cell-label\" [style.margin-left.px]=\"calcLeftMargin(column, row)\">\n      <label\n        *ngIf=\"column.checkboxable && (!displayCheck || displayCheck(row, column, value))\"\n        class=\"datatable-checkbox\"\n      >\n        <input type=\"checkbox\" [checked]=\"isSelected\" (click)=\"onCheckboxChange($event)\" />\n      </label>\n      <ng-container *ngIf=\"column.isTreeColumn\">\n        <button\n          *ngIf=\"!column.treeToggleTemplate\"\n          class=\"datatable-tree-button\"\n          [disabled]=\"treeStatus === 'disabled'\"\n          (click)=\"onTreeAction()\"\n        >\n          <span>\n            <i *ngIf=\"treeStatus === 'loading'\" class=\"icon datatable-icon-collapse\"></i>\n            <i *ngIf=\"treeStatus === 'collapsed'\" class=\"icon datatable-icon-up\"></i>\n            <i *ngIf=\"treeStatus === 'expanded' || treeStatus === 'disabled'\" class=\"icon datatable-icon-down\"></i>\n          </span>\n        </button>\n        <ng-template\n          *ngIf=\"column.treeToggleTemplate\"\n          [ngTemplateOutlet]=\"column.treeToggleTemplate\"\n          [ngTemplateOutletContext]=\"{ cellContext: cellContext }\"\n        >\n        </ng-template>\n      </ng-container>\n\n      <span *ngIf=\"!column.cellTemplate\" [title]=\"sanitizedValue\" [innerHTML]=\"value\"> </span>\n      <ng-template\n        #cellTemplate\n        *ngIf=\"column.cellTemplate\"\n        [ngTemplateOutlet]=\"column.cellTemplate\"\n        [ngTemplateOutletContext]=\"cellContext\"\n      >\n      </ng-template>\n    </div>\n  `\n})\nexport class DataTableBodyCellComponent implements DoCheck, OnDestroy {\n  @Input() displayCheck: (row: any, column?: TableColumn, value?: any) => boolean;\n\n  @Input() set group(group: any) {\n    this._group = group;\n    this.cellContext.group = group;\n    this.checkValueUpdates();\n    this.cd.markForCheck();\n  }\n\n  get group() {\n    return this._group;\n  }\n\n  @Input() set rowHeight(val: number) {\n    this._rowHeight = val;\n    this.cellContext.rowHeight = val;\n    this.checkValueUpdates();\n    this.cd.markForCheck();\n  }\n\n  get rowHeight() {\n    return this._rowHeight;\n  }\n\n  @Input() set isSelected(val: boolean) {\n    this._isSelected = val;\n    this.cellContext.isSelected = val;\n    this.cd.markForCheck();\n  }\n\n  get isSelected(): boolean {\n    return this._isSelected;\n  }\n\n  @Input() set expanded(val: boolean) {\n    this._expanded = val;\n    this.cellContext.expanded = val;\n    this.cd.markForCheck();\n  }\n\n  get expanded(): boolean {\n    return this._expanded;\n  }\n\n  @Input() set rowIndex(val: number) {\n    this._rowIndex = val;\n    this.cellContext.rowIndex = val;\n    this.checkValueUpdates();\n    this.cd.markForCheck();\n  }\n\n  get rowIndex(): number {\n    return this._rowIndex;\n  }\n\n  @Input() set column(column: TableColumn) {\n    this._column = column;\n    this.cellContext.column = column;\n    this.checkValueUpdates();\n    this.cd.markForCheck();\n  }\n\n  get column(): TableColumn {\n    return this._column;\n  }\n\n  @Input() set row(row: any) {\n    this._row = row;\n    this.cellContext.row = row;\n    this.checkValueUpdates();\n    this.cd.markForCheck();\n  }\n\n  get row(): any {\n    return this._row;\n  }\n\n  @Input() set sorts(val: any[]) {\n    this._sorts = val;\n    this.calcSortDir = this.calcSortDir(val);\n  }\n\n  get sorts(): any[] {\n    return this._sorts;\n  }\n\n  @Input() set treeStatus(status: TreeStatus) {\n    if (status !== 'collapsed' && status !== 'expanded' && status !== 'loading' && status !== 'disabled') {\n      this._treeStatus = 'collapsed';\n    } else {\n      this._treeStatus = status;\n    }\n    this.cellContext.treeStatus = this._treeStatus;\n    this.checkValueUpdates();\n    this.cd.markForCheck();\n  }\n\n  get treeStatus(): TreeStatus {\n    return this._treeStatus;\n  }\n\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n\n  @Output() treeAction: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild('cellTemplate', { read: ViewContainerRef, static: true })\n  cellTemplate: ViewContainerRef;\n\n  @HostBinding('class')\n  get columnCssClasses(): any {\n    let cls = 'datatable-body-cell';\n    if (this.column.cellClass) {\n      if (typeof this.column.cellClass === 'string') {\n        cls += ' ' + this.column.cellClass;\n      } else if (typeof this.column.cellClass === 'function') {\n        const res = this.column.cellClass({\n          row: this.row,\n          group: this.group,\n          column: this.column,\n          value: this.value,\n          rowHeight: this.rowHeight\n        });\n\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    if (!this.sortDir) {\n      cls += ' sort-active';\n    }\n    if (this.isFocused) {\n      cls += ' active';\n    }\n    if (this.sortDir === SortDirection.asc) {\n      cls += ' sort-asc';\n    }\n    if (this.sortDir === SortDirection.desc) {\n      cls += ' sort-desc';\n    }\n\n    return cls;\n  }\n\n  @HostBinding('style.width.px')\n  get width(): number {\n    return this.column.width;\n  }\n\n  @HostBinding('style.minWidth.px')\n  get minWidth(): number {\n    return this.column.minWidth;\n  }\n\n  @HostBinding('style.maxWidth.px')\n  get maxWidth(): number {\n    return this.column.maxWidth;\n  }\n\n  @HostBinding('style.height')\n  get height(): string | number {\n    const height = this.rowHeight;\n    if (isNaN(height)) {\n      return height;\n    }\n    return height + 'px';\n  }\n\n  sanitizedValue: any;\n  value: any;\n  sortDir: SortDirection;\n  isFocused = false;\n  onCheckboxChangeFn = this.onCheckboxChange.bind(this);\n  activateFn = this.activate.emit.bind(this.activate);\n\n  cellContext: any = {\n    onCheckboxChangeFn: this.onCheckboxChangeFn,\n    activateFn: this.activateFn,\n    row: this.row,\n    group: this.group,\n    value: this.value,\n    column: this.column,\n    rowHeight: this.rowHeight,\n    isSelected: this.isSelected,\n    rowIndex: this.rowIndex,\n    treeStatus: this.treeStatus,\n    onTreeAction: this.onTreeAction.bind(this)\n  };\n\n  private _isSelected: boolean;\n  private _sorts: any[];\n  private _column: TableColumn;\n  private _row: any;\n  private _group: any;\n  private _rowHeight: number;\n  private _rowIndex: number;\n  private _expanded: boolean;\n  private _element: any;\n  private _treeStatus: TreeStatus;\n\n  constructor(element: ElementRef, private cd: ChangeDetectorRef) {\n    this._element = element.nativeElement;\n  }\n\n  ngDoCheck(): void {\n    this.checkValueUpdates();\n  }\n\n  ngOnDestroy(): void {\n    if (this.cellTemplate) {\n      this.cellTemplate.clear();\n    }\n  }\n\n  checkValueUpdates(): void {\n    let value = '';\n\n    if (!this.row || !this.column) {\n      value = '';\n    } else {\n      const val = this.column.$$valueGetter(this.row, this.column.prop);\n      const userPipe: PipeTransform = this.column.pipe;\n\n      if (userPipe) {\n        value = userPipe.transform(val);\n      } else if (value !== undefined) {\n        value = val;\n      }\n    }\n\n    if (this.value !== value) {\n      this.value = value;\n      this.cellContext.value = value;\n      this.sanitizedValue = value !== null && value !== undefined ? this.stripHtml(value) : value;\n      this.cd.markForCheck();\n    }\n  }\n\n  @HostListener('focus')\n  onFocus(): void {\n    this.isFocused = true;\n  }\n\n  @HostListener('blur')\n  onBlur(): void {\n    this.isFocused = false;\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: MouseEvent): void {\n    this.activate.emit({\n      type: 'click',\n      event,\n      row: this.row,\n      group: this.group,\n      rowHeight: this.rowHeight,\n      column: this.column,\n      value: this.value,\n      cellElement: this._element\n    });\n  }\n\n  @HostListener('dblclick', ['$event'])\n  onDblClick(event: MouseEvent): void {\n    this.activate.emit({\n      type: 'dblclick',\n      event,\n      row: this.row,\n      group: this.group,\n      rowHeight: this.rowHeight,\n      column: this.column,\n      value: this.value,\n      cellElement: this._element\n    });\n  }\n\n  @HostListener('keydown', ['$event'])\n  onKeyDown(event: KeyboardEvent): void {\n    const keyCode = event.keyCode;\n    const isTargetCell = 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 && isTargetCell) {\n      event.preventDefault();\n      event.stopPropagation();\n\n      this.activate.emit({\n        type: 'keydown',\n        event,\n        row: this.row,\n        group: this.group,\n        rowHeight: this.rowHeight,\n        column: this.column,\n        value: this.value,\n        cellElement: this._element\n      });\n    }\n  }\n\n  onCheckboxChange(event: any): void {\n    this.activate.emit({\n      type: 'checkbox',\n      event,\n      row: this.row,\n      group: this.group,\n      rowHeight: this.rowHeight,\n      column: this.column,\n      value: this.value,\n      cellElement: this._element,\n      treeStatus: 'collapsed'\n    });\n  }\n\n  calcSortDir(sorts: any[]): any {\n    if (!sorts) {\n      return;\n    }\n\n    const sort = sorts.find((s: any) => {\n      return s.prop === this.column.prop;\n    });\n\n    if (sort) {\n      return sort.dir;\n    }\n  }\n\n  stripHtml(html: string): string {\n    if (!html.replace) {\n      return html;\n    }\n    return html.replace(/<\\/?[^>]+(>|$)/g, '');\n  }\n\n  onTreeAction() {\n    this.treeAction.emit(this.row);\n  }\n\n  calcLeftMargin(column: any, row: any) {\n    const levelIndent = column.treeLevelIndent != null ? column.treeLevelIndent : 50;\n    return column.isTreeColumn ? row.level * levelIndent : 0;\n  }\n}\n"]}