header.component.js 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519
  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, Output, EventEmitter, Input, HostBinding, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';
  7. import { columnsByPin, columnGroupWidths, columnsByPinArr } from '../../utils/column';
  8. import { SortType } from '../../types/sort.type';
  9. import { SelectionType } from '../../types/selection.type';
  10. import { translateXY } from '../../utils/translate';
  11. var DataTableHeaderComponent = /** @class */ (function () {
  12. function DataTableHeaderComponent(cd) {
  13. this.cd = cd;
  14. this.sort = new EventEmitter();
  15. this.reorder = new EventEmitter();
  16. this.resize = new EventEmitter();
  17. this.select = new EventEmitter();
  18. this.columnContextmenu = new EventEmitter(false);
  19. this._columnGroupWidths = {
  20. total: 100
  21. };
  22. this._styleByGroup = {
  23. left: {},
  24. center: {},
  25. right: {}
  26. };
  27. this.destroyed = false;
  28. }
  29. Object.defineProperty(DataTableHeaderComponent.prototype, "innerWidth", {
  30. get: /**
  31. * @return {?}
  32. */
  33. function () {
  34. return this._innerWidth;
  35. },
  36. set: /**
  37. * @param {?} val
  38. * @return {?}
  39. */
  40. function (val) {
  41. var _this = this;
  42. this._innerWidth = val;
  43. setTimeout((/**
  44. * @return {?}
  45. */
  46. function () {
  47. if (_this._columns) {
  48. /** @type {?} */
  49. var colByPin = columnsByPin(_this._columns);
  50. _this._columnGroupWidths = columnGroupWidths(colByPin, _this._columns);
  51. _this.setStylesByGroup();
  52. }
  53. }));
  54. },
  55. enumerable: true,
  56. configurable: true
  57. });
  58. Object.defineProperty(DataTableHeaderComponent.prototype, "headerHeight", {
  59. get: /**
  60. * @return {?}
  61. */
  62. function () {
  63. return this._headerHeight;
  64. },
  65. set: /**
  66. * @param {?} val
  67. * @return {?}
  68. */
  69. function (val) {
  70. if (val !== 'auto') {
  71. this._headerHeight = val + "px";
  72. }
  73. else {
  74. this._headerHeight = val;
  75. }
  76. },
  77. enumerable: true,
  78. configurable: true
  79. });
  80. Object.defineProperty(DataTableHeaderComponent.prototype, "columns", {
  81. get: /**
  82. * @return {?}
  83. */
  84. function () {
  85. return this._columns;
  86. },
  87. set: /**
  88. * @param {?} val
  89. * @return {?}
  90. */
  91. function (val) {
  92. var _this = this;
  93. this._columns = val;
  94. /** @type {?} */
  95. var colsByPin = columnsByPin(val);
  96. this._columnsByPin = columnsByPinArr(val);
  97. setTimeout((/**
  98. * @return {?}
  99. */
  100. function () {
  101. _this._columnGroupWidths = columnGroupWidths(colsByPin, val);
  102. _this.setStylesByGroup();
  103. }));
  104. },
  105. enumerable: true,
  106. configurable: true
  107. });
  108. Object.defineProperty(DataTableHeaderComponent.prototype, "offsetX", {
  109. get: /**
  110. * @return {?}
  111. */
  112. function () {
  113. return this._offsetX;
  114. },
  115. set: /**
  116. * @param {?} val
  117. * @return {?}
  118. */
  119. function (val) {
  120. this._offsetX = val;
  121. this.setStylesByGroup();
  122. },
  123. enumerable: true,
  124. configurable: true
  125. });
  126. /**
  127. * @return {?}
  128. */
  129. DataTableHeaderComponent.prototype.ngOnDestroy = /**
  130. * @return {?}
  131. */
  132. function () {
  133. this.destroyed = true;
  134. };
  135. /**
  136. * @param {?} __0
  137. * @return {?}
  138. */
  139. DataTableHeaderComponent.prototype.onLongPressStart = /**
  140. * @param {?} __0
  141. * @return {?}
  142. */
  143. function (_a) {
  144. var event = _a.event, model = _a.model;
  145. model.dragging = true;
  146. this.dragEventTarget = event;
  147. };
  148. /**
  149. * @param {?} __0
  150. * @return {?}
  151. */
  152. DataTableHeaderComponent.prototype.onLongPressEnd = /**
  153. * @param {?} __0
  154. * @return {?}
  155. */
  156. function (_a) {
  157. var _this = this;
  158. var event = _a.event, model = _a.model;
  159. this.dragEventTarget = event;
  160. // delay resetting so sort can be
  161. // prevented if we were dragging
  162. setTimeout((/**
  163. * @return {?}
  164. */
  165. function () {
  166. // datatable component creates copies from columns on reorder
  167. // set dragging to false on new objects
  168. /** @type {?} */
  169. var column = _this._columns.find((/**
  170. * @param {?} c
  171. * @return {?}
  172. */
  173. function (c) { return c.$$id === model.$$id; }));
  174. if (column) {
  175. column.dragging = false;
  176. }
  177. }), 5);
  178. };
  179. Object.defineProperty(DataTableHeaderComponent.prototype, "headerWidth", {
  180. get: /**
  181. * @return {?}
  182. */
  183. function () {
  184. if (this.scrollbarH) {
  185. return this.innerWidth + 'px';
  186. }
  187. return '100%';
  188. },
  189. enumerable: true,
  190. configurable: true
  191. });
  192. /**
  193. * @param {?} index
  194. * @param {?} colGroup
  195. * @return {?}
  196. */
  197. DataTableHeaderComponent.prototype.trackByGroups = /**
  198. * @param {?} index
  199. * @param {?} colGroup
  200. * @return {?}
  201. */
  202. function (index, colGroup) {
  203. return colGroup.type;
  204. };
  205. /**
  206. * @param {?} index
  207. * @param {?} column
  208. * @return {?}
  209. */
  210. DataTableHeaderComponent.prototype.columnTrackingFn = /**
  211. * @param {?} index
  212. * @param {?} column
  213. * @return {?}
  214. */
  215. function (index, column) {
  216. return column.$$id;
  217. };
  218. /**
  219. * @param {?} width
  220. * @param {?} column
  221. * @return {?}
  222. */
  223. DataTableHeaderComponent.prototype.onColumnResized = /**
  224. * @param {?} width
  225. * @param {?} column
  226. * @return {?}
  227. */
  228. function (width, column) {
  229. if (width <= column.minWidth) {
  230. width = column.minWidth;
  231. }
  232. else if (width >= column.maxWidth) {
  233. width = column.maxWidth;
  234. }
  235. this.resize.emit({
  236. column: column,
  237. prevValue: column.width,
  238. newValue: width
  239. });
  240. };
  241. /**
  242. * @param {?} __0
  243. * @return {?}
  244. */
  245. DataTableHeaderComponent.prototype.onColumnReordered = /**
  246. * @param {?} __0
  247. * @return {?}
  248. */
  249. function (_a) {
  250. var prevIndex = _a.prevIndex, newIndex = _a.newIndex, model = _a.model;
  251. /** @type {?} */
  252. var column = this.getColumn(newIndex);
  253. column.isTarget = false;
  254. column.targetMarkerContext = undefined;
  255. this.reorder.emit({
  256. column: model,
  257. prevValue: prevIndex,
  258. newValue: newIndex
  259. });
  260. };
  261. /**
  262. * @param {?} __0
  263. * @return {?}
  264. */
  265. DataTableHeaderComponent.prototype.onTargetChanged = /**
  266. * @param {?} __0
  267. * @return {?}
  268. */
  269. function (_a) {
  270. var prevIndex = _a.prevIndex, newIndex = _a.newIndex, initialIndex = _a.initialIndex;
  271. if (prevIndex || prevIndex === 0) {
  272. /** @type {?} */
  273. var oldColumn = this.getColumn(prevIndex);
  274. oldColumn.isTarget = false;
  275. oldColumn.targetMarkerContext = undefined;
  276. }
  277. if (newIndex || newIndex === 0) {
  278. /** @type {?} */
  279. var newColumn = this.getColumn(newIndex);
  280. newColumn.isTarget = true;
  281. if (initialIndex !== newIndex) {
  282. newColumn.targetMarkerContext = {
  283. class: 'targetMarker '.concat(initialIndex > newIndex ? 'dragFromRight' : 'dragFromLeft')
  284. };
  285. }
  286. }
  287. };
  288. /**
  289. * @param {?} index
  290. * @return {?}
  291. */
  292. DataTableHeaderComponent.prototype.getColumn = /**
  293. * @param {?} index
  294. * @return {?}
  295. */
  296. function (index) {
  297. /** @type {?} */
  298. var leftColumnCount = this._columnsByPin[0].columns.length;
  299. if (index < leftColumnCount) {
  300. return this._columnsByPin[0].columns[index];
  301. }
  302. /** @type {?} */
  303. var centerColumnCount = this._columnsByPin[1].columns.length;
  304. if (index < leftColumnCount + centerColumnCount) {
  305. return this._columnsByPin[1].columns[index - leftColumnCount];
  306. }
  307. return this._columnsByPin[2].columns[index - leftColumnCount - centerColumnCount];
  308. };
  309. /**
  310. * @param {?} __0
  311. * @return {?}
  312. */
  313. DataTableHeaderComponent.prototype.onSort = /**
  314. * @param {?} __0
  315. * @return {?}
  316. */
  317. function (_a) {
  318. var column = _a.column, prevValue = _a.prevValue, newValue = _a.newValue;
  319. // if we are dragging don't sort!
  320. if (column.dragging) {
  321. return;
  322. }
  323. /** @type {?} */
  324. var sorts = this.calcNewSorts(column, prevValue, newValue);
  325. this.sort.emit({
  326. sorts: sorts,
  327. column: column,
  328. prevValue: prevValue,
  329. newValue: newValue
  330. });
  331. };
  332. /**
  333. * @param {?} column
  334. * @param {?} prevValue
  335. * @param {?} newValue
  336. * @return {?}
  337. */
  338. DataTableHeaderComponent.prototype.calcNewSorts = /**
  339. * @param {?} column
  340. * @param {?} prevValue
  341. * @param {?} newValue
  342. * @return {?}
  343. */
  344. function (column, prevValue, newValue) {
  345. /** @type {?} */
  346. var idx = 0;
  347. if (!this.sorts) {
  348. this.sorts = [];
  349. }
  350. /** @type {?} */
  351. var sorts = this.sorts.map((/**
  352. * @param {?} s
  353. * @param {?} i
  354. * @return {?}
  355. */
  356. function (s, i) {
  357. s = tslib_1.__assign({}, s);
  358. if (s.prop === column.prop) {
  359. idx = i;
  360. }
  361. return s;
  362. }));
  363. if (newValue === undefined) {
  364. sorts.splice(idx, 1);
  365. }
  366. else if (prevValue) {
  367. sorts[idx].dir = newValue;
  368. }
  369. else {
  370. if (this.sortType === SortType.single) {
  371. sorts.splice(0, this.sorts.length);
  372. }
  373. sorts.push({ dir: newValue, prop: column.prop });
  374. }
  375. return sorts;
  376. };
  377. /**
  378. * @return {?}
  379. */
  380. DataTableHeaderComponent.prototype.setStylesByGroup = /**
  381. * @return {?}
  382. */
  383. function () {
  384. this._styleByGroup.left = this.calcStylesByGroup('left');
  385. this._styleByGroup.center = this.calcStylesByGroup('center');
  386. this._styleByGroup.right = this.calcStylesByGroup('right');
  387. if (!this.destroyed) {
  388. this.cd.detectChanges();
  389. }
  390. };
  391. /**
  392. * @param {?} group
  393. * @return {?}
  394. */
  395. DataTableHeaderComponent.prototype.calcStylesByGroup = /**
  396. * @param {?} group
  397. * @return {?}
  398. */
  399. function (group) {
  400. /** @type {?} */
  401. var widths = this._columnGroupWidths;
  402. /** @type {?} */
  403. var offsetX = this.offsetX;
  404. /** @type {?} */
  405. var styles = {
  406. width: widths[group] + "px"
  407. };
  408. if (group === 'center') {
  409. translateXY(styles, offsetX * -1, 0);
  410. }
  411. else if (group === 'right') {
  412. /** @type {?} */
  413. var totalDiff = widths.total - this.innerWidth;
  414. /** @type {?} */
  415. var offset = totalDiff * -1;
  416. translateXY(styles, offset, 0);
  417. }
  418. return styles;
  419. };
  420. DataTableHeaderComponent.decorators = [
  421. { type: Component, args: [{
  422. selector: 'datatable-header',
  423. template: "\n <div\n orderable\n (reorder)=\"onColumnReordered($event)\"\n (targetChanged)=\"onTargetChanged($event)\"\n [style.width.px]=\"_columnGroupWidths.total\"\n class=\"datatable-header-inner\"\n >\n <div\n *ngFor=\"let colGroup of _columnsByPin; trackBy: trackByGroups\"\n [class]=\"'datatable-row-' + colGroup.type\"\n [ngStyle]=\"_styleByGroup[colGroup.type]\"\n >\n <datatable-header-cell\n *ngFor=\"let column of colGroup.columns; trackBy: columnTrackingFn\"\n resizeable\n [resizeEnabled]=\"column.resizeable\"\n (resize)=\"onColumnResized($event, column)\"\n long-press\n [pressModel]=\"column\"\n [pressEnabled]=\"reorderable && column.draggable\"\n (longPressStart)=\"onLongPressStart($event)\"\n (longPressEnd)=\"onLongPressEnd($event)\"\n draggable\n [dragX]=\"reorderable && column.draggable && column.dragging\"\n [dragY]=\"false\"\n [dragModel]=\"column\"\n [dragEventTarget]=\"dragEventTarget\"\n [headerHeight]=\"headerHeight\"\n [isTarget]=\"column.isTarget\"\n [targetMarkerTemplate]=\"targetMarkerTemplate\"\n [targetMarkerContext]=\"column.targetMarkerContext\"\n [column]=\"column\"\n [sortType]=\"sortType\"\n [sorts]=\"sorts\"\n [selectionType]=\"selectionType\"\n [sortAscendingIcon]=\"sortAscendingIcon\"\n [sortDescendingIcon]=\"sortDescendingIcon\"\n [allRowsSelected]=\"allRowsSelected\"\n (sort)=\"onSort($event)\"\n (select)=\"select.emit($event)\"\n (columnContextmenu)=\"columnContextmenu.emit($event)\"\n >\n </datatable-header-cell>\n </div>\n </div>\n ",
  424. host: {
  425. class: 'datatable-header'
  426. },
  427. changeDetection: ChangeDetectionStrategy.OnPush
  428. }] }
  429. ];
  430. /** @nocollapse */
  431. DataTableHeaderComponent.ctorParameters = function () { return [
  432. { type: ChangeDetectorRef }
  433. ]; };
  434. DataTableHeaderComponent.propDecorators = {
  435. sortAscendingIcon: [{ type: Input }],
  436. sortDescendingIcon: [{ type: Input }],
  437. scrollbarH: [{ type: Input }],
  438. dealsWithGroup: [{ type: Input }],
  439. targetMarkerTemplate: [{ type: Input }],
  440. innerWidth: [{ type: Input }],
  441. sorts: [{ type: Input }],
  442. sortType: [{ type: Input }],
  443. allRowsSelected: [{ type: Input }],
  444. selectionType: [{ type: Input }],
  445. reorderable: [{ type: Input }],
  446. headerHeight: [{ type: HostBinding, args: ['style.height',] }, { type: Input }],
  447. columns: [{ type: Input }],
  448. offsetX: [{ type: Input }],
  449. sort: [{ type: Output }],
  450. reorder: [{ type: Output }],
  451. resize: [{ type: Output }],
  452. select: [{ type: Output }],
  453. columnContextmenu: [{ type: Output }],
  454. headerWidth: [{ type: HostBinding, args: ['style.width',] }]
  455. };
  456. return DataTableHeaderComponent;
  457. }());
  458. export { DataTableHeaderComponent };
  459. if (false) {
  460. /** @type {?} */
  461. DataTableHeaderComponent.prototype.sortAscendingIcon;
  462. /** @type {?} */
  463. DataTableHeaderComponent.prototype.sortDescendingIcon;
  464. /** @type {?} */
  465. DataTableHeaderComponent.prototype.scrollbarH;
  466. /** @type {?} */
  467. DataTableHeaderComponent.prototype.dealsWithGroup;
  468. /** @type {?} */
  469. DataTableHeaderComponent.prototype.targetMarkerTemplate;
  470. /** @type {?} */
  471. DataTableHeaderComponent.prototype.targetMarkerContext;
  472. /** @type {?} */
  473. DataTableHeaderComponent.prototype.sorts;
  474. /** @type {?} */
  475. DataTableHeaderComponent.prototype.sortType;
  476. /** @type {?} */
  477. DataTableHeaderComponent.prototype.allRowsSelected;
  478. /** @type {?} */
  479. DataTableHeaderComponent.prototype.selectionType;
  480. /** @type {?} */
  481. DataTableHeaderComponent.prototype.reorderable;
  482. /** @type {?} */
  483. DataTableHeaderComponent.prototype.dragEventTarget;
  484. /** @type {?} */
  485. DataTableHeaderComponent.prototype.sort;
  486. /** @type {?} */
  487. DataTableHeaderComponent.prototype.reorder;
  488. /** @type {?} */
  489. DataTableHeaderComponent.prototype.resize;
  490. /** @type {?} */
  491. DataTableHeaderComponent.prototype.select;
  492. /** @type {?} */
  493. DataTableHeaderComponent.prototype.columnContextmenu;
  494. /** @type {?} */
  495. DataTableHeaderComponent.prototype._columnsByPin;
  496. /** @type {?} */
  497. DataTableHeaderComponent.prototype._columnGroupWidths;
  498. /** @type {?} */
  499. DataTableHeaderComponent.prototype._innerWidth;
  500. /** @type {?} */
  501. DataTableHeaderComponent.prototype._offsetX;
  502. /** @type {?} */
  503. DataTableHeaderComponent.prototype._columns;
  504. /** @type {?} */
  505. DataTableHeaderComponent.prototype._headerHeight;
  506. /** @type {?} */
  507. DataTableHeaderComponent.prototype._styleByGroup;
  508. /**
  509. * @type {?}
  510. * @private
  511. */
  512. DataTableHeaderComponent.prototype.destroyed;
  513. /**
  514. * @type {?}
  515. * @private
  516. */
  517. DataTableHeaderComponent.prototype.cd;
  518. }
  519. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/header/header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Output,\n  EventEmitter,\n  Input,\n  HostBinding,\n  ChangeDetectorRef,\n  ChangeDetectionStrategy, OnDestroy\n} from '@angular/core';\nimport { MouseEvent } from '../../events';\nimport { columnsByPin, columnGroupWidths, columnsByPinArr } from '../../utils/column';\nimport { SortType } from '../../types/sort.type';\nimport { SelectionType } from '../../types/selection.type';\nimport { DataTableColumnDirective } from '../columns/column.directive';\nimport { translateXY } from '../../utils/translate';\n\n@Component({\n  selector: 'datatable-header',\n  template: `\n    <div\n      orderable\n      (reorder)=\"onColumnReordered($event)\"\n      (targetChanged)=\"onTargetChanged($event)\"\n      [style.width.px]=\"_columnGroupWidths.total\"\n      class=\"datatable-header-inner\"\n    >\n      <div\n        *ngFor=\"let colGroup of _columnsByPin; trackBy: trackByGroups\"\n        [class]=\"'datatable-row-' + colGroup.type\"\n        [ngStyle]=\"_styleByGroup[colGroup.type]\"\n      >\n        <datatable-header-cell\n          *ngFor=\"let column of colGroup.columns; trackBy: columnTrackingFn\"\n          resizeable\n          [resizeEnabled]=\"column.resizeable\"\n          (resize)=\"onColumnResized($event, column)\"\n          long-press\n          [pressModel]=\"column\"\n          [pressEnabled]=\"reorderable && column.draggable\"\n          (longPressStart)=\"onLongPressStart($event)\"\n          (longPressEnd)=\"onLongPressEnd($event)\"\n          draggable\n          [dragX]=\"reorderable && column.draggable && column.dragging\"\n          [dragY]=\"false\"\n          [dragModel]=\"column\"\n          [dragEventTarget]=\"dragEventTarget\"\n          [headerHeight]=\"headerHeight\"\n          [isTarget]=\"column.isTarget\"\n          [targetMarkerTemplate]=\"targetMarkerTemplate\"\n          [targetMarkerContext]=\"column.targetMarkerContext\"\n          [column]=\"column\"\n          [sortType]=\"sortType\"\n          [sorts]=\"sorts\"\n          [selectionType]=\"selectionType\"\n          [sortAscendingIcon]=\"sortAscendingIcon\"\n          [sortDescendingIcon]=\"sortDescendingIcon\"\n          [allRowsSelected]=\"allRowsSelected\"\n          (sort)=\"onSort($event)\"\n          (select)=\"select.emit($event)\"\n          (columnContextmenu)=\"columnContextmenu.emit($event)\"\n        >\n        </datatable-header-cell>\n      </div>\n    </div>\n  `,\n  host: {\n    class: 'datatable-header'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataTableHeaderComponent implements OnDestroy {\n  @Input() sortAscendingIcon: any;\n  @Input() sortDescendingIcon: any;\n  @Input() scrollbarH: boolean;\n  @Input() dealsWithGroup: boolean;\n  @Input() targetMarkerTemplate: any;\n\n  targetMarkerContext: any;\n\n  @Input() set innerWidth(val: number) {\n    this._innerWidth = val;\n    setTimeout(() => {\n      if (this._columns) {\n        const colByPin = columnsByPin(this._columns);\n        this._columnGroupWidths = columnGroupWidths(colByPin, this._columns);\n        this.setStylesByGroup();\n      }\n    });\n  }\n\n  get innerWidth(): number {\n    return this._innerWidth;\n  }\n\n  @Input() sorts: any[];\n  @Input() sortType: SortType;\n  @Input() allRowsSelected: boolean;\n  @Input() selectionType: SelectionType;\n  @Input() reorderable: boolean;\n\n  dragEventTarget: any;\n\n  @HostBinding('style.height')\n  @Input()\n  set headerHeight(val: any) {\n    if (val !== 'auto') {\n      this._headerHeight = `${val}px`;\n    } else {\n      this._headerHeight = val;\n    }\n  }\n\n  get headerHeight(): any {\n    return this._headerHeight;\n  }\n\n  @Input() set columns(val: any[]) {\n    this._columns = val;\n\n    const colsByPin = columnsByPin(val);\n    this._columnsByPin = columnsByPinArr(val);\n    setTimeout(() => {\n      this._columnGroupWidths = columnGroupWidths(colsByPin, val);\n      this.setStylesByGroup();\n    });\n  }\n\n  get columns(): any[] {\n    return this._columns;\n  }\n\n  @Input()\n  set offsetX(val: number) {\n    this._offsetX = val;\n    this.setStylesByGroup();\n  }\n  get offsetX() {\n    return this._offsetX;\n  }\n\n  @Output() sort: EventEmitter<any> = new EventEmitter();\n  @Output() reorder: EventEmitter<any> = new EventEmitter();\n  @Output() resize: EventEmitter<any> = new EventEmitter();\n  @Output() select: EventEmitter<any> = new EventEmitter();\n  @Output() columnContextmenu = new EventEmitter<{ event: MouseEvent; column: any }>(false);\n\n  _columnsByPin: any;\n  _columnGroupWidths: any = {\n    total: 100\n  };\n  _innerWidth: number;\n  _offsetX: number;\n  _columns: any[];\n  _headerHeight: string;\n  _styleByGroup: { [prop: string]: {} } = {\n    left: {},\n    center: {},\n    right: {}\n  };\n\n  private destroyed = false;\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  ngOnDestroy(): void {\n    this.destroyed = true;\n  }\n\n  onLongPressStart({ event, model }: { event: any; model: any }) {\n    model.dragging = true;\n    this.dragEventTarget = event;\n  }\n\n  onLongPressEnd({ event, model }: { event: any; model: any }) {\n    this.dragEventTarget = event;\n\n    // delay resetting so sort can be\n    // prevented if we were dragging\n    setTimeout(() => {\n      // datatable component creates copies from columns on reorder\n      // set dragging to false on new objects\n      const column = this._columns.find(c => c.$$id === model.$$id);\n      if (column) {\n        column.dragging = false;\n      }\n    }, 5);\n  }\n\n  @HostBinding('style.width')\n  get headerWidth(): string {\n    if (this.scrollbarH) {\n      return this.innerWidth + 'px';\n    }\n\n    return '100%';\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  onColumnResized(width: number, column: DataTableColumnDirective): void {\n    if (width <= column.minWidth) {\n      width = column.minWidth;\n    } else if (width >= column.maxWidth) {\n      width = column.maxWidth;\n    }\n\n    this.resize.emit({\n      column,\n      prevValue: column.width,\n      newValue: width\n    });\n  }\n\n  onColumnReordered({ prevIndex, newIndex, model }: any): void {\n    const column = this.getColumn(newIndex);\n    column.isTarget = false;\n    column.targetMarkerContext = undefined;\n    this.reorder.emit({\n      column: model,\n      prevValue: prevIndex,\n      newValue: newIndex\n    });\n  }\n\n  onTargetChanged({ prevIndex, newIndex, initialIndex }: any): void {\n    if (prevIndex || prevIndex === 0) {\n      const oldColumn = this.getColumn(prevIndex);\n      oldColumn.isTarget = false;\n      oldColumn.targetMarkerContext = undefined;\n    }\n    if (newIndex || newIndex === 0) {\n      const newColumn = this.getColumn(newIndex);\n      newColumn.isTarget = true;\n\n      if (initialIndex !== newIndex) {\n        newColumn.targetMarkerContext = {\n          class: 'targetMarker '.concat(initialIndex > newIndex ? 'dragFromRight' : 'dragFromLeft')\n        };\n      }\n    }\n  }\n\n  getColumn(index: number): any {\n    const leftColumnCount = this._columnsByPin[0].columns.length;\n    if (index < leftColumnCount) {\n      return this._columnsByPin[0].columns[index];\n    }\n\n    const centerColumnCount = this._columnsByPin[1].columns.length;\n    if (index < leftColumnCount + centerColumnCount) {\n      return this._columnsByPin[1].columns[index - leftColumnCount];\n    }\n\n    return this._columnsByPin[2].columns[index - leftColumnCount - centerColumnCount];\n  }\n\n  onSort({ column, prevValue, newValue }: any): void {\n    // if we are dragging don't sort!\n    if (column.dragging) {\n      return;\n    }\n\n    const sorts = this.calcNewSorts(column, prevValue, newValue);\n    this.sort.emit({\n      sorts,\n      column,\n      prevValue,\n      newValue\n    });\n  }\n\n  calcNewSorts(column: any, prevValue: number, newValue: number): any[] {\n    let idx = 0;\n\n    if (!this.sorts) {\n      this.sorts = [];\n    }\n\n    const sorts = this.sorts.map((s, i) => {\n      s = { ...s };\n      if (s.prop === column.prop) {\n        idx = i;\n      }\n      return s;\n    });\n\n    if (newValue === undefined) {\n      sorts.splice(idx, 1);\n    } else if (prevValue) {\n      sorts[idx].dir = newValue;\n    } else {\n      if (this.sortType === SortType.single) {\n        sorts.splice(0, this.sorts.length);\n      }\n\n      sorts.push({ dir: newValue, prop: column.prop });\n    }\n\n    return sorts;\n  }\n\n  setStylesByGroup() {\n    this._styleByGroup.left = this.calcStylesByGroup('left');\n    this._styleByGroup.center = this.calcStylesByGroup('center');\n    this._styleByGroup.right = this.calcStylesByGroup('right');\n    if (!this.destroyed) {\n      this.cd.detectChanges();\n    }\n  }\n\n  calcStylesByGroup(group: string): any {\n    const widths = this._columnGroupWidths;\n    const offsetX = this.offsetX;\n\n    const styles = {\n      width: `${widths[group]}px`\n    };\n\n    if (group === 'center') {\n      translateXY(styles, offsetX * -1, 0);\n    } else if (group === 'right') {\n      const totalDiff = widths.total - this.innerWidth;\n      const offset = totalDiff * -1;\n      translateXY(styles, offset, 0);\n    }\n\n    return styles;\n  }\n}\n"]}