datatable.component.js 130 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858
  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, Output, ElementRef, EventEmitter, ViewChild, HostListener, ContentChildren, QueryList, HostBinding, ContentChild, KeyValueDiffers, ViewEncapsulation, ChangeDetectionStrategy, ChangeDetectorRef, SkipSelf, Optional, Inject } from '@angular/core';
  7. import { DatatableGroupHeaderDirective } from './body/body-group-header.directive';
  8. import { BehaviorSubject } from 'rxjs';
  9. import { groupRowsByParents, optionalGetterForProp } from '../utils/tree';
  10. import { setColumnDefaults, translateTemplates } from '../utils/column-helper';
  11. import { ColumnMode } from '../types/column-mode.type';
  12. import { SelectionType } from '../types/selection.type';
  13. import { SortType } from '../types/sort.type';
  14. import { ContextmenuType } from '../types/contextmenu.type';
  15. import { DataTableColumnDirective } from './columns/column.directive';
  16. import { DatatableRowDetailDirective } from './row-detail/row-detail.directive';
  17. import { DatatableFooterDirective } from './footer/footer.directive';
  18. import { DataTableBodyComponent } from './body/body.component';
  19. import { DataTableHeaderComponent } from './header/header.component';
  20. import { ScrollbarHelper } from '../services/scrollbar-helper.service';
  21. import { ColumnChangesService } from '../services/column-changes.service';
  22. import { DimensionsHelper } from '../services/dimensions-helper.service';
  23. import { throttleable } from '../utils/throttle';
  24. import { forceFillColumnWidths, adjustColumnWidths } from '../utils/math';
  25. import { sortRows } from '../utils/sort';
  26. var DatatableComponent = /** @class */ (function () {
  27. function DatatableComponent(scrollbarHelper, dimensionsHelper, cd, element, differs, columnChangesService, configuration) {
  28. var _this = this;
  29. this.scrollbarHelper = scrollbarHelper;
  30. this.dimensionsHelper = dimensionsHelper;
  31. this.cd = cd;
  32. this.columnChangesService = columnChangesService;
  33. this.configuration = configuration;
  34. /**
  35. * List of row objects that should be
  36. * represented as selected in the grid.
  37. * Default value: `[]`
  38. */
  39. this.selected = [];
  40. /**
  41. * Enable vertical scrollbars
  42. */
  43. this.scrollbarV = false;
  44. /**
  45. * Enable horz scrollbars
  46. */
  47. this.scrollbarH = false;
  48. /**
  49. * The row height; which is necessary
  50. * to calculate the height for the lazy rendering.
  51. */
  52. this.rowHeight = 30;
  53. /**
  54. * Type of column width distribution formula.
  55. * Example: flex, force, standard
  56. */
  57. this.columnMode = ColumnMode.standard;
  58. /**
  59. * The minimum header height in pixels.
  60. * Pass a falsey for no header
  61. */
  62. this.headerHeight = 30;
  63. /**
  64. * The minimum footer height in pixels.
  65. * Pass falsey for no footer
  66. */
  67. this.footerHeight = 0;
  68. /**
  69. * If the table should use external paging
  70. * otherwise its assumed that all data is preloaded.
  71. */
  72. this.externalPaging = false;
  73. /**
  74. * If the table should use external sorting or
  75. * the built-in basic sorting.
  76. */
  77. this.externalSorting = false;
  78. /**
  79. * Show the linear loading bar.
  80. * Default value: `false`
  81. */
  82. this.loadingIndicator = false;
  83. /**
  84. * Enable/Disable ability to re-order columns
  85. * by dragging them.
  86. */
  87. this.reorderable = true;
  88. /**
  89. * Swap columns on re-order columns or
  90. * move them.
  91. */
  92. this.swapColumns = true;
  93. /**
  94. * The type of sorting
  95. */
  96. this.sortType = SortType.single;
  97. /**
  98. * Array of sorted columns by property and type.
  99. * Default value: `[]`
  100. */
  101. this.sorts = [];
  102. /**
  103. * Css class overrides
  104. */
  105. this.cssClasses = {
  106. sortAscending: 'datatable-icon-up',
  107. sortDescending: 'datatable-icon-down',
  108. pagerLeftArrow: 'datatable-icon-left',
  109. pagerRightArrow: 'datatable-icon-right',
  110. pagerPrevious: 'datatable-icon-prev',
  111. pagerNext: 'datatable-icon-skip'
  112. };
  113. /**
  114. * Message overrides for localization
  115. *
  116. * emptyMessage [default] = 'No data to display'
  117. * totalMessage [default] = 'total'
  118. * selectedMessage [default] = 'selected'
  119. */
  120. this.messages = {
  121. // Message to show when array is presented
  122. // but contains no values
  123. emptyMessage: 'No data to display',
  124. // Footer total message
  125. totalMessage: 'total',
  126. // Footer selected message
  127. selectedMessage: 'selected'
  128. };
  129. /**
  130. * A boolean you can use to set the detault behaviour of rows and groups
  131. * whether they will start expanded or not. If ommited the default is NOT expanded.
  132. *
  133. */
  134. this.groupExpansionDefault = false;
  135. /**
  136. * Property to which you can use for determining select all
  137. * rows on current page or not.
  138. *
  139. * \@memberOf DatatableComponent
  140. */
  141. this.selectAllRowsOnPage = false;
  142. /**
  143. * A flag for row virtualization on / off
  144. */
  145. this.virtualization = true;
  146. /**
  147. * A flag for switching summary row on / off
  148. */
  149. this.summaryRow = false;
  150. /**
  151. * A height of summary row
  152. */
  153. this.summaryHeight = 30;
  154. /**
  155. * A property holds a summary row position: top/bottom
  156. */
  157. this.summaryPosition = 'top';
  158. /**
  159. * Body was scrolled typically in a `scrollbarV:true` scenario.
  160. */
  161. this.scroll = new EventEmitter();
  162. /**
  163. * A cell or row was focused via keyboard or mouse click.
  164. */
  165. this.activate = new EventEmitter();
  166. /**
  167. * A cell or row was selected.
  168. */
  169. this.select = new EventEmitter();
  170. /**
  171. * Column sort was invoked.
  172. */
  173. this.sort = new EventEmitter();
  174. /**
  175. * The table was paged either triggered by the pager or the body scroll.
  176. */
  177. this.page = new EventEmitter();
  178. /**
  179. * Columns were re-ordered.
  180. */
  181. this.reorder = new EventEmitter();
  182. /**
  183. * Column was resized.
  184. */
  185. this.resize = new EventEmitter();
  186. /**
  187. * The context menu was invoked on the table.
  188. * type indicates whether the header or the body was clicked.
  189. * content contains either the column or the row that was clicked.
  190. */
  191. this.tableContextmenu = new EventEmitter(false);
  192. /**
  193. * A row was expanded ot collapsed for tree
  194. */
  195. this.treeAction = new EventEmitter();
  196. this.rowCount = 0;
  197. this._offsetX = new BehaviorSubject(0);
  198. this._count = 0;
  199. this._offset = 0;
  200. this._subscriptions = [];
  201. /**
  202. * This will be used when displaying or selecting rows.
  203. * when tracking/comparing them, we'll use the value of this fn,
  204. *
  205. * (`fn(x) === fn(y)` instead of `x === y`)
  206. */
  207. this.rowIdentity = (/**
  208. * @param {?} x
  209. * @return {?}
  210. */
  211. function (x) {
  212. if (_this._groupRowsBy) {
  213. // each group in groupedRows are stored as {key, value: [rows]},
  214. // where key is the groupRowsBy index
  215. return x.key;
  216. }
  217. else {
  218. return x;
  219. }
  220. });
  221. // get ref to elm for measuring
  222. this.element = element.nativeElement;
  223. this.rowDiffer = differs.find({}).create();
  224. // apply global settings from Module.forRoot
  225. if (this.configuration && this.configuration.messages) {
  226. this.messages = tslib_1.__assign({}, this.configuration.messages);
  227. }
  228. }
  229. Object.defineProperty(DatatableComponent.prototype, "rows", {
  230. /**
  231. * Gets the rows.
  232. */
  233. get: /**
  234. * Gets the rows.
  235. * @return {?}
  236. */
  237. function () {
  238. return this._rows;
  239. },
  240. /**
  241. * Rows that are displayed in the table.
  242. */
  243. set: /**
  244. * Rows that are displayed in the table.
  245. * @param {?} val
  246. * @return {?}
  247. */
  248. function (val) {
  249. this._rows = val;
  250. if (val) {
  251. this._internalRows = tslib_1.__spread(val);
  252. }
  253. // auto sort on new updates
  254. if (!this.externalSorting) {
  255. this.sortInternalRows();
  256. }
  257. // auto group by parent on new update
  258. this._internalRows = groupRowsByParents(this._internalRows, optionalGetterForProp(this.treeFromRelation), optionalGetterForProp(this.treeToRelation));
  259. // recalculate sizes/etc
  260. this.recalculate();
  261. if (this._rows && this._groupRowsBy) {
  262. // If a column has been specified in _groupRowsBy created a new array with the data grouped by that row
  263. this.groupedRows = this.groupArrayBy(this._rows, this._groupRowsBy);
  264. }
  265. this.cd.markForCheck();
  266. },
  267. enumerable: true,
  268. configurable: true
  269. });
  270. Object.defineProperty(DatatableComponent.prototype, "groupRowsBy", {
  271. get: /**
  272. * @return {?}
  273. */
  274. function () {
  275. return this._groupRowsBy;
  276. },
  277. /**
  278. * This attribute allows the user to set the name of the column to group the data with
  279. */
  280. set: /**
  281. * This attribute allows the user to set the name of the column to group the data with
  282. * @param {?} val
  283. * @return {?}
  284. */
  285. function (val) {
  286. if (val) {
  287. this._groupRowsBy = val;
  288. if (this._rows && this._groupRowsBy) {
  289. // cretes a new array with the data grouped
  290. this.groupedRows = this.groupArrayBy(this._rows, this._groupRowsBy);
  291. }
  292. }
  293. },
  294. enumerable: true,
  295. configurable: true
  296. });
  297. Object.defineProperty(DatatableComponent.prototype, "columns", {
  298. /**
  299. * Get the columns.
  300. */
  301. get: /**
  302. * Get the columns.
  303. * @return {?}
  304. */
  305. function () {
  306. return this._columns;
  307. },
  308. /**
  309. * Columns to be displayed.
  310. */
  311. set: /**
  312. * Columns to be displayed.
  313. * @param {?} val
  314. * @return {?}
  315. */
  316. function (val) {
  317. if (val) {
  318. this._internalColumns = tslib_1.__spread(val);
  319. setColumnDefaults(this._internalColumns);
  320. this.recalculateColumns();
  321. }
  322. this._columns = val;
  323. },
  324. enumerable: true,
  325. configurable: true
  326. });
  327. Object.defineProperty(DatatableComponent.prototype, "limit", {
  328. /**
  329. * Gets the limit.
  330. */
  331. get: /**
  332. * Gets the limit.
  333. * @return {?}
  334. */
  335. function () {
  336. return this._limit;
  337. },
  338. /**
  339. * The page size to be shown.
  340. * Default value: `undefined`
  341. */
  342. set: /**
  343. * The page size to be shown.
  344. * Default value: `undefined`
  345. * @param {?} val
  346. * @return {?}
  347. */
  348. function (val) {
  349. this._limit = val;
  350. // recalculate sizes/etc
  351. this.recalculate();
  352. },
  353. enumerable: true,
  354. configurable: true
  355. });
  356. Object.defineProperty(DatatableComponent.prototype, "count", {
  357. /**
  358. * Gets the count.
  359. */
  360. get: /**
  361. * Gets the count.
  362. * @return {?}
  363. */
  364. function () {
  365. return this._count;
  366. },
  367. /**
  368. * The total count of all rows.
  369. * Default value: `0`
  370. */
  371. set: /**
  372. * The total count of all rows.
  373. * Default value: `0`
  374. * @param {?} val
  375. * @return {?}
  376. */
  377. function (val) {
  378. this._count = val;
  379. // recalculate sizes/etc
  380. this.recalculate();
  381. },
  382. enumerable: true,
  383. configurable: true
  384. });
  385. Object.defineProperty(DatatableComponent.prototype, "offset", {
  386. get: /**
  387. * @return {?}
  388. */
  389. function () {
  390. return Math.max(Math.min(this._offset, Math.ceil(this.rowCount / this.pageSize) - 1), 0);
  391. },
  392. /**
  393. * The current offset ( page - 1 ) shown.
  394. * Default value: `0`
  395. */
  396. set: /**
  397. * The current offset ( page - 1 ) shown.
  398. * Default value: `0`
  399. * @param {?} val
  400. * @return {?}
  401. */
  402. function (val) {
  403. this._offset = val;
  404. },
  405. enumerable: true,
  406. configurable: true
  407. });
  408. Object.defineProperty(DatatableComponent.prototype, "isFixedHeader", {
  409. /**
  410. * CSS class applied if the header height if fixed height.
  411. */
  412. get: /**
  413. * CSS class applied if the header height if fixed height.
  414. * @return {?}
  415. */
  416. function () {
  417. /** @type {?} */
  418. var headerHeight = this.headerHeight;
  419. return typeof headerHeight === 'string' ? (/** @type {?} */ (headerHeight)) !== 'auto' : true;
  420. },
  421. enumerable: true,
  422. configurable: true
  423. });
  424. Object.defineProperty(DatatableComponent.prototype, "isFixedRow", {
  425. /**
  426. * CSS class applied to the root element if
  427. * the row heights are fixed heights.
  428. */
  429. get: /**
  430. * CSS class applied to the root element if
  431. * the row heights are fixed heights.
  432. * @return {?}
  433. */
  434. function () {
  435. return this.rowHeight !== 'auto';
  436. },
  437. enumerable: true,
  438. configurable: true
  439. });
  440. Object.defineProperty(DatatableComponent.prototype, "isVertScroll", {
  441. /**
  442. * CSS class applied to root element if
  443. * vertical scrolling is enabled.
  444. */
  445. get: /**
  446. * CSS class applied to root element if
  447. * vertical scrolling is enabled.
  448. * @return {?}
  449. */
  450. function () {
  451. return this.scrollbarV;
  452. },
  453. enumerable: true,
  454. configurable: true
  455. });
  456. Object.defineProperty(DatatableComponent.prototype, "isVirtualized", {
  457. /**
  458. * CSS class applied to root element if
  459. * virtualization is enabled.
  460. */
  461. get: /**
  462. * CSS class applied to root element if
  463. * virtualization is enabled.
  464. * @return {?}
  465. */
  466. function () {
  467. return this.virtualization;
  468. },
  469. enumerable: true,
  470. configurable: true
  471. });
  472. Object.defineProperty(DatatableComponent.prototype, "isHorScroll", {
  473. /**
  474. * CSS class applied to the root element
  475. * if the horziontal scrolling is enabled.
  476. */
  477. get: /**
  478. * CSS class applied to the root element
  479. * if the horziontal scrolling is enabled.
  480. * @return {?}
  481. */
  482. function () {
  483. return this.scrollbarH;
  484. },
  485. enumerable: true,
  486. configurable: true
  487. });
  488. Object.defineProperty(DatatableComponent.prototype, "isSelectable", {
  489. /**
  490. * CSS class applied to root element is selectable.
  491. */
  492. get: /**
  493. * CSS class applied to root element is selectable.
  494. * @return {?}
  495. */
  496. function () {
  497. return this.selectionType !== undefined;
  498. },
  499. enumerable: true,
  500. configurable: true
  501. });
  502. Object.defineProperty(DatatableComponent.prototype, "isCheckboxSelection", {
  503. /**
  504. * CSS class applied to root is checkbox selection.
  505. */
  506. get: /**
  507. * CSS class applied to root is checkbox selection.
  508. * @return {?}
  509. */
  510. function () {
  511. return this.selectionType === SelectionType.checkbox;
  512. },
  513. enumerable: true,
  514. configurable: true
  515. });
  516. Object.defineProperty(DatatableComponent.prototype, "isCellSelection", {
  517. /**
  518. * CSS class applied to root if cell selection.
  519. */
  520. get: /**
  521. * CSS class applied to root if cell selection.
  522. * @return {?}
  523. */
  524. function () {
  525. return this.selectionType === SelectionType.cell;
  526. },
  527. enumerable: true,
  528. configurable: true
  529. });
  530. Object.defineProperty(DatatableComponent.prototype, "isSingleSelection", {
  531. /**
  532. * CSS class applied to root if single select.
  533. */
  534. get: /**
  535. * CSS class applied to root if single select.
  536. * @return {?}
  537. */
  538. function () {
  539. return this.selectionType === SelectionType.single;
  540. },
  541. enumerable: true,
  542. configurable: true
  543. });
  544. Object.defineProperty(DatatableComponent.prototype, "isMultiSelection", {
  545. /**
  546. * CSS class added to root element if mulit select
  547. */
  548. get: /**
  549. * CSS class added to root element if mulit select
  550. * @return {?}
  551. */
  552. function () {
  553. return this.selectionType === SelectionType.multi;
  554. },
  555. enumerable: true,
  556. configurable: true
  557. });
  558. Object.defineProperty(DatatableComponent.prototype, "isMultiClickSelection", {
  559. /**
  560. * CSS class added to root element if mulit click select
  561. */
  562. get: /**
  563. * CSS class added to root element if mulit click select
  564. * @return {?}
  565. */
  566. function () {
  567. return this.selectionType === SelectionType.multiClick;
  568. },
  569. enumerable: true,
  570. configurable: true
  571. });
  572. Object.defineProperty(DatatableComponent.prototype, "columnTemplates", {
  573. /**
  574. * Returns the column templates.
  575. */
  576. get: /**
  577. * Returns the column templates.
  578. * @return {?}
  579. */
  580. function () {
  581. return this._columnTemplates;
  582. },
  583. /**
  584. * Column templates gathered from `ContentChildren`
  585. * if described in your markup.
  586. */
  587. set: /**
  588. * Column templates gathered from `ContentChildren`
  589. * if described in your markup.
  590. * @param {?} val
  591. * @return {?}
  592. */
  593. function (val) {
  594. this._columnTemplates = val;
  595. this.translateColumns(val);
  596. },
  597. enumerable: true,
  598. configurable: true
  599. });
  600. Object.defineProperty(DatatableComponent.prototype, "allRowsSelected", {
  601. /**
  602. * Returns if all rows are selected.
  603. */
  604. get: /**
  605. * Returns if all rows are selected.
  606. * @return {?}
  607. */
  608. function () {
  609. /** @type {?} */
  610. var allRowsSelected = this.rows && this.selected && this.selected.length === this.rows.length;
  611. if (this.selectAllRowsOnPage) {
  612. /** @type {?} */
  613. var indexes = this.bodyComponent.indexes;
  614. /** @type {?} */
  615. var rowsOnPage = indexes.last - indexes.first;
  616. allRowsSelected = this.selected.length === rowsOnPage;
  617. }
  618. return this.selected && this.rows && this.rows.length !== 0 && allRowsSelected;
  619. },
  620. enumerable: true,
  621. configurable: true
  622. });
  623. /**
  624. * Lifecycle hook that is called after data-bound
  625. * properties of a directive are initialized.
  626. */
  627. /**
  628. * Lifecycle hook that is called after data-bound
  629. * properties of a directive are initialized.
  630. * @return {?}
  631. */
  632. DatatableComponent.prototype.ngOnInit = /**
  633. * Lifecycle hook that is called after data-bound
  634. * properties of a directive are initialized.
  635. * @return {?}
  636. */
  637. function () {
  638. // need to call this immediatly to size
  639. // if the table is hidden the visibility
  640. // listener will invoke this itself upon show
  641. this.recalculate();
  642. };
  643. /**
  644. * Lifecycle hook that is called after a component's
  645. * view has been fully initialized.
  646. */
  647. /**
  648. * Lifecycle hook that is called after a component's
  649. * view has been fully initialized.
  650. * @return {?}
  651. */
  652. DatatableComponent.prototype.ngAfterViewInit = /**
  653. * Lifecycle hook that is called after a component's
  654. * view has been fully initialized.
  655. * @return {?}
  656. */
  657. function () {
  658. var _this = this;
  659. if (!this.externalSorting) {
  660. this.sortInternalRows();
  661. }
  662. // this has to be done to prevent the change detection
  663. // tree from freaking out because we are readjusting
  664. if (typeof requestAnimationFrame === 'undefined') {
  665. return;
  666. }
  667. requestAnimationFrame((/**
  668. * @return {?}
  669. */
  670. function () {
  671. _this.recalculate();
  672. // emit page for virtual server-side kickoff
  673. if (_this.externalPaging && _this.scrollbarV) {
  674. _this.page.emit({
  675. count: _this.count,
  676. pageSize: _this.pageSize,
  677. limit: _this.limit,
  678. offset: 0
  679. });
  680. }
  681. }));
  682. };
  683. /**
  684. * Lifecycle hook that is called after a component's
  685. * content has been fully initialized.
  686. */
  687. /**
  688. * Lifecycle hook that is called after a component's
  689. * content has been fully initialized.
  690. * @return {?}
  691. */
  692. DatatableComponent.prototype.ngAfterContentInit = /**
  693. * Lifecycle hook that is called after a component's
  694. * content has been fully initialized.
  695. * @return {?}
  696. */
  697. function () {
  698. var _this = this;
  699. this.columnTemplates.changes.subscribe((/**
  700. * @param {?} v
  701. * @return {?}
  702. */
  703. function (v) { return _this.translateColumns(v); }));
  704. this.listenForColumnInputChanges();
  705. };
  706. /**
  707. * Translates the templates to the column objects
  708. */
  709. /**
  710. * Translates the templates to the column objects
  711. * @param {?} val
  712. * @return {?}
  713. */
  714. DatatableComponent.prototype.translateColumns = /**
  715. * Translates the templates to the column objects
  716. * @param {?} val
  717. * @return {?}
  718. */
  719. function (val) {
  720. if (val) {
  721. /** @type {?} */
  722. var arr = val.toArray();
  723. if (arr.length) {
  724. this._internalColumns = translateTemplates(arr);
  725. setColumnDefaults(this._internalColumns);
  726. this.recalculateColumns();
  727. this.sortInternalRows();
  728. this.cd.markForCheck();
  729. }
  730. }
  731. };
  732. /**
  733. * Creates a map with the data grouped by the user choice of grouping index
  734. *
  735. * @param originalArray the original array passed via parameter
  736. * @param groupByIndex the index of the column to group the data by
  737. */
  738. /**
  739. * Creates a map with the data grouped by the user choice of grouping index
  740. *
  741. * @param {?} originalArray the original array passed via parameter
  742. * @param {?} groupBy
  743. * @return {?}
  744. */
  745. DatatableComponent.prototype.groupArrayBy = /**
  746. * Creates a map with the data grouped by the user choice of grouping index
  747. *
  748. * @param {?} originalArray the original array passed via parameter
  749. * @param {?} groupBy
  750. * @return {?}
  751. */
  752. function (originalArray, groupBy) {
  753. // create a map to hold groups with their corresponding results
  754. /** @type {?} */
  755. var map = new Map();
  756. /** @type {?} */
  757. var i = 0;
  758. originalArray.forEach((/**
  759. * @param {?} item
  760. * @return {?}
  761. */
  762. function (item) {
  763. /** @type {?} */
  764. var key = item[groupBy];
  765. if (!map.has(key)) {
  766. map.set(key, [item]);
  767. }
  768. else {
  769. map.get(key).push(item);
  770. }
  771. i++;
  772. }));
  773. /** @type {?} */
  774. var addGroup = (/**
  775. * @param {?} key
  776. * @param {?} value
  777. * @return {?}
  778. */
  779. function (key, value) {
  780. return { key: key, value: value };
  781. });
  782. // convert map back to a simple array of objects
  783. return Array.from(map, (/**
  784. * @param {?} x
  785. * @return {?}
  786. */
  787. function (x) { return addGroup(x[0], x[1]); }));
  788. };
  789. /*
  790. * Lifecycle hook that is called when Angular dirty checks a directive.
  791. */
  792. /*
  793. * Lifecycle hook that is called when Angular dirty checks a directive.
  794. */
  795. /**
  796. * @return {?}
  797. */
  798. DatatableComponent.prototype.ngDoCheck = /*
  799. * Lifecycle hook that is called when Angular dirty checks a directive.
  800. */
  801. /**
  802. * @return {?}
  803. */
  804. function () {
  805. if (this.rowDiffer.diff(this.rows)) {
  806. if (!this.externalSorting) {
  807. this.sortInternalRows();
  808. }
  809. else {
  810. this._internalRows = tslib_1.__spread(this.rows);
  811. }
  812. // auto group by parent on new update
  813. this._internalRows = groupRowsByParents(this._internalRows, optionalGetterForProp(this.treeFromRelation), optionalGetterForProp(this.treeToRelation));
  814. this.recalculatePages();
  815. this.cd.markForCheck();
  816. }
  817. };
  818. /**
  819. * Recalc's the sizes of the grid.
  820. *
  821. * Updated automatically on changes to:
  822. *
  823. * - Columns
  824. * - Rows
  825. * - Paging related
  826. *
  827. * Also can be manually invoked or upon window resize.
  828. */
  829. /**
  830. * Recalc's the sizes of the grid.
  831. *
  832. * Updated automatically on changes to:
  833. *
  834. * - Columns
  835. * - Rows
  836. * - Paging related
  837. *
  838. * Also can be manually invoked or upon window resize.
  839. * @return {?}
  840. */
  841. DatatableComponent.prototype.recalculate = /**
  842. * Recalc's the sizes of the grid.
  843. *
  844. * Updated automatically on changes to:
  845. *
  846. * - Columns
  847. * - Rows
  848. * - Paging related
  849. *
  850. * Also can be manually invoked or upon window resize.
  851. * @return {?}
  852. */
  853. function () {
  854. this.recalculateDims();
  855. this.recalculateColumns();
  856. };
  857. /**
  858. * Window resize handler to update sizes.
  859. */
  860. /**
  861. * Window resize handler to update sizes.
  862. * @return {?}
  863. */
  864. DatatableComponent.prototype.onWindowResize = /**
  865. * Window resize handler to update sizes.
  866. * @return {?}
  867. */
  868. function () {
  869. this.recalculate();
  870. };
  871. /**
  872. * Recalulcates the column widths based on column width
  873. * distribution mode and scrollbar offsets.
  874. */
  875. /**
  876. * Recalulcates the column widths based on column width
  877. * distribution mode and scrollbar offsets.
  878. * @param {?=} columns
  879. * @param {?=} forceIdx
  880. * @param {?=} allowBleed
  881. * @return {?}
  882. */
  883. DatatableComponent.prototype.recalculateColumns = /**
  884. * Recalulcates the column widths based on column width
  885. * distribution mode and scrollbar offsets.
  886. * @param {?=} columns
  887. * @param {?=} forceIdx
  888. * @param {?=} allowBleed
  889. * @return {?}
  890. */
  891. function (columns, forceIdx, allowBleed) {
  892. if (columns === void 0) { columns = this._internalColumns; }
  893. if (forceIdx === void 0) { forceIdx = -1; }
  894. if (allowBleed === void 0) { allowBleed = this.scrollbarH; }
  895. if (!columns)
  896. return undefined;
  897. /** @type {?} */
  898. var width = this._innerWidth;
  899. if (this.scrollbarV) {
  900. width = width - this.scrollbarHelper.width;
  901. }
  902. if (this.columnMode === ColumnMode.force) {
  903. forceFillColumnWidths(columns, width, forceIdx, allowBleed);
  904. }
  905. else if (this.columnMode === ColumnMode.flex) {
  906. adjustColumnWidths(columns, width);
  907. }
  908. return columns;
  909. };
  910. /**
  911. * Recalculates the dimensions of the table size.
  912. * Internally calls the page size and row count calcs too.
  913. *
  914. */
  915. /**
  916. * Recalculates the dimensions of the table size.
  917. * Internally calls the page size and row count calcs too.
  918. *
  919. * @return {?}
  920. */
  921. DatatableComponent.prototype.recalculateDims = /**
  922. * Recalculates the dimensions of the table size.
  923. * Internally calls the page size and row count calcs too.
  924. *
  925. * @return {?}
  926. */
  927. function () {
  928. /** @type {?} */
  929. var dims = this.dimensionsHelper.getDimensions(this.element);
  930. this._innerWidth = Math.floor(dims.width);
  931. if (this.scrollbarV) {
  932. /** @type {?} */
  933. var height = dims.height;
  934. if (this.headerHeight)
  935. height = height - this.headerHeight;
  936. if (this.footerHeight)
  937. height = height - this.footerHeight;
  938. this.bodyHeight = height;
  939. }
  940. this.recalculatePages();
  941. };
  942. /**
  943. * Recalculates the pages after a update.
  944. */
  945. /**
  946. * Recalculates the pages after a update.
  947. * @return {?}
  948. */
  949. DatatableComponent.prototype.recalculatePages = /**
  950. * Recalculates the pages after a update.
  951. * @return {?}
  952. */
  953. function () {
  954. this.pageSize = this.calcPageSize();
  955. this.rowCount = this.calcRowCount();
  956. };
  957. /**
  958. * Body triggered a page event.
  959. */
  960. /**
  961. * Body triggered a page event.
  962. * @param {?} __0
  963. * @return {?}
  964. */
  965. DatatableComponent.prototype.onBodyPage = /**
  966. * Body triggered a page event.
  967. * @param {?} __0
  968. * @return {?}
  969. */
  970. function (_a) {
  971. var offset = _a.offset;
  972. // Avoid pagination caming from body events like scroll when the table
  973. // has no virtualization and the external paging is enable.
  974. // This means, let's the developer handle pagination by my him(her) self
  975. if (this.externalPaging && !this.virtualization) {
  976. return;
  977. }
  978. this.offset = offset;
  979. this.page.emit({
  980. count: this.count,
  981. pageSize: this.pageSize,
  982. limit: this.limit,
  983. offset: this.offset
  984. });
  985. };
  986. /**
  987. * The body triggered a scroll event.
  988. */
  989. /**
  990. * The body triggered a scroll event.
  991. * @param {?} event
  992. * @return {?}
  993. */
  994. DatatableComponent.prototype.onBodyScroll = /**
  995. * The body triggered a scroll event.
  996. * @param {?} event
  997. * @return {?}
  998. */
  999. function (event) {
  1000. this._offsetX.next(event.offsetX);
  1001. this.scroll.emit(event);
  1002. this.cd.detectChanges();
  1003. };
  1004. /**
  1005. * The footer triggered a page event.
  1006. */
  1007. /**
  1008. * The footer triggered a page event.
  1009. * @param {?} event
  1010. * @return {?}
  1011. */
  1012. DatatableComponent.prototype.onFooterPage = /**
  1013. * The footer triggered a page event.
  1014. * @param {?} event
  1015. * @return {?}
  1016. */
  1017. function (event) {
  1018. this.offset = event.page - 1;
  1019. this.bodyComponent.updateOffsetY(this.offset);
  1020. this.page.emit({
  1021. count: this.count,
  1022. pageSize: this.pageSize,
  1023. limit: this.limit,
  1024. offset: this.offset
  1025. });
  1026. if (this.selectAllRowsOnPage) {
  1027. this.selected = [];
  1028. this.select.emit({
  1029. selected: this.selected
  1030. });
  1031. }
  1032. };
  1033. /**
  1034. * Recalculates the sizes of the page
  1035. */
  1036. /**
  1037. * Recalculates the sizes of the page
  1038. * @param {?=} val
  1039. * @return {?}
  1040. */
  1041. DatatableComponent.prototype.calcPageSize = /**
  1042. * Recalculates the sizes of the page
  1043. * @param {?=} val
  1044. * @return {?}
  1045. */
  1046. function (val) {
  1047. if (val === void 0) { val = this.rows; }
  1048. // Keep the page size constant even if the row has been expanded.
  1049. // This is because an expanded row is still considered to be a child of
  1050. // the original row. Hence calculation would use rowHeight only.
  1051. if (this.scrollbarV && this.virtualization) {
  1052. /** @type {?} */
  1053. var size = Math.ceil(this.bodyHeight / ((/** @type {?} */ (this.rowHeight))));
  1054. return Math.max(size, 0);
  1055. }
  1056. // if limit is passed, we are paging
  1057. if (this.limit !== undefined) {
  1058. return this.limit;
  1059. }
  1060. // otherwise use row length
  1061. if (val) {
  1062. return val.length;
  1063. }
  1064. // other empty :(
  1065. return 0;
  1066. };
  1067. /**
  1068. * Calculates the row count.
  1069. */
  1070. /**
  1071. * Calculates the row count.
  1072. * @param {?=} val
  1073. * @return {?}
  1074. */
  1075. DatatableComponent.prototype.calcRowCount = /**
  1076. * Calculates the row count.
  1077. * @param {?=} val
  1078. * @return {?}
  1079. */
  1080. function (val) {
  1081. if (val === void 0) { val = this.rows; }
  1082. if (!this.externalPaging) {
  1083. if (!val)
  1084. return 0;
  1085. if (this.groupedRows) {
  1086. return this.groupedRows.length;
  1087. }
  1088. else if (this.treeFromRelation != null && this.treeToRelation != null) {
  1089. return this._internalRows.length;
  1090. }
  1091. else {
  1092. return val.length;
  1093. }
  1094. }
  1095. return this.count;
  1096. };
  1097. /**
  1098. * The header triggered a contextmenu event.
  1099. */
  1100. /**
  1101. * The header triggered a contextmenu event.
  1102. * @param {?} __0
  1103. * @return {?}
  1104. */
  1105. DatatableComponent.prototype.onColumnContextmenu = /**
  1106. * The header triggered a contextmenu event.
  1107. * @param {?} __0
  1108. * @return {?}
  1109. */
  1110. function (_a) {
  1111. var event = _a.event, column = _a.column;
  1112. this.tableContextmenu.emit({ event: event, type: ContextmenuType.header, content: column });
  1113. };
  1114. /**
  1115. * The body triggered a contextmenu event.
  1116. */
  1117. /**
  1118. * The body triggered a contextmenu event.
  1119. * @param {?} __0
  1120. * @return {?}
  1121. */
  1122. DatatableComponent.prototype.onRowContextmenu = /**
  1123. * The body triggered a contextmenu event.
  1124. * @param {?} __0
  1125. * @return {?}
  1126. */
  1127. function (_a) {
  1128. var event = _a.event, row = _a.row;
  1129. this.tableContextmenu.emit({ event: event, type: ContextmenuType.body, content: row });
  1130. };
  1131. /**
  1132. * The header triggered a column resize event.
  1133. */
  1134. /**
  1135. * The header triggered a column resize event.
  1136. * @param {?} __0
  1137. * @return {?}
  1138. */
  1139. DatatableComponent.prototype.onColumnResize = /**
  1140. * The header triggered a column resize event.
  1141. * @param {?} __0
  1142. * @return {?}
  1143. */
  1144. function (_a) {
  1145. var column = _a.column, newValue = _a.newValue;
  1146. /* Safari/iOS 10.2 workaround */
  1147. if (column === undefined) {
  1148. return;
  1149. }
  1150. /** @type {?} */
  1151. var idx;
  1152. /** @type {?} */
  1153. var cols = this._internalColumns.map((/**
  1154. * @param {?} c
  1155. * @param {?} i
  1156. * @return {?}
  1157. */
  1158. function (c, i) {
  1159. c = tslib_1.__assign({}, c);
  1160. if (c.$$id === column.$$id) {
  1161. idx = i;
  1162. c.width = newValue;
  1163. // set this so we can force the column
  1164. // width distribution to be to this value
  1165. c.$$oldWidth = newValue;
  1166. }
  1167. return c;
  1168. }));
  1169. this.recalculateColumns(cols, idx);
  1170. this._internalColumns = cols;
  1171. this.resize.emit({
  1172. column: column,
  1173. newValue: newValue
  1174. });
  1175. };
  1176. /**
  1177. * The header triggered a column re-order event.
  1178. */
  1179. /**
  1180. * The header triggered a column re-order event.
  1181. * @param {?} __0
  1182. * @return {?}
  1183. */
  1184. DatatableComponent.prototype.onColumnReorder = /**
  1185. * The header triggered a column re-order event.
  1186. * @param {?} __0
  1187. * @return {?}
  1188. */
  1189. function (_a) {
  1190. var column = _a.column, newValue = _a.newValue, prevValue = _a.prevValue;
  1191. /** @type {?} */
  1192. var cols = this._internalColumns.map((/**
  1193. * @param {?} c
  1194. * @return {?}
  1195. */
  1196. function (c) {
  1197. return tslib_1.__assign({}, c);
  1198. }));
  1199. if (this.swapColumns) {
  1200. /** @type {?} */
  1201. var prevCol = cols[newValue];
  1202. cols[newValue] = column;
  1203. cols[prevValue] = prevCol;
  1204. }
  1205. else {
  1206. if (newValue > prevValue) {
  1207. /** @type {?} */
  1208. var movedCol = cols[prevValue];
  1209. for (var i = prevValue; i < newValue; i++) {
  1210. cols[i] = cols[i + 1];
  1211. }
  1212. cols[newValue] = movedCol;
  1213. }
  1214. else {
  1215. /** @type {?} */
  1216. var movedCol = cols[prevValue];
  1217. for (var i = prevValue; i > newValue; i--) {
  1218. cols[i] = cols[i - 1];
  1219. }
  1220. cols[newValue] = movedCol;
  1221. }
  1222. }
  1223. this._internalColumns = cols;
  1224. this.reorder.emit({
  1225. column: column,
  1226. newValue: newValue,
  1227. prevValue: prevValue
  1228. });
  1229. };
  1230. /**
  1231. * The header triggered a column sort event.
  1232. */
  1233. /**
  1234. * The header triggered a column sort event.
  1235. * @param {?} event
  1236. * @return {?}
  1237. */
  1238. DatatableComponent.prototype.onColumnSort = /**
  1239. * The header triggered a column sort event.
  1240. * @param {?} event
  1241. * @return {?}
  1242. */
  1243. function (event) {
  1244. // clean selected rows
  1245. if (this.selectAllRowsOnPage) {
  1246. this.selected = [];
  1247. this.select.emit({
  1248. selected: this.selected
  1249. });
  1250. }
  1251. this.sorts = event.sorts;
  1252. // this could be optimized better since it will resort
  1253. // the rows again on the 'push' detection...
  1254. if (this.externalSorting === false) {
  1255. // don't use normal setter so we don't resort
  1256. this.sortInternalRows();
  1257. }
  1258. // auto group by parent on new update
  1259. this._internalRows = groupRowsByParents(this._internalRows, optionalGetterForProp(this.treeFromRelation), optionalGetterForProp(this.treeToRelation));
  1260. // Always go to first page when sorting to see the newly sorted data
  1261. this.offset = 0;
  1262. this.bodyComponent.updateOffsetY(this.offset);
  1263. this.sort.emit(event);
  1264. };
  1265. /**
  1266. * Toggle all row selection
  1267. */
  1268. /**
  1269. * Toggle all row selection
  1270. * @param {?} event
  1271. * @return {?}
  1272. */
  1273. DatatableComponent.prototype.onHeaderSelect = /**
  1274. * Toggle all row selection
  1275. * @param {?} event
  1276. * @return {?}
  1277. */
  1278. function (event) {
  1279. var _a, _b;
  1280. if (this.selectAllRowsOnPage) {
  1281. // before we splice, chk if we currently have all selected
  1282. /** @type {?} */
  1283. var first = this.bodyComponent.indexes.first;
  1284. /** @type {?} */
  1285. var last = this.bodyComponent.indexes.last;
  1286. /** @type {?} */
  1287. var allSelected = this.selected.length === last - first;
  1288. // remove all existing either way
  1289. this.selected = [];
  1290. // do the opposite here
  1291. if (!allSelected) {
  1292. (_a = this.selected).push.apply(_a, tslib_1.__spread(this._internalRows.slice(first, last)));
  1293. }
  1294. }
  1295. else {
  1296. // before we splice, chk if we currently have all selected
  1297. /** @type {?} */
  1298. var allSelected = this.selected.length === this.rows.length;
  1299. // remove all existing either way
  1300. this.selected = [];
  1301. // do the opposite here
  1302. if (!allSelected) {
  1303. (_b = this.selected).push.apply(_b, tslib_1.__spread(this.rows));
  1304. }
  1305. }
  1306. this.select.emit({
  1307. selected: this.selected
  1308. });
  1309. };
  1310. /**
  1311. * A row was selected from body
  1312. */
  1313. /**
  1314. * A row was selected from body
  1315. * @param {?} event
  1316. * @return {?}
  1317. */
  1318. DatatableComponent.prototype.onBodySelect = /**
  1319. * A row was selected from body
  1320. * @param {?} event
  1321. * @return {?}
  1322. */
  1323. function (event) {
  1324. this.select.emit(event);
  1325. };
  1326. /**
  1327. * A row was expanded or collapsed for tree
  1328. */
  1329. /**
  1330. * A row was expanded or collapsed for tree
  1331. * @param {?} event
  1332. * @return {?}
  1333. */
  1334. DatatableComponent.prototype.onTreeAction = /**
  1335. * A row was expanded or collapsed for tree
  1336. * @param {?} event
  1337. * @return {?}
  1338. */
  1339. function (event) {
  1340. var _this = this;
  1341. /** @type {?} */
  1342. var row = event.row;
  1343. // TODO: For duplicated items this will not work
  1344. /** @type {?} */
  1345. var rowIndex = this._rows.findIndex((/**
  1346. * @param {?} r
  1347. * @return {?}
  1348. */
  1349. function (r) { return r[_this.treeToRelation] === event.row[_this.treeToRelation]; }));
  1350. this.treeAction.emit({ row: row, rowIndex: rowIndex });
  1351. };
  1352. /**
  1353. * @return {?}
  1354. */
  1355. DatatableComponent.prototype.ngOnDestroy = /**
  1356. * @return {?}
  1357. */
  1358. function () {
  1359. this._subscriptions.forEach((/**
  1360. * @param {?} subscription
  1361. * @return {?}
  1362. */
  1363. function (subscription) { return subscription.unsubscribe(); }));
  1364. };
  1365. /**
  1366. * listen for changes to input bindings of all DataTableColumnDirective and
  1367. * trigger the columnTemplates.changes observable to emit
  1368. */
  1369. /**
  1370. * listen for changes to input bindings of all DataTableColumnDirective and
  1371. * trigger the columnTemplates.changes observable to emit
  1372. * @private
  1373. * @return {?}
  1374. */
  1375. DatatableComponent.prototype.listenForColumnInputChanges = /**
  1376. * listen for changes to input bindings of all DataTableColumnDirective and
  1377. * trigger the columnTemplates.changes observable to emit
  1378. * @private
  1379. * @return {?}
  1380. */
  1381. function () {
  1382. var _this = this;
  1383. this._subscriptions.push(this.columnChangesService.columnInputChanges$.subscribe((/**
  1384. * @return {?}
  1385. */
  1386. function () {
  1387. if (_this.columnTemplates) {
  1388. _this.columnTemplates.notifyOnChanges();
  1389. }
  1390. })));
  1391. };
  1392. /**
  1393. * @private
  1394. * @return {?}
  1395. */
  1396. DatatableComponent.prototype.sortInternalRows = /**
  1397. * @private
  1398. * @return {?}
  1399. */
  1400. function () {
  1401. this._internalRows = sortRows(this._internalRows, this._internalColumns, this.sorts);
  1402. };
  1403. DatatableComponent.decorators = [
  1404. { type: Component, args: [{
  1405. selector: 'ngx-datatable',
  1406. template: "<div visibilityObserver (visible)=\"recalculate()\">\n <datatable-header\n *ngIf=\"headerHeight\"\n [sorts]=\"sorts\"\n [sortType]=\"sortType\"\n [scrollbarH]=\"scrollbarH\"\n [innerWidth]=\"_innerWidth\"\n [offsetX]=\"_offsetX | async\"\n [dealsWithGroup]=\"groupedRows !== undefined\"\n [columns]=\"_internalColumns\"\n [headerHeight]=\"headerHeight\"\n [reorderable]=\"reorderable\"\n [targetMarkerTemplate]=\"targetMarkerTemplate\"\n [sortAscendingIcon]=\"cssClasses.sortAscending\"\n [sortDescendingIcon]=\"cssClasses.sortDescending\"\n [allRowsSelected]=\"allRowsSelected\"\n [selectionType]=\"selectionType\"\n (sort)=\"onColumnSort($event)\"\n (resize)=\"onColumnResize($event)\"\n (reorder)=\"onColumnReorder($event)\"\n (select)=\"onHeaderSelect($event)\"\n (columnContextmenu)=\"onColumnContextmenu($event)\"\n >\n </datatable-header>\n <datatable-body\n [groupRowsBy]=\"groupRowsBy\"\n [groupedRows]=\"groupedRows\"\n [rows]=\"_internalRows\"\n [groupExpansionDefault]=\"groupExpansionDefault\"\n [scrollbarV]=\"scrollbarV\"\n [scrollbarH]=\"scrollbarH\"\n [virtualization]=\"virtualization\"\n [loadingIndicator]=\"loadingIndicator\"\n [externalPaging]=\"externalPaging\"\n [rowHeight]=\"rowHeight\"\n [rowCount]=\"rowCount\"\n [offset]=\"offset\"\n [trackByProp]=\"trackByProp\"\n [columns]=\"_internalColumns\"\n [pageSize]=\"pageSize\"\n [offsetX]=\"_offsetX | async\"\n [rowDetail]=\"rowDetail\"\n [groupHeader]=\"groupHeader\"\n [selected]=\"selected\"\n [innerWidth]=\"_innerWidth\"\n [bodyHeight]=\"bodyHeight\"\n [selectionType]=\"selectionType\"\n [emptyMessage]=\"messages.emptyMessage\"\n [rowIdentity]=\"rowIdentity\"\n [rowClass]=\"rowClass\"\n [selectCheck]=\"selectCheck\"\n [displayCheck]=\"displayCheck\"\n [summaryRow]=\"summaryRow\"\n [summaryHeight]=\"summaryHeight\"\n [summaryPosition]=\"summaryPosition\"\n (page)=\"onBodyPage($event)\"\n (activate)=\"activate.emit($event)\"\n (rowContextmenu)=\"onRowContextmenu($event)\"\n (select)=\"onBodySelect($event)\"\n (scroll)=\"onBodyScroll($event)\"\n (treeAction)=\"onTreeAction($event)\"\n >\n </datatable-body>\n <datatable-footer\n *ngIf=\"footerHeight\"\n [rowCount]=\"rowCount\"\n [pageSize]=\"pageSize\"\n [offset]=\"offset\"\n [footerHeight]=\"footerHeight\"\n [footerTemplate]=\"footer\"\n [totalMessage]=\"messages.totalMessage\"\n [pagerLeftArrowIcon]=\"cssClasses.pagerLeftArrow\"\n [pagerRightArrowIcon]=\"cssClasses.pagerRightArrow\"\n [pagerPreviousIcon]=\"cssClasses.pagerPrevious\"\n [selectedCount]=\"selected.length\"\n [selectedMessage]=\"!!selectionType && messages.selectedMessage\"\n [pagerNextIcon]=\"cssClasses.pagerNext\"\n (page)=\"onFooterPage($event)\"\n >\n </datatable-footer>\n</div>\n",
  1407. changeDetection: ChangeDetectionStrategy.OnPush,
  1408. encapsulation: ViewEncapsulation.None,
  1409. host: {
  1410. class: 'ngx-datatable'
  1411. },
  1412. styles: [".ngx-datatable{display:block;overflow:hidden;justify-content:center;position:relative;-webkit-transform:translate3d(0,0,0)}.ngx-datatable [hidden]{display:none!important}.ngx-datatable *,.ngx-datatable :after,.ngx-datatable :before{box-sizing:border-box}.ngx-datatable.scroll-vertical .datatable-body{overflow-y:auto}.ngx-datatable.scroll-vertical.virtualized .datatable-body .datatable-row-wrapper{position:absolute}.ngx-datatable.scroll-horz .datatable-body{overflow-x:auto;-webkit-overflow-scrolling:touch}.ngx-datatable.fixed-header .datatable-header .datatable-header-inner{white-space:nowrap}.ngx-datatable.fixed-header .datatable-header .datatable-header-inner .datatable-header-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ngx-datatable.fixed-row .datatable-scroll,.ngx-datatable.fixed-row .datatable-scroll .datatable-body-row{white-space:nowrap}.ngx-datatable.fixed-row .datatable-scroll .datatable-body-row .datatable-body-cell,.ngx-datatable.fixed-row .datatable-scroll .datatable-body-row .datatable-body-group-cell{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.ngx-datatable .datatable-body-row,.ngx-datatable .datatable-header-inner,.ngx-datatable .datatable-row-center{display:flex;flex-direction:row;-o-flex-flow:row;flex-flow:row}.ngx-datatable .datatable-body-cell,.ngx-datatable .datatable-header-cell{overflow-x:hidden;vertical-align:top;display:inline-block;line-height:1.625}.ngx-datatable .datatable-body-cell:focus,.ngx-datatable .datatable-header-cell:focus{outline:0}.ngx-datatable .datatable-row-left,.ngx-datatable .datatable-row-right{z-index:9}.ngx-datatable .datatable-row-center,.ngx-datatable .datatable-row-group,.ngx-datatable .datatable-row-left,.ngx-datatable .datatable-row-right{position:relative}.ngx-datatable .datatable-header{display:block;overflow:hidden}.ngx-datatable .datatable-header .datatable-header-inner{align-items:stretch;-webkit-align-items:stretch}.ngx-datatable .datatable-header .datatable-header-cell{position:relative;display:inline-block}.ngx-datatable .datatable-header .datatable-header-cell.sortable .datatable-header-cell-wrapper{cursor:pointer}.ngx-datatable .datatable-header .datatable-header-cell.longpress .datatable-header-cell-wrapper{cursor:move}.ngx-datatable .datatable-header .datatable-header-cell .sort-btn{line-height:100%;vertical-align:middle;display:inline-block;cursor:pointer}.ngx-datatable .datatable-header .datatable-header-cell .resize-handle,.ngx-datatable .datatable-header .datatable-header-cell .resize-handle--not-resizable{display:inline-block;position:absolute;right:0;top:0;bottom:0;width:5px;padding:0 4px;visibility:hidden}.ngx-datatable .datatable-header .datatable-header-cell .resize-handle{cursor:ew-resize}.ngx-datatable .datatable-header .datatable-header-cell.resizeable:hover .resize-handle,.ngx-datatable .datatable-header .datatable-header-cell:hover .resize-handle--not-resizable{visibility:visible}.ngx-datatable .datatable-header .datatable-header-cell .targetMarker{position:absolute;top:0;bottom:0}.ngx-datatable .datatable-header .datatable-header-cell .targetMarker.dragFromLeft{right:0}.ngx-datatable .datatable-header .datatable-header-cell .targetMarker.dragFromRight{left:0}.ngx-datatable .datatable-header .datatable-header-cell .datatable-header-cell-template-wrap{height:inherit}.ngx-datatable .datatable-body{position:relative;z-index:10;display:block}.ngx-datatable .datatable-body .datatable-scroll{display:inline-block}.ngx-datatable .datatable-body .datatable-row-detail{overflow-y:hidden}.ngx-datatable .datatable-body .datatable-row-wrapper{display:flex;flex-direction:column}.ngx-datatable .datatable-body .datatable-body-row{outline:0}.ngx-datatable .datatable-body .datatable-body-row>div{display:flex}.ngx-datatable .datatable-footer{display:block;width:100%;overflow:auto}.ngx-datatable .datatable-footer .datatable-footer-inner{display:flex;align-items:center;width:100%}.ngx-datatable .datatable-footer .selected-count .page-count{flex:1 1 40%}.ngx-datatable .datatable-footer .selected-count .datatable-pager{flex:1 1 60%}.ngx-datatable .datatable-footer .page-count{flex:1 1 20%}.ngx-datatable .datatable-footer .datatable-pager{flex:1 1 80%;text-align:right}.ngx-datatable .datatable-footer .datatable-pager .pager,.ngx-datatable .datatable-footer .datatable-pager .pager li{padding:0;margin:0;display:inline-block;list-style:none}.ngx-datatable .datatable-footer .datatable-pager .pager li,.ngx-datatable .datatable-footer .datatable-pager .pager li a{outline:0}.ngx-datatable .datatable-footer .datatable-pager .pager li a{cursor:pointer;display:inline-block}.ngx-datatable .datatable-footer .datatable-pager .pager li.disabled a{cursor:not-allowed}"]
  1413. }] }
  1414. ];
  1415. /** @nocollapse */
  1416. DatatableComponent.ctorParameters = function () { return [
  1417. { type: ScrollbarHelper, decorators: [{ type: SkipSelf }] },
  1418. { type: DimensionsHelper, decorators: [{ type: SkipSelf }] },
  1419. { type: ChangeDetectorRef },
  1420. { type: ElementRef },
  1421. { type: KeyValueDiffers },
  1422. { type: ColumnChangesService },
  1423. { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ['configuration',] }] }
  1424. ]; };
  1425. DatatableComponent.propDecorators = {
  1426. targetMarkerTemplate: [{ type: Input }],
  1427. rows: [{ type: Input }],
  1428. groupRowsBy: [{ type: Input }],
  1429. groupedRows: [{ type: Input }],
  1430. columns: [{ type: Input }],
  1431. selected: [{ type: Input }],
  1432. scrollbarV: [{ type: Input }],
  1433. scrollbarH: [{ type: Input }],
  1434. rowHeight: [{ type: Input }],
  1435. columnMode: [{ type: Input }],
  1436. headerHeight: [{ type: Input }],
  1437. footerHeight: [{ type: Input }],
  1438. externalPaging: [{ type: Input }],
  1439. externalSorting: [{ type: Input }],
  1440. limit: [{ type: Input }],
  1441. count: [{ type: Input }],
  1442. offset: [{ type: Input }],
  1443. loadingIndicator: [{ type: Input }],
  1444. selectionType: [{ type: Input }],
  1445. reorderable: [{ type: Input }],
  1446. swapColumns: [{ type: Input }],
  1447. sortType: [{ type: Input }],
  1448. sorts: [{ type: Input }],
  1449. cssClasses: [{ type: Input }],
  1450. messages: [{ type: Input }],
  1451. rowClass: [{ type: Input }],
  1452. selectCheck: [{ type: Input }],
  1453. displayCheck: [{ type: Input }],
  1454. groupExpansionDefault: [{ type: Input }],
  1455. trackByProp: [{ type: Input }],
  1456. selectAllRowsOnPage: [{ type: Input }],
  1457. virtualization: [{ type: Input }],
  1458. treeFromRelation: [{ type: Input }],
  1459. treeToRelation: [{ type: Input }],
  1460. summaryRow: [{ type: Input }],
  1461. summaryHeight: [{ type: Input }],
  1462. summaryPosition: [{ type: Input }],
  1463. scroll: [{ type: Output }],
  1464. activate: [{ type: Output }],
  1465. select: [{ type: Output }],
  1466. sort: [{ type: Output }],
  1467. page: [{ type: Output }],
  1468. reorder: [{ type: Output }],
  1469. resize: [{ type: Output }],
  1470. tableContextmenu: [{ type: Output }],
  1471. treeAction: [{ type: Output }],
  1472. isFixedHeader: [{ type: HostBinding, args: ['class.fixed-header',] }],
  1473. isFixedRow: [{ type: HostBinding, args: ['class.fixed-row',] }],
  1474. isVertScroll: [{ type: HostBinding, args: ['class.scroll-vertical',] }],
  1475. isVirtualized: [{ type: HostBinding, args: ['class.virtualized',] }],
  1476. isHorScroll: [{ type: HostBinding, args: ['class.scroll-horz',] }],
  1477. isSelectable: [{ type: HostBinding, args: ['class.selectable',] }],
  1478. isCheckboxSelection: [{ type: HostBinding, args: ['class.checkbox-selection',] }],
  1479. isCellSelection: [{ type: HostBinding, args: ['class.cell-selection',] }],
  1480. isSingleSelection: [{ type: HostBinding, args: ['class.single-selection',] }],
  1481. isMultiSelection: [{ type: HostBinding, args: ['class.multi-selection',] }],
  1482. isMultiClickSelection: [{ type: HostBinding, args: ['class.multi-click-selection',] }],
  1483. columnTemplates: [{ type: ContentChildren, args: [DataTableColumnDirective,] }],
  1484. rowDetail: [{ type: ContentChild, args: [DatatableRowDetailDirective, { static: false },] }],
  1485. groupHeader: [{ type: ContentChild, args: [DatatableGroupHeaderDirective, { static: false },] }],
  1486. footer: [{ type: ContentChild, args: [DatatableFooterDirective, { static: false },] }],
  1487. bodyComponent: [{ type: ViewChild, args: [DataTableBodyComponent, { static: false },] }],
  1488. headerComponent: [{ type: ViewChild, args: [DataTableHeaderComponent, { static: false },] }],
  1489. rowIdentity: [{ type: Input }],
  1490. onWindowResize: [{ type: HostListener, args: ['window:resize',] }]
  1491. };
  1492. tslib_1.__decorate([
  1493. throttleable(5),
  1494. tslib_1.__metadata("design:type", Function),
  1495. tslib_1.__metadata("design:paramtypes", []),
  1496. tslib_1.__metadata("design:returntype", void 0)
  1497. ], DatatableComponent.prototype, "onWindowResize", null);
  1498. return DatatableComponent;
  1499. }());
  1500. export { DatatableComponent };
  1501. if (false) {
  1502. /**
  1503. * Template for the target marker of drag target columns.
  1504. * @type {?}
  1505. */
  1506. DatatableComponent.prototype.targetMarkerTemplate;
  1507. /**
  1508. * This attribute allows the user to set a grouped array in the following format:
  1509. * [
  1510. * {groupid=1} [
  1511. * {id=1 name="test1"},
  1512. * {id=2 name="test2"},
  1513. * {id=3 name="test3"}
  1514. * ]},
  1515. * {groupid=2>[
  1516. * {id=4 name="test4"},
  1517. * {id=5 name="test5"},
  1518. * {id=6 name="test6"}
  1519. * ]}
  1520. * ]
  1521. * @type {?}
  1522. */
  1523. DatatableComponent.prototype.groupedRows;
  1524. /**
  1525. * List of row objects that should be
  1526. * represented as selected in the grid.
  1527. * Default value: `[]`
  1528. * @type {?}
  1529. */
  1530. DatatableComponent.prototype.selected;
  1531. /**
  1532. * Enable vertical scrollbars
  1533. * @type {?}
  1534. */
  1535. DatatableComponent.prototype.scrollbarV;
  1536. /**
  1537. * Enable horz scrollbars
  1538. * @type {?}
  1539. */
  1540. DatatableComponent.prototype.scrollbarH;
  1541. /**
  1542. * The row height; which is necessary
  1543. * to calculate the height for the lazy rendering.
  1544. * @type {?}
  1545. */
  1546. DatatableComponent.prototype.rowHeight;
  1547. /**
  1548. * Type of column width distribution formula.
  1549. * Example: flex, force, standard
  1550. * @type {?}
  1551. */
  1552. DatatableComponent.prototype.columnMode;
  1553. /**
  1554. * The minimum header height in pixels.
  1555. * Pass a falsey for no header
  1556. * @type {?}
  1557. */
  1558. DatatableComponent.prototype.headerHeight;
  1559. /**
  1560. * The minimum footer height in pixels.
  1561. * Pass falsey for no footer
  1562. * @type {?}
  1563. */
  1564. DatatableComponent.prototype.footerHeight;
  1565. /**
  1566. * If the table should use external paging
  1567. * otherwise its assumed that all data is preloaded.
  1568. * @type {?}
  1569. */
  1570. DatatableComponent.prototype.externalPaging;
  1571. /**
  1572. * If the table should use external sorting or
  1573. * the built-in basic sorting.
  1574. * @type {?}
  1575. */
  1576. DatatableComponent.prototype.externalSorting;
  1577. /**
  1578. * Show the linear loading bar.
  1579. * Default value: `false`
  1580. * @type {?}
  1581. */
  1582. DatatableComponent.prototype.loadingIndicator;
  1583. /**
  1584. * Type of row selection. Options are:
  1585. *
  1586. * - `single`
  1587. * - `multi`
  1588. * - `checkbox`
  1589. * - `multiClick`
  1590. * - `cell`
  1591. *
  1592. * For no selection pass a `falsey`.
  1593. * Default value: `undefined`
  1594. * @type {?}
  1595. */
  1596. DatatableComponent.prototype.selectionType;
  1597. /**
  1598. * Enable/Disable ability to re-order columns
  1599. * by dragging them.
  1600. * @type {?}
  1601. */
  1602. DatatableComponent.prototype.reorderable;
  1603. /**
  1604. * Swap columns on re-order columns or
  1605. * move them.
  1606. * @type {?}
  1607. */
  1608. DatatableComponent.prototype.swapColumns;
  1609. /**
  1610. * The type of sorting
  1611. * @type {?}
  1612. */
  1613. DatatableComponent.prototype.sortType;
  1614. /**
  1615. * Array of sorted columns by property and type.
  1616. * Default value: `[]`
  1617. * @type {?}
  1618. */
  1619. DatatableComponent.prototype.sorts;
  1620. /**
  1621. * Css class overrides
  1622. * @type {?}
  1623. */
  1624. DatatableComponent.prototype.cssClasses;
  1625. /**
  1626. * Message overrides for localization
  1627. *
  1628. * emptyMessage [default] = 'No data to display'
  1629. * totalMessage [default] = 'total'
  1630. * selectedMessage [default] = 'selected'
  1631. * @type {?}
  1632. */
  1633. DatatableComponent.prototype.messages;
  1634. /**
  1635. * Row specific classes.
  1636. * Similar implementation to ngClass.
  1637. *
  1638. * [rowClass]="'first second'"
  1639. * [rowClass]="{ 'first': true, 'second': true, 'third': false }"
  1640. * @type {?}
  1641. */
  1642. DatatableComponent.prototype.rowClass;
  1643. /**
  1644. * A boolean/function you can use to check whether you want
  1645. * to select a particular row based on a criteria. Example:
  1646. *
  1647. * (selection) => {
  1648. * return selection !== 'Ethel Price';
  1649. * }
  1650. * @type {?}
  1651. */
  1652. DatatableComponent.prototype.selectCheck;
  1653. /**
  1654. * A function you can use to check whether you want
  1655. * to show the checkbox for a particular row based on a criteria. Example:
  1656. *
  1657. * (row, column, value) => {
  1658. * return row.name !== 'Ethel Price';
  1659. * }
  1660. * @type {?}
  1661. */
  1662. DatatableComponent.prototype.displayCheck;
  1663. /**
  1664. * A boolean you can use to set the detault behaviour of rows and groups
  1665. * whether they will start expanded or not. If ommited the default is NOT expanded.
  1666. *
  1667. * @type {?}
  1668. */
  1669. DatatableComponent.prototype.groupExpansionDefault;
  1670. /**
  1671. * Property to which you can use for custom tracking of rows.
  1672. * Example: 'name'
  1673. * @type {?}
  1674. */
  1675. DatatableComponent.prototype.trackByProp;
  1676. /**
  1677. * Property to which you can use for determining select all
  1678. * rows on current page or not.
  1679. *
  1680. * \@memberOf DatatableComponent
  1681. * @type {?}
  1682. */
  1683. DatatableComponent.prototype.selectAllRowsOnPage;
  1684. /**
  1685. * A flag for row virtualization on / off
  1686. * @type {?}
  1687. */
  1688. DatatableComponent.prototype.virtualization;
  1689. /**
  1690. * Tree from relation
  1691. * @type {?}
  1692. */
  1693. DatatableComponent.prototype.treeFromRelation;
  1694. /**
  1695. * Tree to relation
  1696. * @type {?}
  1697. */
  1698. DatatableComponent.prototype.treeToRelation;
  1699. /**
  1700. * A flag for switching summary row on / off
  1701. * @type {?}
  1702. */
  1703. DatatableComponent.prototype.summaryRow;
  1704. /**
  1705. * A height of summary row
  1706. * @type {?}
  1707. */
  1708. DatatableComponent.prototype.summaryHeight;
  1709. /**
  1710. * A property holds a summary row position: top/bottom
  1711. * @type {?}
  1712. */
  1713. DatatableComponent.prototype.summaryPosition;
  1714. /**
  1715. * Body was scrolled typically in a `scrollbarV:true` scenario.
  1716. * @type {?}
  1717. */
  1718. DatatableComponent.prototype.scroll;
  1719. /**
  1720. * A cell or row was focused via keyboard or mouse click.
  1721. * @type {?}
  1722. */
  1723. DatatableComponent.prototype.activate;
  1724. /**
  1725. * A cell or row was selected.
  1726. * @type {?}
  1727. */
  1728. DatatableComponent.prototype.select;
  1729. /**
  1730. * Column sort was invoked.
  1731. * @type {?}
  1732. */
  1733. DatatableComponent.prototype.sort;
  1734. /**
  1735. * The table was paged either triggered by the pager or the body scroll.
  1736. * @type {?}
  1737. */
  1738. DatatableComponent.prototype.page;
  1739. /**
  1740. * Columns were re-ordered.
  1741. * @type {?}
  1742. */
  1743. DatatableComponent.prototype.reorder;
  1744. /**
  1745. * Column was resized.
  1746. * @type {?}
  1747. */
  1748. DatatableComponent.prototype.resize;
  1749. /**
  1750. * The context menu was invoked on the table.
  1751. * type indicates whether the header or the body was clicked.
  1752. * content contains either the column or the row that was clicked.
  1753. * @type {?}
  1754. */
  1755. DatatableComponent.prototype.tableContextmenu;
  1756. /**
  1757. * A row was expanded ot collapsed for tree
  1758. * @type {?}
  1759. */
  1760. DatatableComponent.prototype.treeAction;
  1761. /**
  1762. * Row Detail templates gathered from the ContentChild
  1763. * @type {?}
  1764. */
  1765. DatatableComponent.prototype.rowDetail;
  1766. /**
  1767. * Group Header templates gathered from the ContentChild
  1768. * @type {?}
  1769. */
  1770. DatatableComponent.prototype.groupHeader;
  1771. /**
  1772. * Footer template gathered from the ContentChild
  1773. * @type {?}
  1774. */
  1775. DatatableComponent.prototype.footer;
  1776. /**
  1777. * Reference to the body component for manually
  1778. * invoking functions on the body.
  1779. * @type {?}
  1780. */
  1781. DatatableComponent.prototype.bodyComponent;
  1782. /**
  1783. * Reference to the header component for manually
  1784. * invoking functions on the header.
  1785. *
  1786. * \@memberOf DatatableComponent
  1787. * @type {?}
  1788. */
  1789. DatatableComponent.prototype.headerComponent;
  1790. /** @type {?} */
  1791. DatatableComponent.prototype.element;
  1792. /** @type {?} */
  1793. DatatableComponent.prototype._innerWidth;
  1794. /** @type {?} */
  1795. DatatableComponent.prototype.pageSize;
  1796. /** @type {?} */
  1797. DatatableComponent.prototype.bodyHeight;
  1798. /** @type {?} */
  1799. DatatableComponent.prototype.rowCount;
  1800. /** @type {?} */
  1801. DatatableComponent.prototype.rowDiffer;
  1802. /** @type {?} */
  1803. DatatableComponent.prototype._offsetX;
  1804. /** @type {?} */
  1805. DatatableComponent.prototype._limit;
  1806. /** @type {?} */
  1807. DatatableComponent.prototype._count;
  1808. /** @type {?} */
  1809. DatatableComponent.prototype._offset;
  1810. /** @type {?} */
  1811. DatatableComponent.prototype._rows;
  1812. /** @type {?} */
  1813. DatatableComponent.prototype._groupRowsBy;
  1814. /** @type {?} */
  1815. DatatableComponent.prototype._internalRows;
  1816. /** @type {?} */
  1817. DatatableComponent.prototype._internalColumns;
  1818. /** @type {?} */
  1819. DatatableComponent.prototype._columns;
  1820. /** @type {?} */
  1821. DatatableComponent.prototype._columnTemplates;
  1822. /** @type {?} */
  1823. DatatableComponent.prototype._subscriptions;
  1824. /**
  1825. * This will be used when displaying or selecting rows.
  1826. * when tracking/comparing them, we'll use the value of this fn,
  1827. *
  1828. * (`fn(x) === fn(y)` instead of `x === y`)
  1829. * @type {?}
  1830. */
  1831. DatatableComponent.prototype.rowIdentity;
  1832. /**
  1833. * @type {?}
  1834. * @private
  1835. */
  1836. DatatableComponent.prototype.scrollbarHelper;
  1837. /**
  1838. * @type {?}
  1839. * @private
  1840. */
  1841. DatatableComponent.prototype.dimensionsHelper;
  1842. /**
  1843. * @type {?}
  1844. * @private
  1845. */
  1846. DatatableComponent.prototype.cd;
  1847. /**
  1848. * @type {?}
  1849. * @private
  1850. */
  1851. DatatableComponent.prototype.columnChangesService;
  1852. /**
  1853. * @type {?}
  1854. * @private
  1855. */
  1856. DatatableComponent.prototype.configuration;
  1857. }
  1858. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/datatable.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  ElementRef,\n  EventEmitter,\n  ViewChild,\n  HostListener,\n  ContentChildren,\n  OnInit,\n  QueryList,\n  AfterViewInit,\n  HostBinding,\n  ContentChild,\n  DoCheck,\n  KeyValueDiffers,\n  KeyValueDiffer,\n  ViewEncapsulation,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  SkipSelf,\n  OnDestroy,\n  Optional,\n  Inject\n} from '@angular/core';\n\nimport { DatatableGroupHeaderDirective } from './body/body-group-header.directive';\n\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { INgxDatatableConfig } from '../ngx-datatable.module';\nimport { groupRowsByParents, optionalGetterForProp } from '../utils/tree';\nimport { TableColumn } from '../types/table-column.type';\nimport { setColumnDefaults, translateTemplates } from '../utils/column-helper';\nimport { ColumnMode } from '../types/column-mode.type';\nimport { SelectionType } from '../types/selection.type';\nimport { SortType } from '../types/sort.type';\nimport { ContextmenuType } from '../types/contextmenu.type';\nimport { DataTableColumnDirective } from './columns/column.directive';\nimport { DatatableRowDetailDirective } from './row-detail/row-detail.directive';\nimport { DatatableFooterDirective } from './footer/footer.directive';\nimport { DataTableBodyComponent } from './body/body.component';\nimport { DataTableHeaderComponent } from './header/header.component';\nimport { ScrollbarHelper } from '../services/scrollbar-helper.service';\nimport { ColumnChangesService } from '../services/column-changes.service';\nimport { DimensionsHelper } from '../services/dimensions-helper.service';\nimport { throttleable } from '../utils/throttle';\nimport { forceFillColumnWidths, adjustColumnWidths } from '../utils/math';\nimport { sortRows } from '../utils/sort';\n\n@Component({\n  selector: 'ngx-datatable',\n  templateUrl: './datatable.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: ['./datatable.component.scss'],\n  host: {\n    class: 'ngx-datatable'\n  }\n})\nexport class DatatableComponent implements OnInit, DoCheck, AfterViewInit {\n  /**\n   * Template for the target marker of drag target columns.\n   */\n  @Input() targetMarkerTemplate: any;\n\n  /**\n   * Rows that are displayed in the table.\n   */\n  @Input() set rows(val: any) {\n    this._rows = val;\n\n    if (val) {\n      this._internalRows = [...val];\n    }\n\n    // auto sort on new updates\n    if (!this.externalSorting) {\n      this.sortInternalRows();\n    }\n\n    // auto group by parent on new update\n    this._internalRows = groupRowsByParents(\n      this._internalRows,\n      optionalGetterForProp(this.treeFromRelation),\n      optionalGetterForProp(this.treeToRelation)\n    );\n\n    // recalculate sizes/etc\n    this.recalculate();\n\n    if (this._rows && this._groupRowsBy) {\n      // If a column has been specified in _groupRowsBy created a new array with the data grouped by that row\n      this.groupedRows = this.groupArrayBy(this._rows, this._groupRowsBy);\n    }\n\n    this.cd.markForCheck();\n  }\n\n  /**\n   * Gets the rows.\n   */\n  get rows(): any {\n    return this._rows;\n  }\n\n  /**\n   * This attribute allows the user to set the name of the column to group the data with\n   */\n  @Input() set groupRowsBy(val: string) {\n    if (val) {\n      this._groupRowsBy = val;\n      if (this._rows && this._groupRowsBy) {\n        // cretes a new array with the data grouped\n        this.groupedRows = this.groupArrayBy(this._rows, this._groupRowsBy);\n      }\n    }\n  }\n\n  get groupRowsBy() {\n    return this._groupRowsBy;\n  }\n\n  /**\n   * This attribute allows the user to set a grouped array in the following format:\n   *  [\n   *    {groupid=1} [\n   *      {id=1 name=\"test1\"},\n   *      {id=2 name=\"test2\"},\n   *      {id=3 name=\"test3\"}\n   *    ]},\n   *    {groupid=2>[\n   *      {id=4 name=\"test4\"},\n   *      {id=5 name=\"test5\"},\n   *      {id=6 name=\"test6\"}\n   *    ]}\n   *  ]\n   */\n  @Input() groupedRows: any[];\n\n  /**\n   * Columns to be displayed.\n   */\n  @Input() set columns(val: TableColumn[]) {\n    if (val) {\n      this._internalColumns = [...val];\n      setColumnDefaults(this._internalColumns);\n      this.recalculateColumns();\n    }\n\n    this._columns = val;\n  }\n\n  /**\n   * Get the columns.\n   */\n  get columns(): TableColumn[] {\n    return this._columns;\n  }\n\n  /**\n   * List of row objects that should be\n   * represented as selected in the grid.\n   * Default value: `[]`\n   */\n  @Input() selected: any[] = [];\n\n  /**\n   * Enable vertical scrollbars\n   */\n  @Input() scrollbarV: boolean = false;\n\n  /**\n   * Enable horz scrollbars\n   */\n  @Input() scrollbarH: boolean = false;\n\n  /**\n   * The row height; which is necessary\n   * to calculate the height for the lazy rendering.\n   */\n  @Input() rowHeight: number | 'auto' | ((row?: any) => number) = 30;\n\n  /**\n   * Type of column width distribution formula.\n   * Example: flex, force, standard\n   */\n  @Input() columnMode: ColumnMode = ColumnMode.standard;\n\n  /**\n   * The minimum header height in pixels.\n   * Pass a falsey for no header\n   */\n  @Input() headerHeight: any = 30;\n\n  /**\n   * The minimum footer height in pixels.\n   * Pass falsey for no footer\n   */\n  @Input() footerHeight: number = 0;\n\n  /**\n   * If the table should use external paging\n   * otherwise its assumed that all data is preloaded.\n   */\n  @Input() externalPaging: boolean = false;\n\n  /**\n   * If the table should use external sorting or\n   * the built-in basic sorting.\n   */\n  @Input() externalSorting: boolean = false;\n\n  /**\n   * The page size to be shown.\n   * Default value: `undefined`\n   */\n  @Input() set limit(val: number | undefined) {\n    this._limit = val;\n\n    // recalculate sizes/etc\n    this.recalculate();\n  }\n\n  /**\n   * Gets the limit.\n   */\n  get limit(): number | undefined {\n    return this._limit;\n  }\n\n  /**\n   * The total count of all rows.\n   * Default value: `0`\n   */\n  @Input() set count(val: number) {\n    this._count = val;\n\n    // recalculate sizes/etc\n    this.recalculate();\n  }\n\n  /**\n   * Gets the count.\n   */\n  get count(): number {\n    return this._count;\n  }\n\n  /**\n   * The current offset ( page - 1 ) shown.\n   * Default value: `0`\n   */\n  @Input() set offset(val: number) {\n    this._offset = val;\n  }\n  get offset(): number {\n    return Math.max(Math.min(this._offset, Math.ceil(this.rowCount / this.pageSize) - 1), 0);\n  }\n\n  /**\n   * Show the linear loading bar.\n   * Default value: `false`\n   */\n  @Input() loadingIndicator: boolean = false;\n\n  /**\n   * Type of row selection. Options are:\n   *\n   *  - `single`\n   *  - `multi`\n   *  - `checkbox`\n   *  - `multiClick`\n   *  - `cell`\n   *\n   * For no selection pass a `falsey`.\n   * Default value: `undefined`\n   */\n  @Input() selectionType: SelectionType;\n\n  /**\n   * Enable/Disable ability to re-order columns\n   * by dragging them.\n   */\n  @Input() reorderable: boolean = true;\n\n  /**\n   * Swap columns on re-order columns or\n   * move them.\n   */\n  @Input() swapColumns: boolean = true;\n\n  /**\n   * The type of sorting\n   */\n  @Input() sortType: SortType = SortType.single;\n\n  /**\n   * Array of sorted columns by property and type.\n   * Default value: `[]`\n   */\n  @Input() sorts: any[] = [];\n\n  /**\n   * Css class overrides\n   */\n  @Input() cssClasses: any = {\n    sortAscending: 'datatable-icon-up',\n    sortDescending: 'datatable-icon-down',\n    pagerLeftArrow: 'datatable-icon-left',\n    pagerRightArrow: 'datatable-icon-right',\n    pagerPrevious: 'datatable-icon-prev',\n    pagerNext: 'datatable-icon-skip'\n  };\n\n  /**\n   * Message overrides for localization\n   *\n   * emptyMessage     [default] = 'No data to display'\n   * totalMessage     [default] = 'total'\n   * selectedMessage  [default] = 'selected'\n   */\n  @Input() messages: any = {\n    // Message to show when array is presented\n    // but contains no values\n    emptyMessage: 'No data to display',\n\n    // Footer total message\n    totalMessage: 'total',\n\n    // Footer selected message\n    selectedMessage: 'selected'\n  };\n\n  /**\n   * Row specific classes.\n   * Similar implementation to ngClass.\n   *\n   *  [rowClass]=\"'first second'\"\n   *  [rowClass]=\"{ 'first': true, 'second': true, 'third': false }\"\n   */\n  @Input() rowClass: any;\n\n  /**\n   * A boolean/function you can use to check whether you want\n   * to select a particular row based on a criteria. Example:\n   *\n   *    (selection) => {\n   *      return selection !== 'Ethel Price';\n   *    }\n   */\n  @Input() selectCheck: any;\n\n  /**\n   * A function you can use to check whether you want\n   * to show the checkbox for a particular row based on a criteria. Example:\n   *\n   *    (row, column, value) => {\n   *      return row.name !== 'Ethel Price';\n   *    }\n   */\n  @Input() displayCheck: (row: any, column?: any, value?: any) => boolean;\n\n  /**\n   * A boolean you can use to set the detault behaviour of rows and groups\n   * whether they will start expanded or not. If ommited the default is NOT expanded.\n   *\n   */\n  @Input() groupExpansionDefault: boolean = false;\n\n  /**\n   * Property to which you can use for custom tracking of rows.\n   * Example: 'name'\n   */\n  @Input() trackByProp: string;\n\n  /**\n   * Property to which you can use for determining select all\n   * rows on current page or not.\n   *\n   * @memberOf DatatableComponent\n   */\n  @Input() selectAllRowsOnPage = false;\n\n  /**\n   * A flag for row virtualization on / off\n   */\n  @Input() virtualization: boolean = true;\n\n  /**\n   * Tree from relation\n   */\n  @Input() treeFromRelation: string;\n\n  /**\n   * Tree to relation\n   */\n  @Input() treeToRelation: string;\n\n  /**\n   * A flag for switching summary row on / off\n   */\n  @Input() summaryRow: boolean = false;\n\n  /**\n   * A height of summary row\n   */\n  @Input() summaryHeight: number = 30;\n\n  /**\n   * A property holds a summary row position: top/bottom\n   */\n  @Input() summaryPosition: string = 'top';\n\n  /**\n   * Body was scrolled typically in a `scrollbarV:true` scenario.\n   */\n  @Output() scroll: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * A cell or row was focused via keyboard or mouse click.\n   */\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * A cell or row was selected.\n   */\n  @Output() select: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * Column sort was invoked.\n   */\n  @Output() sort: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * The table was paged either triggered by the pager or the body scroll.\n   */\n  @Output() page: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * Columns were re-ordered.\n   */\n  @Output() reorder: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * Column was resized.\n   */\n  @Output() resize: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * The context menu was invoked on the table.\n   * type indicates whether the header or the body was clicked.\n   * content contains either the column or the row that was clicked.\n   */\n  @Output() tableContextmenu = new EventEmitter<{ event: MouseEvent; type: ContextmenuType; content: any }>(false);\n\n  /**\n   * A row was expanded ot collapsed for tree\n   */\n  @Output() treeAction: EventEmitter<any> = new EventEmitter();\n\n  /**\n   * CSS class applied if the header height if fixed height.\n   */\n  @HostBinding('class.fixed-header')\n  get isFixedHeader(): boolean {\n    const headerHeight: number | string = this.headerHeight;\n    return typeof headerHeight === 'string' ? <string>headerHeight !== 'auto' : true;\n  }\n\n  /**\n   * CSS class applied to the root element if\n   * the row heights are fixed heights.\n   */\n  @HostBinding('class.fixed-row')\n  get isFixedRow(): boolean {\n    return this.rowHeight !== 'auto';\n  }\n\n  /**\n   * CSS class applied to root element if\n   * vertical scrolling is enabled.\n   */\n  @HostBinding('class.scroll-vertical')\n  get isVertScroll(): boolean {\n    return this.scrollbarV;\n  }\n\n  /**\n   * CSS class applied to root element if\n   * virtualization is enabled.\n   */\n  @HostBinding('class.virtualized')\n  get isVirtualized(): boolean {\n    return this.virtualization;\n  }\n\n  /**\n   * CSS class applied to the root element\n   * if the horziontal scrolling is enabled.\n   */\n  @HostBinding('class.scroll-horz')\n  get isHorScroll(): boolean {\n    return this.scrollbarH;\n  }\n\n  /**\n   * CSS class applied to root element is selectable.\n   */\n  @HostBinding('class.selectable')\n  get isSelectable(): boolean {\n    return this.selectionType !== undefined;\n  }\n\n  /**\n   * CSS class applied to root is checkbox selection.\n   */\n  @HostBinding('class.checkbox-selection')\n  get isCheckboxSelection(): boolean {\n    return this.selectionType === SelectionType.checkbox;\n  }\n\n  /**\n   * CSS class applied to root if cell selection.\n   */\n  @HostBinding('class.cell-selection')\n  get isCellSelection(): boolean {\n    return this.selectionType === SelectionType.cell;\n  }\n\n  /**\n   * CSS class applied to root if single select.\n   */\n  @HostBinding('class.single-selection')\n  get isSingleSelection(): boolean {\n    return this.selectionType === SelectionType.single;\n  }\n\n  /**\n   * CSS class added to root element if mulit select\n   */\n  @HostBinding('class.multi-selection')\n  get isMultiSelection(): boolean {\n    return this.selectionType === SelectionType.multi;\n  }\n\n  /**\n   * CSS class added to root element if mulit click select\n   */\n  @HostBinding('class.multi-click-selection')\n  get isMultiClickSelection(): boolean {\n    return this.selectionType === SelectionType.multiClick;\n  }\n\n  /**\n   * Column templates gathered from `ContentChildren`\n   * if described in your markup.\n   */\n  @ContentChildren(DataTableColumnDirective)\n  set columnTemplates(val: QueryList<DataTableColumnDirective>) {\n    this._columnTemplates = val;\n    this.translateColumns(val);\n  }\n\n  /**\n   * Returns the column templates.\n   */\n  get columnTemplates(): QueryList<DataTableColumnDirective> {\n    return this._columnTemplates;\n  }\n\n  /**\n   * Row Detail templates gathered from the ContentChild\n   */\n  @ContentChild(DatatableRowDetailDirective, { static: false })\n  rowDetail: DatatableRowDetailDirective;\n\n  /**\n   * Group Header templates gathered from the ContentChild\n   */\n  @ContentChild(DatatableGroupHeaderDirective, { static: false })\n  groupHeader: DatatableGroupHeaderDirective;\n\n  /**\n   * Footer template gathered from the ContentChild\n   */\n  @ContentChild(DatatableFooterDirective, { static: false })\n  footer: DatatableFooterDirective;\n\n  /**\n   * Reference to the body component for manually\n   * invoking functions on the body.\n   */\n  @ViewChild(DataTableBodyComponent, { static: false })\n  bodyComponent: DataTableBodyComponent;\n\n  /**\n   * Reference to the header component for manually\n   * invoking functions on the header.\n   *\n   * @memberOf DatatableComponent\n   */\n  @ViewChild(DataTableHeaderComponent, { static: false })\n  headerComponent: DataTableHeaderComponent;\n\n  /**\n   * Returns if all rows are selected.\n   */\n  get allRowsSelected(): boolean {\n    let allRowsSelected = this.rows && this.selected && this.selected.length === this.rows.length;\n\n    if (this.selectAllRowsOnPage) {\n      const indexes = this.bodyComponent.indexes;\n      const rowsOnPage = indexes.last - indexes.first;\n      allRowsSelected = this.selected.length === rowsOnPage;\n    }\n\n    return this.selected && this.rows && this.rows.length !== 0 && allRowsSelected;\n  }\n\n  element: HTMLElement;\n  _innerWidth: number;\n  pageSize: number;\n  bodyHeight: number;\n  rowCount: number = 0;\n  rowDiffer: KeyValueDiffer<{}, {}>;\n\n  _offsetX = new BehaviorSubject(0);\n  _limit: number | undefined;\n  _count: number = 0;\n  _offset: number = 0;\n  _rows: any[];\n  _groupRowsBy: string;\n  _internalRows: any[];\n  _internalColumns: TableColumn[];\n  _columns: TableColumn[];\n  _columnTemplates: QueryList<DataTableColumnDirective>;\n  _subscriptions: Subscription[] = [];\n\n  constructor(\n    @SkipSelf() private scrollbarHelper: ScrollbarHelper,\n    @SkipSelf() private dimensionsHelper: DimensionsHelper,\n    private cd: ChangeDetectorRef,\n    element: ElementRef,\n    differs: KeyValueDiffers,\n    private columnChangesService: ColumnChangesService,\n    @Optional() @Inject('configuration') private configuration: INgxDatatableConfig\n  ) {\n    // get ref to elm for measuring\n    this.element = element.nativeElement;\n    this.rowDiffer = differs.find({}).create();\n\n    // apply global settings from Module.forRoot\n    if (this.configuration && this.configuration.messages) {\n      this.messages = { ...this.configuration.messages };\n    }\n  }\n\n  /**\n   * Lifecycle hook that is called after data-bound\n   * properties of a directive are initialized.\n   */\n  ngOnInit(): void {\n    // need to call this immediatly to size\n    // if the table is hidden the visibility\n    // listener will invoke this itself upon show\n    this.recalculate();\n  }\n\n  /**\n   * Lifecycle hook that is called after a component's\n   * view has been fully initialized.\n   */\n  ngAfterViewInit(): void {\n    if (!this.externalSorting) {\n      this.sortInternalRows();\n    }\n\n    // this has to be done to prevent the change detection\n    // tree from freaking out because we are readjusting\n    if (typeof requestAnimationFrame === 'undefined') {\n      return;\n    }\n\n    requestAnimationFrame(() => {\n      this.recalculate();\n\n      // emit page for virtual server-side kickoff\n      if (this.externalPaging && this.scrollbarV) {\n        this.page.emit({\n          count: this.count,\n          pageSize: this.pageSize,\n          limit: this.limit,\n          offset: 0\n        });\n      }\n    });\n  }\n\n  /**\n   * Lifecycle hook that is called after a component's\n   * content has been fully initialized.\n   */\n  ngAfterContentInit() {\n    this.columnTemplates.changes.subscribe(v => this.translateColumns(v));\n    this.listenForColumnInputChanges();\n  }\n\n  /**\n   * This will be used when displaying or selecting rows.\n   * when tracking/comparing them, we'll use the value of this fn,\n   *\n   * (`fn(x) === fn(y)` instead of `x === y`)\n   */\n  @Input() rowIdentity: (x: any) => any = (x: any) => {\n    if (this._groupRowsBy) {\n      // each group in groupedRows are stored as {key, value: [rows]},\n      // where key is the groupRowsBy index\n      return x.key;\n    } else {\n      return x;\n    }\n  };\n\n  /**\n   * Translates the templates to the column objects\n   */\n  translateColumns(val: any) {\n    if (val) {\n      const arr = val.toArray();\n      if (arr.length) {\n        this._internalColumns = translateTemplates(arr);\n        setColumnDefaults(this._internalColumns);\n        this.recalculateColumns();\n        this.sortInternalRows();\n        this.cd.markForCheck();\n      }\n    }\n  }\n\n  /**\n   * Creates a map with the data grouped by the user choice of grouping index\n   *\n   * @param originalArray the original array passed via parameter\n   * @param groupByIndex  the index of the column to group the data by\n   */\n  groupArrayBy(originalArray: any, groupBy: any) {\n    // create a map to hold groups with their corresponding results\n    const map = new Map();\n    let i: number = 0;\n\n    originalArray.forEach((item: any) => {\n      const key = item[groupBy];\n      if (!map.has(key)) {\n        map.set(key, [item]);\n      } else {\n        map.get(key).push(item);\n      }\n      i++;\n    });\n\n    const addGroup = (key: any, value: any) => {\n      return { key, value };\n    };\n\n    // convert map back to a simple array of objects\n    return Array.from(map, x => addGroup(x[0], x[1]));\n  }\n\n  /*\n   * Lifecycle hook that is called when Angular dirty checks a directive.\n   */\n  ngDoCheck(): void {\n    if (this.rowDiffer.diff(this.rows)) {\n      if (!this.externalSorting) {\n        this.sortInternalRows();\n      } else {\n        this._internalRows = [...this.rows];\n      }\n\n      // auto group by parent on new update\n      this._internalRows = groupRowsByParents(\n        this._internalRows,\n        optionalGetterForProp(this.treeFromRelation),\n        optionalGetterForProp(this.treeToRelation)\n      );\n\n      this.recalculatePages();\n      this.cd.markForCheck();\n    }\n  }\n\n  /**\n   * Recalc's the sizes of the grid.\n   *\n   * Updated automatically on changes to:\n   *\n   *  - Columns\n   *  - Rows\n   *  - Paging related\n   *\n   * Also can be manually invoked or upon window resize.\n   */\n  recalculate(): void {\n    this.recalculateDims();\n    this.recalculateColumns();\n  }\n\n  /**\n   * Window resize handler to update sizes.\n   */\n  @HostListener('window:resize')\n  @throttleable(5)\n  onWindowResize(): void {\n    this.recalculate();\n  }\n\n  /**\n   * Recalulcates the column widths based on column width\n   * distribution mode and scrollbar offsets.\n   */\n  recalculateColumns(\n    columns: any[] = this._internalColumns,\n    forceIdx: number = -1,\n    allowBleed: boolean = this.scrollbarH\n  ): any[] | undefined {\n    if (!columns) return undefined;\n\n    let width = this._innerWidth;\n    if (this.scrollbarV) {\n      width = width - this.scrollbarHelper.width;\n    }\n\n    if (this.columnMode === ColumnMode.force) {\n      forceFillColumnWidths(columns, width, forceIdx, allowBleed);\n    } else if (this.columnMode === ColumnMode.flex) {\n      adjustColumnWidths(columns, width);\n    }\n\n    return columns;\n  }\n\n  /**\n   * Recalculates the dimensions of the table size.\n   * Internally calls the page size and row count calcs too.\n   *\n   */\n  recalculateDims(): void {\n    const dims = this.dimensionsHelper.getDimensions(this.element);\n    this._innerWidth = Math.floor(dims.width);\n\n    if (this.scrollbarV) {\n      let height = dims.height;\n      if (this.headerHeight) height = height - this.headerHeight;\n      if (this.footerHeight) height = height - this.footerHeight;\n      this.bodyHeight = height;\n    }\n\n    this.recalculatePages();\n  }\n\n  /**\n   * Recalculates the pages after a update.\n   */\n  recalculatePages(): void {\n    this.pageSize = this.calcPageSize();\n    this.rowCount = this.calcRowCount();\n  }\n\n  /**\n   * Body triggered a page event.\n   */\n  onBodyPage({ offset }: any): void {\n    // Avoid pagination caming from body events like scroll when the table\n    // has no virtualization and the external paging is enable.\n    // This means, let's the developer handle pagination by my him(her) self\n    if (this.externalPaging && !this.virtualization) {\n      return;\n    }\n\n    this.offset = offset;\n\n    this.page.emit({\n      count: this.count,\n      pageSize: this.pageSize,\n      limit: this.limit,\n      offset: this.offset\n    });\n  }\n\n  /**\n   * The body triggered a scroll event.\n   */\n  onBodyScroll(event: MouseEvent): void {\n    this._offsetX.next(event.offsetX);\n    this.scroll.emit(event);\n    this.cd.detectChanges();\n  }\n\n  /**\n   * The footer triggered a page event.\n   */\n  onFooterPage(event: any) {\n    this.offset = event.page - 1;\n    this.bodyComponent.updateOffsetY(this.offset);\n\n    this.page.emit({\n      count: this.count,\n      pageSize: this.pageSize,\n      limit: this.limit,\n      offset: this.offset\n    });\n\n    if (this.selectAllRowsOnPage) {\n      this.selected = [];\n      this.select.emit({\n        selected: this.selected\n      });\n    }\n  }\n\n  /**\n   * Recalculates the sizes of the page\n   */\n  calcPageSize(val: any[] = this.rows): number {\n    // Keep the page size constant even if the row has been expanded.\n    // This is because an expanded row is still considered to be a child of\n    // the original row.  Hence calculation would use rowHeight only.\n    if (this.scrollbarV && this.virtualization) {\n      const size = Math.ceil(this.bodyHeight / (this.rowHeight as number));\n      return Math.max(size, 0);\n    }\n\n    // if limit is passed, we are paging\n    if (this.limit !== undefined) {\n      return this.limit;\n    }\n\n    // otherwise use row length\n    if (val) {\n      return val.length;\n    }\n\n    // other empty :(\n    return 0;\n  }\n\n  /**\n   * Calculates the row count.\n   */\n  calcRowCount(val: any[] = this.rows): number {\n    if (!this.externalPaging) {\n      if (!val) return 0;\n\n      if (this.groupedRows) {\n        return this.groupedRows.length;\n      } else if (this.treeFromRelation != null && this.treeToRelation != null) {\n        return this._internalRows.length;\n      } else {\n        return val.length;\n      }\n    }\n\n    return this.count;\n  }\n\n  /**\n   * The header triggered a contextmenu event.\n   */\n  onColumnContextmenu({ event, column }: any): void {\n    this.tableContextmenu.emit({ event, type: ContextmenuType.header, content: column });\n  }\n\n  /**\n   * The body triggered a contextmenu event.\n   */\n  onRowContextmenu({ event, row }: any): void {\n    this.tableContextmenu.emit({ event, type: ContextmenuType.body, content: row });\n  }\n\n  /**\n   * The header triggered a column resize event.\n   */\n  onColumnResize({ column, newValue }: any): void {\n    /* Safari/iOS 10.2 workaround */\n    if (column === undefined) {\n      return;\n    }\n\n    let idx: number;\n    const cols = this._internalColumns.map((c, i) => {\n      c = { ...c };\n\n      if (c.$$id === column.$$id) {\n        idx = i;\n        c.width = newValue;\n\n        // set this so we can force the column\n        // width distribution to be to this value\n        c.$$oldWidth = newValue;\n      }\n\n      return c;\n    });\n\n    this.recalculateColumns(cols, idx);\n    this._internalColumns = cols;\n\n    this.resize.emit({\n      column,\n      newValue\n    });\n  }\n\n  /**\n   * The header triggered a column re-order event.\n   */\n  onColumnReorder({ column, newValue, prevValue }: any): void {\n    const cols = this._internalColumns.map(c => {\n      return { ...c };\n    });\n\n    if (this.swapColumns) {\n      const prevCol = cols[newValue];\n      cols[newValue] = column;\n      cols[prevValue] = prevCol;\n    } else {\n      if (newValue > prevValue) {\n        const movedCol = cols[prevValue];\n        for (let i = prevValue; i < newValue; i++) {\n          cols[i] = cols[i + 1];\n        }\n        cols[newValue] = movedCol;\n      } else {\n        const movedCol = cols[prevValue];\n        for (let i = prevValue; i > newValue; i--) {\n          cols[i] = cols[i - 1];\n        }\n        cols[newValue] = movedCol;\n      }\n    }\n\n    this._internalColumns = cols;\n\n    this.reorder.emit({\n      column,\n      newValue,\n      prevValue\n    });\n  }\n\n  /**\n   * The header triggered a column sort event.\n   */\n  onColumnSort(event: any): void {\n    // clean selected rows\n    if (this.selectAllRowsOnPage) {\n      this.selected = [];\n      this.select.emit({\n        selected: this.selected\n      });\n    }\n\n    this.sorts = event.sorts;\n\n    // this could be optimized better since it will resort\n    // the rows again on the 'push' detection...\n    if (this.externalSorting === false) {\n      // don't use normal setter so we don't resort\n      this.sortInternalRows();\n    }\n\n    // auto group by parent on new update\n    this._internalRows = groupRowsByParents(\n      this._internalRows,\n      optionalGetterForProp(this.treeFromRelation),\n      optionalGetterForProp(this.treeToRelation)\n    );\n\n    // Always go to first page when sorting to see the newly sorted data\n    this.offset = 0;\n    this.bodyComponent.updateOffsetY(this.offset);\n    this.sort.emit(event);\n  }\n\n  /**\n   * Toggle all row selection\n   */\n  onHeaderSelect(event: any): void {\n    if (this.selectAllRowsOnPage) {\n      // before we splice, chk if we currently have all selected\n      const first = this.bodyComponent.indexes.first;\n      const last = this.bodyComponent.indexes.last;\n      const allSelected = this.selected.length === last - first;\n\n      // remove all existing either way\n      this.selected = [];\n\n      // do the opposite here\n      if (!allSelected) {\n        this.selected.push(...this._internalRows.slice(first, last));\n      }\n    } else {\n      // before we splice, chk if we currently have all selected\n      const allSelected = this.selected.length === this.rows.length;\n      // remove all existing either way\n      this.selected = [];\n      // do the opposite here\n      if (!allSelected) {\n        this.selected.push(...this.rows);\n      }\n    }\n\n    this.select.emit({\n      selected: this.selected\n    });\n  }\n\n  /**\n   * A row was selected from body\n   */\n  onBodySelect(event: any): void {\n    this.select.emit(event);\n  }\n\n  /**\n   * A row was expanded or collapsed for tree\n   */\n  onTreeAction(event: any) {\n    const row = event.row;\n    // TODO: For duplicated items this will not work\n    const rowIndex = this._rows.findIndex(r => r[this.treeToRelation] === event.row[this.treeToRelation]);\n    this.treeAction.emit({ row, rowIndex });\n  }\n\n  ngOnDestroy() {\n    this._subscriptions.forEach(subscription => subscription.unsubscribe());\n  }\n\n  /**\n   * listen for changes to input bindings of all DataTableColumnDirective and\n   * trigger the columnTemplates.changes observable to emit\n   */\n  private listenForColumnInputChanges(): void {\n    this._subscriptions.push(\n      this.columnChangesService.columnInputChanges$.subscribe(() => {\n        if (this.columnTemplates) {\n          this.columnTemplates.notifyOnChanges();\n        }\n      })\n    );\n  }\n\n  private sortInternalRows(): void {\n    this._internalRows = sortRows(this._internalRows, this._internalColumns, this.sorts);\n  }\n}\n"]}