body.component.js 93 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { Component, Output, EventEmitter, Input, HostBinding, ChangeDetectorRef, ViewChild, ChangeDetectionStrategy } from '@angular/core';
  7. import { ScrollerComponent } from './scroller.component';
  8. import { SelectionType } from '../../types/selection.type';
  9. import { columnsByPin, columnGroupWidths } from '../../utils/column';
  10. import { RowHeightCache } from '../../utils/row-height-cache';
  11. import { translateXY } from '../../utils/translate';
  12. var DataTableBodyComponent = /** @class */ (function () {
  13. /**
  14. * Creates an instance of DataTableBodyComponent.
  15. */
  16. function DataTableBodyComponent(cd) {
  17. var _this = this;
  18. this.cd = cd;
  19. this.selected = [];
  20. this.scroll = new EventEmitter();
  21. this.page = new EventEmitter();
  22. this.activate = new EventEmitter();
  23. this.select = new EventEmitter();
  24. this.detailToggle = new EventEmitter();
  25. this.rowContextmenu = new EventEmitter(false);
  26. this.treeAction = new EventEmitter();
  27. this.rowHeightsCache = new RowHeightCache();
  28. this.temp = [];
  29. this.offsetY = 0;
  30. this.indexes = {};
  31. this.rowIndexes = new Map();
  32. this.rowExpansions = [];
  33. /**
  34. * Get the height of the detail row.
  35. */
  36. this.getDetailRowHeight = (/**
  37. * @param {?=} row
  38. * @param {?=} index
  39. * @return {?}
  40. */
  41. function (row, index) {
  42. if (!_this.rowDetail) {
  43. return 0;
  44. }
  45. /** @type {?} */
  46. var rowHeight = _this.rowDetail.rowHeight;
  47. return typeof rowHeight === 'function' ? rowHeight(row, index) : ((/** @type {?} */ (rowHeight)));
  48. });
  49. // declare fn here so we can get access to the `this` property
  50. this.rowTrackingFn = (/**
  51. * @param {?} index
  52. * @param {?} row
  53. * @return {?}
  54. */
  55. function (index, row) {
  56. /** @type {?} */
  57. var idx = _this.getRowIndex(row);
  58. if (_this.trackByProp) {
  59. return row[_this.trackByProp];
  60. }
  61. else {
  62. return idx;
  63. }
  64. });
  65. }
  66. Object.defineProperty(DataTableBodyComponent.prototype, "pageSize", {
  67. get: /**
  68. * @return {?}
  69. */
  70. function () {
  71. return this._pageSize;
  72. },
  73. set: /**
  74. * @param {?} val
  75. * @return {?}
  76. */
  77. function (val) {
  78. this._pageSize = val;
  79. this.recalcLayout();
  80. },
  81. enumerable: true,
  82. configurable: true
  83. });
  84. Object.defineProperty(DataTableBodyComponent.prototype, "rows", {
  85. get: /**
  86. * @return {?}
  87. */
  88. function () {
  89. return this._rows;
  90. },
  91. set: /**
  92. * @param {?} val
  93. * @return {?}
  94. */
  95. function (val) {
  96. this._rows = val;
  97. this.recalcLayout();
  98. },
  99. enumerable: true,
  100. configurable: true
  101. });
  102. Object.defineProperty(DataTableBodyComponent.prototype, "columns", {
  103. get: /**
  104. * @return {?}
  105. */
  106. function () {
  107. return this._columns;
  108. },
  109. set: /**
  110. * @param {?} val
  111. * @return {?}
  112. */
  113. function (val) {
  114. this._columns = val;
  115. /** @type {?} */
  116. var colsByPin = columnsByPin(val);
  117. this.columnGroupWidths = columnGroupWidths(colsByPin, val);
  118. },
  119. enumerable: true,
  120. configurable: true
  121. });
  122. Object.defineProperty(DataTableBodyComponent.prototype, "offset", {
  123. get: /**
  124. * @return {?}
  125. */
  126. function () {
  127. return this._offset;
  128. },
  129. set: /**
  130. * @param {?} val
  131. * @return {?}
  132. */
  133. function (val) {
  134. this._offset = val;
  135. if (!this.scrollbarV || (this.scrollbarV && !this.virtualization))
  136. this.recalcLayout();
  137. },
  138. enumerable: true,
  139. configurable: true
  140. });
  141. Object.defineProperty(DataTableBodyComponent.prototype, "rowCount", {
  142. get: /**
  143. * @return {?}
  144. */
  145. function () {
  146. return this._rowCount;
  147. },
  148. set: /**
  149. * @param {?} val
  150. * @return {?}
  151. */
  152. function (val) {
  153. this._rowCount = val;
  154. this.recalcLayout();
  155. },
  156. enumerable: true,
  157. configurable: true
  158. });
  159. Object.defineProperty(DataTableBodyComponent.prototype, "bodyWidth", {
  160. get: /**
  161. * @return {?}
  162. */
  163. function () {
  164. if (this.scrollbarH) {
  165. return this.innerWidth + 'px';
  166. }
  167. else {
  168. return '100%';
  169. }
  170. },
  171. enumerable: true,
  172. configurable: true
  173. });
  174. Object.defineProperty(DataTableBodyComponent.prototype, "bodyHeight", {
  175. get: /**
  176. * @return {?}
  177. */
  178. function () {
  179. return this._bodyHeight;
  180. },
  181. set: /**
  182. * @param {?} val
  183. * @return {?}
  184. */
  185. function (val) {
  186. if (this.scrollbarV) {
  187. this._bodyHeight = val + 'px';
  188. }
  189. else {
  190. this._bodyHeight = 'auto';
  191. }
  192. this.recalcLayout();
  193. },
  194. enumerable: true,
  195. configurable: true
  196. });
  197. Object.defineProperty(DataTableBodyComponent.prototype, "selectEnabled", {
  198. /**
  199. * Returns if selection is enabled.
  200. */
  201. get: /**
  202. * Returns if selection is enabled.
  203. * @return {?}
  204. */
  205. function () {
  206. return !!this.selectionType;
  207. },
  208. enumerable: true,
  209. configurable: true
  210. });
  211. Object.defineProperty(DataTableBodyComponent.prototype, "scrollHeight", {
  212. /**
  213. * Property that would calculate the height of scroll bar
  214. * based on the row heights cache for virtual scroll and virtualization. Other scenarios
  215. * calculate scroll height automatically (as height will be undefined).
  216. */
  217. get: /**
  218. * Property that would calculate the height of scroll bar
  219. * based on the row heights cache for virtual scroll and virtualization. Other scenarios
  220. * calculate scroll height automatically (as height will be undefined).
  221. * @return {?}
  222. */
  223. function () {
  224. if (this.scrollbarV && this.virtualization && this.rowCount) {
  225. return this.rowHeightsCache.query(this.rowCount - 1);
  226. }
  227. // avoid TS7030: Not all code paths return a value.
  228. return undefined;
  229. },
  230. enumerable: true,
  231. configurable: true
  232. });
  233. /**
  234. * Called after the constructor, initializing input properties
  235. */
  236. /**
  237. * Called after the constructor, initializing input properties
  238. * @return {?}
  239. */
  240. DataTableBodyComponent.prototype.ngOnInit = /**
  241. * Called after the constructor, initializing input properties
  242. * @return {?}
  243. */
  244. function () {
  245. var _this = this;
  246. if (this.rowDetail) {
  247. this.listener = this.rowDetail.toggle.subscribe((/**
  248. * @param {?} __0
  249. * @return {?}
  250. */
  251. function (_a) {
  252. var type = _a.type, value = _a.value;
  253. if (type === 'row') {
  254. _this.toggleRowExpansion(value);
  255. }
  256. if (type === 'all') {
  257. _this.toggleAllRows(value);
  258. }
  259. // Refresh rows after toggle
  260. // Fixes #883
  261. _this.updateIndexes();
  262. _this.updateRows();
  263. _this.cd.markForCheck();
  264. }));
  265. }
  266. if (this.groupHeader) {
  267. this.listener = this.groupHeader.toggle.subscribe((/**
  268. * @param {?} __0
  269. * @return {?}
  270. */
  271. function (_a) {
  272. var type = _a.type, value = _a.value;
  273. if (type === 'group') {
  274. _this.toggleRowExpansion(value);
  275. }
  276. if (type === 'all') {
  277. _this.toggleAllRows(value);
  278. }
  279. // Refresh rows after toggle
  280. // Fixes #883
  281. _this.updateIndexes();
  282. _this.updateRows();
  283. _this.cd.markForCheck();
  284. }));
  285. }
  286. };
  287. /**
  288. * Called once, before the instance is destroyed.
  289. */
  290. /**
  291. * Called once, before the instance is destroyed.
  292. * @return {?}
  293. */
  294. DataTableBodyComponent.prototype.ngOnDestroy = /**
  295. * Called once, before the instance is destroyed.
  296. * @return {?}
  297. */
  298. function () {
  299. if (this.rowDetail || this.groupHeader) {
  300. this.listener.unsubscribe();
  301. }
  302. };
  303. /**
  304. * Updates the Y offset given a new offset.
  305. */
  306. /**
  307. * Updates the Y offset given a new offset.
  308. * @param {?=} offset
  309. * @return {?}
  310. */
  311. DataTableBodyComponent.prototype.updateOffsetY = /**
  312. * Updates the Y offset given a new offset.
  313. * @param {?=} offset
  314. * @return {?}
  315. */
  316. function (offset) {
  317. // scroller is missing on empty table
  318. if (!this.scroller) {
  319. return;
  320. }
  321. if (this.scrollbarV && this.virtualization && offset) {
  322. // First get the row Index that we need to move to.
  323. /** @type {?} */
  324. var rowIndex = this.pageSize * offset;
  325. offset = this.rowHeightsCache.query(rowIndex - 1);
  326. }
  327. else if (this.scrollbarV && !this.virtualization) {
  328. offset = 0;
  329. }
  330. this.scroller.setOffset(offset || 0);
  331. };
  332. /**
  333. * Body was scrolled, this is mainly useful for
  334. * when a user is server-side pagination via virtual scroll.
  335. */
  336. /**
  337. * Body was scrolled, this is mainly useful for
  338. * when a user is server-side pagination via virtual scroll.
  339. * @param {?} event
  340. * @return {?}
  341. */
  342. DataTableBodyComponent.prototype.onBodyScroll = /**
  343. * Body was scrolled, this is mainly useful for
  344. * when a user is server-side pagination via virtual scroll.
  345. * @param {?} event
  346. * @return {?}
  347. */
  348. function (event) {
  349. /** @type {?} */
  350. var scrollYPos = event.scrollYPos;
  351. /** @type {?} */
  352. var scrollXPos = event.scrollXPos;
  353. // if scroll change, trigger update
  354. // this is mainly used for header cell positions
  355. if (this.offsetY !== scrollYPos || this.offsetX !== scrollXPos) {
  356. this.scroll.emit({
  357. offsetY: scrollYPos,
  358. offsetX: scrollXPos
  359. });
  360. }
  361. this.offsetY = scrollYPos;
  362. this.offsetX = scrollXPos;
  363. this.updateIndexes();
  364. this.updatePage(event.direction);
  365. this.updateRows();
  366. };
  367. /**
  368. * Updates the page given a direction.
  369. */
  370. /**
  371. * Updates the page given a direction.
  372. * @param {?} direction
  373. * @return {?}
  374. */
  375. DataTableBodyComponent.prototype.updatePage = /**
  376. * Updates the page given a direction.
  377. * @param {?} direction
  378. * @return {?}
  379. */
  380. function (direction) {
  381. /** @type {?} */
  382. var offset = this.indexes.first / this.pageSize;
  383. if (direction === 'up') {
  384. offset = Math.ceil(offset);
  385. }
  386. else if (direction === 'down') {
  387. offset = Math.floor(offset);
  388. }
  389. if (direction !== undefined && !isNaN(offset)) {
  390. this.page.emit({ offset: offset });
  391. }
  392. };
  393. /**
  394. * Updates the rows in the view port
  395. */
  396. /**
  397. * Updates the rows in the view port
  398. * @return {?}
  399. */
  400. DataTableBodyComponent.prototype.updateRows = /**
  401. * Updates the rows in the view port
  402. * @return {?}
  403. */
  404. function () {
  405. var _a = this.indexes, first = _a.first, last = _a.last;
  406. /** @type {?} */
  407. var rowIndex = first;
  408. /** @type {?} */
  409. var idx = 0;
  410. /** @type {?} */
  411. var temp = [];
  412. this.rowIndexes.clear();
  413. // if grouprowsby has been specified treat row paging
  414. // parameters as group paging parameters ie if limit 10 has been
  415. // specified treat it as 10 groups rather than 10 rows
  416. if (this.groupedRows) {
  417. /** @type {?} */
  418. var maxRowsPerGroup = 3;
  419. // if there is only one group set the maximum number of
  420. // rows per group the same as the total number of rows
  421. if (this.groupedRows.length === 1) {
  422. maxRowsPerGroup = this.groupedRows[0].value.length;
  423. }
  424. while (rowIndex < last && rowIndex < this.groupedRows.length) {
  425. // Add the groups into this page
  426. /** @type {?} */
  427. var group = this.groupedRows[rowIndex];
  428. temp[idx] = group;
  429. idx++;
  430. // Group index in this context
  431. rowIndex++;
  432. }
  433. }
  434. else {
  435. while (rowIndex < last && rowIndex < this.rowCount) {
  436. /** @type {?} */
  437. var row = this.rows[rowIndex];
  438. if (row) {
  439. this.rowIndexes.set(row, rowIndex);
  440. temp[idx] = row;
  441. }
  442. idx++;
  443. rowIndex++;
  444. }
  445. }
  446. this.temp = temp;
  447. };
  448. /**
  449. * Get the row height
  450. */
  451. /**
  452. * Get the row height
  453. * @param {?} row
  454. * @return {?}
  455. */
  456. DataTableBodyComponent.prototype.getRowHeight = /**
  457. * Get the row height
  458. * @param {?} row
  459. * @return {?}
  460. */
  461. function (row) {
  462. // if its a function return it
  463. if (typeof this.rowHeight === 'function') {
  464. return this.rowHeight(row);
  465. }
  466. return (/** @type {?} */ (this.rowHeight));
  467. };
  468. /**
  469. * @param group the group with all rows
  470. */
  471. /**
  472. * @param {?} group the group with all rows
  473. * @return {?}
  474. */
  475. DataTableBodyComponent.prototype.getGroupHeight = /**
  476. * @param {?} group the group with all rows
  477. * @return {?}
  478. */
  479. function (group) {
  480. /** @type {?} */
  481. var rowHeight = 0;
  482. if (group.value) {
  483. for (var index = 0; index < group.value.length; index++) {
  484. rowHeight += this.getRowAndDetailHeight(group.value[index]);
  485. }
  486. }
  487. return rowHeight;
  488. };
  489. /**
  490. * Calculate row height based on the expanded state of the row.
  491. */
  492. /**
  493. * Calculate row height based on the expanded state of the row.
  494. * @param {?} row
  495. * @return {?}
  496. */
  497. DataTableBodyComponent.prototype.getRowAndDetailHeight = /**
  498. * Calculate row height based on the expanded state of the row.
  499. * @param {?} row
  500. * @return {?}
  501. */
  502. function (row) {
  503. /** @type {?} */
  504. var rowHeight = this.getRowHeight(row);
  505. /** @type {?} */
  506. var expanded = this.getRowExpanded(row);
  507. // Adding detail row height if its expanded.
  508. if (expanded) {
  509. rowHeight += this.getDetailRowHeight(row);
  510. }
  511. return rowHeight;
  512. };
  513. /**
  514. * Calculates the styles for the row so that the rows can be moved in 2D space
  515. * during virtual scroll inside the DOM. In the below case the Y position is
  516. * manipulated. As an example, if the height of row 0 is 30 px and row 1 is
  517. * 100 px then following styles are generated:
  518. *
  519. * transform: translate3d(0px, 0px, 0px); -> row0
  520. * transform: translate3d(0px, 30px, 0px); -> row1
  521. * transform: translate3d(0px, 130px, 0px); -> row2
  522. *
  523. * Row heights have to be calculated based on the row heights cache as we wont
  524. * be able to determine which row is of what height before hand. In the above
  525. * case the positionY of the translate3d for row2 would be the sum of all the
  526. * heights of the rows before it (i.e. row0 and row1).
  527. *
  528. * @param rows the row that needs to be placed in the 2D space.
  529. * @returns the CSS3 style to be applied
  530. *
  531. * @memberOf DataTableBodyComponent
  532. */
  533. /**
  534. * Calculates the styles for the row so that the rows can be moved in 2D space
  535. * during virtual scroll inside the DOM. In the below case the Y position is
  536. * manipulated. As an example, if the height of row 0 is 30 px and row 1 is
  537. * 100 px then following styles are generated:
  538. *
  539. * transform: translate3d(0px, 0px, 0px); -> row0
  540. * transform: translate3d(0px, 30px, 0px); -> row1
  541. * transform: translate3d(0px, 130px, 0px); -> row2
  542. *
  543. * Row heights have to be calculated based on the row heights cache as we wont
  544. * be able to determine which row is of what height before hand. In the above
  545. * case the positionY of the translate3d for row2 would be the sum of all the
  546. * heights of the rows before it (i.e. row0 and row1).
  547. *
  548. * \@memberOf DataTableBodyComponent
  549. * @param {?} rows the row that needs to be placed in the 2D space.
  550. * @return {?} the CSS3 style to be applied
  551. *
  552. */
  553. DataTableBodyComponent.prototype.getRowsStyles = /**
  554. * Calculates the styles for the row so that the rows can be moved in 2D space
  555. * during virtual scroll inside the DOM. In the below case the Y position is
  556. * manipulated. As an example, if the height of row 0 is 30 px and row 1 is
  557. * 100 px then following styles are generated:
  558. *
  559. * transform: translate3d(0px, 0px, 0px); -> row0
  560. * transform: translate3d(0px, 30px, 0px); -> row1
  561. * transform: translate3d(0px, 130px, 0px); -> row2
  562. *
  563. * Row heights have to be calculated based on the row heights cache as we wont
  564. * be able to determine which row is of what height before hand. In the above
  565. * case the positionY of the translate3d for row2 would be the sum of all the
  566. * heights of the rows before it (i.e. row0 and row1).
  567. *
  568. * \@memberOf DataTableBodyComponent
  569. * @param {?} rows the row that needs to be placed in the 2D space.
  570. * @return {?} the CSS3 style to be applied
  571. *
  572. */
  573. function (rows) {
  574. /** @type {?} */
  575. var styles = {};
  576. // only add styles for the group if there is a group
  577. if (this.groupedRows) {
  578. styles.width = this.columnGroupWidths.total;
  579. }
  580. if (this.scrollbarV && this.virtualization) {
  581. /** @type {?} */
  582. var idx = 0;
  583. if (this.groupedRows) {
  584. // Get the latest row rowindex in a group
  585. /** @type {?} */
  586. var row = rows[rows.length - 1];
  587. idx = row ? this.getRowIndex(row) : 0;
  588. }
  589. else {
  590. idx = this.getRowIndex(rows);
  591. }
  592. // const pos = idx * rowHeight;
  593. // The position of this row would be the sum of all row heights
  594. // until the previous row position.
  595. /** @type {?} */
  596. var pos = this.rowHeightsCache.query(idx - 1);
  597. translateXY(styles, 0, pos);
  598. }
  599. return styles;
  600. };
  601. /**
  602. * Calculate bottom summary row offset for scrollbar mode.
  603. * For more information about cache and offset calculation
  604. * see description for `getRowsStyles` method
  605. *
  606. * @returns the CSS3 style to be applied
  607. *
  608. * @memberOf DataTableBodyComponent
  609. */
  610. /**
  611. * Calculate bottom summary row offset for scrollbar mode.
  612. * For more information about cache and offset calculation
  613. * see description for `getRowsStyles` method
  614. *
  615. * \@memberOf DataTableBodyComponent
  616. * @return {?} the CSS3 style to be applied
  617. *
  618. */
  619. DataTableBodyComponent.prototype.getBottomSummaryRowStyles = /**
  620. * Calculate bottom summary row offset for scrollbar mode.
  621. * For more information about cache and offset calculation
  622. * see description for `getRowsStyles` method
  623. *
  624. * \@memberOf DataTableBodyComponent
  625. * @return {?} the CSS3 style to be applied
  626. *
  627. */
  628. function () {
  629. if (!this.scrollbarV || !this.rows || !this.rows.length) {
  630. return null;
  631. }
  632. /** @type {?} */
  633. var styles = { position: 'absolute' };
  634. /** @type {?} */
  635. var pos = this.rowHeightsCache.query(this.rows.length - 1);
  636. translateXY(styles, 0, pos);
  637. return styles;
  638. };
  639. /**
  640. * Hides the loading indicator
  641. */
  642. /**
  643. * Hides the loading indicator
  644. * @return {?}
  645. */
  646. DataTableBodyComponent.prototype.hideIndicator = /**
  647. * Hides the loading indicator
  648. * @return {?}
  649. */
  650. function () {
  651. var _this = this;
  652. setTimeout((/**
  653. * @return {?}
  654. */
  655. function () { return (_this.loadingIndicator = false); }), 500);
  656. };
  657. /**
  658. * Updates the index of the rows in the viewport
  659. */
  660. /**
  661. * Updates the index of the rows in the viewport
  662. * @return {?}
  663. */
  664. DataTableBodyComponent.prototype.updateIndexes = /**
  665. * Updates the index of the rows in the viewport
  666. * @return {?}
  667. */
  668. function () {
  669. /** @type {?} */
  670. var first = 0;
  671. /** @type {?} */
  672. var last = 0;
  673. if (this.scrollbarV) {
  674. if (this.virtualization) {
  675. // Calculation of the first and last indexes will be based on where the
  676. // scrollY position would be at. The last index would be the one
  677. // that shows up inside the view port the last.
  678. /** @type {?} */
  679. var height = parseInt(this.bodyHeight, 0);
  680. first = this.rowHeightsCache.getRowIndex(this.offsetY);
  681. last = this.rowHeightsCache.getRowIndex(height + this.offsetY) + 1;
  682. }
  683. else {
  684. // If virtual rows are not needed
  685. // We render all in one go
  686. first = 0;
  687. last = this.rowCount;
  688. }
  689. }
  690. else {
  691. // The server is handling paging and will pass an array that begins with the
  692. // element at a specified offset. first should always be 0 with external paging.
  693. if (!this.externalPaging) {
  694. first = Math.max(this.offset * this.pageSize, 0);
  695. }
  696. last = Math.min(first + this.pageSize, this.rowCount);
  697. }
  698. this.indexes = { first: first, last: last };
  699. };
  700. /**
  701. * Refreshes the full Row Height cache. Should be used
  702. * when the entire row array state has changed.
  703. */
  704. /**
  705. * Refreshes the full Row Height cache. Should be used
  706. * when the entire row array state has changed.
  707. * @return {?}
  708. */
  709. DataTableBodyComponent.prototype.refreshRowHeightCache = /**
  710. * Refreshes the full Row Height cache. Should be used
  711. * when the entire row array state has changed.
  712. * @return {?}
  713. */
  714. function () {
  715. var e_1, _a;
  716. if (!this.scrollbarV || (this.scrollbarV && !this.virtualization)) {
  717. return;
  718. }
  719. // clear the previous row height cache if already present.
  720. // this is useful during sorts, filters where the state of the
  721. // rows array is changed.
  722. this.rowHeightsCache.clearCache();
  723. // Initialize the tree only if there are rows inside the tree.
  724. if (this.rows && this.rows.length) {
  725. /** @type {?} */
  726. var rowExpansions = new Set();
  727. try {
  728. for (var _b = tslib_1.__values(this.rows), _c = _b.next(); !_c.done; _c = _b.next()) {
  729. var row = _c.value;
  730. if (this.getRowExpanded(row)) {
  731. rowExpansions.add(row);
  732. }
  733. }
  734. }
  735. catch (e_1_1) { e_1 = { error: e_1_1 }; }
  736. finally {
  737. try {
  738. if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
  739. }
  740. finally { if (e_1) throw e_1.error; }
  741. }
  742. this.rowHeightsCache.initCache({
  743. rows: this.rows,
  744. rowHeight: this.rowHeight,
  745. detailRowHeight: this.getDetailRowHeight,
  746. externalVirtual: this.scrollbarV && this.externalPaging,
  747. rowCount: this.rowCount,
  748. rowIndexes: this.rowIndexes,
  749. rowExpansions: rowExpansions
  750. });
  751. }
  752. };
  753. /**
  754. * Gets the index for the view port
  755. */
  756. /**
  757. * Gets the index for the view port
  758. * @return {?}
  759. */
  760. DataTableBodyComponent.prototype.getAdjustedViewPortIndex = /**
  761. * Gets the index for the view port
  762. * @return {?}
  763. */
  764. function () {
  765. // Capture the row index of the first row that is visible on the viewport.
  766. // If the scroll bar is just below the row which is highlighted then make that as the
  767. // first index.
  768. /** @type {?} */
  769. var viewPortFirstRowIndex = this.indexes.first;
  770. if (this.scrollbarV && this.virtualization) {
  771. /** @type {?} */
  772. var offsetScroll = this.rowHeightsCache.query(viewPortFirstRowIndex - 1);
  773. return offsetScroll <= this.offsetY ? viewPortFirstRowIndex - 1 : viewPortFirstRowIndex;
  774. }
  775. return viewPortFirstRowIndex;
  776. };
  777. /**
  778. * Toggle the Expansion of the row i.e. if the row is expanded then it will
  779. * collapse and vice versa. Note that the expanded status is stored as
  780. * a part of the row object itself as we have to preserve the expanded row
  781. * status in case of sorting and filtering of the row set.
  782. */
  783. /**
  784. * Toggle the Expansion of the row i.e. if the row is expanded then it will
  785. * collapse and vice versa. Note that the expanded status is stored as
  786. * a part of the row object itself as we have to preserve the expanded row
  787. * status in case of sorting and filtering of the row set.
  788. * @param {?} row
  789. * @return {?}
  790. */
  791. DataTableBodyComponent.prototype.toggleRowExpansion = /**
  792. * Toggle the Expansion of the row i.e. if the row is expanded then it will
  793. * collapse and vice versa. Note that the expanded status is stored as
  794. * a part of the row object itself as we have to preserve the expanded row
  795. * status in case of sorting and filtering of the row set.
  796. * @param {?} row
  797. * @return {?}
  798. */
  799. function (row) {
  800. // Capture the row index of the first row that is visible on the viewport.
  801. /** @type {?} */
  802. var viewPortFirstRowIndex = this.getAdjustedViewPortIndex();
  803. /** @type {?} */
  804. var rowExpandedIdx = this.getRowExpandedIdx(row, this.rowExpansions);
  805. /** @type {?} */
  806. var expanded = rowExpandedIdx > -1;
  807. // If the detailRowHeight is auto --> only in case of non-virtualized scroll
  808. if (this.scrollbarV && this.virtualization) {
  809. /** @type {?} */
  810. var detailRowHeight = this.getDetailRowHeight(row) * (expanded ? -1 : 1);
  811. // const idx = this.rowIndexes.get(row) || 0;
  812. /** @type {?} */
  813. var idx = this.getRowIndex(row);
  814. this.rowHeightsCache.update(idx, detailRowHeight);
  815. }
  816. // Update the toggled row and update thive nevere heights in the cache.
  817. if (expanded) {
  818. this.rowExpansions.splice(rowExpandedIdx, 1);
  819. }
  820. else {
  821. this.rowExpansions.push(row);
  822. }
  823. this.detailToggle.emit({
  824. rows: [row],
  825. currentIndex: viewPortFirstRowIndex
  826. });
  827. };
  828. /**
  829. * Expand/Collapse all the rows no matter what their state is.
  830. */
  831. /**
  832. * Expand/Collapse all the rows no matter what their state is.
  833. * @param {?} expanded
  834. * @return {?}
  835. */
  836. DataTableBodyComponent.prototype.toggleAllRows = /**
  837. * Expand/Collapse all the rows no matter what their state is.
  838. * @param {?} expanded
  839. * @return {?}
  840. */
  841. function (expanded) {
  842. var e_2, _a;
  843. // clear prev expansions
  844. this.rowExpansions = [];
  845. // Capture the row index of the first row that is visible on the viewport.
  846. /** @type {?} */
  847. var viewPortFirstRowIndex = this.getAdjustedViewPortIndex();
  848. if (expanded) {
  849. try {
  850. for (var _b = tslib_1.__values(this.rows), _c = _b.next(); !_c.done; _c = _b.next()) {
  851. var row = _c.value;
  852. this.rowExpansions.push(row);
  853. }
  854. }
  855. catch (e_2_1) { e_2 = { error: e_2_1 }; }
  856. finally {
  857. try {
  858. if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
  859. }
  860. finally { if (e_2) throw e_2.error; }
  861. }
  862. }
  863. if (this.scrollbarV) {
  864. // Refresh the full row heights cache since every row was affected.
  865. this.recalcLayout();
  866. }
  867. // Emit all rows that have been expanded.
  868. this.detailToggle.emit({
  869. rows: this.rows,
  870. currentIndex: viewPortFirstRowIndex
  871. });
  872. };
  873. /**
  874. * Recalculates the table
  875. */
  876. /**
  877. * Recalculates the table
  878. * @return {?}
  879. */
  880. DataTableBodyComponent.prototype.recalcLayout = /**
  881. * Recalculates the table
  882. * @return {?}
  883. */
  884. function () {
  885. this.refreshRowHeightCache();
  886. this.updateIndexes();
  887. this.updateRows();
  888. };
  889. /**
  890. * Tracks the column
  891. */
  892. /**
  893. * Tracks the column
  894. * @param {?} index
  895. * @param {?} column
  896. * @return {?}
  897. */
  898. DataTableBodyComponent.prototype.columnTrackingFn = /**
  899. * Tracks the column
  900. * @param {?} index
  901. * @param {?} column
  902. * @return {?}
  903. */
  904. function (index, column) {
  905. return column.$$id;
  906. };
  907. /**
  908. * Gets the row pinning group styles
  909. */
  910. /**
  911. * Gets the row pinning group styles
  912. * @param {?} group
  913. * @return {?}
  914. */
  915. DataTableBodyComponent.prototype.stylesByGroup = /**
  916. * Gets the row pinning group styles
  917. * @param {?} group
  918. * @return {?}
  919. */
  920. function (group) {
  921. /** @type {?} */
  922. var widths = this.columnGroupWidths;
  923. /** @type {?} */
  924. var offsetX = this.offsetX;
  925. /** @type {?} */
  926. var styles = {
  927. width: widths[group] + "px"
  928. };
  929. if (group === 'left') {
  930. translateXY(styles, offsetX, 0);
  931. }
  932. else if (group === 'right') {
  933. /** @type {?} */
  934. var bodyWidth = parseInt(this.innerWidth + '', 0);
  935. /** @type {?} */
  936. var totalDiff = widths.total - bodyWidth;
  937. /** @type {?} */
  938. var offsetDiff = totalDiff - offsetX;
  939. /** @type {?} */
  940. var offset = offsetDiff * -1;
  941. translateXY(styles, offset, 0);
  942. }
  943. return styles;
  944. };
  945. /**
  946. * Returns if the row was expanded and set default row expansion when row expansion is empty
  947. */
  948. /**
  949. * Returns if the row was expanded and set default row expansion when row expansion is empty
  950. * @param {?} row
  951. * @return {?}
  952. */
  953. DataTableBodyComponent.prototype.getRowExpanded = /**
  954. * Returns if the row was expanded and set default row expansion when row expansion is empty
  955. * @param {?} row
  956. * @return {?}
  957. */
  958. function (row) {
  959. var e_3, _a;
  960. if (this.rowExpansions.length === 0 && this.groupExpansionDefault) {
  961. try {
  962. for (var _b = tslib_1.__values(this.groupedRows), _c = _b.next(); !_c.done; _c = _b.next()) {
  963. var group = _c.value;
  964. this.rowExpansions.push(group);
  965. }
  966. }
  967. catch (e_3_1) { e_3 = { error: e_3_1 }; }
  968. finally {
  969. try {
  970. if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
  971. }
  972. finally { if (e_3) throw e_3.error; }
  973. }
  974. }
  975. return this.getRowExpandedIdx(row, this.rowExpansions) > -1;
  976. };
  977. /**
  978. * @param {?} row
  979. * @param {?} expanded
  980. * @return {?}
  981. */
  982. DataTableBodyComponent.prototype.getRowExpandedIdx = /**
  983. * @param {?} row
  984. * @param {?} expanded
  985. * @return {?}
  986. */
  987. function (row, expanded) {
  988. var _this = this;
  989. if (!expanded || !expanded.length)
  990. return -1;
  991. /** @type {?} */
  992. var rowId = this.rowIdentity(row);
  993. return expanded.findIndex((/**
  994. * @param {?} r
  995. * @return {?}
  996. */
  997. function (r) {
  998. /** @type {?} */
  999. var id = _this.rowIdentity(r);
  1000. return id === rowId;
  1001. }));
  1002. };
  1003. /**
  1004. * Gets the row index given a row
  1005. */
  1006. /**
  1007. * Gets the row index given a row
  1008. * @param {?} row
  1009. * @return {?}
  1010. */
  1011. DataTableBodyComponent.prototype.getRowIndex = /**
  1012. * Gets the row index given a row
  1013. * @param {?} row
  1014. * @return {?}
  1015. */
  1016. function (row) {
  1017. return this.rowIndexes.get(row) || 0;
  1018. };
  1019. /**
  1020. * @param {?} row
  1021. * @return {?}
  1022. */
  1023. DataTableBodyComponent.prototype.onTreeAction = /**
  1024. * @param {?} row
  1025. * @return {?}
  1026. */
  1027. function (row) {
  1028. this.treeAction.emit({ row: row });
  1029. };
  1030. DataTableBodyComponent.decorators = [
  1031. { type: Component, args: [{
  1032. selector: 'datatable-body',
  1033. template: "\n <datatable-selection\n #selector\n [selected]=\"selected\"\n [rows]=\"rows\"\n [selectCheck]=\"selectCheck\"\n [selectEnabled]=\"selectEnabled\"\n [selectionType]=\"selectionType\"\n [rowIdentity]=\"rowIdentity\"\n (select)=\"select.emit($event)\"\n (activate)=\"activate.emit($event)\"\n >\n <datatable-progress *ngIf=\"loadingIndicator\"> </datatable-progress>\n <datatable-scroller\n *ngIf=\"rows?.length\"\n [scrollbarV]=\"scrollbarV\"\n [scrollbarH]=\"scrollbarH\"\n [scrollHeight]=\"scrollHeight\"\n [scrollWidth]=\"columnGroupWidths?.total\"\n (scroll)=\"onBodyScroll($event)\"\n >\n <datatable-summary-row\n *ngIf=\"summaryRow && summaryPosition === 'top'\"\n [rowHeight]=\"summaryHeight\"\n [offsetX]=\"offsetX\"\n [innerWidth]=\"innerWidth\"\n [rows]=\"rows\"\n [columns]=\"columns\"\n >\n </datatable-summary-row>\n <datatable-row-wrapper\n [groupedRows]=\"groupedRows\"\n *ngFor=\"let group of temp; let i = index; trackBy: rowTrackingFn\"\n [innerWidth]=\"innerWidth\"\n [ngStyle]=\"getRowsStyles(group)\"\n [rowDetail]=\"rowDetail\"\n [groupHeader]=\"groupHeader\"\n [offsetX]=\"offsetX\"\n [detailRowHeight]=\"getDetailRowHeight(group[i], i)\"\n [row]=\"group\"\n [expanded]=\"getRowExpanded(group)\"\n [rowIndex]=\"getRowIndex(group[i])\"\n (rowContextmenu)=\"rowContextmenu.emit($event)\"\n >\n <datatable-body-row\n *ngIf=\"!groupedRows; else groupedRowsTemplate\"\n tabindex=\"-1\"\n [isSelected]=\"selector.getRowSelected(group)\"\n [innerWidth]=\"innerWidth\"\n [offsetX]=\"offsetX\"\n [columns]=\"columns\"\n [rowHeight]=\"getRowHeight(group)\"\n [row]=\"group\"\n [rowIndex]=\"getRowIndex(group)\"\n [expanded]=\"getRowExpanded(group)\"\n [rowClass]=\"rowClass\"\n [displayCheck]=\"displayCheck\"\n [treeStatus]=\"group.treeStatus\"\n (treeAction)=\"onTreeAction(group)\"\n (activate)=\"selector.onActivate($event, indexes.first + i)\"\n >\n </datatable-body-row>\n <ng-template #groupedRowsTemplate>\n <datatable-body-row\n *ngFor=\"let row of group.value; let i = index; trackBy: rowTrackingFn\"\n tabindex=\"-1\"\n [isSelected]=\"selector.getRowSelected(row)\"\n [innerWidth]=\"innerWidth\"\n [offsetX]=\"offsetX\"\n [columns]=\"columns\"\n [rowHeight]=\"getRowHeight(row)\"\n [row]=\"row\"\n [group]=\"group.value\"\n [rowIndex]=\"getRowIndex(row)\"\n [expanded]=\"getRowExpanded(row)\"\n [rowClass]=\"rowClass\"\n (activate)=\"selector.onActivate($event, i)\"\n >\n </datatable-body-row>\n </ng-template>\n </datatable-row-wrapper>\n <datatable-summary-row\n *ngIf=\"summaryRow && summaryPosition === 'bottom'\"\n [ngStyle]=\"getBottomSummaryRowStyles()\"\n [rowHeight]=\"summaryHeight\"\n [offsetX]=\"offsetX\"\n [innerWidth]=\"innerWidth\"\n [rows]=\"rows\"\n [columns]=\"columns\"\n >\n </datatable-summary-row>\n </datatable-scroller>\n <div class=\"empty-row\" *ngIf=\"!rows?.length && !loadingIndicator\" [innerHTML]=\"emptyMessage\"></div>\n </datatable-selection>\n ",
  1034. changeDetection: ChangeDetectionStrategy.OnPush,
  1035. host: {
  1036. class: 'datatable-body'
  1037. }
  1038. }] }
  1039. ];
  1040. /** @nocollapse */
  1041. DataTableBodyComponent.ctorParameters = function () { return [
  1042. { type: ChangeDetectorRef }
  1043. ]; };
  1044. DataTableBodyComponent.propDecorators = {
  1045. scrollbarV: [{ type: Input }],
  1046. scrollbarH: [{ type: Input }],
  1047. loadingIndicator: [{ type: Input }],
  1048. externalPaging: [{ type: Input }],
  1049. rowHeight: [{ type: Input }],
  1050. offsetX: [{ type: Input }],
  1051. emptyMessage: [{ type: Input }],
  1052. selectionType: [{ type: Input }],
  1053. selected: [{ type: Input }],
  1054. rowIdentity: [{ type: Input }],
  1055. rowDetail: [{ type: Input }],
  1056. groupHeader: [{ type: Input }],
  1057. selectCheck: [{ type: Input }],
  1058. displayCheck: [{ type: Input }],
  1059. trackByProp: [{ type: Input }],
  1060. rowClass: [{ type: Input }],
  1061. groupedRows: [{ type: Input }],
  1062. groupExpansionDefault: [{ type: Input }],
  1063. innerWidth: [{ type: Input }],
  1064. groupRowsBy: [{ type: Input }],
  1065. virtualization: [{ type: Input }],
  1066. summaryRow: [{ type: Input }],
  1067. summaryPosition: [{ type: Input }],
  1068. summaryHeight: [{ type: Input }],
  1069. pageSize: [{ type: Input }],
  1070. rows: [{ type: Input }],
  1071. columns: [{ type: Input }],
  1072. offset: [{ type: Input }],
  1073. rowCount: [{ type: Input }],
  1074. bodyWidth: [{ type: HostBinding, args: ['style.width',] }],
  1075. bodyHeight: [{ type: Input }, { type: HostBinding, args: ['style.height',] }],
  1076. scroll: [{ type: Output }],
  1077. page: [{ type: Output }],
  1078. activate: [{ type: Output }],
  1079. select: [{ type: Output }],
  1080. detailToggle: [{ type: Output }],
  1081. rowContextmenu: [{ type: Output }],
  1082. treeAction: [{ type: Output }],
  1083. scroller: [{ type: ViewChild, args: [ScrollerComponent, { static: false },] }]
  1084. };
  1085. return DataTableBodyComponent;
  1086. }());
  1087. export { DataTableBodyComponent };
  1088. if (false) {
  1089. /** @type {?} */
  1090. DataTableBodyComponent.prototype.scrollbarV;
  1091. /** @type {?} */
  1092. DataTableBodyComponent.prototype.scrollbarH;
  1093. /** @type {?} */
  1094. DataTableBodyComponent.prototype.loadingIndicator;
  1095. /** @type {?} */
  1096. DataTableBodyComponent.prototype.externalPaging;
  1097. /** @type {?} */
  1098. DataTableBodyComponent.prototype.rowHeight;
  1099. /** @type {?} */
  1100. DataTableBodyComponent.prototype.offsetX;
  1101. /** @type {?} */
  1102. DataTableBodyComponent.prototype.emptyMessage;
  1103. /** @type {?} */
  1104. DataTableBodyComponent.prototype.selectionType;
  1105. /** @type {?} */
  1106. DataTableBodyComponent.prototype.selected;
  1107. /** @type {?} */
  1108. DataTableBodyComponent.prototype.rowIdentity;
  1109. /** @type {?} */
  1110. DataTableBodyComponent.prototype.rowDetail;
  1111. /** @type {?} */
  1112. DataTableBodyComponent.prototype.groupHeader;
  1113. /** @type {?} */
  1114. DataTableBodyComponent.prototype.selectCheck;
  1115. /** @type {?} */
  1116. DataTableBodyComponent.prototype.displayCheck;
  1117. /** @type {?} */
  1118. DataTableBodyComponent.prototype.trackByProp;
  1119. /** @type {?} */
  1120. DataTableBodyComponent.prototype.rowClass;
  1121. /** @type {?} */
  1122. DataTableBodyComponent.prototype.groupedRows;
  1123. /** @type {?} */
  1124. DataTableBodyComponent.prototype.groupExpansionDefault;
  1125. /** @type {?} */
  1126. DataTableBodyComponent.prototype.innerWidth;
  1127. /** @type {?} */
  1128. DataTableBodyComponent.prototype.groupRowsBy;
  1129. /** @type {?} */
  1130. DataTableBodyComponent.prototype.virtualization;
  1131. /** @type {?} */
  1132. DataTableBodyComponent.prototype.summaryRow;
  1133. /** @type {?} */
  1134. DataTableBodyComponent.prototype.summaryPosition;
  1135. /** @type {?} */
  1136. DataTableBodyComponent.prototype.summaryHeight;
  1137. /** @type {?} */
  1138. DataTableBodyComponent.prototype.scroll;
  1139. /** @type {?} */
  1140. DataTableBodyComponent.prototype.page;
  1141. /** @type {?} */
  1142. DataTableBodyComponent.prototype.activate;
  1143. /** @type {?} */
  1144. DataTableBodyComponent.prototype.select;
  1145. /** @type {?} */
  1146. DataTableBodyComponent.prototype.detailToggle;
  1147. /** @type {?} */
  1148. DataTableBodyComponent.prototype.rowContextmenu;
  1149. /** @type {?} */
  1150. DataTableBodyComponent.prototype.treeAction;
  1151. /** @type {?} */
  1152. DataTableBodyComponent.prototype.scroller;
  1153. /** @type {?} */
  1154. DataTableBodyComponent.prototype.rowHeightsCache;
  1155. /** @type {?} */
  1156. DataTableBodyComponent.prototype.temp;
  1157. /** @type {?} */
  1158. DataTableBodyComponent.prototype.offsetY;
  1159. /** @type {?} */
  1160. DataTableBodyComponent.prototype.indexes;
  1161. /** @type {?} */
  1162. DataTableBodyComponent.prototype.columnGroupWidths;
  1163. /** @type {?} */
  1164. DataTableBodyComponent.prototype.columnGroupWidthsWithoutGroup;
  1165. /** @type {?} */
  1166. DataTableBodyComponent.prototype.rowTrackingFn;
  1167. /** @type {?} */
  1168. DataTableBodyComponent.prototype.listener;
  1169. /** @type {?} */
  1170. DataTableBodyComponent.prototype.rowIndexes;
  1171. /** @type {?} */
  1172. DataTableBodyComponent.prototype.rowExpansions;
  1173. /** @type {?} */
  1174. DataTableBodyComponent.prototype._rows;
  1175. /** @type {?} */
  1176. DataTableBodyComponent.prototype._bodyHeight;
  1177. /** @type {?} */
  1178. DataTableBodyComponent.prototype._columns;
  1179. /** @type {?} */
  1180. DataTableBodyComponent.prototype._rowCount;
  1181. /** @type {?} */
  1182. DataTableBodyComponent.prototype._offset;
  1183. /** @type {?} */
  1184. DataTableBodyComponent.prototype._pageSize;
  1185. /**
  1186. * Get the height of the detail row.
  1187. * @type {?}
  1188. */
  1189. DataTableBodyComponent.prototype.getDetailRowHeight;
  1190. /**
  1191. * @type {?}
  1192. * @private
  1193. */
  1194. DataTableBodyComponent.prototype.cd;
  1195. }
  1196. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"body.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/body/body.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACL,SAAS,EACT,MAAM,EACN,YAAY,EACZ,KAAK,EACL,WAAW,EACX,iBAAiB,EACjB,SAAS,EAGT,uBAAuB,EACxB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAEzD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEpD;IAwPE;;OAEG;IACH,gCAAoB,EAAqB;QAAzC,iBAUC;QAVmB,OAAE,GAAF,EAAE,CAAmB;QA5IhC,aAAQ,GAAU,EAAE,CAAC;QAyFpB,WAAM,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC/C,SAAI,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC7C,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAC;QACjD,WAAM,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC/C,iBAAY,GAAsB,IAAI,YAAY,EAAE,CAAC;QACrD,mBAAc,GAAG,IAAI,YAAY,CAAkC,KAAK,CAAC,CAAC;QAC1E,eAAU,GAAsB,IAAI,YAAY,EAAE,CAAC;QAwB7D,oBAAe,GAAmB,IAAI,cAAc,EAAE,CAAC;QACvD,SAAI,GAAU,EAAE,CAAC;QACjB,YAAO,GAAG,CAAC,CAAC;QACZ,YAAO,GAAQ,EAAE,CAAC;QAKlB,eAAU,GAAQ,IAAI,GAAG,EAAE,CAAC;QAC5B,kBAAa,GAAU,EAAE,CAAC;;;;QAmO1B,uBAAkB;;;;;QAAG,UAAC,GAAS,EAAE,KAAW;YAC1C,IAAI,CAAC,KAAI,CAAC,SAAS,EAAE;gBACnB,OAAO,CAAC,CAAC;aACV;;gBACK,SAAS,GAAG,KAAI,CAAC,SAAS,CAAC,SAAS;YAC1C,OAAO,OAAO,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,mBAAA,SAAS,EAAU,CAAC,CAAC;QACzF,CAAC,EAAC;QA5NA,8DAA8D;QAC9D,IAAI,CAAC,aAAa;;;;;QAAG,UAAC,KAAa,EAAE,GAAQ;;gBACrC,GAAG,GAAG,KAAI,CAAC,WAAW,CAAC,GAAG,CAAC;YACjC,IAAI,KAAI,CAAC,WAAW,EAAE;gBACpB,OAAO,GAAG,CAAC,KAAI,CAAC,WAAW,CAAC,CAAC;aAC9B;iBAAM;gBACL,OAAO,GAAG,CAAC;aACZ;QACH,CAAC,CAAA,CAAC;IACJ,CAAC;IArID,sBAAa,4CAAQ;;;;QAKrB;YACE,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;;;;;QAPD,UAAsB,GAAW;YAC/B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;YACrB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;;;OAAA;IAMD,sBAAa,wCAAI;;;;QAKjB;YACE,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;;;;;QAPD,UAAkB,GAAU;YAC1B,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;YACjB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;;;OAAA;IAMD,sBAAa,2CAAO;;;;QAMpB;YACE,OAAO,IAAI,CAAC,QAAQ,CAAC;QACvB,CAAC;;;;;QARD,UAAqB,GAAU;YAC7B,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;;gBACd,SAAS,GAAG,YAAY,CAAC,GAAG,CAAC;YACnC,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAC7D,CAAC;;;OAAA;IAMD,sBAAa,0CAAM;;;;QAMnB;YACE,OAAO,IAAI,CAAC,OAAO,CAAC;QACtB,CAAC;;;;;QARD,UAAoB,GAAW;YAC7B,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YACnB,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;gBAC/D,IAAI,CAAC,YAAY,EAAE,CAAC;QACxB,CAAC;;;OAAA;IAMD,sBAAa,4CAAQ;;;;QAKrB;YACE,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;;;;;QAPD,UAAsB,GAAW;YAC/B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;YACrB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;;;OAAA;IAMD,sBACI,6CAAS;;;;QADb;YAEE,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,OAAO,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;aAC/B;iBAAM;gBACL,OAAO,MAAM,CAAC;aACf;QACH,CAAC;;;OAAA;IAED,sBAEI,8CAAU;;;;QAUd;YACE,OAAO,IAAI,CAAC,WAAW,CAAC;QAC1B,CAAC;;;;;QAdD,UAEe,GAAG;YAChB,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,CAAC,WAAW,GAAG,GAAG,GAAG,IAAI,CAAC;aAC/B;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;aAC3B;YAED,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;;;OAAA;IAmBD,sBAAI,iDAAa;QAHjB;;WAEG;;;;;QACH;YACE,OAAO,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;QAC9B,CAAC;;;OAAA;IAOD,sBAAI,gDAAY;QALhB;;;;WAIG;;;;;;;QACH;YACE,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,EAAE;gBAC3D,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;aACtD;YACD,mDAAmD;YACnD,OAAO,SAAS,CAAC;QACnB,CAAC;;;OAAA;IAmCD;;OAEG;;;;;IACH,yCAAQ;;;;IAAR;QAAA,iBAkCC;QAjCC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS;;;;YAAC,UAAC,EAA6C;oBAA3C,cAAI,EAAE,gBAAK;gBAC5D,IAAI,IAAI,KAAK,KAAK,EAAE;oBAClB,KAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;iBAChC;gBACD,IAAI,IAAI,KAAK,KAAK,EAAE;oBAClB,KAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;iBAC3B;gBAED,4BAA4B;gBAC5B,aAAa;gBACb,KAAI,CAAC,aAAa,EAAE,CAAC;gBACrB,KAAI,CAAC,UAAU,EAAE,CAAC;gBAClB,KAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;YACzB,CAAC,EAAC,CAAC;SACJ;QAED,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,SAAS;;;;YAAC,UAAC,EAA6C;oBAA3C,cAAI,EAAE,gBAAK;gBAC9D,IAAI,IAAI,KAAK,OAAO,EAAE;oBACpB,KAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;iBAChC;gBACD,IAAI,IAAI,KAAK,KAAK,EAAE;oBAClB,KAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;iBAC3B;gBAED,4BAA4B;gBAC5B,aAAa;gBACb,KAAI,CAAC,aAAa,EAAE,CAAC;gBACrB,KAAI,CAAC,UAAU,EAAE,CAAC;gBAClB,KAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;YACzB,CAAC,EAAC,CAAC;SACJ;IACH,CAAC;IAED;;OAEG;;;;;IACH,4CAAW;;;;IAAX;QACE,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;SAC7B;IACH,CAAC;IAED;;OAEG;;;;;;IACH,8CAAa;;;;;IAAb,UAAc,MAAe;QAC3B,qCAAqC;QACrC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAO;SACR;QAED,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,cAAc,IAAI,MAAM,EAAE;;;gBAE9C,QAAQ,GAAG,IAAI,CAAC,QAAQ,GAAG,MAAM;YACvC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;SACnD;aAAM,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YAClD,MAAM,GAAG,CAAC,CAAC;SACZ;QAED,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;IACvC,CAAC;IAED;;;OAGG;;;;;;;IACH,6CAAY;;;;;;IAAZ,UAAa,KAAU;;YACf,UAAU,GAAW,KAAK,CAAC,UAAU;;YACrC,UAAU,GAAW,KAAK,CAAC,UAAU;QAE3C,mCAAmC;QACnC,gDAAgD;QAChD,IAAI,IAAI,CAAC,OAAO,KAAK,UAAU,IAAI,IAAI,CAAC,OAAO,KAAK,UAAU,EAAE;YAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;gBACf,OAAO,EAAE,UAAU;gBACnB,OAAO,EAAE,UAAU;aACpB,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC;QAC1B,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC;QAE1B,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED;;OAEG;;;;;;IACH,2CAAU;;;;;IAAV,UAAW,SAAiB;;YACtB,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ;QAE/C,IAAI,SAAS,KAAK,IAAI,EAAE;YACtB,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC5B;aAAM,IAAI,SAAS,KAAK,MAAM,EAAE;YAC/B,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;SAC7B;QAED,IAAI,SAAS,KAAK,SAAS,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAC7C,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,MAAM,QAAA,EAAE,CAAC,CAAC;SAC5B;IACH,CAAC;IAED;;OAEG;;;;;IACH,2CAAU;;;;IAAV;QACQ,IAAA,iBAA8B,EAA5B,gBAAK,EAAE,cAAqB;;YAChC,QAAQ,GAAG,KAAK;;YAChB,GAAG,GAAG,CAAC;;YACL,IAAI,GAAU,EAAE;QAEtB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QAExB,qDAAqD;QACrD,gEAAgE;QAChE,sDAAsD;QACtD,IAAI,IAAI,CAAC,WAAW,EAAE;;gBAChB,eAAe,GAAG,CAAC;YACvB,uDAAuD;YACvD,sDAAsD;YACtD,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;gBACjC,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;aACpD;YAED,OAAO,QAAQ,GAAG,IAAI,IAAI,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE;;;oBAEtD,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;gBACxC,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;gBAClB,GAAG,EAAE,CAAC;gBAEN,8BAA8B;gBAC9B,QAAQ,EAAE,CAAC;aACZ;SACF;aAAM;YACL,OAAO,QAAQ,GAAG,IAAI,IAAI,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE;;oBAC5C,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAE/B,IAAI,GAAG,EAAE;oBACP,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;oBACnC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;iBACjB;gBAED,GAAG,EAAE,CAAC;gBACN,QAAQ,EAAE,CAAC;aACZ;SACF;QAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED;;OAEG;;;;;;IACH,6CAAY;;;;;IAAZ,UAAa,GAAQ;QACnB,8BAA8B;QAC9B,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,UAAU,EAAE;YACxC,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SAC5B;QAED,OAAO,mBAAA,IAAI,CAAC,SAAS,EAAU,CAAC;IAClC,CAAC;IAED;;OAEG;;;;;IACH,+CAAc;;;;IAAd,UAAe,KAAU;;YACnB,SAAS,GAAG,CAAC;QAEjB,IAAI,KAAK,CAAC,KAAK,EAAE;YACf,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACvD,SAAS,IAAI,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;aAC7D;SACF;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;;;;;;IACH,sDAAqB;;;;;IAArB,UAAsB,GAAQ;;YACxB,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;;YAChC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC;QAEzC,4CAA4C;QAC5C,IAAI,QAAQ,EAAE;YACZ,SAAS,IAAI,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;SAC3C;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAaD;;;;;;;;;;;;;;;;;;;OAmBG;;;;;;;;;;;;;;;;;;;;;IACH,8CAAa;;;;;;;;;;;;;;;;;;;;IAAb,UAAc,IAAS;;YACf,MAAM,GAAQ,EAAE;QAEtB,oDAAoD;QACpD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;SAC7C;QAED,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,cAAc,EAAE;;gBACtC,GAAG,GAAG,CAAC;YAEX,IAAI,IAAI,CAAC,WAAW,EAAE;;;oBAEd,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;gBACjC,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACvC;iBAAM;gBACL,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aAC9B;;;;;gBAKK,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC;YAE/C,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;SAC7B;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;;;;;OAQG;;;;;;;;;;IACH,0DAAyB;;;;;;;;;IAAzB;QACE,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACvD,OAAO,IAAI,CAAC;SACb;;YAEK,MAAM,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE;;YACjC,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAE5D,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;QAE5B,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;;;;;IACH,8CAAa;;;;IAAb;QAAA,iBAEC;QADC,UAAU;;;QAAC,cAAM,OAAA,CAAC,KAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,EAA/B,CAA+B,GAAE,GAAG,CAAC,CAAC;IACzD,CAAC;IAED;;OAEG;;;;;IACH,8CAAa;;;;IAAb;;YACM,KAAK,GAAG,CAAC;;YACT,IAAI,GAAG,CAAC;QAEZ,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,IAAI,CAAC,cAAc,EAAE;;;;;oBAIjB,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;gBAC3C,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACvD,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;aACpE;iBAAM;gBACL,iCAAiC;gBACjC,0BAA0B;gBAC1B,KAAK,GAAG,CAAC,CAAC;gBACV,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;aACtB;SACF;aAAM;YACL,4EAA4E;YAC5E,iFAAiF;YACjF,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACxB,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;aAClD;YACD,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvD;QAED,IAAI,CAAC,OAAO,GAAG,EAAE,KAAK,OAAA,EAAE,IAAI,MAAA,EAAE,CAAC;IACjC,CAAC;IAED;;;OAGG;;;;;;IACH,sDAAqB;;;;;IAArB;;QACE,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YACjE,OAAO;SACR;QAED,0DAA0D;QAC1D,8DAA8D;QAC9D,yBAAyB;QACzB,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;QAElC,8DAA8D;QAC9D,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;;gBAC3B,aAAa,GAAG,IAAI,GAAG,EAAE;;gBAC/B,KAAkB,IAAA,KAAA,iBAAA,IAAI,CAAC,IAAI,CAAA,gBAAA,4BAAE;oBAAxB,IAAM,GAAG,WAAA;oBACZ,IAAI,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;wBAC5B,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;qBACxB;iBACF;;;;;;;;;YAED,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC;gBAC7B,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,eAAe,EAAE,IAAI,CAAC,kBAAkB;gBACxC,eAAe,EAAE,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,cAAc;gBACvD,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,aAAa,eAAA;aACd,CAAC,CAAC;SACJ;IACH,CAAC;IAED;;OAEG;;;;;IACH,yDAAwB;;;;IAAxB;;;;;YAIQ,qBAAqB,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK;QAEhD,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,cAAc,EAAE;;gBACpC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,qBAAqB,GAAG,CAAC,CAAC;YAC1E,OAAO,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,qBAAqB,GAAG,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC;SACzF;QAED,OAAO,qBAAqB,CAAC;IAC/B,CAAC;IAED;;;;;OAKG;;;;;;;;;IACH,mDAAkB;;;;;;;;IAAlB,UAAmB,GAAQ;;;YAEnB,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,EAAE;;YACvD,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC;;YAChE,QAAQ,GAAG,cAAc,GAAG,CAAC,CAAC;QAEpC,4EAA4E;QAC5E,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,cAAc,EAAE;;gBACpC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;;;gBAEpE,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC;YACjC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC;SACnD;QAED,uEAAuE;QACvE,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;SAC9C;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC9B;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YACrB,IAAI,EAAE,CAAC,GAAG,CAAC;YACX,YAAY,EAAE,qBAAqB;SACpC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;;;;;;IACH,8CAAa;;;;;IAAb,UAAc,QAAiB;;QAC7B,wBAAwB;QACxB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;;;YAGlB,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,EAAE;QAE7D,IAAI,QAAQ,EAAE;;gBACZ,KAAkB,IAAA,KAAA,iBAAA,IAAI,CAAC,IAAI,CAAA,gBAAA,4BAAE;oBAAxB,IAAM,GAAG,WAAA;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAC9B;;;;;;;;;SACF;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,mEAAmE;YACnE,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QAED,yCAAyC;QACzC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YACrB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,YAAY,EAAE,qBAAqB;SACpC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;;;;;IACH,6CAAY;;;;IAAZ;QACE,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED;;OAEG;;;;;;;IACH,iDAAgB;;;;;;IAAhB,UAAiB,KAAa,EAAE,MAAW;QACzC,OAAO,MAAM,CAAC,IAAI,CAAC;IACrB,CAAC;IAED;;OAEG;;;;;;IACH,8CAAa;;;;;IAAb,UAAc,KAAa;;YACnB,MAAM,GAAG,IAAI,CAAC,iBAAiB;;YAC/B,OAAO,GAAG,IAAI,CAAC,OAAO;;YAEtB,MAAM,GAAG;YACb,KAAK,EAAK,MAAM,CAAC,KAAK,CAAC,OAAI;SAC5B;QAED,IAAI,KAAK,KAAK,MAAM,EAAE;YACpB,WAAW,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;SACjC;aAAM,IAAI,KAAK,KAAK,OAAO,EAAE;;gBACtB,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,UAAU,GAAG,EAAE,EAAE,CAAC,CAAC;;gBAC7C,SAAS,GAAG,MAAM,CAAC,KAAK,GAAG,SAAS;;gBACpC,UAAU,GAAG,SAAS,GAAG,OAAO;;gBAChC,MAAM,GAAG,UAAU,GAAG,CAAC,CAAC;YAC9B,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;SAChC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;;;;;;IACH,+CAAc;;;;;IAAd,UAAe,GAAQ;;QACrB,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,qBAAqB,EAAE;;gBACjE,KAAoB,IAAA,KAAA,iBAAA,IAAI,CAAC,WAAW,CAAA,gBAAA,4BAAE;oBAAjC,IAAM,KAAK,WAAA;oBACd,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAChC;;;;;;;;;SACF;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9D,CAAC;;;;;;IAED,kDAAiB;;;;;IAAjB,UAAkB,GAAQ,EAAE,QAAe;QAA3C,iBAQC;QAPC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,OAAO,CAAC,CAAC,CAAC;;YAEvC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC;QACnC,OAAO,QAAQ,CAAC,SAAS;;;;QAAC,UAAC,CAAC;;gBACpB,EAAE,GAAG,KAAI,CAAC,WAAW,CAAC,CAAC,CAAC;YAC9B,OAAO,EAAE,KAAK,KAAK,CAAC;QACtB,CAAC,EAAC,CAAC;IACL,CAAC;IAED;;OAEG;;;;;;IACH,4CAAW;;;;;IAAX,UAAY,GAAQ;QAClB,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;;;;;IAED,6CAAY;;;;IAAZ,UAAa,GAAQ;QACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,KAAA,EAAE,CAAC,CAAC;IAChC,CAAC;;gBAnwBF,SAAS,SAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,ipHA8FT;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,IAAI,EAAE;wBACJ,KAAK,EAAE,gBAAgB;qBACxB;iBACF;;;;gBAlHC,iBAAiB;;;6BAoHhB,KAAK;6BACL,KAAK;mCACL,KAAK;iCACL,KAAK;4BACL,KAAK;0BACL,KAAK;+BACL,KAAK;gCACL,KAAK;2BACL,KAAK;8BACL,KAAK;4BACL,KAAK;8BACL,KAAK;8BACL,KAAK;+BACL,KAAK;8BACL,KAAK;2BACL,KAAK;8BACL,KAAK;wCACL,KAAK;6BACL,KAAK;8BACL,KAAK;iCACL,KAAK;6BACL,KAAK;kCACL,KAAK;gCACL,KAAK;2BAEL,KAAK;uBASL,KAAK;0BASL,KAAK;yBAUL,KAAK;2BAUL,KAAK;4BASL,WAAW,SAAC,aAAa;6BASzB,KAAK,YACL,WAAW,SAAC,cAAc;yBAe1B,MAAM;uBACN,MAAM;2BACN,MAAM;yBACN,MAAM;+BACN,MAAM;iCACN,MAAM;6BACN,MAAM;2BAEN,SAAS,SAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;;IAojBjD,6BAAC;CAAA,AApwBD,IAowBC;SA9pBY,sBAAsB;;;IACjC,4CAA6B;;IAC7B,4CAA6B;;IAC7B,kDAAmC;;IACnC,gDAAiC;;IACjC,2CAA8D;;IAC9D,yCAAyB;;IACzB,8CAA8B;;IAC9B,+CAAsC;;IACtC,0CAA8B;;IAC9B,6CAA0B;;IAC1B,2CAAwB;;IACxB,6CAA0B;;IAC1B,6CAA0B;;IAC1B,8CAA2B;;IAC3B,6CAA6B;;IAC7B,0CAAuB;;IACvB,6CAA0B;;IAC1B,uDAAwC;;IACxC,4CAA4B;;IAC5B,6CAA6B;;IAC7B,gDAAiC;;IACjC,4CAA6B;;IAC7B,iDAAiC;;IACjC,+CAA+B;;IA0E/B,wCAAyD;;IACzD,sCAAuD;;IACvD,0CAA2D;;IAC3D,wCAAyD;;IACzD,8CAA+D;;IAC/D,gDAAoF;;IACpF,4CAA6D;;IAE7D,0CAA6E;;IAsB7E,iDAAuD;;IACvD,sCAAiB;;IACjB,yCAAY;;IACZ,yCAAkB;;IAClB,mDAAuB;;IACvB,+DAAmC;;IACnC,+CAAmB;;IACnB,0CAAc;;IACd,4CAA4B;;IAC5B,+CAA0B;;IAE1B,uCAAa;;IACb,6CAAiB;;IACjB,0CAAgB;;IAChB,2CAAkB;;IAClB,yCAAgB;;IAChB,2CAAkB;;;;;IA4NlB,oDAME;;;;;IA7NU,oCAA6B","sourcesContent":["import {\n  Component,\n  Output,\n  EventEmitter,\n  Input,\n  HostBinding,\n  ChangeDetectorRef,\n  ViewChild,\n  OnInit,\n  OnDestroy,\n  ChangeDetectionStrategy\n} from '@angular/core';\nimport { ScrollerComponent } from './scroller.component';\nimport { MouseEvent } from '../../events';\nimport { SelectionType } from '../../types/selection.type';\nimport { columnsByPin, columnGroupWidths } from '../../utils/column';\nimport { RowHeightCache } from '../../utils/row-height-cache';\nimport { translateXY } from '../../utils/translate';\n\n@Component({\n  selector: 'datatable-body',\n  template: `\n    <datatable-selection\n      #selector\n      [selected]=\"selected\"\n      [rows]=\"rows\"\n      [selectCheck]=\"selectCheck\"\n      [selectEnabled]=\"selectEnabled\"\n      [selectionType]=\"selectionType\"\n      [rowIdentity]=\"rowIdentity\"\n      (select)=\"select.emit($event)\"\n      (activate)=\"activate.emit($event)\"\n    >\n      <datatable-progress *ngIf=\"loadingIndicator\"> </datatable-progress>\n      <datatable-scroller\n        *ngIf=\"rows?.length\"\n        [scrollbarV]=\"scrollbarV\"\n        [scrollbarH]=\"scrollbarH\"\n        [scrollHeight]=\"scrollHeight\"\n        [scrollWidth]=\"columnGroupWidths?.total\"\n        (scroll)=\"onBodyScroll($event)\"\n      >\n        <datatable-summary-row\n          *ngIf=\"summaryRow && summaryPosition === 'top'\"\n          [rowHeight]=\"summaryHeight\"\n          [offsetX]=\"offsetX\"\n          [innerWidth]=\"innerWidth\"\n          [rows]=\"rows\"\n          [columns]=\"columns\"\n        >\n        </datatable-summary-row>\n        <datatable-row-wrapper\n          [groupedRows]=\"groupedRows\"\n          *ngFor=\"let group of temp; let i = index; trackBy: rowTrackingFn\"\n          [innerWidth]=\"innerWidth\"\n          [ngStyle]=\"getRowsStyles(group)\"\n          [rowDetail]=\"rowDetail\"\n          [groupHeader]=\"groupHeader\"\n          [offsetX]=\"offsetX\"\n          [detailRowHeight]=\"getDetailRowHeight(group[i], i)\"\n          [row]=\"group\"\n          [expanded]=\"getRowExpanded(group)\"\n          [rowIndex]=\"getRowIndex(group[i])\"\n          (rowContextmenu)=\"rowContextmenu.emit($event)\"\n        >\n          <datatable-body-row\n            *ngIf=\"!groupedRows; else groupedRowsTemplate\"\n            tabindex=\"-1\"\n            [isSelected]=\"selector.getRowSelected(group)\"\n            [innerWidth]=\"innerWidth\"\n            [offsetX]=\"offsetX\"\n            [columns]=\"columns\"\n            [rowHeight]=\"getRowHeight(group)\"\n            [row]=\"group\"\n            [rowIndex]=\"getRowIndex(group)\"\n            [expanded]=\"getRowExpanded(group)\"\n            [rowClass]=\"rowClass\"\n            [displayCheck]=\"displayCheck\"\n            [treeStatus]=\"group.treeStatus\"\n            (treeAction)=\"onTreeAction(group)\"\n            (activate)=\"selector.onActivate($event, indexes.first + i)\"\n          >\n          </datatable-body-row>\n          <ng-template #groupedRowsTemplate>\n            <datatable-body-row\n              *ngFor=\"let row of group.value; let i = index; trackBy: rowTrackingFn\"\n              tabindex=\"-1\"\n              [isSelected]=\"selector.getRowSelected(row)\"\n              [innerWidth]=\"innerWidth\"\n              [offsetX]=\"offsetX\"\n              [columns]=\"columns\"\n              [rowHeight]=\"getRowHeight(row)\"\n              [row]=\"row\"\n              [group]=\"group.value\"\n              [rowIndex]=\"getRowIndex(row)\"\n              [expanded]=\"getRowExpanded(row)\"\n              [rowClass]=\"rowClass\"\n              (activate)=\"selector.onActivate($event, i)\"\n            >\n            </datatable-body-row>\n          </ng-template>\n        </datatable-row-wrapper>\n        <datatable-summary-row\n          *ngIf=\"summaryRow && summaryPosition === 'bottom'\"\n          [ngStyle]=\"getBottomSummaryRowStyles()\"\n          [rowHeight]=\"summaryHeight\"\n          [offsetX]=\"offsetX\"\n          [innerWidth]=\"innerWidth\"\n          [rows]=\"rows\"\n          [columns]=\"columns\"\n        >\n        </datatable-summary-row>\n      </datatable-scroller>\n      <div class=\"empty-row\" *ngIf=\"!rows?.length && !loadingIndicator\" [innerHTML]=\"emptyMessage\"></div>\n    </datatable-selection>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'datatable-body'\n  }\n})\nexport class DataTableBodyComponent implements OnInit, OnDestroy {\n  @Input() scrollbarV: boolean;\n  @Input() scrollbarH: boolean;\n  @Input() loadingIndicator: boolean;\n  @Input() externalPaging: boolean;\n  @Input() rowHeight: number | 'auto' | ((row?: any) => number);\n  @Input() offsetX: number;\n  @Input() emptyMessage: string;\n  @Input() selectionType: SelectionType;\n  @Input() selected: any[] = [];\n  @Input() rowIdentity: any;\n  @Input() rowDetail: any;\n  @Input() groupHeader: any;\n  @Input() selectCheck: any;\n  @Input() displayCheck: any;\n  @Input() trackByProp: string;\n  @Input() rowClass: any;\n  @Input() groupedRows: any;\n  @Input() groupExpansionDefault: boolean;\n  @Input() innerWidth: number;\n  @Input() groupRowsBy: string;\n  @Input() virtualization: boolean;\n  @Input() summaryRow: boolean;\n  @Input() summaryPosition: string;\n  @Input() summaryHeight: number;\n\n  @Input() set pageSize(val: number) {\n    this._pageSize = val;\n    this.recalcLayout();\n  }\n\n  get pageSize(): number {\n    return this._pageSize;\n  }\n\n  @Input() set rows(val: any[]) {\n    this._rows = val;\n    this.recalcLayout();\n  }\n\n  get rows(): any[] {\n    return this._rows;\n  }\n\n  @Input() set columns(val: any[]) {\n    this._columns = val;\n    const colsByPin = columnsByPin(val);\n    this.columnGroupWidths = columnGroupWidths(colsByPin, val);\n  }\n\n  get columns(): any[] {\n    return this._columns;\n  }\n\n  @Input() set offset(val: number) {\n    this._offset = val;\n    if (!this.scrollbarV || (this.scrollbarV && !this.virtualization))\n      this.recalcLayout();\n  }\n\n  get offset(): number {\n    return this._offset;\n  }\n\n  @Input() set rowCount(val: number) {\n    this._rowCount = val;\n    this.recalcLayout();\n  }\n\n  get rowCount(): number {\n    return this._rowCount;\n  }\n\n  @HostBinding('style.width')\n  get bodyWidth(): string {\n    if (this.scrollbarH) {\n      return this.innerWidth + 'px';\n    } else {\n      return '100%';\n    }\n  }\n\n  @Input()\n  @HostBinding('style.height')\n  set bodyHeight(val) {\n    if (this.scrollbarV) {\n      this._bodyHeight = val + 'px';\n    } else {\n      this._bodyHeight = 'auto';\n    }\n\n    this.recalcLayout();\n  }\n\n  get bodyHeight() {\n    return this._bodyHeight;\n  }\n\n  @Output() scroll: EventEmitter<any> = new EventEmitter();\n  @Output() page: EventEmitter<any> = new EventEmitter();\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n  @Output() select: EventEmitter<any> = new EventEmitter();\n  @Output() detailToggle: EventEmitter<any> = new EventEmitter();\n  @Output() rowContextmenu = new EventEmitter<{ event: MouseEvent; row: any }>(false);\n  @Output() treeAction: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild(ScrollerComponent, { static: false }) scroller: ScrollerComponent;\n\n  /**\n   * Returns if selection is enabled.\n   */\n  get selectEnabled(): boolean {\n    return !!this.selectionType;\n  }\n\n  /**\n   * Property that would calculate the height of scroll bar\n   * based on the row heights cache for virtual scroll and virtualization. Other scenarios\n   * calculate scroll height automatically (as height will be undefined).\n   */\n  get scrollHeight(): number | undefined {\n    if (this.scrollbarV && this.virtualization && this.rowCount) {\n      return this.rowHeightsCache.query(this.rowCount - 1);\n    }\n    // avoid TS7030: Not all code paths return a value.\n    return undefined;\n  }\n\n  rowHeightsCache: RowHeightCache = new RowHeightCache();\n  temp: any[] = [];\n  offsetY = 0;\n  indexes: any = {};\n  columnGroupWidths: any;\n  columnGroupWidthsWithoutGroup: any;\n  rowTrackingFn: any;\n  listener: any;\n  rowIndexes: any = new Map();\n  rowExpansions: any[] = [];\n\n  _rows: any[];\n  _bodyHeight: any;\n  _columns: any[];\n  _rowCount: number;\n  _offset: number;\n  _pageSize: number;\n\n  /**\n   * Creates an instance of DataTableBodyComponent.\n   */\n  constructor(private cd: ChangeDetectorRef) {\n    // declare fn here so we can get access to the `this` property\n    this.rowTrackingFn = (index: number, row: any): any => {\n      const idx = this.getRowIndex(row);\n      if (this.trackByProp) {\n        return row[this.trackByProp];\n      } else {\n        return idx;\n      }\n    };\n  }\n\n  /**\n   * Called after the constructor, initializing input properties\n   */\n  ngOnInit(): void {\n    if (this.rowDetail) {\n      this.listener = this.rowDetail.toggle.subscribe(({ type, value }: { type: string; value: any }) => {\n        if (type === 'row') {\n          this.toggleRowExpansion(value);\n        }\n        if (type === 'all') {\n          this.toggleAllRows(value);\n        }\n\n        // Refresh rows after toggle\n        // Fixes #883\n        this.updateIndexes();\n        this.updateRows();\n        this.cd.markForCheck();\n      });\n    }\n\n    if (this.groupHeader) {\n      this.listener = this.groupHeader.toggle.subscribe(({ type, value }: { type: string; value: any }) => {\n        if (type === 'group') {\n          this.toggleRowExpansion(value);\n        }\n        if (type === 'all') {\n          this.toggleAllRows(value);\n        }\n\n        // Refresh rows after toggle\n        // Fixes #883\n        this.updateIndexes();\n        this.updateRows();\n        this.cd.markForCheck();\n      });\n    }\n  }\n\n  /**\n   * Called once, before the instance is destroyed.\n   */\n  ngOnDestroy(): void {\n    if (this.rowDetail || this.groupHeader) {\n      this.listener.unsubscribe();\n    }\n  }\n\n  /**\n   * Updates the Y offset given a new offset.\n   */\n  updateOffsetY(offset?: number): void {\n    // scroller is missing on empty table\n    if (!this.scroller) {\n      return;\n    }\n\n    if (this.scrollbarV && this.virtualization && offset) {\n      // First get the row Index that we need to move to.\n      const rowIndex = this.pageSize * offset;\n      offset = this.rowHeightsCache.query(rowIndex - 1);\n    } else if (this.scrollbarV && !this.virtualization) {\n      offset = 0;\n    }\n\n    this.scroller.setOffset(offset || 0);\n  }\n\n  /**\n   * Body was scrolled, this is mainly useful for\n   * when a user is server-side pagination via virtual scroll.\n   */\n  onBodyScroll(event: any): void {\n    const scrollYPos: number = event.scrollYPos;\n    const scrollXPos: number = event.scrollXPos;\n\n    // if scroll change, trigger update\n    // this is mainly used for header cell positions\n    if (this.offsetY !== scrollYPos || this.offsetX !== scrollXPos) {\n      this.scroll.emit({\n        offsetY: scrollYPos,\n        offsetX: scrollXPos\n      });\n    }\n\n    this.offsetY = scrollYPos;\n    this.offsetX = scrollXPos;\n\n    this.updateIndexes();\n    this.updatePage(event.direction);\n    this.updateRows();\n  }\n\n  /**\n   * Updates the page given a direction.\n   */\n  updatePage(direction: string): void {\n    let offset = this.indexes.first / this.pageSize;\n\n    if (direction === 'up') {\n      offset = Math.ceil(offset);\n    } else if (direction === 'down') {\n      offset = Math.floor(offset);\n    }\n\n    if (direction !== undefined && !isNaN(offset)) {\n      this.page.emit({ offset });\n    }\n  }\n\n  /**\n   * Updates the rows in the view port\n   */\n  updateRows(): void {\n    const { first, last } = this.indexes;\n    let rowIndex = first;\n    let idx = 0;\n    const temp: any[] = [];\n\n    this.rowIndexes.clear();\n\n    // if grouprowsby has been specified treat row paging\n    // parameters as group paging parameters ie if limit 10 has been\n    // specified treat it as 10 groups rather than 10 rows\n    if (this.groupedRows) {\n      let maxRowsPerGroup = 3;\n      // if there is only one group set the maximum number of\n      // rows per group the same as the total number of rows\n      if (this.groupedRows.length === 1) {\n        maxRowsPerGroup = this.groupedRows[0].value.length;\n      }\n\n      while (rowIndex < last && rowIndex < this.groupedRows.length) {\n        // Add the groups into this page\n        const group = this.groupedRows[rowIndex];\n        temp[idx] = group;\n        idx++;\n\n        // Group index in this context\n        rowIndex++;\n      }\n    } else {\n      while (rowIndex < last && rowIndex < this.rowCount) {\n        const row = this.rows[rowIndex];\n\n        if (row) {\n          this.rowIndexes.set(row, rowIndex);\n          temp[idx] = row;\n        }\n\n        idx++;\n        rowIndex++;\n      }\n    }\n\n    this.temp = temp;\n  }\n\n  /**\n   * Get the row height\n   */\n  getRowHeight(row: any): number {\n    // if its a function return it\n    if (typeof this.rowHeight === 'function') {\n      return this.rowHeight(row);\n    }\n\n    return this.rowHeight as number;\n  }\n\n  /**\n   * @param group the group with all rows\n   */\n  getGroupHeight(group: any): number {\n    let rowHeight = 0;\n\n    if (group.value) {\n      for (let index = 0; index < group.value.length; index++) {\n        rowHeight += this.getRowAndDetailHeight(group.value[index]);\n      }\n    }\n\n    return rowHeight;\n  }\n\n  /**\n   * Calculate row height based on the expanded state of the row.\n   */\n  getRowAndDetailHeight(row: any): number {\n    let rowHeight = this.getRowHeight(row);\n    const expanded = this.getRowExpanded(row);\n\n    // Adding detail row height if its expanded.\n    if (expanded) {\n      rowHeight += this.getDetailRowHeight(row);\n    }\n\n    return rowHeight;\n  }\n\n  /**\n   * Get the height of the detail row.\n   */\n  getDetailRowHeight = (row?: any, index?: any): number => {\n    if (!this.rowDetail) {\n      return 0;\n    }\n    const rowHeight = this.rowDetail.rowHeight;\n    return typeof rowHeight === 'function' ? rowHeight(row, index) : (rowHeight as number);\n  };\n\n  /**\n   * Calculates the styles for the row so that the rows can be moved in 2D space\n   * during virtual scroll inside the DOM.   In the below case the Y position is\n   * manipulated.   As an example, if the height of row 0 is 30 px and row 1 is\n   * 100 px then following styles are generated:\n   *\n   * transform: translate3d(0px, 0px, 0px);    ->  row0\n   * transform: translate3d(0px, 30px, 0px);   ->  row1\n   * transform: translate3d(0px, 130px, 0px);  ->  row2\n   *\n   * Row heights have to be calculated based on the row heights cache as we wont\n   * be able to determine which row is of what height before hand.  In the above\n   * case the positionY of the translate3d for row2 would be the sum of all the\n   * heights of the rows before it (i.e. row0 and row1).\n   *\n   * @param rows the row that needs to be placed in the 2D space.\n   * @returns the CSS3 style to be applied\n   *\n   * @memberOf DataTableBodyComponent\n   */\n  getRowsStyles(rows: any): any {\n    const styles: any = {};\n\n    // only add styles for the group if there is a group\n    if (this.groupedRows) {\n      styles.width = this.columnGroupWidths.total;\n    }\n\n    if (this.scrollbarV && this.virtualization) {\n      let idx = 0;\n\n      if (this.groupedRows) {\n        // Get the latest row rowindex in a group\n        const row = rows[rows.length - 1];\n        idx = row ? this.getRowIndex(row) : 0;\n      } else {\n        idx = this.getRowIndex(rows);\n      }\n\n      // const pos = idx * rowHeight;\n      // The position of this row would be the sum of all row heights\n      // until the previous row position.\n      const pos = this.rowHeightsCache.query(idx - 1);\n\n      translateXY(styles, 0, pos);\n    }\n\n    return styles;\n  }\n\n  /**\n   * Calculate bottom summary row offset for scrollbar mode.\n   * For more information about cache and offset calculation\n   * see description for `getRowsStyles` method\n   *\n   * @returns the CSS3 style to be applied\n   *\n   * @memberOf DataTableBodyComponent\n   */\n  getBottomSummaryRowStyles(): any {\n    if (!this.scrollbarV || !this.rows || !this.rows.length) {\n      return null;\n    }\n\n    const styles = { position: 'absolute' };\n    const pos = this.rowHeightsCache.query(this.rows.length - 1);\n\n    translateXY(styles, 0, pos);\n\n    return styles;\n  }\n\n  /**\n   * Hides the loading indicator\n   */\n  hideIndicator(): void {\n    setTimeout(() => (this.loadingIndicator = false), 500);\n  }\n\n  /**\n   * Updates the index of the rows in the viewport\n   */\n  updateIndexes(): void {\n    let first = 0;\n    let last = 0;\n\n    if (this.scrollbarV) {\n      if (this.virtualization) {\n        // Calculation of the first and last indexes will be based on where the\n        // scrollY position would be at.  The last index would be the one\n        // that shows up inside the view port the last.\n        const height = parseInt(this.bodyHeight, 0);\n        first = this.rowHeightsCache.getRowIndex(this.offsetY);\n        last = this.rowHeightsCache.getRowIndex(height + this.offsetY) + 1;\n      } else {\n        // If virtual rows are not needed\n        // We render all in one go\n        first = 0;\n        last = this.rowCount;\n      }\n    } else {\n      // The server is handling paging and will pass an array that begins with the\n      // element at a specified offset.  first should always be 0 with external paging.\n      if (!this.externalPaging) {\n        first = Math.max(this.offset * this.pageSize, 0);\n      }\n      last = Math.min(first + this.pageSize, this.rowCount);\n    }\n\n    this.indexes = { first, last };\n  }\n\n  /**\n   * Refreshes the full Row Height cache.  Should be used\n   * when the entire row array state has changed.\n   */\n  refreshRowHeightCache(): void {\n    if (!this.scrollbarV || (this.scrollbarV && !this.virtualization)) {\n      return;\n    }\n\n    // clear the previous row height cache if already present.\n    // this is useful during sorts, filters where the state of the\n    // rows array is changed.\n    this.rowHeightsCache.clearCache();\n\n    // Initialize the tree only if there are rows inside the tree.\n    if (this.rows && this.rows.length) {\n      const rowExpansions = new Set();\n      for (const row of this.rows) {\n        if (this.getRowExpanded(row)) {\n          rowExpansions.add(row);\n        }\n      }\n\n      this.rowHeightsCache.initCache({\n        rows: this.rows,\n        rowHeight: this.rowHeight,\n        detailRowHeight: this.getDetailRowHeight,\n        externalVirtual: this.scrollbarV && this.externalPaging,\n        rowCount: this.rowCount,\n        rowIndexes: this.rowIndexes,\n        rowExpansions\n      });\n    }\n  }\n\n  /**\n   * Gets the index for the view port\n   */\n  getAdjustedViewPortIndex(): number {\n    // Capture the row index of the first row that is visible on the viewport.\n    // If the scroll bar is just below the row which is highlighted then make that as the\n    // first index.\n    const viewPortFirstRowIndex = this.indexes.first;\n\n    if (this.scrollbarV && this.virtualization) {\n      const offsetScroll = this.rowHeightsCache.query(viewPortFirstRowIndex - 1);\n      return offsetScroll <= this.offsetY ? viewPortFirstRowIndex - 1 : viewPortFirstRowIndex;\n    }\n\n    return viewPortFirstRowIndex;\n  }\n\n  /**\n   * Toggle the Expansion of the row i.e. if the row is expanded then it will\n   * collapse and vice versa.   Note that the expanded status is stored as\n   * a part of the row object itself as we have to preserve the expanded row\n   * status in case of sorting and filtering of the row set.\n   */\n  toggleRowExpansion(row: any): void {\n    // Capture the row index of the first row that is visible on the viewport.\n    const viewPortFirstRowIndex = this.getAdjustedViewPortIndex();\n    const rowExpandedIdx = this.getRowExpandedIdx(row, this.rowExpansions);\n    const expanded = rowExpandedIdx > -1;\n\n    // If the detailRowHeight is auto --> only in case of non-virtualized scroll\n    if (this.scrollbarV && this.virtualization) {\n      const detailRowHeight = this.getDetailRowHeight(row) * (expanded ? -1 : 1);\n      // const idx = this.rowIndexes.get(row) || 0;\n      const idx = this.getRowIndex(row);\n      this.rowHeightsCache.update(idx, detailRowHeight);\n    }\n\n    // Update the toggled row and update thive nevere heights in the cache.\n    if (expanded) {\n      this.rowExpansions.splice(rowExpandedIdx, 1);\n    } else {\n      this.rowExpansions.push(row);\n    }\n\n    this.detailToggle.emit({\n      rows: [row],\n      currentIndex: viewPortFirstRowIndex\n    });\n  }\n\n  /**\n   * Expand/Collapse all the rows no matter what their state is.\n   */\n  toggleAllRows(expanded: boolean): void {\n    // clear prev expansions\n    this.rowExpansions = [];\n\n    // Capture the row index of the first row that is visible on the viewport.\n    const viewPortFirstRowIndex = this.getAdjustedViewPortIndex();\n\n    if (expanded) {\n      for (const row of this.rows) {\n        this.rowExpansions.push(row);\n      }\n    }\n\n    if (this.scrollbarV) {\n      // Refresh the full row heights cache since every row was affected.\n      this.recalcLayout();\n    }\n\n    // Emit all rows that have been expanded.\n    this.detailToggle.emit({\n      rows: this.rows,\n      currentIndex: viewPortFirstRowIndex\n    });\n  }\n\n  /**\n   * Recalculates the table\n   */\n  recalcLayout(): void {\n    this.refreshRowHeightCache();\n    this.updateIndexes();\n    this.updateRows();\n  }\n\n  /**\n   * Tracks the column\n   */\n  columnTrackingFn(index: number, column: any): any {\n    return column.$$id;\n  }\n\n  /**\n   * Gets the row pinning group styles\n   */\n  stylesByGroup(group: string) {\n    const widths = this.columnGroupWidths;\n    const offsetX = this.offsetX;\n\n    const styles = {\n      width: `${widths[group]}px`\n    };\n\n    if (group === 'left') {\n      translateXY(styles, offsetX, 0);\n    } else if (group === 'right') {\n      const bodyWidth = parseInt(this.innerWidth + '', 0);\n      const totalDiff = widths.total - bodyWidth;\n      const offsetDiff = totalDiff - offsetX;\n      const offset = offsetDiff * -1;\n      translateXY(styles, offset, 0);\n    }\n\n    return styles;\n  }\n\n  /**\n   * Returns if the row was expanded and set default row expansion when row expansion is empty\n   */\n  getRowExpanded(row: any): boolean {\n    if (this.rowExpansions.length === 0 && this.groupExpansionDefault) {\n      for (const group of this.groupedRows) {\n        this.rowExpansions.push(group);\n      }\n    }\n\n    return this.getRowExpandedIdx(row, this.rowExpansions) > -1;\n  }\n\n  getRowExpandedIdx(row: any, expanded: any[]): number {\n    if (!expanded || !expanded.length) return -1;\n\n    const rowId = this.rowIdentity(row);\n    return expanded.findIndex((r) => {\n      const id = this.rowIdentity(r);\n      return id === rowId;\n    });\n  }\n\n  /**\n   * Gets the row index given a row\n   */\n  getRowIndex(row: any): number {\n    return this.rowIndexes.get(row) || 0;\n  }\n\n  onTreeAction(row: any) {\n    this.treeAction.emit({ row });\n  }\n}\n"]}