@covalent/core 3.1.2 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (317) hide show
  1. package/bundles/covalent-core-user-profile.umd.js +1 -9
  2. package/bundles/covalent-core-user-profile.umd.js.map +1 -1
  3. package/bundles/covalent-core-user-profile.umd.min.js.map +1 -1
  4. package/esm2015/user-profile/user-profile.module.js +3 -11
  5. package/fesm2015/covalent-core-user-profile.js +1 -9
  6. package/fesm2015/covalent-core-user-profile.js.map +1 -1
  7. package/package.json +1 -1
  8. package/schematics/components.js +1 -14
  9. package/schematics/components.js.map +1 -1
  10. package/theming/_all-theme.scss +0 -14
  11. package/theming/prebuilt/blue-grey-deep-orange.css +0 -248
  12. package/theming/prebuilt/blue-grey-deep-orange.css.map +1 -1
  13. package/theming/prebuilt/blue-orange.css +0 -248
  14. package/theming/prebuilt/blue-orange.css.map +1 -1
  15. package/theming/prebuilt/indigo-pink.css +0 -248
  16. package/theming/prebuilt/indigo-pink.css.map +1 -1
  17. package/theming/prebuilt/orange-light-blue.css +0 -248
  18. package/theming/prebuilt/orange-light-blue.css.map +1 -1
  19. package/theming/prebuilt/teal-orange.css +0 -248
  20. package/theming/prebuilt/teal-orange.css.map +1 -1
  21. package/typography/_all-typography.scss +0 -10
  22. package/user-profile/covalent-core-user-profile.metadata.json +1 -1
  23. package/bundles/covalent-core-chips.umd.js +0 -1507
  24. package/bundles/covalent-core-chips.umd.js.map +0 -1
  25. package/bundles/covalent-core-chips.umd.min.js +0 -16
  26. package/bundles/covalent-core-chips.umd.min.js.map +0 -1
  27. package/bundles/covalent-core-data-table.umd.js +0 -2756
  28. package/bundles/covalent-core-data-table.umd.js.map +0 -1
  29. package/bundles/covalent-core-data-table.umd.min.js +0 -16
  30. package/bundles/covalent-core-data-table.umd.min.js.map +0 -1
  31. package/bundles/covalent-core-expansion-panel.umd.js +0 -853
  32. package/bundles/covalent-core-expansion-panel.umd.js.map +0 -1
  33. package/bundles/covalent-core-expansion-panel.umd.min.js +0 -16
  34. package/bundles/covalent-core-expansion-panel.umd.min.js.map +0 -1
  35. package/bundles/covalent-core-loading.umd.js +0 -1534
  36. package/bundles/covalent-core-loading.umd.js.map +0 -1
  37. package/bundles/covalent-core-loading.umd.min.js +0 -16
  38. package/bundles/covalent-core-loading.umd.min.js.map +0 -1
  39. package/bundles/covalent-core-media.umd.js +0 -749
  40. package/bundles/covalent-core-media.umd.js.map +0 -1
  41. package/bundles/covalent-core-media.umd.min.js +0 -16
  42. package/bundles/covalent-core-media.umd.min.js.map +0 -1
  43. package/bundles/covalent-core-nav-links.umd.js +0 -197
  44. package/bundles/covalent-core-nav-links.umd.js.map +0 -1
  45. package/bundles/covalent-core-nav-links.umd.min.js +0 -2
  46. package/bundles/covalent-core-nav-links.umd.min.js.map +0 -1
  47. package/bundles/covalent-core-notifications.umd.js +0 -275
  48. package/bundles/covalent-core-notifications.umd.js.map +0 -1
  49. package/bundles/covalent-core-notifications.umd.min.js +0 -2
  50. package/bundles/covalent-core-notifications.umd.min.js.map +0 -1
  51. package/bundles/covalent-core-paging.umd.js +0 -491
  52. package/bundles/covalent-core-paging.umd.js.map +0 -1
  53. package/bundles/covalent-core-paging.umd.min.js +0 -2
  54. package/bundles/covalent-core-paging.umd.min.js.map +0 -1
  55. package/bundles/covalent-core-sidesheet.umd.js +0 -145
  56. package/bundles/covalent-core-sidesheet.umd.js.map +0 -1
  57. package/bundles/covalent-core-sidesheet.umd.min.js +0 -2
  58. package/bundles/covalent-core-sidesheet.umd.min.js.map +0 -1
  59. package/bundles/covalent-core-steps.umd.js +0 -1756
  60. package/bundles/covalent-core-steps.umd.js.map +0 -1
  61. package/bundles/covalent-core-steps.umd.min.js +0 -16
  62. package/bundles/covalent-core-steps.umd.min.js.map +0 -1
  63. package/bundles/covalent-core-tab-select.umd.js +0 -732
  64. package/bundles/covalent-core-tab-select.umd.js.map +0 -1
  65. package/bundles/covalent-core-tab-select.umd.min.js +0 -16
  66. package/bundles/covalent-core-tab-select.umd.min.js.map +0 -1
  67. package/bundles/covalent-core-virtual-scroll.umd.js +0 -785
  68. package/bundles/covalent-core-virtual-scroll.umd.js.map +0 -1
  69. package/bundles/covalent-core-virtual-scroll.umd.min.js +0 -16
  70. package/bundles/covalent-core-virtual-scroll.umd.min.js.map +0 -1
  71. package/chips/README.md +0 -99
  72. package/chips/_chips-theme.scss +0 -87
  73. package/chips/chips.component.d.ts +0 -287
  74. package/chips/chips.component.scss +0 -147
  75. package/chips/chips.module.d.ts +0 -2
  76. package/chips/covalent-core-chips.d.ts +0 -4
  77. package/chips/covalent-core-chips.metadata.json +0 -1
  78. package/chips/index.d.ts +0 -1
  79. package/chips/package.json +0 -11
  80. package/chips/public-api.d.ts +0 -2
  81. package/data-table/README.md +0 -134
  82. package/data-table/_data-table-theme.scss +0 -115
  83. package/data-table/covalent-core-data-table.d.ts +0 -4
  84. package/data-table/covalent-core-data-table.metadata.json +0 -1
  85. package/data-table/data-table-cell/data-table-cell.component.d.ts +0 -22
  86. package/data-table/data-table-cell/data-table-cell.component.scss +0 -58
  87. package/data-table/data-table-column/data-table-column.component.d.ts +0 -63
  88. package/data-table/data-table-column/data-table-column.component.scss +0 -80
  89. package/data-table/data-table-row/data-table-row.component.d.ts +0 -20
  90. package/data-table/data-table-row/data-table-row.component.scss +0 -12
  91. package/data-table/data-table-table/data-table-table.component.d.ts +0 -6
  92. package/data-table/data-table-table/data-table-table.component.scss +0 -7
  93. package/data-table/data-table.component.d.ts +0 -356
  94. package/data-table/data-table.component.scss +0 -93
  95. package/data-table/data-table.module.d.ts +0 -2
  96. package/data-table/directives/data-table-template.directive.d.ts +0 -6
  97. package/data-table/index.d.ts +0 -1
  98. package/data-table/package.json +0 -11
  99. package/data-table/public-api.d.ts +0 -8
  100. package/data-table/services/data-table.service.d.ts +0 -31
  101. package/esm2015/chips/chips.component.js +0 -1115
  102. package/esm2015/chips/chips.module.js +0 -23
  103. package/esm2015/chips/covalent-core-chips.js +0 -10
  104. package/esm2015/chips/index.js +0 -7
  105. package/esm2015/chips/public-api.js +0 -8
  106. package/esm2015/data-table/covalent-core-data-table.js +0 -10
  107. package/esm2015/data-table/data-table-cell/data-table-cell.component.js +0 -88
  108. package/esm2015/data-table/data-table-column/data-table-column.component.js +0 -218
  109. package/esm2015/data-table/data-table-row/data-table-row.component.js +0 -132
  110. package/esm2015/data-table/data-table-table/data-table-table.component.js +0 -43
  111. package/esm2015/data-table/data-table.component.js +0 -1640
  112. package/esm2015/data-table/data-table.module.js +0 -39
  113. package/esm2015/data-table/directives/data-table-template.directive.js +0 -32
  114. package/esm2015/data-table/index.js +0 -7
  115. package/esm2015/data-table/public-api.js +0 -14
  116. package/esm2015/data-table/services/data-table.service.js +0 -116
  117. package/esm2015/expansion-panel/covalent-core-expansion-panel.js +0 -10
  118. package/esm2015/expansion-panel/expansion-panel-group.component.js +0 -212
  119. package/esm2015/expansion-panel/expansion-panel.component.js +0 -272
  120. package/esm2015/expansion-panel/expansion-panel.module.js +0 -31
  121. package/esm2015/expansion-panel/index.js +0 -7
  122. package/esm2015/expansion-panel/public-api.js +0 -9
  123. package/esm2015/loading/covalent-core-loading.js +0 -10
  124. package/esm2015/loading/directives/loading.directive.js +0 -231
  125. package/esm2015/loading/index.js +0 -7
  126. package/esm2015/loading/loading.component.js +0 -302
  127. package/esm2015/loading/loading.module.js +0 -30
  128. package/esm2015/loading/public-api.js +0 -11
  129. package/esm2015/loading/services/loading.factory.js +0 -297
  130. package/esm2015/loading/services/loading.service.js +0 -319
  131. package/esm2015/media/covalent-core-media.js +0 -10
  132. package/esm2015/media/directives/media-toggle.directive.js +0 -207
  133. package/esm2015/media/index.js +0 -7
  134. package/esm2015/media/media.module.js +0 -20
  135. package/esm2015/media/public-api.js +0 -9
  136. package/esm2015/media/services/media.service.js +0 -169
  137. package/esm2015/nav-links/covalent-core-nav-links.js +0 -10
  138. package/esm2015/nav-links/index.js +0 -7
  139. package/esm2015/nav-links/nav-links.component.js +0 -138
  140. package/esm2015/nav-links/nav-links.module.js +0 -37
  141. package/esm2015/nav-links/public-api.js +0 -8
  142. package/esm2015/notifications/covalent-core-notifications.js +0 -10
  143. package/esm2015/notifications/index.js +0 -7
  144. package/esm2015/notifications/notification-count.component.js +0 -191
  145. package/esm2015/notifications/notifications.module.js +0 -20
  146. package/esm2015/notifications/public-api.js +0 -8
  147. package/esm2015/paging/covalent-core-paging.js +0 -10
  148. package/esm2015/paging/index.js +0 -7
  149. package/esm2015/paging/paging-bar.component.js +0 -412
  150. package/esm2015/paging/paging.module.js +0 -20
  151. package/esm2015/paging/public-api.js +0 -8
  152. package/esm2015/sidesheet/covalent-core-sidesheet.js +0 -10
  153. package/esm2015/sidesheet/index.js +0 -7
  154. package/esm2015/sidesheet/public-api.js +0 -8
  155. package/esm2015/sidesheet/sidesheet.component.js +0 -72
  156. package/esm2015/sidesheet/sidesheet.module.js +0 -27
  157. package/esm2015/steps/covalent-core-steps.js +0 -10
  158. package/esm2015/steps/index.js +0 -7
  159. package/esm2015/steps/nav/nav-step-link/nav-step-link.component.js +0 -144
  160. package/esm2015/steps/nav/nav-steps-horizontal/nav-steps-horizontal.component.js +0 -371
  161. package/esm2015/steps/nav/nav-steps-vertical/nav-steps-vertical.component.js +0 -130
  162. package/esm2015/steps/public-api.js +0 -14
  163. package/esm2015/steps/step-body/step-body.component.js +0 -83
  164. package/esm2015/steps/step-header/step-header.component.js +0 -79
  165. package/esm2015/steps/step.component.js +0 -312
  166. package/esm2015/steps/steps.component.js +0 -234
  167. package/esm2015/steps/steps.module.js +0 -44
  168. package/esm2015/tab-select/covalent-core-tab-select.js +0 -10
  169. package/esm2015/tab-select/index.js +0 -7
  170. package/esm2015/tab-select/public-api.js +0 -9
  171. package/esm2015/tab-select/tab-option.component.js +0 -82
  172. package/esm2015/tab-select/tab-select.component.js +0 -291
  173. package/esm2015/tab-select/tab-select.module.js +0 -31
  174. package/esm2015/virtual-scroll/covalent-core-virtual-scroll.js +0 -10
  175. package/esm2015/virtual-scroll/index.js +0 -7
  176. package/esm2015/virtual-scroll/public-api.js +0 -9
  177. package/esm2015/virtual-scroll/virtual-scroll-container.component.js +0 -391
  178. package/esm2015/virtual-scroll/virtual-scroll-row.directive.js +0 -25
  179. package/esm2015/virtual-scroll/virtual-scroll.module.js +0 -21
  180. package/expansion-panel/README.md +0 -116
  181. package/expansion-panel/_expansion-panel-theme.scss +0 -80
  182. package/expansion-panel/covalent-core-expansion-panel.d.ts +0 -4
  183. package/expansion-panel/covalent-core-expansion-panel.metadata.json +0 -1
  184. package/expansion-panel/expansion-panel-group.component.d.ts +0 -31
  185. package/expansion-panel/expansion-panel-group.component.scss +0 -0
  186. package/expansion-panel/expansion-panel.component.d.ts +0 -82
  187. package/expansion-panel/expansion-panel.component.scss +0 -50
  188. package/expansion-panel/expansion-panel.module.d.ts +0 -2
  189. package/expansion-panel/index.d.ts +0 -1
  190. package/expansion-panel/package.json +0 -11
  191. package/expansion-panel/public-api.d.ts +0 -3
  192. package/fesm2015/covalent-core-chips.js +0 -1151
  193. package/fesm2015/covalent-core-chips.js.map +0 -1
  194. package/fesm2015/covalent-core-data-table.js +0 -2309
  195. package/fesm2015/covalent-core-data-table.js.map +0 -1
  196. package/fesm2015/covalent-core-expansion-panel.js +0 -528
  197. package/fesm2015/covalent-core-expansion-panel.js.map +0 -1
  198. package/fesm2015/covalent-core-loading.js +0 -1179
  199. package/fesm2015/covalent-core-loading.js.map +0 -1
  200. package/fesm2015/covalent-core-media.js +0 -411
  201. package/fesm2015/covalent-core-media.js.map +0 -1
  202. package/fesm2015/covalent-core-nav-links.js +0 -193
  203. package/fesm2015/covalent-core-nav-links.js.map +0 -1
  204. package/fesm2015/covalent-core-notifications.js +0 -228
  205. package/fesm2015/covalent-core-notifications.js.map +0 -1
  206. package/fesm2015/covalent-core-paging.js +0 -451
  207. package/fesm2015/covalent-core-paging.js.map +0 -1
  208. package/fesm2015/covalent-core-sidesheet.js +0 -118
  209. package/fesm2015/covalent-core-sidesheet.js.map +0 -1
  210. package/fesm2015/covalent-core-steps.js +0 -1384
  211. package/fesm2015/covalent-core-steps.js.map +0 -1
  212. package/fesm2015/covalent-core-tab-select.js +0 -416
  213. package/fesm2015/covalent-core-tab-select.js.map +0 -1
  214. package/fesm2015/covalent-core-virtual-scroll.js +0 -453
  215. package/fesm2015/covalent-core-virtual-scroll.js.map +0 -1
  216. package/loading/README.md +0 -180
  217. package/loading/_loading-theme.scss +0 -10
  218. package/loading/covalent-core-loading.d.ts +0 -4
  219. package/loading/covalent-core-loading.metadata.json +0 -1
  220. package/loading/directives/loading.directive.d.ts +0 -71
  221. package/loading/index.d.ts +0 -1
  222. package/loading/loading.component.d.ts +0 -87
  223. package/loading/loading.component.scss +0 -42
  224. package/loading/loading.module.d.ts +0 -2
  225. package/loading/package.json +0 -11
  226. package/loading/public-api.d.ts +0 -5
  227. package/loading/services/loading.factory.d.ts +0 -66
  228. package/loading/services/loading.service.d.ts +0 -118
  229. package/media/covalent-core-media.d.ts +0 -4
  230. package/media/covalent-core-media.metadata.json +0 -1
  231. package/media/directives/media-toggle.directive.d.ts +0 -42
  232. package/media/index.d.ts +0 -1
  233. package/media/media.module.d.ts +0 -2
  234. package/media/package.json +0 -11
  235. package/media/public-api.d.ts +0 -3
  236. package/media/services/media.service.d.ts +0 -31
  237. package/nav-links/README.md +0 -1
  238. package/nav-links/covalent-core-nav-links.d.ts +0 -4
  239. package/nav-links/covalent-core-nav-links.metadata.json +0 -1
  240. package/nav-links/index.d.ts +0 -1
  241. package/nav-links/nav-links.component.d.ts +0 -51
  242. package/nav-links/nav-links.component.scss +0 -15
  243. package/nav-links/nav-links.module.d.ts +0 -2
  244. package/nav-links/package.json +0 -11
  245. package/nav-links/public-api.d.ts +0 -2
  246. package/notifications/README.md +0 -69
  247. package/notifications/_notification-count-theme.scss +0 -27
  248. package/notifications/covalent-core-notifications.d.ts +0 -4
  249. package/notifications/covalent-core-notifications.metadata.json +0 -1
  250. package/notifications/index.d.ts +0 -1
  251. package/notifications/notification-count.component.d.ts +0 -74
  252. package/notifications/notification-count.component.scss +0 -90
  253. package/notifications/notifications.module.d.ts +0 -2
  254. package/notifications/package.json +0 -11
  255. package/notifications/public-api.d.ts +0 -2
  256. package/paging/README.md +0 -141
  257. package/paging/_paging-bar-theme.scss +0 -26
  258. package/paging/covalent-core-paging.d.ts +0 -4
  259. package/paging/covalent-core-paging.metadata.json +0 -1
  260. package/paging/index.d.ts +0 -1
  261. package/paging/package.json +0 -11
  262. package/paging/paging-bar.component.d.ts +0 -115
  263. package/paging/paging-bar.component.scss +0 -23
  264. package/paging/paging.module.d.ts +0 -2
  265. package/paging/public-api.d.ts +0 -2
  266. package/sidesheet/README.md +0 -68
  267. package/sidesheet/covalent-core-sidesheet.d.ts +0 -4
  268. package/sidesheet/covalent-core-sidesheet.metadata.json +0 -1
  269. package/sidesheet/index.d.ts +0 -1
  270. package/sidesheet/package.json +0 -11
  271. package/sidesheet/public-api.d.ts +0 -2
  272. package/sidesheet/sidesheet.component.d.ts +0 -13
  273. package/sidesheet/sidesheet.component.scss +0 -101
  274. package/sidesheet/sidesheet.module.d.ts +0 -2
  275. package/steps/README.md +0 -159
  276. package/steps/_steps-theme.scss +0 -108
  277. package/steps/covalent-core-steps.d.ts +0 -4
  278. package/steps/covalent-core-steps.metadata.json +0 -1
  279. package/steps/index.d.ts +0 -1
  280. package/steps/nav/README.md +0 -90
  281. package/steps/nav/nav-step-link/nav-step-link.component.d.ts +0 -42
  282. package/steps/nav/nav-step-link/nav-step-link.component.scss +0 -17
  283. package/steps/nav/nav-steps-horizontal/nav-steps-horizontal.component.d.ts +0 -79
  284. package/steps/nav/nav-steps-horizontal/nav-steps-horizontal.component.scss +0 -83
  285. package/steps/nav/nav-steps-vertical/nav-steps-vertical.component.d.ts +0 -18
  286. package/steps/nav/nav-steps-vertical/nav-steps-vertical.component.scss +0 -18
  287. package/steps/package.json +0 -11
  288. package/steps/public-api.d.ts +0 -8
  289. package/steps/step-body/step-body.component.d.ts +0 -25
  290. package/steps/step-body/step-body.component.scss +0 -29
  291. package/steps/step-header/step-header.component.d.ts +0 -35
  292. package/steps/step-header/step-header.component.scss +0 -90
  293. package/steps/step.component.d.ts +0 -97
  294. package/steps/steps.component.d.ts +0 -60
  295. package/steps/steps.component.scss +0 -55
  296. package/steps/steps.module.d.ts +0 -2
  297. package/tab-select/README.md +0 -93
  298. package/tab-select/covalent-core-tab-select.d.ts +0 -4
  299. package/tab-select/covalent-core-tab-select.metadata.json +0 -1
  300. package/tab-select/index.d.ts +0 -1
  301. package/tab-select/package.json +0 -11
  302. package/tab-select/public-api.d.ts +0 -3
  303. package/tab-select/tab-option.component.d.ts +0 -20
  304. package/tab-select/tab-option.component.scss +0 -0
  305. package/tab-select/tab-select.component.d.ts +0 -62
  306. package/tab-select/tab-select.component.scss +0 -3
  307. package/tab-select/tab-select.module.d.ts +0 -2
  308. package/virtual-scroll/README.md +0 -68
  309. package/virtual-scroll/covalent-core-virtual-scroll.d.ts +0 -4
  310. package/virtual-scroll/covalent-core-virtual-scroll.metadata.json +0 -1
  311. package/virtual-scroll/index.d.ts +0 -1
  312. package/virtual-scroll/package.json +0 -11
  313. package/virtual-scroll/public-api.d.ts +0 -3
  314. package/virtual-scroll/virtual-scroll-container.component.d.ts +0 -73
  315. package/virtual-scroll/virtual-scroll-container.component.scss +0 -7
  316. package/virtual-scroll/virtual-scroll-row.directive.d.ts +0 -5
  317. package/virtual-scroll/virtual-scroll.module.d.ts +0 -2
@@ -1,1640 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: data-table.component.ts
4
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
- */
6
- import { Component, Input, Output, EventEmitter, forwardRef, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild, ContentChildren, QueryList, Inject, Optional, ViewChildren, ElementRef, } from '@angular/core';
7
- import { DOCUMENT } from '@angular/common';
8
- import { DomSanitizer } from '@angular/platform-browser';
9
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
10
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
11
- import { ENTER, SPACE, UP_ARROW, DOWN_ARROW } from '@angular/cdk/keycodes';
12
- import { Subject } from 'rxjs';
13
- import { debounceTime } from 'rxjs/operators';
14
- import { TdDataTableRowComponent } from './data-table-row/data-table-row.component';
15
- import { TdDataTableTemplateDirective } from './directives/data-table-template.directive';
16
- import { mixinControlValueAccessor } from '@covalent/core/common';
17
- /** @enum {string} */
18
- const TdDataTableSortingOrder = {
19
- Ascending: "ASC",
20
- Descending: "DESC",
21
- };
22
- export { TdDataTableSortingOrder };
23
- /**
24
- * @record
25
- */
26
- export function ITdDataTableColumnWidth() { }
27
- if (false) {
28
- /** @type {?|undefined} */
29
- ITdDataTableColumnWidth.prototype.min;
30
- /** @type {?|undefined} */
31
- ITdDataTableColumnWidth.prototype.max;
32
- }
33
- /**
34
- * @record
35
- */
36
- export function ITdDataTableColumn() { }
37
- if (false) {
38
- /** @type {?} */
39
- ITdDataTableColumn.prototype.name;
40
- /** @type {?} */
41
- ITdDataTableColumn.prototype.label;
42
- /** @type {?|undefined} */
43
- ITdDataTableColumn.prototype.tooltip;
44
- /** @type {?|undefined} */
45
- ITdDataTableColumn.prototype.numeric;
46
- /** @type {?|undefined} */
47
- ITdDataTableColumn.prototype.format;
48
- /** @type {?|undefined} */
49
- ITdDataTableColumn.prototype.nested;
50
- /** @type {?|undefined} */
51
- ITdDataTableColumn.prototype.sortable;
52
- /** @type {?|undefined} */
53
- ITdDataTableColumn.prototype.hidden;
54
- /** @type {?|undefined} */
55
- ITdDataTableColumn.prototype.filter;
56
- /** @type {?|undefined} */
57
- ITdDataTableColumn.prototype.width;
58
- /** @type {?|undefined} */
59
- ITdDataTableColumn.prototype.columnSortOrder;
60
- }
61
- /**
62
- * @record
63
- */
64
- export function ITdDataTableSelectEvent() { }
65
- if (false) {
66
- /** @type {?} */
67
- ITdDataTableSelectEvent.prototype.row;
68
- /** @type {?} */
69
- ITdDataTableSelectEvent.prototype.selected;
70
- /** @type {?} */
71
- ITdDataTableSelectEvent.prototype.index;
72
- }
73
- /**
74
- * @record
75
- */
76
- export function ITdDataTableSelectAllEvent() { }
77
- if (false) {
78
- /** @type {?} */
79
- ITdDataTableSelectAllEvent.prototype.rows;
80
- /** @type {?} */
81
- ITdDataTableSelectAllEvent.prototype.selected;
82
- }
83
- /**
84
- * @record
85
- */
86
- export function ITdDataTableRowClickEvent() { }
87
- if (false) {
88
- /** @type {?} */
89
- ITdDataTableRowClickEvent.prototype.row;
90
- /** @type {?} */
91
- ITdDataTableRowClickEvent.prototype.index;
92
- }
93
- /**
94
- * @record
95
- */
96
- export function IInternalColumnWidth() { }
97
- if (false) {
98
- /** @type {?} */
99
- IInternalColumnWidth.prototype.value;
100
- /** @type {?} */
101
- IInternalColumnWidth.prototype.limit;
102
- /** @type {?} */
103
- IInternalColumnWidth.prototype.index;
104
- /** @type {?|undefined} */
105
- IInternalColumnWidth.prototype.min;
106
- /** @type {?|undefined} */
107
- IInternalColumnWidth.prototype.max;
108
- }
109
- /**
110
- * Constant to set the rows offset before and after the viewport
111
- * @type {?}
112
- */
113
- const TD_VIRTUAL_OFFSET = 2;
114
- /**
115
- * Constant to set default row height if none is provided
116
- * @type {?}
117
- */
118
- const TD_VIRTUAL_DEFAULT_ROW_HEIGHT = 48;
119
- export class TdDataTableBase {
120
- /**
121
- * @param {?} _changeDetectorRef
122
- */
123
- constructor(_changeDetectorRef) {
124
- this._changeDetectorRef = _changeDetectorRef;
125
- }
126
- }
127
- if (false) {
128
- /** @type {?} */
129
- TdDataTableBase.prototype._changeDetectorRef;
130
- }
131
- /* tslint:disable-next-line */
132
- /** @type {?} */
133
- export const _TdDataTableMixinBase = mixinControlValueAccessor(TdDataTableBase, []);
134
- export class TdDataTableComponent extends _TdDataTableMixinBase {
135
- /**
136
- * @param {?} _document
137
- * @param {?} _elementRef
138
- * @param {?} _domSanitizer
139
- * @param {?} _changeDetectorRef
140
- */
141
- constructor(_document, _elementRef, _domSanitizer, _changeDetectorRef) {
142
- super(_changeDetectorRef);
143
- this._document = _document;
144
- this._elementRef = _elementRef;
145
- this._domSanitizer = _domSanitizer;
146
- this._hostWidth = 0;
147
- /**
148
- * manually resizable columns
149
- */
150
- this._resizableColumns = false;
151
- this._columnClientX = 0;
152
- this._onColumnResize = new Subject();
153
- this._widths = [];
154
- this._onResize = new Subject();
155
- this._scrollHorizontalOffset = 0;
156
- this._onHorizontalScroll = new Subject();
157
- this._onVerticalScroll = new Subject();
158
- // Array of cached row heights to allow dynamic row heights
159
- this._rowHeightCache = [];
160
- // Total pseudo height of all the elements
161
- this._totalHeight = 0;
162
- // Total host height for the viewport
163
- this._hostHeight = 0;
164
- // Scrolled vertical pixels
165
- this._scrollVerticalOffset = 0;
166
- // Variables that set from and to which rows will be rendered
167
- this._fromRow = 0;
168
- this._toRow = 0;
169
- this._selectable = false;
170
- this._clickable = false;
171
- this._multiple = true;
172
- this._allSelected = false;
173
- this._indeterminate = false;
174
- /**
175
- * sorting
176
- */
177
- this._sortable = false;
178
- this._sortOrder = TdDataTableSortingOrder.Ascending;
179
- /**
180
- * shift select
181
- */
182
- this._shiftPreviouslyPressed = false;
183
- this._lastSelectedIndex = -1;
184
- this._firstSelectedIndex = -1;
185
- this._firstCheckboxValue = false;
186
- /**
187
- * template fetching support
188
- */
189
- this._templateMap = new Map();
190
- /**
191
- * sortChange?: function
192
- * Event emitted when the column headers are clicked. [sortable] needs to be enabled.
193
- * Emits an [ITdDataTableSortChangeEvent] implemented object.
194
- */
195
- this.sortChange = new EventEmitter();
196
- /**
197
- * rowSelect?: function
198
- * Event emitted when a row is selected/deselected. [selectable] needs to be enabled.
199
- * Emits an [ITdDataTableSelectEvent] implemented object.
200
- */
201
- this.rowSelect = new EventEmitter();
202
- /**
203
- * rowClick?: function
204
- * Event emitted when a row is clicked.
205
- * Emits an [ITdDataTableRowClickEvent] implemented object.
206
- */
207
- this.rowClick = new EventEmitter();
208
- /**
209
- * selectAll?: function
210
- * Event emitted when all rows are selected/deselected by the all checkbox. [selectable] needs to be enabled.
211
- * Emits an [ITdDataTableSelectAllEvent] implemented object.
212
- */
213
- this.selectAll = new EventEmitter();
214
- /**
215
- * compareWith?: function(row, model): boolean
216
- * Allows custom comparison between row and model to see if row is selected or not
217
- * Default comparation is by reference
218
- */
219
- this.compareWith = (/**
220
- * @param {?} row
221
- * @param {?} model
222
- * @return {?}
223
- */
224
- (row, model) => {
225
- return row === model;
226
- });
227
- }
228
- /**
229
- * @return {?}
230
- */
231
- get resizingColumn() {
232
- return this._resizingColumn;
233
- }
234
- /**
235
- * @return {?}
236
- */
237
- get hostWidth() {
238
- // if the checkboxes are rendered, we need to remove their width
239
- // from the total width to calculate properly
240
- if (this.selectable) {
241
- return this._hostWidth - 42;
242
- }
243
- return this._hostWidth;
244
- }
245
- /**
246
- * Returns the offset style with a proper calculation on how much it should move
247
- * over the y axis of the total height
248
- * @return {?}
249
- */
250
- get offsetTransform() {
251
- return this._offsetTransform;
252
- }
253
- /**
254
- * Returns the assumed total height of the rows
255
- * @return {?}
256
- */
257
- get totalHeight() {
258
- return this._totalHeight;
259
- }
260
- /**
261
- * Returns the initial row to render in the viewport
262
- * @return {?}
263
- */
264
- get fromRow() {
265
- return this._fromRow;
266
- }
267
- /**
268
- * Returns the last row to render in the viewport
269
- * @return {?}
270
- */
271
- get toRow() {
272
- return this._toRow;
273
- }
274
- /**
275
- * Returns scroll position to reposition column headers
276
- * @return {?}
277
- */
278
- get columnsLeftScroll() {
279
- return this._scrollHorizontalOffset * -1;
280
- }
281
- /**
282
- * Returns true if all values are selected.
283
- * @return {?}
284
- */
285
- get allSelected() {
286
- return this._allSelected;
287
- }
288
- /**
289
- * Returns true if all values are not deselected
290
- * and at least one is.
291
- * @return {?}
292
- */
293
- get indeterminate() {
294
- return this._indeterminate;
295
- }
296
- /**
297
- * data?: {[key: string]: any}[]
298
- * Sets the data to be rendered as rows.
299
- * @param {?} data
300
- * @return {?}
301
- */
302
- set data(data) {
303
- this._data = data;
304
- this._rowHeightCache = [];
305
- Promise.resolve().then((/**
306
- * @return {?}
307
- */
308
- () => {
309
- this.refresh();
310
- // scroll back to the top if the data has changed
311
- this._scrollableDiv.nativeElement.scrollTop = 0;
312
- }));
313
- }
314
- /**
315
- * @return {?}
316
- */
317
- get data() {
318
- return this._data;
319
- }
320
- /**
321
- * @return {?}
322
- */
323
- get virtualData() {
324
- return this._virtualData;
325
- }
326
- /**
327
- * columns?: ITdDataTableColumn[]
328
- * Sets additional column configuration. [ITdDataTableColumn.name] has to exist in [data] as key.
329
- * Defaults to [data] keys.
330
- * @param {?} cols
331
- * @return {?}
332
- */
333
- set columns(cols) {
334
- this._columns = cols;
335
- }
336
- /**
337
- * @return {?}
338
- */
339
- get columns() {
340
- if (this._columns) {
341
- return this._columns;
342
- }
343
- if (this.hasData) {
344
- this._columns = [];
345
- // if columns is undefined, use key in [data] rows as name and label for column headers.
346
- /** @type {?} */
347
- const row = this._data[0];
348
- Object.keys(row).forEach((/**
349
- * @param {?} k
350
- * @return {?}
351
- */
352
- (k) => {
353
- if (!this._columns.find((/**
354
- * @param {?} c
355
- * @return {?}
356
- */
357
- (c) => c.name === k))) {
358
- this._columns.push({ name: k, label: k });
359
- }
360
- }));
361
- return this._columns;
362
- }
363
- else {
364
- return [];
365
- }
366
- }
367
- /**
368
- * resizableColumns?: boolean
369
- * Enables manual column resize.
370
- * Defaults to 'false'
371
- * @param {?} resizableColumns
372
- * @return {?}
373
- */
374
- set resizableColumns(resizableColumns) {
375
- this._resizableColumns = coerceBooleanProperty(resizableColumns);
376
- }
377
- /**
378
- * @return {?}
379
- */
380
- get resizableColumns() {
381
- return this._resizableColumns;
382
- }
383
- /**
384
- * selectable?: boolean
385
- * Enables row selection events, hover and selected row states.
386
- * Defaults to 'false'
387
- * @param {?} selectable
388
- * @return {?}
389
- */
390
- set selectable(selectable) {
391
- this._selectable = coerceBooleanProperty(selectable);
392
- }
393
- /**
394
- * @return {?}
395
- */
396
- get selectable() {
397
- return this._selectable;
398
- }
399
- /**
400
- * clickable?: boolean
401
- * Enables row click events, hover.
402
- * Defaults to 'false'
403
- * @param {?} clickable
404
- * @return {?}
405
- */
406
- set clickable(clickable) {
407
- this._clickable = coerceBooleanProperty(clickable);
408
- }
409
- /**
410
- * @return {?}
411
- */
412
- get clickable() {
413
- return this._clickable;
414
- }
415
- /**
416
- * multiple?: boolean
417
- * Enables multiple row selection. [selectable] needs to be enabled.
418
- * Defaults to 'false'
419
- * @param {?} multiple
420
- * @return {?}
421
- */
422
- set multiple(multiple) {
423
- this._multiple = coerceBooleanProperty(multiple);
424
- }
425
- /**
426
- * @return {?}
427
- */
428
- get multiple() {
429
- return this._multiple;
430
- }
431
- /**
432
- * sortable?: boolean
433
- * Enables sorting events, sort icons and active column states.
434
- * Defaults to 'false'
435
- * @param {?} sortable
436
- * @return {?}
437
- */
438
- set sortable(sortable) {
439
- this._sortable = coerceBooleanProperty(sortable);
440
- }
441
- /**
442
- * @return {?}
443
- */
444
- get sortable() {
445
- return this._sortable;
446
- }
447
- /**
448
- * sortBy?: string
449
- * Sets the active sort column. [sortable] needs to be enabled.
450
- * @param {?} columnName
451
- * @return {?}
452
- */
453
- set sortBy(columnName) {
454
- if (!columnName) {
455
- return;
456
- }
457
- /** @type {?} */
458
- const column = this.columns.find((/**
459
- * @param {?} c
460
- * @return {?}
461
- */
462
- (c) => c.name === columnName));
463
- if (!column) {
464
- throw new Error('[sortBy] must be a valid column name');
465
- }
466
- this._sortBy = column;
467
- }
468
- /**
469
- * @return {?}
470
- */
471
- get sortByColumn() {
472
- return this._sortBy;
473
- }
474
- /**
475
- * sortOrder?: ['ASC' | 'DESC'] or TdDataTableSortingOrder
476
- * Sets the sort order of the [sortBy] column. [sortable] needs to be enabled.
477
- * Defaults to 'ASC' or TdDataTableSortingOrder.Ascending
478
- * @param {?} order
479
- * @return {?}
480
- */
481
- set sortOrder(order) {
482
- /** @type {?} */
483
- const sortOrder = order ? order.toUpperCase() : 'ASC';
484
- if (sortOrder !== 'DESC' && sortOrder !== 'ASC') {
485
- throw new Error('[sortOrder] must be empty, ASC or DESC');
486
- }
487
- this._sortOrder = sortOrder === 'ASC' ? TdDataTableSortingOrder.Ascending : TdDataTableSortingOrder.Descending;
488
- }
489
- /**
490
- * @return {?}
491
- */
492
- get sortOrderEnum() {
493
- return this._sortOrder;
494
- }
495
- /**
496
- * @return {?}
497
- */
498
- get hasData() {
499
- return this._data && this._data.length > 0;
500
- }
501
- /**
502
- * Initialize observable for resize and scroll events
503
- * @return {?}
504
- */
505
- ngOnInit() {
506
- // initialize observable for resize calculations
507
- this._resizeSubs = this._onResize.asObservable().subscribe((/**
508
- * @return {?}
509
- */
510
- () => {
511
- if (this._rows) {
512
- this._rows.toArray().forEach((/**
513
- * @param {?} row
514
- * @param {?} index
515
- * @return {?}
516
- */
517
- (row, index) => {
518
- this._rowHeightCache[this.fromRow + index] = row.height + 1;
519
- }));
520
- }
521
- this._calculateWidths();
522
- this._calculateVirtualRows();
523
- }));
524
- // initialize observable for column resize calculations
525
- this._columnResizeSubs = this._onColumnResize
526
- .asObservable()
527
- .pipe(debounceTime(0))
528
- .subscribe((/**
529
- * @param {?} clientX
530
- * @return {?}
531
- */
532
- (clientX) => {
533
- this._columnClientX = clientX;
534
- this._calculateWidths();
535
- this._changeDetectorRef.markForCheck();
536
- }));
537
- // initialize observable for scroll column header reposition
538
- this._horizontalScrollSubs = this._onHorizontalScroll.asObservable().subscribe((/**
539
- * @param {?} horizontalScroll
540
- * @return {?}
541
- */
542
- (horizontalScroll) => {
543
- this._scrollHorizontalOffset = horizontalScroll;
544
- this._changeDetectorRef.markForCheck();
545
- }));
546
- // initialize observable for virtual scroll rendering
547
- this._verticalScrollSubs = this._onVerticalScroll.asObservable().subscribe((/**
548
- * @param {?} verticalScroll
549
- * @return {?}
550
- */
551
- (verticalScroll) => {
552
- this._scrollVerticalOffset = verticalScroll;
553
- this._calculateVirtualRows();
554
- this._changeDetectorRef.markForCheck();
555
- }));
556
- this._valueChangesSubs = this.valueChanges.subscribe((/**
557
- * @param {?} value
558
- * @return {?}
559
- */
560
- (value) => {
561
- this.refresh();
562
- }));
563
- }
564
- /**
565
- * Loads templates and sets them in a map for faster access.
566
- * @return {?}
567
- */
568
- ngAfterContentInit() {
569
- for (const template of this._templates.toArray()) {
570
- this._templateMap.set(template.tdDataTableTemplate, template.templateRef);
571
- }
572
- }
573
- /**
574
- * Checks hosts native elements widths to see if it has changed (resize check)
575
- * @return {?}
576
- */
577
- ngAfterContentChecked() {
578
- // check if the scroll has been reset when element is hidden
579
- if (this._scrollVerticalOffset - this._scrollableDiv.nativeElement.scrollTop > 5) {
580
- // scroll back to the top if element has been reset
581
- this._onVerticalScroll.next(0);
582
- }
583
- if (this._elementRef.nativeElement) {
584
- /** @type {?} */
585
- const newHostWidth = this._elementRef.nativeElement.getBoundingClientRect().width;
586
- // if the width has changed then we throw a resize event.
587
- if (this._hostWidth !== newHostWidth) {
588
- setTimeout((/**
589
- * @return {?}
590
- */
591
- () => {
592
- this._hostWidth = newHostWidth;
593
- this._onResize.next();
594
- }), 0);
595
- }
596
- }
597
- if (this._scrollableDiv.nativeElement) {
598
- /** @type {?} */
599
- const newHostHeight = this._scrollableDiv.nativeElement.getBoundingClientRect().height;
600
- // if the height of the viewport has changed, then we mark for check
601
- if (this._hostHeight !== newHostHeight) {
602
- this._hostHeight = newHostHeight;
603
- this._calculateVirtualRows();
604
- this._changeDetectorRef.markForCheck();
605
- }
606
- }
607
- }
608
- /**
609
- * Registers to an observable that checks if all rows have been rendered
610
- * so we can start calculating the widths
611
- * @return {?}
612
- */
613
- ngAfterViewInit() {
614
- this._rowsChangedSubs = this._rows.changes.pipe(debounceTime(0)).subscribe((/**
615
- * @return {?}
616
- */
617
- () => {
618
- this._onResize.next();
619
- }));
620
- this._calculateVirtualRows();
621
- }
622
- /**
623
- * Unsubscribes observables when data table is destroyed
624
- * @return {?}
625
- */
626
- ngOnDestroy() {
627
- if (this._resizeSubs) {
628
- this._resizeSubs.unsubscribe();
629
- }
630
- if (this._columnResizeSubs) {
631
- this._columnResizeSubs.unsubscribe();
632
- }
633
- if (this._horizontalScrollSubs) {
634
- this._horizontalScrollSubs.unsubscribe();
635
- }
636
- if (this._verticalScrollSubs) {
637
- this._verticalScrollSubs.unsubscribe();
638
- }
639
- if (this._rowsChangedSubs) {
640
- this._rowsChangedSubs.unsubscribe();
641
- }
642
- if (this._valueChangesSubs) {
643
- this._valueChangesSubs.unsubscribe();
644
- }
645
- }
646
- /**
647
- * Method that gets executed every time there is a scroll event
648
- * Calls the scroll observable
649
- * @param {?} event
650
- * @return {?}
651
- */
652
- handleScroll(event) {
653
- /** @type {?} */
654
- const element = (/** @type {?} */ (event.target));
655
- if (element) {
656
- /** @type {?} */
657
- const horizontalScroll = element.scrollLeft;
658
- if (this._scrollHorizontalOffset !== horizontalScroll) {
659
- this._onHorizontalScroll.next(horizontalScroll);
660
- }
661
- /** @type {?} */
662
- const verticalScroll = element.scrollTop;
663
- if (this._scrollVerticalOffset !== verticalScroll) {
664
- this._onVerticalScroll.next(verticalScroll);
665
- }
666
- }
667
- }
668
- /**
669
- * Returns the width needed for the columns via index
670
- * @param {?} index
671
- * @return {?}
672
- */
673
- getColumnWidth(index) {
674
- if (this._widths[index]) {
675
- return this._widths[index].value;
676
- }
677
- return undefined;
678
- }
679
- /**
680
- * @param {?} column
681
- * @param {?} value
682
- * @return {?}
683
- */
684
- getCellValue(column, value) {
685
- if (column.nested === undefined || column.nested) {
686
- return this._getNestedValue(column.name, value);
687
- }
688
- return value[column.name];
689
- }
690
- /**
691
- * Getter method for template references
692
- * @param {?} name
693
- * @return {?}
694
- */
695
- getTemplateRef(name) {
696
- return this._templateMap.get(name);
697
- }
698
- /**
699
- * Clears model (ngModel) of component by removing all values in array.
700
- * @return {?}
701
- */
702
- clearModel() {
703
- this.value.splice(0, this.value.length);
704
- }
705
- /**
706
- * Refreshes data table and rerenders [data] and [columns]
707
- * @return {?}
708
- */
709
- refresh() {
710
- this._calculateVirtualRows();
711
- this._calculateWidths();
712
- this._calculateCheckboxState();
713
- this._changeDetectorRef.markForCheck();
714
- }
715
- /**
716
- * Selects or clears all rows depending on 'checked' value.
717
- * @param {?} checked
718
- * @return {?}
719
- */
720
- _selectAll(checked) {
721
- /** @type {?} */
722
- const toggledRows = [];
723
- if (checked) {
724
- this._data.forEach((/**
725
- * @param {?} row
726
- * @return {?}
727
- */
728
- (row) => {
729
- // skiping already selected rows
730
- if (!this.isRowSelected(row)) {
731
- this.value.push(row);
732
- // checking which ones are being toggled
733
- toggledRows.push(row);
734
- }
735
- }));
736
- this._allSelected = true;
737
- this._indeterminate = true;
738
- }
739
- else {
740
- this._data.forEach((/**
741
- * @param {?} row
742
- * @return {?}
743
- */
744
- (row) => {
745
- // checking which ones are being toggled
746
- if (this.isRowSelected(row)) {
747
- toggledRows.push(row);
748
- /** @type {?} */
749
- const modelRow = this.value.filter((/**
750
- * @param {?} val
751
- * @return {?}
752
- */
753
- (val) => {
754
- return this.compareWith(row, val);
755
- }))[0];
756
- /** @type {?} */
757
- const index = this.value.indexOf(modelRow);
758
- if (index > -1) {
759
- this.value.splice(index, 1);
760
- }
761
- }
762
- }));
763
- this._allSelected = false;
764
- this._indeterminate = false;
765
- }
766
- this.selectAll.emit({ rows: toggledRows, selected: checked });
767
- this.onChange(this.value);
768
- }
769
- /**
770
- * Checks if row is selected
771
- * @param {?} row
772
- * @return {?}
773
- */
774
- isRowSelected(row) {
775
- // compare items by [compareWith] function
776
- return this.value
777
- ? this.value.filter((/**
778
- * @param {?} val
779
- * @return {?}
780
- */
781
- (val) => {
782
- return this.compareWith(row, val);
783
- })).length > 0
784
- : false;
785
- }
786
- /**
787
- * Selects or clears a row depending on 'checked' value if the row 'isSelectable'
788
- * handles cntrl clicks and shift clicks for multi-select
789
- * @param {?} row
790
- * @param {?} event
791
- * @param {?} currentSelected
792
- * @return {?}
793
- */
794
- select(row, event, currentSelected) {
795
- if (this.selectable) {
796
- this.blockEvent(event);
797
- // Check to see if Shift key is selected and need to select everything in between
798
- /** @type {?} */
799
- const mouseEvent = (/** @type {?} */ (event));
800
- if (this.multiple && mouseEvent && mouseEvent.shiftKey && this._lastSelectedIndex > -1) {
801
- /** @type {?} */
802
- let firstIndex = currentSelected;
803
- /** @type {?} */
804
- let lastIndex = this._lastSelectedIndex;
805
- if (currentSelected > this._lastSelectedIndex) {
806
- firstIndex = this._lastSelectedIndex;
807
- lastIndex = currentSelected;
808
- }
809
- // if clicking a checkbox behind the initial check, then toggle all selections expect the initial checkbox
810
- // else the checkboxes clicked are all after the initial one
811
- if ((this._firstSelectedIndex >= currentSelected && this._lastSelectedIndex > this._firstSelectedIndex) ||
812
- (this._firstSelectedIndex <= currentSelected && this._lastSelectedIndex < this._firstSelectedIndex)) {
813
- for (let i = firstIndex; i <= lastIndex; i++) {
814
- if (this._firstSelectedIndex !== i) {
815
- this._doSelection(this._data[i], i);
816
- }
817
- }
818
- }
819
- else if (this._firstSelectedIndex > currentSelected || this._firstSelectedIndex < currentSelected) {
820
- // change indexes depending on where the next checkbox is selected (before or after)
821
- if (this._firstSelectedIndex > currentSelected) {
822
- lastIndex--;
823
- }
824
- else if (this._firstSelectedIndex < currentSelected) {
825
- firstIndex++;
826
- }
827
- for (let i = firstIndex; i <= lastIndex; i++) {
828
- /** @type {?} */
829
- const rowSelected = this.isRowSelected(this._data[i]);
830
- // if row is selected and first checkbox was selected
831
- // or if row was unselected and first checkbox was unselected
832
- // we ignore the toggle
833
- if ((this._firstCheckboxValue && !rowSelected) || (!this._firstCheckboxValue && rowSelected)) {
834
- this._doSelection(this._data[i], i);
835
- }
836
- else if (this._shiftPreviouslyPressed &&
837
- ((currentSelected >= this._firstSelectedIndex && currentSelected <= this._lastSelectedIndex) ||
838
- (currentSelected <= this._firstSelectedIndex && currentSelected >= this._lastSelectedIndex))) {
839
- // else if the checkbox selected was in the middle of the last selection and the first selection
840
- // then we undo the selections
841
- this._doSelection(this._data[i], i);
842
- }
843
- }
844
- }
845
- this._shiftPreviouslyPressed = true;
846
- // if shift wasnt pressed, then we take the element checked as the first row
847
- // incase the next click uses shift
848
- }
849
- else if (mouseEvent && !mouseEvent.shiftKey) {
850
- this._firstCheckboxValue = this._doSelection(row, currentSelected);
851
- this._shiftPreviouslyPressed = false;
852
- this._firstSelectedIndex = currentSelected;
853
- }
854
- this._lastSelectedIndex = currentSelected;
855
- }
856
- }
857
- /**
858
- * Overrides the onselectstart method of the document so other text on the page
859
- * doesn't get selected when doing shift selections.
860
- * @return {?}
861
- */
862
- disableTextSelection() {
863
- if (this._document) {
864
- this._document.onselectstart = (/**
865
- * @return {?}
866
- */
867
- function () {
868
- return false;
869
- });
870
- }
871
- }
872
- /**
873
- * Resets the original onselectstart method.
874
- * @return {?}
875
- */
876
- enableTextSelection() {
877
- if (this._document) {
878
- this._document.onselectstart = undefined;
879
- }
880
- }
881
- /**
882
- * emits the onRowClickEvent when a row is clicked
883
- * if clickable is true and selectable is false then select the row
884
- * @param {?} row
885
- * @param {?} index
886
- * @param {?} event
887
- * @return {?}
888
- */
889
- handleRowClick(row, index, event) {
890
- if (this.clickable) {
891
- // ignoring linting rules here because attribute it actually null or not there
892
- // can't check for undefined
893
- /** @type {?} */
894
- const srcElement = event.srcElement || event.currentTarget;
895
- /** @type {?} */
896
- const element = (/** @type {?} */ (event.target));
897
- /* tslint:disable-next-line */
898
- if (srcElement.getAttribute('stopRowClick') === null && element.tagName.toLowerCase() !== 'mat-pseudo-checkbox') {
899
- this.rowClick.emit({
900
- row,
901
- index,
902
- });
903
- }
904
- }
905
- }
906
- /**
907
- * Method handle for sort click event in column headers.
908
- * @param {?} column
909
- * @return {?}
910
- */
911
- handleSort(column) {
912
- if (this._sortBy === column) {
913
- this._sortOrder =
914
- this._sortOrder === TdDataTableSortingOrder.Ascending
915
- ? TdDataTableSortingOrder.Descending
916
- : TdDataTableSortingOrder.Ascending;
917
- }
918
- else {
919
- this._sortBy = column;
920
- this._sortOrder = TdDataTableSortingOrder.Ascending;
921
- }
922
- this.sortChange.next({ name: this._sortBy.name, order: this._sortOrder });
923
- }
924
- /**
925
- * Handle all keyup events when focusing a data table row
926
- * @param {?} event
927
- * @param {?} row
928
- * @param {?} index
929
- * @return {?}
930
- */
931
- _rowKeyup(event, row, index) {
932
- switch (event.keyCode) {
933
- case ENTER:
934
- case SPACE:
935
- /** if user presses enter or space, the row should be selected */
936
- if (this.selectable) {
937
- this._doSelection(this._data[this.fromRow + index], this.fromRow + index);
938
- }
939
- break;
940
- case UP_ARROW:
941
- /**
942
- * if users presses the up arrow, we focus the prev row
943
- * unless its the first row
944
- */
945
- if (index > 0) {
946
- this._rows.toArray()[index - 1].focus();
947
- }
948
- this.blockEvent(event);
949
- if (this.selectable && this.multiple && event.shiftKey && this.fromRow + index >= 0) {
950
- this._doSelection(this._data[this.fromRow + index], this.fromRow + index);
951
- }
952
- break;
953
- case DOWN_ARROW:
954
- /**
955
- * if users presses the down arrow, we focus the next row
956
- * unless its the last row
957
- */
958
- if (index < this._rows.toArray().length - 1) {
959
- this._rows.toArray()[index + 1].focus();
960
- }
961
- this.blockEvent(event);
962
- if (this.selectable && this.multiple && event.shiftKey && this.fromRow + index < this._data.length) {
963
- this._doSelection(this._data[this.fromRow + index], this.fromRow + index);
964
- }
965
- break;
966
- default:
967
- // default
968
- }
969
- }
970
- /**
971
- * Sets column index of the dragged column and initial clientX of column
972
- * @param {?} index
973
- * @param {?} event
974
- * @return {?}
975
- */
976
- _handleStartColumnDrag(index, event) {
977
- this._columnClientX = event.clientX;
978
- this._resizingColumn = index;
979
- }
980
- /**
981
- * Calculates new width depending on new clientX of dragger column
982
- * @param {?} event
983
- * @return {?}
984
- */
985
- _handleColumnDrag(event) {
986
- // check if there was been a separator clicked for resize
987
- if (this._resizingColumn !== undefined && event.clientX > 0) {
988
- /** @type {?} */
989
- const xPosition = event.clientX;
990
- // checks if the separator is being moved to try and resize the column, else dont do anything
991
- if (xPosition > 0 && this._columnClientX > 0 && xPosition - this._columnClientX !== 0) {
992
- // calculate the new width depending if making the column bigger or smaller
993
- /** @type {?} */
994
- let proposedManualWidth = this._widths[this._resizingColumn].value + (xPosition - this._columnClientX);
995
- // if the proposed new width is less than the projected min width of the column, use projected min width
996
- if (proposedManualWidth < this._colElements.toArray()[this._resizingColumn].projectedWidth) {
997
- proposedManualWidth = this._colElements.toArray()[this._resizingColumn].projectedWidth;
998
- }
999
- this.columns[this._resizingColumn].width = proposedManualWidth;
1000
- // update new x position for the resized column
1001
- this._onColumnResize.next(xPosition);
1002
- }
1003
- }
1004
- }
1005
- /**
1006
- * Ends dragged flags
1007
- * @return {?}
1008
- */
1009
- _handleEndColumnDrag() {
1010
- this._columnClientX = undefined;
1011
- this._resizingColumn = undefined;
1012
- }
1013
- /**
1014
- * Method to prevent the default events
1015
- * @param {?} event
1016
- * @return {?}
1017
- */
1018
- blockEvent(event) {
1019
- event.preventDefault();
1020
- }
1021
- /**
1022
- * @private
1023
- * @param {?} name
1024
- * @param {?} value
1025
- * @return {?}
1026
- */
1027
- _getNestedValue(name, value) {
1028
- if (!(value instanceof Object) || !name) {
1029
- return value;
1030
- }
1031
- if (name.indexOf('.') > -1) {
1032
- /** @type {?} */
1033
- const splitName = name.split(/\.(.+)/, 2);
1034
- return this._getNestedValue(splitName[1], value[splitName[0]]);
1035
- }
1036
- else {
1037
- return value[name];
1038
- }
1039
- }
1040
- /**
1041
- * Does the actual Row Selection
1042
- * @private
1043
- * @param {?} row
1044
- * @param {?} rowIndex
1045
- * @return {?}
1046
- */
1047
- _doSelection(row, rowIndex) {
1048
- /** @type {?} */
1049
- const wasSelected = this.isRowSelected(row);
1050
- if (!wasSelected) {
1051
- if (!this._multiple) {
1052
- this.clearModel();
1053
- }
1054
- this.value.push(row);
1055
- }
1056
- else {
1057
- // compare items by [compareWith] function
1058
- row = this.value.filter((/**
1059
- * @param {?} val
1060
- * @return {?}
1061
- */
1062
- (val) => {
1063
- return this.compareWith(row, val);
1064
- }))[0];
1065
- /** @type {?} */
1066
- const index = this.value.indexOf(row);
1067
- if (index > -1) {
1068
- this.value.splice(index, 1);
1069
- }
1070
- }
1071
- this._calculateCheckboxState();
1072
- this.rowSelect.emit({ row, index: rowIndex, selected: !wasSelected });
1073
- this.onChange(this.value);
1074
- return !wasSelected;
1075
- }
1076
- /**
1077
- * Calculate all the state of all checkboxes
1078
- * @private
1079
- * @return {?}
1080
- */
1081
- _calculateCheckboxState() {
1082
- if (this._data) {
1083
- this._allSelected = typeof this._data.find((/**
1084
- * @param {?} d
1085
- * @return {?}
1086
- */
1087
- (d) => !this.isRowSelected(d))) === 'undefined';
1088
- this._indeterminate = false;
1089
- for (const row of this._data) {
1090
- if (!this.isRowSelected(row)) {
1091
- continue;
1092
- }
1093
- this._indeterminate = true;
1094
- break;
1095
- }
1096
- }
1097
- }
1098
- /**
1099
- * Calculates the widths for columns and cells depending on content
1100
- * @private
1101
- * @return {?}
1102
- */
1103
- _calculateWidths() {
1104
- if (this._colElements && this._colElements.length) {
1105
- this._widths = [];
1106
- this._colElements.forEach((/**
1107
- * @param {?} col
1108
- * @param {?} index
1109
- * @return {?}
1110
- */
1111
- (col, index) => {
1112
- this._adjustColumnWidth(index, this._calculateWidth());
1113
- }));
1114
- this._adjustColumnWidhts();
1115
- this._changeDetectorRef.markForCheck();
1116
- }
1117
- }
1118
- /**
1119
- * Adjusts columns after calculation to see if they need to be recalculated.
1120
- * @private
1121
- * @return {?}
1122
- */
1123
- _adjustColumnWidhts() {
1124
- /** @type {?} */
1125
- let fixedTotalWidth = 0;
1126
- // get the number of total columns that have flexible widths (not fixed or hidden)
1127
- /** @type {?} */
1128
- const flexibleWidths = this._widths.filter((/**
1129
- * @param {?} width
1130
- * @param {?} index
1131
- * @return {?}
1132
- */
1133
- (width, index) => {
1134
- if (this.columns[index].hidden) {
1135
- return false;
1136
- }
1137
- if (width.limit || width.max || width.min) {
1138
- fixedTotalWidth += width.value;
1139
- }
1140
- return !width.limit && !width.max && !width.min;
1141
- })).length;
1142
- // calculate how much pixes are left that could be spread across
1143
- // the flexible columns
1144
- /** @type {?} */
1145
- let recalculateHostWidth = 0;
1146
- if (fixedTotalWidth < this.hostWidth) {
1147
- recalculateHostWidth = this.hostWidth - fixedTotalWidth;
1148
- }
1149
- // if we have flexible columns and pixels to spare on them
1150
- // we try and spread the pixels across them
1151
- if (flexibleWidths && recalculateHostWidth) {
1152
- /** @type {?} */
1153
- const newValue = Math.floor(recalculateHostWidth / flexibleWidths);
1154
- /** @type {?} */
1155
- let adjustedNumber = 0;
1156
- // adjust the column widths with the spread pixels
1157
- this._widths.forEach((/**
1158
- * @param {?} colWidth
1159
- * @return {?}
1160
- */
1161
- (colWidth) => {
1162
- if ((this._widths[colWidth.index].max && this._widths[colWidth.index].value > newValue) ||
1163
- (this._widths[colWidth.index].min && this._widths[colWidth.index].value < newValue) ||
1164
- !this._widths[colWidth.index].limit) {
1165
- this._adjustColumnWidth(colWidth.index, newValue);
1166
- adjustedNumber++;
1167
- }
1168
- }));
1169
- // if there are still columns that need to be recalculated, we start over
1170
- /** @type {?} */
1171
- const newFlexibleWidths = this._widths.filter((/**
1172
- * @param {?} width
1173
- * @return {?}
1174
- */
1175
- (width) => {
1176
- return !width.limit && !width.max;
1177
- })).length;
1178
- if (newFlexibleWidths !== adjustedNumber && newFlexibleWidths !== flexibleWidths) {
1179
- this._adjustColumnWidhts();
1180
- }
1181
- }
1182
- }
1183
- /**
1184
- * Adjusts a single column to see if it can be recalculated
1185
- * @private
1186
- * @param {?} index
1187
- * @param {?} value
1188
- * @return {?}
1189
- */
1190
- _adjustColumnWidth(index, value) {
1191
- this._widths[index] = {
1192
- value,
1193
- index,
1194
- limit: false,
1195
- min: false,
1196
- max: false,
1197
- };
1198
- // flag to see if we need to skip the min width projection
1199
- // depending if a width or min width has been provided
1200
- /** @type {?} */
1201
- let skipMinWidthProjection = false;
1202
- if (this.columns[index]) {
1203
- // if the provided width has min/max, then we check to see if we need to set it
1204
- if (typeof this.columns[index].width === 'object') {
1205
- /** @type {?} */
1206
- const widthOpts = (/** @type {?} */ (this.columns[index].width));
1207
- // if the column width is less than the configured min, we override it
1208
- skipMinWidthProjection = widthOpts && !!widthOpts.min;
1209
- if (widthOpts && widthOpts.min >= this._widths[index].value) {
1210
- this._widths[index].value = widthOpts.min;
1211
- this._widths[index].min = true;
1212
- // if the column width is more than the configured max, we override it
1213
- }
1214
- else if (widthOpts && widthOpts.max <= this._widths[index].value) {
1215
- this._widths[index].value = widthOpts.max;
1216
- this._widths[index].max = true;
1217
- }
1218
- // if it has a fixed width, then we just set it
1219
- }
1220
- else if (typeof this.columns[index].width === 'number') {
1221
- this._widths[index].value = (/** @type {?} */ (this.columns[index].width));
1222
- skipMinWidthProjection = this._widths[index].limit = true;
1223
- }
1224
- }
1225
- // if there wasn't any width or min width provided, we set a min to what the column width min should be
1226
- if (!skipMinWidthProjection && this._widths[index].value < this._colElements.toArray()[index].projectedWidth) {
1227
- this._widths[index].value = this._colElements.toArray()[index].projectedWidth;
1228
- this._widths[index].min = true;
1229
- this._widths[index].limit = false;
1230
- }
1231
- }
1232
- /**
1233
- * Generic method to calculate column width
1234
- * @private
1235
- * @return {?}
1236
- */
1237
- _calculateWidth() {
1238
- /** @type {?} */
1239
- const renderedColumns = this.columns.filter((/**
1240
- * @param {?} col
1241
- * @return {?}
1242
- */
1243
- (col) => !col.hidden));
1244
- return Math.floor(this.hostWidth / renderedColumns.length);
1245
- }
1246
- /**
1247
- * Method to calculate the rows to be rendered in the viewport
1248
- * @private
1249
- * @return {?}
1250
- */
1251
- _calculateVirtualRows() {
1252
- /** @type {?} */
1253
- let scrolledRows = 0;
1254
- if (this._data) {
1255
- this._totalHeight = 0;
1256
- /** @type {?} */
1257
- let rowHeightSum = 0;
1258
- // loop through all rows to see if we have their height cached
1259
- // and sum them all to calculate the total height
1260
- this._data.forEach((/**
1261
- * @param {?} d
1262
- * @param {?} i
1263
- * @return {?}
1264
- */
1265
- (d, i) => {
1266
- // iterate through all rows at first and assume all
1267
- // rows are the same height as the first one
1268
- if (!this._rowHeightCache[i]) {
1269
- this._rowHeightCache[i] = this._rowHeightCache[0] || TD_VIRTUAL_DEFAULT_ROW_HEIGHT;
1270
- }
1271
- rowHeightSum += this._rowHeightCache[i];
1272
- // check how many rows have been scrolled
1273
- if (this._scrollVerticalOffset - rowHeightSum > 0) {
1274
- scrolledRows++;
1275
- }
1276
- }));
1277
- this._totalHeight = rowHeightSum;
1278
- // set the initial row to be rendered taking into account the row offset
1279
- /** @type {?} */
1280
- const fromRow = scrolledRows - TD_VIRTUAL_OFFSET;
1281
- this._fromRow = fromRow > 0 ? fromRow : 0;
1282
- /** @type {?} */
1283
- let hostHeight = this._hostHeight;
1284
- /** @type {?} */
1285
- let index = 0;
1286
- // calculate how many rows can fit in the viewport
1287
- while (hostHeight > 0) {
1288
- hostHeight -= this._rowHeightCache[this.fromRow + index];
1289
- index++;
1290
- }
1291
- // set the last row to be rendered taking into account the row offset
1292
- /** @type {?} */
1293
- const range = index - 1 + TD_VIRTUAL_OFFSET * 2;
1294
- /** @type {?} */
1295
- let toRow = range + this.fromRow;
1296
- // if last row is greater than the total length, then we use the total length
1297
- if (isFinite(toRow) && toRow > this._data.length) {
1298
- toRow = this._data.length;
1299
- }
1300
- else if (!isFinite(toRow)) {
1301
- toRow = TD_VIRTUAL_OFFSET;
1302
- }
1303
- this._toRow = toRow;
1304
- }
1305
- else {
1306
- this._totalHeight = 0;
1307
- this._fromRow = 0;
1308
- this._toRow = 0;
1309
- }
1310
- /** @type {?} */
1311
- let offset = 0;
1312
- // calculate the proper offset depending on how many rows have been scrolled
1313
- if (scrolledRows > TD_VIRTUAL_OFFSET) {
1314
- for (let index = 0; index < this.fromRow; index++) {
1315
- offset += this._rowHeightCache[index];
1316
- }
1317
- }
1318
- this._offsetTransform = this._domSanitizer.bypassSecurityTrustStyle('translateY(' + (offset - this.totalHeight) + 'px)');
1319
- if (this._data) {
1320
- this._virtualData = this.data.slice(this.fromRow, this.toRow);
1321
- }
1322
- // mark for check at the end of the queue so we are sure
1323
- // that the changes will be marked
1324
- Promise.resolve().then((/**
1325
- * @return {?}
1326
- */
1327
- () => {
1328
- this._changeDetectorRef.markForCheck();
1329
- }));
1330
- }
1331
- }
1332
- TdDataTableComponent.decorators = [
1333
- { type: Component, args: [{
1334
- providers: [
1335
- {
1336
- provide: NG_VALUE_ACCESSOR,
1337
- useExisting: forwardRef((/**
1338
- * @return {?}
1339
- */
1340
- () => TdDataTableComponent)),
1341
- multi: true,
1342
- },
1343
- ],
1344
- selector: 'td-data-table',
1345
- template: "<table td-data-table [style.left.px]=\"columnsLeftScroll\" [class.mat-selectable]=\"selectable\">\n <thead class=\"td-data-table-head\" (dragover)=\"_handleColumnDrag($event)\">\n <tr td-data-table-column-row>\n <th td-data-table-column class=\"mat-checkbox-column\" *ngIf=\"selectable\">\n <mat-checkbox\n #checkBoxAll\n *ngIf=\"multiple\"\n [disabled]=\"!hasData\"\n [indeterminate]=\"indeterminate && !allSelected && hasData\"\n [checked]=\"allSelected && hasData\"\n (click)=\"blockEvent($event); _selectAll(!checkBoxAll.checked)\"\n (keyup.enter)=\"_selectAll(!checkBoxAll.checked)\"\n (keyup.space)=\"_selectAll(!checkBoxAll.checked)\"\n (keydown.space)=\"blockEvent($event)\"\n ></mat-checkbox>\n </th>\n <th\n td-data-table-column\n #columnElement\n *ngFor=\"let column of columns; let i = index; let last = last\"\n [style.min-width.px]=\"getColumnWidth(i)\"\n [style.max-width.px]=\"getColumnWidth(i)\"\n [name]=\"column.name\"\n [numeric]=\"column.numeric\"\n [active]=\"(column.sortable || sortable) && column === sortByColumn\"\n [sortable]=\"column.sortable || (sortable && column.sortable !== false)\"\n [sortOrder]=\"sortOrderEnum\"\n [hidden]=\"column.hidden\"\n [isColumnSortOrder]=\"!!column.columnSortOrder\"\n (sortChange)=\"handleSort(column)\"\n >\n <span [matTooltip]=\"column.tooltip\" [class]=\"column.columnSortOrder ? 'td-table-header-label' : ''\">\n {{ column.label }}\n <span *ngIf=\"column.columnSortOrder\" class=\"td-data-table-sort-badge\">\n {{ column.columnSortOrder || '' }}\n\n <span\n td-column-resizer\n *ngIf=\"resizableColumns\"\n draggable=\"true\"\n class=\"td-data-table-column-resizer\"\n [class.td-resizing]=\"i === resizingColumn\"\n (mousedown)=\"_handleStartColumnDrag(i, $event)\"\n (dragstart)=\"$event?.dataTransfer?.setData('text', '')\"\n (drag)=\"_handleColumnDrag($event)\"\n (dragend)=\"_handleEndColumnDrag()\"\n (mouseup)=\"_handleEndColumnDrag()\"\n >\n <span class=\"td-data-table-column-separator\"></span>\n </span>\n </span>\n </span>\n </th>\n </tr>\n </thead>\n</table>\n<div #scrollableDiv class=\"td-data-table-scrollable\" (scroll)=\"handleScroll($event)\">\n <div [style.height.px]=\"totalHeight\"></div>\n <table\n td-data-table\n [style.transform]=\"offsetTransform\"\n [style.position]=\"'absolute'\"\n [class.mat-selectable]=\"selectable\"\n [class.mat-clickable]=\"clickable\"\n >\n <tbody class=\"td-data-table-body\">\n <tr\n td-data-table-row\n #dtRow\n [tabIndex]=\"selectable ? 0 : -1\"\n [selected]=\"(clickable || selectable) && isRowSelected(row)\"\n *ngFor=\"let row of virtualData; let rowIndex = index\"\n (click)=\"handleRowClick(row, fromRow + rowIndex, $event)\"\n (keyup)=\"selectable && _rowKeyup($event, row, rowIndex)\"\n (keydown.space)=\"blockEvent($event)\"\n (keydown.shift.space)=\"blockEvent($event)\"\n (keydown.shift)=\"disableTextSelection()\"\n (keyup.shift)=\"enableTextSelection()\"\n >\n <td td-data-table-cell class=\"mat-checkbox-cell\" *ngIf=\"selectable\">\n <mat-pseudo-checkbox\n [state]=\"dtRow.selected ? 'checked' : 'unchecked'\"\n (mousedown)=\"disableTextSelection()\"\n (mouseup)=\"enableTextSelection()\"\n stopRowClick\n (click)=\"select(row, $event, fromRow + rowIndex)\"\n ></mat-pseudo-checkbox>\n </td>\n <td\n td-data-table-cell\n [numeric]=\"column.numeric\"\n [hidden]=\"column.hidden\"\n *ngFor=\"let column of columns; let i = index\"\n [style.min-width.px]=\"getColumnWidth(i)\"\n [style.max-width.px]=\"getColumnWidth(i)\"\n >\n <span *ngIf=\"!getTemplateRef(column.name)\">\n {{ column.format ? column.format(getCellValue(column, row)) : getCellValue(column, row) }}\n </span>\n <ng-template\n *ngIf=\"getTemplateRef(column.name)\"\n [ngTemplateOutlet]=\"getTemplateRef(column.name)\"\n [ngTemplateOutletContext]=\"{\n value: getCellValue(column, row),\n row: row,\n column: column.name,\n index: rowIndex\n }\"\n ></ng-template>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n<ng-content></ng-content>\n",
1346
- inputs: ['value'],
1347
- changeDetection: ChangeDetectionStrategy.OnPush,
1348
- styles: [".td-data-table-sort-badge{-ms-flex-align:center;-ms-flex-pack:center;align-items:center;border-radius:50%;display:-ms-flexbox;display:flex;height:16px;justify-content:center;margin-left:4px;width:16px}:host{display:block;overflow:hidden}:host .td-data-table-scrollable{height:calc(100% - 56px);overflow:auto;position:relative}.td-table-header-label{display:-ms-flexbox;display:flex}.td-data-table-column-resizer{cursor:col-resize;right:0;width:6px}.td-data-table-column-resizer,.td-data-table-column-resizer .td-data-table-column-separator{height:100%;position:absolute;top:0}.td-data-table-column-resizer .td-data-table-column-separator{left:2px}.td-data-table-column-resizer.td-resizing{cursor:-webkit-grabbing}table.td-data-table{width:auto!important}table.td-data-table.mat-selectable tbody>tr.td-data-table-row{transition:background-color .2s}table.td-data-table.mat-selectable .td-data-table-column:first-child>.td-data-table-column-content-wrapper,table.td-data-table.mat-selectable td.td-data-table-cell:first-child>.td-data-table-column-content-wrapper,table.td-data-table.mat-selectable th.td-data-table-column:first-child>.td-data-table-column-content-wrapper{min-width:18px;padding:0 24px;width:18px}table.td-data-table.mat-selectable .td-data-table-column:nth-child(2)>.td-data-table-column-content-wrapper,table.td-data-table.mat-selectable td.td-data-table-cell:nth-child(2)>.td-data-table-column-content-wrapper,table.td-data-table.mat-selectable th.td-data-table-column:nth-child(2)>.td-data-table-column-content-wrapper{padding-left:0}[dir=rtl] table.td-data-table.mat-selectable .td-data-table-column:nth-child(2)>.td-data-table-column-content-wrapper,[dir=rtl] table.td-data-table.mat-selectable td.td-data-table-cell:nth-child(2)>.td-data-table-column-content-wrapper,[dir=rtl] table.td-data-table.mat-selectable th.td-data-table-column:nth-child(2)>.td-data-table-column-content-wrapper{padding-left:28px;padding-right:0}table.td-data-table td.mat-checkbox-cell,table.td-data-table th.mat-checkbox-column{font-size:0!important;min-width:42px;width:42px}table.td-data-table td.mat-checkbox-cell mat-pseudo-checkbox,table.td-data-table th.mat-checkbox-column mat-pseudo-checkbox{height:18px;width:18px}::ng-deep table.td-data-table td.mat-checkbox-cell mat-pseudo-checkbox.mat-pseudo-checkbox-checked:after,::ng-deep table.td-data-table th.mat-checkbox-column mat-pseudo-checkbox.mat-pseudo-checkbox-checked:after{height:4px!important;width:11px!important}table.td-data-table td.mat-checkbox-cell mat-checkbox ::ng-deep .mat-checkbox-inner-container,table.td-data-table th.mat-checkbox-column mat-checkbox ::ng-deep .mat-checkbox-inner-container{height:18px;margin:0;width:18px}"]
1349
- }] }
1350
- ];
1351
- /** @nocollapse */
1352
- TdDataTableComponent.ctorParameters = () => [
1353
- { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] },
1354
- { type: ElementRef },
1355
- { type: DomSanitizer },
1356
- { type: ChangeDetectorRef }
1357
- ];
1358
- TdDataTableComponent.propDecorators = {
1359
- _templates: [{ type: ContentChildren, args: [TdDataTableTemplateDirective, { descendants: true },] }],
1360
- _scrollableDiv: [{ type: ViewChild, args: ['scrollableDiv', { static: true },] }],
1361
- _colElements: [{ type: ViewChildren, args: ['columnElement',] }],
1362
- _rows: [{ type: ViewChildren, args: [TdDataTableRowComponent,] }],
1363
- data: [{ type: Input, args: ['data',] }],
1364
- columns: [{ type: Input, args: ['columns',] }],
1365
- resizableColumns: [{ type: Input, args: ['resizableColumns',] }],
1366
- selectable: [{ type: Input, args: ['selectable',] }],
1367
- clickable: [{ type: Input, args: ['clickable',] }],
1368
- multiple: [{ type: Input, args: ['multiple',] }],
1369
- sortable: [{ type: Input, args: ['sortable',] }],
1370
- sortBy: [{ type: Input, args: ['sortBy',] }],
1371
- sortOrder: [{ type: Input, args: ['sortOrder',] }],
1372
- sortChange: [{ type: Output }],
1373
- rowSelect: [{ type: Output }],
1374
- rowClick: [{ type: Output }],
1375
- selectAll: [{ type: Output }],
1376
- compareWith: [{ type: Input }]
1377
- };
1378
- if (false) {
1379
- /**
1380
- * responsive width calculations
1381
- * @type {?}
1382
- * @private
1383
- */
1384
- TdDataTableComponent.prototype._resizeSubs;
1385
- /**
1386
- * @type {?}
1387
- * @private
1388
- */
1389
- TdDataTableComponent.prototype._rowsChangedSubs;
1390
- /**
1391
- * @type {?}
1392
- * @private
1393
- */
1394
- TdDataTableComponent.prototype._hostWidth;
1395
- /**
1396
- * manually resizable columns
1397
- * @type {?}
1398
- * @private
1399
- */
1400
- TdDataTableComponent.prototype._resizableColumns;
1401
- /**
1402
- * @type {?}
1403
- * @private
1404
- */
1405
- TdDataTableComponent.prototype._columnClientX;
1406
- /**
1407
- * @type {?}
1408
- * @private
1409
- */
1410
- TdDataTableComponent.prototype._columnResizeSubs;
1411
- /**
1412
- * @type {?}
1413
- * @private
1414
- */
1415
- TdDataTableComponent.prototype._resizingColumn;
1416
- /**
1417
- * @type {?}
1418
- * @private
1419
- */
1420
- TdDataTableComponent.prototype._onColumnResize;
1421
- /**
1422
- * @type {?}
1423
- * @private
1424
- */
1425
- TdDataTableComponent.prototype._widths;
1426
- /**
1427
- * @type {?}
1428
- * @private
1429
- */
1430
- TdDataTableComponent.prototype._onResize;
1431
- /**
1432
- * column header reposition and viewpoort
1433
- * @type {?}
1434
- * @private
1435
- */
1436
- TdDataTableComponent.prototype._verticalScrollSubs;
1437
- /**
1438
- * @type {?}
1439
- * @private
1440
- */
1441
- TdDataTableComponent.prototype._horizontalScrollSubs;
1442
- /**
1443
- * @type {?}
1444
- * @private
1445
- */
1446
- TdDataTableComponent.prototype._scrollHorizontalOffset;
1447
- /**
1448
- * @type {?}
1449
- * @private
1450
- */
1451
- TdDataTableComponent.prototype._onHorizontalScroll;
1452
- /**
1453
- * @type {?}
1454
- * @private
1455
- */
1456
- TdDataTableComponent.prototype._onVerticalScroll;
1457
- /**
1458
- * @type {?}
1459
- * @private
1460
- */
1461
- TdDataTableComponent.prototype._rowHeightCache;
1462
- /**
1463
- * @type {?}
1464
- * @private
1465
- */
1466
- TdDataTableComponent.prototype._totalHeight;
1467
- /**
1468
- * @type {?}
1469
- * @private
1470
- */
1471
- TdDataTableComponent.prototype._hostHeight;
1472
- /**
1473
- * @type {?}
1474
- * @private
1475
- */
1476
- TdDataTableComponent.prototype._scrollVerticalOffset;
1477
- /**
1478
- * @type {?}
1479
- * @private
1480
- */
1481
- TdDataTableComponent.prototype._offsetTransform;
1482
- /**
1483
- * @type {?}
1484
- * @private
1485
- */
1486
- TdDataTableComponent.prototype._fromRow;
1487
- /**
1488
- * @type {?}
1489
- * @private
1490
- */
1491
- TdDataTableComponent.prototype._toRow;
1492
- /**
1493
- * @type {?}
1494
- * @private
1495
- */
1496
- TdDataTableComponent.prototype._valueChangesSubs;
1497
- /**
1498
- * internal attributes
1499
- * @type {?}
1500
- * @private
1501
- */
1502
- TdDataTableComponent.prototype._data;
1503
- /**
1504
- * @type {?}
1505
- * @private
1506
- */
1507
- TdDataTableComponent.prototype._virtualData;
1508
- /**
1509
- * @type {?}
1510
- * @private
1511
- */
1512
- TdDataTableComponent.prototype._columns;
1513
- /**
1514
- * @type {?}
1515
- * @private
1516
- */
1517
- TdDataTableComponent.prototype._selectable;
1518
- /**
1519
- * @type {?}
1520
- * @private
1521
- */
1522
- TdDataTableComponent.prototype._clickable;
1523
- /**
1524
- * @type {?}
1525
- * @private
1526
- */
1527
- TdDataTableComponent.prototype._multiple;
1528
- /**
1529
- * @type {?}
1530
- * @private
1531
- */
1532
- TdDataTableComponent.prototype._allSelected;
1533
- /**
1534
- * @type {?}
1535
- * @private
1536
- */
1537
- TdDataTableComponent.prototype._indeterminate;
1538
- /**
1539
- * sorting
1540
- * @type {?}
1541
- * @private
1542
- */
1543
- TdDataTableComponent.prototype._sortable;
1544
- /**
1545
- * @type {?}
1546
- * @private
1547
- */
1548
- TdDataTableComponent.prototype._sortBy;
1549
- /**
1550
- * @type {?}
1551
- * @private
1552
- */
1553
- TdDataTableComponent.prototype._sortOrder;
1554
- /**
1555
- * shift select
1556
- * @type {?}
1557
- * @private
1558
- */
1559
- TdDataTableComponent.prototype._shiftPreviouslyPressed;
1560
- /**
1561
- * @type {?}
1562
- * @private
1563
- */
1564
- TdDataTableComponent.prototype._lastSelectedIndex;
1565
- /**
1566
- * @type {?}
1567
- * @private
1568
- */
1569
- TdDataTableComponent.prototype._firstSelectedIndex;
1570
- /**
1571
- * @type {?}
1572
- * @private
1573
- */
1574
- TdDataTableComponent.prototype._firstCheckboxValue;
1575
- /**
1576
- * template fetching support
1577
- * @type {?}
1578
- * @private
1579
- */
1580
- TdDataTableComponent.prototype._templateMap;
1581
- /** @type {?} */
1582
- TdDataTableComponent.prototype._templates;
1583
- /** @type {?} */
1584
- TdDataTableComponent.prototype._scrollableDiv;
1585
- /** @type {?} */
1586
- TdDataTableComponent.prototype._colElements;
1587
- /** @type {?} */
1588
- TdDataTableComponent.prototype._rows;
1589
- /**
1590
- * sortChange?: function
1591
- * Event emitted when the column headers are clicked. [sortable] needs to be enabled.
1592
- * Emits an [ITdDataTableSortChangeEvent] implemented object.
1593
- * @type {?}
1594
- */
1595
- TdDataTableComponent.prototype.sortChange;
1596
- /**
1597
- * rowSelect?: function
1598
- * Event emitted when a row is selected/deselected. [selectable] needs to be enabled.
1599
- * Emits an [ITdDataTableSelectEvent] implemented object.
1600
- * @type {?}
1601
- */
1602
- TdDataTableComponent.prototype.rowSelect;
1603
- /**
1604
- * rowClick?: function
1605
- * Event emitted when a row is clicked.
1606
- * Emits an [ITdDataTableRowClickEvent] implemented object.
1607
- * @type {?}
1608
- */
1609
- TdDataTableComponent.prototype.rowClick;
1610
- /**
1611
- * selectAll?: function
1612
- * Event emitted when all rows are selected/deselected by the all checkbox. [selectable] needs to be enabled.
1613
- * Emits an [ITdDataTableSelectAllEvent] implemented object.
1614
- * @type {?}
1615
- */
1616
- TdDataTableComponent.prototype.selectAll;
1617
- /**
1618
- * compareWith?: function(row, model): boolean
1619
- * Allows custom comparison between row and model to see if row is selected or not
1620
- * Default comparation is by reference
1621
- * @type {?}
1622
- */
1623
- TdDataTableComponent.prototype.compareWith;
1624
- /**
1625
- * @type {?}
1626
- * @private
1627
- */
1628
- TdDataTableComponent.prototype._document;
1629
- /**
1630
- * @type {?}
1631
- * @private
1632
- */
1633
- TdDataTableComponent.prototype._elementRef;
1634
- /**
1635
- * @type {?}
1636
- * @private
1637
- */
1638
- TdDataTableComponent.prototype._domSanitizer;
1639
- }
1640
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"../../../../../src/platform/core/data-table/","sources":["data-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  forwardRef,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ViewChild,\n  OnDestroy,\n  AfterViewInit,\n  ContentChildren,\n  TemplateRef,\n  AfterContentInit,\n  QueryList,\n  Inject,\n  Optional,\n  ViewChildren,\n  ElementRef,\n  OnInit,\n  AfterContentChecked,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ENTER, SPACE, UP_ARROW, DOWN_ARROW } from '@angular/cdk/keycodes';\n\nimport { Observable, Subscription, Subject } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\n\nimport { TdDataTableRowComponent } from './data-table-row/data-table-row.component';\nimport {\n  ITdDataTableSortChangeEvent,\n  TdDataTableColumnComponent,\n} from './data-table-column/data-table-column.component';\nimport { TdDataTableTemplateDirective } from './directives/data-table-template.directive';\n\nimport { IControlValueAccessor, mixinControlValueAccessor } from '@covalent/core/common';\n\nexport enum TdDataTableSortingOrder {\n  Ascending = 'ASC',\n  Descending = 'DESC',\n}\n\nexport interface ITdDataTableColumnWidth {\n  min?: number;\n  max?: number;\n}\n\nexport interface ITdDataTableColumn {\n  name: string;\n  label: string;\n  tooltip?: string;\n  numeric?: boolean;\n  format?: (value: any) => any;\n  nested?: boolean;\n  sortable?: boolean;\n  hidden?: boolean;\n  filter?: boolean;\n  width?: ITdDataTableColumnWidth | number;\n  columnSortOrder?: number;\n}\n\nexport interface ITdDataTableSelectEvent {\n  row: any;\n  selected: boolean;\n  index: number;\n}\n\nexport interface ITdDataTableSelectAllEvent {\n  rows: any[];\n  selected: boolean;\n}\n\nexport interface ITdDataTableRowClickEvent {\n  row: any;\n  index: number;\n}\n\nexport interface IInternalColumnWidth {\n  value: number;\n  limit: boolean;\n  index: number;\n  min?: boolean;\n  max?: boolean;\n}\n\n/**\n * Constant to set the rows offset before and after the viewport\n */\nconst TD_VIRTUAL_OFFSET: number = 2;\n\n/**\n * Constant to set default row height if none is provided\n */\nconst TD_VIRTUAL_DEFAULT_ROW_HEIGHT: number = 48;\n\nexport class TdDataTableBase {\n  constructor(public _changeDetectorRef: ChangeDetectorRef) {}\n}\n\n/* tslint:disable-next-line */\nexport const _TdDataTableMixinBase = mixinControlValueAccessor(TdDataTableBase, []);\n\n@Component({\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TdDataTableComponent),\n      multi: true,\n    },\n  ],\n  selector: 'td-data-table',\n  styleUrls: ['./data-table.component.scss'],\n  templateUrl: './data-table.component.html',\n  inputs: ['value'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TdDataTableComponent\n  extends _TdDataTableMixinBase\n  implements IControlValueAccessor, OnInit, AfterContentInit, AfterContentChecked, AfterViewInit, OnDestroy\n{\n  /** responsive width calculations */\n  private _resizeSubs: Subscription;\n  private _rowsChangedSubs: Subscription;\n  private _hostWidth: number = 0;\n\n  /** manually resizable columns */\n  private _resizableColumns: boolean = false;\n  private _columnClientX: number = 0;\n  private _columnResizeSubs: Subscription;\n  private _resizingColumn: number;\n  private _onColumnResize: Subject<number> = new Subject<number>();\n\n  get resizingColumn(): number {\n    return this._resizingColumn;\n  }\n\n  get hostWidth(): number {\n    // if the checkboxes are rendered, we need to remove their width\n    // from the total width to calculate properly\n    if (this.selectable) {\n      return this._hostWidth - 42;\n    }\n    return this._hostWidth;\n  }\n\n  private _widths: IInternalColumnWidth[] = [];\n  private _onResize: Subject<void> = new Subject<void>();\n\n  /** column header reposition and viewpoort */\n  private _verticalScrollSubs: Subscription;\n  private _horizontalScrollSubs: Subscription;\n  private _scrollHorizontalOffset: number = 0;\n\n  private _onHorizontalScroll: Subject<number> = new Subject<number>();\n  private _onVerticalScroll: Subject<number> = new Subject<number>();\n\n  // Array of cached row heights to allow dynamic row heights\n  private _rowHeightCache: number[] = [];\n  // Total pseudo height of all the elements\n  private _totalHeight: number = 0;\n  // Total host height for the viewport\n  private _hostHeight: number = 0;\n  // Scrolled vertical pixels\n  private _scrollVerticalOffset: number = 0;\n  // Style to move the content a certain offset depending on scrolled offset\n  private _offsetTransform: SafeStyle;\n\n  // Variables that set from and to which rows will be rendered\n  private _fromRow: number = 0;\n  private _toRow: number = 0;\n\n  /**\n   * Returns the offset style with a proper calculation on how much it should move\n   * over the y axis of the total height\n   */\n  get offsetTransform(): SafeStyle {\n    return this._offsetTransform;\n  }\n\n  /**\n   * Returns the assumed total height of the rows\n   */\n  get totalHeight(): number {\n    return this._totalHeight;\n  }\n\n  /**\n   * Returns the initial row to render in the viewport\n   */\n  get fromRow(): number {\n    return this._fromRow;\n  }\n\n  /**\n   * Returns the last row to render in the viewport\n   */\n  get toRow(): number {\n    return this._toRow;\n  }\n\n  private _valueChangesSubs: Subscription;\n  /** internal attributes */\n  private _data: any[];\n  // data virtually iterated by component\n  private _virtualData: any[];\n  private _columns: ITdDataTableColumn[];\n  private _selectable: boolean = false;\n  private _clickable: boolean = false;\n  private _multiple: boolean = true;\n  private _allSelected: boolean = false;\n  private _indeterminate: boolean = false;\n\n  /** sorting */\n  private _sortable: boolean = false;\n  private _sortBy: ITdDataTableColumn;\n  private _sortOrder: TdDataTableSortingOrder = TdDataTableSortingOrder.Ascending;\n\n  /** shift select */\n  private _shiftPreviouslyPressed: boolean = false;\n  private _lastSelectedIndex: number = -1;\n  private _firstSelectedIndex: number = -1;\n  private _firstCheckboxValue: boolean = false;\n\n  /** template fetching support */\n  private _templateMap: Map<string, TemplateRef<any>> = new Map<string, TemplateRef<any>>();\n  @ContentChildren(TdDataTableTemplateDirective, { descendants: true })\n  _templates: QueryList<TdDataTableTemplateDirective>;\n\n  @ViewChild('scrollableDiv', { static: true }) _scrollableDiv: ElementRef;\n\n  @ViewChildren('columnElement') _colElements: QueryList<TdDataTableColumnComponent>;\n\n  @ViewChildren(TdDataTableRowComponent) _rows: QueryList<TdDataTableRowComponent>;\n\n  /**\n   * Returns scroll position to reposition column headers\n   */\n  get columnsLeftScroll(): number {\n    return this._scrollHorizontalOffset * -1;\n  }\n\n  /**\n   * Returns true if all values are selected.\n   */\n  get allSelected(): boolean {\n    return this._allSelected;\n  }\n\n  /**\n   * Returns true if all values are not deselected\n   * and at least one is.\n   */\n  get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n\n  /**\n   * data?: {[key: string]: any}[]\n   * Sets the data to be rendered as rows.\n   */\n  @Input('data')\n  set data(data: any[]) {\n    this._data = data;\n    this._rowHeightCache = [];\n    Promise.resolve().then(() => {\n      this.refresh();\n      // scroll back to the top if the data has changed\n      this._scrollableDiv.nativeElement.scrollTop = 0;\n    });\n  }\n  get data(): any[] {\n    return this._data;\n  }\n\n  get virtualData(): any[] {\n    return this._virtualData;\n  }\n\n  /**\n   * columns?: ITdDataTableColumn[]\n   * Sets additional column configuration. [ITdDataTableColumn.name] has to exist in [data] as key.\n   * Defaults to [data] keys.\n   */\n  @Input('columns')\n  set columns(cols: ITdDataTableColumn[]) {\n    this._columns = cols;\n  }\n  get columns(): ITdDataTableColumn[] {\n    if (this._columns) {\n      return this._columns;\n    }\n\n    if (this.hasData) {\n      this._columns = [];\n      // if columns is undefined, use key in [data] rows as name and label for column headers.\n      const row: any = this._data[0];\n      Object.keys(row).forEach((k: string) => {\n        if (!this._columns.find((c: any) => c.name === k)) {\n          this._columns.push({ name: k, label: k });\n        }\n      });\n      return this._columns;\n    } else {\n      return [];\n    }\n  }\n\n  /**\n   * resizableColumns?: boolean\n   * Enables manual column resize.\n   * Defaults to 'false'\n   */\n  @Input('resizableColumns')\n  set resizableColumns(resizableColumns: boolean) {\n    this._resizableColumns = coerceBooleanProperty(resizableColumns);\n  }\n  get resizableColumns(): boolean {\n    return this._resizableColumns;\n  }\n\n  /**\n   * selectable?: boolean\n   * Enables row selection events, hover and selected row states.\n   * Defaults to 'false'\n   */\n  @Input('selectable')\n  set selectable(selectable: boolean) {\n    this._selectable = coerceBooleanProperty(selectable);\n  }\n  get selectable(): boolean {\n    return this._selectable;\n  }\n\n  /**\n   * clickable?: boolean\n   * Enables row click events, hover.\n   * Defaults to 'false'\n   */\n  @Input('clickable')\n  set clickable(clickable: boolean) {\n    this._clickable = coerceBooleanProperty(clickable);\n  }\n  get clickable(): boolean {\n    return this._clickable;\n  }\n\n  /**\n   * multiple?: boolean\n   * Enables multiple row selection. [selectable] needs to be enabled.\n   * Defaults to 'false'\n   */\n  @Input('multiple')\n  set multiple(multiple: boolean) {\n    this._multiple = coerceBooleanProperty(multiple);\n  }\n  get multiple(): boolean {\n    return this._multiple;\n  }\n\n  /**\n   * sortable?: boolean\n   * Enables sorting events, sort icons and active column states.\n   * Defaults to 'false'\n   */\n  @Input('sortable')\n  set sortable(sortable: boolean) {\n    this._sortable = coerceBooleanProperty(sortable);\n  }\n  get sortable(): boolean {\n    return this._sortable;\n  }\n\n  /**\n   * sortBy?: string\n   * Sets the active sort column. [sortable] needs to be enabled.\n   */\n  @Input('sortBy')\n  set sortBy(columnName: string) {\n    if (!columnName) {\n      return;\n    }\n    const column: ITdDataTableColumn = this.columns.find((c: any) => c.name === columnName);\n    if (!column) {\n      throw new Error('[sortBy] must be a valid column name');\n    }\n\n    this._sortBy = column;\n  }\n  get sortByColumn(): ITdDataTableColumn {\n    return this._sortBy;\n  }\n\n  /**\n   * sortOrder?: ['ASC' | 'DESC'] or TdDataTableSortingOrder\n   * Sets the sort order of the [sortBy] column. [sortable] needs to be enabled.\n   * Defaults to 'ASC' or TdDataTableSortingOrder.Ascending\n   */\n  @Input('sortOrder')\n  set sortOrder(order: 'ASC' | 'DESC') {\n    const sortOrder: string = order ? order.toUpperCase() : 'ASC';\n    if (sortOrder !== 'DESC' && sortOrder !== 'ASC') {\n      throw new Error('[sortOrder] must be empty, ASC or DESC');\n    }\n\n    this._sortOrder = sortOrder === 'ASC' ? TdDataTableSortingOrder.Ascending : TdDataTableSortingOrder.Descending;\n  }\n  get sortOrderEnum(): TdDataTableSortingOrder {\n    return this._sortOrder;\n  }\n\n  get hasData(): boolean {\n    return this._data && this._data.length > 0;\n  }\n\n  /**\n   * sortChange?: function\n   * Event emitted when the column headers are clicked. [sortable] needs to be enabled.\n   * Emits an [ITdDataTableSortChangeEvent] implemented object.\n   */\n  @Output() sortChange: EventEmitter<ITdDataTableSortChangeEvent> = new EventEmitter<ITdDataTableSortChangeEvent>();\n\n  /**\n   * rowSelect?: function\n   * Event emitted when a row is selected/deselected. [selectable] needs to be enabled.\n   * Emits an [ITdDataTableSelectEvent] implemented object.\n   */\n  @Output() rowSelect: EventEmitter<ITdDataTableSelectEvent> = new EventEmitter<ITdDataTableSelectEvent>();\n\n  /**\n   * rowClick?: function\n   * Event emitted when a row is clicked.\n   * Emits an [ITdDataTableRowClickEvent] implemented object.\n   */\n  @Output() rowClick: EventEmitter<ITdDataTableRowClickEvent> = new EventEmitter<ITdDataTableRowClickEvent>();\n\n  /**\n   * selectAll?: function\n   * Event emitted when all rows are selected/deselected by the all checkbox. [selectable] needs to be enabled.\n   * Emits an [ITdDataTableSelectAllEvent] implemented object.\n   */\n  @Output() selectAll: EventEmitter<ITdDataTableSelectAllEvent> = new EventEmitter<ITdDataTableSelectAllEvent>();\n\n  constructor(\n    @Optional() @Inject(DOCUMENT) private _document: any,\n    private _elementRef: ElementRef,\n    private _domSanitizer: DomSanitizer,\n    _changeDetectorRef: ChangeDetectorRef,\n  ) {\n    super(_changeDetectorRef);\n  }\n\n  /**\n   * compareWith?: function(row, model): boolean\n   * Allows custom comparison between row and model to see if row is selected or not\n   * Default comparation is by reference\n   */\n  @Input() compareWith: (row: any, model: any) => boolean = (row: any, model: any) => {\n    return row === model;\n  };\n\n  /**\n   * Initialize observable for resize and scroll events\n   */\n  ngOnInit(): void {\n    // initialize observable for resize calculations\n    this._resizeSubs = this._onResize.asObservable().subscribe(() => {\n      if (this._rows) {\n        this._rows.toArray().forEach((row: TdDataTableRowComponent, index: number) => {\n          this._rowHeightCache[this.fromRow + index] = row.height + 1;\n        });\n      }\n      this._calculateWidths();\n      this._calculateVirtualRows();\n    });\n\n    // initialize observable for column resize calculations\n    this._columnResizeSubs = this._onColumnResize\n      .asObservable()\n      .pipe(debounceTime(0))\n      .subscribe((clientX: number) => {\n        this._columnClientX = clientX;\n        this._calculateWidths();\n        this._changeDetectorRef.markForCheck();\n      });\n    // initialize observable for scroll column header reposition\n    this._horizontalScrollSubs = this._onHorizontalScroll.asObservable().subscribe((horizontalScroll: number) => {\n      this._scrollHorizontalOffset = horizontalScroll;\n      this._changeDetectorRef.markForCheck();\n    });\n    // initialize observable for virtual scroll rendering\n    this._verticalScrollSubs = this._onVerticalScroll.asObservable().subscribe((verticalScroll: number) => {\n      this._scrollVerticalOffset = verticalScroll;\n      this._calculateVirtualRows();\n      this._changeDetectorRef.markForCheck();\n    });\n    this._valueChangesSubs = this.valueChanges.subscribe((value: any) => {\n      this.refresh();\n    });\n  }\n\n  /**\n   * Loads templates and sets them in a map for faster access.\n   */\n  ngAfterContentInit(): void {\n    for (const template of this._templates.toArray()) {\n      this._templateMap.set(template.tdDataTableTemplate, template.templateRef);\n    }\n  }\n\n  /**\n   * Checks hosts native elements widths to see if it has changed (resize check)\n   */\n  ngAfterContentChecked(): void {\n    // check if the scroll has been reset when element is hidden\n    if (this._scrollVerticalOffset - this._scrollableDiv.nativeElement.scrollTop > 5) {\n      // scroll back to the top if element has been reset\n      this._onVerticalScroll.next(0);\n    }\n    if (this._elementRef.nativeElement) {\n      const newHostWidth: number = this._elementRef.nativeElement.getBoundingClientRect().width;\n      // if the width has changed then we throw a resize event.\n      if (this._hostWidth !== newHostWidth) {\n        setTimeout(() => {\n          this._hostWidth = newHostWidth;\n          this._onResize.next();\n        }, 0);\n      }\n    }\n    if (this._scrollableDiv.nativeElement) {\n      const newHostHeight: number = this._scrollableDiv.nativeElement.getBoundingClientRect().height;\n      // if the height of the viewport has changed, then we mark for check\n      if (this._hostHeight !== newHostHeight) {\n        this._hostHeight = newHostHeight;\n        this._calculateVirtualRows();\n        this._changeDetectorRef.markForCheck();\n      }\n    }\n  }\n\n  /**\n   * Registers to an observable that checks if all rows have been rendered\n   * so we can start calculating the widths\n   */\n  ngAfterViewInit(): void {\n    this._rowsChangedSubs = this._rows.changes.pipe(debounceTime(0)).subscribe(() => {\n      this._onResize.next();\n    });\n    this._calculateVirtualRows();\n  }\n\n  /**\n   * Unsubscribes observables when data table is destroyed\n   */\n  ngOnDestroy(): void {\n    if (this._resizeSubs) {\n      this._resizeSubs.unsubscribe();\n    }\n    if (this._columnResizeSubs) {\n      this._columnResizeSubs.unsubscribe();\n    }\n    if (this._horizontalScrollSubs) {\n      this._horizontalScrollSubs.unsubscribe();\n    }\n    if (this._verticalScrollSubs) {\n      this._verticalScrollSubs.unsubscribe();\n    }\n    if (this._rowsChangedSubs) {\n      this._rowsChangedSubs.unsubscribe();\n    }\n    if (this._valueChangesSubs) {\n      this._valueChangesSubs.unsubscribe();\n    }\n  }\n\n  /**\n   * Method that gets executed every time there is a scroll event\n   * Calls the scroll observable\n   */\n  handleScroll(event: Event): void {\n    const element: HTMLElement = <HTMLElement>event.target;\n    if (element) {\n      const horizontalScroll: number = element.scrollLeft;\n      if (this._scrollHorizontalOffset !== horizontalScroll) {\n        this._onHorizontalScroll.next(horizontalScroll);\n      }\n      const verticalScroll: number = element.scrollTop;\n      if (this._scrollVerticalOffset !== verticalScroll) {\n        this._onVerticalScroll.next(verticalScroll);\n      }\n    }\n  }\n\n  /**\n   * Returns the width needed for the columns via index\n   */\n  getColumnWidth(index: number): number {\n    if (this._widths[index]) {\n      return this._widths[index].value;\n    }\n    return undefined;\n  }\n\n  getCellValue(column: ITdDataTableColumn, value: any): string {\n    if (column.nested === undefined || column.nested) {\n      return this._getNestedValue(column.name, value);\n    }\n    return value[column.name];\n  }\n\n  /**\n   * Getter method for template references\n   */\n  getTemplateRef(name: string): TemplateRef<any> {\n    return this._templateMap.get(name);\n  }\n\n  /**\n   * Clears model (ngModel) of component by removing all values in array.\n   */\n  clearModel(): void {\n    this.value.splice(0, this.value.length);\n  }\n\n  /**\n   * Refreshes data table and rerenders [data] and [columns]\n   */\n  refresh(): void {\n    this._calculateVirtualRows();\n    this._calculateWidths();\n    this._calculateCheckboxState();\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /**\n   * Selects or clears all rows depending on 'checked' value.\n   */\n  _selectAll(checked: boolean): void {\n    const toggledRows: any[] = [];\n    if (checked) {\n      this._data.forEach((row: any) => {\n        // skiping already selected rows\n        if (!this.isRowSelected(row)) {\n          this.value.push(row);\n          // checking which ones are being toggled\n          toggledRows.push(row);\n        }\n      });\n      this._allSelected = true;\n      this._indeterminate = true;\n    } else {\n      this._data.forEach((row: any) => {\n        // checking which ones are being toggled\n        if (this.isRowSelected(row)) {\n          toggledRows.push(row);\n          const modelRow: any = this.value.filter((val: any) => {\n            return this.compareWith(row, val);\n          })[0];\n          const index: number = this.value.indexOf(modelRow);\n          if (index > -1) {\n            this.value.splice(index, 1);\n          }\n        }\n      });\n      this._allSelected = false;\n      this._indeterminate = false;\n    }\n    this.selectAll.emit({ rows: toggledRows, selected: checked });\n    this.onChange(this.value);\n  }\n\n  /**\n   * Checks if row is selected\n   */\n  isRowSelected(row: any): boolean {\n    // compare items by [compareWith] function\n    return this.value\n      ? this.value.filter((val: any) => {\n          return this.compareWith(row, val);\n        }).length > 0\n      : false;\n  }\n\n  /**\n   * Selects or clears a row depending on 'checked' value if the row 'isSelectable'\n   * handles cntrl clicks and shift clicks for multi-select\n   */\n  select(row: any, event: Event, currentSelected: number): void {\n    if (this.selectable) {\n      this.blockEvent(event);\n      // Check to see if Shift key is selected and need to select everything in between\n      const mouseEvent: MouseEvent = event as MouseEvent;\n      if (this.multiple && mouseEvent && mouseEvent.shiftKey && this._lastSelectedIndex > -1) {\n        let firstIndex: number = currentSelected;\n        let lastIndex: number = this._lastSelectedIndex;\n        if (currentSelected > this._lastSelectedIndex) {\n          firstIndex = this._lastSelectedIndex;\n          lastIndex = currentSelected;\n        }\n        // if clicking a checkbox behind the initial check, then toggle all selections expect the initial checkbox\n        // else the checkboxes clicked are all after the initial one\n        if (\n          (this._firstSelectedIndex >= currentSelected && this._lastSelectedIndex > this._firstSelectedIndex) ||\n          (this._firstSelectedIndex <= currentSelected && this._lastSelectedIndex < this._firstSelectedIndex)\n        ) {\n          for (let i: number = firstIndex; i <= lastIndex; i++) {\n            if (this._firstSelectedIndex !== i) {\n              this._doSelection(this._data[i], i);\n            }\n          }\n        } else if (this._firstSelectedIndex > currentSelected || this._firstSelectedIndex < currentSelected) {\n          // change indexes depending on where the next checkbox is selected (before or after)\n          if (this._firstSelectedIndex > currentSelected) {\n            lastIndex--;\n          } else if (this._firstSelectedIndex < currentSelected) {\n            firstIndex++;\n          }\n          for (let i: number = firstIndex; i <= lastIndex; i++) {\n            const rowSelected: boolean = this.isRowSelected(this._data[i]);\n            // if row is selected and first checkbox was selected\n            // or if row was unselected and first checkbox was unselected\n            // we ignore the toggle\n            if ((this._firstCheckboxValue && !rowSelected) || (!this._firstCheckboxValue && rowSelected)) {\n              this._doSelection(this._data[i], i);\n            } else if (\n              this._shiftPreviouslyPressed &&\n              ((currentSelected >= this._firstSelectedIndex && currentSelected <= this._lastSelectedIndex) ||\n                (currentSelected <= this._firstSelectedIndex && currentSelected >= this._lastSelectedIndex))\n            ) {\n              // else if the checkbox selected was in the middle of the last selection and the first selection\n              // then we undo the selections\n              this._doSelection(this._data[i], i);\n            }\n          }\n        }\n        this._shiftPreviouslyPressed = true;\n        // if shift wasnt pressed, then we take the element checked as the first row\n        // incase the next click uses shift\n      } else if (mouseEvent && !mouseEvent.shiftKey) {\n        this._firstCheckboxValue = this._doSelection(row, currentSelected);\n        this._shiftPreviouslyPressed = false;\n        this._firstSelectedIndex = currentSelected;\n      }\n      this._lastSelectedIndex = currentSelected;\n    }\n  }\n\n  /**\n   * Overrides the onselectstart method of the document so other text on the page\n   * doesn't get selected when doing shift selections.\n   */\n  disableTextSelection(): void {\n    if (this._document) {\n      this._document.onselectstart = function (): boolean {\n        return false;\n      };\n    }\n  }\n\n  /**\n   * Resets the original onselectstart method.\n   */\n  enableTextSelection(): void {\n    if (this._document) {\n      this._document.onselectstart = undefined;\n    }\n  }\n\n  /**\n   * emits the onRowClickEvent when a row is clicked\n   * if clickable is true and selectable is false then select the row\n   */\n  handleRowClick(row: any, index: number, event: Event): void {\n    if (this.clickable) {\n      // ignoring linting rules here because attribute it actually null or not there\n      // can't check for undefined\n      const srcElement: any = event.srcElement || event.currentTarget;\n      const element: HTMLElement = event.target as HTMLElement;\n      /* tslint:disable-next-line */\n      if (srcElement.getAttribute('stopRowClick') === null && element.tagName.toLowerCase() !== 'mat-pseudo-checkbox') {\n        this.rowClick.emit({\n          row,\n          index,\n        });\n      }\n    }\n  }\n\n  /**\n   * Method handle for sort click event in column headers.\n   */\n  handleSort(column: ITdDataTableColumn): void {\n    if (this._sortBy === column) {\n      this._sortOrder =\n        this._sortOrder === TdDataTableSortingOrder.Ascending\n          ? TdDataTableSortingOrder.Descending\n          : TdDataTableSortingOrder.Ascending;\n    } else {\n      this._sortBy = column;\n      this._sortOrder = TdDataTableSortingOrder.Ascending;\n    }\n    this.sortChange.next({ name: this._sortBy.name, order: this._sortOrder });\n  }\n\n  /**\n   * Handle all keyup events when focusing a data table row\n   */\n  _rowKeyup(event: KeyboardEvent, row: any, index: number): void {\n    switch (event.keyCode) {\n      case ENTER:\n      case SPACE:\n        /** if user presses enter or space, the row should be selected */\n        if (this.selectable) {\n          this._doSelection(this._data[this.fromRow + index], this.fromRow + index);\n        }\n        break;\n      case UP_ARROW:\n        /**\n         * if users presses the up arrow, we focus the prev row\n         * unless its the first row\n         */\n        if (index > 0) {\n          this._rows.toArray()[index - 1].focus();\n        }\n        this.blockEvent(event);\n        if (this.selectable && this.multiple && event.shiftKey && this.fromRow + index >= 0) {\n          this._doSelection(this._data[this.fromRow + index], this.fromRow + index);\n        }\n        break;\n      case DOWN_ARROW:\n        /**\n         * if users presses the down arrow, we focus the next row\n         * unless its the last row\n         */\n        if (index < this._rows.toArray().length - 1) {\n          this._rows.toArray()[index + 1].focus();\n        }\n        this.blockEvent(event);\n        if (this.selectable && this.multiple && event.shiftKey && this.fromRow + index < this._data.length) {\n          this._doSelection(this._data[this.fromRow + index], this.fromRow + index);\n        }\n        break;\n      default:\n      // default\n    }\n  }\n\n  /**\n   * Sets column index of the dragged column and initial clientX of column\n   */\n  _handleStartColumnDrag(index: number, event: MouseEvent): void {\n    this._columnClientX = event.clientX;\n    this._resizingColumn = index;\n  }\n\n  /**\n   * Calculates new width depending on new clientX of dragger column\n   */\n  _handleColumnDrag(event: MouseEvent | DragEvent): void {\n    // check if there was been a separator clicked for resize\n    if (this._resizingColumn !== undefined && event.clientX > 0) {\n      const xPosition: number = event.clientX;\n      // checks if the separator is being moved to try and resize the column, else dont do anything\n      if (xPosition > 0 && this._columnClientX > 0 && xPosition - this._columnClientX !== 0) {\n        // calculate the new width depending if making the column bigger or smaller\n        let proposedManualWidth: number = this._widths[this._resizingColumn].value + (xPosition - this._columnClientX);\n        // if the proposed new width is less than the projected min width of the column, use projected min width\n        if (proposedManualWidth < this._colElements.toArray()[this._resizingColumn].projectedWidth) {\n          proposedManualWidth = this._colElements.toArray()[this._resizingColumn].projectedWidth;\n        }\n        this.columns[this._resizingColumn].width = proposedManualWidth;\n        // update new x position for the resized column\n        this._onColumnResize.next(xPosition);\n      }\n    }\n  }\n\n  /**\n   * Ends dragged flags\n   */\n  _handleEndColumnDrag(): void {\n    this._columnClientX = undefined;\n    this._resizingColumn = undefined;\n  }\n\n  /**\n   * Method to prevent the default events\n   */\n  blockEvent(event: Event): void {\n    event.preventDefault();\n  }\n\n  private _getNestedValue(name: string, value: any): string {\n    if (!(value instanceof Object) || !name) {\n      return value;\n    }\n    if (name.indexOf('.') > -1) {\n      const splitName: string[] = name.split(/\\.(.+)/, 2);\n      return this._getNestedValue(splitName[1], value[splitName[0]]);\n    } else {\n      return value[name];\n    }\n  }\n\n  /**\n   * Does the actual Row Selection\n   */\n  private _doSelection(row: any, rowIndex: number): boolean {\n    const wasSelected: boolean = this.isRowSelected(row);\n    if (!wasSelected) {\n      if (!this._multiple) {\n        this.clearModel();\n      }\n      this.value.push(row);\n    } else {\n      // compare items by [compareWith] function\n      row = this.value.filter((val: any) => {\n        return this.compareWith(row, val);\n      })[0];\n      const index: number = this.value.indexOf(row);\n      if (index > -1) {\n        this.value.splice(index, 1);\n      }\n    }\n    this._calculateCheckboxState();\n    this.rowSelect.emit({ row, index: rowIndex, selected: !wasSelected });\n    this.onChange(this.value);\n    return !wasSelected;\n  }\n\n  /**\n   * Calculate all the state of all checkboxes\n   */\n  private _calculateCheckboxState(): void {\n    if (this._data) {\n      this._allSelected = typeof this._data.find((d: any) => !this.isRowSelected(d)) === 'undefined';\n      this._indeterminate = false;\n      for (const row of this._data) {\n        if (!this.isRowSelected(row)) {\n          continue;\n        }\n        this._indeterminate = true;\n        break;\n      }\n    }\n  }\n\n  /**\n   * Calculates the widths for columns and cells depending on content\n   */\n  private _calculateWidths(): void {\n    if (this._colElements && this._colElements.length) {\n      this._widths = [];\n      this._colElements.forEach((col: TdDataTableColumnComponent, index: number) => {\n        this._adjustColumnWidth(index, this._calculateWidth());\n      });\n      this._adjustColumnWidhts();\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  /**\n   * Adjusts columns after calculation to see if they need to be recalculated.\n   */\n  private _adjustColumnWidhts(): void {\n    let fixedTotalWidth: number = 0;\n    // get the number of total columns that have flexible widths (not fixed or hidden)\n    const flexibleWidths: number = this._widths.filter((width: IInternalColumnWidth, index: number) => {\n      if (this.columns[index].hidden) {\n        return false;\n      }\n      if (width.limit || width.max || width.min) {\n        fixedTotalWidth += width.value;\n      }\n      return !width.limit && !width.max && !width.min;\n    }).length;\n    // calculate how much pixes are left that could be spread across\n    // the flexible columns\n    let recalculateHostWidth: number = 0;\n    if (fixedTotalWidth < this.hostWidth) {\n      recalculateHostWidth = this.hostWidth - fixedTotalWidth;\n    }\n    // if we have flexible columns and pixels to spare on them\n    // we try and spread the pixels across them\n    if (flexibleWidths && recalculateHostWidth) {\n      const newValue: number = Math.floor(recalculateHostWidth / flexibleWidths);\n      let adjustedNumber: number = 0;\n      // adjust the column widths with the spread pixels\n      this._widths.forEach((colWidth: IInternalColumnWidth) => {\n        if (\n          (this._widths[colWidth.index].max && this._widths[colWidth.index].value > newValue) ||\n          (this._widths[colWidth.index].min && this._widths[colWidth.index].value < newValue) ||\n          !this._widths[colWidth.index].limit\n        ) {\n          this._adjustColumnWidth(colWidth.index, newValue);\n          adjustedNumber++;\n        }\n      });\n      // if there are still columns that need to be recalculated, we start over\n      const newFlexibleWidths: number = this._widths.filter((width: IInternalColumnWidth) => {\n        return !width.limit && !width.max;\n      }).length;\n      if (newFlexibleWidths !== adjustedNumber && newFlexibleWidths !== flexibleWidths) {\n        this._adjustColumnWidhts();\n      }\n    }\n  }\n\n  /**\n   * Adjusts a single column to see if it can be recalculated\n   */\n  private _adjustColumnWidth(index: number, value: number): void {\n    this._widths[index] = {\n      value,\n      index,\n      limit: false,\n      min: false,\n      max: false,\n    };\n    // flag to see if we need to skip the min width projection\n    // depending if a width or min width has been provided\n    let skipMinWidthProjection: boolean = false;\n    if (this.columns[index]) {\n      // if the provided width has min/max, then we check to see if we need to set it\n      if (typeof this.columns[index].width === 'object') {\n        const widthOpts: ITdDataTableColumnWidth = <ITdDataTableColumnWidth>this.columns[index].width;\n        // if the column width is less than the configured min, we override it\n        skipMinWidthProjection = widthOpts && !!widthOpts.min;\n        if (widthOpts && widthOpts.min >= this._widths[index].value) {\n          this._widths[index].value = widthOpts.min;\n          this._widths[index].min = true;\n          // if the column width is more than the configured max, we override it\n        } else if (widthOpts && widthOpts.max <= this._widths[index].value) {\n          this._widths[index].value = widthOpts.max;\n          this._widths[index].max = true;\n        }\n        // if it has a fixed width, then we just set it\n      } else if (typeof this.columns[index].width === 'number') {\n        this._widths[index].value = <number>this.columns[index].width;\n        skipMinWidthProjection = this._widths[index].limit = true;\n      }\n    }\n    // if there wasn't any width or min width provided, we set a min to what the column width min should be\n    if (!skipMinWidthProjection && this._widths[index].value < this._colElements.toArray()[index].projectedWidth) {\n      this._widths[index].value = this._colElements.toArray()[index].projectedWidth;\n      this._widths[index].min = true;\n      this._widths[index].limit = false;\n    }\n  }\n\n  /**\n   * Generic method to calculate column width\n   */\n  private _calculateWidth(): number {\n    const renderedColumns: ITdDataTableColumn[] = this.columns.filter((col: ITdDataTableColumn) => !col.hidden);\n    return Math.floor(this.hostWidth / renderedColumns.length);\n  }\n\n  /**\n   * Method to calculate the rows to be rendered in the viewport\n   */\n  private _calculateVirtualRows(): void {\n    let scrolledRows: number = 0;\n    if (this._data) {\n      this._totalHeight = 0;\n      let rowHeightSum: number = 0;\n      // loop through all rows to see if we have their height cached\n      // and sum them all to calculate the total height\n      this._data.forEach((d: any, i: number) => {\n        // iterate through all rows at first and assume all\n        // rows are the same height as the first one\n        if (!this._rowHeightCache[i]) {\n          this._rowHeightCache[i] = this._rowHeightCache[0] || TD_VIRTUAL_DEFAULT_ROW_HEIGHT;\n        }\n        rowHeightSum += this._rowHeightCache[i];\n        // check how many rows have been scrolled\n        if (this._scrollVerticalOffset - rowHeightSum > 0) {\n          scrolledRows++;\n        }\n      });\n      this._totalHeight = rowHeightSum;\n      // set the initial row to be rendered taking into account the row offset\n      const fromRow: number = scrolledRows - TD_VIRTUAL_OFFSET;\n      this._fromRow = fromRow > 0 ? fromRow : 0;\n\n      let hostHeight: number = this._hostHeight;\n      let index: number = 0;\n      // calculate how many rows can fit in the viewport\n      while (hostHeight > 0) {\n        hostHeight -= this._rowHeightCache[this.fromRow + index];\n        index++;\n      }\n      // set the last row to be rendered taking into account the row offset\n      const range: number = index - 1 + TD_VIRTUAL_OFFSET * 2;\n      let toRow: number = range + this.fromRow;\n      // if last row is greater than the total length, then we use the total length\n      if (isFinite(toRow) && toRow > this._data.length) {\n        toRow = this._data.length;\n      } else if (!isFinite(toRow)) {\n        toRow = TD_VIRTUAL_OFFSET;\n      }\n      this._toRow = toRow;\n    } else {\n      this._totalHeight = 0;\n      this._fromRow = 0;\n      this._toRow = 0;\n    }\n\n    let offset: number = 0;\n    // calculate the proper offset depending on how many rows have been scrolled\n    if (scrolledRows > TD_VIRTUAL_OFFSET) {\n      for (let index: number = 0; index < this.fromRow; index++) {\n        offset += this._rowHeightCache[index];\n      }\n    }\n\n    this._offsetTransform = this._domSanitizer.bypassSecurityTrustStyle(\n      'translateY(' + (offset - this.totalHeight) + 'px)',\n    );\n    if (this._data) {\n      this._virtualData = this.data.slice(this.fromRow, this.toRow);\n    }\n    // mark for check at the end of the queue so we are sure\n    // that the changes will be marked\n    Promise.resolve().then(() => {\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n}\n"]}