header.component.js 35 KB

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