@material/web 1.0.0-pre.1 → 1.0.0-pre.2

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 (417) hide show
  1. package/README.md +66 -19
  2. package/autocomplete/lib/_filled-autocomplete.scss +1 -34
  3. package/autocomplete/lib/_outlined-autocomplete.scss +1 -34
  4. package/autocomplete/lib/autocomplete.d.ts +0 -4
  5. package/autocomplete/lib/autocomplete.js +5 -12
  6. package/autocomplete/lib/autocomplete.js.map +1 -1
  7. package/autocomplete/lib/autocompleteitem/autocomplete-item.d.ts +2 -2
  8. package/autocomplete/lib/autocompleteitem/autocomplete-item.js +2 -2
  9. package/autocomplete/lib/autocompleteitem/autocomplete-item.js.map +1 -1
  10. package/autocomplete/lib/autocompletelist/autocomplete-list.d.ts +1 -1
  11. package/autocomplete/lib/autocompletelist/autocomplete-list.js +2 -2
  12. package/autocomplete/lib/autocompletelist/autocomplete-list.js.map +1 -1
  13. package/autocomplete/lib/filled-styles.css.js +1 -1
  14. package/autocomplete/lib/filled-styles.css.js.map +1 -1
  15. package/autocomplete/lib/outlined-styles.css.js +1 -1
  16. package/autocomplete/lib/outlined-styles.css.js.map +1 -1
  17. package/button/lib/_elevation.scss +1 -1
  18. package/button/lib/_icon.scss +14 -24
  19. package/button/lib/_shared.scss +1 -0
  20. package/button/lib/button.d.ts +0 -3
  21. package/button/lib/button.js +1 -12
  22. package/button/lib/button.js.map +1 -1
  23. package/button/lib/filled-styles.css.js +1 -1
  24. package/button/lib/filled-styles.css.js.map +1 -1
  25. package/button/lib/link-button.d.ts +0 -1
  26. package/button/lib/link-button.js +0 -5
  27. package/button/lib/link-button.js.map +1 -1
  28. package/button/lib/shared-elevation-styles.css.js +1 -1
  29. package/button/lib/shared-elevation-styles.css.js.map +1 -1
  30. package/button/lib/shared-styles.css.js +1 -1
  31. package/button/lib/shared-styles.css.js.map +1 -1
  32. package/checkbox/checkbox.d.ts +11 -2
  33. package/checkbox/checkbox.js +11 -2
  34. package/checkbox/checkbox.js.map +1 -1
  35. package/checkbox/lib/checkbox.d.ts +28 -0
  36. package/checkbox/lib/checkbox.js +30 -1
  37. package/checkbox/lib/checkbox.js.map +1 -1
  38. package/chips/chip/lib/_chip-theme.scss +1 -1
  39. package/dialog/_dialog.scss +6 -0
  40. package/dialog/dialog.d.ts +38 -0
  41. package/dialog/dialog.js +41 -0
  42. package/dialog/dialog.js.map +1 -0
  43. package/dialog/harness.d.ts +18 -0
  44. package/dialog/harness.js +55 -0
  45. package/dialog/harness.js.map +1 -0
  46. package/dialog/lib/_dialog.scss +386 -0
  47. package/dialog/lib/_tokens.scss +86 -0
  48. package/{list/lib/divider/list-divider-styles.css.d.ts → dialog/lib/dialog-styles.css.d.ts} +0 -0
  49. package/dialog/lib/dialog-styles.css.js +9 -0
  50. package/dialog/lib/dialog-styles.css.js.map +1 -0
  51. package/dialog/lib/dialog-styles.scss +8 -0
  52. package/dialog/lib/dialog.d.ts +190 -0
  53. package/dialog/lib/dialog.js +566 -0
  54. package/dialog/lib/dialog.js.map +1 -0
  55. package/divider/_divider.scss +6 -0
  56. package/divider/divider.d.ts +24 -0
  57. package/divider/divider.js +27 -0
  58. package/divider/divider.js.map +1 -0
  59. package/divider/lib/_divider.scss +54 -0
  60. package/{menu/lib/menu-button-styles.css.d.ts → divider/lib/divider-styles.css.d.ts} +0 -0
  61. package/divider/lib/divider-styles.css.js +9 -0
  62. package/divider/lib/divider-styles.css.js.map +1 -0
  63. package/divider/lib/divider-styles.scss +8 -0
  64. package/divider/lib/divider.d.ts +23 -0
  65. package/divider/lib/divider.js +41 -0
  66. package/divider/lib/divider.js.map +1 -0
  67. package/elevation/lib/_elevation.scss +1 -1
  68. package/elevation/lib/_md-comp-elevation.scss +1 -1
  69. package/elevation/lib/elevation-styles.css.js +1 -1
  70. package/elevation/lib/elevation-styles.css.js.map +1 -1
  71. package/fab/lib/_shared.scss +1 -1
  72. package/fab/lib/fab-shared-styles.css.js +1 -1
  73. package/fab/lib/fab-shared-styles.css.js.map +1 -1
  74. package/field/lib/_filled-field.scss +5 -2
  75. package/field/lib/_md-comp-filled-field.scss +3 -1
  76. package/field/lib/_md-comp-outlined-field.scss +1 -1
  77. package/field/lib/_shared.scss +2 -0
  78. package/field/lib/field.d.ts +0 -2
  79. package/field/lib/field.js +2 -4
  80. package/field/lib/field.js.map +1 -1
  81. package/field/lib/filled-styles.css.js +1 -1
  82. package/field/lib/filled-styles.css.js.map +1 -1
  83. package/field/lib/outlined-styles.css.js +1 -1
  84. package/field/lib/outlined-styles.css.js.map +1 -1
  85. package/field/lib/shared-styles.css.js +1 -1
  86. package/field/lib/shared-styles.css.js.map +1 -1
  87. package/focus/lib/_focus-ring.scss +3 -10
  88. package/focus/lib/focus-ring-styles.css.js +1 -1
  89. package/focus/lib/focus-ring-styles.css.js.map +1 -1
  90. package/focus/lib/focus-ring.d.ts +1 -4
  91. package/focus/lib/focus-ring.js +2 -11
  92. package/focus/lib/focus-ring.js.map +1 -1
  93. package/iconbutton/lib/_filled-icon-button.scss +1 -1
  94. package/iconbutton/lib/_filled-tonal-icon-button.scss +1 -1
  95. package/iconbutton/lib/_outlined-icon-button.scss +7 -5
  96. package/iconbutton/lib/_shared.scss +5 -25
  97. package/iconbutton/lib/_standard-icon-button.scss +4 -6
  98. package/iconbutton/lib/filled-styles.css.js +1 -1
  99. package/iconbutton/lib/filled-styles.css.js.map +1 -1
  100. package/iconbutton/lib/filled-tonal-styles.css.js +1 -1
  101. package/iconbutton/lib/filled-tonal-styles.css.js.map +1 -1
  102. package/iconbutton/lib/icon-button-toggle.d.ts +13 -42
  103. package/iconbutton/lib/icon-button-toggle.js +33 -103
  104. package/iconbutton/lib/icon-button-toggle.js.map +1 -1
  105. package/iconbutton/lib/icon-button.d.ts +2 -4
  106. package/iconbutton/lib/icon-button.js +3 -9
  107. package/iconbutton/lib/icon-button.js.map +1 -1
  108. package/iconbutton/lib/outlined-styles.css.js +1 -1
  109. package/iconbutton/lib/outlined-styles.css.js.map +1 -1
  110. package/iconbutton/lib/shared-styles.css.js +1 -1
  111. package/iconbutton/lib/shared-styles.css.js.map +1 -1
  112. package/iconbutton/lib/standard-styles.css.js +1 -1
  113. package/iconbutton/lib/standard-styles.css.js.map +1 -1
  114. package/list/lib/_list.scss +32 -40
  115. package/list/lib/avatar/_list-item-avatar.scss +1 -1
  116. package/list/lib/avatar/list-item-avatar-styles.css.js +1 -1
  117. package/list/lib/avatar/list-item-avatar-styles.css.js.map +1 -1
  118. package/list/lib/avatar/list-item-avatar.d.ts +9 -4
  119. package/list/lib/avatar/list-item-avatar.js +24 -11
  120. package/list/lib/avatar/list-item-avatar.js.map +1 -1
  121. package/list/lib/icon/_list-item-icon.scss +3 -1
  122. package/list/lib/icon/list-item-icon-styles.css.js +1 -1
  123. package/list/lib/icon/list-item-icon-styles.css.js.map +1 -1
  124. package/list/lib/icon/list-item-icon.d.ts +0 -3
  125. package/list/lib/icon/list-item-icon.js +1 -12
  126. package/list/lib/icon/list-item-icon.js.map +1 -1
  127. package/list/lib/image/_list-item-image.scss +1 -1
  128. package/list/lib/image/list-item-image-styles.css.js +1 -1
  129. package/list/lib/image/list-item-image-styles.css.js.map +1 -1
  130. package/list/lib/image/list-item-image.d.ts +11 -4
  131. package/list/lib/image/list-item-image.js +24 -13
  132. package/list/lib/image/list-item-image.js.map +1 -1
  133. package/list/lib/list-styles.css.js +1 -1
  134. package/list/lib/list-styles.css.js.map +1 -1
  135. package/list/lib/list.d.ts +99 -28
  136. package/list/lib/list.js +210 -111
  137. package/list/lib/list.js.map +1 -1
  138. package/list/lib/listitem/_list-item.scss +104 -39
  139. package/list/lib/listitem/harness.js +2 -1
  140. package/list/lib/listitem/harness.js.map +1 -1
  141. package/{tokens/v0_150/index.test.css.d.ts → list/lib/listitem/list-item-private-styles.css.d.ts} +0 -0
  142. package/list/lib/listitem/list-item-private-styles.css.js +9 -0
  143. package/list/lib/listitem/list-item-private-styles.css.js.map +1 -0
  144. package/list/lib/listitem/list-item-private-styles.scss +8 -0
  145. package/list/lib/listitem/list-item-styles.css.js +1 -1
  146. package/list/lib/listitem/list-item-styles.css.js.map +1 -1
  147. package/list/lib/listitem/list-item.d.ts +99 -43
  148. package/list/lib/listitem/list-item.js +201 -172
  149. package/list/lib/listitem/list-item.js.map +1 -1
  150. package/list/lib/listitemlink/list-item-link.d.ts +17 -0
  151. package/list/lib/listitemlink/list-item-link.js +42 -0
  152. package/list/lib/listitemlink/list-item-link.js.map +1 -0
  153. package/list/lib/video/_list-item-video.scss +10 -4
  154. package/list/lib/video/list-item-video-styles.css.js +1 -1
  155. package/list/lib/video/list-item-video-styles.css.js.map +1 -1
  156. package/list/lib/video/list-item-video.d.ts +43 -4
  157. package/list/lib/video/list-item-video.js +90 -12
  158. package/list/lib/video/list-item-video.js.map +1 -1
  159. package/list/list-item-avatar.d.ts +2 -1
  160. package/list/list-item-avatar.js +2 -1
  161. package/list/list-item-avatar.js.map +1 -1
  162. package/list/list-item-icon.d.ts +2 -1
  163. package/list/list-item-icon.js +2 -1
  164. package/list/list-item-icon.js.map +1 -1
  165. package/list/list-item-image.d.ts +2 -1
  166. package/list/list-item-image.js +2 -1
  167. package/list/list-item-image.js.map +1 -1
  168. package/list/list-item-link.d.ts +35 -0
  169. package/list/list-item-link.js +39 -0
  170. package/list/list-item-link.js.map +1 -0
  171. package/list/list-item-video.d.ts +2 -1
  172. package/list/list-item-video.js +2 -1
  173. package/list/list-item-video.js.map +1 -1
  174. package/list/list-item.d.ts +18 -2
  175. package/list/list-item.js +20 -3
  176. package/list/list-item.js.map +1 -1
  177. package/list/list.d.ts +15 -1
  178. package/list/list.js +15 -1
  179. package/list/list.js.map +1 -1
  180. package/menu/_menu-item.scss +6 -0
  181. package/menu/_menu.scss +6 -0
  182. package/menu/harness.d.ts +5 -0
  183. package/menu/harness.js +22 -0
  184. package/menu/harness.js.map +1 -1
  185. package/menu/lib/_menu.scss +61 -62
  186. package/menu/lib/menu-styles.css.js +1 -1
  187. package/menu/lib/menu-styles.css.js.map +1 -1
  188. package/menu/lib/menu.d.ts +176 -42
  189. package/menu/lib/menu.js +506 -246
  190. package/menu/lib/menu.js.map +1 -1
  191. package/menu/lib/menuitem/_menu-item.scss +115 -0
  192. package/{tokens/v0_150/lib.test.css.d.ts → menu/lib/menuitem/menu-item-private-styles.css.d.ts} +0 -0
  193. package/menu/lib/menuitem/menu-item-private-styles.css.js +9 -0
  194. package/menu/lib/menuitem/menu-item-private-styles.css.js.map +1 -0
  195. package/menu/lib/menuitem/menu-item-private-styles.scss +8 -0
  196. package/menu/lib/menuitem/menu-item-styles.css.d.ts +1 -0
  197. package/menu/lib/menuitem/menu-item-styles.css.js +9 -0
  198. package/menu/lib/menuitem/menu-item-styles.css.js.map +1 -0
  199. package/menu/lib/menuitem/menu-item-styles.scss +8 -0
  200. package/menu/lib/menuitem/menu-item.d.ts +20 -3
  201. package/menu/lib/menuitem/menu-item.js +42 -3
  202. package/menu/lib/menuitem/menu-item.js.map +1 -1
  203. package/menu/lib/menuitemlink/menu-item-link.d.ts +25 -0
  204. package/menu/lib/menuitemlink/menu-item-link.js +51 -0
  205. package/menu/lib/menuitemlink/menu-item-link.js.map +1 -0
  206. package/menu/lib/shared.d.ts +134 -0
  207. package/menu/lib/shared.js +85 -0
  208. package/menu/lib/shared.js.map +1 -0
  209. package/menu/lib/submenuitem/harness.d.ts +11 -0
  210. package/menu/lib/submenuitem/harness.js +12 -0
  211. package/menu/lib/submenuitem/harness.js.map +1 -0
  212. package/menu/lib/submenuitem/sub-menu-item.d.ts +89 -0
  213. package/menu/lib/submenuitem/sub-menu-item.js +266 -0
  214. package/menu/lib/submenuitem/sub-menu-item.js.map +1 -0
  215. package/menu/lib/surfacePositionController.d.ts +117 -0
  216. package/menu/lib/surfacePositionController.js +196 -0
  217. package/menu/lib/surfacePositionController.js.map +1 -0
  218. package/menu/lib/typeaheadController.d.ts +144 -0
  219. package/menu/lib/typeaheadController.js +242 -0
  220. package/menu/lib/typeaheadController.js.map +1 -0
  221. package/menu/menu-item-link.d.ts +33 -0
  222. package/menu/menu-item-link.js +37 -0
  223. package/menu/menu-item-link.js.map +1 -0
  224. package/menu/menu-item.d.ts +19 -2
  225. package/menu/menu-item.js +22 -4
  226. package/menu/menu-item.js.map +1 -1
  227. package/menu/menu.d.ts +45 -0
  228. package/menu/menu.js +43 -0
  229. package/menu/menu.js.map +1 -1
  230. package/menu/sub-menu-item.d.ts +60 -0
  231. package/menu/sub-menu-item.js +64 -0
  232. package/menu/sub-menu-item.js.map +1 -0
  233. package/menusurface/lib/_menu-surface.scss +1 -1
  234. package/menusurface/lib/menu-surface-styles.css.js +1 -1
  235. package/menusurface/lib/menu-surface-styles.css.js.map +1 -1
  236. package/motion/animation.d.ts +20 -3
  237. package/motion/animation.js +39 -4
  238. package/motion/animation.js.map +1 -1
  239. package/navigationbar/lib/_navigation-bar.scss +9 -9
  240. package/navigationbar/lib/navigation-bar-styles.css.js +1 -1
  241. package/navigationbar/lib/navigation-bar-styles.css.js.map +1 -1
  242. package/navigationdrawer/lib/_navigation-drawer.scss +1 -1
  243. package/navigationdrawer/lib/navigation-drawer-styles.css.js +1 -1
  244. package/navigationdrawer/lib/navigation-drawer-styles.css.js.map +1 -1
  245. package/navigationtab/lib/_navigation-tab.scss +8 -19
  246. package/navigationtab/lib/navigation-tab-styles.css.js +1 -1
  247. package/navigationtab/lib/navigation-tab-styles.css.js.map +1 -1
  248. package/package.json +1 -8
  249. package/radio/lib/_radio.scss +0 -1
  250. package/radio/lib/radio-styles.css.js +1 -1
  251. package/radio/lib/radio-styles.css.js.map +1 -1
  252. package/radio/lib/radio.d.ts +10 -1
  253. package/radio/lib/radio.js +10 -1
  254. package/radio/lib/radio.js.map +1 -1
  255. package/radio/radio.d.ts +16 -1
  256. package/radio/radio.js +16 -1
  257. package/radio/radio.js.map +1 -1
  258. package/ripple/lib/_ripple.scss +5 -21
  259. package/ripple/lib/ripple-styles.css.js +1 -1
  260. package/ripple/lib/ripple-styles.css.js.map +1 -1
  261. package/ripple/lib/ripple.js +2 -2
  262. package/ripple/lib/ripple.js.map +1 -1
  263. package/sass/_map-ext.scss +24 -0
  264. package/sass/_string-ext.scss +23 -0
  265. package/segmentedbuttonset/lib/segmented-button-set.d.ts +0 -2
  266. package/segmentedbuttonset/lib/segmented-button-set.js +0 -2
  267. package/segmentedbuttonset/lib/segmented-button-set.js.map +1 -1
  268. package/switch/lib/_handle.scss +56 -9
  269. package/switch/lib/_icon.scss +36 -0
  270. package/switch/lib/_switch.scss +1 -115
  271. package/switch/lib/_track.scss +39 -0
  272. package/switch/lib/switch-styles.css.js +1 -1
  273. package/switch/lib/switch-styles.css.js.map +1 -1
  274. package/switch/lib/switch.d.ts +3 -0
  275. package/switch/lib/switch.js +3 -0
  276. package/switch/lib/switch.js.map +1 -1
  277. package/textfield/lib/_filled-text-field.scss +4 -2
  278. package/textfield/lib/_outlined-text-field.scss +3 -2
  279. package/textfield/lib/filled-styles.css.js +1 -1
  280. package/textfield/lib/filled-styles.css.js.map +1 -1
  281. package/textfield/lib/outlined-styles.css.js +1 -1
  282. package/textfield/lib/outlined-styles.css.js.map +1 -1
  283. package/textfield/lib/text-field.d.ts +0 -2
  284. package/textfield/lib/text-field.js +0 -2
  285. package/textfield/lib/text-field.js.map +1 -1
  286. package/tokens/_index.scss +1 -1
  287. package/tokens/{v0_150 → v0_152}/_index.scss +1 -1
  288. package/tokens/{v0_150 → v0_152}/_md-comp-assist-chip.scss +2 -2
  289. package/tokens/{v0_150 → v0_152}/_md-comp-badge.scss +2 -2
  290. package/tokens/{v0_150 → v0_152}/_md-comp-banner.scss +2 -43
  291. package/tokens/{v0_150 → v0_152}/_md-comp-bottom-app-bar.scss +3 -4
  292. package/tokens/{v0_150 → v0_152}/_md-comp-carousel-item.scss +2 -2
  293. package/tokens/{v0_150 → v0_152}/_md-comp-checkbox.scss +2 -12
  294. package/tokens/{v0_150 → v0_152}/_md-comp-circular-progress-indicator.scss +2 -2
  295. package/tokens/{v0_150 → v0_152}/_md-comp-data-table.scss +2 -4
  296. package/tokens/{v0_150 → v0_152}/_md-comp-date-input-modal.scss +2 -2
  297. package/tokens/{v0_150 → v0_152}/_md-comp-date-picker-docked.scss +2 -2
  298. package/tokens/{v0_150 → v0_152}/_md-comp-date-picker-modal.scss +2 -2
  299. package/tokens/{v0_150 → v0_152}/_md-comp-dialog.scss +2 -25
  300. package/tokens/{v0_150 → v0_152}/_md-comp-divider.scss +2 -2
  301. package/tokens/{v0_150 → v0_152}/_md-comp-elevated-button.scss +2 -2
  302. package/tokens/{v0_150 → v0_152}/_md-comp-elevated-card.scss +2 -2
  303. package/tokens/{v0_150 → v0_152}/_md-comp-extended-fab-branded.scss +2 -2
  304. package/tokens/{v0_150 → v0_152}/_md-comp-extended-fab-primary.scss +2 -2
  305. package/tokens/{v0_150 → v0_152}/_md-comp-extended-fab-secondary.scss +2 -2
  306. package/tokens/{v0_150 → v0_152}/_md-comp-extended-fab-surface.scss +2 -2
  307. package/tokens/{v0_150 → v0_152}/_md-comp-extended-fab-tertiary.scss +2 -4
  308. package/tokens/{v0_150 → v0_152}/_md-comp-fab-branded-large.scss +2 -3
  309. package/tokens/{v0_150 → v0_152}/_md-comp-fab-branded.scss +2 -2
  310. package/tokens/{v0_150 → v0_152}/_md-comp-fab-primary-large.scss +2 -2
  311. package/tokens/{v0_150 → v0_152}/_md-comp-fab-primary-small.scss +2 -2
  312. package/tokens/{v0_150 → v0_152}/_md-comp-fab-primary.scss +2 -2
  313. package/tokens/{v0_150 → v0_152}/_md-comp-fab-secondary-large.scss +2 -2
  314. package/tokens/{v0_150 → v0_152}/_md-comp-fab-secondary-small.scss +2 -2
  315. package/tokens/{v0_150 → v0_152}/_md-comp-fab-secondary.scss +2 -2
  316. package/tokens/{v0_150 → v0_152}/_md-comp-fab-surface-large.scss +2 -2
  317. package/tokens/{v0_150 → v0_152}/_md-comp-fab-surface-small.scss +2 -2
  318. package/tokens/{v0_150 → v0_152}/_md-comp-fab-surface.scss +2 -2
  319. package/tokens/{v0_150 → v0_152}/_md-comp-fab-tertiary-large.scss +2 -2
  320. package/tokens/{v0_150 → v0_152}/_md-comp-fab-tertiary-small.scss +2 -2
  321. package/tokens/{v0_150 → v0_152}/_md-comp-fab-tertiary.scss +2 -2
  322. package/tokens/{v0_150 → v0_152}/_md-comp-filled-autocomplete.scss +2 -3
  323. package/tokens/{v0_150 → v0_152}/_md-comp-filled-button.scss +2 -8
  324. package/tokens/{v0_150 → v0_152}/_md-comp-filled-card.scss +2 -4
  325. package/tokens/{v0_150 → v0_152}/_md-comp-filled-icon-button.scss +2 -2
  326. package/tokens/{v0_150 → v0_152}/_md-comp-filled-menu-button.scss +2 -2
  327. package/tokens/{v0_150 → v0_152}/_md-comp-filled-select.scss +2 -6
  328. package/tokens/{v0_150 → v0_152}/_md-comp-filled-text-field.scss +2 -3
  329. package/tokens/{v0_150 → v0_152}/_md-comp-filled-tonal-button.scss +2 -2
  330. package/tokens/{v0_150 → v0_152}/_md-comp-filled-tonal-icon-button.scss +2 -2
  331. package/tokens/{v0_150 → v0_152}/_md-comp-filter-chip.scss +2 -30
  332. package/tokens/{v0_150 → v0_152}/_md-comp-full-screen-dialog.scss +3 -53
  333. package/tokens/{v0_150 → v0_152}/_md-comp-icon-button.scss +3 -3
  334. package/tokens/{v0_150 → v0_152}/_md-comp-input-chip.scss +2 -52
  335. package/tokens/{v0_150 → v0_152}/_md-comp-linear-progress-indicator.scss +2 -2
  336. package/tokens/{v0_150 → v0_152}/_md-comp-list.scss +3 -12
  337. package/tokens/{v0_150 → v0_152}/_md-comp-menu.scss +2 -4
  338. package/tokens/{v0_150 → v0_152}/_md-comp-navigation-bar.scss +2 -9
  339. package/tokens/{v0_150 → v0_152}/_md-comp-navigation-drawer.scss +2 -8
  340. package/tokens/{v0_150 → v0_152}/_md-comp-navigation-rail.scss +2 -39
  341. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-autocomplete.scss +2 -3
  342. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-button.scss +2 -6
  343. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-card.scss +2 -2
  344. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-icon-button.scss +2 -4
  345. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-menu-button.scss +2 -2
  346. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-segmented-button.scss +2 -2
  347. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-select.scss +2 -6
  348. package/tokens/{v0_150 → v0_152}/_md-comp-outlined-text-field.scss +2 -3
  349. package/tokens/{v0_150 → v0_152}/_md-comp-plain-tooltip.scss +2 -2
  350. package/tokens/{v0_150 → v0_152}/_md-comp-primary-navigation-tab.scss +2 -2
  351. package/tokens/{v0_150 → v0_152}/_md-comp-radio-button.scss +2 -2
  352. package/tokens/{v0_150 → v0_152}/_md-comp-rich-tooltip.scss +2 -2
  353. package/tokens/{v0_150 → v0_152}/_md-comp-scrim.scss +2 -2
  354. package/tokens/{v0_150 → v0_152}/_md-comp-search-bar.scss +2 -2
  355. package/tokens/{v0_150 → v0_152}/_md-comp-search-view.scss +2 -2
  356. package/tokens/{v0_150 → v0_152}/_md-comp-secondary-navigation-tab.scss +2 -2
  357. package/tokens/{v0_150 → v0_152}/_md-comp-sheet-bottom.scss +2 -2
  358. package/tokens/{v0_150 → v0_152}/_md-comp-sheet-floating.scss +2 -2
  359. package/tokens/{v0_150 → v0_152}/_md-comp-sheet-side.scss +4 -2
  360. package/tokens/{v0_150 → v0_152}/_md-comp-slider.scss +2 -4
  361. package/tokens/{v0_150 → v0_152}/_md-comp-snackbar.scss +2 -2
  362. package/tokens/{v0_150 → v0_152}/_md-comp-standard-menu-button.scss +2 -2
  363. package/tokens/{v0_150 → v0_152}/_md-comp-suggestion-chip.scss +2 -2
  364. package/tokens/{v0_150 → v0_152}/_md-comp-switch.scss +2 -11
  365. package/tokens/{v0_150 → v0_152}/_md-comp-text-button.scss +2 -6
  366. package/tokens/{v0_150 → v0_152}/_md-comp-time-input.scss +2 -2
  367. package/tokens/{v0_150 → v0_152}/_md-comp-time-picker.scss +2 -5
  368. package/tokens/{v0_150 → v0_152}/_md-comp-top-app-bar-large.scss +2 -2
  369. package/tokens/{v0_150 → v0_152}/_md-comp-top-app-bar-medium.scss +2 -2
  370. package/tokens/{v0_150 → v0_152}/_md-comp-top-app-bar-small-centered.scss +2 -3
  371. package/tokens/{v0_150 → v0_152}/_md-comp-top-app-bar-small.scss +2 -3
  372. package/tokens/{v0_150 → v0_152}/_md-ref-palette.scss +2 -2
  373. package/tokens/{v0_150 → v0_152}/_md-ref-typeface.scss +2 -2
  374. package/tokens/{v0_150 → v0_152}/_md-sys-color.scss +2 -20
  375. package/tokens/{v0_150 → v0_152}/_md-sys-elevation.scss +4 -13
  376. package/tokens/{v0_150 → v0_152}/_md-sys-motion.scss +2 -2
  377. package/tokens/{v0_150 → v0_152}/_md-sys-shape.scss +2 -2
  378. package/tokens/{v0_150 → v0_152}/_md-sys-state.scss +2 -2
  379. package/tokens/{v0_150 → v0_152}/_md-sys-typescale.scss +2 -3
  380. package/tokens/v0_152/index.test.css.d.ts +1 -0
  381. package/tokens/{v0_150 → v0_152}/index.test.css.js +0 -0
  382. package/tokens/{v0_150 → v0_152}/index.test.css.js.map +0 -0
  383. package/tokens/{v0_150 → v0_152}/index.test.scss +1 -1
  384. package/tokens/v0_152/lib.test.css.d.ts +1 -0
  385. package/tokens/{v0_150 → v0_152}/lib.test.css.js +0 -0
  386. package/tokens/{v0_150 → v0_152}/lib.test.css.js.map +0 -0
  387. package/tokens/{v0_150 → v0_152}/lib.test.scss +1 -1
  388. package/list/lib/_tokens.scss +0 -80
  389. package/list/lib/divider/_list-divider.scss +0 -46
  390. package/list/lib/divider/list-divider-styles.css.js +0 -9
  391. package/list/lib/divider/list-divider-styles.css.js.map +0 -1
  392. package/list/lib/divider/list-divider-styles.scss +0 -8
  393. package/list/lib/divider/list-divider.d.ts +0 -13
  394. package/list/lib/divider/list-divider.js +0 -32
  395. package/list/lib/divider/list-divider.js.map +0 -1
  396. package/list/list-divider.d.ts +0 -19
  397. package/list/list-divider.js +0 -22
  398. package/list/list-divider.js.map +0 -1
  399. package/menu/lib/_menu-button.scss +0 -14
  400. package/menu/lib/adapter.d.ts +0 -66
  401. package/menu/lib/adapter.js +0 -7
  402. package/menu/lib/adapter.js.map +0 -1
  403. package/menu/lib/constants.d.ts +0 -22
  404. package/menu/lib/constants.js +0 -23
  405. package/menu/lib/constants.js.map +0 -1
  406. package/menu/lib/foundation.d.ts +0 -49
  407. package/menu/lib/foundation.js +0 -123
  408. package/menu/lib/foundation.js.map +0 -1
  409. package/menu/lib/menu-button-styles.css.js +0 -9
  410. package/menu/lib/menu-button-styles.css.js.map +0 -1
  411. package/menu/lib/menu-button-styles.scss +0 -8
  412. package/menu/lib/menu-button.d.ts +0 -27
  413. package/menu/lib/menu-button.js +0 -93
  414. package/menu/lib/menu-button.js.map +0 -1
  415. package/menu/menu-button.d.ts +0 -14
  416. package/menu/menu-button.js +0 -17
  417. package/menu/menu-button.js.map +0 -1
@@ -3,24 +3,21 @@
3
3
  // SPDX-License-Identifier: Apache-2.0
4
4
  //
5
5
 
6
- // stylelint-disable selector-class-pattern --
7
- // Selector '.md3-*' should only be used in this project.
8
-
9
6
  @use 'sass:map';
10
7
 
11
- @use '../../elevation/lib/elevation';
12
8
  @use '../../list/list';
13
- @use '../../list/list-item';
14
- @use '../../menusurface/menu-surface';
9
+ @use './menuitem/menu-item';
15
10
  @use '../../sass/resolvers';
16
11
  @use '../../sass/theme';
17
12
  @use '../../tokens';
13
+ @use '../../elevation/lib/elevation';
14
+ @use '../../focus/focus-ring';
18
15
 
19
16
  $_custom-property-prefix: 'menu';
20
17
 
21
18
  @mixin theme($theme) {
22
19
  $theme: theme.validate-theme(tokens.md-comp-menu-values(), $theme);
23
- $theme: _resolve-tokens($tokens);
20
+ $theme: _resolve-tokens($theme);
24
21
  $theme: theme.create-theme-vars($theme, $_custom-property-prefix);
25
22
 
26
23
  @include theme.emit-theme-vars($theme);
@@ -35,74 +32,76 @@ $_custom-property-prefix: 'menu';
35
32
  @each $token, $value in $tokens {
36
33
  --_#{$token}: #{$value};
37
34
  }
38
- }
39
35
 
40
- .md3-menu {
41
- @include menu-surface.theme(
36
+ @include list.theme(
42
37
  (
43
- container-elevation: var(--_container-elevation),
44
- container-shape: var(--_container-shape),
45
- container-shadow-color: var(--_container-shadow-color),
46
- container-surface-tint-layer-color:
47
- var(--_container-surface-tint-layer-color),
38
+ container-color: var(--_container-color),
48
39
  )
49
40
  );
50
41
 
51
- @include list.theme(
42
+ @include elevation.theme(
52
43
  (
53
- container-color: var(--_container-color),
54
- container-surface-tint-layer-color:
55
- var(--_container-surface-tint-layer-color),
56
- container-elevation: var(--_container-elevation),
44
+ level: var(--_container-elevation),
45
+ shadow-color: var(--_container-shadow-color),
46
+ surface-tint: var(--_container-surface-tint-layer-color),
57
47
  )
58
48
  );
59
- @include list-item.theme(
49
+
50
+ @include focus-ring.theme(
60
51
  (
61
- list-item-container-color: var(--_container-color),
62
- list-item-one-line-container-height: var(--_list-item-container-height),
63
- list-item-disabled-label-text-color:
64
- var(--_list-item-disabled-label-text-color),
65
- list-item-disabled-label-text-opacity:
66
- var(--_list-item-disabled-label-text-opacity),
67
- list-item-hover-label-text-color:
68
- var(--_list-item-hover-label-text-color),
69
- list-item-hover-state-layer-color:
70
- var(--_list-item-hover-state-layer-color),
71
- list-item-hover-state-layer-opacity:
72
- var(--_list-item-hover-state-layer-opacity),
73
- list-item-label-text-color: var(--_list-item-label-text-color),
74
- list-item-label-text-font: var(--_list-item-label-text-font),
75
- list-item-label-text-line-height:
76
- var(--_list-item-label-text-line-height),
77
- list-item-label-text-size: var(--_list-item-label-text-size),
78
- list-item-label-text-tracking: var(--_list-item-label-text-tracking),
79
- list-item-label-text-weight: var(--_list-item-label-text-tracking),
80
- list-item-disabled-leading-icon-color:
81
- var(--_list-item-with-leading-icon-disabled-leading-icon-color),
82
- list-item-disabled-leading-icon-opacity:
83
- var(--_list-item-with-leading-icon-disabled-leading-icon-opacity),
84
- list-item-hover-leading-icon-color:
85
- var(--_list-item-with-leading-icon-hover-icon-color),
86
- list-item-leading-icon-color:
87
- var(--_list-item-with-leading-icon-leading-icon-color),
88
- list-item-leading-icon-size:
89
- var(--_list-item-with-leading-icon-leading-icon-size),
90
- list-item-disabled-trailing-icon-color:
91
- var(--_list-item-with-trailing-icon-disabled-trailing-icon-color),
92
- list-item-disabled-trailing-icon-opacity:
93
- var(--_list-item-with-trailing-icon-disabled-trailing-icon-opacity),
94
- list-item-hover-trailing-icon-color:
95
- var(--_list-item-with-trailing-icon-hover-icon-color),
96
- list-item-trailing-icon-color:
97
- var(--_list-item-with-trailing-icon-trailing-icon-color),
98
- list-item-trailing-icon-size:
99
- var(--_list-item-with-leading-icon-trailing-icon-size),
52
+ shape: var(--_container-shape),
100
53
  )
101
54
  );
102
55
  }
56
+
57
+ .menu {
58
+ border-radius: var(--_container-shape);
59
+ display: none;
60
+ opacity: 0;
61
+ z-index: 20;
62
+ position: absolute;
63
+ user-select: none;
64
+ max-height: inherit;
65
+ height: inherit;
66
+
67
+ &.fixed {
68
+ position: fixed;
69
+ }
70
+
71
+ md-list {
72
+ height: inherit;
73
+ max-height: inherit;
74
+ display: block;
75
+ overflow: auto;
76
+ }
77
+
78
+ &.has-overflow md-list {
79
+ overflow: visible;
80
+ }
81
+
82
+ &.animating md-list {
83
+ pointer-events: none;
84
+ overflow: hidden;
85
+ }
86
+
87
+ &.animating ::slotted(.hidden) {
88
+ opacity: 0;
89
+ }
90
+
91
+ slot {
92
+ display: block;
93
+ height: inherit;
94
+ max-height: inherit;
95
+ }
96
+ }
97
+
98
+ md-elevation {
99
+ position: absolute;
100
+ inset: 0;
101
+ pointer-events: none;
102
+ }
103
103
  }
104
104
 
105
105
  @function _resolve-tokens($tokens) {
106
- $tokens: elevation.resolve-tokens($tokens, 'container-elevation');
107
- @return $tokens;
106
+ @return elevation.resolve-tokens($tokens, 'elevation-key');
108
107
  }
@@ -4,6 +4,6 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import { css } from 'lit';
7
- export const styles = css `:host{--_cascading-menu-indicator-icon-color: var(--md-menu-cascading-menu-indicator-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_cascading-menu-indicator-icon-size: var(--md-menu-cascading-menu-indicator-icon-size, 24px);--_container-color: var(--md-menu-container-color, var(--md-sys-color-surface, #fffbfe));--_container-elevation: var(--md-menu-container-elevation, 2);--_container-shadow-color: var(--md-menu-container-shadow-color, var(--md-sys-color-shadow, #000));--_container-shape: var(--md-menu-container-shape, 4px);--_container-surface-tint-layer-color: var(--md-menu-container-surface-tint-layer-color, var(--md-sys-color-primary, #6750a4));--_divider-color: var(--md-menu-divider-color, var(--md-sys-color-surface-variant, #e7e0ec));--_divider-height: var(--md-menu-divider-height, 1px);--_list-item-container-height: var(--md-menu-list-item-container-height, 48px);--_list-item-disabled-label-text-color: var(--md-menu-list-item-disabled-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-disabled-label-text-opacity: var(--md-menu-list-item-disabled-label-text-opacity, 0.38);--_list-item-focus-label-text-color: var(--md-menu-list-item-focus-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-color: var(--md-menu-list-item-focus-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-opacity: var(--md-menu-list-item-focus-state-layer-opacity, 0.12);--_list-item-hover-label-text-color: var(--md-menu-list-item-hover-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-color: var(--md-menu-list-item-hover-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-opacity: var(--md-menu-list-item-hover-state-layer-opacity, 0.08);--_list-item-label-text-color: var(--md-menu-list-item-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-label-text-font: var(--md-menu-list-item-label-text-font, Roboto);--_list-item-label-text-line-height: var(--md-menu-list-item-label-text-line-height, 1.25rem);--_list-item-label-text-size: var(--md-menu-list-item-label-text-size, 0.875rem);--_list-item-label-text-tracking: var(--md-menu-list-item-label-text-tracking, 0.006rem);--_list-item-label-text-type: var(--md-menu-list-item-label-text-type, 500 0.875rem / 1.25rem Roboto);--_list-item-label-text-weight: var(--md-menu-list-item-label-text-weight, 500);--_list-item-pressed-label-text-color: var(--md-menu-list-item-pressed-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-color: var(--md-menu-list-item-pressed-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-opacity: var(--md-menu-list-item-pressed-state-layer-opacity, 0.12);--_list-item-selected-container-color: var(--md-menu-list-item-selected-container-color, var(--md-sys-color-surface-variant, #e7e0ec));--_list-item-with-leading-icon-disabled-leading-icon-color: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-leading-icon-disabled-leading-icon-opacity: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-opacity, 0.38);--_list-item-with-leading-icon-focus-icon-color: var(--md-menu-list-item-with-leading-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-hover-icon-color: var(--md-menu-list-item-with-leading-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-color: var(--md-menu-list-item-with-leading-icon-leading-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-size: var(--md-menu-list-item-with-leading-icon-leading-icon-size, 24px);--_list-item-with-leading-icon-pressed-icon-color: var(--md-menu-list-item-with-leading-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-disabled-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-trailing-icon-disabled-trailing-icon-opacity: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-opacity, 0.38);--_list-item-with-trailing-icon-focus-icon-color: var(--md-menu-list-item-with-trailing-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-hover-icon-color: var(--md-menu-list-item-with-trailing-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-pressed-icon-color: var(--md-menu-list-item-with-trailing-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-trailing-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-size: var(--md-menu-list-item-with-trailing-icon-trailing-icon-size, 24px)}.md3-menu{--md-menu-surface-container-elevation:var(--_container-elevation);--md-menu-surface-container-shape:var(--_container-shape);--md-menu-surface-container-shadow-color:var(--_container-shadow-color);--md-menu-surface-container-surface-tint-layer-color:var(--_container-surface-tint-layer-color);--md-list-container-color:var(--_container-color);--md-list-container-surface-tint-layer-color:var(--_container-surface-tint-layer-color);--md-list-container-elevation:var(--_container-elevation);--md-list-list-item-container-color:var(--_container-color);--md-list-list-item-one-line-container-height:var(--_list-item-container-height);--md-list-list-item-disabled-label-text-color:var(--_list-item-disabled-label-text-color);--md-list-list-item-disabled-label-text-opacity:var(--_list-item-disabled-label-text-opacity);--md-list-list-item-hover-label-text-color:var(--_list-item-hover-label-text-color);--md-list-list-item-hover-state-layer-color:var(--_list-item-hover-state-layer-color);--md-list-list-item-hover-state-layer-opacity:var(--_list-item-hover-state-layer-opacity);--md-list-list-item-label-text-color:var(--_list-item-label-text-color);--md-list-list-item-label-text-font:var(--_list-item-label-text-font);--md-list-list-item-label-text-line-height:var(--_list-item-label-text-line-height);--md-list-list-item-label-text-size:var(--_list-item-label-text-size);--md-list-list-item-label-text-tracking:var(--_list-item-label-text-tracking);--md-list-list-item-label-text-weight:var(--_list-item-label-text-tracking);--md-list-list-item-disabled-leading-icon-color:var(--_list-item-with-leading-icon-disabled-leading-icon-color);--md-list-list-item-disabled-leading-icon-opacity:var(--_list-item-with-leading-icon-disabled-leading-icon-opacity);--md-list-list-item-hover-leading-icon-color:var(--_list-item-with-leading-icon-hover-icon-color);--md-list-list-item-leading-icon-color:var(--_list-item-with-leading-icon-leading-icon-color);--md-list-list-item-leading-icon-size:var(--_list-item-with-leading-icon-leading-icon-size);--md-list-list-item-disabled-trailing-icon-color:var(--_list-item-with-trailing-icon-disabled-trailing-icon-color);--md-list-list-item-disabled-trailing-icon-opacity:var(--_list-item-with-trailing-icon-disabled-trailing-icon-opacity);--md-list-list-item-hover-trailing-icon-color:var(--_list-item-with-trailing-icon-hover-icon-color);--md-list-list-item-trailing-icon-color:var(--_list-item-with-trailing-icon-trailing-icon-color);--md-list-list-item-trailing-icon-size:var(--_list-item-with-leading-icon-trailing-icon-size)}/*# sourceMappingURL=menu-styles.css.map */
7
+ export const styles = css `:host{--_cascading-menu-indicator-icon-color: var(--md-menu-cascading-menu-indicator-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_cascading-menu-indicator-icon-size: var(--md-menu-cascading-menu-indicator-icon-size, 24px);--_container-color: var(--md-menu-container-color, var(--md-sys-color-surface, #fffbfe));--_container-elevation: var(--md-menu-container-elevation, 3);--_container-shadow-color: var(--md-menu-container-shadow-color, var(--md-sys-color-shadow, #000));--_container-shape: var(--md-menu-container-shape, 4px);--_container-surface-tint-layer-color: var(--md-menu-container-surface-tint-layer-color, var(--md-sys-color-primary, #6750a4));--_list-item-container-height: var(--md-menu-list-item-container-height, 48px);--_list-item-disabled-label-text-color: var(--md-menu-list-item-disabled-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-disabled-label-text-opacity: var(--md-menu-list-item-disabled-label-text-opacity, 0.38);--_list-item-focus-label-text-color: var(--md-menu-list-item-focus-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-color: var(--md-menu-list-item-focus-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-opacity: var(--md-menu-list-item-focus-state-layer-opacity, 0.12);--_list-item-hover-label-text-color: var(--md-menu-list-item-hover-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-color: var(--md-menu-list-item-hover-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-opacity: var(--md-menu-list-item-hover-state-layer-opacity, 0.08);--_list-item-label-text-color: var(--md-menu-list-item-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-label-text-font: var(--md-menu-list-item-label-text-font, Roboto);--_list-item-label-text-line-height: var(--md-menu-list-item-label-text-line-height, 1.25rem);--_list-item-label-text-size: var(--md-menu-list-item-label-text-size, 0.875rem);--_list-item-label-text-tracking: var(--md-menu-list-item-label-text-tracking, 0.006rem);--_list-item-label-text-type: var(--md-menu-list-item-label-text-type, 500 0.875rem / 1.25rem Roboto);--_list-item-label-text-weight: var(--md-menu-list-item-label-text-weight, 500);--_list-item-pressed-label-text-color: var(--md-menu-list-item-pressed-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-color: var(--md-menu-list-item-pressed-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-opacity: var(--md-menu-list-item-pressed-state-layer-opacity, 0.12);--_list-item-selected-container-color: var(--md-menu-list-item-selected-container-color, var(--md-sys-color-surface-variant, #e7e0ec));--_list-item-with-leading-icon-disabled-leading-icon-color: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-leading-icon-disabled-leading-icon-opacity: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-opacity, 0.38);--_list-item-with-leading-icon-focus-icon-color: var(--md-menu-list-item-with-leading-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-hover-icon-color: var(--md-menu-list-item-with-leading-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-color: var(--md-menu-list-item-with-leading-icon-leading-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-size: var(--md-menu-list-item-with-leading-icon-leading-icon-size, 24px);--_list-item-with-leading-icon-pressed-icon-color: var(--md-menu-list-item-with-leading-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-disabled-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-trailing-icon-disabled-trailing-icon-opacity: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-opacity, 0.38);--_list-item-with-trailing-icon-focus-icon-color: var(--md-menu-list-item-with-trailing-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-hover-icon-color: var(--md-menu-list-item-with-trailing-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-pressed-icon-color: var(--md-menu-list-item-with-trailing-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-trailing-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-size: var(--md-menu-list-item-with-trailing-icon-trailing-icon-size, 24px);--md-elevation-level:var(--_container-elevation);--md-elevation-shadow-color:var(--_container-shadow-color);--md-elevation-surface-tint:var(--_container-surface-tint-layer-color);--md-focus-ring-shape-start-start:var(--_container-shape);--md-focus-ring-shape-start-end:var(--_container-shape);--md-focus-ring-shape-end-end:var(--_container-shape);--md-focus-ring-shape-end-start:var(--_container-shape)}.menu{border-radius:var(--_container-shape);display:none;opacity:0;z-index:20;position:absolute;user-select:none;max-height:inherit;height:inherit}.menu.fixed{position:fixed}.menu md-list{height:inherit;max-height:inherit;display:block;overflow:auto}.menu.has-overflow md-list{overflow:visible}.menu.animating md-list{pointer-events:none;overflow:hidden}.menu.animating ::slotted(.hidden){opacity:0}.menu slot{display:block;height:inherit;max-height:inherit}md-elevation{position:absolute;inset:0;pointer-events:none}/*# sourceMappingURL=menu-styles.css.map */
8
8
  `;
9
9
  //# sourceMappingURL=menu-styles.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"menu-styles.css.js","sourceRoot":"","sources":["menu-styles.css.ts"],"names":[],"mappings":"AAAA;;;;IAII;AACH,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAC;AACxB,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;CACzB,CAAC","sourcesContent":["/**\n * @license\n * Copyright 2022 Google LLC\n * SPDX-License-Identifier: Apache-2.0\n */\n import {css} from 'lit';\n export const styles = css`:host{--_cascading-menu-indicator-icon-color: var(--md-menu-cascading-menu-indicator-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_cascading-menu-indicator-icon-size: var(--md-menu-cascading-menu-indicator-icon-size, 24px);--_container-color: var(--md-menu-container-color, var(--md-sys-color-surface, #fffbfe));--_container-elevation: var(--md-menu-container-elevation, 2);--_container-shadow-color: var(--md-menu-container-shadow-color, var(--md-sys-color-shadow, #000));--_container-shape: var(--md-menu-container-shape, 4px);--_container-surface-tint-layer-color: var(--md-menu-container-surface-tint-layer-color, var(--md-sys-color-primary, #6750a4));--_divider-color: var(--md-menu-divider-color, var(--md-sys-color-surface-variant, #e7e0ec));--_divider-height: var(--md-menu-divider-height, 1px);--_list-item-container-height: var(--md-menu-list-item-container-height, 48px);--_list-item-disabled-label-text-color: var(--md-menu-list-item-disabled-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-disabled-label-text-opacity: var(--md-menu-list-item-disabled-label-text-opacity, 0.38);--_list-item-focus-label-text-color: var(--md-menu-list-item-focus-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-color: var(--md-menu-list-item-focus-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-opacity: var(--md-menu-list-item-focus-state-layer-opacity, 0.12);--_list-item-hover-label-text-color: var(--md-menu-list-item-hover-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-color: var(--md-menu-list-item-hover-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-opacity: var(--md-menu-list-item-hover-state-layer-opacity, 0.08);--_list-item-label-text-color: var(--md-menu-list-item-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-label-text-font: var(--md-menu-list-item-label-text-font, Roboto);--_list-item-label-text-line-height: var(--md-menu-list-item-label-text-line-height, 1.25rem);--_list-item-label-text-size: var(--md-menu-list-item-label-text-size, 0.875rem);--_list-item-label-text-tracking: var(--md-menu-list-item-label-text-tracking, 0.006rem);--_list-item-label-text-type: var(--md-menu-list-item-label-text-type, 500 0.875rem / 1.25rem Roboto);--_list-item-label-text-weight: var(--md-menu-list-item-label-text-weight, 500);--_list-item-pressed-label-text-color: var(--md-menu-list-item-pressed-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-color: var(--md-menu-list-item-pressed-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-opacity: var(--md-menu-list-item-pressed-state-layer-opacity, 0.12);--_list-item-selected-container-color: var(--md-menu-list-item-selected-container-color, var(--md-sys-color-surface-variant, #e7e0ec));--_list-item-with-leading-icon-disabled-leading-icon-color: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-leading-icon-disabled-leading-icon-opacity: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-opacity, 0.38);--_list-item-with-leading-icon-focus-icon-color: var(--md-menu-list-item-with-leading-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-hover-icon-color: var(--md-menu-list-item-with-leading-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-color: var(--md-menu-list-item-with-leading-icon-leading-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-size: var(--md-menu-list-item-with-leading-icon-leading-icon-size, 24px);--_list-item-with-leading-icon-pressed-icon-color: var(--md-menu-list-item-with-leading-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-disabled-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-trailing-icon-disabled-trailing-icon-opacity: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-opacity, 0.38);--_list-item-with-trailing-icon-focus-icon-color: var(--md-menu-list-item-with-trailing-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-hover-icon-color: var(--md-menu-list-item-with-trailing-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-pressed-icon-color: var(--md-menu-list-item-with-trailing-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-trailing-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-size: var(--md-menu-list-item-with-trailing-icon-trailing-icon-size, 24px)}.md3-menu{--md-menu-surface-container-elevation:var(--_container-elevation);--md-menu-surface-container-shape:var(--_container-shape);--md-menu-surface-container-shadow-color:var(--_container-shadow-color);--md-menu-surface-container-surface-tint-layer-color:var(--_container-surface-tint-layer-color);--md-list-container-color:var(--_container-color);--md-list-container-surface-tint-layer-color:var(--_container-surface-tint-layer-color);--md-list-container-elevation:var(--_container-elevation);--md-list-list-item-container-color:var(--_container-color);--md-list-list-item-one-line-container-height:var(--_list-item-container-height);--md-list-list-item-disabled-label-text-color:var(--_list-item-disabled-label-text-color);--md-list-list-item-disabled-label-text-opacity:var(--_list-item-disabled-label-text-opacity);--md-list-list-item-hover-label-text-color:var(--_list-item-hover-label-text-color);--md-list-list-item-hover-state-layer-color:var(--_list-item-hover-state-layer-color);--md-list-list-item-hover-state-layer-opacity:var(--_list-item-hover-state-layer-opacity);--md-list-list-item-label-text-color:var(--_list-item-label-text-color);--md-list-list-item-label-text-font:var(--_list-item-label-text-font);--md-list-list-item-label-text-line-height:var(--_list-item-label-text-line-height);--md-list-list-item-label-text-size:var(--_list-item-label-text-size);--md-list-list-item-label-text-tracking:var(--_list-item-label-text-tracking);--md-list-list-item-label-text-weight:var(--_list-item-label-text-tracking);--md-list-list-item-disabled-leading-icon-color:var(--_list-item-with-leading-icon-disabled-leading-icon-color);--md-list-list-item-disabled-leading-icon-opacity:var(--_list-item-with-leading-icon-disabled-leading-icon-opacity);--md-list-list-item-hover-leading-icon-color:var(--_list-item-with-leading-icon-hover-icon-color);--md-list-list-item-leading-icon-color:var(--_list-item-with-leading-icon-leading-icon-color);--md-list-list-item-leading-icon-size:var(--_list-item-with-leading-icon-leading-icon-size);--md-list-list-item-disabled-trailing-icon-color:var(--_list-item-with-trailing-icon-disabled-trailing-icon-color);--md-list-list-item-disabled-trailing-icon-opacity:var(--_list-item-with-trailing-icon-disabled-trailing-icon-opacity);--md-list-list-item-hover-trailing-icon-color:var(--_list-item-with-trailing-icon-hover-icon-color);--md-list-list-item-trailing-icon-color:var(--_list-item-with-trailing-icon-trailing-icon-color);--md-list-list-item-trailing-icon-size:var(--_list-item-with-leading-icon-trailing-icon-size)}/*# sourceMappingURL=menu-styles.css.map */\n`;\n "]}
1
+ {"version":3,"file":"menu-styles.css.js","sourceRoot":"","sources":["menu-styles.css.ts"],"names":[],"mappings":"AAAA;;;;IAII;AACH,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAC;AACxB,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;CACzB,CAAC","sourcesContent":["/**\n * @license\n * Copyright 2022 Google LLC\n * SPDX-License-Identifier: Apache-2.0\n */\n import {css} from 'lit';\n export const styles = css`:host{--_cascading-menu-indicator-icon-color: var(--md-menu-cascading-menu-indicator-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_cascading-menu-indicator-icon-size: var(--md-menu-cascading-menu-indicator-icon-size, 24px);--_container-color: var(--md-menu-container-color, var(--md-sys-color-surface, #fffbfe));--_container-elevation: var(--md-menu-container-elevation, 3);--_container-shadow-color: var(--md-menu-container-shadow-color, var(--md-sys-color-shadow, #000));--_container-shape: var(--md-menu-container-shape, 4px);--_container-surface-tint-layer-color: var(--md-menu-container-surface-tint-layer-color, var(--md-sys-color-primary, #6750a4));--_list-item-container-height: var(--md-menu-list-item-container-height, 48px);--_list-item-disabled-label-text-color: var(--md-menu-list-item-disabled-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-disabled-label-text-opacity: var(--md-menu-list-item-disabled-label-text-opacity, 0.38);--_list-item-focus-label-text-color: var(--md-menu-list-item-focus-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-color: var(--md-menu-list-item-focus-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-focus-state-layer-opacity: var(--md-menu-list-item-focus-state-layer-opacity, 0.12);--_list-item-hover-label-text-color: var(--md-menu-list-item-hover-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-color: var(--md-menu-list-item-hover-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-hover-state-layer-opacity: var(--md-menu-list-item-hover-state-layer-opacity, 0.08);--_list-item-label-text-color: var(--md-menu-list-item-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-label-text-font: var(--md-menu-list-item-label-text-font, Roboto);--_list-item-label-text-line-height: var(--md-menu-list-item-label-text-line-height, 1.25rem);--_list-item-label-text-size: var(--md-menu-list-item-label-text-size, 0.875rem);--_list-item-label-text-tracking: var(--md-menu-list-item-label-text-tracking, 0.006rem);--_list-item-label-text-type: var(--md-menu-list-item-label-text-type, 500 0.875rem / 1.25rem Roboto);--_list-item-label-text-weight: var(--md-menu-list-item-label-text-weight, 500);--_list-item-pressed-label-text-color: var(--md-menu-list-item-pressed-label-text-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-color: var(--md-menu-list-item-pressed-state-layer-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-pressed-state-layer-opacity: var(--md-menu-list-item-pressed-state-layer-opacity, 0.12);--_list-item-selected-container-color: var(--md-menu-list-item-selected-container-color, var(--md-sys-color-surface-variant, #e7e0ec));--_list-item-with-leading-icon-disabled-leading-icon-color: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-leading-icon-disabled-leading-icon-opacity: var(--md-menu-list-item-with-leading-icon-disabled-leading-icon-opacity, 0.38);--_list-item-with-leading-icon-focus-icon-color: var(--md-menu-list-item-with-leading-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-hover-icon-color: var(--md-menu-list-item-with-leading-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-color: var(--md-menu-list-item-with-leading-icon-leading-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-leading-icon-leading-icon-size: var(--md-menu-list-item-with-leading-icon-leading-icon-size, 24px);--_list-item-with-leading-icon-pressed-icon-color: var(--md-menu-list-item-with-leading-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-disabled-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-color, var(--md-sys-color-on-surface, #1c1b1f));--_list-item-with-trailing-icon-disabled-trailing-icon-opacity: var(--md-menu-list-item-with-trailing-icon-disabled-trailing-icon-opacity, 0.38);--_list-item-with-trailing-icon-focus-icon-color: var(--md-menu-list-item-with-trailing-icon-focus-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-hover-icon-color: var(--md-menu-list-item-with-trailing-icon-hover-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-pressed-icon-color: var(--md-menu-list-item-with-trailing-icon-pressed-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-color: var(--md-menu-list-item-with-trailing-icon-trailing-icon-color, var(--md-sys-color-on-surface-variant, #49454f));--_list-item-with-trailing-icon-trailing-icon-size: var(--md-menu-list-item-with-trailing-icon-trailing-icon-size, 24px);--md-elevation-level:var(--_container-elevation);--md-elevation-shadow-color:var(--_container-shadow-color);--md-elevation-surface-tint:var(--_container-surface-tint-layer-color);--md-focus-ring-shape-start-start:var(--_container-shape);--md-focus-ring-shape-start-end:var(--_container-shape);--md-focus-ring-shape-end-end:var(--_container-shape);--md-focus-ring-shape-end-start:var(--_container-shape)}.menu{border-radius:var(--_container-shape);display:none;opacity:0;z-index:20;position:absolute;user-select:none;max-height:inherit;height:inherit}.menu.fixed{position:fixed}.menu md-list{height:inherit;max-height:inherit;display:block;overflow:auto}.menu.has-overflow md-list{overflow:visible}.menu.animating md-list{pointer-events:none;overflow:hidden}.menu.animating ::slotted(.hidden){opacity:0}.menu slot{display:block;height:inherit;max-height:inherit}md-elevation{position:absolute;inset:0;pointer-events:none}/*# sourceMappingURL=menu-styles.css.map */\n`;\n "]}
@@ -4,59 +4,193 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import '../../list/list.js';
7
- import '../../menusurface/menu-surface.js';
7
+ import '../../focus/focus-ring.js';
8
+ import '../../elevation/elevation.js';
8
9
  import { LitElement } from 'lit';
10
+ import { MdFocusRing } from '../../focus/focus-ring.js';
9
11
  import { List } from '../../list/lib/list.js';
10
- import { ListItem } from '../../list/lib/listitem/list-item.js';
11
- import { Corner, MenuSurface } from '../../menusurface/lib/menu-surface.js';
12
- import { MDCMenuAdapter } from './adapter.js';
13
- import { MDCMenuFoundation } from './foundation.js';
14
- interface ActionDetail {
15
- item: ListItem;
16
- }
17
- /** Element to focus on when menu is first opened. */
12
+ import { MenuItem } from './shared.js';
13
+ import { Corner, SurfacePositionController } from './surfacePositionController.js';
14
+ import { TypeaheadController } from './typeaheadController.js';
15
+ export { Corner } from './surfacePositionController.js';
16
+ /**
17
+ * Element to focus on when menu is first opened.
18
+ */
18
19
  export declare type DefaultFocusState = 'NONE' | 'LIST_ROOT' | 'FIRST_ITEM' | 'LAST_ITEM';
19
20
  /**
20
- * @fires selected {SelectedDetail}
21
- * @fires action {ActionDetail}
22
- * @fires items-updated
23
- * @fires opened
24
- * @fires closed
21
+ * @fires opening Fired before the opening animation begins (not fired on quick)
22
+ * @fires opened Fired once the menu is open, after any animations
23
+ * @fires closing Fired before the closing animation begins (not fired on quick)
24
+ * @fires closed Fired once the menu is closed, after any animations
25
25
  */
26
26
  export declare abstract class Menu extends LitElement {
27
- protected mdcFoundation: MDCMenuFoundation;
28
- protected listElementInternal: List | null;
29
- mdcRoot: MenuSurface;
30
- slotElement: HTMLSlotElement | null;
31
- anchor: HTMLElement | null;
27
+ protected readonly listElement: List | null;
28
+ protected readonly surfaceEl: HTMLElement | null;
29
+ protected readonly slotEl: HTMLSlotElement | null;
30
+ protected readonly focusRing: MdFocusRing;
32
31
  ariaLabel: string;
33
- open: boolean;
34
- quick: boolean;
35
- corner: Corner;
36
- x: number | null;
37
- y: number | null;
38
- absolute: boolean;
39
- activatable: boolean;
32
+ /**
33
+ * The element in which the menu should align to.
34
+ */
35
+ anchor: HTMLElement | null;
36
+ /**
37
+ * Makes the element use `position:fixed` instead of `position:absolute`. In
38
+ * most cases, the menu should position itself above most other
39
+ * `position:absolute` or `position:fixed` elements when placed inside of
40
+ * them. e.g. using a menu inside of an `md-dialog`.
41
+ *
42
+ * __NOTE__: Fixed menus will not scroll with the page and will be fixed to
43
+ * the window instead.
44
+ */
40
45
  fixed: boolean;
41
- forceGroupSelection: boolean;
42
- fullwidth: boolean;
43
- flipMenuHorizontally: boolean;
44
- stayOpenOnBodyClick: boolean;
46
+ /**
47
+ * Skips the opening and closing animations.
48
+ */
49
+ quick: boolean;
50
+ /**
51
+ * Displays overflow content like a submenu.
52
+ *
53
+ * __NOTE__: This may cause adverse effects if you set
54
+ * `md-menu {max-height:...}`
55
+ * and have items overflowing items in the "y" direction.
56
+ */
57
+ hasOverflow: boolean;
58
+ /**
59
+ * Opens the menu and makes it visible. Alternative to the `.show()` and
60
+ * `.close()` methods
61
+ */
62
+ open: boolean;
63
+ /**
64
+ * Offsets the menu's inline alignment from the anchor by the given number in
65
+ * pixels. This value is direction aware and will follow the LTR / RTL
66
+ * direction.
67
+ *
68
+ * e.g. LTR: positive -> right, negative -> left
69
+ * RTL: positive -> left, negative -> right
70
+ */
71
+ xOffset: number;
72
+ /**
73
+ * Offsets the menu's block alignment from the anchor by the given number in
74
+ * pixels.
75
+ *
76
+ * e.g. positive -> down, negative -> up
77
+ */
78
+ yOffset: number;
79
+ /**
80
+ * The tabindex of the underlying list element.
81
+ */
82
+ listTabIndex: number;
83
+ /**
84
+ * The max time between the keystrokes of the typeahead menu behavior before
85
+ * it clears the typeahead buffer.
86
+ */
87
+ typeaheadBufferTime: number;
88
+ /**
89
+ * The corner of the anchor which to align the menu in the standard logical
90
+ * property style of <block>_<inline>.
91
+ */
92
+ anchorCorner: Corner;
93
+ /**
94
+ * The corner of the menu which to align the anchor in the standard logical
95
+ * property style of <block>_<inline>.
96
+ */
97
+ menuCorner: Corner;
98
+ /**
99
+ * Keeps the user clicks outside the menu
100
+ */
101
+ stayOpenOnOutsideClick: boolean;
102
+ /**
103
+ * After closing, does not restore focus to the last focused element before
104
+ * the menu was opened.
105
+ */
45
106
  skipRestoreFocus: boolean;
107
+ /**
108
+ * The element that should be focused by default once opened.
109
+ */
46
110
  defaultFocus: DefaultFocusState;
47
- protected listUpdateComplete: null | Promise<unknown>;
48
- protected get listElement(): List;
49
- get items(): ListItem[];
111
+ protected openCloseAnimationSignal: import("../../motion/animation.js").AnimationSignal;
112
+ /**
113
+ * Whether the menu is animating upwards or downwards when opening. This is
114
+ * helpful for calculating some animation calculations.
115
+ */
116
+ protected get openDirection(): 'UP' | 'DOWN';
117
+ /**
118
+ * The element that was focused before the menu opened.
119
+ */
120
+ protected lastFocusedElement: HTMLElement | null;
121
+ /**
122
+ * Handles typeahead navigation through the menu.
123
+ */
124
+ protected typeaheadController: TypeaheadController;
125
+ /**
126
+ * Handles positioning the surface and aligning it to the anchor.
127
+ */
128
+ protected menuPositionController: SurfacePositionController;
129
+ /**
130
+ * The menu items associated with this menu. The items must be `MenuItem`s and
131
+ * have both the `md-menu-item` and `md-list-item` attributes.
132
+ */
133
+ get items(): MenuItem[];
50
134
  render(): import("lit-html").TemplateResult<1>;
51
- protected getMenuItemTagName(): string;
52
- protected createAdapter(): MDCMenuAdapter;
53
- protected onKeydown(evt: KeyboardEvent): void;
54
- protected onAction(evt: CustomEvent<ActionDetail>): void;
55
- protected onOpened(): void;
56
- protected onClosed(): void;
57
- protected getUpdateComplete(): Promise<boolean>;
58
- protected firstUpdated(): Promise<void>;
135
+ /**
136
+ * Renders the positionable surface element and its contents.
137
+ */
138
+ protected renderSurface(): import("lit-html").TemplateResult<1>;
139
+ /**
140
+ * Renders the List element and its items
141
+ */
142
+ protected renderList(): import("lit-html").TemplateResult<1>;
143
+ /**
144
+ * Renders the menu items' slot
145
+ */
146
+ protected renderMenuItems(): import("lit-html").TemplateResult<1>;
147
+ /**
148
+ * Renders the elevation component.
149
+ */
150
+ protected renderElevation(): import("lit-html").TemplateResult<1>;
151
+ /**
152
+ * Renders the focus ring component.
153
+ */
154
+ protected renderFocusRing(): import("lit-html").TemplateResult<1>;
155
+ protected getSurfaceClasses(): {
156
+ open: boolean;
157
+ fixed: boolean;
158
+ 'has-overflow': boolean;
159
+ };
160
+ protected onListFocus(): void;
161
+ protected onListClick(): void;
162
+ protected onListBlur(): void;
163
+ /**
164
+ * Saves the last focused element focuses the new element based on
165
+ * `defaultFocus`, and animates open.
166
+ */
167
+ protected onOpened: () => void;
168
+ /**
169
+ * Animates closed.
170
+ */
171
+ protected beforeClose: () => Promise<void>;
172
+ /**
173
+ * Focuses the last focused element.
174
+ */
175
+ protected onClosed: () => void;
176
+ /**
177
+ * Performs the opening animation:
178
+ *
179
+ * https://direct.googleplex.com/#/spec/295000003+271060003
180
+ */
181
+ protected animateOpen(): void;
182
+ /**
183
+ * Performs the closing animation:
184
+ *
185
+ * https://direct.googleplex.com/#/spec/295000003+271060003
186
+ */
187
+ protected animateClose(): Promise<unknown>;
188
+ connectedCallback(): void;
189
+ disconnectedCallback(): void;
190
+ protected onWindowClick: (e: MouseEvent) => void;
191
+ protected onCloseMenu(e: Event): void;
192
+ protected onDeactivateItems(e: Event): void;
193
+ focus(): void;
59
194
  close(): void;
60
195
  show(): void;
61
196
  }
62
- export {};