@aurelia-mdc-web/all 9.3.3-au2 → 9.3.4-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 (326) hide show
  1. package/dist/alert/alert-configuration.js +5 -9
  2. package/dist/alert/alert-configuration.js.map +1 -1
  3. package/dist/alert/alert-modal/alert-modal.js +8 -11
  4. package/dist/alert/alert-modal/alert-modal.js.map +1 -1
  5. package/dist/alert/alert-modal/alert-modal.scss +10 -0
  6. package/dist/alert/alert-modal/i-alert-modal-payload.js +1 -5
  7. package/dist/alert/alert-modal/i-alert-modal-payload.js.map +1 -1
  8. package/dist/alert/alert-service.js +23 -27
  9. package/dist/alert/alert-service.js.map +1 -1
  10. package/dist/alert/decorators/confirm-action.js +1 -4
  11. package/dist/alert/decorators/confirm-action.js.map +1 -1
  12. package/dist/alert/decorators/using-progress.js +1 -4
  13. package/dist/alert/decorators/using-progress.js.map +1 -1
  14. package/dist/alert/exceptions-tracker.js +1 -5
  15. package/dist/alert/exceptions-tracker.js.map +1 -1
  16. package/dist/alert/global-progress/global-progress.js +24 -27
  17. package/dist/alert/global-progress/global-progress.js.map +1 -1
  18. package/dist/alert/global-progress/global-progress.scss +38 -0
  19. package/dist/alert/prompt-dialog/prompt-dialog.js +9 -12
  20. package/dist/alert/prompt-dialog/prompt-dialog.js.map +1 -1
  21. package/dist/banner/mdc-banner.js +42 -45
  22. package/dist/banner/mdc-banner.js.map +1 -1
  23. package/dist/base/attributes/mdc-focus-trap.js +22 -25
  24. package/dist/base/attributes/mdc-focus-trap.js.map +1 -1
  25. package/dist/base/elements/i-validated-element.js +1 -2
  26. package/dist/base/elements/mdc-promisify-reference.js +13 -16
  27. package/dist/base/elements/mdc-promisify-reference.js.map +1 -1
  28. package/dist/base/index.js +9 -21
  29. package/dist/base/index.js.map +1 -1
  30. package/dist/base/interceptors.js +5 -12
  31. package/dist/base/interceptors.js.map +1 -1
  32. package/dist/base/material-palette.js +1 -4
  33. package/dist/base/material-palette.js.map +1 -1
  34. package/dist/base/mdc-component.js +1 -5
  35. package/dist/base/mdc-component.js.map +1 -1
  36. package/dist/base/next-element.js +1 -4
  37. package/dist/base/next-element.js.map +1 -1
  38. package/dist/button/enhance-mdc-button.js +6 -9
  39. package/dist/button/enhance-mdc-button.js.map +1 -1
  40. package/dist/button/mdc-button-label.js +6 -9
  41. package/dist/button/mdc-button-label.js.map +1 -1
  42. package/dist/button/mdc-button.js +27 -30
  43. package/dist/button/mdc-button.js.map +1 -1
  44. package/dist/card/mdc-card-action-buttons.js +6 -9
  45. package/dist/card/mdc-card-action-buttons.js.map +1 -1
  46. package/dist/card/mdc-card-action-icons.js +6 -9
  47. package/dist/card/mdc-card-action-icons.js.map +1 -1
  48. package/dist/card/mdc-card-actions/mdc-card-actions.js +12 -15
  49. package/dist/card/mdc-card-actions/mdc-card-actions.js.map +1 -1
  50. package/dist/card/mdc-card-media/mdc-card-media.js +15 -18
  51. package/dist/card/mdc-card-media/mdc-card-media.js.map +1 -1
  52. package/dist/card/mdc-card-primary-action.js +12 -15
  53. package/dist/card/mdc-card-primary-action.js.map +1 -1
  54. package/dist/card/mdc-card.js +12 -15
  55. package/dist/card/mdc-card.js.map +1 -1
  56. package/dist/checkbox/mdc-checkbox.js +35 -38
  57. package/dist/checkbox/mdc-checkbox.js.map +1 -1
  58. package/dist/chips/mdc-chip/mdc-chip.js +34 -37
  59. package/dist/chips/mdc-chip/mdc-chip.js.map +1 -1
  60. package/dist/chips/mdc-chip-action/enhance-mdc-chip-action.js +6 -9
  61. package/dist/chips/mdc-chip-action/enhance-mdc-chip-action.js.map +1 -1
  62. package/dist/chips/mdc-chip-action/mdc-chip-action.js +37 -40
  63. package/dist/chips/mdc-chip-action/mdc-chip-action.js.map +1 -1
  64. package/dist/chips/mdc-chip-set/mdc-chip-set.js +24 -27
  65. package/dist/chips/mdc-chip-set/mdc-chip-set.js.map +1 -1
  66. package/dist/chips/styles/_index.scss +1 -0
  67. package/dist/chips/styles/mdc-chips.import.scss +1 -0
  68. package/dist/chips/styles/mdc-chips.scss +11 -0
  69. package/dist/circular-progress/mdc-circular-progress.js +22 -25
  70. package/dist/circular-progress/mdc-circular-progress.js.map +1 -1
  71. package/dist/circular-progress/styles/_index.scss +1 -0
  72. package/dist/circular-progress/styles/mdc-circular-progress.import.scss +1 -0
  73. package/dist/circular-progress/styles/mdc-circular-progress.scss +14 -0
  74. package/dist/data-table/mdc-data-table-row.js +10 -13
  75. package/dist/data-table/mdc-data-table-row.js.map +1 -1
  76. package/dist/data-table/mdc-data-table.js +88 -91
  77. package/dist/data-table/mdc-data-table.js.map +1 -1
  78. package/dist/data-table/styles/_index.scss +1 -0
  79. package/dist/data-table/styles/mdc-data-table.import.scss +1 -0
  80. package/dist/data-table/styles/mdc-data-table.scss +64 -0
  81. package/dist/dialog/mdc-dialog-actions.js +10 -13
  82. package/dist/dialog/mdc-dialog-actions.js.map +1 -1
  83. package/dist/dialog/mdc-dialog-content.js +6 -9
  84. package/dist/dialog/mdc-dialog-content.js.map +1 -1
  85. package/dist/dialog/mdc-dialog-service.js +13 -17
  86. package/dist/dialog/mdc-dialog-service.js.map +1 -1
  87. package/dist/dialog/mdc-dialog-title.js +6 -9
  88. package/dist/dialog/mdc-dialog-title.js.map +1 -1
  89. package/dist/dialog/mdc-dialog.js +46 -49
  90. package/dist/dialog/mdc-dialog.js.map +1 -1
  91. package/dist/drawer/mdc-drawer-app-content.js +6 -9
  92. package/dist/drawer/mdc-drawer-app-content.js.map +1 -1
  93. package/dist/drawer/mdc-drawer-content.js +6 -9
  94. package/dist/drawer/mdc-drawer-content.js.map +1 -1
  95. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.js +14 -17
  96. package/dist/drawer/mdc-drawer-header/mdc-drawer-header.js.map +1 -1
  97. package/dist/drawer/mdc-drawer.js +21 -24
  98. package/dist/drawer/mdc-drawer.js.map +1 -1
  99. package/dist/drawer/styles/_index.scss +1 -0
  100. package/dist/drawer/styles/mdc-drawer.import.scss +1 -0
  101. package/dist/drawer/styles/mdc-drawer.scss +0 -0
  102. package/dist/elevation/mdc-elevation.js +6 -9
  103. package/dist/elevation/mdc-elevation.js.map +1 -1
  104. package/dist/expandable/mdc-expandable.js +17 -20
  105. package/dist/expandable/mdc-expandable.js.map +1 -1
  106. package/dist/expandable/styles/_icon-variables.scss +3 -0
  107. package/dist/expandable/styles/_index.scss +1 -0
  108. package/dist/expandable/styles/_mixins.scss +287 -0
  109. package/dist/expandable/styles/_variables.scss +17 -0
  110. package/dist/expandable/styles/mdc-expandable.import.scss +1 -0
  111. package/dist/expandable/styles/mdc-expandable.scss +3 -0
  112. package/dist/fab/enhance-mdc-fab.js +6 -9
  113. package/dist/fab/enhance-mdc-fab.js.map +1 -1
  114. package/dist/fab/mdc-fab-icon.js +6 -9
  115. package/dist/fab/mdc-fab-icon.js.map +1 -1
  116. package/dist/fab/mdc-fab.js +30 -33
  117. package/dist/fab/mdc-fab.js.map +1 -1
  118. package/dist/floating-label/mdc-floating-label.js +13 -16
  119. package/dist/floating-label/mdc-floating-label.js.map +1 -1
  120. package/dist/form-field/mdc-form-field.js +24 -27
  121. package/dist/form-field/mdc-form-field.js.map +1 -1
  122. package/dist/icon/mdc-icon.js +7 -10
  123. package/dist/icon/mdc-icon.js.map +1 -1
  124. package/dist/icon-button/enhance-mdc-icon-button.js +6 -9
  125. package/dist/icon-button/enhance-mdc-icon-button.js.map +1 -1
  126. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js +15 -18
  127. package/dist/icon-button/mdc-icon-button-icon/mdc-icon-button-icon.js.map +1 -1
  128. package/dist/icon-button/mdc-icon-button.js +25 -28
  129. package/dist/icon-button/mdc-icon-button.js.map +1 -1
  130. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.js +19 -22
  131. package/dist/image-list/mdc-image-list-item/mdc-image-list-item.js.map +1 -1
  132. package/dist/image-list/mdc-image-list.js +18 -21
  133. package/dist/image-list/mdc-image-list.js.map +1 -1
  134. package/dist/image-list/styles/_index.scss +1 -0
  135. package/dist/image-list/styles/mdc-image-list.import.scss +1 -0
  136. package/dist/image-list/styles/mdc-image-list.scss +7 -0
  137. package/dist/index.js +151 -297
  138. package/dist/index.js.map +1 -1
  139. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js +33 -36
  140. package/dist/layout-grid/mdc-layout-grid-cell/mdc-layout-grid-cell.js.map +1 -1
  141. package/dist/layout-grid/mdc-layout-grid-inner.js +6 -9
  142. package/dist/layout-grid/mdc-layout-grid-inner.js.map +1 -1
  143. package/dist/layout-grid/mdc-layout-grid.js +30 -33
  144. package/dist/layout-grid/mdc-layout-grid.js.map +1 -1
  145. package/dist/layout-grid/styles/_index.scss +1 -0
  146. package/dist/layout-grid/styles/mdc-layout-grid.import.scss +1 -0
  147. package/dist/layout-grid/styles/mdc-layout-grid.scss +11 -0
  148. package/dist/line-ripple/mdc-line-ripple.js +10 -13
  149. package/dist/line-ripple/mdc-line-ripple.js.map +1 -1
  150. package/dist/linear-progress/mdc-linear-progress.js +23 -26
  151. package/dist/linear-progress/mdc-linear-progress.js.map +1 -1
  152. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js +15 -18
  153. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-divider/mdc-deprecated-list-divider.js.map +1 -1
  154. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-group.js +14 -17
  155. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-group.js.map +1 -1
  156. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js +6 -9
  157. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/enhance-mdc-deprecated-list-item.js.map +1 -1
  158. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js +6 -9
  159. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-graphic.js.map +1 -1
  160. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js +6 -9
  161. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item-meta.js.map +1 -1
  162. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js +25 -28
  163. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item/mdc-deprecated-list-item.js.map +1 -1
  164. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js +6 -9
  165. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-primary-text.js.map +1 -1
  166. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js +6 -9
  167. package/dist/list/mdc-deprecated-list/mdc-deprecated-list-item-secondary-text.js.map +1 -1
  168. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.js +75 -78
  169. package/dist/list/mdc-deprecated-list/mdc-deprecated-list.js.map +1 -1
  170. package/dist/list/mdc-list-divider/mdc-list-divider.js +18 -21
  171. package/dist/list/mdc-list-divider/mdc-list-divider.js.map +1 -1
  172. package/dist/list/mdc-list-group.js +14 -17
  173. package/dist/list/mdc-list-group.js.map +1 -1
  174. package/dist/list/mdc-list-item/enhance-mdc-list-item.js +6 -9
  175. package/dist/list/mdc-list-item/enhance-mdc-list-item.js.map +1 -1
  176. package/dist/list/mdc-list-item/mdc-list-item-leading.js +6 -9
  177. package/dist/list/mdc-list-item/mdc-list-item-leading.js.map +1 -1
  178. package/dist/list/mdc-list-item/mdc-list-item-trailing.js +6 -9
  179. package/dist/list/mdc-list-item/mdc-list-item-trailing.js.map +1 -1
  180. package/dist/list/mdc-list-item/mdc-list-item.js +37 -40
  181. package/dist/list/mdc-list-item/mdc-list-item.js.map +1 -1
  182. package/dist/list/mdc-list-item-overline-text.js +6 -9
  183. package/dist/list/mdc-list-item-overline-text.js.map +1 -1
  184. package/dist/list/mdc-list-item-primary-text.js +6 -9
  185. package/dist/list/mdc-list-item-primary-text.js.map +1 -1
  186. package/dist/list/mdc-list-item-secondary-text.js +6 -9
  187. package/dist/list/mdc-list-item-secondary-text.js.map +1 -1
  188. package/dist/list/mdc-list.js +55 -58
  189. package/dist/list/mdc-list.js.map +1 -1
  190. package/dist/list/styles/_index.scss +1 -0
  191. package/dist/list/styles/mdc-list.import.scss +1 -0
  192. package/dist/list/styles/mdc-list.scss +6 -0
  193. package/dist/lookup/discardable-promise.js +1 -5
  194. package/dist/lookup/discardable-promise.js.map +1 -1
  195. package/dist/lookup/mdc-lookup-configuration.js +1 -5
  196. package/dist/lookup/mdc-lookup-configuration.js.map +1 -1
  197. package/dist/lookup/mdc-lookup.js +66 -69
  198. package/dist/lookup/mdc-lookup.js.map +1 -1
  199. package/dist/mdc-configuration.js +11 -15
  200. package/dist/mdc-configuration.js.map +1 -1
  201. package/dist/menu/mdc-menu-selection-group-icon.js +6 -9
  202. package/dist/menu/mdc-menu-selection-group-icon.js.map +1 -1
  203. package/dist/menu/mdc-menu-selection-group.js +6 -9
  204. package/dist/menu/mdc-menu-selection-group.js.map +1 -1
  205. package/dist/menu/mdc-menu.js +68 -71
  206. package/dist/menu/mdc-menu.js.map +1 -1
  207. package/dist/menu-surface/mdc-menu-surface-anchor.js +8 -11
  208. package/dist/menu-surface/mdc-menu-surface-anchor.js.map +1 -1
  209. package/dist/menu-surface/mdc-menu-surface.js +58 -61
  210. package/dist/menu-surface/mdc-menu-surface.js.map +1 -1
  211. package/dist/notched-outline/mdc-notched-outline.js +17 -20
  212. package/dist/notched-outline/mdc-notched-outline.js.map +1 -1
  213. package/dist/radio/mdc-radio.js +24 -27
  214. package/dist/radio/mdc-radio.js.map +1 -1
  215. package/dist/ripple/mdc-ripple.js +48 -51
  216. package/dist/ripple/mdc-ripple.js.map +1 -1
  217. package/dist/ripple/styles/_index.scss +1 -0
  218. package/dist/ripple/styles/mdc-ripple.import.scss +1 -0
  219. package/dist/ripple/styles/mdc-ripple.scss +10 -0
  220. package/dist/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js +6 -9
  221. package/dist/segmented-button/mdc-segmented-button-segment/enhance-mdc-segmented-button-segment.js.map +1 -1
  222. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.js +24 -27
  223. package/dist/segmented-button/mdc-segmented-button-segment/mdc-segmented-button-segment.js.map +1 -1
  224. package/dist/segmented-button/mdc-segmented-button.js +21 -24
  225. package/dist/segmented-button/mdc-segmented-button.js.map +1 -1
  226. package/dist/select/mdc-default-select-configuration.js +1 -5
  227. package/dist/select/mdc-default-select-configuration.js.map +1 -1
  228. package/dist/select/mdc-select-adapter-aurelia.js +1 -2
  229. package/dist/select/mdc-select-adapter-aurelia.js.map +1 -1
  230. package/dist/select/mdc-select-foundation-aurelia.js +43 -47
  231. package/dist/select/mdc-select-foundation-aurelia.js.map +1 -1
  232. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.js +24 -27
  233. package/dist/select/mdc-select-helper-text/mdc-select-helper-text.js.map +1 -1
  234. package/dist/select/mdc-select-icon.js +13 -16
  235. package/dist/select/mdc-select-icon.js.map +1 -1
  236. package/dist/select/mdc-select-value-observer.js +11 -14
  237. package/dist/select/mdc-select-value-observer.js.map +1 -1
  238. package/dist/select/mdc-select.js +64 -67
  239. package/dist/select/mdc-select.js.map +1 -1
  240. package/dist/slider/mdc-slider-foundation-aurelia.js +2 -6
  241. package/dist/slider/mdc-slider-foundation-aurelia.js.map +1 -1
  242. package/dist/slider/mdc-slider.js +76 -79
  243. package/dist/slider/mdc-slider.js.map +1 -1
  244. package/dist/slider/styles/_index.scss +1 -0
  245. package/dist/slider/styles/mdc-slider.import.scss +1 -0
  246. package/dist/slider/styles/mdc-slider.scss +8 -0
  247. package/dist/snackbar/mdc-snackbar-service.js +4 -8
  248. package/dist/snackbar/mdc-snackbar-service.js.map +1 -1
  249. package/dist/snackbar/mdc-snackbar.js +52 -55
  250. package/dist/snackbar/mdc-snackbar.js.map +1 -1
  251. package/dist/switch/enhance-mdc-switch.js +6 -9
  252. package/dist/switch/enhance-mdc-switch.js.map +1 -1
  253. package/dist/switch/mdc-switch.js +13 -16
  254. package/dist/switch/mdc-switch.js.map +1 -1
  255. package/dist/tab-bar/indicator/mdc-tab-indicator.js +23 -26
  256. package/dist/tab-bar/indicator/mdc-tab-indicator.js.map +1 -1
  257. package/dist/tab-bar/mdc-tab-bar.js +26 -29
  258. package/dist/tab-bar/mdc-tab-bar.js.map +1 -1
  259. package/dist/tab-bar/scroller/mdc-tab-scroller.js +22 -25
  260. package/dist/tab-bar/scroller/mdc-tab-scroller.js.map +1 -1
  261. package/dist/tab-bar/tab/mdc-tab.js +41 -44
  262. package/dist/tab-bar/tab/mdc-tab.js.map +1 -1
  263. package/dist/text-field/enhance-mdc-text-field.js +6 -9
  264. package/dist/text-field/enhance-mdc-text-field.js.map +1 -1
  265. package/dist/text-field/mdc-default-text-field-configuration.js +1 -5
  266. package/dist/text-field/mdc-default-text-field-configuration.js.map +1 -1
  267. package/dist/text-field/mdc-inputmask.js +12 -15
  268. package/dist/text-field/mdc-inputmask.js.map +1 -1
  269. package/dist/text-field/mdc-text-field-character-counter.js +10 -13
  270. package/dist/text-field/mdc-text-field-character-counter.js.map +1 -1
  271. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js +11 -14
  272. package/dist/text-field/mdc-text-field-helper-line/mdc-text-field-helper-line.js.map +1 -1
  273. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js +19 -22
  274. package/dist/text-field/mdc-text-field-helper-text/mdc-text-field-helper-text.js.map +1 -1
  275. package/dist/text-field/mdc-text-field-icon.js +19 -22
  276. package/dist/text-field/mdc-text-field-icon.js.map +1 -1
  277. package/dist/text-field/mdc-text-field.js +109 -112
  278. package/dist/text-field/mdc-text-field.js.map +1 -1
  279. package/dist/text-field/styles/_index.scss +1 -0
  280. package/dist/text-field/styles/mdc-text-field.import.scss +1 -0
  281. package/dist/text-field/styles/mdc-text-field.scss +8 -0
  282. package/dist/tooltip/mdc-default-tooltip-configuration.js +1 -5
  283. package/dist/tooltip/mdc-default-tooltip-configuration.js.map +1 -1
  284. package/dist/tooltip/mdc-tooltip-attribute.js +36 -39
  285. package/dist/tooltip/mdc-tooltip-attribute.js.map +1 -1
  286. package/dist/tooltip/mdc-tooltip.js +57 -60
  287. package/dist/tooltip/mdc-tooltip.js.map +1 -1
  288. package/dist/top-app-bar/enhance-top-app-bar-actions.js +6 -9
  289. package/dist/top-app-bar/enhance-top-app-bar-actions.js.map +1 -1
  290. package/dist/top-app-bar/mdc-top-app-bar-action-item.js +6 -9
  291. package/dist/top-app-bar/mdc-top-app-bar-action-item.js.map +1 -1
  292. package/dist/top-app-bar/mdc-top-app-bar-fixed-adjust.js +6 -9
  293. package/dist/top-app-bar/mdc-top-app-bar-fixed-adjust.js.map +1 -1
  294. package/dist/top-app-bar/mdc-top-app-bar-nav-icon.js +6 -9
  295. package/dist/top-app-bar/mdc-top-app-bar-nav-icon.js.map +1 -1
  296. package/dist/top-app-bar/mdc-top-app-bar-row.js +6 -9
  297. package/dist/top-app-bar/mdc-top-app-bar-row.js.map +1 -1
  298. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js +12 -15
  299. package/dist/top-app-bar/mdc-top-app-bar-section/mdc-top-app-bar-section.js.map +1 -1
  300. package/dist/top-app-bar/mdc-top-app-bar-title.js +6 -9
  301. package/dist/top-app-bar/mdc-top-app-bar-title.js.map +1 -1
  302. package/dist/top-app-bar/mdc-top-app-bar.js +40 -43
  303. package/dist/top-app-bar/mdc-top-app-bar.js.map +1 -1
  304. package/dist/tree-view/i-tree-node.js +1 -2
  305. package/dist/tree-view/mdc-tree-node-meta.js +6 -9
  306. package/dist/tree-view/mdc-tree-node-meta.js.map +1 -1
  307. package/dist/tree-view/mdc-tree-node.js +6 -9
  308. package/dist/tree-view/mdc-tree-node.js.map +1 -1
  309. package/dist/tree-view/mdc-tree-view.js +25 -29
  310. package/dist/tree-view/mdc-tree-view.js.map +1 -1
  311. package/dist/tree-view/node-filter.js +6 -9
  312. package/dist/tree-view/node-filter.js.map +1 -1
  313. package/dist/tree-view/styles/_index.scss +1 -0
  314. package/dist/tree-view/styles/_mixins.scss +145 -0
  315. package/dist/tree-view/styles/_variables.scss +8 -0
  316. package/dist/tree-view/styles/mdc-tree-view.import.scss +1 -0
  317. package/dist/tree-view/styles/mdc-tree-view.scss +3 -0
  318. package/dist/typography/mdc-typography.js +57 -60
  319. package/dist/typography/mdc-typography.js.map +1 -1
  320. package/dist/validation/mdc-validation-controller-factory.js +6 -10
  321. package/dist/validation/mdc-validation-controller-factory.js.map +1 -1
  322. package/dist/validation/mdc-validation-result-presenter.js +1 -5
  323. package/dist/validation/mdc-validation-result-presenter.js.map +1 -1
  324. package/dist/validation/validate.js +1 -4
  325. package/dist/validation/validate.js.map +1 -1
  326. package/package.json +2 -2
@@ -1,19 +1,16 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MdcMenuSurface = void 0;
4
- const tslib_1 = require("tslib");
5
- const base_1 = require("../base");
6
- const menu_surface_1 = require("@material/menu-surface");
7
- const aurelia_1 = require("aurelia");
8
- const util_1 = require("@material/animation/util");
9
- menu_surface_1.strings.OPENED_EVENT = menu_surface_1.strings.OPENED_EVENT.toLowerCase();
10
- menu_surface_1.strings.CLOSED_EVENT = menu_surface_1.strings.CLOSED_EVENT.toLowerCase();
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { MdcComponent, booleanAttr, number } from '../base';
3
+ import { MDCMenuSurfaceFoundation, cssClasses, Corner, strings } from '@material/menu-surface';
4
+ import { inject, customAttribute, bindable, BindingMode } from 'aurelia';
5
+ import { getCorrectPropertyName } from '@material/animation/util';
6
+ strings.OPENED_EVENT = strings.OPENED_EVENT.toLowerCase();
7
+ strings.CLOSED_EVENT = strings.CLOSED_EVENT.toLowerCase();
11
8
  let MdcMenuSurface = (() => {
12
- let _classDecorators = [(0, aurelia_1.inject)(Element), (0, aurelia_1.customAttribute)('mdc-menu-surface')];
9
+ let _classDecorators = [inject(Element), customAttribute('mdc-menu-surface')];
13
10
  let _classDescriptor;
14
11
  let _classExtraInitializers = [];
15
12
  let _classThis;
16
- let _classSuper = base_1.MdcComponent;
13
+ let _classSuper = MdcComponent;
17
14
  let _anchor_decorators;
18
15
  let _anchor_initializers = [];
19
16
  let _anchor_extraInitializers = [];
@@ -51,65 +48,65 @@ let MdcMenuSurface = (() => {
51
48
  static { _classThis = this; }
52
49
  static {
53
50
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
54
- _anchor_decorators = [(0, aurelia_1.bindable)()];
55
- _hoistToBody_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr, mode: aurelia_1.BindingMode.oneTime })];
56
- _fixed_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
57
- _anchorCorner_decorators = [(0, aurelia_1.bindable)()];
58
- _anchorMargin_decorators = [(0, aurelia_1.bindable)()];
59
- _quickOpen_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
60
- _fullWidth_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
61
- _stayOpen_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
62
- _maxHeight_decorators = [(0, aurelia_1.bindable)({ set: base_1.number })];
63
- _horizontallyCenteredOnViewport_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
64
- _openBottomBias_decorators = [(0, aurelia_1.bindable)({ set: base_1.number })];
65
- tslib_1.__esDecorate(null, null, _anchor_decorators, { kind: "field", name: "anchor", static: false, private: false, access: { has: obj => "anchor" in obj, get: obj => obj.anchor, set: (obj, value) => { obj.anchor = value; } }, metadata: _metadata }, _anchor_initializers, _anchor_extraInitializers);
66
- tslib_1.__esDecorate(null, null, _hoistToBody_decorators, { kind: "field", name: "hoistToBody", static: false, private: false, access: { has: obj => "hoistToBody" in obj, get: obj => obj.hoistToBody, set: (obj, value) => { obj.hoistToBody = value; } }, metadata: _metadata }, _hoistToBody_initializers, _hoistToBody_extraInitializers);
67
- tslib_1.__esDecorate(null, null, _fixed_decorators, { kind: "field", name: "fixed", static: false, private: false, access: { has: obj => "fixed" in obj, get: obj => obj.fixed, set: (obj, value) => { obj.fixed = value; } }, metadata: _metadata }, _fixed_initializers, _fixed_extraInitializers);
68
- tslib_1.__esDecorate(null, null, _anchorCorner_decorators, { kind: "field", name: "anchorCorner", static: false, private: false, access: { has: obj => "anchorCorner" in obj, get: obj => obj.anchorCorner, set: (obj, value) => { obj.anchorCorner = value; } }, metadata: _metadata }, _anchorCorner_initializers, _anchorCorner_extraInitializers);
69
- tslib_1.__esDecorate(null, null, _anchorMargin_decorators, { kind: "field", name: "anchorMargin", static: false, private: false, access: { has: obj => "anchorMargin" in obj, get: obj => obj.anchorMargin, set: (obj, value) => { obj.anchorMargin = value; } }, metadata: _metadata }, _anchorMargin_initializers, _anchorMargin_extraInitializers);
70
- tslib_1.__esDecorate(null, null, _quickOpen_decorators, { kind: "field", name: "quickOpen", static: false, private: false, access: { has: obj => "quickOpen" in obj, get: obj => obj.quickOpen, set: (obj, value) => { obj.quickOpen = value; } }, metadata: _metadata }, _quickOpen_initializers, _quickOpen_extraInitializers);
71
- tslib_1.__esDecorate(null, null, _fullWidth_decorators, { kind: "field", name: "fullWidth", static: false, private: false, access: { has: obj => "fullWidth" in obj, get: obj => obj.fullWidth, set: (obj, value) => { obj.fullWidth = value; } }, metadata: _metadata }, _fullWidth_initializers, _fullWidth_extraInitializers);
72
- tslib_1.__esDecorate(null, null, _stayOpen_decorators, { kind: "field", name: "stayOpen", static: false, private: false, access: { has: obj => "stayOpen" in obj, get: obj => obj.stayOpen, set: (obj, value) => { obj.stayOpen = value; } }, metadata: _metadata }, _stayOpen_initializers, _stayOpen_extraInitializers);
73
- tslib_1.__esDecorate(null, null, _maxHeight_decorators, { kind: "field", name: "maxHeight", static: false, private: false, access: { has: obj => "maxHeight" in obj, get: obj => obj.maxHeight, set: (obj, value) => { obj.maxHeight = value; } }, metadata: _metadata }, _maxHeight_initializers, _maxHeight_extraInitializers);
74
- tslib_1.__esDecorate(null, null, _horizontallyCenteredOnViewport_decorators, { kind: "field", name: "horizontallyCenteredOnViewport", static: false, private: false, access: { has: obj => "horizontallyCenteredOnViewport" in obj, get: obj => obj.horizontallyCenteredOnViewport, set: (obj, value) => { obj.horizontallyCenteredOnViewport = value; } }, metadata: _metadata }, _horizontallyCenteredOnViewport_initializers, _horizontallyCenteredOnViewport_extraInitializers);
75
- tslib_1.__esDecorate(null, null, _openBottomBias_decorators, { kind: "field", name: "openBottomBias", static: false, private: false, access: { has: obj => "openBottomBias" in obj, get: obj => obj.openBottomBias, set: (obj, value) => { obj.openBottomBias = value; } }, metadata: _metadata }, _openBottomBias_initializers, _openBottomBias_extraInitializers);
76
- tslib_1.__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
51
+ _anchor_decorators = [bindable()];
52
+ _hoistToBody_decorators = [bindable({ set: booleanAttr, mode: BindingMode.oneTime })];
53
+ _fixed_decorators = [bindable({ set: booleanAttr })];
54
+ _anchorCorner_decorators = [bindable()];
55
+ _anchorMargin_decorators = [bindable()];
56
+ _quickOpen_decorators = [bindable({ set: booleanAttr })];
57
+ _fullWidth_decorators = [bindable({ set: booleanAttr })];
58
+ _stayOpen_decorators = [bindable({ set: booleanAttr })];
59
+ _maxHeight_decorators = [bindable({ set: number })];
60
+ _horizontallyCenteredOnViewport_decorators = [bindable({ set: booleanAttr })];
61
+ _openBottomBias_decorators = [bindable({ set: number })];
62
+ __esDecorate(null, null, _anchor_decorators, { kind: "field", name: "anchor", static: false, private: false, access: { has: obj => "anchor" in obj, get: obj => obj.anchor, set: (obj, value) => { obj.anchor = value; } }, metadata: _metadata }, _anchor_initializers, _anchor_extraInitializers);
63
+ __esDecorate(null, null, _hoistToBody_decorators, { kind: "field", name: "hoistToBody", static: false, private: false, access: { has: obj => "hoistToBody" in obj, get: obj => obj.hoistToBody, set: (obj, value) => { obj.hoistToBody = value; } }, metadata: _metadata }, _hoistToBody_initializers, _hoistToBody_extraInitializers);
64
+ __esDecorate(null, null, _fixed_decorators, { kind: "field", name: "fixed", static: false, private: false, access: { has: obj => "fixed" in obj, get: obj => obj.fixed, set: (obj, value) => { obj.fixed = value; } }, metadata: _metadata }, _fixed_initializers, _fixed_extraInitializers);
65
+ __esDecorate(null, null, _anchorCorner_decorators, { kind: "field", name: "anchorCorner", static: false, private: false, access: { has: obj => "anchorCorner" in obj, get: obj => obj.anchorCorner, set: (obj, value) => { obj.anchorCorner = value; } }, metadata: _metadata }, _anchorCorner_initializers, _anchorCorner_extraInitializers);
66
+ __esDecorate(null, null, _anchorMargin_decorators, { kind: "field", name: "anchorMargin", static: false, private: false, access: { has: obj => "anchorMargin" in obj, get: obj => obj.anchorMargin, set: (obj, value) => { obj.anchorMargin = value; } }, metadata: _metadata }, _anchorMargin_initializers, _anchorMargin_extraInitializers);
67
+ __esDecorate(null, null, _quickOpen_decorators, { kind: "field", name: "quickOpen", static: false, private: false, access: { has: obj => "quickOpen" in obj, get: obj => obj.quickOpen, set: (obj, value) => { obj.quickOpen = value; } }, metadata: _metadata }, _quickOpen_initializers, _quickOpen_extraInitializers);
68
+ __esDecorate(null, null, _fullWidth_decorators, { kind: "field", name: "fullWidth", static: false, private: false, access: { has: obj => "fullWidth" in obj, get: obj => obj.fullWidth, set: (obj, value) => { obj.fullWidth = value; } }, metadata: _metadata }, _fullWidth_initializers, _fullWidth_extraInitializers);
69
+ __esDecorate(null, null, _stayOpen_decorators, { kind: "field", name: "stayOpen", static: false, private: false, access: { has: obj => "stayOpen" in obj, get: obj => obj.stayOpen, set: (obj, value) => { obj.stayOpen = value; } }, metadata: _metadata }, _stayOpen_initializers, _stayOpen_extraInitializers);
70
+ __esDecorate(null, null, _maxHeight_decorators, { kind: "field", name: "maxHeight", static: false, private: false, access: { has: obj => "maxHeight" in obj, get: obj => obj.maxHeight, set: (obj, value) => { obj.maxHeight = value; } }, metadata: _metadata }, _maxHeight_initializers, _maxHeight_extraInitializers);
71
+ __esDecorate(null, null, _horizontallyCenteredOnViewport_decorators, { kind: "field", name: "horizontallyCenteredOnViewport", static: false, private: false, access: { has: obj => "horizontallyCenteredOnViewport" in obj, get: obj => obj.horizontallyCenteredOnViewport, set: (obj, value) => { obj.horizontallyCenteredOnViewport = value; } }, metadata: _metadata }, _horizontallyCenteredOnViewport_initializers, _horizontallyCenteredOnViewport_extraInitializers);
72
+ __esDecorate(null, null, _openBottomBias_decorators, { kind: "field", name: "openBottomBias", static: false, private: false, access: { has: obj => "openBottomBias" in obj, get: obj => obj.openBottomBias, set: (obj, value) => { obj.openBottomBias = value; } }, metadata: _metadata }, _openBottomBias_initializers, _openBottomBias_extraInitializers);
73
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
77
74
  MdcMenuSurface = _classThis = _classDescriptor.value;
78
75
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
79
- tslib_1.__runInitializers(_classThis, _classExtraInitializers);
76
+ __runInitializers(_classThis, _classExtraInitializers);
80
77
  }
81
78
  originalParent;
82
79
  previousFocus;
83
- anchor = tslib_1.__runInitializers(this, _anchor_initializers, void 0);
80
+ anchor = __runInitializers(this, _anchor_initializers, void 0);
84
81
  /** Sets the foundation to use page offsets for an positioning when the menu is hoisted to the body. */
85
- hoistToBody = (tslib_1.__runInitializers(this, _anchor_extraInitializers), tslib_1.__runInitializers(this, _hoistToBody_initializers, void 0));
86
- fixed = (tslib_1.__runInitializers(this, _hoistToBody_extraInitializers), tslib_1.__runInitializers(this, _fixed_initializers, void 0));
82
+ hoistToBody = (__runInitializers(this, _anchor_extraInitializers), __runInitializers(this, _hoistToBody_initializers, void 0));
83
+ fixed = (__runInitializers(this, _hoistToBody_extraInitializers), __runInitializers(this, _fixed_initializers, void 0));
87
84
  fixedChanged() {
88
85
  if (this.fixed) {
89
- this.root.classList.add(menu_surface_1.cssClasses.FIXED);
86
+ this.root.classList.add(cssClasses.FIXED);
90
87
  }
91
88
  else {
92
- this.root.classList.remove(menu_surface_1.cssClasses.FIXED);
89
+ this.root.classList.remove(cssClasses.FIXED);
93
90
  }
94
91
  this.foundation?.setFixedPosition(this.fixed);
95
92
  }
96
- anchorCorner = (tslib_1.__runInitializers(this, _fixed_extraInitializers), tslib_1.__runInitializers(this, _anchorCorner_initializers, void 0));
93
+ anchorCorner = (__runInitializers(this, _fixed_extraInitializers), __runInitializers(this, _anchorCorner_initializers, void 0));
97
94
  anchorCornerChanged() {
98
95
  if (this.anchorCorner !== undefined) {
99
- this.foundation?.setAnchorCorner(menu_surface_1.Corner[this.anchorCorner]);
96
+ this.foundation?.setAnchorCorner(Corner[this.anchorCorner]);
100
97
  }
101
98
  }
102
- anchorMargin = (tslib_1.__runInitializers(this, _anchorCorner_extraInitializers), tslib_1.__runInitializers(this, _anchorMargin_initializers, void 0));
99
+ anchorMargin = (__runInitializers(this, _anchorCorner_extraInitializers), __runInitializers(this, _anchorMargin_initializers, void 0));
103
100
  anchorMarginChanged() {
104
101
  if (this.anchorMargin !== undefined) {
105
102
  this.foundation?.setAnchorMargin(this.anchorMargin);
106
103
  }
107
104
  }
108
- quickOpen = (tslib_1.__runInitializers(this, _anchorMargin_extraInitializers), tslib_1.__runInitializers(this, _quickOpen_initializers, void 0));
105
+ quickOpen = (__runInitializers(this, _anchorMargin_extraInitializers), __runInitializers(this, _quickOpen_initializers, void 0));
109
106
  quickOpenChanged() {
110
107
  this.foundation?.setQuickOpen(this.quickOpen);
111
108
  }
112
- fullWidth = (tslib_1.__runInitializers(this, _quickOpen_extraInitializers), tslib_1.__runInitializers(this, _fullWidth_initializers, void 0));
109
+ fullWidth = (__runInitializers(this, _quickOpen_extraInitializers), __runInitializers(this, _fullWidth_initializers, void 0));
113
110
  fullWidthChanged() {
114
111
  if (this.fullWidth) {
115
112
  this.root.classList.add('mdc-menu-surface--fullwidth');
@@ -118,18 +115,18 @@ let MdcMenuSurface = (() => {
118
115
  this.root.classList.remove('mdc-menu-surface--fullwidth');
119
116
  }
120
117
  }
121
- stayOpen = (tslib_1.__runInitializers(this, _fullWidth_extraInitializers), tslib_1.__runInitializers(this, _stayOpen_initializers, void 0));
122
- maxHeight = (tslib_1.__runInitializers(this, _stayOpen_extraInitializers), tslib_1.__runInitializers(this, _maxHeight_initializers, void 0));
118
+ stayOpen = (__runInitializers(this, _fullWidth_extraInitializers), __runInitializers(this, _stayOpen_initializers, void 0));
119
+ maxHeight = (__runInitializers(this, _stayOpen_extraInitializers), __runInitializers(this, _maxHeight_initializers, void 0));
123
120
  async maxHeightChanged() {
124
121
  await this.initialised;
125
122
  this.foundation?.setMaxHeight(this.maxHeight);
126
123
  }
127
- horizontallyCenteredOnViewport = (tslib_1.__runInitializers(this, _maxHeight_extraInitializers), tslib_1.__runInitializers(this, _horizontallyCenteredOnViewport_initializers, void 0));
124
+ horizontallyCenteredOnViewport = (__runInitializers(this, _maxHeight_extraInitializers), __runInitializers(this, _horizontallyCenteredOnViewport_initializers, void 0));
128
125
  async horizontallyCenteredOnViewportChanged() {
129
126
  await this.initialised;
130
127
  this.foundation?.setIsHorizontallyCenteredOnViewport(this.horizontallyCenteredOnViewport);
131
128
  }
132
- openBottomBias = (tslib_1.__runInitializers(this, _horizontallyCenteredOnViewport_extraInitializers), tslib_1.__runInitializers(this, _openBottomBias_initializers, void 0));
129
+ openBottomBias = (__runInitializers(this, _horizontallyCenteredOnViewport_extraInitializers), __runInitializers(this, _openBottomBias_initializers, void 0));
133
130
  async openBottomBiasChanged() {
134
131
  await this.initialised;
135
132
  this.foundation?.setOpenBottomBias(this.openBottomBias);
@@ -154,7 +151,7 @@ let MdcMenuSurface = (() => {
154
151
  }
155
152
  }
156
153
  attaching() {
157
- this.root.classList.add(menu_surface_1.cssClasses.ROOT);
154
+ this.root.classList.add(cssClasses.ROOT);
158
155
  }
159
156
  handleEvent(evt) {
160
157
  switch (evt.currentTarget) {
@@ -192,7 +189,7 @@ let MdcMenuSurface = (() => {
192
189
  this.anchorMarginChanged();
193
190
  const parentEl = this.root.parentElement;
194
191
  if (!this.anchor) {
195
- this.anchor = parentEl?.classList.contains(menu_surface_1.cssClasses.ANCHOR) ? parentEl : null;
192
+ this.anchor = parentEl?.classList.contains(cssClasses.ANCHOR) ? parentEl : null;
196
193
  }
197
194
  if (this.hoistToBody) {
198
195
  this.originalParent = this.root.parentElement;
@@ -203,7 +200,7 @@ let MdcMenuSurface = (() => {
203
200
  }
204
201
  this.foundation?.setFixedPosition(this.fixed);
205
202
  if (this.anchorCorner) {
206
- this.foundation?.setAnchorCorner(menu_surface_1.Corner[this.anchorCorner]);
203
+ this.foundation?.setAnchorCorner(Corner[this.anchorCorner]);
207
204
  }
208
205
  if (this.anchorMargin) {
209
206
  this.foundation?.setAnchorMargin(this.anchorMargin);
@@ -246,23 +243,23 @@ let MdcMenuSurface = (() => {
246
243
  hasClass: (className) => this.root.classList.contains(className),
247
244
  hasAnchor: () => !!this.anchor,
248
245
  notifyClose: () => {
249
- this.emit(menu_surface_1.MDCMenuSurfaceFoundation.strings.CLOSED_EVENT, {});
246
+ this.emit(MDCMenuSurfaceFoundation.strings.CLOSED_EVENT, {});
250
247
  this.deregisterBodyClickListener();
251
248
  },
252
249
  notifyClosing: () => {
253
- this.emit(menu_surface_1.MDCMenuSurfaceFoundation.strings.CLOSING_EVENT, {});
250
+ this.emit(MDCMenuSurfaceFoundation.strings.CLOSING_EVENT, {});
254
251
  },
255
252
  notifyOpen: () => {
256
- this.emit(menu_surface_1.MDCMenuSurfaceFoundation.strings.OPENED_EVENT, {});
253
+ this.emit(MDCMenuSurfaceFoundation.strings.OPENED_EVENT, {});
257
254
  this.registerBodyClickListener();
258
255
  },
259
256
  notifyOpening: () => {
260
- this.emit(menu_surface_1.MDCMenuSurfaceFoundation.strings.OPENING_EVENT, {});
257
+ this.emit(MDCMenuSurfaceFoundation.strings.OPENING_EVENT, {});
261
258
  },
262
259
  isElementInContainer: (el) => this.root.contains(el),
263
260
  isRtl: () => getComputedStyle(this.root).getPropertyValue('direction') === 'rtl',
264
261
  setTransformOrigin: (origin) => {
265
- const propertyName = `${(0, util_1.getCorrectPropertyName)(window, 'transform')}-origin`;
262
+ const propertyName = `${getCorrectPropertyName(window, 'transform')}-origin`;
266
263
  this.root.style.setProperty(propertyName, origin);
267
264
  },
268
265
  isFocused: () => document.activeElement === this.root,
@@ -307,14 +304,14 @@ let MdcMenuSurface = (() => {
307
304
  (this.root).style.maxHeight = height;
308
305
  },
309
306
  };
310
- return new menu_surface_1.MDCMenuSurfaceFoundation(adapter);
307
+ return new MDCMenuSurfaceFoundation(adapter);
311
308
  }
312
309
  constructor() {
313
310
  super(...arguments);
314
- tslib_1.__runInitializers(this, _openBottomBias_extraInitializers);
311
+ __runInitializers(this, _openBottomBias_extraInitializers);
315
312
  }
316
313
  };
317
314
  return MdcMenuSurface = _classThis;
318
315
  })();
319
- exports.MdcMenuSurface = MdcMenuSurface;
316
+ export { MdcMenuSurface };
320
317
  //# sourceMappingURL=mdc-menu-surface.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"mdc-menu-surface.js","sourceRoot":"","sources":["../../src/menu-surface/mdc-menu-surface.ts"],"names":[],"mappings":"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","sourcesContent":["import { MdcComponent, booleanAttr, number } from '../base';\r\nimport { MDCMenuSurfaceFoundation, MDCMenuSurfaceAdapter, cssClasses, Corner, MDCMenuDistance, strings } from '@material/menu-surface';\r\nimport { inject, customAttribute, bindable, BindingMode } from 'aurelia';\r\nimport { getCorrectPropertyName } from '@material/animation/util';\r\n\r\nstrings.OPENED_EVENT = strings.OPENED_EVENT.toLowerCase();\r\nstrings.CLOSED_EVENT = strings.CLOSED_EVENT.toLowerCase();\r\n\r\n@inject(Element)\r\n@customAttribute('mdc-menu-surface')\r\nexport class MdcMenuSurface extends MdcComponent<MDCMenuSurfaceFoundation> implements EventListenerObject {\r\n originalParent: HTMLElement | null;\r\n private previousFocus?: HTMLElement | SVGElement | null;\r\n\r\n @bindable()\r\n anchor?: Element | null;\r\n\r\n /** Sets the foundation to use page offsets for an positioning when the menu is hoisted to the body. */\r\n @bindable({ set: booleanAttr, mode: BindingMode.oneTime })\r\n hoistToBody: boolean;\r\n\r\n @bindable({ set: booleanAttr })\r\n fixed: boolean;\r\n fixedChanged() {\r\n if (this.fixed) {\r\n this.root.classList.add(cssClasses.FIXED);\r\n } else {\r\n this.root.classList.remove(cssClasses.FIXED);\r\n }\r\n this.foundation?.setFixedPosition(this.fixed);\r\n }\r\n\r\n @bindable()\r\n anchorCorner?: keyof typeof Corner;\r\n anchorCornerChanged() {\r\n if (this.anchorCorner !== undefined) {\r\n this.foundation?.setAnchorCorner(Corner[this.anchorCorner]);\r\n }\r\n }\r\n\r\n @bindable()\r\n anchorMargin?: Partial<MDCMenuDistance>;\r\n anchorMarginChanged() {\r\n if (this.anchorMargin !== undefined) {\r\n this.foundation?.setAnchorMargin(this.anchorMargin);\r\n }\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n quickOpen: boolean;\r\n quickOpenChanged() {\r\n this.foundation?.setQuickOpen(this.quickOpen);\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n fullWidth: boolean;\r\n fullWidthChanged() {\r\n if (this.fullWidth) {\r\n this.root.classList.add('mdc-menu-surface--fullwidth');\r\n } else {\r\n this.root.classList.remove('mdc-menu-surface--fullwidth');\r\n }\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n stayOpen: boolean;\r\n\r\n @bindable({ set: number })\r\n maxHeight: number;\r\n async maxHeightChanged() {\r\n await this.initialised;\r\n this.foundation?.setMaxHeight(this.maxHeight);\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n horizontallyCenteredOnViewport: boolean;\r\n async horizontallyCenteredOnViewportChanged() {\r\n await this.initialised;\r\n this.foundation?.setIsHorizontallyCenteredOnViewport(this.horizontallyCenteredOnViewport);\r\n }\r\n\r\n @bindable({ set: number })\r\n openBottomBias: number;\r\n async openBottomBiasChanged() {\r\n await this.initialised;\r\n this.foundation?.setOpenBottomBias(this.openBottomBias);\r\n }\r\n\r\n get open(): boolean {\r\n return this.foundation?.isOpen() ?? false;\r\n }\r\n\r\n set open(value: boolean) {\r\n if (value) {\r\n this.foundation?.open();\r\n } else {\r\n this.foundation?.close();\r\n }\r\n }\r\n\r\n handleKeydown(evt: KeyboardEvent) {\r\n this.foundation?.handleKeydown(evt);\r\n }\r\n\r\n handleBodyClick(evt: MouseEvent) {\r\n if (!this.stayOpen) {\r\n this.foundation?.handleBodyClick(evt);\r\n }\r\n }\r\n\r\n attaching() {\r\n this.root.classList.add(cssClasses.ROOT);\r\n }\r\n\r\n handleEvent(evt: Event): void {\r\n switch (evt.currentTarget) {\r\n case this.root:\r\n switch (evt.type) {\r\n case 'keydown': this.handleKeydown(evt as KeyboardEvent); break;\r\n }\r\n break;\r\n case document.body:\r\n switch (evt.type) {\r\n case 'click': this.handleBodyClick(evt as MouseEvent); break;\r\n }\r\n break;\r\n }\r\n }\r\n\r\n registerBodyClickListener() {\r\n // this is different to native implementation\r\n // refer to https://github.com/material-components/material-components-web/issues/6188\r\n // capture so that no race between handleBodyClick and quickOpen when\r\n // menusurface opened on button click which registers this listener\r\n document.body.addEventListener('click', this);\r\n }\r\n\r\n deregisterBodyClickListener() {\r\n document.body.removeEventListener('click', this);\r\n }\r\n\r\n initialSyncWithDOM() {\r\n this.fixedChanged();\r\n this.fullWidthChanged();\r\n this.quickOpenChanged();\r\n this.anchorCornerChanged();\r\n this.anchorMarginChanged();\r\n\r\n const parentEl = this.root.parentElement;\r\n if (!this.anchor) {\r\n this.anchor = parentEl?.classList.contains(cssClasses.ANCHOR) ? parentEl : null;\r\n }\r\n if (this.hoistToBody) {\r\n this.originalParent = this.root.parentElement;\r\n if (this.originalParent) {\r\n document.body.appendChild(this.originalParent.removeChild(this.root));\r\n this.foundation?.setIsHoisted(true);\r\n }\r\n }\r\n this.foundation?.setFixedPosition(this.fixed);\r\n if (this.anchorCorner) {\r\n this.foundation?.setAnchorCorner(Corner[this.anchorCorner]);\r\n }\r\n if (this.anchorMargin) {\r\n this.foundation?.setAnchorMargin(this.anchorMargin);\r\n }\r\n if (this.maxHeight) {\r\n this.foundation?.setMaxHeight(this.maxHeight);\r\n }\r\n if (this.horizontallyCenteredOnViewport !== undefined) {\r\n this.foundation?.setIsHorizontallyCenteredOnViewport(this.horizontallyCenteredOnViewport);\r\n }\r\n this.listen('keydown', this);\r\n }\r\n\r\n destroy() {\r\n this.unlisten('keydown', this);\r\n if (this.originalParent) {\r\n this.originalParent.appendChild(document.body.removeChild(this.root));\r\n }\r\n super.destroy();\r\n }\r\n\r\n close(skipRestoreFocus = false) {\r\n this.foundation?.close(skipRestoreFocus);\r\n }\r\n\r\n /** Sets the absolute x/y position to position based on. Requires the menu to be hoisted. */\r\n setAbsolutePosition(x: number, y: number) {\r\n this.foundation?.setAbsolutePosition(x, y);\r\n this.hoistToBody = true;\r\n }\r\n\r\n /**\r\n * @param corner Default anchor corner alignment of top-left surface corner.\r\n */\r\n setAnchorCorner(corner: Corner) {\r\n this.foundation?.setAnchorCorner(corner);\r\n }\r\n\r\n getDefaultFoundation() {\r\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\r\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\r\n const adapter: MDCMenuSurfaceAdapter = {\r\n addClass: (className) => this.root.classList.add(className),\r\n removeClass: (className) => this.root.classList.remove(className),\r\n hasClass: (className) => this.root.classList.contains(className),\r\n hasAnchor: () => !!this.anchor,\r\n notifyClose: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.CLOSED_EVENT, {});\r\n this.deregisterBodyClickListener();\r\n },\r\n notifyClosing: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.CLOSING_EVENT, {});\r\n },\r\n notifyOpen: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.OPENED_EVENT, {});\r\n this.registerBodyClickListener();\r\n },\r\n notifyOpening: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.OPENING_EVENT, {});\r\n },\r\n isElementInContainer: (el) => this.root.contains(el),\r\n isRtl: () => getComputedStyle(this.root).getPropertyValue('direction') === 'rtl',\r\n setTransformOrigin: (origin) => {\r\n const propertyName =\r\n `${getCorrectPropertyName(window, 'transform')}-origin`;\r\n this.root.style.setProperty(propertyName, origin);\r\n },\r\n isFocused: () => document.activeElement === this.root,\r\n saveFocus: () => {\r\n this.previousFocus = document.activeElement as HTMLElement | SVGElement | null;\r\n },\r\n restoreFocus: () => {\r\n if (this.root.contains(document.activeElement)) {\r\n if (this.previousFocus?.focus) {\r\n this.previousFocus.focus();\r\n }\r\n }\r\n },\r\n getInnerDimensions: () => {\r\n const firstChild = this.root.firstElementChild as HTMLElement;\r\n // workaround https://github.com/material-components/material-components-web/issues/6709\r\n // by explicitly displaying vertical scroll if a list does not fit\r\n this.root.style.overflowY = this.root.offsetHeight < firstChild.offsetHeight ? 'scroll' : '';\r\n return {\r\n width: this.root.offsetWidth,\r\n height: this.root.offsetHeight\r\n };\r\n },\r\n getAnchorDimensions: () => this.anchor ? this.anchor.getBoundingClientRect() : null,\r\n getWindowDimensions: () => {\r\n return { width: window.innerWidth, height: window.innerHeight };\r\n },\r\n getBodyDimensions: () => {\r\n return { width: document.body.clientWidth, height: document.body.clientHeight };\r\n },\r\n getWindowScroll: () => {\r\n return { x: window.pageXOffset, y: window.pageYOffset };\r\n },\r\n setPosition: (position) => {\r\n const rootHTML = this.root;\r\n rootHTML.style.left = 'left' in position ? `${position.left}px` : '';\r\n rootHTML.style.right = 'right' in position ? `${position.right}px` : '';\r\n rootHTML.style.top = 'top' in position ? `${position.top}px` : '';\r\n rootHTML.style.bottom = 'bottom' in position ? `${position.bottom}px` : '';\r\n },\r\n setMaxHeight: (height) => {\r\n (this.root).style.maxHeight = height;\r\n },\r\n };\r\n return new MDCMenuSurfaceFoundation(adapter);\r\n }\r\n\r\n}\r\n"]}
1
+ {"version":3,"file":"mdc-menu-surface.js","sourceRoot":"","sources":["../../src/menu-surface/mdc-menu-surface.ts"],"names":[],"mappings":"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","sourcesContent":["import { MdcComponent, booleanAttr, number } from '../base';\r\nimport { MDCMenuSurfaceFoundation, MDCMenuSurfaceAdapter, cssClasses, Corner, MDCMenuDistance, strings } from '@material/menu-surface';\r\nimport { inject, customAttribute, bindable, BindingMode } from 'aurelia';\r\nimport { getCorrectPropertyName } from '@material/animation/util';\r\n\r\nstrings.OPENED_EVENT = strings.OPENED_EVENT.toLowerCase();\r\nstrings.CLOSED_EVENT = strings.CLOSED_EVENT.toLowerCase();\r\n\r\n@inject(Element)\r\n@customAttribute('mdc-menu-surface')\r\nexport class MdcMenuSurface extends MdcComponent<MDCMenuSurfaceFoundation> implements EventListenerObject {\r\n originalParent: HTMLElement | null;\r\n private previousFocus?: HTMLElement | SVGElement | null;\r\n\r\n @bindable()\r\n anchor?: Element | null;\r\n\r\n /** Sets the foundation to use page offsets for an positioning when the menu is hoisted to the body. */\r\n @bindable({ set: booleanAttr, mode: BindingMode.oneTime })\r\n hoistToBody: boolean;\r\n\r\n @bindable({ set: booleanAttr })\r\n fixed: boolean;\r\n fixedChanged() {\r\n if (this.fixed) {\r\n this.root.classList.add(cssClasses.FIXED);\r\n } else {\r\n this.root.classList.remove(cssClasses.FIXED);\r\n }\r\n this.foundation?.setFixedPosition(this.fixed);\r\n }\r\n\r\n @bindable()\r\n anchorCorner?: keyof typeof Corner;\r\n anchorCornerChanged() {\r\n if (this.anchorCorner !== undefined) {\r\n this.foundation?.setAnchorCorner(Corner[this.anchorCorner]);\r\n }\r\n }\r\n\r\n @bindable()\r\n anchorMargin?: Partial<MDCMenuDistance>;\r\n anchorMarginChanged() {\r\n if (this.anchorMargin !== undefined) {\r\n this.foundation?.setAnchorMargin(this.anchorMargin);\r\n }\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n quickOpen: boolean;\r\n quickOpenChanged() {\r\n this.foundation?.setQuickOpen(this.quickOpen);\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n fullWidth: boolean;\r\n fullWidthChanged() {\r\n if (this.fullWidth) {\r\n this.root.classList.add('mdc-menu-surface--fullwidth');\r\n } else {\r\n this.root.classList.remove('mdc-menu-surface--fullwidth');\r\n }\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n stayOpen: boolean;\r\n\r\n @bindable({ set: number })\r\n maxHeight: number;\r\n async maxHeightChanged() {\r\n await this.initialised;\r\n this.foundation?.setMaxHeight(this.maxHeight);\r\n }\r\n\r\n @bindable({ set: booleanAttr })\r\n horizontallyCenteredOnViewport: boolean;\r\n async horizontallyCenteredOnViewportChanged() {\r\n await this.initialised;\r\n this.foundation?.setIsHorizontallyCenteredOnViewport(this.horizontallyCenteredOnViewport);\r\n }\r\n\r\n @bindable({ set: number })\r\n openBottomBias: number;\r\n async openBottomBiasChanged() {\r\n await this.initialised;\r\n this.foundation?.setOpenBottomBias(this.openBottomBias);\r\n }\r\n\r\n get open(): boolean {\r\n return this.foundation?.isOpen() ?? false;\r\n }\r\n\r\n set open(value: boolean) {\r\n if (value) {\r\n this.foundation?.open();\r\n } else {\r\n this.foundation?.close();\r\n }\r\n }\r\n\r\n handleKeydown(evt: KeyboardEvent) {\r\n this.foundation?.handleKeydown(evt);\r\n }\r\n\r\n handleBodyClick(evt: MouseEvent) {\r\n if (!this.stayOpen) {\r\n this.foundation?.handleBodyClick(evt);\r\n }\r\n }\r\n\r\n attaching() {\r\n this.root.classList.add(cssClasses.ROOT);\r\n }\r\n\r\n handleEvent(evt: Event): void {\r\n switch (evt.currentTarget) {\r\n case this.root:\r\n switch (evt.type) {\r\n case 'keydown': this.handleKeydown(evt as KeyboardEvent); break;\r\n }\r\n break;\r\n case document.body:\r\n switch (evt.type) {\r\n case 'click': this.handleBodyClick(evt as MouseEvent); break;\r\n }\r\n break;\r\n }\r\n }\r\n\r\n registerBodyClickListener() {\r\n // this is different to native implementation\r\n // refer to https://github.com/material-components/material-components-web/issues/6188\r\n // capture so that no race between handleBodyClick and quickOpen when\r\n // menusurface opened on button click which registers this listener\r\n document.body.addEventListener('click', this);\r\n }\r\n\r\n deregisterBodyClickListener() {\r\n document.body.removeEventListener('click', this);\r\n }\r\n\r\n initialSyncWithDOM() {\r\n this.fixedChanged();\r\n this.fullWidthChanged();\r\n this.quickOpenChanged();\r\n this.anchorCornerChanged();\r\n this.anchorMarginChanged();\r\n\r\n const parentEl = this.root.parentElement;\r\n if (!this.anchor) {\r\n this.anchor = parentEl?.classList.contains(cssClasses.ANCHOR) ? parentEl : null;\r\n }\r\n if (this.hoistToBody) {\r\n this.originalParent = this.root.parentElement;\r\n if (this.originalParent) {\r\n document.body.appendChild(this.originalParent.removeChild(this.root));\r\n this.foundation?.setIsHoisted(true);\r\n }\r\n }\r\n this.foundation?.setFixedPosition(this.fixed);\r\n if (this.anchorCorner) {\r\n this.foundation?.setAnchorCorner(Corner[this.anchorCorner]);\r\n }\r\n if (this.anchorMargin) {\r\n this.foundation?.setAnchorMargin(this.anchorMargin);\r\n }\r\n if (this.maxHeight) {\r\n this.foundation?.setMaxHeight(this.maxHeight);\r\n }\r\n if (this.horizontallyCenteredOnViewport !== undefined) {\r\n this.foundation?.setIsHorizontallyCenteredOnViewport(this.horizontallyCenteredOnViewport);\r\n }\r\n this.listen('keydown', this);\r\n }\r\n\r\n destroy() {\r\n this.unlisten('keydown', this);\r\n if (this.originalParent) {\r\n this.originalParent.appendChild(document.body.removeChild(this.root));\r\n }\r\n super.destroy();\r\n }\r\n\r\n close(skipRestoreFocus = false) {\r\n this.foundation?.close(skipRestoreFocus);\r\n }\r\n\r\n /** Sets the absolute x/y position to position based on. Requires the menu to be hoisted. */\r\n setAbsolutePosition(x: number, y: number) {\r\n this.foundation?.setAbsolutePosition(x, y);\r\n this.hoistToBody = true;\r\n }\r\n\r\n /**\r\n * @param corner Default anchor corner alignment of top-left surface corner.\r\n */\r\n setAnchorCorner(corner: Corner) {\r\n this.foundation?.setAnchorCorner(corner);\r\n }\r\n\r\n getDefaultFoundation() {\r\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\r\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\r\n const adapter: MDCMenuSurfaceAdapter = {\r\n addClass: (className) => this.root.classList.add(className),\r\n removeClass: (className) => this.root.classList.remove(className),\r\n hasClass: (className) => this.root.classList.contains(className),\r\n hasAnchor: () => !!this.anchor,\r\n notifyClose: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.CLOSED_EVENT, {});\r\n this.deregisterBodyClickListener();\r\n },\r\n notifyClosing: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.CLOSING_EVENT, {});\r\n },\r\n notifyOpen: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.OPENED_EVENT, {});\r\n this.registerBodyClickListener();\r\n },\r\n notifyOpening: () => {\r\n this.emit(MDCMenuSurfaceFoundation.strings.OPENING_EVENT, {});\r\n },\r\n isElementInContainer: (el) => this.root.contains(el),\r\n isRtl: () => getComputedStyle(this.root).getPropertyValue('direction') === 'rtl',\r\n setTransformOrigin: (origin) => {\r\n const propertyName =\r\n `${getCorrectPropertyName(window, 'transform')}-origin`;\r\n this.root.style.setProperty(propertyName, origin);\r\n },\r\n isFocused: () => document.activeElement === this.root,\r\n saveFocus: () => {\r\n this.previousFocus = document.activeElement as HTMLElement | SVGElement | null;\r\n },\r\n restoreFocus: () => {\r\n if (this.root.contains(document.activeElement)) {\r\n if (this.previousFocus?.focus) {\r\n this.previousFocus.focus();\r\n }\r\n }\r\n },\r\n getInnerDimensions: () => {\r\n const firstChild = this.root.firstElementChild as HTMLElement;\r\n // workaround https://github.com/material-components/material-components-web/issues/6709\r\n // by explicitly displaying vertical scroll if a list does not fit\r\n this.root.style.overflowY = this.root.offsetHeight < firstChild.offsetHeight ? 'scroll' : '';\r\n return {\r\n width: this.root.offsetWidth,\r\n height: this.root.offsetHeight\r\n };\r\n },\r\n getAnchorDimensions: () => this.anchor ? this.anchor.getBoundingClientRect() : null,\r\n getWindowDimensions: () => {\r\n return { width: window.innerWidth, height: window.innerHeight };\r\n },\r\n getBodyDimensions: () => {\r\n return { width: document.body.clientWidth, height: document.body.clientHeight };\r\n },\r\n getWindowScroll: () => {\r\n return { x: window.pageXOffset, y: window.pageYOffset };\r\n },\r\n setPosition: (position) => {\r\n const rootHTML = this.root;\r\n rootHTML.style.left = 'left' in position ? `${position.left}px` : '';\r\n rootHTML.style.right = 'right' in position ? `${position.right}px` : '';\r\n rootHTML.style.top = 'top' in position ? `${position.top}px` : '';\r\n rootHTML.style.bottom = 'bottom' in position ? `${position.bottom}px` : '';\r\n },\r\n setMaxHeight: (height) => {\r\n (this.root).style.maxHeight = height;\r\n },\r\n };\r\n return new MDCMenuSurfaceFoundation(adapter);\r\n }\r\n\r\n}\r\n"]}
@@ -1,18 +1,15 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MdcNotchedOutline = void 0;
4
- const tslib_1 = require("tslib");
5
- const base_1 = require("../base");
6
- const notched_outline_1 = require("@material/notched-outline");
7
- const floating_label_1 = require("@material/floating-label");
8
- const aurelia_1 = require("aurelia");
9
- const mdc_notched_outline_html_raw_1 = tslib_1.__importDefault(require("./mdc-notched-outline.html?raw"));
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { MdcComponent } from '../base';
3
+ import { MDCNotchedOutlineFoundation, cssClasses } from '@material/notched-outline';
4
+ import { MDCFloatingLabelFoundation } from '@material/floating-label';
5
+ import { inject, customElement, slotted } from 'aurelia';
6
+ import template from './mdc-notched-outline.html?raw';
10
7
  let MdcNotchedOutline = (() => {
11
- let _classDecorators = [(0, aurelia_1.inject)(Element), (0, aurelia_1.customElement)({ name: 'mdc-notched-outline', template: mdc_notched_outline_html_raw_1.default })];
8
+ let _classDecorators = [inject(Element), customElement({ name: 'mdc-notched-outline', template })];
12
9
  let _classDescriptor;
13
10
  let _classExtraInitializers = [];
14
11
  let _classThis;
15
- let _classSuper = base_1.MdcComponent;
12
+ let _classSuper = MdcComponent;
16
13
  let _labels_decorators;
17
14
  let _labels_initializers = [];
18
15
  let _labels_extraInitializers = [];
@@ -20,21 +17,21 @@ let MdcNotchedOutline = (() => {
20
17
  static { _classThis = this; }
21
18
  static {
22
19
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
23
- _labels_decorators = [(0, aurelia_1.slotted)({ query: `.${floating_label_1.MDCFloatingLabelFoundation.cssClasses.ROOT}` })];
24
- tslib_1.__esDecorate(null, null, _labels_decorators, { kind: "field", name: "labels", static: false, private: false, access: { has: obj => "labels" in obj, get: obj => obj.labels, set: (obj, value) => { obj.labels = value; } }, metadata: _metadata }, _labels_initializers, _labels_extraInitializers);
25
- tslib_1.__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
20
+ _labels_decorators = [slotted({ query: `.${MDCFloatingLabelFoundation.cssClasses.ROOT}` })];
21
+ __esDecorate(null, null, _labels_decorators, { kind: "field", name: "labels", static: false, private: false, access: { has: obj => "labels" in obj, get: obj => obj.labels, set: (obj, value) => { obj.labels = value; } }, metadata: _metadata }, _labels_initializers, _labels_extraInitializers);
22
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
26
23
  MdcNotchedOutline = _classThis = _classDescriptor.value;
27
24
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
28
- tslib_1.__runInitializers(_classThis, _classExtraInitializers);
25
+ __runInitializers(_classThis, _classExtraInitializers);
29
26
  }
30
27
  notchElement_; // assigned in html
31
28
  label;
32
- labels = tslib_1.__runInitializers(this, _labels_initializers, void 0);
29
+ labels = __runInitializers(this, _labels_initializers, void 0);
33
30
  labelsChanged() {
34
31
  if (this.labels.length) {
35
32
  this.label = this.labels[0];
36
33
  this.label.style.transitionDuration = '0s';
37
- this.root.classList.add(notched_outline_1.cssClasses.OUTLINE_UPGRADED);
34
+ this.root.classList.add(cssClasses.OUTLINE_UPGRADED);
38
35
  requestAnimationFrame(() => {
39
36
  this.label.style.transitionDuration = '';
40
37
  });
@@ -68,14 +65,14 @@ let MdcNotchedOutline = (() => {
68
65
  setNotchWidthProperty: (width) => this.notchElement_.style.setProperty('width', `${width}px`),
69
66
  removeNotchWidthProperty: () => this.notchElement_.style.removeProperty('width'),
70
67
  };
71
- return new notched_outline_1.MDCNotchedOutlineFoundation(adapter);
68
+ return new MDCNotchedOutlineFoundation(adapter);
72
69
  }
73
70
  constructor() {
74
71
  super(...arguments);
75
- tslib_1.__runInitializers(this, _labels_extraInitializers);
72
+ __runInitializers(this, _labels_extraInitializers);
76
73
  }
77
74
  };
78
75
  return MdcNotchedOutline = _classThis;
79
76
  })();
80
- exports.MdcNotchedOutline = MdcNotchedOutline;
77
+ export { MdcNotchedOutline };
81
78
  //# sourceMappingURL=mdc-notched-outline.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"mdc-notched-outline.js","sourceRoot":"","sources":["../../src/notched-outline/mdc-notched-outline.ts"],"names":[],"mappings":";;;;AAAA,kCAAuC;AACvC,+DAA8G;AAC9G,6DAAsE;AACtE,qCAAyD;AACzD,0GAAsD;IAIzC,iBAAiB;4BAF7B,IAAA,gBAAM,EAAC,OAAO,CAAC,EACf,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,qBAAqB,EAAE,QAAQ,EAAR,sCAAQ,EAAE,CAAC;;;;sBAClB,mBAAY;;;;iCAApB,SAAQ,WAAyC;;;;kCAK7E,IAAA,iBAAO,EAAC,EAAE,KAAK,EAAE,IAAI,2CAA0B,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC;YACrE,4KAAA,MAAM,6BAAN,MAAM,uFAAgB;YANxB,qLAmDC;;;YAnDY,+DAAiB;;QACpB,aAAa,CAAe,CAAC,mBAAmB;QAExD,KAAK,CAAe;QAGpB,MAAM,iEAAgB;QACtB,aAAa;YACX,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;gBACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,kBAAkB,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,4BAAU,CAAC,gBAAgB,CAAC,CAAC;gBACrD,qBAAqB,CAAC,GAAG,EAAE;oBACzB,IAAI,CAAC,KAAM,CAAC,KAAK,CAAC,kBAAkB,GAAG,EAAE,CAAC;gBAC5C,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;YACzB,CAAC;QACH,CAAC;QAED,kBAAkB;YAChB,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;QAED;;;WAGG;QACH,KAAK,CAAC,UAAkB;YACtB,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAED;;WAEG;QACH,UAAU;YACR,IAAI,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC;QAChC,CAAC;QAED,oBAAoB;YAClB,sGAAsG;YACtG,yGAAyG;YACzG,MAAM,OAAO,GAA6B;gBACxC,QAAQ,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC;gBAC3D,WAAW,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;gBACjE,qBAAqB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;gBAC7F,wBAAwB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC;aACjF,CAAC;YACF,OAAO,IAAI,6CAA2B,CAAC,OAAO,CAAC,CAAC;QAClD,CAAC;;;;;;;;AAjDU,8CAAiB","sourcesContent":["import { MdcComponent } from '../base';\r\nimport { MDCNotchedOutlineFoundation, MDCNotchedOutlineAdapter, cssClasses } from '@material/notched-outline';\r\nimport { MDCFloatingLabelFoundation } from '@material/floating-label';\r\nimport { inject, customElement, slotted } from 'aurelia';\r\nimport template from './mdc-notched-outline.html?raw';\r\n\r\n@inject(Element)\r\n@customElement({ name: 'mdc-notched-outline', template })\r\nexport class MdcNotchedOutline extends MdcComponent<MDCNotchedOutlineFoundation> {\r\n private notchElement_!: HTMLElement; // assigned in html\r\n\r\n label?: HTMLElement;\r\n\r\n @slotted({ query: `.${MDCFloatingLabelFoundation.cssClasses.ROOT}` })\r\n labels: HTMLElement[];\r\n labelsChanged() {\r\n if (this.labels.length) {\r\n this.label = this.labels[0];\r\n this.label.style.transitionDuration = '0s';\r\n this.root.classList.add(cssClasses.OUTLINE_UPGRADED);\r\n requestAnimationFrame(() => {\r\n this.label!.style.transitionDuration = '';\r\n });\r\n } else {\r\n this.label = undefined;\r\n }\r\n }\r\n\r\n initialSyncWithDOM() {\r\n this.labelsChanged();\r\n }\r\n\r\n /**\r\n * Updates classes and styles to open the notch to the specified width.\r\n * @param notchWidth The notch width in the outline.\r\n */\r\n notch(notchWidth: number) {\r\n this.foundation?.notch(notchWidth);\r\n }\r\n\r\n /**\r\n * Updates classes and styles to close the notch.\r\n */\r\n closeNotch() {\r\n this.foundation?.closeNotch();\r\n }\r\n\r\n getDefaultFoundation() {\r\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\r\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\r\n const adapter: MDCNotchedOutlineAdapter = {\r\n addClass: (className) => this.root.classList.add(className),\r\n removeClass: (className) => this.root.classList.remove(className),\r\n setNotchWidthProperty: (width) => this.notchElement_.style.setProperty('width', `${width}px`),\r\n removeNotchWidthProperty: () => this.notchElement_.style.removeProperty('width'),\r\n };\r\n return new MDCNotchedOutlineFoundation(adapter);\r\n }\r\n\r\n}\r\n"]}
1
+ {"version":3,"file":"mdc-notched-outline.js","sourceRoot":"","sources":["../../src/notched-outline/mdc-notched-outline.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,2BAA2B,EAA4B,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAC9G,OAAO,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACzD,OAAO,QAAQ,MAAM,gCAAgC,CAAC;IAIzC,iBAAiB;4BAF7B,MAAM,CAAC,OAAO,CAAC,EACf,aAAa,CAAC,EAAE,IAAI,EAAE,qBAAqB,EAAE,QAAQ,EAAE,CAAC;;;;sBAClB,YAAY;;;;iCAApB,SAAQ,WAAyC;;;;kCAK7E,OAAO,CAAC,EAAE,KAAK,EAAE,IAAI,0BAA0B,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC;YACrE,oKAAA,MAAM,6BAAN,MAAM,uFAAgB;YANxB,6KAmDC;;;YAnDY,uDAAiB;;QACpB,aAAa,CAAe,CAAC,mBAAmB;QAExD,KAAK,CAAe;QAGpB,MAAM,yDAAgB;QACtB,aAAa;YACX,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;gBACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,kBAAkB,GAAG,IAAI,CAAC;gBAC3C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;gBACrD,qBAAqB,CAAC,GAAG,EAAE;oBACzB,IAAI,CAAC,KAAM,CAAC,KAAK,CAAC,kBAAkB,GAAG,EAAE,CAAC;gBAC5C,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;YACzB,CAAC;QACH,CAAC;QAED,kBAAkB;YAChB,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;QAED;;;WAGG;QACH,KAAK,CAAC,UAAkB;YACtB,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAED;;WAEG;QACH,UAAU;YACR,IAAI,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC;QAChC,CAAC;QAED,oBAAoB;YAClB,sGAAsG;YACtG,yGAAyG;YACzG,MAAM,OAAO,GAA6B;gBACxC,QAAQ,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC;gBAC3D,WAAW,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;gBACjE,qBAAqB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;gBAC7F,wBAAwB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC;aACjF,CAAC;YACF,OAAO,IAAI,2BAA2B,CAAC,OAAO,CAAC,CAAC;QAClD,CAAC;;;;;;;;SAjDU,iBAAiB","sourcesContent":["import { MdcComponent } from '../base';\r\nimport { MDCNotchedOutlineFoundation, MDCNotchedOutlineAdapter, cssClasses } from '@material/notched-outline';\r\nimport { MDCFloatingLabelFoundation } from '@material/floating-label';\r\nimport { inject, customElement, slotted } from 'aurelia';\r\nimport template from './mdc-notched-outline.html?raw';\r\n\r\n@inject(Element)\r\n@customElement({ name: 'mdc-notched-outline', template })\r\nexport class MdcNotchedOutline extends MdcComponent<MDCNotchedOutlineFoundation> {\r\n private notchElement_!: HTMLElement; // assigned in html\r\n\r\n label?: HTMLElement;\r\n\r\n @slotted({ query: `.${MDCFloatingLabelFoundation.cssClasses.ROOT}` })\r\n labels: HTMLElement[];\r\n labelsChanged() {\r\n if (this.labels.length) {\r\n this.label = this.labels[0];\r\n this.label.style.transitionDuration = '0s';\r\n this.root.classList.add(cssClasses.OUTLINE_UPGRADED);\r\n requestAnimationFrame(() => {\r\n this.label!.style.transitionDuration = '';\r\n });\r\n } else {\r\n this.label = undefined;\r\n }\r\n }\r\n\r\n initialSyncWithDOM() {\r\n this.labelsChanged();\r\n }\r\n\r\n /**\r\n * Updates classes and styles to open the notch to the specified width.\r\n * @param notchWidth The notch width in the outline.\r\n */\r\n notch(notchWidth: number) {\r\n this.foundation?.notch(notchWidth);\r\n }\r\n\r\n /**\r\n * Updates classes and styles to close the notch.\r\n */\r\n closeNotch() {\r\n this.foundation?.closeNotch();\r\n }\r\n\r\n getDefaultFoundation() {\r\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\r\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\r\n const adapter: MDCNotchedOutlineAdapter = {\r\n addClass: (className) => this.root.classList.add(className),\r\n removeClass: (className) => this.root.classList.remove(className),\r\n setNotchWidthProperty: (width) => this.notchElement_.style.setProperty('width', `${width}px`),\r\n removeNotchWidthProperty: () => this.notchElement_.style.removeProperty('width'),\r\n };\r\n return new MDCNotchedOutlineFoundation(adapter);\r\n }\r\n\r\n}\r\n"]}
@@ -1,21 +1,18 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MdcRadio = void 0;
4
- const tslib_1 = require("tslib");
5
- const base_1 = require("../base");
6
- const radio_1 = require("@material/radio");
7
- const aurelia_1 = require("aurelia");
8
- const mdc_radio_html_raw_1 = tslib_1.__importDefault(require("./mdc-radio.html?raw"));
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { MdcComponent, booleanAttr } from '../base';
3
+ import { MDCRadioFoundation } from '@material/radio';
4
+ import { inject, customElement, CustomElement, bindable } from 'aurelia';
5
+ import template from './mdc-radio.html?raw';
9
6
  let radioId = 0;
10
7
  /**
11
8
  * @selector mdc-radio
12
9
  */
13
10
  let MdcRadio = (() => {
14
- let _classDecorators = [(0, aurelia_1.inject)(Element), (0, aurelia_1.customElement)({ name: 'mdc-radio', template: mdc_radio_html_raw_1.default })];
11
+ let _classDecorators = [inject(Element), customElement({ name: 'mdc-radio', template })];
15
12
  let _classDescriptor;
16
13
  let _classExtraInitializers = [];
17
14
  let _classThis;
18
- let _classSuper = base_1.MdcComponent;
15
+ let _classSuper = MdcComponent;
19
16
  let _disabled_decorators;
20
17
  let _disabled_initializers = [];
21
18
  let _disabled_extraInitializers = [];
@@ -26,14 +23,14 @@ let MdcRadio = (() => {
26
23
  static { _classThis = this; }
27
24
  static {
28
25
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
29
- _disabled_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
30
- _touch_decorators = [(0, aurelia_1.bindable)({ set: base_1.booleanAttr })];
31
- tslib_1.__esDecorate(null, null, _disabled_decorators, { kind: "field", name: "disabled", static: false, private: false, access: { has: obj => "disabled" in obj, get: obj => obj.disabled, set: (obj, value) => { obj.disabled = value; } }, metadata: _metadata }, _disabled_initializers, _disabled_extraInitializers);
32
- tslib_1.__esDecorate(null, null, _touch_decorators, { kind: "field", name: "touch", static: false, private: false, access: { has: obj => "touch" in obj, get: obj => obj.touch, set: (obj, value) => { obj.touch = value; } }, metadata: _metadata }, _touch_initializers, _touch_extraInitializers);
33
- tslib_1.__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
26
+ _disabled_decorators = [bindable({ set: booleanAttr })];
27
+ _touch_decorators = [bindable({ set: booleanAttr })];
28
+ __esDecorate(null, null, _disabled_decorators, { kind: "field", name: "disabled", static: false, private: false, access: { has: obj => "disabled" in obj, get: obj => obj.disabled, set: (obj, value) => { obj.disabled = value; } }, metadata: _metadata }, _disabled_initializers, _disabled_extraInitializers);
29
+ __esDecorate(null, null, _touch_decorators, { kind: "field", name: "touch", static: false, private: false, access: { has: obj => "touch" in obj, get: obj => obj.touch, set: (obj, value) => { obj.touch = value; } }, metadata: _metadata }, _touch_initializers, _touch_extraInitializers);
30
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
34
31
  MdcRadio = _classThis = _classDescriptor.value;
35
32
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
36
- tslib_1.__runInitializers(_classThis, _classExtraInitializers);
33
+ __runInitializers(_classThis, _classExtraInitializers);
37
34
  }
38
35
  constructor(root) {
39
36
  super(root);
@@ -42,15 +39,15 @@ let MdcRadio = (() => {
42
39
  nativeControl_;
43
40
  id = `mdc-radio-${++radioId}-input`;
44
41
  /** Disables the component */
45
- disabled = tslib_1.__runInitializers(this, _disabled_initializers, void 0);
42
+ disabled = __runInitializers(this, _disabled_initializers, void 0);
46
43
  disabledChanged() {
47
44
  if (this.nativeControl_) {
48
45
  this.nativeControl_.disabled = this.disabled;
49
46
  }
50
47
  }
51
48
  /** Set the component touch target to 48 x 48 px */
52
- touch = (tslib_1.__runInitializers(this, _disabled_extraInitializers), tslib_1.__runInitializers(this, _touch_initializers, void 0));
53
- _checked = tslib_1.__runInitializers(this, _touch_extraInitializers);
49
+ touch = (__runInitializers(this, _disabled_extraInitializers), __runInitializers(this, _touch_initializers, void 0));
50
+ _checked = __runInitializers(this, _touch_extraInitializers);
54
51
  /** Use to verify the checked value */
55
52
  get checked() {
56
53
  if (this.nativeControl_) {
@@ -111,7 +108,7 @@ let MdcRadio = (() => {
111
108
  setNativeControlDisabled: (disabled) => this.nativeControl_.disabled =
112
109
  disabled,
113
110
  };
114
- return new radio_1.MDCRadioFoundation(adapter);
111
+ return new MDCRadioFoundation(adapter);
115
112
  }
116
113
  /** Set focus to the radio button */
117
114
  focus() {
@@ -124,7 +121,7 @@ let MdcRadio = (() => {
124
121
  };
125
122
  return MdcRadio = _classThis;
126
123
  })();
127
- exports.MdcRadio = MdcRadio;
124
+ export { MdcRadio };
128
125
  function defineMdcRadioElementApis(element) {
129
126
  Object.defineProperties(element, {
130
127
  type: {
@@ -132,30 +129,30 @@ function defineMdcRadioElementApis(element) {
132
129
  },
133
130
  checked: {
134
131
  get() {
135
- return aurelia_1.CustomElement.for(this).viewModel.checked;
132
+ return CustomElement.for(this).viewModel.checked;
136
133
  },
137
134
  set(value) {
138
- aurelia_1.CustomElement.for(this).viewModel.checked = value;
135
+ CustomElement.for(this).viewModel.checked = value;
139
136
  },
140
137
  configurable: true
141
138
  },
142
139
  value: {
143
140
  get() {
144
- return aurelia_1.CustomElement.for(this).viewModel.value;
141
+ return CustomElement.for(this).viewModel.value;
145
142
  },
146
143
  set(value) {
147
- aurelia_1.CustomElement.for(this).viewModel.value = value;
144
+ CustomElement.for(this).viewModel.value = value;
148
145
  }
149
146
  },
150
147
  focus: {
151
148
  value() {
152
- aurelia_1.CustomElement.for(this).viewModel.focus();
149
+ CustomElement.for(this).viewModel.focus();
153
150
  },
154
151
  configurable: true
155
152
  },
156
153
  blur: {
157
154
  value() {
158
- aurelia_1.CustomElement.for(this).viewModel.blur();
155
+ CustomElement.for(this).viewModel.blur();
159
156
  },
160
157
  configurable: true
161
158
  }
@@ -1 +1 @@
1
- {"version":3,"file":"mdc-radio.js","sourceRoot":"","sources":["../../src/radio/mdc-radio.ts"],"names":[],"mappings":";;;;AAAA,kCAAoD;AACpD,2CAAsE;AACtE,qCAAyE;AACzE,sFAA4C;AAE5C,IAAI,OAAO,GAAG,CAAC,CAAC;AAEhB;;GAEG;IAGU,QAAQ;4BAFpB,IAAA,gBAAM,EAAC,OAAO,CAAC,EACf,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAR,4BAAQ,EAAE,CAAC;;;;sBACjB,mBAAY;;;;;;;wBAApB,SAAQ,WAAgC;;;;oCAW3D,IAAA,kBAAQ,EAAC,EAAE,GAAG,EAAE,kBAAW,EAAE,CAAC;iCAS9B,IAAA,kBAAQ,EAAC,EAAE,GAAG,EAAE,kBAAW,EAAE,CAAC;YAR/B,kLAAA,QAAQ,6BAAR,QAAQ,2FAAU;YASlB,yKAAA,KAAK,6BAAL,KAAK,qFAAU;YArBjB,qLAsGC;;;YAtGY,+DAAQ;;QACnB,YAAY,IAAsB;YAChC,KAAK,CAAC,IAAI,CAAC,CAAC;YACZ,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;QAED,cAAc,CAAmB;QAEjC,EAAE,GAAG,aAAa,EAAE,OAAO,QAAQ,CAAC;QAEpC,6BAA6B;QAE7B,QAAQ,mEAAU;QAClB,eAAe;YACb,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC/C,CAAC;QACH,CAAC;QAED,mDAAmD;QAEnD,KAAK,gIAAU;QAEf,QAAQ,6DAAW;QACnB,sCAAsC;QACtC,IAAI,OAAO;YACT,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YACrC,CAAC;iBAAM,CAAC;gBACN,OAAO,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC;YAChC,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,OAAgB;YAC1B,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;YACxB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,IAAI,CAAC,cAAc,CAAC,OAAO,GAAG,OAAO,CAAC;YACxC,CAAC;QACH,CAAC;QAED,MAAM,CAAU;QAChB,gCAAgC;QAChC,IAAI,KAAK;YACP,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;YACnC,CAAC;iBAAM,CAAC;gBACN,OAAO,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC;QAED,IAAI,KAAK,CAAC,KAAa;YACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,IAAI,CAAC,cAAc,CAAC,KAAK,GAAG,KAAK,CAAC;YACpC,CAAC;QACH,CAAC;QAED,SAAS;YACP,IAAI,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC;gBACtC,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;gBAEzD,IAAI,cAAc,IAAI,cAAc,KAAK,EAAE,EAAE,CAAC;oBAC3C,IAAI,CAAC,IAAyB,CAAC,OAAO,GAAG,IAAI,CAAC;gBACjD,CAAC;YACH,CAAC;QACH,CAAC;QAED,kBAAkB;YAChB,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC/B,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;YAC3B,CAAC;QACH,CAAC;QAED,OAAO;YACL,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC5B,CAAC;QAED,oBAAoB;YAClB,sGAAsG;YACtG,yGAAyG;YACzG,MAAM,OAAO,GAAoB;gBAC/B,QAAQ,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC;gBAC3D,WAAW,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;gBACjE,wBAAwB,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ;oBAClE,QAAQ;aACX,CAAC;YACF,OAAO,IAAI,0BAAkB,CAAC,OAAO,CAAC,CAAC;QACzC,CAAC;QAED,oCAAoC;QACpC,KAAK;YACH,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC9B,CAAC;QAED,2CAA2C;QAC3C,IAAI;YACF,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAC7B,CAAC;;;;AArGU,4BAAQ;AAkHrB,SAAS,yBAAyB,CAAC,OAAoB;IACrD,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE;QAC/B,IAAI,EAAE;YACJ,KAAK,EAAE,OAAO;SACf;QACD,OAAO,EAAE;YACP,GAAG;gBACD,OAAO,uBAAa,CAAC,GAAG,CAAW,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC;YAC7D,CAAC;YACD,GAAG,CAAyB,KAAc;gBACxC,uBAAa,CAAC,GAAG,CAAW,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,GAAG,KAAK,CAAC;YAC9D,CAAC;YACD,YAAY,EAAE,IAAI;SACnB;QACD,KAAK,EAAE;YACL,GAAG;gBACD,OAAO,uBAAa,CAAC,GAAG,CAAW,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC;YAC3D,CAAC;YACD,GAAG,CAAyB,KAAa;gBACvC,uBAAa,CAAC,GAAG,CAAW,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,GAAG,KAAK,CAAC;YAC5D,CAAC;SACF;QACD,KAAK,EAAE;YACL,KAAK;gBACH,uBAAa,CAAC,GAAG,CAAW,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACtD,CAAC;YACD,YAAY,EAAE,IAAI;SACnB;QACD,IAAI,EAAE;YACJ,KAAK;gBACH,uBAAa,CAAC,GAAG,CAAW,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YACrD,CAAC;YACD,YAAY,EAAE,IAAI;SACnB;KACF,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { MdcComponent, booleanAttr } from '../base';\r\nimport { MDCRadioFoundation, MDCRadioAdapter } from '@material/radio';\r\nimport { inject, customElement, CustomElement, bindable } from 'aurelia';\r\nimport template from './mdc-radio.html?raw';\r\n\r\nlet radioId = 0;\r\n\r\n/**\r\n * @selector mdc-radio\r\n */\r\n@inject(Element)\r\n@customElement({ name: 'mdc-radio', template })\r\nexport class MdcRadio extends MdcComponent<MDCRadioFoundation> {\r\n constructor(root: IMdcRadioElement) {\r\n super(root);\r\n defineMdcRadioElementApis(this.root);\r\n }\r\n\r\n nativeControl_: HTMLInputElement;\r\n\r\n id = `mdc-radio-${++radioId}-input`;\r\n\r\n /** Disables the component */\r\n @bindable({ set: booleanAttr })\r\n disabled: boolean;\r\n disabledChanged() {\r\n if (this.nativeControl_) {\r\n this.nativeControl_.disabled = this.disabled;\r\n }\r\n }\r\n\r\n /** Set the component touch target to 48 x 48 px */\r\n @bindable({ set: booleanAttr })\r\n touch: boolean;\r\n\r\n _checked?: boolean;\r\n /** Use to verify the checked value */\r\n get checked(): boolean {\r\n if (this.nativeControl_) {\r\n return this.nativeControl_.checked;\r\n } else {\r\n return this._checked ?? false;\r\n }\r\n }\r\n\r\n set checked(checked: boolean) {\r\n this._checked = checked;\r\n if (this.nativeControl_) {\r\n this.nativeControl_.checked = checked;\r\n }\r\n }\r\n\r\n _value?: string;\r\n /** Value of the radio button */\r\n get value(): string {\r\n if (this.nativeControl_) {\r\n return this.nativeControl_.value;\r\n } else {\r\n return this._value ?? '';\r\n }\r\n }\r\n\r\n set value(value: string) {\r\n this._value = value;\r\n if (this.nativeControl_) {\r\n this.nativeControl_.value = value;\r\n }\r\n }\r\n\r\n attaching() {\r\n if (this.root.hasAttribute('checked')) {\r\n const attributeValue = this.root.getAttribute('checked');\r\n\r\n if (attributeValue || attributeValue === '') {\r\n (this.root as IMdcRadioElement).checked = true;\r\n }\r\n }\r\n }\r\n\r\n initialSyncWithDOM() {\r\n this.disabledChanged();\r\n if (this._checked !== undefined) {\r\n this.checked = this._checked;\r\n }\r\n if (this._value !== undefined) {\r\n this.value = this._value;\r\n }\r\n }\r\n\r\n destroy() {\r\n this._checked = undefined;\r\n }\r\n\r\n getDefaultFoundation() {\r\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\r\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\r\n const adapter: MDCRadioAdapter = {\r\n addClass: (className) => this.root.classList.add(className),\r\n removeClass: (className) => this.root.classList.remove(className),\r\n setNativeControlDisabled: (disabled) => this.nativeControl_.disabled =\r\n disabled,\r\n };\r\n return new MDCRadioFoundation(adapter);\r\n }\r\n\r\n /** Set focus to the radio button */\r\n focus() {\r\n this.nativeControl_.focus();\r\n }\r\n\r\n /** Set focus away from the radio button */\r\n blur() {\r\n this.nativeControl_.blur();\r\n }\r\n}\r\n\r\n/** @hidden */\r\nexport interface IMdcRadioElement extends HTMLElement {\r\n checked: boolean;\r\n $au: {\r\n 'au:resource:custom-element': {\r\n viewModel: MdcRadio;\r\n };\r\n };\r\n}\r\n\r\nfunction defineMdcRadioElementApis(element: HTMLElement) {\r\n Object.defineProperties(element, {\r\n type: {\r\n value: 'radio',\r\n },\r\n checked: {\r\n get(this: IMdcRadioElement) {\r\n return CustomElement.for<MdcRadio>(this).viewModel.checked;\r\n },\r\n set(this: IMdcRadioElement, value: boolean) {\r\n CustomElement.for<MdcRadio>(this).viewModel.checked = value;\r\n },\r\n configurable: true\r\n },\r\n value: {\r\n get(this: IMdcRadioElement) {\r\n return CustomElement.for<MdcRadio>(this).viewModel.value;\r\n },\r\n set(this: IMdcRadioElement, value: string) {\r\n CustomElement.for<MdcRadio>(this).viewModel.value = value;\r\n }\r\n },\r\n focus: {\r\n value(this: IMdcRadioElement) {\r\n CustomElement.for<MdcRadio>(this).viewModel.focus();\r\n },\r\n configurable: true\r\n },\r\n blur: {\r\n value(this: IMdcRadioElement) {\r\n CustomElement.for<MdcRadio>(this).viewModel.blur();\r\n },\r\n configurable: true\r\n }\r\n });\r\n}\r\n"]}
1
+ {"version":3,"file":"mdc-radio.js","sourceRoot":"","sources":["../../src/radio/mdc-radio.ts"],"names":[],"mappings":"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","sourcesContent":["import { MdcComponent, booleanAttr } from '../base';\r\nimport { MDCRadioFoundation, MDCRadioAdapter } from '@material/radio';\r\nimport { inject, customElement, CustomElement, bindable } from 'aurelia';\r\nimport template from './mdc-radio.html?raw';\r\n\r\nlet radioId = 0;\r\n\r\n/**\r\n * @selector mdc-radio\r\n */\r\n@inject(Element)\r\n@customElement({ name: 'mdc-radio', template })\r\nexport class MdcRadio extends MdcComponent<MDCRadioFoundation> {\r\n constructor(root: IMdcRadioElement) {\r\n super(root);\r\n defineMdcRadioElementApis(this.root);\r\n }\r\n\r\n nativeControl_: HTMLInputElement;\r\n\r\n id = `mdc-radio-${++radioId}-input`;\r\n\r\n /** Disables the component */\r\n @bindable({ set: booleanAttr })\r\n disabled: boolean;\r\n disabledChanged() {\r\n if (this.nativeControl_) {\r\n this.nativeControl_.disabled = this.disabled;\r\n }\r\n }\r\n\r\n /** Set the component touch target to 48 x 48 px */\r\n @bindable({ set: booleanAttr })\r\n touch: boolean;\r\n\r\n _checked?: boolean;\r\n /** Use to verify the checked value */\r\n get checked(): boolean {\r\n if (this.nativeControl_) {\r\n return this.nativeControl_.checked;\r\n } else {\r\n return this._checked ?? false;\r\n }\r\n }\r\n\r\n set checked(checked: boolean) {\r\n this._checked = checked;\r\n if (this.nativeControl_) {\r\n this.nativeControl_.checked = checked;\r\n }\r\n }\r\n\r\n _value?: string;\r\n /** Value of the radio button */\r\n get value(): string {\r\n if (this.nativeControl_) {\r\n return this.nativeControl_.value;\r\n } else {\r\n return this._value ?? '';\r\n }\r\n }\r\n\r\n set value(value: string) {\r\n this._value = value;\r\n if (this.nativeControl_) {\r\n this.nativeControl_.value = value;\r\n }\r\n }\r\n\r\n attaching() {\r\n if (this.root.hasAttribute('checked')) {\r\n const attributeValue = this.root.getAttribute('checked');\r\n\r\n if (attributeValue || attributeValue === '') {\r\n (this.root as IMdcRadioElement).checked = true;\r\n }\r\n }\r\n }\r\n\r\n initialSyncWithDOM() {\r\n this.disabledChanged();\r\n if (this._checked !== undefined) {\r\n this.checked = this._checked;\r\n }\r\n if (this._value !== undefined) {\r\n this.value = this._value;\r\n }\r\n }\r\n\r\n destroy() {\r\n this._checked = undefined;\r\n }\r\n\r\n getDefaultFoundation() {\r\n // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\r\n // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\r\n const adapter: MDCRadioAdapter = {\r\n addClass: (className) => this.root.classList.add(className),\r\n removeClass: (className) => this.root.classList.remove(className),\r\n setNativeControlDisabled: (disabled) => this.nativeControl_.disabled =\r\n disabled,\r\n };\r\n return new MDCRadioFoundation(adapter);\r\n }\r\n\r\n /** Set focus to the radio button */\r\n focus() {\r\n this.nativeControl_.focus();\r\n }\r\n\r\n /** Set focus away from the radio button */\r\n blur() {\r\n this.nativeControl_.blur();\r\n }\r\n}\r\n\r\n/** @hidden */\r\nexport interface IMdcRadioElement extends HTMLElement {\r\n checked: boolean;\r\n $au: {\r\n 'au:resource:custom-element': {\r\n viewModel: MdcRadio;\r\n };\r\n };\r\n}\r\n\r\nfunction defineMdcRadioElementApis(element: HTMLElement) {\r\n Object.defineProperties(element, {\r\n type: {\r\n value: 'radio',\r\n },\r\n checked: {\r\n get(this: IMdcRadioElement) {\r\n return CustomElement.for<MdcRadio>(this).viewModel.checked;\r\n },\r\n set(this: IMdcRadioElement, value: boolean) {\r\n CustomElement.for<MdcRadio>(this).viewModel.checked = value;\r\n },\r\n configurable: true\r\n },\r\n value: {\r\n get(this: IMdcRadioElement) {\r\n return CustomElement.for<MdcRadio>(this).viewModel.value;\r\n },\r\n set(this: IMdcRadioElement, value: string) {\r\n CustomElement.for<MdcRadio>(this).viewModel.value = value;\r\n }\r\n },\r\n focus: {\r\n value(this: IMdcRadioElement) {\r\n CustomElement.for<MdcRadio>(this).viewModel.focus();\r\n },\r\n configurable: true\r\n },\r\n blur: {\r\n value(this: IMdcRadioElement) {\r\n CustomElement.for<MdcRadio>(this).viewModel.blur();\r\n },\r\n configurable: true\r\n }\r\n });\r\n}\r\n"]}