body-cell.component.js 47 KB

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