@aurelia-mdc-web/all 9.3.1-au2 → 9.3.3-au2

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 (621) hide show
  1. package/dist/alert/alert-configuration.js +15 -0
  2. package/dist/alert/alert-configuration.js.map +1 -0
  3. package/dist/alert/alert-modal/alert-modal.html +27 -0
  4. package/dist/alert/alert-modal/alert-modal.js +30 -0
  5. package/dist/alert/alert-modal/alert-modal.js.map +1 -0
  6. package/dist/alert/alert-modal/i-alert-modal-payload.js +14 -0
  7. package/dist/alert/alert-modal/i-alert-modal-payload.js.map +1 -0
  8. package/dist/alert/alert-service.js +106 -0
  9. package/dist/alert/alert-service.js.map +1 -0
  10. package/dist/alert/decorators/confirm-action.js +17 -0
  11. package/dist/alert/decorators/confirm-action.js.map +1 -0
  12. package/dist/alert/decorators/using-progress.js +27 -0
  13. package/dist/alert/decorators/using-progress.js.map +1 -0
  14. package/dist/alert/exceptions-tracker.js +8 -0
  15. package/dist/alert/exceptions-tracker.js.map +1 -0
  16. package/dist/alert/global-progress/global-progress.html +9 -0
  17. package/dist/alert/global-progress/global-progress.js +64 -0
  18. package/dist/alert/global-progress/global-progress.js.map +1 -0
  19. package/dist/alert/prompt-dialog/prompt-dialog.html +15 -0
  20. package/dist/alert/prompt-dialog/prompt-dialog.js +44 -0
  21. package/dist/alert/prompt-dialog/prompt-dialog.js.map +1 -0
  22. package/dist/banner/mdc-banner.html +21 -21
  23. package/dist/banner/mdc-banner.js +45 -42
  24. package/dist/banner/mdc-banner.js.map +1 -1
  25. package/dist/base/attributes/mdc-focus-trap.js +25 -22
  26. package/dist/base/attributes/mdc-focus-trap.js.map +1 -1
  27. package/dist/base/elements/i-validated-element.js +2 -1
  28. package/dist/base/elements/i-validated-element.js.map +1 -1
  29. package/dist/base/elements/mdc-promisify-reference.js +16 -13
  30. package/dist/base/elements/mdc-promisify-reference.js.map +1 -1
  31. package/dist/base/index.js +21 -9
  32. package/dist/base/index.js.map +1 -1
  33. package/dist/base/interceptors.js +12 -5
  34. package/dist/base/interceptors.js.map +1 -1
  35. package/dist/base/material-palette.js +4 -1
  36. package/dist/base/material-palette.js.map +1 -1
  37. package/dist/base/mdc-component.js +5 -1
  38. package/dist/base/mdc-component.js.map +1 -1
  39. package/dist/base/next-element.js +4 -1
  40. package/dist/base/next-element.js.map +1 -1
  41. package/dist/button/enhance-mdc-button.js +9 -6
  42. package/dist/button/enhance-mdc-button.js.map +1 -1
  43. package/dist/button/mdc-button-label.js +9 -6
  44. package/dist/button/mdc-button-label.js.map +1 -1
  45. package/dist/button/mdc-button.html +12 -12
  46. package/dist/button/mdc-button.js +30 -27
  47. package/dist/button/mdc-button.js.map +1 -1
  48. package/dist/card/mdc-card-action-buttons.js +9 -6
  49. package/dist/card/mdc-card-action-buttons.js.map +1 -1
  50. package/dist/card/mdc-card-action-icons.js +9 -6
  51. package/dist/card/mdc-card-action-icons.js.map +1 -1
  52. package/dist/card/mdc-card-actions/mdc-card-actions.html +3 -3
  53. package/dist/card/mdc-card-actions/mdc-card-actions.js +15 -12
  54. package/dist/card/mdc-card-actions/mdc-card-actions.js.map +1 -1
  55. package/dist/card/mdc-card-media/mdc-card-media.html +5 -5
  56. package/dist/card/mdc-card-media/mdc-card-media.js +18 -15
  57. package/dist/card/mdc-card-media/mdc-card-media.js.map +1 -1
  58. package/dist/card/mdc-card-primary-action.html +5 -5
  59. package/dist/card/mdc-card-primary-action.js +15 -12
  60. package/dist/card/mdc-card-primary-action.js.map +1 -1
  61. package/dist/card/mdc-card.html +3 -3
  62. package/dist/card/mdc-card.js +15 -12
  63. package/dist/card/mdc-card.js.map +1 -1
  64. package/dist/checkbox/mdc-checkbox.html +12 -12
  65. package/dist/checkbox/mdc-checkbox.js +38 -35
  66. package/dist/checkbox/mdc-checkbox.js.map +1 -1
  67. package/dist/chips/mdc-chip/mdc-chip.html +24 -24
  68. package/dist/chips/mdc-chip/mdc-chip.js +37 -34
  69. package/dist/chips/mdc-chip/mdc-chip.js.map +1 -1
  70. package/dist/chips/mdc-chip-action/enhance-mdc-chip-action.js +9 -6
  71. package/dist/chips/mdc-chip-action/enhance-mdc-chip-action.js.map +1 -1
  72. package/dist/chips/mdc-chip-action/mdc-chip-action.html +25 -25
  73. package/dist/chips/mdc-chip-action/mdc-chip-action.js +40 -37
  74. package/dist/chips/mdc-chip-action/mdc-chip-action.js.map +1 -1
  75. package/dist/chips/mdc-chip-set/mdc-chip-set.html +10 -10
  76. package/dist/chips/mdc-chip-set/mdc-chip-set.js +27 -24
  77. package/dist/chips/mdc-chip-set/mdc-chip-set.js.map +1 -1
  78. package/dist/circular-progress/mdc-circular-progress.html +38 -38
  79. package/dist/circular-progress/mdc-circular-progress.js +25 -22
  80. package/dist/circular-progress/mdc-circular-progress.js.map +1 -1
  81. package/dist/data-table/mdc-data-table-row.js +13 -10
  82. package/dist/data-table/mdc-data-table-row.js.map +1 -1
  83. package/dist/data-table/mdc-data-table.html +50 -49
  84. package/dist/data-table/mdc-data-table.js +183 -91
  85. package/dist/data-table/mdc-data-table.js.map +1 -1
  86. package/dist/dialog/mdc-dialog-actions.js +13 -10
  87. package/dist/dialog/mdc-dialog-actions.js.map +1 -1
  88. package/dist/dialog/mdc-dialog-content.js +9 -6
  89. package/dist/dialog/mdc-dialog-content.js.map +1 -1
  90. package/dist/dialog/mdc-dialog-service.js +20 -13
  91. package/dist/dialog/mdc-dialog-service.js.map +1 -1
  92. package/dist/dialog/mdc-dialog-title.js +9 -6
  93. package/dist/dialog/mdc-dialog-title.js.map +1 -1
  94. package/dist/dialog/mdc-dialog.html +14 -14
  95. package/dist/dialog/mdc-dialog.js +49 -46
  96. package/dist/dialog/mdc-dialog.js.map +1 -1
  97. package/dist/drawer/mdc-drawer-app-content.js +9 -6
  98. package/dist/drawer/mdc-drawer-app-content.js.map +1 -1
  99. package/dist/drawer/mdc-drawer-content.js +9 -6
  100. package/dist/drawer/mdc-drawer-content.js.map +1 -1
  101. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.html +5 -5
  102. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.js +17 -14
  103. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.js.map +1 -1
  104. package/dist/drawer/mdc-drawer.html +6 -6
  105. package/dist/drawer/mdc-drawer.js +24 -21
  106. package/dist/drawer/mdc-drawer.js.map +1 -1
  107. package/dist/elevation/mdc-elevation.js +9 -6
  108. package/dist/elevation/mdc-elevation.js.map +1 -1
  109. package/dist/expandable/mdc-expandable.html +28 -28
  110. package/dist/expandable/mdc-expandable.js +20 -17
  111. package/dist/expandable/mdc-expandable.js.map +1 -1
  112. package/dist/fab/enhance-mdc-fab.js +9 -6
  113. package/dist/fab/enhance-mdc-fab.js.map +1 -1
  114. package/dist/fab/mdc-fab-icon.js +9 -6
  115. package/dist/fab/mdc-fab-icon.js.map +1 -1
  116. package/dist/fab/mdc-fab.html +13 -13
  117. package/dist/fab/mdc-fab.js +33 -30
  118. package/dist/fab/mdc-fab.js.map +1 -1
  119. package/dist/floating-label/mdc-floating-label.html +1 -1
  120. package/dist/floating-label/mdc-floating-label.js +16 -13
  121. package/dist/floating-label/mdc-floating-label.js.map +1 -1
  122. package/dist/form-field/mdc-form-field.html +6 -6
  123. package/dist/form-field/mdc-form-field.js +27 -24
  124. package/dist/form-field/mdc-form-field.js.map +1 -1
  125. package/dist/icon/mdc-icon.html +3 -3
  126. package/dist/icon/mdc-icon.js +10 -7
  127. package/dist/icon/mdc-icon.js.map +1 -1
  128. package/dist/icon-button/enhance-mdc-icon-button.js +9 -6
  129. package/dist/icon-button/enhance-mdc-icon-button.js.map +1 -1
  130. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.html +4 -4
  131. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js +18 -15
  132. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js.map +1 -1
  133. package/dist/icon-button/mdc-icon-button.html +11 -11
  134. package/dist/icon-button/mdc-icon-button.js +28 -25
  135. package/dist/icon-button/mdc-icon-button.js.map +1 -1
  136. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.html +9 -9
  137. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.js +22 -19
  138. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.js.map +1 -1
  139. package/dist/image-list/mdc-image-list.html +7 -7
  140. package/dist/image-list/mdc-image-list.js +35 -32
  141. package/dist/image-list/mdc-image-list.js.map +1 -1
  142. package/dist/index.js +297 -139
  143. package/dist/index.js.map +1 -1
  144. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.html +12 -12
  145. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js +36 -33
  146. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js.map +1 -1
  147. package/dist/layout-grid/mdc-layout-grid-inner.js +9 -6
  148. package/dist/layout-grid/mdc-layout-grid-inner.js.map +1 -1
  149. package/dist/layout-grid/mdc-layout-grid.html +8 -8
  150. package/dist/layout-grid/mdc-layout-grid.js +33 -30
  151. package/dist/layout-grid/mdc-layout-grid.js.map +1 -1
  152. package/dist/line-ripple/mdc-line-ripple.js +13 -10
  153. package/dist/line-ripple/mdc-line-ripple.js.map +1 -1
  154. package/dist/linear-progress/mdc-linear-progress.html +12 -12
  155. package/dist/linear-progress/mdc-linear-progress.js +26 -23
  156. package/dist/linear-progress/mdc-linear-progress.js.map +1 -1
  157. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.html +4 -4
  158. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js +18 -15
  159. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js.map +1 -1
  160. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-group.js +17 -14
  161. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-group.js.map +1 -1
  162. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js +9 -6
  163. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js.map +1 -1
  164. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js +9 -6
  165. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js.map +1 -1
  166. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js +9 -6
  167. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js.map +1 -1
  168. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.html +8 -8
  169. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js +28 -25
  170. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js.map +1 -1
  171. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js +9 -6
  172. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js.map +1 -1
  173. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js +9 -6
  174. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js.map +1 -1
  175. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.html +15 -15
  176. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.js +78 -75
  177. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.js.map +1 -1
  178. package/dist/list/mdc-list-divider/mdc-list-divider.html +7 -7
  179. package/dist/list/mdc-list-divider/mdc-list-divider.js +21 -18
  180. package/dist/list/mdc-list-divider/mdc-list-divider.js.map +1 -1
  181. package/dist/list/mdc-list-group.js +17 -14
  182. package/dist/list/mdc-list-group.js.map +1 -1
  183. package/dist/list/mdc-list-item/enhance-mdc-list-item.js +9 -6
  184. package/dist/list/mdc-list-item/enhance-mdc-list-item.js.map +1 -1
  185. package/dist/list/mdc-list-item/mdc-list-item-leading.js +9 -6
  186. package/dist/list/mdc-list-item/mdc-list-item-leading.js.map +1 -1
  187. package/dist/list/mdc-list-item/mdc-list-item-trailing.js +9 -6
  188. package/dist/list/mdc-list-item/mdc-list-item-trailing.js.map +1 -1
  189. package/dist/list/mdc-list-item/mdc-list-item.html +13 -13
  190. package/dist/list/mdc-list-item/mdc-list-item.js +40 -37
  191. package/dist/list/mdc-list-item/mdc-list-item.js.map +1 -1
  192. package/dist/list/mdc-list-item-overline-text.js +9 -6
  193. package/dist/list/mdc-list-item-overline-text.js.map +1 -1
  194. package/dist/list/mdc-list-item-primary-text.js +9 -6
  195. package/dist/list/mdc-list-item-primary-text.js.map +1 -1
  196. package/dist/list/mdc-list-item-secondary-text.js +9 -6
  197. package/dist/list/mdc-list-item-secondary-text.js.map +1 -1
  198. package/dist/list/mdc-list.html +5 -5
  199. package/dist/list/mdc-list.js +58 -55
  200. package/dist/list/mdc-list.js.map +1 -1
  201. package/dist/lookup/discardable-promise.js +5 -1
  202. package/dist/lookup/discardable-promise.js.map +1 -1
  203. package/dist/lookup/mdc-lookup-configuration.js +5 -1
  204. package/dist/lookup/mdc-lookup-configuration.js.map +1 -1
  205. package/dist/lookup/mdc-lookup.html +27 -27
  206. package/dist/lookup/mdc-lookup.js +74 -71
  207. package/dist/lookup/mdc-lookup.js.map +1 -1
  208. package/dist/mdc-configuration.js +15 -9
  209. package/dist/mdc-configuration.js.map +1 -1
  210. package/dist/menu/mdc-menu-selection-group-icon.js +9 -6
  211. package/dist/menu/mdc-menu-selection-group-icon.js.map +1 -1
  212. package/dist/menu/mdc-menu-selection-group.js +9 -6
  213. package/dist/menu/mdc-menu-selection-group.js.map +1 -1
  214. package/dist/menu/mdc-menu.html +6 -6
  215. package/dist/menu/mdc-menu.js +71 -68
  216. package/dist/menu/mdc-menu.js.map +1 -1
  217. package/dist/menu-surface/mdc-menu-surface-anchor.js +11 -8
  218. package/dist/menu-surface/mdc-menu-surface-anchor.js.map +1 -1
  219. package/dist/menu-surface/mdc-menu-surface.js +61 -58
  220. package/dist/menu-surface/mdc-menu-surface.js.map +1 -1
  221. package/dist/notched-outline/mdc-notched-outline.html +7 -7
  222. package/dist/notched-outline/mdc-notched-outline.js +20 -17
  223. package/dist/notched-outline/mdc-notched-outline.js.map +1 -1
  224. package/dist/radio/mdc-radio.html +9 -9
  225. package/dist/radio/mdc-radio.js +27 -24
  226. package/dist/radio/mdc-radio.js.map +1 -1
  227. package/dist/ripple/mdc-ripple.js +51 -48
  228. package/dist/ripple/mdc-ripple.js.map +1 -1
  229. package/dist/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js +9 -6
  230. package/dist/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js.map +1 -1
  231. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.html +11 -11
  232. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.js +27 -24
  233. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.js.map +1 -1
  234. package/dist/segmented-button/mdc-segmented-button.html +3 -3
  235. package/dist/segmented-button/mdc-segmented-button.js +24 -21
  236. package/dist/segmented-button/mdc-segmented-button.js.map +1 -1
  237. package/dist/select/mdc-default-select-configuration.js +5 -1
  238. package/dist/select/mdc-default-select-configuration.js.map +1 -1
  239. package/dist/select/mdc-select-adapter-aurelia.js +2 -1
  240. package/dist/select/mdc-select-adapter-aurelia.js.map +1 -1
  241. package/dist/select/mdc-select-foundation-aurelia.js +47 -43
  242. package/dist/select/mdc-select-foundation-aurelia.js.map +1 -1
  243. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.html +7 -7
  244. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.js +27 -24
  245. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.js.map +1 -1
  246. package/dist/select/mdc-select-icon.js +16 -13
  247. package/dist/select/mdc-select-icon.js.map +1 -1
  248. package/dist/select/mdc-select-value-observer.js +16 -12
  249. package/dist/select/mdc-select-value-observer.js.map +1 -1
  250. package/dist/select/mdc-select.html +38 -38
  251. package/dist/select/mdc-select.js +71 -68
  252. package/dist/select/mdc-select.js.map +1 -1
  253. package/dist/slider/mdc-slider-foundation-aurelia.js +6 -2
  254. package/dist/slider/mdc-slider-foundation-aurelia.js.map +1 -1
  255. package/dist/slider/mdc-slider.html +36 -36
  256. package/dist/slider/mdc-slider.js +79 -76
  257. package/dist/slider/mdc-slider.js.map +1 -1
  258. package/dist/snackbar/mdc-snackbar-service.js +8 -4
  259. package/dist/snackbar/mdc-snackbar-service.js.map +1 -1
  260. package/dist/snackbar/mdc-snackbar.html +14 -14
  261. package/dist/snackbar/mdc-snackbar.js +55 -52
  262. package/dist/snackbar/mdc-snackbar.js.map +1 -1
  263. package/dist/switch/enhance-mdc-switch.js +9 -6
  264. package/dist/switch/enhance-mdc-switch.js.map +1 -1
  265. package/dist/switch/mdc-switch.html +21 -21
  266. package/dist/switch/mdc-switch.js +16 -13
  267. package/dist/switch/mdc-switch.js.map +1 -1
  268. package/dist/tab-bar/indicator/mdc-tab-indicator.html +9 -9
  269. package/dist/tab-bar/indicator/mdc-tab-indicator.js +26 -23
  270. package/dist/tab-bar/indicator/mdc-tab-indicator.js.map +1 -1
  271. package/dist/tab-bar/mdc-tab-bar.html +6 -6
  272. package/dist/tab-bar/mdc-tab-bar.js +29 -26
  273. package/dist/tab-bar/mdc-tab-bar.js.map +1 -1
  274. package/dist/tab-bar/scroller/mdc-tab-scroller.html +11 -11
  275. package/dist/tab-bar/scroller/mdc-tab-scroller.js +25 -22
  276. package/dist/tab-bar/scroller/mdc-tab-scroller.js.map +1 -1
  277. package/dist/tab-bar/tab/mdc-tab.html +20 -20
  278. package/dist/tab-bar/tab/mdc-tab.js +44 -41
  279. package/dist/tab-bar/tab/mdc-tab.js.map +1 -1
  280. package/dist/text-field/enhance-mdc-text-field.js +9 -6
  281. package/dist/text-field/enhance-mdc-text-field.js.map +1 -1
  282. package/dist/text-field/mdc-default-text-field-configuration.js +5 -1
  283. package/dist/text-field/mdc-default-text-field-configuration.js.map +1 -1
  284. package/dist/text-field/mdc-inputmask.js +76 -0
  285. package/dist/text-field/mdc-inputmask.js.map +1 -0
  286. package/dist/text-field/mdc-text-field-character-counter.js +13 -10
  287. package/dist/text-field/mdc-text-field-character-counter.js.map +1 -1
  288. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.html +7 -7
  289. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js +14 -11
  290. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js.map +1 -1
  291. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.html +6 -6
  292. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js +22 -19
  293. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js.map +1 -1
  294. package/dist/text-field/mdc-text-field-icon.js +22 -19
  295. package/dist/text-field/mdc-text-field-icon.js.map +1 -1
  296. package/dist/text-field/mdc-text-field.html +29 -29
  297. package/dist/text-field/mdc-text-field.js +116 -113
  298. package/dist/text-field/mdc-text-field.js.map +1 -1
  299. package/dist/tooltip/mdc-default-tooltip-configuration.js +5 -1
  300. package/dist/tooltip/mdc-default-tooltip-configuration.js.map +1 -1
  301. package/dist/tooltip/mdc-tooltip-attribute.js +39 -36
  302. package/dist/tooltip/mdc-tooltip-attribute.js.map +1 -1
  303. package/dist/tooltip/mdc-tooltip.html +7 -7
  304. package/dist/tooltip/mdc-tooltip.js +66 -63
  305. package/dist/tooltip/mdc-tooltip.js.map +1 -1
  306. package/dist/top-app-bar/enhance-top-app-bar-actions.js +9 -6
  307. package/dist/top-app-bar/enhance-top-app-bar-actions.js.map +1 -1
  308. package/dist/top-app-bar/mdc-top-app-bar-action-item.js +9 -6
  309. package/dist/top-app-bar/mdc-top-app-bar-action-item.js.map +1 -1
  310. package/dist/top-app-bar/mdc-top-app-bar-fixed-adjust.js +9 -6
  311. package/dist/top-app-bar/mdc-top-app-bar-fixed-adjust.js.map +1 -1
  312. package/dist/top-app-bar/mdc-top-app-bar-nav-icon.js +9 -6
  313. package/dist/top-app-bar/mdc-top-app-bar-nav-icon.js.map +1 -1
  314. package/dist/top-app-bar/mdc-top-app-bar-row.js +9 -6
  315. package/dist/top-app-bar/mdc-top-app-bar-row.js.map +1 -1
  316. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.html +3 -3
  317. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js +15 -12
  318. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js.map +1 -1
  319. package/dist/top-app-bar/mdc-top-app-bar-title.js +9 -6
  320. package/dist/top-app-bar/mdc-top-app-bar-title.js.map +1 -1
  321. package/dist/top-app-bar/mdc-top-app-bar.html +9 -9
  322. package/dist/top-app-bar/mdc-top-app-bar.js +43 -40
  323. package/dist/top-app-bar/mdc-top-app-bar.js.map +1 -1
  324. package/dist/tree-view/i-tree-node.js +2 -1
  325. package/dist/tree-view/i-tree-node.js.map +1 -1
  326. package/dist/tree-view/mdc-tree-node-meta.js +9 -6
  327. package/dist/tree-view/mdc-tree-node-meta.js.map +1 -1
  328. package/dist/tree-view/mdc-tree-node.js +9 -6
  329. package/dist/tree-view/mdc-tree-node.js.map +1 -1
  330. package/dist/tree-view/mdc-tree-view.js +29 -25
  331. package/dist/tree-view/mdc-tree-view.js.map +1 -1
  332. package/dist/tree-view/node-filter.js +9 -6
  333. package/dist/tree-view/node-filter.js.map +1 -1
  334. package/dist/types/alert/alert-configuration.d.ts +8 -0
  335. package/dist/types/alert/alert-modal/alert-modal.d.ts +6 -0
  336. package/dist/types/alert/alert-modal/i-alert-modal-payload.d.ts +9 -0
  337. package/dist/types/alert/alert-service.d.ts +27 -0
  338. package/dist/types/alert/decorators/confirm-action.d.ts +3 -0
  339. package/dist/types/alert/decorators/using-progress.d.ts +6 -0
  340. package/dist/types/alert/exceptions-tracker.d.ts +3 -0
  341. package/dist/types/alert/global-progress/global-progress.d.ts +11 -0
  342. package/dist/types/alert/prompt-dialog/prompt-dialog.d.ts +21 -0
  343. package/dist/types/data-table/mdc-data-table.d.ts +16 -4
  344. package/dist/types/index.d.ts +11 -1
  345. package/dist/types/lookup/mdc-lookup.d.ts +3 -3
  346. package/dist/types/mdc-configuration.d.ts +2 -0
  347. package/dist/types/select/mdc-select.d.ts +3 -3
  348. package/dist/types/text-field/mdc-inputmask.d.ts +11 -0
  349. package/dist/types/text-field/mdc-text-field.d.ts +3 -3
  350. package/dist/types/tooltip/mdc-tooltip.d.ts +3 -3
  351. package/dist/types/validation/validate.d.ts +10 -0
  352. package/dist/typography/mdc-typography.js +60 -57
  353. package/dist/typography/mdc-typography.js.map +1 -1
  354. package/dist/validation/mdc-validation-controller-factory.js +10 -6
  355. package/dist/validation/mdc-validation-controller-factory.js.map +1 -1
  356. package/dist/validation/mdc-validation-result-presenter.js +5 -1
  357. package/dist/validation/mdc-validation-result-presenter.js.map +1 -1
  358. package/dist/validation/validate.js +27 -0
  359. package/dist/validation/validate.js.map +1 -0
  360. package/package.json +4 -2
  361. package/src/alert/alert-configuration.ts +11 -0
  362. package/src/alert/alert-modal/alert-modal.html +27 -0
  363. package/src/alert/alert-modal/alert-modal.scss +10 -0
  364. package/src/alert/alert-modal/alert-modal.ts +13 -0
  365. package/src/alert/alert-modal/i-alert-modal-payload.ts +9 -0
  366. package/src/alert/alert-service.ts +113 -0
  367. package/src/alert/decorators/confirm-action.ts +18 -0
  368. package/src/alert/decorators/using-progress.ts +30 -0
  369. package/src/alert/exceptions-tracker.ts +3 -0
  370. package/src/alert/global-progress/global-progress.html +9 -0
  371. package/src/alert/global-progress/global-progress.scss +38 -0
  372. package/src/alert/global-progress/global-progress.ts +27 -0
  373. package/src/alert/prompt-dialog/prompt-dialog.html +15 -0
  374. package/src/alert/prompt-dialog/prompt-dialog.ts +35 -0
  375. package/src/banner/mdc-banner.html +21 -21
  376. package/src/banner/mdc-banner.ts +116 -116
  377. package/src/base/attributes/mdc-focus-trap.ts +42 -42
  378. package/src/base/elements/i-validated-element.ts +12 -12
  379. package/src/base/elements/mdc-promisify-reference.ts +21 -21
  380. package/src/base/interceptors.ts +25 -25
  381. package/src/base/material-palette.md +7 -7
  382. package/src/base/material-palette.ts +22 -22
  383. package/src/base/mdc-component.ts +69 -69
  384. package/src/base/next-element.ts +39 -39
  385. package/src/button/enhance-mdc-button.ts +8 -8
  386. package/src/button/mdc-button-label.ts +15 -15
  387. package/src/button/mdc-button.html +12 -12
  388. package/src/button/mdc-button.ts +62 -62
  389. package/src/card/mdc-card-action-buttons.ts +19 -19
  390. package/src/card/mdc-card-action-icons.ts +19 -19
  391. package/src/card/mdc-card-actions/mdc-card-actions.html +3 -3
  392. package/src/card/mdc-card-actions/mdc-card-actions.ts +15 -15
  393. package/src/card/mdc-card-media/mdc-card-media.html +5 -5
  394. package/src/card/mdc-card-media/mdc-card-media.ts +21 -21
  395. package/src/card/mdc-card-primary-action.html +5 -5
  396. package/src/card/mdc-card-primary-action.ts +16 -16
  397. package/src/card/mdc-card.html +3 -3
  398. package/src/card/mdc-card.ts +16 -16
  399. package/src/checkbox/mdc-checkbox.html +12 -12
  400. package/src/checkbox/mdc-checkbox.ts +217 -217
  401. package/src/chips/mdc-chip/mdc-chip.html +24 -24
  402. package/src/chips/mdc-chip-action/enhance-mdc-chip-action.ts +8 -8
  403. package/src/chips/mdc-chip-action/mdc-chip-action.html +25 -25
  404. package/src/chips/mdc-chip-action/mdc-chip-action.ts +143 -143
  405. package/src/chips/mdc-chip-set/mdc-chip-set.html +10 -10
  406. package/src/chips/mdc-chip-set/mdc-chip-set.ts +117 -117
  407. package/src/circular-progress/mdc-circular-progress.html +38 -38
  408. package/src/circular-progress/mdc-circular-progress.ts +91 -91
  409. package/src/circular-progress/styles/_index.scss +1 -1
  410. package/src/circular-progress/styles/mdc-circular-progress.import.scss +1 -1
  411. package/src/circular-progress/styles/mdc-circular-progress.scss +14 -14
  412. package/src/data-table/mdc-data-table-row.ts +24 -24
  413. package/src/data-table/mdc-data-table.html +50 -49
  414. package/src/data-table/mdc-data-table.ts +111 -13
  415. package/src/data-table/styles/_index.scss +1 -0
  416. package/src/data-table/styles/mdc-data-table.import.scss +1 -0
  417. package/src/data-table/styles/mdc-data-table.scss +64 -0
  418. package/src/dialog/mdc-dialog-actions.ts +23 -23
  419. package/src/dialog/mdc-dialog-content.ts +11 -11
  420. package/src/dialog/mdc-dialog-service.ts +83 -80
  421. package/src/dialog/mdc-dialog-title.ts +8 -8
  422. package/src/dialog/mdc-dialog.html +14 -14
  423. package/src/dialog/mdc-dialog.ts +224 -224
  424. package/src/drawer/mdc-drawer-app-content.ts +11 -11
  425. package/src/drawer/mdc-drawer-content.ts +11 -11
  426. package/src/drawer/mdc-drawer-header/mdc-drawer-header.html +5 -5
  427. package/src/drawer/mdc-drawer-header/mdc-drawer-header.ts +18 -18
  428. package/src/drawer/mdc-drawer.html +6 -6
  429. package/src/drawer/mdc-drawer.ts +125 -125
  430. package/src/elevation/mdc-elevation.ts +23 -23
  431. package/src/expandable/mdc-expandable.html +28 -28
  432. package/src/expandable/styles/_icon-variables.scss +3 -3
  433. package/src/expandable/styles/_index.scss +1 -1
  434. package/src/expandable/styles/_mixins.scss +287 -287
  435. package/src/expandable/styles/_variables.scss +17 -17
  436. package/src/expandable/styles/mdc-expandable.import.scss +1 -1
  437. package/src/expandable/styles/mdc-expandable.scss +3 -3
  438. package/src/fab/enhance-mdc-fab.ts +8 -8
  439. package/src/fab/mdc-fab-icon.ts +15 -15
  440. package/src/fab/mdc-fab.html +13 -13
  441. package/src/fab/mdc-fab.ts +50 -50
  442. package/src/floating-label/mdc-floating-label.html +1 -1
  443. package/src/floating-label/mdc-floating-label.ts +44 -44
  444. package/src/form-field/mdc-form-field.html +6 -6
  445. package/src/icon/mdc-icon.html +3 -3
  446. package/src/icon/mdc-icon.ts +11 -11
  447. package/src/icon-button/enhance-mdc-icon-button.ts +8 -8
  448. package/src/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.html +4 -4
  449. package/src/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.ts +29 -29
  450. package/src/icon-button/mdc-icon-button.html +11 -11
  451. package/src/icon-button/mdc-icon-button.ts +69 -69
  452. package/src/image-list/mdc-image-list-item/mdc-image-list-item.html +9 -9
  453. package/src/image-list/mdc-image-list-item/mdc-image-list-item.ts +31 -31
  454. package/src/image-list/mdc-image-list.html +7 -7
  455. package/src/image-list/mdc-image-list.ts +73 -73
  456. package/src/image-list/styles/_index.scss +1 -1
  457. package/src/image-list/styles/mdc-image-list.import.scss +1 -1
  458. package/src/image-list/styles/mdc-image-list.scss +7 -7
  459. package/src/index.ts +17 -3
  460. package/src/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.html +12 -12
  461. package/src/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.ts +49 -49
  462. package/src/layout-grid/mdc-layout-grid-inner.ts +8 -8
  463. package/src/layout-grid/mdc-layout-grid.html +8 -8
  464. package/src/layout-grid/mdc-layout-grid.ts +67 -67
  465. package/src/layout-grid/styles/_index.scss +1 -1
  466. package/src/layout-grid/styles/mdc-layout-grid.import.scss +1 -1
  467. package/src/layout-grid/styles/mdc-layout-grid.scss +11 -11
  468. package/src/line-ripple/mdc-line-ripple.ts +41 -41
  469. package/src/linear-progress/mdc-linear-progress.html +12 -12
  470. package/src/linear-progress/mdc-linear-progress.ts +103 -103
  471. package/src/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.html +4 -4
  472. package/src/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.ts +18 -18
  473. package/src/list/mdc-deprecated-list/mdc-deprecated-list-group.ts +27 -27
  474. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.ts +8 -8
  475. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.ts +15 -15
  476. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.ts +15 -15
  477. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.html +8 -8
  478. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.ts +11 -11
  479. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.ts +11 -11
  480. package/src/list/mdc-deprecated-list/mdc-deprecated-list.html +15 -15
  481. package/src/list/mdc-deprecated-list/mdc-deprecated-list.ts +331 -331
  482. package/src/list/mdc-list-divider/mdc-list-divider.html +7 -7
  483. package/src/list/mdc-list-divider/mdc-list-divider.ts +24 -24
  484. package/src/list/mdc-list-group.ts +27 -27
  485. package/src/list/mdc-list-item/enhance-mdc-list-item.ts +8 -8
  486. package/src/list/mdc-list-item/mdc-list-item-leading.ts +34 -34
  487. package/src/list/mdc-list-item/mdc-list-item-trailing.ts +36 -36
  488. package/src/list/mdc-list-item/mdc-list-item.html +13 -13
  489. package/src/list/mdc-list-item-overline-text.ts +8 -8
  490. package/src/list/mdc-list-item-primary-text.ts +11 -11
  491. package/src/list/mdc-list-item-secondary-text.ts +11 -11
  492. package/src/list/mdc-list.html +5 -5
  493. package/src/list/mdc-list.ts +300 -300
  494. package/src/lookup/discardable-promise.ts +24 -24
  495. package/src/lookup/mdc-lookup-configuration.ts +11 -11
  496. package/src/lookup/mdc-lookup.html +27 -27
  497. package/src/lookup/mdc-lookup.ts +5 -5
  498. package/src/mdc-configuration.ts +2 -0
  499. package/src/menu/mdc-menu-selection-group-icon.ts +11 -11
  500. package/src/menu/mdc-menu-selection-group.ts +4 -4
  501. package/src/menu/mdc-menu.html +6 -6
  502. package/src/menu-surface/mdc-menu-surface-anchor.ts +12 -12
  503. package/src/menu-surface/mdc-menu-surface.ts +275 -275
  504. package/src/notched-outline/mdc-notched-outline.html +7 -7
  505. package/src/notched-outline/mdc-notched-outline.ts +60 -60
  506. package/src/radio/mdc-radio.html +9 -9
  507. package/src/radio/mdc-radio.ts +162 -162
  508. package/src/resource.d.ts +22 -22
  509. package/src/ripple/mdc-ripple.ts +114 -114
  510. package/src/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.ts +8 -8
  511. package/src/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.html +11 -11
  512. package/src/segmented-button/mdc-segmented-button.html +3 -3
  513. package/src/segmented-button/mdc-segmented-button.ts +89 -89
  514. package/src/select/mdc-default-select-configuration.ts +3 -3
  515. package/src/select/mdc-select-adapter-aurelia.ts +213 -213
  516. package/src/select/mdc-select-foundation-aurelia.ts +484 -484
  517. package/src/select/mdc-select-helper-text/mdc-select-helper-text.html +7 -7
  518. package/src/select/mdc-select-helper-text/mdc-select-helper-text.ts +55 -55
  519. package/src/select/mdc-select-icon.ts +41 -41
  520. package/src/select/mdc-select-value-observer.ts +347 -346
  521. package/src/select/mdc-select.html +38 -38
  522. package/src/select/mdc-select.ts +480 -480
  523. package/src/slider/mdc-slider-foundation-aurelia.ts +13 -13
  524. package/src/slider/mdc-slider.html +36 -36
  525. package/src/slider/mdc-slider.ts +409 -409
  526. package/src/slider/styles/_index.scss +1 -1
  527. package/src/slider/styles/mdc-slider.import.scss +1 -1
  528. package/src/slider/styles/mdc-slider.scss +8 -8
  529. package/src/snackbar/mdc-snackbar-service.ts +48 -48
  530. package/src/snackbar/mdc-snackbar.html +14 -14
  531. package/src/snackbar/mdc-snackbar.ts +109 -109
  532. package/src/switch/enhance-mdc-switch.ts +8 -8
  533. package/src/switch/mdc-switch.html +21 -21
  534. package/src/switch/mdc-switch.ts +86 -86
  535. package/src/tab-bar/indicator/mdc-tab-indicator.html +9 -9
  536. package/src/tab-bar/indicator/mdc-tab-indicator.ts +51 -51
  537. package/src/tab-bar/mdc-tab-bar.html +6 -6
  538. package/src/tab-bar/mdc-tab-bar.ts +119 -119
  539. package/src/tab-bar/scroller/mdc-tab-scroller.html +11 -11
  540. package/src/tab-bar/scroller/mdc-tab-scroller.ts +85 -85
  541. package/src/tab-bar/tab/mdc-tab.html +20 -20
  542. package/src/tab-bar/tab/mdc-tab.ts +118 -118
  543. package/src/text-field/enhance-mdc-text-field.ts +12 -12
  544. package/src/text-field/mdc-default-text-field-configuration.ts +3 -3
  545. package/src/text-field/mdc-inputmask.ts +45 -0
  546. package/src/text-field/mdc-text-field-character-counter.ts +32 -32
  547. package/src/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.html +7 -7
  548. package/src/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.ts +37 -37
  549. package/src/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.html +6 -6
  550. package/src/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.ts +47 -47
  551. package/src/text-field/mdc-text-field-icon.ts +59 -59
  552. package/src/text-field/mdc-text-field.html +29 -29
  553. package/src/text-field/mdc-text-field.ts +535 -535
  554. package/src/tooltip/mdc-default-tooltip-configuration.ts +5 -5
  555. package/src/tooltip/mdc-tooltip-attribute.ts +118 -118
  556. package/src/tooltip/mdc-tooltip.html +7 -7
  557. package/src/tooltip/mdc-tooltip.ts +6 -6
  558. package/src/top-app-bar/enhance-top-app-bar-actions.ts +9 -9
  559. package/src/top-app-bar/mdc-top-app-bar-action-item.ts +12 -12
  560. package/src/top-app-bar/mdc-top-app-bar-fixed-adjust.ts +13 -13
  561. package/src/top-app-bar/mdc-top-app-bar-nav-icon.ts +12 -12
  562. package/src/top-app-bar/mdc-top-app-bar-row.ts +7 -7
  563. package/src/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.html +3 -3
  564. package/src/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.ts +9 -9
  565. package/src/top-app-bar/mdc-top-app-bar-title.ts +7 -7
  566. package/src/top-app-bar/mdc-top-app-bar.html +9 -9
  567. package/src/top-app-bar/mdc-top-app-bar.ts +93 -93
  568. package/src/tree-view/i-tree-node.ts +8 -8
  569. package/src/tree-view/mdc-tree-node-meta.ts +11 -11
  570. package/src/tree-view/mdc-tree-node.ts +4 -4
  571. package/src/tree-view/node-filter.ts +12 -12
  572. package/src/tree-view/styles/_index.scss +1 -1
  573. package/src/tree-view/styles/_mixins.scss +145 -145
  574. package/src/tree-view/styles/_variables.scss +8 -8
  575. package/src/tree-view/styles/mdc-tree-view.import.scss +1 -1
  576. package/src/tree-view/styles/mdc-tree-view.scss +3 -3
  577. package/src/typography/mdc-typography.ts +130 -130
  578. package/src/validation/mdc-validation-controller-factory.ts +20 -20
  579. package/src/validation/mdc-validation-result-presenter.ts +36 -36
  580. package/src/validation/validate.ts +32 -0
  581. package/styles/mdc-all.scss +53 -52
  582. package/src/banner/doc/api.json +0 -1106
  583. package/src/base/doc/api.json +0 -1408
  584. package/src/button/doc/api.json +0 -621
  585. package/src/card/doc/api.json +0 -214
  586. package/src/checkbox/doc/api.json +0 -1320
  587. package/src/chips/doc/api.json +0 -2533
  588. package/src/circular-progress/doc/api.json +0 -1085
  589. package/src/data-table/doc/api.json +0 -2064
  590. package/src/dialog/doc/api.json +0 -1667
  591. package/src/drawer/doc/api.json +0 -1416
  592. package/src/elevation/doc/api.json +0 -317
  593. package/src/expandable/doc/api.json +0 -677
  594. package/src/fab/doc/api.json +0 -396
  595. package/src/floating-label/doc/api.json +0 -914
  596. package/src/form-field/doc/api.json +0 -948
  597. package/src/icon/doc/api.json +0 -224
  598. package/src/icon-button/doc/api.json +0 -1109
  599. package/src/image-list/doc/api.json +0 -438
  600. package/src/layout-grid/doc/api.json +0 -600
  601. package/src/line-ripple/doc/api.json +0 -857
  602. package/src/linear-progress/doc/api.json +0 -949
  603. package/src/list/doc/api.json +0 -5725
  604. package/src/lookup/doc/api.json +0 -2370
  605. package/src/menu/doc/api.json +0 -2246
  606. package/src/menu-surface/doc/api.json +0 -1800
  607. package/src/notched-outline/doc/api.json +0 -943
  608. package/src/radio/doc/api.json +0 -1159
  609. package/src/ripple/doc/api.json +0 -1212
  610. package/src/segmented-button/doc/api.json +0 -1937
  611. package/src/select/doc/api.json +0 -4247
  612. package/src/slider/doc/api.json +0 -1954
  613. package/src/snackbar/doc/api.json +0 -1699
  614. package/src/switch/doc/api.json +0 -899
  615. package/src/tab-bar/doc/api.json +0 -4253
  616. package/src/text-field/doc/api.json +0 -3179
  617. package/src/tooltip/doc/api.json +0 -2531
  618. package/src/top-app-bar/doc/api.json +0 -1752
  619. package/src/tree-view/doc/api.json +0 -1710
  620. package/src/typography/doc/api.json +0 -3058
  621. package/src/validation/doc/api.json +0 -371
@@ -1,16 +1,19 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MdcDataTable = void 0;
4
+ const tslib_1 = require("tslib");
2
5
  /* eslint-disable no-template-curly-in-string */
3
- import { MdcComponent, booleanAttr, number } from '../base';
4
- import { MDCDataTableFoundation, selectors, events, cssClasses, dataAttributes, SortValue, messages } from '@material/data-table';
5
- import { closest } from '@material/dom/ponyfill';
6
- import { inject, customElement, bindable, BindingMode } from 'aurelia';
7
- import { processContent, CustomElement } from '@aurelia/runtime-html';
8
- import template from './mdc-data-table.html?raw';
9
- events.ROW_CLICK = events.ROW_CLICK.toLowerCase();
10
- events.ROW_SELECTION_CHANGED = events.ROW_SELECTION_CHANGED.toLowerCase();
11
- events.SELECTED_ALL = events.SELECTED_ALL.toLowerCase();
12
- events.SORTED = events.SORTED.toLowerCase();
13
- events.UNSELECTED_ALL = events.UNSELECTED_ALL.toLowerCase();
6
+ const base_1 = require("../base");
7
+ const data_table_1 = require("@material/data-table");
8
+ const ponyfill_1 = require("@material/dom/ponyfill");
9
+ const aurelia_1 = require("aurelia");
10
+ const runtime_html_1 = require("@aurelia/runtime-html");
11
+ const mdc_data_table_html_raw_1 = tslib_1.__importDefault(require("./mdc-data-table.html?raw"));
12
+ data_table_1.events.ROW_CLICK = data_table_1.events.ROW_CLICK.toLowerCase();
13
+ data_table_1.events.ROW_SELECTION_CHANGED = data_table_1.events.ROW_SELECTION_CHANGED.toLowerCase();
14
+ data_table_1.events.SELECTED_ALL = data_table_1.events.SELECTED_ALL.toLowerCase();
15
+ data_table_1.events.SORTED = data_table_1.events.SORTED.toLowerCase();
16
+ data_table_1.events.UNSELECTED_ALL = data_table_1.events.UNSELECTED_ALL.toLowerCase();
14
17
  const NAVIGATION_EVENT = 'mdcdatatable:navigation';
15
18
  /**
16
19
  * Use `pagination-total` replaceable part to customise pagination total label.
@@ -22,7 +25,7 @@ const NAVIGATION_EVENT = 'mdcdatatable:navigation';
22
25
  * @emits mdcdatatable:rowclick | Emitted when a row is clicked
23
26
  */
24
27
  let MdcDataTable = (() => {
25
- let _classDecorators = [inject(Element), customElement({ name: 'mdc-data-table', template }), processContent(function processContent(node) {
28
+ let _classDecorators = [(0, aurelia_1.inject)(Element), (0, aurelia_1.customElement)({ name: 'mdc-data-table', template: mdc_data_table_html_raw_1.default }), (0, runtime_html_1.processContent)(function processContent(node) {
26
29
  const element = node;
27
30
  const table = element.querySelector('table');
28
31
  if (!table) {
@@ -34,11 +37,11 @@ let MdcDataTable = (() => {
34
37
  if (!headerRow) {
35
38
  throw new Error('Have you forgotten the <thead><tr> tags in you data table markup?');
36
39
  }
37
- headerRow.classList.add(cssClasses.HEADER_ROW);
40
+ headerRow.classList.add(data_table_1.cssClasses.HEADER_ROW);
38
41
  headerRow.setAttribute('ref', 'headerRow');
39
42
  const headerCells = headerRow.querySelectorAll('th');
40
43
  for (const th of Array.from(headerCells)) {
41
- th.classList.add(cssClasses.HEADER_CELL);
44
+ th.classList.add(data_table_1.cssClasses.HEADER_CELL);
42
45
  th.classList.toggle('mdc-data-table__header-cell--numeric', th.hasAttribute('numeric'));
43
46
  th.setAttribute('role', 'columnheader');
44
47
  th.setAttribute('scope', 'col');
@@ -47,7 +50,7 @@ let MdcDataTable = (() => {
47
50
  if (!tbody) {
48
51
  throw new Error('Have you forgotten the <tbody> tag in you data table markup?');
49
52
  }
50
- tbody.classList.add(cssClasses.CONTENT);
53
+ tbody.classList.add(data_table_1.cssClasses.CONTENT);
51
54
  tbody.setAttribute('ref', 'content');
52
55
  const paginationTotalSlot = element.querySelector('[au-slot="pagination-total"]');
53
56
  paginationTotalSlot?.remove();
@@ -58,7 +61,7 @@ let MdcDataTable = (() => {
58
61
  let _classDescriptor;
59
62
  let _classExtraInitializers = [];
60
63
  let _classThis;
61
- let _classSuper = MdcComponent;
64
+ let _classSuper = base_1.MdcComponent;
62
65
  let _pagination_decorators;
63
66
  let _pagination_initializers = [];
64
67
  let _pagination_extraInitializers = [];
@@ -74,6 +77,12 @@ let MdcDataTable = (() => {
74
77
  let _stickyHeader_decorators;
75
78
  let _stickyHeader_initializers = [];
76
79
  let _stickyHeader_extraInitializers = [];
80
+ let _manualCheckboxHandling_decorators;
81
+ let _manualCheckboxHandling_initializers = [];
82
+ let _manualCheckboxHandling_extraInitializers = [];
83
+ let _saveColumnWidths_decorators;
84
+ let _saveColumnWidths_initializers = [];
85
+ let _saveColumnWidths_extraInitializers = [];
77
86
  let _recordsCount_decorators;
78
87
  let _recordsCount_initializers = [];
79
88
  let _recordsCount_extraInitializers = [];
@@ -90,42 +99,52 @@ let MdcDataTable = (() => {
90
99
  static { _classThis = this; }
91
100
  static {
92
101
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
93
- _pagination_decorators = [bindable({ set: booleanAttr })];
94
- _rowsPerPageLabel_decorators = [bindable()];
95
- _pageSizes_decorators = [bindable()];
96
- _pageSize_decorators = [bindable({ mode: BindingMode.twoWay })];
97
- _stickyHeader_decorators = [bindable({ set: booleanAttr })];
98
- _recordsCount_decorators = [bindable({ set: number })];
99
- _activePage_decorators = [bindable({ set: number })];
100
- _busy_decorators = [bindable({ set: booleanAttr })];
101
- _hoistPageSelectToBody_decorators = [bindable({ set: booleanAttr })];
102
- __esDecorate(null, null, _pagination_decorators, { kind: "field", name: "pagination", static: false, private: false, access: { has: obj => "pagination" in obj, get: obj => obj.pagination, set: (obj, value) => { obj.pagination = value; } }, metadata: _metadata }, _pagination_initializers, _pagination_extraInitializers);
103
- __esDecorate(null, null, _rowsPerPageLabel_decorators, { kind: "field", name: "rowsPerPageLabel", static: false, private: false, access: { has: obj => "rowsPerPageLabel" in obj, get: obj => obj.rowsPerPageLabel, set: (obj, value) => { obj.rowsPerPageLabel = value; } }, metadata: _metadata }, _rowsPerPageLabel_initializers, _rowsPerPageLabel_extraInitializers);
104
- __esDecorate(null, null, _pageSizes_decorators, { kind: "field", name: "pageSizes", static: false, private: false, access: { has: obj => "pageSizes" in obj, get: obj => obj.pageSizes, set: (obj, value) => { obj.pageSizes = value; } }, metadata: _metadata }, _pageSizes_initializers, _pageSizes_extraInitializers);
105
- __esDecorate(null, null, _pageSize_decorators, { kind: "field", name: "pageSize", static: false, private: false, access: { has: obj => "pageSize" in obj, get: obj => obj.pageSize, set: (obj, value) => { obj.pageSize = value; } }, metadata: _metadata }, _pageSize_initializers, _pageSize_extraInitializers);
106
- __esDecorate(null, null, _stickyHeader_decorators, { kind: "field", name: "stickyHeader", static: false, private: false, access: { has: obj => "stickyHeader" in obj, get: obj => obj.stickyHeader, set: (obj, value) => { obj.stickyHeader = value; } }, metadata: _metadata }, _stickyHeader_initializers, _stickyHeader_extraInitializers);
107
- __esDecorate(null, null, _recordsCount_decorators, { kind: "field", name: "recordsCount", static: false, private: false, access: { has: obj => "recordsCount" in obj, get: obj => obj.recordsCount, set: (obj, value) => { obj.recordsCount = value; } }, metadata: _metadata }, _recordsCount_initializers, _recordsCount_extraInitializers);
108
- __esDecorate(null, null, _activePage_decorators, { kind: "field", name: "activePage", static: false, private: false, access: { has: obj => "activePage" in obj, get: obj => obj.activePage, set: (obj, value) => { obj.activePage = value; } }, metadata: _metadata }, _activePage_initializers, _activePage_extraInitializers);
109
- __esDecorate(null, null, _busy_decorators, { kind: "field", name: "busy", static: false, private: false, access: { has: obj => "busy" in obj, get: obj => obj.busy, set: (obj, value) => { obj.busy = value; } }, metadata: _metadata }, _busy_initializers, _busy_extraInitializers);
110
- __esDecorate(null, null, _hoistPageSelectToBody_decorators, { kind: "field", name: "hoistPageSelectToBody", static: false, private: false, access: { has: obj => "hoistPageSelectToBody" in obj, get: obj => obj.hoistPageSelectToBody, set: (obj, value) => { obj.hoistPageSelectToBody = value; } }, metadata: _metadata }, _hoistPageSelectToBody_initializers, _hoistPageSelectToBody_extraInitializers);
111
- __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
102
+ _pagination_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
103
+ _rowsPerPageLabel_decorators = [(0, aurelia_1.bindable)()];
104
+ _pageSizes_decorators = [(0, aurelia_1.bindable)()];
105
+ _pageSize_decorators = [(0, aurelia_1.bindable)({ mode: aurelia_1.BindingMode.twoWay })];
106
+ _stickyHeader_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
107
+ _manualCheckboxHandling_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
108
+ _saveColumnWidths_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
109
+ _recordsCount_decorators = [(0, aurelia_1.bindable)({ set: base_1.number })];
110
+ _activePage_decorators = [(0, aurelia_1.bindable)({ set: base_1.number })];
111
+ _busy_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
112
+ _hoistPageSelectToBody_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
113
+ tslib_1.__esDecorate(null, null, _pagination_decorators, { kind: "field", name: "pagination", static: false, private: false, access: { has: obj => "pagination" in obj, get: obj => obj.pagination, set: (obj, value) => { obj.pagination = value; } }, metadata: _metadata }, _pagination_initializers, _pagination_extraInitializers);
114
+ tslib_1.__esDecorate(null, null, _rowsPerPageLabel_decorators, { kind: "field", name: "rowsPerPageLabel", static: false, private: false, access: { has: obj => "rowsPerPageLabel" in obj, get: obj => obj.rowsPerPageLabel, set: (obj, value) => { obj.rowsPerPageLabel = value; } }, metadata: _metadata }, _rowsPerPageLabel_initializers, _rowsPerPageLabel_extraInitializers);
115
+ tslib_1.__esDecorate(null, null, _pageSizes_decorators, { kind: "field", name: "pageSizes", static: false, private: false, access: { has: obj => "pageSizes" in obj, get: obj => obj.pageSizes, set: (obj, value) => { obj.pageSizes = value; } }, metadata: _metadata }, _pageSizes_initializers, _pageSizes_extraInitializers);
116
+ tslib_1.__esDecorate(null, null, _pageSize_decorators, { kind: "field", name: "pageSize", static: false, private: false, access: { has: obj => "pageSize" in obj, get: obj => obj.pageSize, set: (obj, value) => { obj.pageSize = value; } }, metadata: _metadata }, _pageSize_initializers, _pageSize_extraInitializers);
117
+ tslib_1.__esDecorate(null, null, _stickyHeader_decorators, { kind: "field", name: "stickyHeader", static: false, private: false, access: { has: obj => "stickyHeader" in obj, get: obj => obj.stickyHeader, set: (obj, value) => { obj.stickyHeader = value; } }, metadata: _metadata }, _stickyHeader_initializers, _stickyHeader_extraInitializers);
118
+ tslib_1.__esDecorate(null, null, _manualCheckboxHandling_decorators, { kind: "field", name: "manualCheckboxHandling", static: false, private: false, access: { has: obj => "manualCheckboxHandling" in obj, get: obj => obj.manualCheckboxHandling, set: (obj, value) => { obj.manualCheckboxHandling = value; } }, metadata: _metadata }, _manualCheckboxHandling_initializers, _manualCheckboxHandling_extraInitializers);
119
+ tslib_1.__esDecorate(null, null, _saveColumnWidths_decorators, { kind: "field", name: "saveColumnWidths", static: false, private: false, access: { has: obj => "saveColumnWidths" in obj, get: obj => obj.saveColumnWidths, set: (obj, value) => { obj.saveColumnWidths = value; } }, metadata: _metadata }, _saveColumnWidths_initializers, _saveColumnWidths_extraInitializers);
120
+ tslib_1.__esDecorate(null, null, _recordsCount_decorators, { kind: "field", name: "recordsCount", static: false, private: false, access: { has: obj => "recordsCount" in obj, get: obj => obj.recordsCount, set: (obj, value) => { obj.recordsCount = value; } }, metadata: _metadata }, _recordsCount_initializers, _recordsCount_extraInitializers);
121
+ tslib_1.__esDecorate(null, null, _activePage_decorators, { kind: "field", name: "activePage", static: false, private: false, access: { has: obj => "activePage" in obj, get: obj => obj.activePage, set: (obj, value) => { obj.activePage = value; } }, metadata: _metadata }, _activePage_initializers, _activePage_extraInitializers);
122
+ tslib_1.__esDecorate(null, null, _busy_decorators, { kind: "field", name: "busy", static: false, private: false, access: { has: obj => "busy" in obj, get: obj => obj.busy, set: (obj, value) => { obj.busy = value; } }, metadata: _metadata }, _busy_initializers, _busy_extraInitializers);
123
+ tslib_1.__esDecorate(null, null, _hoistPageSelectToBody_decorators, { kind: "field", name: "hoistPageSelectToBody", static: false, private: false, access: { has: obj => "hoistPageSelectToBody" in obj, get: obj => obj.hoistPageSelectToBody, set: (obj, value) => { obj.hoistPageSelectToBody = value; } }, metadata: _metadata }, _hoistPageSelectToBody_initializers, _hoistPageSelectToBody_extraInitializers);
124
+ tslib_1.__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
112
125
  MdcDataTable = _classThis = _classDescriptor.value;
113
126
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
114
- __runInitializers(_classThis, _classExtraInitializers);
127
+ tslib_1.__runInitializers(_classThis, _classExtraInitializers);
115
128
  }
116
129
  header;
117
130
  content;
131
+ columnResized;
132
+ mutationObserver;
118
133
  /** Shows pagination footer */
119
- pagination = __runInitializers(this, _pagination_initializers, void 0);
134
+ pagination = tslib_1.__runInitializers(this, _pagination_initializers, void 0);
120
135
  /** Caption for the page size selector */
121
- rowsPerPageLabel = (__runInitializers(this, _pagination_extraInitializers), __runInitializers(this, _rowsPerPageLabel_initializers, 'Rows per page'));
136
+ rowsPerPageLabel = (tslib_1.__runInitializers(this, _pagination_extraInitializers), tslib_1.__runInitializers(this, _rowsPerPageLabel_initializers, 'Rows per page'));
122
137
  /** Page sizes available for selection, e.g. [10, 25, 100, 'All'] */
123
- pageSizes = (__runInitializers(this, _rowsPerPageLabel_extraInitializers), __runInitializers(this, _pageSizes_initializers, [10, 25, 100]));
138
+ pageSizes = (tslib_1.__runInitializers(this, _rowsPerPageLabel_extraInitializers), tslib_1.__runInitializers(this, _pageSizes_initializers, [10, 25, 100]));
124
139
  /** Selected page size */
125
- pageSize = (__runInitializers(this, _pageSizes_extraInitializers), __runInitializers(this, _pageSize_initializers, 10));
140
+ pageSize = (tslib_1.__runInitializers(this, _pageSizes_extraInitializers), tslib_1.__runInitializers(this, _pageSize_initializers, 10));
126
141
  /** Makes header row sticky (fixed) on vertical scroll.
127
142
  * (Note: Sticky header feature is not compatible with IE11 browsers.) */
128
- stickyHeader = (__runInitializers(this, _pageSize_extraInitializers), __runInitializers(this, _stickyHeader_initializers, void 0));
143
+ stickyHeader = (tslib_1.__runInitializers(this, _pageSize_extraInitializers), tslib_1.__runInitializers(this, _stickyHeader_initializers, void 0));
144
+ /** Turns off checkbox handling by the MDC framework */
145
+ manualCheckboxHandling = (tslib_1.__runInitializers(this, _stickyHeader_extraInitializers), tslib_1.__runInitializers(this, _manualCheckboxHandling_initializers, void 0));
146
+ /** Turns on automatic column widths saving to localStorage */
147
+ saveColumnWidths = (tslib_1.__runInitializers(this, _manualCheckboxHandling_extraInitializers), tslib_1.__runInitializers(this, _saveColumnWidths_initializers, void 0));
129
148
  get paginationPosition() {
130
149
  if (typeof this.pageSize !== 'number' || this.pageSize === undefined || isNaN(this.activePage) || isNaN(this.recordsCount)) {
131
150
  return undefined;
@@ -136,9 +155,9 @@ let MdcDataTable = (() => {
136
155
  : (this.activePage === pagesCount ? 'last' : 'between');
137
156
  }
138
157
  /** Sets total number of records. Used in navigation row. */
139
- recordsCount = (__runInitializers(this, _stickyHeader_extraInitializers), __runInitializers(this, _recordsCount_initializers, void 0));
158
+ recordsCount = (tslib_1.__runInitializers(this, _saveColumnWidths_extraInitializers), tslib_1.__runInitializers(this, _recordsCount_initializers, void 0));
140
159
  /** Sets the active page number. Used in navigation row. */
141
- activePage = (__runInitializers(this, _recordsCount_extraInitializers), __runInitializers(this, _activePage_initializers, void 0));
160
+ activePage = (tslib_1.__runInitializers(this, _recordsCount_extraInitializers), tslib_1.__runInitializers(this, _activePage_initializers, void 0));
142
161
  get paginationTotal() {
143
162
  if (typeof this.pageSize !== 'number' || this.pageSize === undefined || isNaN(this.activePage) || isNaN(this.recordsCount)) {
144
163
  return undefined;
@@ -148,7 +167,7 @@ let MdcDataTable = (() => {
148
167
  return `${firstRecord}-${lastRecord} of ${this.recordsCount}`;
149
168
  }
150
169
  /** Turns on a linear progress indicator at the top of the table */
151
- busy = (__runInitializers(this, _activePage_extraInitializers), __runInitializers(this, _busy_initializers, void 0));
170
+ busy = (tslib_1.__runInitializers(this, _activePage_extraInitializers), tslib_1.__runInitializers(this, _busy_initializers, void 0));
152
171
  busyChanged() {
153
172
  if (this.busy) {
154
173
  this.foundation?.showProgress();
@@ -157,14 +176,14 @@ let MdcDataTable = (() => {
157
176
  this.foundation?.hideProgress();
158
177
  }
159
178
  }
160
- hoistPageSelectToBody = (__runInitializers(this, _busy_extraInitializers), __runInitializers(this, _hoistPageSelectToBody_initializers, void 0));
179
+ hoistPageSelectToBody = (tslib_1.__runInitializers(this, _busy_extraInitializers), tslib_1.__runInitializers(this, _hoistPageSelectToBody_initializers, void 0));
161
180
  get rowCheckboxList() {
162
- return Array.from(this.root.querySelectorAll(`.${cssClasses.ROW} .mdc-checkbox`))
163
- .map(x => CustomElement.for(x).viewModel);
181
+ return Array.from(this.root.querySelectorAll(`.${data_table_1.cssClasses.ROW} .mdc-checkbox`))
182
+ .map(x => runtime_html_1.CustomElement.for(x).viewModel);
164
183
  }
165
184
  get headerRowCheckbox() {
166
- const el = this.root.querySelector(`.${cssClasses.HEADER_ROW} .mdc-checkbox`);
167
- return el ? CustomElement.for(el).viewModel : undefined;
185
+ const el = this.root.querySelector(`.${data_table_1.cssClasses.HEADER_ROW} .mdc-checkbox`);
186
+ return el ? runtime_html_1.CustomElement.for(el).viewModel : undefined;
168
187
  }
169
188
  handleHeaderRowCheckboxChange() {
170
189
  this.foundation?.handleHeaderRowCheckboxChange();
@@ -181,7 +200,7 @@ let MdcDataTable = (() => {
181
200
  this.emit(NAVIGATION_EVENT, { type }, true);
182
201
  }
183
202
  handleContentClick(event) {
184
- const dataRowEl = closest(event.target, selectors.ROW);
203
+ const dataRowEl = (0, ponyfill_1.closest)(event.target, data_table_1.selectors.ROW);
185
204
  if (!dataRowEl) {
186
205
  return;
187
206
  }
@@ -197,19 +216,19 @@ let MdcDataTable = (() => {
197
216
  this.foundation?.layout();
198
217
  }
199
218
  /**
200
- * @return Returns array of header row cell elements.
219
+ * Returns array of header row cell elements.
201
220
  */
202
221
  getHeaderCells() {
203
- return [].slice.call(this.root.querySelectorAll(selectors.HEADER_CELL));
222
+ return [].slice.call(this.root.querySelectorAll(data_table_1.selectors.HEADER_CELL));
204
223
  }
205
224
  /**
206
- * @return Returns array of row elements.
225
+ * Returns array of row elements.
207
226
  */
208
227
  getRows() {
209
228
  return this.foundation.getRows();
210
229
  }
211
230
  /**
212
- * @return Returns array of selected row ids.
231
+ * Returns array of selected row ids.
213
232
  */
214
233
  getSelectedRowIds() {
215
234
  return this.foundation.getSelectedRowIds();
@@ -243,35 +262,108 @@ let MdcDataTable = (() => {
243
262
  }
244
263
  }
245
264
  beforeFoundationCreated() {
246
- this.header = this.root.querySelector(`.${cssClasses.HEADER_ROW}`);
247
- this.header.addEventListener('change', this);
265
+ this.header = this.root.querySelector(`.${data_table_1.cssClasses.HEADER_ROW}`);
266
+ this.content = this.root.querySelector(`.${data_table_1.cssClasses.CONTENT}`);
248
267
  this.header.addEventListener('click', this);
249
- this.content = this.root.querySelector(`.${cssClasses.CONTENT}`);
250
- this.content.addEventListener('change', this);
251
- this.content.addEventListener('click', this);
268
+ this.header.querySelectorAll('th[resizeable]').forEach(x => {
269
+ const resizeHandle = document.createElement('div');
270
+ resizeHandle.addEventListener('mousedown', (event) => this.startColumnResize(event, x));
271
+ x.insertBefore(document.createElement('div'), x.firstChild).classList.add('mdc-data-table__header-cell__hover-indicator');
272
+ x.appendChild(resizeHandle).classList.add('mdc-data-table__header-cell__resize-handle');
273
+ });
274
+ if (this.saveColumnWidths) {
275
+ this.restoreColumnWidths();
276
+ this.mutationObserver = new MutationObserver(() => this.restoreColumnWidths());
277
+ this.mutationObserver.observe(this.content, { childList: true, subtree: false });
278
+ }
279
+ if (!this.manualCheckboxHandling) {
280
+ this.header.addEventListener('change', this);
281
+ this.content.addEventListener('change', this);
282
+ }
252
283
  const rowCheckboxList = this.rowCheckboxList;
253
- this.rowCheckboxList.forEach(x => x.root.classList.add(cssClasses.ROW_CHECKBOX));
284
+ this.rowCheckboxList.forEach(x => x.root.classList.add(data_table_1.cssClasses.ROW_CHECKBOX));
254
285
  if (this.headerRowCheckbox) {
255
- this.headerRowCheckbox.root.classList.add(cssClasses.HEADER_ROW_CHECKBOX);
286
+ this.headerRowCheckbox.root.classList.add(data_table_1.cssClasses.HEADER_ROW_CHECKBOX);
256
287
  rowCheckboxList.push(this.headerRowCheckbox);
257
288
  }
258
289
  }
290
+ restoreColumnWidths() {
291
+ const widths = JSON.parse(localStorage.getItem(`mdc-data-table-${this.root.id}-column-widths`) ?? '[]');
292
+ this.setColumnWidths(widths);
293
+ }
259
294
  initialSyncWithDOM() {
260
295
  if (this.busy !== undefined) {
261
296
  this.busyChanged();
262
297
  }
263
- const rowCheckboxList = this.rowCheckboxList;
264
- for (let i = 0; i < rowCheckboxList.length; ++i) {
265
- if (rowCheckboxList[i].checked) {
266
- this.getRowByIndex(i).classList.add(cssClasses.ROW_SELECTED);
298
+ if (!this.manualCheckboxHandling) {
299
+ const rowCheckboxList = this.rowCheckboxList;
300
+ for (let i = 0; i < rowCheckboxList.length; ++i) {
301
+ if (rowCheckboxList[i].checked) {
302
+ this.getRowByIndex(i).classList.add(data_table_1.cssClasses.ROW_SELECTED);
303
+ }
267
304
  }
268
305
  }
269
306
  this.foundation?.layout();
270
307
  }
308
+ startColumnResize(event, headerCell) {
309
+ this.columnResized = true;
310
+ const startX = event.clientX;
311
+ const resizeHandle = event.target;
312
+ const initialHandlePosition = resizeHandle.offsetLeft;
313
+ // Create a visual indicator for the resize handle
314
+ const handleIndicator = document.createElement('div');
315
+ handleIndicator.classList.add('mdc-data-table__header-cell__resize-handle-indicator');
316
+ handleIndicator.style.left = `${initialHandlePosition}px`;
317
+ handleIndicator.style.height = `${headerCell.offsetHeight}px`;
318
+ document.body.style.cursor = 'col-resize';
319
+ headerCell.classList.add('mdc-data-table__header-cell--resizing');
320
+ headerCell.appendChild(handleIndicator);
321
+ const onMouseMove = (moveEvent) => {
322
+ const deltaX = moveEvent.clientX - startX;
323
+ handleIndicator.style.left = `${Math.max(initialHandlePosition + deltaX, headerCell.clientLeft)}px`;
324
+ };
325
+ const onMouseUp = () => {
326
+ const finalDeltaX = parseInt(handleIndicator.style.left, 10) - initialHandlePosition;
327
+ const newWidth = Math.max(5, headerCell.offsetWidth + finalDeltaX); // Minimum width of 5px
328
+ // Apply the new width to the column
329
+ headerCell.style.minWidth = headerCell.style.maxWidth = `${newWidth}px`;
330
+ this.content.querySelectorAll(`tr td:nth-child(${Array.from(headerCell.parentElement.children).indexOf(headerCell) + 1})`)
331
+ .forEach((cell) => {
332
+ cell.style.minWidth = cell.style.maxWidth = `${newWidth}px`;
333
+ });
334
+ // Clean up
335
+ handleIndicator.remove();
336
+ this.columnResized = false;
337
+ document.body.style.cursor = '';
338
+ headerCell.classList.remove('mdc-data-table__header-cell--resizing');
339
+ document.removeEventListener('mousemove', onMouseMove);
340
+ document.removeEventListener('mouseup', onMouseUp);
341
+ // Save the new widths if required
342
+ const widths = this.getHeaderCells().map(x => x.style.minWidth);
343
+ if (this.saveColumnWidths) {
344
+ localStorage.setItem(`mdc-data-table-${this.root.id}-column-widths`, JSON.stringify(widths));
345
+ }
346
+ this.emit('mdcdatatable:columnsresized', { widths }, true);
347
+ };
348
+ document.addEventListener('mousemove', onMouseMove);
349
+ document.addEventListener('mouseup', onMouseUp);
350
+ }
271
351
  destroy() {
272
352
  this.header.removeEventListener('change', this);
273
353
  this.header.removeEventListener('click', this);
274
354
  this.content.removeEventListener('change', this);
355
+ this.mutationObserver?.disconnect();
356
+ }
357
+ setColumnWidths(widths) {
358
+ if (!widths || widths.length === 0) {
359
+ return;
360
+ }
361
+ this.getHeaderCells().forEach((x, i) => {
362
+ x.style.minWidth = x.style.maxWidth = widths[i];
363
+ this.content.querySelectorAll(`tr td:nth-child(${i + 1})`).forEach((cell) => {
364
+ cell.style.minWidth = cell.style.maxWidth = widths[i];
365
+ });
366
+ });
275
367
  }
276
368
  getDefaultFoundation() {
277
369
  // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.
@@ -289,10 +381,10 @@ let MdcDataTable = (() => {
289
381
  this.getHeaderCells()[index].classList.remove(className);
290
382
  },
291
383
  notifySortAction: (data) => {
292
- this.emit(events.SORTED, data, /** shouldBubble */ true);
384
+ this.emit(data_table_1.events.SORTED, data, /** shouldBubble */ true);
293
385
  },
294
386
  getTableContainerHeight: () => {
295
- const tableContainer = this.root.querySelector(`.${cssClasses.TABLE_CONTAINER}`);
387
+ const tableContainer = this.root.querySelector(`.${data_table_1.cssClasses.TABLE_CONTAINER}`);
296
388
  if (!tableContainer) {
297
389
  throw new Error('MDCDataTable: Table container element not found.');
298
390
  }
@@ -300,14 +392,14 @@ let MdcDataTable = (() => {
300
392
  return tableContainer.getBoundingClientRect().height;
301
393
  },
302
394
  getTableHeaderHeight: () => {
303
- const tableHeader = this.root.querySelector(selectors.HEADER_ROW);
395
+ const tableHeader = this.root.querySelector(data_table_1.selectors.HEADER_ROW);
304
396
  if (!tableHeader) {
305
397
  throw new Error('MDCDataTable: Table header element not found.');
306
398
  }
307
399
  return tableHeader.getBoundingClientRect().height;
308
400
  },
309
401
  setProgressIndicatorStyles: (styles) => {
310
- const progressIndicator = this.root.querySelector(selectors.PROGRESS_INDICATOR);
402
+ const progressIndicator = this.root.querySelector(data_table_1.selectors.PROGRESS_INDICATOR);
311
403
  if (!progressIndicator) {
312
404
  throw new Error('MDCDataTable: Progress indicator element not found.');
313
405
  }
@@ -317,15 +409,15 @@ let MdcDataTable = (() => {
317
409
  this.getRows()[rowIndex].classList.add(className);
318
410
  },
319
411
  getRowCount: () => this.getRows().length,
320
- getRowElements: () => [].slice.call(this.root.querySelectorAll(selectors.ROW)),
321
- getRowIdAtIndex: (rowIndex) => this.getRows()[rowIndex].getAttribute(dataAttributes.ROW_ID),
322
- getRowIndexByChildElement: (el) => this.getRows().indexOf(closest(el, selectors.ROW)),
323
- getSelectedRowCount: () => this.root.querySelectorAll(selectors.ROW_SELECTED).length,
412
+ getRowElements: () => [].slice.call(this.root.querySelectorAll(data_table_1.selectors.ROW)),
413
+ getRowIdAtIndex: (rowIndex) => this.getRows()[rowIndex].getAttribute(data_table_1.dataAttributes.ROW_ID),
414
+ getRowIndexByChildElement: (el) => this.getRows().indexOf((0, ponyfill_1.closest)(el, data_table_1.selectors.ROW)),
415
+ getSelectedRowCount: () => this.root.querySelectorAll(data_table_1.selectors.ROW_SELECTED).length,
324
416
  isCheckboxAtRowIndexChecked: (rowIndex) => this.rowCheckboxList[rowIndex].checked,
325
417
  isHeaderRowCheckboxChecked: () => this.headerRowCheckbox?.checked ?? false,
326
- isRowsSelectable: () => !!this.root.querySelector(selectors.ROW_CHECKBOX),
418
+ isRowsSelectable: () => !!this.root.querySelector(data_table_1.selectors.ROW_CHECKBOX),
327
419
  notifyRowSelectionChanged: (data) => {
328
- this.emit(events.ROW_SELECTION_CHANGED, {
420
+ this.emit(data_table_1.events.ROW_SELECTION_CHANGED, {
329
421
  row: this.getRowByIndex(data.rowIndex),
330
422
  rowId: this.getRowIdByIndex(data.rowIndex),
331
423
  rowIndex: data.rowIndex,
@@ -333,13 +425,13 @@ let MdcDataTable = (() => {
333
425
  }, /** shouldBubble */ true);
334
426
  },
335
427
  notifySelectedAll: () => {
336
- this.emit(events.SELECTED_ALL, {}, /** shouldBubble */ true);
428
+ this.emit(data_table_1.events.SELECTED_ALL, {}, /** shouldBubble */ true);
337
429
  },
338
430
  notifyUnselectedAll: () => {
339
- this.emit(events.UNSELECTED_ALL, {}, /** shouldBubble */ true);
431
+ this.emit(data_table_1.events.UNSELECTED_ALL, {}, /** shouldBubble */ true);
340
432
  },
341
433
  notifyRowClick: (data) => {
342
- this.emit(events.ROW_CLICK, data, /** shouldBubble */ true);
434
+ this.emit(data_table_1.events.ROW_CLICK, data, /** shouldBubble */ true);
343
435
  },
344
436
  registerHeaderRowCheckbox: () => {
345
437
  // const checkboxEl = this.root.querySelector<IMdcCheckboxElement>(selectors.HEADER_ROW_CHECKBOX);
@@ -375,7 +467,7 @@ let MdcDataTable = (() => {
375
467
  },
376
468
  setSortStatusLabelByHeaderCellIndex: (columnIndex, sortValue) => {
377
469
  const headerCell = this.getHeaderCells()[columnIndex];
378
- const sortStatusLabel = headerCell.querySelector(selectors.SORT_STATUS_LABEL);
470
+ const sortStatusLabel = headerCell.querySelector(data_table_1.selectors.SORT_STATUS_LABEL);
379
471
  if (!sortStatusLabel) {
380
472
  return;
381
473
  }
@@ -383,20 +475,20 @@ let MdcDataTable = (() => {
383
475
  this.getSortStatusMessageBySortValue(sortValue);
384
476
  }
385
477
  };
386
- return new MDCDataTableFoundation(adapter);
478
+ return new data_table_1.MDCDataTableFoundation(adapter);
387
479
  }
388
480
  getRowByIndex(index) {
389
481
  return this.getRows()[index];
390
482
  }
391
483
  getRowIdByIndex(index) {
392
- return this.getRowByIndex(index).getAttribute(dataAttributes.ROW_ID);
484
+ return this.getRowByIndex(index).getAttribute(data_table_1.dataAttributes.ROW_ID);
393
485
  }
394
486
  handleHeaderRowClick(event) {
395
- const headerCell = closest(event.target, selectors.HEADER_CELL_WITH_SORT);
487
+ const headerCell = (0, ponyfill_1.closest)(event.target, data_table_1.selectors.HEADER_CELL_WITH_SORT);
396
488
  if (!headerCell) {
397
489
  return;
398
490
  }
399
- const columnId = headerCell.getAttribute(dataAttributes.COLUMN_ID);
491
+ const columnId = headerCell.getAttribute(data_table_1.dataAttributes.COLUMN_ID);
400
492
  const columnIndex = this.getHeaderCells().indexOf(headerCell);
401
493
  if (columnIndex === -1) {
402
494
  return;
@@ -405,23 +497,23 @@ let MdcDataTable = (() => {
405
497
  }
406
498
  getSortStatusMessageBySortValue(sortValue) {
407
499
  switch (sortValue) {
408
- case SortValue.ASCENDING:
409
- return messages.SORTED_IN_ASCENDING;
410
- case SortValue.DESCENDING:
411
- return messages.SORTED_IN_DESCENDING;
500
+ case data_table_1.SortValue.ASCENDING:
501
+ return data_table_1.messages.SORTED_IN_ASCENDING;
502
+ case data_table_1.SortValue.DESCENDING:
503
+ return data_table_1.messages.SORTED_IN_DESCENDING;
412
504
  default:
413
505
  return '';
414
506
  }
415
507
  }
416
508
  getRowIdByRowElement(rowElement) {
417
- return rowElement.getAttribute(dataAttributes.ROW_ID);
509
+ return rowElement.getAttribute(data_table_1.dataAttributes.ROW_ID);
418
510
  }
419
511
  constructor() {
420
512
  super(...arguments);
421
- __runInitializers(this, _hoistPageSelectToBody_extraInitializers);
513
+ tslib_1.__runInitializers(this, _hoistPageSelectToBody_extraInitializers);
422
514
  }
423
515
  };
424
516
  return MdcDataTable = _classThis;
425
517
  })();
426
- export { MdcDataTable };
518
+ exports.MdcDataTable = MdcDataTable;
427
519
  //# sourceMappingURL=mdc-data-table.js.map