@aurelia-mdc-web/all 9.3.0-au2 → 9.3.2-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 (933) hide show
  1. package/dist/alert/alert-modal/alert-modal.html +27 -0
  2. package/dist/alert/global-progress/global-progress.html +9 -0
  3. package/dist/alert/prompt-dialog/prompt-dialog.html +15 -0
  4. package/dist/banner/mdc-banner.html +21 -21
  5. package/dist/button/mdc-button.html +12 -12
  6. package/dist/card/mdc-card-actions/mdc-card-actions.html +3 -3
  7. package/dist/card/mdc-card-media/mdc-card-media.html +5 -5
  8. package/dist/card/mdc-card-primary-action.html +5 -5
  9. package/dist/card/mdc-card.html +3 -3
  10. package/dist/checkbox/mdc-checkbox.html +12 -12
  11. package/dist/chips/mdc-chip/mdc-chip.html +24 -24
  12. package/dist/chips/mdc-chip-action/mdc-chip-action.html +25 -25
  13. package/dist/chips/mdc-chip-set/mdc-chip-set.html +10 -10
  14. package/dist/circular-progress/mdc-circular-progress.html +38 -38
  15. package/dist/data-table/mdc-data-table.html +50 -49
  16. package/dist/dialog/mdc-dialog.html +14 -14
  17. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.html +5 -5
  18. package/dist/drawer/mdc-drawer.html +6 -6
  19. package/dist/expandable/mdc-expandable.html +28 -28
  20. package/dist/fab/mdc-fab.html +13 -13
  21. package/dist/floating-label/mdc-floating-label.html +1 -1
  22. package/dist/form-field/mdc-form-field.html +6 -6
  23. package/dist/icon/mdc-icon.html +3 -3
  24. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.html +4 -4
  25. package/dist/icon-button/mdc-icon-button.html +11 -11
  26. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.html +9 -9
  27. package/dist/image-list/mdc-image-list.html +7 -7
  28. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.html +12 -12
  29. package/dist/layout-grid/mdc-layout-grid.html +8 -8
  30. package/dist/linear-progress/mdc-linear-progress.html +12 -12
  31. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.html +4 -4
  32. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.html +8 -8
  33. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.html +15 -15
  34. package/dist/list/mdc-list-divider/mdc-list-divider.html +7 -7
  35. package/dist/list/mdc-list-item/mdc-list-item.html +13 -13
  36. package/dist/list/mdc-list.html +5 -5
  37. package/dist/lookup/mdc-lookup.html +27 -27
  38. package/dist/menu/mdc-menu.html +6 -6
  39. package/dist/notched-outline/mdc-notched-outline.html +7 -7
  40. package/dist/radio/mdc-radio.html +9 -9
  41. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.html +11 -11
  42. package/dist/segmented-button/mdc-segmented-button.html +3 -3
  43. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.html +7 -7
  44. package/dist/select/mdc-select.html +38 -38
  45. package/dist/slider/mdc-slider.html +36 -36
  46. package/dist/snackbar/mdc-snackbar.html +14 -14
  47. package/dist/src/alert/alert-configuration.js +15 -0
  48. package/dist/src/alert/alert-configuration.js.map +1 -0
  49. package/dist/src/alert/alert-modal/alert-modal.js +30 -0
  50. package/dist/src/alert/alert-modal/alert-modal.js.map +1 -0
  51. package/dist/src/alert/alert-modal/i-alert-modal-payload.js +14 -0
  52. package/dist/src/alert/alert-modal/i-alert-modal-payload.js.map +1 -0
  53. package/dist/src/alert/alert-service.js +106 -0
  54. package/dist/src/alert/alert-service.js.map +1 -0
  55. package/dist/src/alert/decorators/confirm-action.js +17 -0
  56. package/dist/src/alert/decorators/confirm-action.js.map +1 -0
  57. package/dist/src/alert/decorators/using-progress.js +27 -0
  58. package/dist/src/alert/decorators/using-progress.js.map +1 -0
  59. package/dist/src/alert/exceptions-tracker.js +8 -0
  60. package/dist/src/alert/exceptions-tracker.js.map +1 -0
  61. package/dist/src/alert/global-progress/global-progress.js +64 -0
  62. package/dist/src/alert/global-progress/global-progress.js.map +1 -0
  63. package/dist/src/alert/prompt-dialog/prompt-dialog.js +44 -0
  64. package/dist/src/alert/prompt-dialog/prompt-dialog.js.map +1 -0
  65. package/dist/src/banner/mdc-banner.js +154 -0
  66. package/dist/src/banner/mdc-banner.js.map +1 -0
  67. package/dist/src/base/attributes/mdc-focus-trap.js +71 -0
  68. package/dist/src/base/attributes/mdc-focus-trap.js.map +1 -0
  69. package/dist/src/base/elements/i-validated-element.js +3 -0
  70. package/dist/src/base/elements/i-validated-element.js.map +1 -0
  71. package/dist/src/base/elements/mdc-promisify-reference.js +48 -0
  72. package/dist/src/base/elements/mdc-promisify-reference.js.map +1 -0
  73. package/dist/src/base/index.js +32 -0
  74. package/dist/src/base/index.js.map +1 -0
  75. package/dist/src/base/interceptors.js +29 -0
  76. package/dist/src/base/interceptors.js.map +1 -0
  77. package/dist/{base → src/base}/material-palette.js +4 -1
  78. package/dist/src/base/material-palette.js.map +1 -0
  79. package/dist/{base → src/base}/mdc-component.js +5 -1
  80. package/dist/src/base/mdc-component.js.map +1 -0
  81. package/dist/{base → src/base}/next-element.js +4 -1
  82. package/dist/src/base/next-element.js.map +1 -0
  83. package/dist/{button → src/button}/enhance-mdc-button.js +9 -6
  84. package/dist/src/button/enhance-mdc-button.js.map +1 -0
  85. package/dist/{button → src/button}/mdc-button-label.js +9 -6
  86. package/dist/src/button/mdc-button-label.js.map +1 -0
  87. package/dist/src/button/mdc-button.js +102 -0
  88. package/dist/src/button/mdc-button.js.map +1 -0
  89. package/dist/{card → src/card}/mdc-card-action-buttons.js +9 -6
  90. package/dist/src/card/mdc-card-action-buttons.js.map +1 -0
  91. package/dist/{card → src/card}/mdc-card-action-icons.js +9 -6
  92. package/dist/src/card/mdc-card-action-icons.js.map +1 -0
  93. package/dist/src/card/mdc-card-actions/mdc-card-actions.js +41 -0
  94. package/dist/src/card/mdc-card-actions/mdc-card-actions.js.map +1 -0
  95. package/dist/src/card/mdc-card-media/mdc-card-media.js +50 -0
  96. package/dist/src/card/mdc-card-media/mdc-card-media.js.map +1 -0
  97. package/dist/src/card/mdc-card-primary-action.js +41 -0
  98. package/dist/src/card/mdc-card-primary-action.js.map +1 -0
  99. package/dist/src/card/mdc-card.js +41 -0
  100. package/dist/src/card/mdc-card.js.map +1 -0
  101. package/dist/{checkbox → src/checkbox}/mdc-checkbox.js +38 -35
  102. package/dist/src/checkbox/mdc-checkbox.js.map +1 -0
  103. package/dist/{chips → src/chips}/mdc-chip/mdc-chip.js +37 -34
  104. package/dist/src/chips/mdc-chip/mdc-chip.js.map +1 -0
  105. package/dist/{chips → src/chips}/mdc-chip-action/enhance-mdc-chip-action.js +9 -6
  106. package/dist/src/chips/mdc-chip-action/enhance-mdc-chip-action.js.map +1 -0
  107. package/dist/src/chips/mdc-chip-action/mdc-chip-action.js +152 -0
  108. package/dist/src/chips/mdc-chip-action/mdc-chip-action.js.map +1 -0
  109. package/dist/{chips → src/chips}/mdc-chip-set/mdc-chip-set.js +27 -24
  110. package/dist/src/chips/mdc-chip-set/mdc-chip-set.js.map +1 -0
  111. package/dist/{circular-progress → src/circular-progress}/mdc-circular-progress.js +25 -22
  112. package/dist/src/circular-progress/mdc-circular-progress.js.map +1 -0
  113. package/dist/{data-table → src/data-table}/mdc-data-table-row.js +13 -10
  114. package/dist/src/data-table/mdc-data-table-row.js.map +1 -0
  115. package/dist/src/data-table/mdc-data-table.js +519 -0
  116. package/dist/src/data-table/mdc-data-table.js.map +1 -0
  117. package/dist/src/dialog/mdc-dialog-actions.js +47 -0
  118. package/dist/src/dialog/mdc-dialog-actions.js.map +1 -0
  119. package/dist/{dialog → src/dialog}/mdc-dialog-content.js +9 -6
  120. package/dist/src/dialog/mdc-dialog-content.js.map +1 -0
  121. package/dist/{dialog → src/dialog}/mdc-dialog-service.js +20 -13
  122. package/dist/src/dialog/mdc-dialog-service.js.map +1 -0
  123. package/dist/src/dialog/mdc-dialog-title.js +28 -0
  124. package/dist/src/dialog/mdc-dialog-title.js.map +1 -0
  125. package/dist/{dialog → src/dialog}/mdc-dialog.js +49 -46
  126. package/dist/src/dialog/mdc-dialog.js.map +1 -0
  127. package/dist/{drawer → src/drawer}/mdc-drawer-app-content.js +9 -6
  128. package/dist/src/drawer/mdc-drawer-app-content.js.map +1 -0
  129. package/dist/{drawer → src/drawer}/mdc-drawer-content.js +9 -6
  130. package/dist/src/drawer/mdc-drawer-content.js.map +1 -0
  131. package/dist/src/drawer/mdc-drawer-header/mdc-drawer-header.js +46 -0
  132. package/dist/src/drawer/mdc-drawer-header/mdc-drawer-header.js.map +1 -0
  133. package/dist/{drawer → src/drawer}/mdc-drawer.js +24 -21
  134. package/dist/src/drawer/mdc-drawer.js.map +1 -0
  135. package/dist/{elevation → src/elevation}/mdc-elevation.js +9 -6
  136. package/dist/src/elevation/mdc-elevation.js.map +1 -0
  137. package/dist/{expandable → src/expandable}/mdc-expandable.js +20 -17
  138. package/dist/src/expandable/mdc-expandable.js.map +1 -0
  139. package/dist/{fab → src/fab}/enhance-mdc-fab.js +9 -6
  140. package/dist/src/fab/enhance-mdc-fab.js.map +1 -0
  141. package/dist/{fab → src/fab}/mdc-fab-icon.js +9 -6
  142. package/dist/src/fab/mdc-fab-icon.js.map +1 -0
  143. package/dist/src/fab/mdc-fab.js +93 -0
  144. package/dist/src/fab/mdc-fab.js.map +1 -0
  145. package/dist/{floating-label → src/floating-label}/mdc-floating-label.js +16 -13
  146. package/dist/src/floating-label/mdc-floating-label.js.map +1 -0
  147. package/dist/src/form-field/mdc-form-field.js +85 -0
  148. package/dist/src/form-field/mdc-form-field.js.map +1 -0
  149. package/dist/src/icon/mdc-icon.js +32 -0
  150. package/dist/src/icon/mdc-icon.js.map +1 -0
  151. package/dist/{icon-button → src/icon-button}/enhance-mdc-icon-button.js +9 -6
  152. package/dist/src/icon-button/enhance-mdc-icon-button.js.map +1 -0
  153. package/dist/src/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js +47 -0
  154. package/dist/src/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js.map +1 -0
  155. package/dist/src/icon-button/mdc-icon-button.js +102 -0
  156. package/dist/src/icon-button/mdc-icon-button.js.map +1 -0
  157. package/dist/src/image-list/mdc-image-list-item/mdc-image-list-item.js +61 -0
  158. package/dist/src/image-list/mdc-image-list-item/mdc-image-list-item.js.map +1 -0
  159. package/dist/{image-list → src/image-list}/mdc-image-list.js +35 -32
  160. package/dist/src/image-list/mdc-image-list.js.map +1 -0
  161. package/dist/src/index.js +337 -0
  162. package/dist/src/index.js.map +1 -0
  163. package/dist/src/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js +95 -0
  164. package/dist/src/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js.map +1 -0
  165. package/dist/{layout-grid → src/layout-grid}/mdc-layout-grid-inner.js +9 -6
  166. package/dist/src/layout-grid/mdc-layout-grid-inner.js.map +1 -0
  167. package/dist/src/layout-grid/mdc-layout-grid.js +109 -0
  168. package/dist/src/layout-grid/mdc-layout-grid.js.map +1 -0
  169. package/dist/{line-ripple → src/line-ripple}/mdc-line-ripple.js +13 -10
  170. package/dist/src/line-ripple/mdc-line-ripple.js.map +1 -0
  171. package/dist/{linear-progress → src/linear-progress}/mdc-linear-progress.js +26 -23
  172. package/dist/src/linear-progress/mdc-linear-progress.js.map +1 -0
  173. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js +47 -0
  174. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js.map +1 -0
  175. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-group.js +17 -14
  176. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-group.js.map +1 -0
  177. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js +9 -6
  178. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js.map +1 -0
  179. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js +9 -6
  180. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js.map +1 -0
  181. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js +9 -6
  182. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js.map +1 -0
  183. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js +112 -0
  184. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js.map +1 -0
  185. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js +9 -6
  186. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js.map +1 -0
  187. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js +9 -6
  188. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js.map +1 -0
  189. package/dist/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list.js +78 -75
  190. package/dist/src/list/mdc-deprecated-list/mdc-deprecated-list.js.map +1 -0
  191. package/dist/src/list/mdc-list-divider/mdc-list-divider.js +54 -0
  192. package/dist/src/list/mdc-list-divider/mdc-list-divider.js.map +1 -0
  193. package/dist/{list → src/list}/mdc-list-group.js +17 -14
  194. package/dist/src/list/mdc-list-group.js.map +1 -0
  195. package/dist/{list → src/list}/mdc-list-item/enhance-mdc-list-item.js +9 -6
  196. package/dist/src/list/mdc-list-item/enhance-mdc-list-item.js.map +1 -0
  197. package/dist/{list → src/list}/mdc-list-item/mdc-list-item-leading.js +9 -6
  198. package/dist/src/list/mdc-list-item/mdc-list-item-leading.js.map +1 -0
  199. package/dist/{list → src/list}/mdc-list-item/mdc-list-item-trailing.js +9 -6
  200. package/dist/src/list/mdc-list-item/mdc-list-item-trailing.js.map +1 -0
  201. package/dist/src/list/mdc-list-item/mdc-list-item.js +155 -0
  202. package/dist/src/list/mdc-list-item/mdc-list-item.js.map +1 -0
  203. package/dist/src/list/mdc-list-item-overline-text.js +28 -0
  204. package/dist/src/list/mdc-list-item-overline-text.js.map +1 -0
  205. package/dist/{list → src/list}/mdc-list-item-primary-text.js +9 -6
  206. package/dist/src/list/mdc-list-item-primary-text.js.map +1 -0
  207. package/dist/{list → src/list}/mdc-list-item-secondary-text.js +9 -6
  208. package/dist/src/list/mdc-list-item-secondary-text.js.map +1 -0
  209. package/dist/{list → src/list}/mdc-list.js +58 -55
  210. package/dist/src/list/mdc-list.js.map +1 -0
  211. package/dist/{lookup → src/lookup}/discardable-promise.js +5 -1
  212. package/dist/src/lookup/discardable-promise.js.map +1 -0
  213. package/dist/{lookup → src/lookup}/mdc-lookup-configuration.js +5 -1
  214. package/dist/src/lookup/mdc-lookup-configuration.js.map +1 -0
  215. package/dist/{lookup → src/lookup}/mdc-lookup.js +74 -71
  216. package/dist/src/lookup/mdc-lookup.js.map +1 -0
  217. package/dist/src/mdc-configuration.js +17 -0
  218. package/dist/src/mdc-configuration.js.map +1 -0
  219. package/dist/{menu → src/menu}/mdc-menu-selection-group-icon.js +9 -6
  220. package/dist/src/menu/mdc-menu-selection-group-icon.js.map +1 -0
  221. package/dist/src/menu/mdc-menu-selection-group.js +24 -0
  222. package/dist/src/menu/mdc-menu-selection-group.js.map +1 -0
  223. package/dist/{menu → src/menu}/mdc-menu.js +71 -68
  224. package/dist/src/menu/mdc-menu.js.map +1 -0
  225. package/dist/src/menu-surface/mdc-menu-surface-anchor.js +32 -0
  226. package/dist/src/menu-surface/mdc-menu-surface-anchor.js.map +1 -0
  227. package/dist/{menu-surface → src/menu-surface}/mdc-menu-surface.js +61 -58
  228. package/dist/src/menu-surface/mdc-menu-surface.js.map +1 -0
  229. package/dist/{notched-outline → src/notched-outline}/mdc-notched-outline.js +20 -17
  230. package/dist/src/notched-outline/mdc-notched-outline.js.map +1 -0
  231. package/dist/{radio → src/radio}/mdc-radio.js +27 -24
  232. package/dist/src/radio/mdc-radio.js.map +1 -0
  233. package/dist/src/ripple/mdc-ripple.js +150 -0
  234. package/dist/src/ripple/mdc-ripple.js.map +1 -0
  235. package/dist/{segmented-button → src/segmented-button}/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js +9 -6
  236. package/dist/src/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js.map +1 -0
  237. package/dist/{segmented-button → src/segmented-button}/mdc-segmented-button-segment/mdc-segmented-button-segment.js +27 -24
  238. package/dist/src/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.js.map +1 -0
  239. package/dist/{segmented-button → src/segmented-button}/mdc-segmented-button.js +24 -21
  240. package/dist/src/segmented-button/mdc-segmented-button.js.map +1 -0
  241. package/dist/src/select/mdc-default-select-configuration.js +8 -0
  242. package/dist/src/select/mdc-default-select-configuration.js.map +1 -0
  243. package/dist/{select → src/select}/mdc-select-adapter-aurelia.js +2 -1
  244. package/dist/src/select/mdc-select-adapter-aurelia.js.map +1 -0
  245. package/dist/{select → src/select}/mdc-select-foundation-aurelia.js +47 -43
  246. package/dist/src/select/mdc-select-foundation-aurelia.js.map +1 -0
  247. package/dist/src/select/mdc-select-helper-text/mdc-select-helper-text.js +75 -0
  248. package/dist/src/select/mdc-select-helper-text/mdc-select-helper-text.js.map +1 -0
  249. package/dist/{select → src/select}/mdc-select-icon.js +16 -13
  250. package/dist/src/select/mdc-select-icon.js.map +1 -0
  251. package/dist/{select → src/select}/mdc-select-value-observer.js +16 -12
  252. package/dist/src/select/mdc-select-value-observer.js.map +1 -0
  253. package/dist/{select → src/select}/mdc-select.js +71 -68
  254. package/dist/src/select/mdc-select.js.map +1 -0
  255. package/dist/{slider → src/slider}/mdc-slider-foundation-aurelia.js +6 -2
  256. package/dist/src/slider/mdc-slider-foundation-aurelia.js.map +1 -0
  257. package/dist/{slider → src/slider}/mdc-slider.js +79 -76
  258. package/dist/src/slider/mdc-slider.js.map +1 -0
  259. package/dist/{snackbar → src/snackbar}/mdc-snackbar-service.js +8 -4
  260. package/dist/src/snackbar/mdc-snackbar-service.js.map +1 -0
  261. package/dist/src/snackbar/mdc-snackbar.js +144 -0
  262. package/dist/src/snackbar/mdc-snackbar.js.map +1 -0
  263. package/dist/{switch → src/switch}/enhance-mdc-switch.js +9 -6
  264. package/dist/src/switch/enhance-mdc-switch.js.map +1 -0
  265. package/dist/{switch → src/switch}/mdc-switch.js +16 -13
  266. package/dist/src/switch/mdc-switch.js.map +1 -0
  267. package/dist/src/tab-bar/indicator/mdc-tab-indicator.js +75 -0
  268. package/dist/src/tab-bar/indicator/mdc-tab-indicator.js.map +1 -0
  269. package/dist/{tab-bar → src/tab-bar}/mdc-tab-bar.js +29 -26
  270. package/dist/src/tab-bar/mdc-tab-bar.js.map +1 -0
  271. package/dist/{tab-bar → src/tab-bar}/scroller/mdc-tab-scroller.js +25 -22
  272. package/dist/src/tab-bar/scroller/mdc-tab-scroller.js.map +1 -0
  273. package/dist/src/tab-bar/tab/mdc-tab.js +146 -0
  274. package/dist/src/tab-bar/tab/mdc-tab.js.map +1 -0
  275. package/dist/{text-field → src/text-field}/enhance-mdc-text-field.js +9 -6
  276. package/dist/src/text-field/enhance-mdc-text-field.js.map +1 -0
  277. package/dist/src/text-field/mdc-default-text-field-configuration.js +8 -0
  278. package/dist/src/text-field/mdc-default-text-field-configuration.js.map +1 -0
  279. package/dist/src/text-field/mdc-inputmask.js +76 -0
  280. package/dist/src/text-field/mdc-inputmask.js.map +1 -0
  281. package/dist/{text-field → src/text-field}/mdc-text-field-character-counter.js +13 -10
  282. package/dist/src/text-field/mdc-text-field-character-counter.js.map +1 -0
  283. package/dist/src/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js +45 -0
  284. package/dist/src/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js.map +1 -0
  285. package/dist/src/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js +65 -0
  286. package/dist/src/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js.map +1 -0
  287. package/dist/{text-field → src/text-field}/mdc-text-field-icon.js +22 -19
  288. package/dist/src/text-field/mdc-text-field-icon.js.map +1 -0
  289. package/dist/{text-field → src/text-field}/mdc-text-field.js +116 -113
  290. package/dist/src/text-field/mdc-text-field.js.map +1 -0
  291. package/dist/src/tooltip/mdc-default-tooltip-configuration.js +10 -0
  292. package/dist/src/tooltip/mdc-default-tooltip-configuration.js.map +1 -0
  293. package/dist/src/tooltip/mdc-tooltip-attribute.js +151 -0
  294. package/dist/src/tooltip/mdc-tooltip-attribute.js.map +1 -0
  295. package/dist/{tooltip → src/tooltip}/mdc-tooltip.js +66 -63
  296. package/dist/src/tooltip/mdc-tooltip.js.map +1 -0
  297. package/dist/{top-app-bar → src/top-app-bar}/enhance-top-app-bar-actions.js +9 -6
  298. package/dist/src/top-app-bar/enhance-top-app-bar-actions.js.map +1 -0
  299. package/dist/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-action-item.js +9 -6
  300. package/dist/src/top-app-bar/mdc-top-app-bar-action-item.js.map +1 -0
  301. package/dist/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-fixed-adjust.js +9 -6
  302. package/dist/src/top-app-bar/mdc-top-app-bar-fixed-adjust.js.map +1 -0
  303. package/dist/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-nav-icon.js +9 -6
  304. package/dist/src/top-app-bar/mdc-top-app-bar-nav-icon.js.map +1 -0
  305. package/dist/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-row.js +9 -6
  306. package/dist/src/top-app-bar/mdc-top-app-bar-row.js.map +1 -0
  307. package/dist/src/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js +35 -0
  308. package/dist/src/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js.map +1 -0
  309. package/dist/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-title.js +9 -6
  310. package/dist/src/top-app-bar/mdc-top-app-bar-title.js.map +1 -0
  311. package/dist/src/top-app-bar/mdc-top-app-bar.js +124 -0
  312. package/dist/src/top-app-bar/mdc-top-app-bar.js.map +1 -0
  313. package/dist/src/tree-view/i-tree-node.js +3 -0
  314. package/dist/src/tree-view/i-tree-node.js.map +1 -0
  315. package/dist/{tree-view → src/tree-view}/mdc-tree-node-meta.js +9 -6
  316. package/dist/src/tree-view/mdc-tree-node-meta.js.map +1 -0
  317. package/dist/src/tree-view/mdc-tree-node.js +24 -0
  318. package/dist/src/tree-view/mdc-tree-node.js.map +1 -0
  319. package/dist/{tree-view → src/tree-view}/mdc-tree-view.js +29 -25
  320. package/dist/src/tree-view/mdc-tree-view.js.map +1 -0
  321. package/dist/{tree-view → src/tree-view}/node-filter.js +9 -6
  322. package/dist/src/tree-view/node-filter.js.map +1 -0
  323. package/dist/{typography → src/typography}/mdc-typography.js +60 -57
  324. package/dist/src/typography/mdc-typography.js.map +1 -0
  325. package/dist/src/validation/mdc-validation-controller-factory.js +21 -0
  326. package/dist/src/validation/mdc-validation-controller-factory.js.map +1 -0
  327. package/dist/{validation → src/validation}/mdc-validation-result-presenter.js +5 -1
  328. package/dist/src/validation/mdc-validation-result-presenter.js.map +1 -0
  329. package/dist/src/validation/validate.js +27 -0
  330. package/dist/src/validation/validate.js.map +1 -0
  331. package/dist/switch/mdc-switch.html +21 -21
  332. package/dist/tab-bar/indicator/mdc-tab-indicator.html +9 -9
  333. package/dist/tab-bar/mdc-tab-bar.html +6 -6
  334. package/dist/tab-bar/scroller/mdc-tab-scroller.html +11 -11
  335. package/dist/tab-bar/tab/mdc-tab.html +20 -20
  336. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.html +7 -7
  337. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.html +6 -6
  338. package/dist/text-field/mdc-text-field.html +29 -29
  339. package/dist/tooltip/mdc-tooltip.html +7 -7
  340. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.html +3 -3
  341. package/dist/top-app-bar/mdc-top-app-bar.html +9 -9
  342. package/dist/types/src/alert/alert-configuration.d.ts +8 -0
  343. package/dist/types/src/alert/alert-modal/alert-modal.d.ts +6 -0
  344. package/dist/types/src/alert/alert-modal/i-alert-modal-payload.d.ts +9 -0
  345. package/dist/types/src/alert/alert-service.d.ts +27 -0
  346. package/dist/types/src/alert/decorators/confirm-action.d.ts +3 -0
  347. package/dist/types/src/alert/decorators/using-progress.d.ts +6 -0
  348. package/dist/types/src/alert/exceptions-tracker.d.ts +3 -0
  349. package/dist/types/src/alert/global-progress/global-progress.d.ts +11 -0
  350. package/dist/types/src/alert/prompt-dialog/prompt-dialog.d.ts +21 -0
  351. package/dist/types/{data-table → src/data-table}/mdc-data-table.d.ts +16 -4
  352. package/dist/types/{index.d.ts → src/index.d.ts} +11 -1
  353. package/dist/types/{lookup → src/lookup}/mdc-lookup.d.ts +3 -3
  354. package/dist/types/{mdc-configuration.d.ts → src/mdc-configuration.d.ts} +2 -0
  355. package/dist/types/{select → src/select}/mdc-select.d.ts +3 -3
  356. package/dist/types/src/text-field/mdc-inputmask.d.ts +11 -0
  357. package/dist/types/{text-field → src/text-field}/mdc-text-field.d.ts +3 -3
  358. package/dist/types/{tooltip → src/tooltip}/mdc-tooltip.d.ts +3 -3
  359. package/dist/types/src/validation/validate.d.ts +10 -0
  360. package/package.json +5 -3
  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/mdc-chip.ts +290 -290
  403. package/src/chips/mdc-chip-action/enhance-mdc-chip-action.ts +8 -8
  404. package/src/chips/mdc-chip-action/mdc-chip-action.html +25 -25
  405. package/src/chips/mdc-chip-action/mdc-chip-action.ts +143 -143
  406. package/src/chips/mdc-chip-set/mdc-chip-set.html +10 -10
  407. package/src/chips/mdc-chip-set/mdc-chip-set.ts +117 -117
  408. package/src/circular-progress/mdc-circular-progress.html +38 -38
  409. package/src/circular-progress/mdc-circular-progress.ts +91 -91
  410. package/src/circular-progress/styles/_index.scss +1 -1
  411. package/src/circular-progress/styles/mdc-circular-progress.import.scss +1 -1
  412. package/src/circular-progress/styles/mdc-circular-progress.scss +14 -14
  413. package/src/data-table/mdc-data-table-row.ts +24 -24
  414. package/src/data-table/mdc-data-table.html +50 -49
  415. package/src/data-table/mdc-data-table.ts +530 -432
  416. package/src/data-table/styles/_index.scss +1 -0
  417. package/src/data-table/styles/mdc-data-table.import.scss +1 -0
  418. package/src/data-table/styles/mdc-data-table.scss +64 -0
  419. package/src/dialog/mdc-dialog-actions.ts +23 -23
  420. package/src/dialog/mdc-dialog-content.ts +11 -11
  421. package/src/dialog/mdc-dialog-service.ts +3 -0
  422. package/src/dialog/mdc-dialog-title.ts +8 -8
  423. package/src/dialog/mdc-dialog.html +14 -14
  424. package/src/dialog/mdc-dialog.ts +224 -224
  425. package/src/drawer/mdc-drawer-app-content.ts +11 -11
  426. package/src/drawer/mdc-drawer-content.ts +11 -11
  427. package/src/drawer/mdc-drawer-header/mdc-drawer-header.html +5 -5
  428. package/src/drawer/mdc-drawer-header/mdc-drawer-header.ts +18 -18
  429. package/src/drawer/mdc-drawer.html +6 -6
  430. package/src/drawer/mdc-drawer.ts +125 -125
  431. package/src/elevation/mdc-elevation.ts +23 -23
  432. package/src/expandable/mdc-expandable.html +28 -28
  433. package/src/expandable/mdc-expandable.ts +104 -104
  434. package/src/expandable/styles/_icon-variables.scss +3 -3
  435. package/src/expandable/styles/_index.scss +1 -1
  436. package/src/expandable/styles/_mixins.scss +287 -287
  437. package/src/expandable/styles/_variables.scss +17 -17
  438. package/src/expandable/styles/mdc-expandable.import.scss +1 -1
  439. package/src/expandable/styles/mdc-expandable.scss +3 -3
  440. package/src/fab/enhance-mdc-fab.ts +8 -8
  441. package/src/fab/mdc-fab-icon.ts +15 -15
  442. package/src/fab/mdc-fab.html +13 -13
  443. package/src/fab/mdc-fab.ts +50 -50
  444. package/src/floating-label/mdc-floating-label.html +1 -1
  445. package/src/floating-label/mdc-floating-label.ts +44 -44
  446. package/src/form-field/mdc-form-field.html +6 -6
  447. package/src/form-field/mdc-form-field.ts +60 -60
  448. package/src/icon/mdc-icon.html +3 -3
  449. package/src/icon/mdc-icon.ts +11 -11
  450. package/src/icon-button/enhance-mdc-icon-button.ts +8 -8
  451. package/src/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.html +4 -4
  452. package/src/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.ts +29 -29
  453. package/src/icon-button/mdc-icon-button.html +11 -11
  454. package/src/icon-button/mdc-icon-button.ts +69 -69
  455. package/src/image-list/mdc-image-list-item/mdc-image-list-item.html +9 -9
  456. package/src/image-list/mdc-image-list-item/mdc-image-list-item.ts +31 -31
  457. package/src/image-list/mdc-image-list.html +7 -7
  458. package/src/image-list/mdc-image-list.ts +73 -73
  459. package/src/image-list/styles/_index.scss +1 -1
  460. package/src/image-list/styles/mdc-image-list.import.scss +1 -1
  461. package/src/image-list/styles/mdc-image-list.scss +7 -7
  462. package/src/index.ts +17 -3
  463. package/src/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.html +12 -12
  464. package/src/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.ts +49 -49
  465. package/src/layout-grid/mdc-layout-grid-inner.ts +8 -8
  466. package/src/layout-grid/mdc-layout-grid.html +8 -8
  467. package/src/layout-grid/mdc-layout-grid.ts +67 -67
  468. package/src/layout-grid/styles/_index.scss +1 -1
  469. package/src/layout-grid/styles/mdc-layout-grid.import.scss +1 -1
  470. package/src/layout-grid/styles/mdc-layout-grid.scss +11 -11
  471. package/src/line-ripple/mdc-line-ripple.ts +41 -41
  472. package/src/linear-progress/mdc-linear-progress.html +12 -12
  473. package/src/linear-progress/mdc-linear-progress.ts +103 -103
  474. package/src/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.html +4 -4
  475. package/src/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.ts +18 -18
  476. package/src/list/mdc-deprecated-list/mdc-deprecated-list-group.ts +27 -27
  477. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.ts +8 -8
  478. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.ts +15 -15
  479. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.ts +15 -15
  480. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.html +8 -8
  481. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.ts +108 -108
  482. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.ts +11 -11
  483. package/src/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.ts +11 -11
  484. package/src/list/mdc-deprecated-list/mdc-deprecated-list.html +15 -15
  485. package/src/list/mdc-deprecated-list/mdc-deprecated-list.ts +331 -331
  486. package/src/list/mdc-list-divider/mdc-list-divider.html +7 -7
  487. package/src/list/mdc-list-divider/mdc-list-divider.ts +24 -24
  488. package/src/list/mdc-list-group.ts +27 -27
  489. package/src/list/mdc-list-item/enhance-mdc-list-item.ts +8 -8
  490. package/src/list/mdc-list-item/mdc-list-item-leading.ts +34 -34
  491. package/src/list/mdc-list-item/mdc-list-item-trailing.ts +36 -36
  492. package/src/list/mdc-list-item/mdc-list-item.html +13 -13
  493. package/src/list/mdc-list-item/mdc-list-item.ts +136 -136
  494. package/src/list/mdc-list-item-overline-text.ts +8 -8
  495. package/src/list/mdc-list-item-primary-text.ts +11 -11
  496. package/src/list/mdc-list-item-secondary-text.ts +11 -11
  497. package/src/list/mdc-list.html +5 -5
  498. package/src/list/mdc-list.ts +300 -300
  499. package/src/lookup/discardable-promise.ts +24 -24
  500. package/src/lookup/mdc-lookup-configuration.ts +11 -11
  501. package/src/lookup/mdc-lookup.html +27 -27
  502. package/src/lookup/mdc-lookup.ts +5 -5
  503. package/src/mdc-configuration.ts +2 -0
  504. package/src/menu/mdc-menu-selection-group-icon.ts +11 -11
  505. package/src/menu/mdc-menu-selection-group.ts +4 -4
  506. package/src/menu/mdc-menu.html +6 -6
  507. package/src/menu/mdc-menu.ts +340 -340
  508. package/src/menu-surface/mdc-menu-surface-anchor.ts +12 -12
  509. package/src/menu-surface/mdc-menu-surface.ts +275 -275
  510. package/src/notched-outline/mdc-notched-outline.html +7 -7
  511. package/src/notched-outline/mdc-notched-outline.ts +60 -60
  512. package/src/radio/mdc-radio.html +9 -9
  513. package/src/radio/mdc-radio.ts +162 -162
  514. package/src/resource.d.ts +22 -22
  515. package/src/ripple/mdc-ripple.ts +114 -114
  516. package/src/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.ts +8 -8
  517. package/src/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.html +11 -11
  518. package/src/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.ts +170 -170
  519. package/src/segmented-button/mdc-segmented-button.html +3 -3
  520. package/src/segmented-button/mdc-segmented-button.ts +89 -89
  521. package/src/select/mdc-default-select-configuration.ts +3 -3
  522. package/src/select/mdc-select-adapter-aurelia.ts +213 -213
  523. package/src/select/mdc-select-foundation-aurelia.ts +484 -484
  524. package/src/select/mdc-select-helper-text/mdc-select-helper-text.html +7 -7
  525. package/src/select/mdc-select-helper-text/mdc-select-helper-text.ts +55 -55
  526. package/src/select/mdc-select-icon.ts +41 -41
  527. package/src/select/mdc-select-value-observer.ts +2 -1
  528. package/src/select/mdc-select.html +38 -38
  529. package/src/select/mdc-select.ts +4 -4
  530. package/src/slider/mdc-slider-foundation-aurelia.ts +13 -13
  531. package/src/slider/mdc-slider.html +36 -36
  532. package/src/slider/mdc-slider.ts +409 -409
  533. package/src/slider/styles/_index.scss +1 -1
  534. package/src/slider/styles/mdc-slider.import.scss +1 -1
  535. package/src/slider/styles/mdc-slider.scss +8 -8
  536. package/src/snackbar/mdc-snackbar-service.ts +48 -48
  537. package/src/snackbar/mdc-snackbar.html +14 -14
  538. package/src/snackbar/mdc-snackbar.ts +109 -109
  539. package/src/switch/enhance-mdc-switch.ts +8 -8
  540. package/src/switch/mdc-switch.html +21 -21
  541. package/src/switch/mdc-switch.ts +86 -86
  542. package/src/tab-bar/indicator/mdc-tab-indicator.html +9 -9
  543. package/src/tab-bar/indicator/mdc-tab-indicator.ts +51 -51
  544. package/src/tab-bar/mdc-tab-bar.html +6 -6
  545. package/src/tab-bar/mdc-tab-bar.ts +119 -119
  546. package/src/tab-bar/scroller/mdc-tab-scroller.html +11 -11
  547. package/src/tab-bar/scroller/mdc-tab-scroller.ts +85 -85
  548. package/src/tab-bar/tab/mdc-tab.html +20 -20
  549. package/src/tab-bar/tab/mdc-tab.ts +118 -118
  550. package/src/text-field/enhance-mdc-text-field.ts +12 -12
  551. package/src/text-field/mdc-default-text-field-configuration.ts +3 -3
  552. package/src/text-field/mdc-inputmask.ts +45 -0
  553. package/src/text-field/mdc-text-field-character-counter.ts +32 -32
  554. package/src/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.html +7 -7
  555. package/src/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.ts +37 -37
  556. package/src/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.html +6 -6
  557. package/src/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.ts +47 -47
  558. package/src/text-field/mdc-text-field-icon.ts +59 -59
  559. package/src/text-field/mdc-text-field.html +29 -29
  560. package/src/text-field/mdc-text-field.ts +4 -4
  561. package/src/tooltip/mdc-default-tooltip-configuration.ts +5 -5
  562. package/src/tooltip/mdc-tooltip-attribute.ts +118 -118
  563. package/src/tooltip/mdc-tooltip.html +7 -7
  564. package/src/tooltip/mdc-tooltip.ts +6 -6
  565. package/src/top-app-bar/enhance-top-app-bar-actions.ts +9 -9
  566. package/src/top-app-bar/mdc-top-app-bar-action-item.ts +12 -12
  567. package/src/top-app-bar/mdc-top-app-bar-fixed-adjust.ts +13 -13
  568. package/src/top-app-bar/mdc-top-app-bar-nav-icon.ts +12 -12
  569. package/src/top-app-bar/mdc-top-app-bar-row.ts +7 -7
  570. package/src/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.html +3 -3
  571. package/src/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.ts +9 -9
  572. package/src/top-app-bar/mdc-top-app-bar-title.ts +7 -7
  573. package/src/top-app-bar/mdc-top-app-bar.html +9 -9
  574. package/src/top-app-bar/mdc-top-app-bar.ts +93 -93
  575. package/src/tree-view/i-tree-node.ts +8 -8
  576. package/src/tree-view/mdc-tree-node-meta.ts +11 -11
  577. package/src/tree-view/mdc-tree-node.ts +4 -4
  578. package/src/tree-view/mdc-tree-view.ts +147 -147
  579. package/src/tree-view/node-filter.ts +12 -12
  580. package/src/tree-view/styles/_index.scss +1 -1
  581. package/src/tree-view/styles/_mixins.scss +145 -145
  582. package/src/tree-view/styles/_variables.scss +8 -8
  583. package/src/tree-view/styles/mdc-tree-view.import.scss +1 -1
  584. package/src/tree-view/styles/mdc-tree-view.scss +3 -3
  585. package/src/typography/mdc-typography.ts +130 -130
  586. package/src/validation/mdc-validation-controller-factory.ts +20 -20
  587. package/src/validation/mdc-validation-result-presenter.ts +36 -36
  588. package/src/validation/validate.ts +32 -0
  589. package/styles/mdc-all.scss +53 -52
  590. package/dist/banner/mdc-banner.js +0 -151
  591. package/dist/banner/mdc-banner.js.map +0 -1
  592. package/dist/base/attributes/mdc-focus-trap.js +0 -68
  593. package/dist/base/attributes/mdc-focus-trap.js.map +0 -1
  594. package/dist/base/elements/i-validated-element.js +0 -2
  595. package/dist/base/elements/i-validated-element.js.map +0 -1
  596. package/dist/base/elements/mdc-promisify-reference.js +0 -45
  597. package/dist/base/elements/mdc-promisify-reference.js.map +0 -1
  598. package/dist/base/index.js +0 -20
  599. package/dist/base/index.js.map +0 -1
  600. package/dist/base/interceptors.js +0 -22
  601. package/dist/base/interceptors.js.map +0 -1
  602. package/dist/base/material-palette.js.map +0 -1
  603. package/dist/base/mdc-component.js.map +0 -1
  604. package/dist/base/next-element.js.map +0 -1
  605. package/dist/button/enhance-mdc-button.js.map +0 -1
  606. package/dist/button/mdc-button-label.js.map +0 -1
  607. package/dist/button/mdc-button.js +0 -99
  608. package/dist/button/mdc-button.js.map +0 -1
  609. package/dist/card/mdc-card-action-buttons.js.map +0 -1
  610. package/dist/card/mdc-card-action-icons.js.map +0 -1
  611. package/dist/card/mdc-card-actions/mdc-card-actions.js +0 -38
  612. package/dist/card/mdc-card-actions/mdc-card-actions.js.map +0 -1
  613. package/dist/card/mdc-card-media/mdc-card-media.js +0 -47
  614. package/dist/card/mdc-card-media/mdc-card-media.js.map +0 -1
  615. package/dist/card/mdc-card-primary-action.js +0 -38
  616. package/dist/card/mdc-card-primary-action.js.map +0 -1
  617. package/dist/card/mdc-card.js +0 -38
  618. package/dist/card/mdc-card.js.map +0 -1
  619. package/dist/checkbox/mdc-checkbox.js.map +0 -1
  620. package/dist/chips/mdc-chip/mdc-chip.js.map +0 -1
  621. package/dist/chips/mdc-chip-action/enhance-mdc-chip-action.js.map +0 -1
  622. package/dist/chips/mdc-chip-action/mdc-chip-action.js +0 -149
  623. package/dist/chips/mdc-chip-action/mdc-chip-action.js.map +0 -1
  624. package/dist/chips/mdc-chip-set/mdc-chip-set.js.map +0 -1
  625. package/dist/circular-progress/mdc-circular-progress.js.map +0 -1
  626. package/dist/data-table/mdc-data-table-row.js.map +0 -1
  627. package/dist/data-table/mdc-data-table.js +0 -427
  628. package/dist/data-table/mdc-data-table.js.map +0 -1
  629. package/dist/dialog/mdc-dialog-actions.js +0 -44
  630. package/dist/dialog/mdc-dialog-actions.js.map +0 -1
  631. package/dist/dialog/mdc-dialog-content.js.map +0 -1
  632. package/dist/dialog/mdc-dialog-service.js.map +0 -1
  633. package/dist/dialog/mdc-dialog-title.js +0 -25
  634. package/dist/dialog/mdc-dialog-title.js.map +0 -1
  635. package/dist/dialog/mdc-dialog.js.map +0 -1
  636. package/dist/drawer/mdc-drawer-app-content.js.map +0 -1
  637. package/dist/drawer/mdc-drawer-content.js.map +0 -1
  638. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.js +0 -43
  639. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.js.map +0 -1
  640. package/dist/drawer/mdc-drawer.js.map +0 -1
  641. package/dist/elevation/mdc-elevation.js.map +0 -1
  642. package/dist/expandable/mdc-expandable.js.map +0 -1
  643. package/dist/fab/enhance-mdc-fab.js.map +0 -1
  644. package/dist/fab/mdc-fab-icon.js.map +0 -1
  645. package/dist/fab/mdc-fab.js +0 -90
  646. package/dist/fab/mdc-fab.js.map +0 -1
  647. package/dist/floating-label/mdc-floating-label.js.map +0 -1
  648. package/dist/form-field/mdc-form-field.js +0 -82
  649. package/dist/form-field/mdc-form-field.js.map +0 -1
  650. package/dist/icon/mdc-icon.js +0 -29
  651. package/dist/icon/mdc-icon.js.map +0 -1
  652. package/dist/icon-button/enhance-mdc-icon-button.js.map +0 -1
  653. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js +0 -44
  654. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js.map +0 -1
  655. package/dist/icon-button/mdc-icon-button.js +0 -99
  656. package/dist/icon-button/mdc-icon-button.js.map +0 -1
  657. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.js +0 -58
  658. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.js.map +0 -1
  659. package/dist/image-list/mdc-image-list.js.map +0 -1
  660. package/dist/index.js +0 -179
  661. package/dist/index.js.map +0 -1
  662. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js +0 -92
  663. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js.map +0 -1
  664. package/dist/layout-grid/mdc-layout-grid-inner.js.map +0 -1
  665. package/dist/layout-grid/mdc-layout-grid.js +0 -106
  666. package/dist/layout-grid/mdc-layout-grid.js.map +0 -1
  667. package/dist/line-ripple/mdc-line-ripple.js.map +0 -1
  668. package/dist/linear-progress/mdc-linear-progress.js.map +0 -1
  669. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js +0 -44
  670. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js.map +0 -1
  671. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-group.js.map +0 -1
  672. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js.map +0 -1
  673. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js.map +0 -1
  674. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js.map +0 -1
  675. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js +0 -109
  676. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js.map +0 -1
  677. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js.map +0 -1
  678. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js.map +0 -1
  679. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.js.map +0 -1
  680. package/dist/list/mdc-list-divider/mdc-list-divider.js +0 -51
  681. package/dist/list/mdc-list-divider/mdc-list-divider.js.map +0 -1
  682. package/dist/list/mdc-list-group.js.map +0 -1
  683. package/dist/list/mdc-list-item/enhance-mdc-list-item.js.map +0 -1
  684. package/dist/list/mdc-list-item/mdc-list-item-leading.js.map +0 -1
  685. package/dist/list/mdc-list-item/mdc-list-item-trailing.js.map +0 -1
  686. package/dist/list/mdc-list-item/mdc-list-item.js +0 -152
  687. package/dist/list/mdc-list-item/mdc-list-item.js.map +0 -1
  688. package/dist/list/mdc-list-item-overline-text.js +0 -25
  689. package/dist/list/mdc-list-item-overline-text.js.map +0 -1
  690. package/dist/list/mdc-list-item-primary-text.js.map +0 -1
  691. package/dist/list/mdc-list-item-secondary-text.js.map +0 -1
  692. package/dist/list/mdc-list.js.map +0 -1
  693. package/dist/lookup/discardable-promise.js.map +0 -1
  694. package/dist/lookup/mdc-lookup-configuration.js.map +0 -1
  695. package/dist/lookup/mdc-lookup.js.map +0 -1
  696. package/dist/mdc-configuration.js +0 -11
  697. package/dist/mdc-configuration.js.map +0 -1
  698. package/dist/menu/mdc-menu-selection-group-icon.js.map +0 -1
  699. package/dist/menu/mdc-menu-selection-group.js +0 -21
  700. package/dist/menu/mdc-menu-selection-group.js.map +0 -1
  701. package/dist/menu/mdc-menu.js.map +0 -1
  702. package/dist/menu-surface/mdc-menu-surface-anchor.js +0 -29
  703. package/dist/menu-surface/mdc-menu-surface-anchor.js.map +0 -1
  704. package/dist/menu-surface/mdc-menu-surface.js.map +0 -1
  705. package/dist/notched-outline/mdc-notched-outline.js.map +0 -1
  706. package/dist/radio/mdc-radio.js.map +0 -1
  707. package/dist/ripple/mdc-ripple.js +0 -147
  708. package/dist/ripple/mdc-ripple.js.map +0 -1
  709. package/dist/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js.map +0 -1
  710. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.js.map +0 -1
  711. package/dist/segmented-button/mdc-segmented-button.js.map +0 -1
  712. package/dist/select/mdc-default-select-configuration.js +0 -4
  713. package/dist/select/mdc-default-select-configuration.js.map +0 -1
  714. package/dist/select/mdc-select-adapter-aurelia.js.map +0 -1
  715. package/dist/select/mdc-select-foundation-aurelia.js.map +0 -1
  716. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.js +0 -72
  717. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.js.map +0 -1
  718. package/dist/select/mdc-select-icon.js.map +0 -1
  719. package/dist/select/mdc-select-value-observer.js.map +0 -1
  720. package/dist/select/mdc-select.js.map +0 -1
  721. package/dist/slider/mdc-slider-foundation-aurelia.js.map +0 -1
  722. package/dist/slider/mdc-slider.js.map +0 -1
  723. package/dist/snackbar/mdc-snackbar-service.js.map +0 -1
  724. package/dist/snackbar/mdc-snackbar.js +0 -141
  725. package/dist/snackbar/mdc-snackbar.js.map +0 -1
  726. package/dist/switch/enhance-mdc-switch.js.map +0 -1
  727. package/dist/switch/mdc-switch.js.map +0 -1
  728. package/dist/tab-bar/indicator/mdc-tab-indicator.js +0 -72
  729. package/dist/tab-bar/indicator/mdc-tab-indicator.js.map +0 -1
  730. package/dist/tab-bar/mdc-tab-bar.js.map +0 -1
  731. package/dist/tab-bar/scroller/mdc-tab-scroller.js.map +0 -1
  732. package/dist/tab-bar/tab/mdc-tab.js +0 -143
  733. package/dist/tab-bar/tab/mdc-tab.js.map +0 -1
  734. package/dist/text-field/enhance-mdc-text-field.js.map +0 -1
  735. package/dist/text-field/mdc-default-text-field-configuration.js +0 -4
  736. package/dist/text-field/mdc-default-text-field-configuration.js.map +0 -1
  737. package/dist/text-field/mdc-text-field-character-counter.js.map +0 -1
  738. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js +0 -42
  739. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js.map +0 -1
  740. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js +0 -62
  741. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js.map +0 -1
  742. package/dist/text-field/mdc-text-field-icon.js.map +0 -1
  743. package/dist/text-field/mdc-text-field.js.map +0 -1
  744. package/dist/tooltip/mdc-default-tooltip-configuration.js +0 -6
  745. package/dist/tooltip/mdc-default-tooltip-configuration.js.map +0 -1
  746. package/dist/tooltip/mdc-tooltip-attribute.js +0 -148
  747. package/dist/tooltip/mdc-tooltip-attribute.js.map +0 -1
  748. package/dist/tooltip/mdc-tooltip.js.map +0 -1
  749. package/dist/top-app-bar/enhance-top-app-bar-actions.js.map +0 -1
  750. package/dist/top-app-bar/mdc-top-app-bar-action-item.js.map +0 -1
  751. package/dist/top-app-bar/mdc-top-app-bar-fixed-adjust.js.map +0 -1
  752. package/dist/top-app-bar/mdc-top-app-bar-nav-icon.js.map +0 -1
  753. package/dist/top-app-bar/mdc-top-app-bar-row.js.map +0 -1
  754. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js +0 -32
  755. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js.map +0 -1
  756. package/dist/top-app-bar/mdc-top-app-bar-title.js.map +0 -1
  757. package/dist/top-app-bar/mdc-top-app-bar.js +0 -121
  758. package/dist/top-app-bar/mdc-top-app-bar.js.map +0 -1
  759. package/dist/tree-view/i-tree-node.js +0 -2
  760. package/dist/tree-view/i-tree-node.js.map +0 -1
  761. package/dist/tree-view/mdc-tree-node-meta.js.map +0 -1
  762. package/dist/tree-view/mdc-tree-node.js +0 -21
  763. package/dist/tree-view/mdc-tree-node.js.map +0 -1
  764. package/dist/tree-view/mdc-tree-view.js.map +0 -1
  765. package/dist/tree-view/node-filter.js.map +0 -1
  766. package/dist/typography/mdc-typography.js.map +0 -1
  767. package/dist/validation/mdc-validation-controller-factory.js +0 -17
  768. package/dist/validation/mdc-validation-controller-factory.js.map +0 -1
  769. package/dist/validation/mdc-validation-result-presenter.js.map +0 -1
  770. package/src/banner/doc/api.json +0 -1106
  771. package/src/base/doc/api.json +0 -1408
  772. package/src/button/doc/api.json +0 -621
  773. package/src/card/doc/api.json +0 -214
  774. package/src/checkbox/doc/api.json +0 -1320
  775. package/src/chips/doc/api.json +0 -2533
  776. package/src/circular-progress/doc/api.json +0 -1085
  777. package/src/data-table/doc/api.json +0 -2064
  778. package/src/dialog/doc/api.json +0 -1667
  779. package/src/drawer/doc/api.json +0 -1416
  780. package/src/elevation/doc/api.json +0 -317
  781. package/src/expandable/doc/api.json +0 -677
  782. package/src/fab/doc/api.json +0 -396
  783. package/src/floating-label/doc/api.json +0 -914
  784. package/src/form-field/doc/api.json +0 -948
  785. package/src/icon/doc/api.json +0 -224
  786. package/src/icon-button/doc/api.json +0 -1109
  787. package/src/image-list/doc/api.json +0 -438
  788. package/src/layout-grid/doc/api.json +0 -600
  789. package/src/line-ripple/doc/api.json +0 -857
  790. package/src/linear-progress/doc/api.json +0 -949
  791. package/src/list/doc/api.json +0 -5725
  792. package/src/lookup/doc/api.json +0 -2370
  793. package/src/menu/doc/api.json +0 -2246
  794. package/src/menu-surface/doc/api.json +0 -1800
  795. package/src/notched-outline/doc/api.json +0 -943
  796. package/src/radio/doc/api.json +0 -1159
  797. package/src/ripple/doc/api.json +0 -1212
  798. package/src/segmented-button/doc/api.json +0 -1937
  799. package/src/select/doc/api.json +0 -4247
  800. package/src/slider/doc/api.json +0 -1954
  801. package/src/snackbar/doc/api.json +0 -1699
  802. package/src/switch/doc/api.json +0 -899
  803. package/src/tab-bar/doc/api.json +0 -4253
  804. package/src/text-field/doc/api.json +0 -3179
  805. package/src/tooltip/doc/api.json +0 -2531
  806. package/src/top-app-bar/doc/api.json +0 -1752
  807. package/src/tree-view/doc/api.json +0 -1710
  808. package/src/typography/doc/api.json +0 -3058
  809. package/src/validation/doc/api.json +0 -371
  810. /package/dist/types/{banner → src/banner}/mdc-banner.d.ts +0 -0
  811. /package/dist/types/{base → src/base}/attributes/mdc-focus-trap.d.ts +0 -0
  812. /package/dist/types/{base → src/base}/elements/i-validated-element.d.ts +0 -0
  813. /package/dist/types/{base → src/base}/elements/mdc-promisify-reference.d.ts +0 -0
  814. /package/dist/types/{base → src/base}/index.d.ts +0 -0
  815. /package/dist/types/{base → src/base}/interceptors.d.ts +0 -0
  816. /package/dist/types/{base → src/base}/material-palette.d.ts +0 -0
  817. /package/dist/types/{base → src/base}/mdc-component.d.ts +0 -0
  818. /package/dist/types/{base → src/base}/next-element.d.ts +0 -0
  819. /package/dist/types/{button → src/button}/enhance-mdc-button.d.ts +0 -0
  820. /package/dist/types/{button → src/button}/mdc-button-label.d.ts +0 -0
  821. /package/dist/types/{button → src/button}/mdc-button.d.ts +0 -0
  822. /package/dist/types/{card → src/card}/mdc-card-action-buttons.d.ts +0 -0
  823. /package/dist/types/{card → src/card}/mdc-card-action-icons.d.ts +0 -0
  824. /package/dist/types/{card → src/card}/mdc-card-actions/mdc-card-actions.d.ts +0 -0
  825. /package/dist/types/{card → src/card}/mdc-card-media/mdc-card-media.d.ts +0 -0
  826. /package/dist/types/{card → src/card}/mdc-card-primary-action.d.ts +0 -0
  827. /package/dist/types/{card → src/card}/mdc-card.d.ts +0 -0
  828. /package/dist/types/{checkbox → src/checkbox}/mdc-checkbox.d.ts +0 -0
  829. /package/dist/types/{chips → src/chips}/mdc-chip/mdc-chip.d.ts +0 -0
  830. /package/dist/types/{chips → src/chips}/mdc-chip-action/enhance-mdc-chip-action.d.ts +0 -0
  831. /package/dist/types/{chips → src/chips}/mdc-chip-action/mdc-chip-action.d.ts +0 -0
  832. /package/dist/types/{chips → src/chips}/mdc-chip-set/mdc-chip-set.d.ts +0 -0
  833. /package/dist/types/{circular-progress → src/circular-progress}/mdc-circular-progress.d.ts +0 -0
  834. /package/dist/types/{data-table → src/data-table}/mdc-data-table-row.d.ts +0 -0
  835. /package/dist/types/{dialog → src/dialog}/mdc-dialog-actions.d.ts +0 -0
  836. /package/dist/types/{dialog → src/dialog}/mdc-dialog-content.d.ts +0 -0
  837. /package/dist/types/{dialog → src/dialog}/mdc-dialog-service.d.ts +0 -0
  838. /package/dist/types/{dialog → src/dialog}/mdc-dialog-title.d.ts +0 -0
  839. /package/dist/types/{dialog → src/dialog}/mdc-dialog.d.ts +0 -0
  840. /package/dist/types/{drawer → src/drawer}/mdc-drawer-app-content.d.ts +0 -0
  841. /package/dist/types/{drawer → src/drawer}/mdc-drawer-content.d.ts +0 -0
  842. /package/dist/types/{drawer → src/drawer}/mdc-drawer-header/mdc-drawer-header.d.ts +0 -0
  843. /package/dist/types/{drawer → src/drawer}/mdc-drawer.d.ts +0 -0
  844. /package/dist/types/{elevation → src/elevation}/mdc-elevation.d.ts +0 -0
  845. /package/dist/types/{expandable → src/expandable}/mdc-expandable.d.ts +0 -0
  846. /package/dist/types/{fab → src/fab}/enhance-mdc-fab.d.ts +0 -0
  847. /package/dist/types/{fab → src/fab}/mdc-fab-icon.d.ts +0 -0
  848. /package/dist/types/{fab → src/fab}/mdc-fab.d.ts +0 -0
  849. /package/dist/types/{floating-label → src/floating-label}/mdc-floating-label.d.ts +0 -0
  850. /package/dist/types/{form-field → src/form-field}/mdc-form-field.d.ts +0 -0
  851. /package/dist/types/{icon → src/icon}/mdc-icon.d.ts +0 -0
  852. /package/dist/types/{icon-button → src/icon-button}/enhance-mdc-icon-button.d.ts +0 -0
  853. /package/dist/types/{icon-button → src/icon-button}/mdc-icon-button-icon/mdc-icon-button-icon.d.ts +0 -0
  854. /package/dist/types/{icon-button → src/icon-button}/mdc-icon-button.d.ts +0 -0
  855. /package/dist/types/{image-list → src/image-list}/mdc-image-list-item/mdc-image-list-item.d.ts +0 -0
  856. /package/dist/types/{image-list → src/image-list}/mdc-image-list.d.ts +0 -0
  857. /package/dist/types/{layout-grid → src/layout-grid}/mdc-layout-grid-cell/mdc-layout-grid-cell.d.ts +0 -0
  858. /package/dist/types/{layout-grid → src/layout-grid}/mdc-layout-grid-inner.d.ts +0 -0
  859. /package/dist/types/{layout-grid → src/layout-grid}/mdc-layout-grid.d.ts +0 -0
  860. /package/dist/types/{line-ripple → src/line-ripple}/mdc-line-ripple.d.ts +0 -0
  861. /package/dist/types/{linear-progress → src/linear-progress}/mdc-linear-progress.d.ts +0 -0
  862. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.d.ts +0 -0
  863. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-group.d.ts +0 -0
  864. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.d.ts +0 -0
  865. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.d.ts +0 -0
  866. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.d.ts +0 -0
  867. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.d.ts +0 -0
  868. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.d.ts +0 -0
  869. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.d.ts +0 -0
  870. /package/dist/types/{list → src/list}/mdc-deprecated-list/mdc-deprecated-list.d.ts +0 -0
  871. /package/dist/types/{list → src/list}/mdc-list-divider/mdc-list-divider.d.ts +0 -0
  872. /package/dist/types/{list → src/list}/mdc-list-group.d.ts +0 -0
  873. /package/dist/types/{list → src/list}/mdc-list-item/enhance-mdc-list-item.d.ts +0 -0
  874. /package/dist/types/{list → src/list}/mdc-list-item/mdc-list-item-leading.d.ts +0 -0
  875. /package/dist/types/{list → src/list}/mdc-list-item/mdc-list-item-trailing.d.ts +0 -0
  876. /package/dist/types/{list → src/list}/mdc-list-item/mdc-list-item.d.ts +0 -0
  877. /package/dist/types/{list → src/list}/mdc-list-item-overline-text.d.ts +0 -0
  878. /package/dist/types/{list → src/list}/mdc-list-item-primary-text.d.ts +0 -0
  879. /package/dist/types/{list → src/list}/mdc-list-item-secondary-text.d.ts +0 -0
  880. /package/dist/types/{list → src/list}/mdc-list.d.ts +0 -0
  881. /package/dist/types/{lookup → src/lookup}/discardable-promise.d.ts +0 -0
  882. /package/dist/types/{lookup → src/lookup}/mdc-lookup-configuration.d.ts +0 -0
  883. /package/dist/types/{menu → src/menu}/mdc-menu-selection-group-icon.d.ts +0 -0
  884. /package/dist/types/{menu → src/menu}/mdc-menu-selection-group.d.ts +0 -0
  885. /package/dist/types/{menu → src/menu}/mdc-menu.d.ts +0 -0
  886. /package/dist/types/{menu-surface → src/menu-surface}/mdc-menu-surface-anchor.d.ts +0 -0
  887. /package/dist/types/{menu-surface → src/menu-surface}/mdc-menu-surface.d.ts +0 -0
  888. /package/dist/types/{notched-outline → src/notched-outline}/mdc-notched-outline.d.ts +0 -0
  889. /package/dist/types/{radio → src/radio}/mdc-radio.d.ts +0 -0
  890. /package/dist/types/{ripple → src/ripple}/mdc-ripple.d.ts +0 -0
  891. /package/dist/types/{segmented-button → src/segmented-button}/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.d.ts +0 -0
  892. /package/dist/types/{segmented-button → src/segmented-button}/mdc-segmented-button-segment/mdc-segmented-button-segment.d.ts +0 -0
  893. /package/dist/types/{segmented-button → src/segmented-button}/mdc-segmented-button.d.ts +0 -0
  894. /package/dist/types/{select → src/select}/mdc-default-select-configuration.d.ts +0 -0
  895. /package/dist/types/{select → src/select}/mdc-select-adapter-aurelia.d.ts +0 -0
  896. /package/dist/types/{select → src/select}/mdc-select-foundation-aurelia.d.ts +0 -0
  897. /package/dist/types/{select → src/select}/mdc-select-helper-text/mdc-select-helper-text.d.ts +0 -0
  898. /package/dist/types/{select → src/select}/mdc-select-icon.d.ts +0 -0
  899. /package/dist/types/{select → src/select}/mdc-select-value-observer.d.ts +0 -0
  900. /package/dist/types/{slider → src/slider}/mdc-slider-foundation-aurelia.d.ts +0 -0
  901. /package/dist/types/{slider → src/slider}/mdc-slider.d.ts +0 -0
  902. /package/dist/types/{snackbar → src/snackbar}/mdc-snackbar-service.d.ts +0 -0
  903. /package/dist/types/{snackbar → src/snackbar}/mdc-snackbar.d.ts +0 -0
  904. /package/dist/types/{switch → src/switch}/enhance-mdc-switch.d.ts +0 -0
  905. /package/dist/types/{switch → src/switch}/mdc-switch.d.ts +0 -0
  906. /package/dist/types/{tab-bar → src/tab-bar}/indicator/mdc-tab-indicator.d.ts +0 -0
  907. /package/dist/types/{tab-bar → src/tab-bar}/mdc-tab-bar.d.ts +0 -0
  908. /package/dist/types/{tab-bar → src/tab-bar}/scroller/mdc-tab-scroller.d.ts +0 -0
  909. /package/dist/types/{tab-bar → src/tab-bar}/tab/mdc-tab.d.ts +0 -0
  910. /package/dist/types/{text-field → src/text-field}/enhance-mdc-text-field.d.ts +0 -0
  911. /package/dist/types/{text-field → src/text-field}/mdc-default-text-field-configuration.d.ts +0 -0
  912. /package/dist/types/{text-field → src/text-field}/mdc-text-field-character-counter.d.ts +0 -0
  913. /package/dist/types/{text-field → src/text-field}/mdc-text-field-helper-line/mdc-text-field-helper-line.d.ts +0 -0
  914. /package/dist/types/{text-field → src/text-field}/mdc-text-field-helper-text/mdc-text-field-helper-text.d.ts +0 -0
  915. /package/dist/types/{text-field → src/text-field}/mdc-text-field-icon.d.ts +0 -0
  916. /package/dist/types/{tooltip → src/tooltip}/mdc-default-tooltip-configuration.d.ts +0 -0
  917. /package/dist/types/{tooltip → src/tooltip}/mdc-tooltip-attribute.d.ts +0 -0
  918. /package/dist/types/{top-app-bar → src/top-app-bar}/enhance-top-app-bar-actions.d.ts +0 -0
  919. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-action-item.d.ts +0 -0
  920. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-fixed-adjust.d.ts +0 -0
  921. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-nav-icon.d.ts +0 -0
  922. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-row.d.ts +0 -0
  923. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-section/mdc-top-app-bar-section.d.ts +0 -0
  924. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar-title.d.ts +0 -0
  925. /package/dist/types/{top-app-bar → src/top-app-bar}/mdc-top-app-bar.d.ts +0 -0
  926. /package/dist/types/{tree-view → src/tree-view}/i-tree-node.d.ts +0 -0
  927. /package/dist/types/{tree-view → src/tree-view}/mdc-tree-node-meta.d.ts +0 -0
  928. /package/dist/types/{tree-view → src/tree-view}/mdc-tree-node.d.ts +0 -0
  929. /package/dist/types/{tree-view → src/tree-view}/mdc-tree-view.d.ts +0 -0
  930. /package/dist/types/{tree-view → src/tree-view}/node-filter.d.ts +0 -0
  931. /package/dist/types/{typography → src/typography}/mdc-typography.d.ts +0 -0
  932. /package/dist/types/{validation → src/validation}/mdc-validation-controller-factory.d.ts +0 -0
  933. /package/dist/types/{validation → src/validation}/mdc-validation-result-presenter.d.ts +0 -0
@@ -1,432 +1,530 @@
1
- /* eslint-disable no-template-curly-in-string */
2
- import { MdcComponent, booleanAttr, number } from '../base';
3
- import {
4
- MDCDataTableFoundation, selectors, MDCDataTableAdapter, events, cssClasses, RowClickEventData,
5
- dataAttributes, MDCDataTableRowSelectionChangedEventDetail, SortValue, messages
6
- } from '@material/data-table';
7
- import { closest } from '@material/dom/ponyfill';
8
- import { inject, customElement, INode, bindable, BindingMode } from 'aurelia';
9
- import { processContent, CustomElement } from '@aurelia/runtime-html';
10
- import template from './mdc-data-table.html?raw';
11
- import { MdcCheckbox } from '../checkbox/mdc-checkbox';
12
-
13
- events.ROW_CLICK = events.ROW_CLICK.toLowerCase();
14
- events.ROW_SELECTION_CHANGED = events.ROW_SELECTION_CHANGED.toLowerCase();
15
- events.SELECTED_ALL = events.SELECTED_ALL.toLowerCase();
16
- events.SORTED = events.SORTED.toLowerCase();
17
- events.UNSELECTED_ALL = events.UNSELECTED_ALL.toLowerCase();
18
- const NAVIGATION_EVENT = 'mdcdatatable:navigation';
19
-
20
- /**
21
- * Use `pagination-total` replaceable part to customise pagination total label.
22
- * @selector mdc-data-table
23
- * @emits mdcdatatable:rowselectionchanged | Emitted when row checkbox is checked or unchecked
24
- * @emits mdcdatatable:selectedall | Emitted when header row checkbox is checked
25
- * @emits mdcdatatable:unselectedall | Emitted when header row checkbox is unchecked
26
- * @emits mdcdatatable:sorted | Emitted when clicked on sortable header cell
27
- * @emits mdcdatatable:rowclick | Emitted when a row is clicked
28
- */
29
- @inject(Element)
30
- @customElement({ name: 'mdc-data-table', template })
31
- @processContent(function processContent(node: INode) {
32
- const element = node as HTMLElement;
33
- const table = element.querySelector('table');
34
- if (!table) {
35
- throw new Error('Have you forgotten the <table> tag in you data table markup?');
36
- }
37
- table.classList.add('mdc-data-table__table');
38
- table.setAttribute('aria-label', '${ariaLabel}');
39
-
40
- const headerRow = element.querySelector('thead>tr');
41
- if (!headerRow) {
42
- throw new Error('Have you forgotten the <thead><tr> tags in you data table markup?');
43
- }
44
- headerRow.classList.add(cssClasses.HEADER_ROW);
45
- headerRow.setAttribute('ref', 'headerRow');
46
- const headerCells = headerRow.querySelectorAll<HTMLElement>('th');
47
- for (const th of Array.from(headerCells)) {
48
- th.classList.add(cssClasses.HEADER_CELL);
49
- th.classList.toggle('mdc-data-table__header-cell--numeric', th.hasAttribute('numeric'));
50
- th.setAttribute('role', 'columnheader');
51
- th.setAttribute('scope', 'col');
52
- }
53
-
54
- const tbody = element.querySelector('tbody');
55
- if (!tbody) {
56
- throw new Error('Have you forgotten the <tbody> tag in you data table markup?');
57
- }
58
- tbody.classList.add(cssClasses.CONTENT);
59
- tbody.setAttribute('ref', 'content');
60
-
61
- const paginationTotalSlot = element.querySelector('[au-slot="pagination-total"]');
62
- paginationTotalSlot?.remove();
63
-
64
- if (paginationTotalSlot) {
65
- element.appendChild(paginationTotalSlot);
66
- }
67
- }
68
- )
69
- export class MdcDataTable extends MdcComponent<MDCDataTableFoundation> implements EventListenerObject {
70
- header: HTMLElement;
71
- content: HTMLElement;
72
-
73
- /** Shows pagination footer */
74
- @bindable({ set: booleanAttr })
75
- pagination: boolean;
76
-
77
- /** Caption for the page size selector */
78
- @bindable()
79
- rowsPerPageLabel: string = 'Rows per page';
80
-
81
- /** Page sizes available for selection, e.g. [10, 25, 100, 'All'] */
82
- @bindable()
83
- pageSizes: unknown[] = [10, 25, 100];
84
-
85
- /** Selected page size */
86
- @bindable({ mode: BindingMode.twoWay })
87
- pageSize: unknown = 10;
88
-
89
- /** Makes header row sticky (fixed) on vertical scroll.
90
- * (Note: Sticky header feature is not compatible with IE11 browsers.) */
91
- @bindable({ set: booleanAttr })
92
- stickyHeader: boolean;
93
-
94
- get paginationPosition(): 'first' | 'between' | 'last' | undefined {
95
- if (typeof this.pageSize !== 'number' || this.pageSize === undefined || isNaN(this.activePage) || isNaN(this.recordsCount)) {
96
- return undefined;
97
- }
98
- const pagesCount = Math.ceil(this.recordsCount / this.pageSize);
99
- return this.activePage === 1
100
- ? (pagesCount === 1 ? undefined : 'first')
101
- : (this.activePage === pagesCount ? 'last' : 'between');
102
- }
103
-
104
- /** Sets total number of records. Used in navigation row. */
105
- @bindable({ set: number })
106
- recordsCount: number;
107
-
108
- /** Sets the active page number. Used in navigation row. */
109
- @bindable({ set: number })
110
- activePage: number;
111
-
112
- get paginationTotal(): string | undefined {
113
- if (typeof this.pageSize !== 'number' || this.pageSize === undefined || isNaN(this.activePage) || isNaN(this.recordsCount)) {
114
- return undefined;
115
- }
116
- const firstRecord = this.pageSize * (this.activePage - 1) + 1;
117
- const lastRecord = Math.min(this.pageSize * this.activePage, this.recordsCount);
118
- return `${firstRecord}-${lastRecord} of ${this.recordsCount}`;
119
- }
120
-
121
- /** Turns on a linear progress indicator at the top of the table */
122
- @bindable({ set: booleanAttr })
123
- busy: boolean;
124
- busyChanged() {
125
- if (this.busy) {
126
- this.foundation?.showProgress();
127
- } else {
128
- this.foundation?.hideProgress();
129
- }
130
- }
131
-
132
- @bindable({ set: booleanAttr })
133
- hoistPageSelectToBody: boolean;
134
-
135
- get rowCheckboxList(): MdcCheckbox[] {
136
- return Array.from(this.root.querySelectorAll(`.${cssClasses.ROW} .mdc-checkbox`))
137
- .map(x => CustomElement.for<MdcCheckbox>(x).viewModel);
138
- }
139
-
140
- get headerRowCheckbox(): MdcCheckbox | undefined {
141
- const el = this.root.querySelector(`.${cssClasses.HEADER_ROW} .mdc-checkbox`);
142
- return el ? CustomElement.for<MdcCheckbox>(el).viewModel : undefined;
143
- }
144
-
145
- handleHeaderRowCheckboxChange() {
146
- this.foundation?.handleHeaderRowCheckboxChange();
147
- }
148
-
149
- handleRowCheckboxChange(event: Event) {
150
- if ((event.target as HTMLInputElement).type === 'checkbox') {
151
- this.foundation?.handleRowCheckboxChange(event);
152
- }
153
- }
154
-
155
- headerRowClickListener(event: Event) {
156
- this.handleHeaderRowClick(event);
157
- }
158
-
159
- handleNavigationClick(type: 'first' | 'prev' | 'next' | 'last') {
160
- this.emit(NAVIGATION_EVENT, { type }, true);
161
- }
162
-
163
- handleContentClick(event: Event) {
164
- const dataRowEl = closest(event.target as Element, selectors.ROW) as HTMLElement;
165
- if (!dataRowEl) {
166
- return;
167
- }
168
-
169
- this.foundation?.handleRowClick({
170
- rowId: this.getRowIdByRowElement(dataRowEl),
171
- row: dataRowEl,
172
- });
173
- }
174
-
175
- /**
176
- * Re-initializes header row checkbox and row checkboxes when selectable rows are added or removed from table.
177
- */
178
- layout() {
179
- this.foundation?.layout();
180
- }
181
-
182
- /**
183
- * @return Returns array of header row cell elements.
184
- */
185
- getHeaderCells(): Element[] {
186
- return [].slice.call(this.root.querySelectorAll(selectors.HEADER_CELL)) as Element[];
187
- }
188
-
189
- /**
190
- * @return Returns array of row elements.
191
- */
192
- getRows(): Element[] {
193
- return this.foundation!.getRows();
194
- }
195
-
196
- /**
197
- * @return Returns array of selected row ids.
198
- */
199
- getSelectedRowIds(): (string | null)[] {
200
- return this.foundation!.getSelectedRowIds();
201
- }
202
-
203
- /**
204
- * Sets selected row ids. Overwrites previously selected rows.
205
- * @param rowIds Array of row ids that needs to be selected.
206
- */
207
- setSelectedRowIds(rowIds: string[]) {
208
- this.foundation?.setSelectedRowIds(rowIds);
209
- }
210
-
211
- handleEvent(evt: Event): void {
212
- switch (evt.currentTarget) {
213
- case this.header:
214
- switch (evt.type) {
215
- case 'change': this.handleHeaderRowCheckboxChange(); break;
216
- case 'click': this.handleHeaderRowClick(evt); break;
217
- }
218
- break;
219
- case this.content:
220
- switch (evt.type) {
221
- case 'change': this.handleRowCheckboxChange(evt); break;
222
- }
223
- break;
224
- }
225
- }
226
-
227
- beforeFoundationCreated() {
228
- this.header = this.root.querySelector<HTMLElement>(`.${cssClasses.HEADER_ROW}`)!;
229
- this.header.addEventListener('change', this);
230
- this.header.addEventListener('click', this);
231
-
232
- this.content = this.root.querySelector<HTMLElement>(`.${cssClasses.CONTENT}`)!;
233
- this.content.addEventListener('change', this);
234
- this.content.addEventListener('click', this);
235
-
236
- const rowCheckboxList = this.rowCheckboxList;
237
- this.rowCheckboxList.forEach(x => x.root.classList.add(cssClasses.ROW_CHECKBOX));
238
- if (this.headerRowCheckbox) {
239
- this.headerRowCheckbox.root.classList.add(cssClasses.HEADER_ROW_CHECKBOX);
240
- rowCheckboxList.push(this.headerRowCheckbox);
241
- }
242
- }
243
-
244
- initialSyncWithDOM() {
245
- if (this.busy !== undefined) {
246
- this.busyChanged();
247
- }
248
- const rowCheckboxList = this.rowCheckboxList;
249
- for (let i = 0; i < rowCheckboxList.length; ++i) {
250
- if (rowCheckboxList[i].checked) {
251
- this.getRowByIndex(i).classList.add(cssClasses.ROW_SELECTED);
252
- }
253
- }
254
- this.foundation?.layout();
255
- }
256
-
257
- destroy() {
258
- this.header.removeEventListener('change', this);
259
- this.header.removeEventListener('click', this);
260
- this.content.removeEventListener('change', this);
261
- }
262
-
263
- getDefaultFoundation() {
264
- // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.
265
- // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.
266
- // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.
267
- const adapter: MDCDataTableAdapter = {
268
- addClass: (className) => this.root.classList.add(className),
269
- removeClass: (className) => this.root.classList.remove(className),
270
- getHeaderCellElements: () => this.getHeaderCells(),
271
- getHeaderCellCount: () => this.getHeaderCells().length,
272
- getAttributeByHeaderCellIndex: (index, attribute) => this.getHeaderCells()[index].getAttribute(attribute),
273
- setAttributeByHeaderCellIndex: (index, attribute, value) => this.getHeaderCells()[index].setAttribute(attribute, value),
274
- setClassNameByHeaderCellIndex: (index, className) => this.getHeaderCells()[index].classList.add(className),
275
- removeClassNameByHeaderCellIndex: (index, className) => {
276
- this.getHeaderCells()[index].classList.remove(className);
277
- },
278
- notifySortAction: (data) => {
279
- this.emit(events.SORTED, data, /** shouldBubble */ true);
280
- },
281
- getTableContainerHeight: () => {
282
- const tableContainer =
283
- this.root.querySelector<HTMLElement>(`.${cssClasses.TABLE_CONTAINER}`);
284
-
285
- if (!tableContainer) {
286
- throw new Error('MDCDataTable: Table container element not found.');
287
- }
288
-
289
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
290
- return tableContainer.getBoundingClientRect().height as any;
291
- },
292
- getTableHeaderHeight: () => {
293
- const tableHeader =
294
- this.root.querySelector<HTMLElement>(selectors.HEADER_ROW);
295
-
296
- if (!tableHeader) {
297
- throw new Error('MDCDataTable: Table header element not found.');
298
- }
299
-
300
- return tableHeader.getBoundingClientRect().height;
301
- },
302
- setProgressIndicatorStyles: (styles) => {
303
- const progressIndicator = this.root.querySelector<HTMLElement>(selectors.PROGRESS_INDICATOR);
304
-
305
- if (!progressIndicator) {
306
- throw new Error('MDCDataTable: Progress indicator element not found.');
307
- }
308
-
309
- Object.assign(progressIndicator.style, styles);
310
- },
311
- addClassAtRowIndex: (rowIndex: number, className: string) => {
312
- this.getRows()[rowIndex].classList.add(className);
313
- },
314
- getRowCount: () => this.getRows().length,
315
- getRowElements: () => [].slice.call(this.root.querySelectorAll(selectors.ROW)) as Element[],
316
- getRowIdAtIndex: (rowIndex: number) =>
317
- this.getRows()[rowIndex].getAttribute(dataAttributes.ROW_ID),
318
- getRowIndexByChildElement: (el: Element) => this.getRows().indexOf((closest(el, selectors.ROW) as HTMLElement)),
319
- getSelectedRowCount: () => this.root.querySelectorAll(selectors.ROW_SELECTED).length,
320
- isCheckboxAtRowIndexChecked: (rowIndex: number) => this.rowCheckboxList[rowIndex].checked,
321
- isHeaderRowCheckboxChecked: () => this.headerRowCheckbox?.checked ?? false,
322
- isRowsSelectable: () => !!this.root.querySelector(selectors.ROW_CHECKBOX),
323
- notifyRowSelectionChanged:
324
- (data: MDCDataTableRowSelectionChangedEventDetail) => {
325
- this.emit(
326
- events.ROW_SELECTION_CHANGED, {
327
- row: this.getRowByIndex(data.rowIndex),
328
- rowId: this.getRowIdByIndex(data.rowIndex),
329
- rowIndex: data.rowIndex,
330
- selected: data.selected,
331
- }, /** shouldBubble */ true);
332
- },
333
- notifySelectedAll: () => {
334
- this.emit(events.SELECTED_ALL, {}, /** shouldBubble */ true);
335
- },
336
- notifyUnselectedAll: () => {
337
- this.emit(events.UNSELECTED_ALL, {}, /** shouldBubble */ true);
338
- },
339
- notifyRowClick: (data: RowClickEventData) => {
340
- this.emit(events.ROW_CLICK, data, /** shouldBubble */ true);
341
- },
342
- registerHeaderRowCheckbox: () => {
343
- // const checkboxEl = this.root.querySelector<IMdcCheckboxElement>(selectors.HEADER_ROW_CHECKBOX);
344
- // this.headerRowCheckbox = checkboxEl?.au?.controller.viewModel;
345
- },
346
- registerRowCheckboxes: () => {
347
- // this.rowCheckboxList = [];
348
- // this.getRows().forEach((rowEl) => {
349
- // const checkbox = rowEl.querySelector<IMdcCheckboxElement>(selectors.ROW_CHECKBOX)?.au?.controller.viewModel;
350
- // if (checkbox) {
351
- // this.rowCheckboxList.push(checkbox);
352
- // }
353
- // });
354
- },
355
- removeClassAtRowIndex: (rowIndex: number, className: string) => {
356
- this.getRows()[rowIndex].classList.remove(className);
357
- },
358
- setAttributeAtRowIndex:
359
- (rowIndex: number, attr: string, value: string) => {
360
- this.getRows()[rowIndex].setAttribute(attr, value);
361
- },
362
- setHeaderRowCheckboxChecked: (checked: boolean) => {
363
- if (this.headerRowCheckbox) {
364
- this.headerRowCheckbox.checked = checked;
365
- }
366
- },
367
- setHeaderRowCheckboxIndeterminate: (indeterminate: boolean) => {
368
- if (this.headerRowCheckbox) {
369
- this.headerRowCheckbox.indeterminate = indeterminate;
370
- }
371
- },
372
- setRowCheckboxCheckedAtIndex: (rowIndex: number, checked: boolean) => {
373
- this.rowCheckboxList[rowIndex].checked = checked;
374
- },
375
- setSortStatusLabelByHeaderCellIndex: (
376
- columnIndex: number, sortValue: SortValue) => {
377
- const headerCell = this.getHeaderCells()[columnIndex];
378
- const sortStatusLabel =
379
- headerCell.querySelector<HTMLElement>(selectors.SORT_STATUS_LABEL);
380
-
381
- if (!sortStatusLabel) {
382
- return;
383
- }
384
-
385
- sortStatusLabel.textContent =
386
- this.getSortStatusMessageBySortValue(sortValue);
387
- }
388
- };
389
- return new MDCDataTableFoundation(adapter);
390
- }
391
-
392
- private getRowByIndex(index: number): Element {
393
- return this.getRows()[index];
394
- }
395
-
396
- private getRowIdByIndex(index: number): string | null {
397
- return this.getRowByIndex(index).getAttribute(dataAttributes.ROW_ID);
398
- }
399
-
400
- private handleHeaderRowClick(event: Event): void {
401
- const headerCell =
402
- closest(event.target as Element, selectors.HEADER_CELL_WITH_SORT) as
403
- HTMLElement;
404
-
405
- if (!headerCell) {
406
- return;
407
- }
408
-
409
- const columnId = headerCell.getAttribute(dataAttributes.COLUMN_ID);
410
- const columnIndex = this.getHeaderCells().indexOf(headerCell);
411
- if (columnIndex === -1) {
412
- return;
413
- }
414
-
415
- this.foundation?.handleSortAction({ columnId, columnIndex, headerCell });
416
- }
417
-
418
- private getSortStatusMessageBySortValue(sortValue: SortValue): string {
419
- switch (sortValue) {
420
- case SortValue.ASCENDING:
421
- return messages.SORTED_IN_ASCENDING;
422
- case SortValue.DESCENDING:
423
- return messages.SORTED_IN_DESCENDING;
424
- default:
425
- return '';
426
- }
427
- }
428
-
429
- private getRowIdByRowElement(rowElement: HTMLElement): string | null {
430
- return rowElement.getAttribute(dataAttributes.ROW_ID);
431
- }
432
- }
1
+ /* eslint-disable no-template-curly-in-string */
2
+ import { MdcComponent, booleanAttr, number } from '../base';
3
+ import {
4
+ MDCDataTableFoundation, selectors, MDCDataTableAdapter, events, cssClasses, RowClickEventData,
5
+ dataAttributes, MDCDataTableRowSelectionChangedEventDetail, SortValue, messages
6
+ } from '@material/data-table';
7
+ import { closest } from '@material/dom/ponyfill';
8
+ import { inject, customElement, INode, bindable, BindingMode } from 'aurelia';
9
+ import { processContent, CustomElement } from '@aurelia/runtime-html';
10
+ import template from './mdc-data-table.html?raw';
11
+ import { MdcCheckbox } from '../checkbox/mdc-checkbox';
12
+
13
+ events.ROW_CLICK = events.ROW_CLICK.toLowerCase();
14
+ events.ROW_SELECTION_CHANGED = events.ROW_SELECTION_CHANGED.toLowerCase();
15
+ events.SELECTED_ALL = events.SELECTED_ALL.toLowerCase();
16
+ events.SORTED = events.SORTED.toLowerCase();
17
+ events.UNSELECTED_ALL = events.UNSELECTED_ALL.toLowerCase();
18
+ const NAVIGATION_EVENT = 'mdcdatatable:navigation';
19
+
20
+ export interface MDCDataTableColumnsResizedEventDetail {
21
+ widths: string[];
22
+ }
23
+
24
+ /**
25
+ * Use `pagination-total` replaceable part to customise pagination total label.
26
+ * @selector mdc-data-table
27
+ * @emits mdcdatatable:rowselectionchanged | Emitted when row checkbox is checked or unchecked
28
+ * @emits mdcdatatable:selectedall | Emitted when header row checkbox is checked
29
+ * @emits mdcdatatable:unselectedall | Emitted when header row checkbox is unchecked
30
+ * @emits mdcdatatable:sorted | Emitted when clicked on sortable header cell
31
+ * @emits mdcdatatable:rowclick | Emitted when a row is clicked
32
+ */
33
+ @inject(Element)
34
+ @customElement({ name: 'mdc-data-table', template })
35
+ @processContent(function processContent(node: INode) {
36
+ const element = node as HTMLElement;
37
+ const table = element.querySelector('table');
38
+ if (!table) {
39
+ throw new Error('Have you forgotten the <table> tag in you data table markup?');
40
+ }
41
+ table.classList.add('mdc-data-table__table');
42
+ table.setAttribute('aria-label', '${ariaLabel}');
43
+
44
+ const headerRow = element.querySelector('thead>tr');
45
+ if (!headerRow) {
46
+ throw new Error('Have you forgotten the <thead><tr> tags in you data table markup?');
47
+ }
48
+ headerRow.classList.add(cssClasses.HEADER_ROW);
49
+ headerRow.setAttribute('ref', 'headerRow');
50
+ const headerCells = headerRow.querySelectorAll<HTMLElement>('th');
51
+ for (const th of Array.from(headerCells)) {
52
+ th.classList.add(cssClasses.HEADER_CELL);
53
+ th.classList.toggle('mdc-data-table__header-cell--numeric', th.hasAttribute('numeric'));
54
+ th.setAttribute('role', 'columnheader');
55
+ th.setAttribute('scope', 'col');
56
+ }
57
+
58
+ const tbody = element.querySelector('tbody');
59
+ if (!tbody) {
60
+ throw new Error('Have you forgotten the <tbody> tag in you data table markup?');
61
+ }
62
+ tbody.classList.add(cssClasses.CONTENT);
63
+ tbody.setAttribute('ref', 'content');
64
+
65
+ const paginationTotalSlot = element.querySelector('[au-slot="pagination-total"]');
66
+ paginationTotalSlot?.remove();
67
+
68
+ if (paginationTotalSlot) {
69
+ element.appendChild(paginationTotalSlot);
70
+ }
71
+ }
72
+ )
73
+ export class MdcDataTable extends MdcComponent<MDCDataTableFoundation> implements EventListenerObject {
74
+ header: HTMLElement;
75
+ content: HTMLElement;
76
+ columnResized: boolean;
77
+ private mutationObserver: MutationObserver;
78
+
79
+ /** Shows pagination footer */
80
+ @bindable({ set: booleanAttr })
81
+ pagination: boolean;
82
+
83
+ /** Caption for the page size selector */
84
+ @bindable()
85
+ rowsPerPageLabel: string = 'Rows per page';
86
+
87
+ /** Page sizes available for selection, e.g. [10, 25, 100, 'All'] */
88
+ @bindable()
89
+ pageSizes: unknown[] = [10, 25, 100];
90
+
91
+ /** Selected page size */
92
+ @bindable({ mode: BindingMode.twoWay })
93
+ pageSize: unknown = 10;
94
+
95
+ /** Makes header row sticky (fixed) on vertical scroll.
96
+ * (Note: Sticky header feature is not compatible with IE11 browsers.) */
97
+ @bindable({ set: booleanAttr })
98
+ stickyHeader: boolean;
99
+
100
+ /** Turns off checkbox handling by the MDC framework */
101
+ @bindable({ set: booleanAttr })
102
+ manualCheckboxHandling: boolean;
103
+
104
+ /** Turns on automatic column widths saving to localStorage */
105
+ @bindable({ set: booleanAttr })
106
+ saveColumnWidths: boolean;
107
+
108
+ get paginationPosition(): 'first' | 'between' | 'last' | undefined {
109
+ if (typeof this.pageSize !== 'number' || this.pageSize === undefined || isNaN(this.activePage) || isNaN(this.recordsCount)) {
110
+ return undefined;
111
+ }
112
+ const pagesCount = Math.ceil(this.recordsCount / this.pageSize);
113
+ return this.activePage === 1
114
+ ? (pagesCount === 1 ? undefined : 'first')
115
+ : (this.activePage === pagesCount ? 'last' : 'between');
116
+ }
117
+
118
+ /** Sets total number of records. Used in navigation row. */
119
+ @bindable({ set: number })
120
+ recordsCount: number;
121
+
122
+ /** Sets the active page number. Used in navigation row. */
123
+ @bindable({ set: number })
124
+ activePage: number;
125
+
126
+ get paginationTotal(): string | undefined {
127
+ if (typeof this.pageSize !== 'number' || this.pageSize === undefined || isNaN(this.activePage) || isNaN(this.recordsCount)) {
128
+ return undefined;
129
+ }
130
+ const firstRecord = this.pageSize * (this.activePage - 1) + 1;
131
+ const lastRecord = Math.min(this.pageSize * this.activePage, this.recordsCount);
132
+ return `${firstRecord}-${lastRecord} of ${this.recordsCount}`;
133
+ }
134
+
135
+ /** Turns on a linear progress indicator at the top of the table */
136
+ @bindable({ set: booleanAttr })
137
+ busy: boolean;
138
+ busyChanged() {
139
+ if (this.busy) {
140
+ this.foundation?.showProgress();
141
+ } else {
142
+ this.foundation?.hideProgress();
143
+ }
144
+ }
145
+
146
+ @bindable({ set: booleanAttr })
147
+ hoistPageSelectToBody: boolean;
148
+
149
+ get rowCheckboxList(): MdcCheckbox[] {
150
+ return Array.from(this.root.querySelectorAll(`.${cssClasses.ROW} .mdc-checkbox`))
151
+ .map(x => CustomElement.for<MdcCheckbox>(x).viewModel);
152
+ }
153
+
154
+ get headerRowCheckbox(): MdcCheckbox | undefined {
155
+ const el = this.root.querySelector(`.${cssClasses.HEADER_ROW} .mdc-checkbox`);
156
+ return el ? CustomElement.for<MdcCheckbox>(el).viewModel : undefined;
157
+ }
158
+
159
+ handleHeaderRowCheckboxChange() {
160
+ this.foundation?.handleHeaderRowCheckboxChange();
161
+ }
162
+
163
+ handleRowCheckboxChange(event: Event) {
164
+ if ((event.target as HTMLInputElement).type === 'checkbox') {
165
+ this.foundation?.handleRowCheckboxChange(event);
166
+ }
167
+ }
168
+
169
+ headerRowClickListener(event: Event) {
170
+ this.handleHeaderRowClick(event);
171
+ }
172
+
173
+ handleNavigationClick(type: 'first' | 'prev' | 'next' | 'last') {
174
+ this.emit(NAVIGATION_EVENT, { type }, true);
175
+ }
176
+
177
+ handleContentClick(event: Event) {
178
+ const dataRowEl = closest(event.target as Element, selectors.ROW) as HTMLElement;
179
+ if (!dataRowEl) {
180
+ return;
181
+ }
182
+
183
+ this.foundation?.handleRowClick({
184
+ rowId: this.getRowIdByRowElement(dataRowEl),
185
+ row: dataRowEl,
186
+ });
187
+ }
188
+
189
+ /**
190
+ * Re-initializes header row checkbox and row checkboxes when selectable rows are added or removed from table.
191
+ */
192
+ layout() {
193
+ this.foundation?.layout();
194
+ }
195
+
196
+ /**
197
+ * Returns array of header row cell elements.
198
+ */
199
+ getHeaderCells(): HTMLElement[] {
200
+ return [].slice.call(this.root.querySelectorAll(selectors.HEADER_CELL)) as HTMLElement[];
201
+ }
202
+
203
+ /**
204
+ * Returns array of row elements.
205
+ */
206
+ getRows(): Element[] {
207
+ return this.foundation!.getRows();
208
+ }
209
+
210
+ /**
211
+ * Returns array of selected row ids.
212
+ */
213
+ getSelectedRowIds(): (string | null)[] {
214
+ return this.foundation!.getSelectedRowIds();
215
+ }
216
+
217
+ /**
218
+ * Sets selected row ids. Overwrites previously selected rows.
219
+ * @param rowIds Array of row ids that needs to be selected.
220
+ */
221
+ setSelectedRowIds(rowIds: string[]) {
222
+ this.foundation?.setSelectedRowIds(rowIds);
223
+ }
224
+
225
+ handleEvent(evt: Event): void {
226
+ switch (evt.currentTarget) {
227
+ case this.header:
228
+ switch (evt.type) {
229
+ case 'change': this.handleHeaderRowCheckboxChange(); break;
230
+ case 'click': this.handleHeaderRowClick(evt); break;
231
+ }
232
+ break;
233
+ case this.content:
234
+ switch (evt.type) {
235
+ case 'change': this.handleRowCheckboxChange(evt); break;
236
+ }
237
+ break;
238
+ }
239
+ }
240
+
241
+ beforeFoundationCreated() {
242
+ this.header = this.root.querySelector<HTMLElement>(`.${cssClasses.HEADER_ROW}`)!;
243
+ this.content = this.root.querySelector<HTMLElement>(`.${cssClasses.CONTENT}`)!;
244
+ this.header.addEventListener('click', this);
245
+ this.header.querySelectorAll('th[resizeable]').forEach(x => {
246
+ const resizeHandle = document.createElement('div');
247
+ resizeHandle.addEventListener('mousedown', (event) => this.startColumnResize(event, x as HTMLElement));
248
+ x.insertBefore(document.createElement('div'), x.firstChild).classList.add('mdc-data-table__header-cell__hover-indicator');
249
+ x.appendChild(resizeHandle).classList.add('mdc-data-table__header-cell__resize-handle');
250
+ });
251
+ if (this.saveColumnWidths) {
252
+ this.restoreColumnWidths();
253
+ this.mutationObserver = new MutationObserver(() => this.restoreColumnWidths());
254
+ this.mutationObserver.observe(this.content, { childList: true, subtree: false });
255
+ }
256
+
257
+ if (!this.manualCheckboxHandling) {
258
+ this.header.addEventListener('change', this);
259
+ this.content.addEventListener('change', this);
260
+ }
261
+
262
+ const rowCheckboxList = this.rowCheckboxList;
263
+ this.rowCheckboxList.forEach(x => x.root.classList.add(cssClasses.ROW_CHECKBOX));
264
+ if (this.headerRowCheckbox) {
265
+ this.headerRowCheckbox.root.classList.add(cssClasses.HEADER_ROW_CHECKBOX);
266
+ rowCheckboxList.push(this.headerRowCheckbox);
267
+ }
268
+ }
269
+
270
+ public restoreColumnWidths() {
271
+ const widths = JSON.parse(localStorage.getItem(`mdc-data-table-${this.root.id}-column-widths`) ?? '[]');
272
+ this.setColumnWidths(widths);
273
+ }
274
+
275
+ initialSyncWithDOM() {
276
+ if (this.busy !== undefined) {
277
+ this.busyChanged();
278
+ }
279
+ if (!this.manualCheckboxHandling) {
280
+ const rowCheckboxList = this.rowCheckboxList;
281
+ for (let i = 0; i < rowCheckboxList.length; ++i) {
282
+ if (rowCheckboxList[i].checked) {
283
+ this.getRowByIndex(i).classList.add(cssClasses.ROW_SELECTED);
284
+ }
285
+ }
286
+ }
287
+ this.foundation?.layout();
288
+ }
289
+
290
+ private startColumnResize(event: MouseEvent, headerCell: HTMLElement): void {
291
+ this.columnResized = true;
292
+ const startX = event.clientX;
293
+ const resizeHandle = event.target as HTMLElement;
294
+ const initialHandlePosition = resizeHandle.offsetLeft;
295
+
296
+ // Create a visual indicator for the resize handle
297
+ const handleIndicator = document.createElement('div');
298
+ handleIndicator.classList.add('mdc-data-table__header-cell__resize-handle-indicator');
299
+ handleIndicator.style.left = `${initialHandlePosition}px`;
300
+ handleIndicator.style.height = `${headerCell.offsetHeight}px`;
301
+ document.body.style.cursor = 'col-resize';
302
+ headerCell.classList.add('mdc-data-table__header-cell--resizing');
303
+ headerCell.appendChild(handleIndicator);
304
+
305
+ const onMouseMove = (moveEvent: MouseEvent) => {
306
+ const deltaX = moveEvent.clientX - startX;
307
+ handleIndicator.style.left = `${Math.max(initialHandlePosition + deltaX, headerCell.clientLeft)}px`;
308
+ };
309
+
310
+ const onMouseUp = () => {
311
+ const finalDeltaX = parseInt(handleIndicator.style.left, 10) - initialHandlePosition;
312
+ const newWidth = Math.max(5, headerCell.offsetWidth + finalDeltaX); // Minimum width of 5px
313
+
314
+ // Apply the new width to the column
315
+ headerCell.style.minWidth = headerCell.style.maxWidth = `${newWidth}px`;
316
+ this.content.querySelectorAll(`tr td:nth-child(${Array.from(headerCell.parentElement!.children).indexOf(headerCell) + 1})`)
317
+ .forEach((cell: HTMLElement) => {
318
+ cell.style.minWidth = cell.style.maxWidth = `${newWidth}px`;
319
+ });
320
+
321
+ // Clean up
322
+ handleIndicator.remove();
323
+ this.columnResized = false;
324
+ document.body.style.cursor = '';
325
+ headerCell.classList.remove('mdc-data-table__header-cell--resizing');
326
+ document.removeEventListener('mousemove', onMouseMove);
327
+ document.removeEventListener('mouseup', onMouseUp);
328
+
329
+ // Save the new widths if required
330
+ const widths = this.getHeaderCells().map(x => x.style.minWidth);
331
+ if (this.saveColumnWidths) {
332
+ localStorage.setItem(`mdc-data-table-${this.root.id}-column-widths`, JSON.stringify(widths));
333
+ }
334
+
335
+ this.emit<MDCDataTableColumnsResizedEventDetail>('mdcdatatable:columnsresized', { widths }, true);
336
+ };
337
+
338
+ document.addEventListener('mousemove', onMouseMove);
339
+ document.addEventListener('mouseup', onMouseUp);
340
+ }
341
+
342
+ destroy() {
343
+ this.header.removeEventListener('change', this);
344
+ this.header.removeEventListener('click', this);
345
+ this.content.removeEventListener('change', this);
346
+ this.mutationObserver?.disconnect();
347
+ }
348
+
349
+ public setColumnWidths(widths: string[]) {
350
+ if (!widths || widths.length === 0) {
351
+ return;
352
+ }
353
+ this.getHeaderCells().forEach((x, i) => {
354
+ x.style.minWidth = x.style.maxWidth = widths[i];
355
+ this.content.querySelectorAll(`tr td:nth-child(${i + 1})`).forEach((cell: HTMLElement) => {
356
+ cell.style.minWidth = cell.style.maxWidth = widths[i];
357
+ });
358
+ });
359
+ }
360
+
361
+ getDefaultFoundation() {
362
+ // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.
363
+ // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.
364
+ // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.
365
+ const adapter: MDCDataTableAdapter = {
366
+ addClass: (className) => this.root.classList.add(className),
367
+ removeClass: (className) => this.root.classList.remove(className),
368
+ getHeaderCellElements: () => this.getHeaderCells(),
369
+ getHeaderCellCount: () => this.getHeaderCells().length,
370
+ getAttributeByHeaderCellIndex: (index, attribute) => this.getHeaderCells()[index].getAttribute(attribute),
371
+ setAttributeByHeaderCellIndex: (index, attribute, value) => this.getHeaderCells()[index].setAttribute(attribute, value),
372
+ setClassNameByHeaderCellIndex: (index, className) => this.getHeaderCells()[index].classList.add(className),
373
+ removeClassNameByHeaderCellIndex: (index, className) => {
374
+ this.getHeaderCells()[index].classList.remove(className);
375
+ },
376
+ notifySortAction: (data) => {
377
+ this.emit(events.SORTED, data, /** shouldBubble */ true);
378
+ },
379
+ getTableContainerHeight: () => {
380
+ const tableContainer =
381
+ this.root.querySelector<HTMLElement>(`.${cssClasses.TABLE_CONTAINER}`);
382
+
383
+ if (!tableContainer) {
384
+ throw new Error('MDCDataTable: Table container element not found.');
385
+ }
386
+
387
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
388
+ return tableContainer.getBoundingClientRect().height as any;
389
+ },
390
+ getTableHeaderHeight: () => {
391
+ const tableHeader =
392
+ this.root.querySelector<HTMLElement>(selectors.HEADER_ROW);
393
+
394
+ if (!tableHeader) {
395
+ throw new Error('MDCDataTable: Table header element not found.');
396
+ }
397
+
398
+ return tableHeader.getBoundingClientRect().height;
399
+ },
400
+ setProgressIndicatorStyles: (styles) => {
401
+ const progressIndicator = this.root.querySelector<HTMLElement>(selectors.PROGRESS_INDICATOR);
402
+
403
+ if (!progressIndicator) {
404
+ throw new Error('MDCDataTable: Progress indicator element not found.');
405
+ }
406
+
407
+ Object.assign(progressIndicator.style, styles);
408
+ },
409
+ addClassAtRowIndex: (rowIndex: number, className: string) => {
410
+ this.getRows()[rowIndex].classList.add(className);
411
+ },
412
+ getRowCount: () => this.getRows().length,
413
+ getRowElements: () => [].slice.call(this.root.querySelectorAll(selectors.ROW)) as Element[],
414
+ getRowIdAtIndex: (rowIndex: number) =>
415
+ this.getRows()[rowIndex].getAttribute(dataAttributes.ROW_ID),
416
+ getRowIndexByChildElement: (el: Element) => this.getRows().indexOf((closest(el, selectors.ROW) as HTMLElement)),
417
+ getSelectedRowCount: () => this.root.querySelectorAll(selectors.ROW_SELECTED).length,
418
+ isCheckboxAtRowIndexChecked: (rowIndex: number) => this.rowCheckboxList[rowIndex].checked,
419
+ isHeaderRowCheckboxChecked: () => this.headerRowCheckbox?.checked ?? false,
420
+ isRowsSelectable: () => !!this.root.querySelector(selectors.ROW_CHECKBOX),
421
+ notifyRowSelectionChanged:
422
+ (data: MDCDataTableRowSelectionChangedEventDetail) => {
423
+ this.emit(
424
+ events.ROW_SELECTION_CHANGED, {
425
+ row: this.getRowByIndex(data.rowIndex),
426
+ rowId: this.getRowIdByIndex(data.rowIndex),
427
+ rowIndex: data.rowIndex,
428
+ selected: data.selected,
429
+ }, /** shouldBubble */ true);
430
+ },
431
+ notifySelectedAll: () => {
432
+ this.emit(events.SELECTED_ALL, {}, /** shouldBubble */ true);
433
+ },
434
+ notifyUnselectedAll: () => {
435
+ this.emit(events.UNSELECTED_ALL, {}, /** shouldBubble */ true);
436
+ },
437
+ notifyRowClick: (data: RowClickEventData) => {
438
+ this.emit(events.ROW_CLICK, data, /** shouldBubble */ true);
439
+ },
440
+ registerHeaderRowCheckbox: () => {
441
+ // const checkboxEl = this.root.querySelector<IMdcCheckboxElement>(selectors.HEADER_ROW_CHECKBOX);
442
+ // this.headerRowCheckbox = checkboxEl?.au?.controller.viewModel;
443
+ },
444
+ registerRowCheckboxes: () => {
445
+ // this.rowCheckboxList = [];
446
+ // this.getRows().forEach((rowEl) => {
447
+ // const checkbox = rowEl.querySelector<IMdcCheckboxElement>(selectors.ROW_CHECKBOX)?.au?.controller.viewModel;
448
+ // if (checkbox) {
449
+ // this.rowCheckboxList.push(checkbox);
450
+ // }
451
+ // });
452
+ },
453
+ removeClassAtRowIndex: (rowIndex: number, className: string) => {
454
+ this.getRows()[rowIndex].classList.remove(className);
455
+ },
456
+ setAttributeAtRowIndex:
457
+ (rowIndex: number, attr: string, value: string) => {
458
+ this.getRows()[rowIndex].setAttribute(attr, value);
459
+ },
460
+ setHeaderRowCheckboxChecked: (checked: boolean) => {
461
+ if (this.headerRowCheckbox) {
462
+ this.headerRowCheckbox.checked = checked;
463
+ }
464
+ },
465
+ setHeaderRowCheckboxIndeterminate: (indeterminate: boolean) => {
466
+ if (this.headerRowCheckbox) {
467
+ this.headerRowCheckbox.indeterminate = indeterminate;
468
+ }
469
+ },
470
+ setRowCheckboxCheckedAtIndex: (rowIndex: number, checked: boolean) => {
471
+ this.rowCheckboxList[rowIndex].checked = checked;
472
+ },
473
+ setSortStatusLabelByHeaderCellIndex: (
474
+ columnIndex: number, sortValue: SortValue) => {
475
+ const headerCell = this.getHeaderCells()[columnIndex];
476
+ const sortStatusLabel =
477
+ headerCell.querySelector<HTMLElement>(selectors.SORT_STATUS_LABEL);
478
+
479
+ if (!sortStatusLabel) {
480
+ return;
481
+ }
482
+
483
+ sortStatusLabel.textContent =
484
+ this.getSortStatusMessageBySortValue(sortValue);
485
+ }
486
+ };
487
+ return new MDCDataTableFoundation(adapter);
488
+ }
489
+
490
+ private getRowByIndex(index: number): Element {
491
+ return this.getRows()[index];
492
+ }
493
+
494
+ private getRowIdByIndex(index: number): string | null {
495
+ return this.getRowByIndex(index).getAttribute(dataAttributes.ROW_ID);
496
+ }
497
+
498
+ private handleHeaderRowClick(event: Event): void {
499
+ const headerCell =
500
+ closest(event.target as Element, selectors.HEADER_CELL_WITH_SORT) as
501
+ HTMLElement;
502
+
503
+ if (!headerCell) {
504
+ return;
505
+ }
506
+
507
+ const columnId = headerCell.getAttribute(dataAttributes.COLUMN_ID);
508
+ const columnIndex = this.getHeaderCells().indexOf(headerCell);
509
+ if (columnIndex === -1) {
510
+ return;
511
+ }
512
+
513
+ this.foundation?.handleSortAction({ columnId, columnIndex, headerCell });
514
+ }
515
+
516
+ private getSortStatusMessageBySortValue(sortValue: SortValue): string {
517
+ switch (sortValue) {
518
+ case SortValue.ASCENDING:
519
+ return messages.SORTED_IN_ASCENDING;
520
+ case SortValue.DESCENDING:
521
+ return messages.SORTED_IN_DESCENDING;
522
+ default:
523
+ return '';
524
+ }
525
+ }
526
+
527
+ private getRowIdByRowElement(rowElement: HTMLElement): string | null {
528
+ return rowElement.getAttribute(dataAttributes.ROW_ID);
529
+ }
530
+ }