@universal-material/web 3.0.140 → 3.0.141

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 (915) hide show
  1. package/app-bar/top-app-bar.d.ts +47 -0
  2. package/app-bar/top-app-bar.d.ts.map +1 -0
  3. package/app-bar/top-app-bar.js +174 -0
  4. package/app-bar/top-app-bar.js.map +1 -0
  5. package/app-bar/top-app-bar.styles.d.ts +2 -0
  6. package/app-bar/top-app-bar.styles.d.ts.map +1 -0
  7. package/app-bar/top-app-bar.styles.js +117 -0
  8. package/app-bar/top-app-bar.styles.js.map +1 -0
  9. package/button/button-base.d.ts +12 -0
  10. package/button/button-base.d.ts.map +1 -0
  11. package/button/button-base.js +46 -0
  12. package/button/button-base.js.map +1 -0
  13. package/button/button-base.styles.d.ts +2 -0
  14. package/button/button-base.styles.d.ts.map +1 -0
  15. package/button/button-base.styles.js +16 -0
  16. package/button/button-base.styles.js.map +1 -0
  17. package/button/button-set.d.ts +15 -0
  18. package/button/button-set.d.ts.map +1 -0
  19. package/button/button-set.js +23 -0
  20. package/button/button-set.js.map +1 -0
  21. package/button/button-set.styles.d.ts +2 -0
  22. package/button/button-set.styles.d.ts.map +1 -0
  23. package/button/button-set.styles.js +20 -0
  24. package/button/button-set.styles.js.map +1 -0
  25. package/button/button.d.ts +33 -0
  26. package/button/button.d.ts.map +1 -0
  27. package/button/button.js +55 -0
  28. package/button/button.js.map +1 -0
  29. package/button/button.styles.d.ts +2 -0
  30. package/button/button.styles.d.ts.map +1 -0
  31. package/button/button.styles.js +103 -0
  32. package/button/button.styles.js.map +1 -0
  33. package/button/fab.d.ts +31 -0
  34. package/button/fab.d.ts.map +1 -0
  35. package/button/fab.js +57 -0
  36. package/button/fab.js.map +1 -0
  37. package/button/fab.styles.d.ts +2 -0
  38. package/button/fab.styles.d.ts.map +1 -0
  39. package/button/fab.styles.js +89 -0
  40. package/button/fab.styles.js.map +1 -0
  41. package/button/icon-button.d.ts +34 -0
  42. package/button/icon-button.d.ts.map +1 -0
  43. package/button/icon-button.js +75 -0
  44. package/button/icon-button.js.map +1 -0
  45. package/button/icon-button.styles.d.ts +2 -0
  46. package/button/icon-button.styles.d.ts.map +1 -0
  47. package/button/icon-button.styles.js +77 -0
  48. package/button/icon-button.styles.js.map +1 -0
  49. package/button-field/button-field.d.ts +18 -0
  50. package/button-field/button-field.d.ts.map +1 -0
  51. package/button-field/button-field.js +54 -0
  52. package/button-field/button-field.js.map +1 -0
  53. package/button-field/button-field.styles.d.ts +2 -0
  54. package/button-field/button-field.styles.d.ts.map +1 -0
  55. package/button-field/button-field.styles.js +17 -0
  56. package/button-field/button-field.styles.js.map +1 -0
  57. package/calendar/calendar-adapter.d.ts +6 -0
  58. package/calendar/calendar-adapter.d.ts.map +1 -0
  59. package/calendar/calendar-adapter.js +2 -0
  60. package/calendar/calendar-adapter.js.map +1 -0
  61. package/calendar/calendar-base.d.ts +30 -0
  62. package/calendar/calendar-base.d.ts.map +1 -0
  63. package/calendar/calendar-base.js +188 -0
  64. package/calendar/calendar-base.js.map +1 -0
  65. package/calendar/calendar-base.styles.d.ts +2 -0
  66. package/calendar/calendar-base.styles.d.ts.map +1 -0
  67. package/calendar/calendar-base.styles.js +81 -0
  68. package/calendar/calendar-base.styles.js.map +1 -0
  69. package/calendar/calendar.d.ts +11 -0
  70. package/calendar/calendar.d.ts.map +1 -0
  71. package/calendar/calendar.js +43 -0
  72. package/calendar/calendar.js.map +1 -0
  73. package/calendar/calendar.styles.d.ts +2 -0
  74. package/calendar/calendar.styles.d.ts.map +1 -0
  75. package/calendar/calendar.styles.js +5 -0
  76. package/calendar/calendar.styles.js.map +1 -0
  77. package/calendar/default-calendar-adapter.d.ts +10 -0
  78. package/calendar/default-calendar-adapter.d.ts.map +1 -0
  79. package/calendar/default-calendar-adapter.js +32 -0
  80. package/calendar/default-calendar-adapter.js.map +1 -0
  81. package/calendar/range-calendar.d.ts +16 -0
  82. package/calendar/range-calendar.d.ts.map +1 -0
  83. package/calendar/range-calendar.js +113 -0
  84. package/calendar/range-calendar.js.map +1 -0
  85. package/calendar/range-calendar.styles.d.ts +2 -0
  86. package/calendar/range-calendar.styles.d.ts.map +1 -0
  87. package/calendar/range-calendar.styles.js +41 -0
  88. package/calendar/range-calendar.styles.js.map +1 -0
  89. package/card/card-content.d.ts +13 -0
  90. package/card/card-content.d.ts.map +1 -0
  91. package/card/card-content.js +39 -0
  92. package/card/card-content.js.map +1 -0
  93. package/card/card-content.styles.d.ts +2 -0
  94. package/card/card-content.styles.d.ts.map +1 -0
  95. package/card/card-content.styles.js +19 -0
  96. package/card/card-content.styles.js.map +1 -0
  97. package/card/card-media.d.ts +12 -0
  98. package/card/card-media.d.ts.map +1 -0
  99. package/card/card-media.js +24 -0
  100. package/card/card-media.js.map +1 -0
  101. package/card/card-media.styles.d.ts +2 -0
  102. package/card/card-media.styles.d.ts.map +1 -0
  103. package/card/card-media.styles.js +13 -0
  104. package/card/card-media.styles.js.map +1 -0
  105. package/card/card.d.ts +19 -0
  106. package/card/card.d.ts.map +1 -0
  107. package/card/card.js +36 -0
  108. package/card/card.js.map +1 -0
  109. package/card/card.styles.d.ts +2 -0
  110. package/card/card.styles.d.ts.map +1 -0
  111. package/card/card.styles.js +31 -0
  112. package/card/card.styles.js.map +1 -0
  113. package/checkbox/checkbox-list-item.d.ts +11 -0
  114. package/checkbox/checkbox-list-item.d.ts.map +1 -0
  115. package/checkbox/checkbox-list-item.js +11 -0
  116. package/checkbox/checkbox-list-item.js.map +1 -0
  117. package/checkbox/checkbox.d.ts +21 -0
  118. package/checkbox/checkbox.d.ts.map +1 -0
  119. package/checkbox/checkbox.js +53 -0
  120. package/checkbox/checkbox.js.map +1 -0
  121. package/checkbox/checkbox.styles.d.ts +2 -0
  122. package/checkbox/checkbox.styles.d.ts.map +1 -0
  123. package/checkbox/checkbox.styles.js +62 -0
  124. package/checkbox/checkbox.styles.js.map +1 -0
  125. package/chip/chip-set.d.ts +10 -0
  126. package/chip/chip-set.d.ts.map +1 -0
  127. package/chip/chip-set.js +12 -0
  128. package/chip/chip-set.js.map +1 -0
  129. package/chip/chip-set.styles.d.ts +2 -0
  130. package/chip/chip-set.styles.d.ts.map +1 -0
  131. package/chip/chip-set.styles.js +7 -0
  132. package/chip/chip-set.styles.js.map +1 -0
  133. package/chip/chip.d.ts +64 -0
  134. package/chip/chip.d.ts.map +1 -0
  135. package/chip/chip.js +187 -0
  136. package/chip/chip.js.map +1 -0
  137. package/chip/chip.styles.d.ts +2 -0
  138. package/chip/chip.styles.d.ts.map +1 -0
  139. package/chip/chip.styles.js +168 -0
  140. package/chip/chip.styles.js.map +1 -0
  141. package/chip-field/chip-field.d.ts +42 -0
  142. package/chip-field/chip-field.d.ts.map +1 -0
  143. package/chip-field/chip-field.js +145 -0
  144. package/chip-field/chip-field.js.map +1 -0
  145. package/chip-field/chip-field.styles.d.ts +2 -0
  146. package/chip-field/chip-field.styles.d.ts.map +1 -0
  147. package/chip-field/chip-field.styles.js +22 -0
  148. package/chip-field/chip-field.styles.js.map +1 -0
  149. package/config.d.ts +16 -0
  150. package/config.d.ts.map +1 -0
  151. package/config.js +25 -0
  152. package/config.js.map +1 -0
  153. package/custom-elements.json +21401 -0
  154. package/datepicker/datepicker.d.ts +1 -0
  155. package/datepicker/datepicker.d.ts.map +1 -0
  156. package/datepicker/datepicker.js +2 -0
  157. package/datepicker/datepicker.js.map +1 -0
  158. package/datepicker/datepicker.styles.d.ts +2 -0
  159. package/datepicker/datepicker.styles.d.ts.map +1 -0
  160. package/datepicker/datepicker.styles.js +5 -0
  161. package/datepicker/datepicker.styles.js.map +1 -0
  162. package/dialog/confirm-dialog-builder.d.ts +12 -0
  163. package/dialog/confirm-dialog-builder.d.ts.map +1 -0
  164. package/dialog/confirm-dialog-builder.js +26 -0
  165. package/dialog/confirm-dialog-builder.js.map +1 -0
  166. package/dialog/dialog-builder.d.ts +15 -0
  167. package/dialog/dialog-builder.d.ts.map +1 -0
  168. package/dialog/dialog-builder.js +42 -0
  169. package/dialog/dialog-builder.js.map +1 -0
  170. package/dialog/dialog-button-def.d.ts +6 -0
  171. package/dialog/dialog-button-def.d.ts.map +1 -0
  172. package/dialog/dialog-button-def.js +2 -0
  173. package/dialog/dialog-button-def.js.map +1 -0
  174. package/dialog/dialog.d.ts +44 -0
  175. package/dialog/dialog.d.ts.map +1 -0
  176. package/dialog/dialog.js +216 -0
  177. package/dialog/dialog.js.map +1 -0
  178. package/dialog/dialog.styles.d.ts +2 -0
  179. package/dialog/dialog.styles.d.ts.map +1 -0
  180. package/dialog/dialog.styles.js +165 -0
  181. package/dialog/dialog.styles.js.map +1 -0
  182. package/dialog/message-dialog-builder.d.ts +10 -0
  183. package/dialog/message-dialog-builder.d.ts.map +1 -0
  184. package/dialog/message-dialog-builder.js +16 -0
  185. package/dialog/message-dialog-builder.js.map +1 -0
  186. package/elevation/elevation.d.ts +11 -0
  187. package/elevation/elevation.d.ts.map +1 -0
  188. package/elevation/elevation.js +16 -0
  189. package/elevation/elevation.js.map +1 -0
  190. package/elevation/elevation.styles.d.ts +2 -0
  191. package/elevation/elevation.styles.d.ts.map +1 -0
  192. package/elevation/elevation.styles.js +28 -0
  193. package/elevation/elevation.styles.js.map +1 -0
  194. package/field/field-base.d.ts +68 -0
  195. package/field/field-base.d.ts.map +1 -0
  196. package/field/field-base.js +174 -0
  197. package/field/field-base.js.map +1 -0
  198. package/field/field-base.styles.d.ts +2 -0
  199. package/field/field-base.styles.d.ts.map +1 -0
  200. package/field/field-base.styles.js +372 -0
  201. package/field/field-base.styles.js.map +1 -0
  202. package/field/field-defaults-context.d.ts +5 -0
  203. package/field/field-defaults-context.d.ts.map +1 -0
  204. package/field/field-defaults-context.js +3 -0
  205. package/field/field-defaults-context.js.map +1 -0
  206. package/field/field-defaults.d.ts +5 -0
  207. package/field/field-defaults.d.ts.map +1 -0
  208. package/field/field-defaults.js +2 -0
  209. package/field/field-defaults.js.map +1 -0
  210. package/field/field-variant.d.ts +2 -0
  211. package/field/field-variant.d.ts.map +1 -0
  212. package/field/field-variant.js +2 -0
  213. package/field/field-variant.js.map +1 -0
  214. package/field/field.d.ts +15 -0
  215. package/field/field.d.ts.map +1 -0
  216. package/field/field.js +44 -0
  217. package/field/field.js.map +1 -0
  218. package/index.d.ts +80 -0
  219. package/index.d.ts.map +1 -0
  220. package/index.js +80 -0
  221. package/index.js.map +1 -0
  222. package/list/list-item.d.ts +13 -0
  223. package/list/list-item.d.ts.map +1 -0
  224. package/list/list-item.js +38 -0
  225. package/list/list-item.js.map +1 -0
  226. package/list/list-item.styles.d.ts +2 -0
  227. package/list/list-item.styles.d.ts.map +1 -0
  228. package/list/list-item.styles.js +48 -0
  229. package/list/list-item.styles.js.map +1 -0
  230. package/list/list.d.ts +11 -0
  231. package/list/list.d.ts.map +1 -0
  232. package/list/list.js +15 -0
  233. package/list/list.js.map +1 -0
  234. package/list/list.styles.d.ts +2 -0
  235. package/list/list.styles.d.ts.map +1 -0
  236. package/list/list.styles.js +8 -0
  237. package/list/list.styles.js.map +1 -0
  238. package/menu/menu-item.d.ts +40 -0
  239. package/menu/menu-item.d.ts.map +1 -0
  240. package/menu/menu-item.js +98 -0
  241. package/menu/menu-item.js.map +1 -0
  242. package/menu/menu-item.styles.d.ts +2 -0
  243. package/menu/menu-item.styles.d.ts.map +1 -0
  244. package/menu/menu-item.styles.js +54 -0
  245. package/menu/menu-item.styles.js.map +1 -0
  246. package/menu/menu.d.ts +48 -0
  247. package/menu/menu.d.ts.map +1 -0
  248. package/menu/menu.js +328 -0
  249. package/menu/menu.js.map +1 -0
  250. package/menu/menu.styles.d.ts +2 -0
  251. package/menu/menu.styles.d.ts.map +1 -0
  252. package/menu/menu.styles.js +69 -0
  253. package/menu/menu.styles.js.map +1 -0
  254. package/navigation/drawer-item.d.ts +40 -0
  255. package/navigation/drawer-item.d.ts.map +1 -0
  256. package/navigation/drawer-item.js +94 -0
  257. package/navigation/drawer-item.js.map +1 -0
  258. package/navigation/drawer-item.styles.d.ts +2 -0
  259. package/navigation/drawer-item.styles.d.ts.map +1 -0
  260. package/navigation/drawer-item.styles.js +52 -0
  261. package/navigation/drawer-item.styles.js.map +1 -0
  262. package/navigation/drawer.d.ts +11 -0
  263. package/navigation/drawer.d.ts.map +1 -0
  264. package/navigation/drawer.js +23 -0
  265. package/navigation/drawer.js.map +1 -0
  266. package/navigation/drawer.styles.d.ts +2 -0
  267. package/navigation/drawer.styles.d.ts.map +1 -0
  268. package/navigation/drawer.styles.js +22 -0
  269. package/navigation/drawer.styles.js.map +1 -0
  270. package/navigation/side-navigation-swiper.styles.d.ts +2 -0
  271. package/navigation/side-navigation-swiper.styles.d.ts.map +1 -0
  272. package/navigation/side-navigation-swiper.styles.js +131 -0
  273. package/navigation/side-navigation-swiper.styles.js.map +1 -0
  274. package/navigation/side-navigation.d.ts +33 -0
  275. package/navigation/side-navigation.d.ts.map +1 -0
  276. package/navigation/side-navigation.js +138 -0
  277. package/navigation/side-navigation.js.map +1 -0
  278. package/navigation/side-navigation.styles.d.ts +2 -0
  279. package/navigation/side-navigation.styles.d.ts.map +1 -0
  280. package/navigation/side-navigation.styles.js +124 -0
  281. package/navigation/side-navigation.styles.js.map +1 -0
  282. package/package.json +1 -1
  283. package/progress/circular-progress.d.ts +14 -0
  284. package/progress/circular-progress.d.ts.map +1 -0
  285. package/progress/circular-progress.js +80 -0
  286. package/progress/circular-progress.js.map +1 -0
  287. package/progress/circular-progress.styles.d.ts +2 -0
  288. package/progress/circular-progress.styles.d.ts.map +1 -0
  289. package/progress/circular-progress.styles.js +75 -0
  290. package/progress/circular-progress.styles.js.map +1 -0
  291. package/progress/progress-bar.d.ts +14 -0
  292. package/progress/progress-bar.d.ts.map +1 -0
  293. package/progress/progress-bar.js +49 -0
  294. package/progress/progress-bar.js.map +1 -0
  295. package/progress/progress-bar.styles.d.ts +2 -0
  296. package/progress/progress-bar.styles.d.ts.map +1 -0
  297. package/progress/progress-bar.styles.js +152 -0
  298. package/progress/progress-bar.styles.js.map +1 -0
  299. package/radio/radio-list-item.d.ts +11 -0
  300. package/radio/radio-list-item.d.ts.map +1 -0
  301. package/radio/radio-list-item.js +11 -0
  302. package/radio/radio-list-item.js.map +1 -0
  303. package/radio/radio.d.ts +24 -0
  304. package/radio/radio.d.ts.map +1 -0
  305. package/radio/radio.js +125 -0
  306. package/radio/radio.js.map +1 -0
  307. package/radio/radio.styles.d.ts +2 -0
  308. package/radio/radio.styles.d.ts.map +1 -0
  309. package/radio/radio.styles.js +33 -0
  310. package/radio/radio.styles.js.map +1 -0
  311. package/ripple/ripple.d.ts +28 -0
  312. package/ripple/ripple.d.ts.map +1 -0
  313. package/ripple/ripple.js +120 -0
  314. package/ripple/ripple.js.map +1 -0
  315. package/ripple/ripple.styles.d.ts +2 -0
  316. package/ripple/ripple.styles.d.ts.map +1 -0
  317. package/ripple/ripple.styles.js +74 -0
  318. package/ripple/ripple.styles.js.map +1 -0
  319. package/select/extended-option.d.ts +5 -0
  320. package/select/extended-option.d.ts.map +1 -0
  321. package/select/extended-option.js +2 -0
  322. package/select/extended-option.js.map +1 -0
  323. package/select/extended-select.d.ts +6 -0
  324. package/select/extended-select.d.ts.map +1 -0
  325. package/select/extended-select.js +2 -0
  326. package/select/extended-select.js.map +1 -0
  327. package/select/option.d.ts +27 -0
  328. package/select/option.d.ts.map +1 -0
  329. package/select/option.js +132 -0
  330. package/select/option.js.map +1 -0
  331. package/select/option.styles.d.ts +2 -0
  332. package/select/option.styles.d.ts.map +1 -0
  333. package/select/option.styles.js +15 -0
  334. package/select/option.styles.js.map +1 -0
  335. package/select/select-navigation-controller.d.ts +14 -0
  336. package/select/select-navigation-controller.d.ts.map +1 -0
  337. package/select/select-navigation-controller.js +82 -0
  338. package/select/select-navigation-controller.js.map +1 -0
  339. package/select/select.d.ts +47 -0
  340. package/select/select.d.ts.map +1 -0
  341. package/select/select.js +268 -0
  342. package/select/select.js.map +1 -0
  343. package/select/select.styles.d.ts +2 -0
  344. package/select/select.styles.d.ts.map +1 -0
  345. package/select/select.styles.js +39 -0
  346. package/select/select.styles.js.map +1 -0
  347. package/shared/base.styles.d.ts +2 -0
  348. package/shared/base.styles.d.ts.map +1 -0
  349. package/shared/base.styles.js +31 -0
  350. package/shared/base.styles.js.map +1 -0
  351. package/shared/button-wrapper.d.ts +39 -0
  352. package/shared/button-wrapper.d.ts.map +1 -0
  353. package/shared/button-wrapper.js +123 -0
  354. package/shared/button-wrapper.js.map +1 -0
  355. package/shared/button-wrapper.styles.d.ts +2 -0
  356. package/shared/button-wrapper.styles.d.ts.map +1 -0
  357. package/shared/button-wrapper.styles.js +63 -0
  358. package/shared/button-wrapper.styles.js.map +1 -0
  359. package/shared/char-count-text-field/native-text-field-wrapper.d.ts +15 -0
  360. package/shared/char-count-text-field/native-text-field-wrapper.d.ts.map +1 -0
  361. package/shared/char-count-text-field/native-text-field-wrapper.js +54 -0
  362. package/shared/char-count-text-field/native-text-field-wrapper.js.map +1 -0
  363. package/shared/compare-text.d.ts +2 -0
  364. package/shared/compare-text.d.ts.map +1 -0
  365. package/shared/compare-text.js +5 -0
  366. package/shared/compare-text.js.map +1 -0
  367. package/shared/events/dispatch-event.d.ts +1 -0
  368. package/shared/events/dispatch-event.d.ts.map +1 -0
  369. package/shared/events/dispatch-event.js +2 -0
  370. package/shared/events/dispatch-event.js.map +1 -0
  371. package/shared/events/redispatch-event.d.ts +2 -0
  372. package/shared/events/redispatch-event.d.ts.map +1 -0
  373. package/shared/events/redispatch-event.js +14 -0
  374. package/shared/events/redispatch-event.js.map +1 -0
  375. package/shared/extract-template-html.d.ts +2 -0
  376. package/shared/extract-template-html.d.ts.map +1 -0
  377. package/shared/extract-template-html.js +8 -0
  378. package/shared/extract-template-html.js.map +1 -0
  379. package/shared/menu-field/menu-field-navigation-controller.d.ts +20 -0
  380. package/shared/menu-field/menu-field-navigation-controller.d.ts.map +1 -0
  381. package/shared/menu-field/menu-field-navigation-controller.js +108 -0
  382. package/shared/menu-field/menu-field-navigation-controller.js.map +1 -0
  383. package/shared/menu-field/menu-field.d.ts +7 -0
  384. package/shared/menu-field/menu-field.d.ts.map +1 -0
  385. package/shared/menu-field/menu-field.js +2 -0
  386. package/shared/menu-field/menu-field.js.map +1 -0
  387. package/shared/mixin-attribute-properties.d.ts +4 -0
  388. package/shared/mixin-attribute-properties.d.ts.map +1 -0
  389. package/shared/mixin-attribute-properties.js +27 -0
  390. package/shared/mixin-attribute-properties.js.map +1 -0
  391. package/shared/mixin.d.ts +3 -0
  392. package/shared/mixin.d.ts.map +1 -0
  393. package/shared/mixin.js +2 -0
  394. package/shared/mixin.js.map +1 -0
  395. package/shared/normalize-text.d.ts +2 -0
  396. package/shared/normalize-text.d.ts.map +1 -0
  397. package/shared/normalize-text.js +9 -0
  398. package/shared/normalize-text.js.map +1 -0
  399. package/shared/selection-control/checkbox-base.d.ts +1 -0
  400. package/shared/selection-control/checkbox-base.d.ts.map +1 -0
  401. package/shared/selection-control/checkbox-base.js +7 -0
  402. package/shared/selection-control/checkbox-base.js.map +1 -0
  403. package/shared/selection-control/selection-control-list-item.d.ts +4 -0
  404. package/shared/selection-control/selection-control-list-item.d.ts.map +1 -0
  405. package/shared/selection-control/selection-control-list-item.js +44 -0
  406. package/shared/selection-control/selection-control-list-item.js.map +1 -0
  407. package/shared/selection-control/selection-control.d.ts +36 -0
  408. package/shared/selection-control/selection-control.d.ts.map +1 -0
  409. package/shared/selection-control/selection-control.js +155 -0
  410. package/shared/selection-control/selection-control.js.map +1 -0
  411. package/shared/selection-control/selection-control.styles.d.ts +2 -0
  412. package/shared/selection-control/selection-control.styles.d.ts.map +1 -0
  413. package/shared/selection-control/selection-control.styles.js +67 -0
  414. package/shared/selection-control/selection-control.styles.js.map +1 -0
  415. package/shared/sets/set-base.d.ts +11 -0
  416. package/shared/sets/set-base.d.ts.map +1 -0
  417. package/shared/sets/set-base.js +22 -0
  418. package/shared/sets/set-base.js.map +1 -0
  419. package/shared/sets/set-base.styles.d.ts +2 -0
  420. package/shared/sets/set-base.styles.d.ts.map +1 -0
  421. package/shared/sets/set-base.styles.js +22 -0
  422. package/shared/sets/set-base.styles.js.map +1 -0
  423. package/shared/text-field-base/text-field-base.d.ts +16 -0
  424. package/shared/text-field-base/text-field-base.d.ts.map +1 -0
  425. package/shared/text-field-base/text-field-base.js +29 -0
  426. package/shared/text-field-base/text-field-base.js.map +1 -0
  427. package/shared/text-field-base/text-field-base.styles.d.ts +2 -0
  428. package/shared/text-field-base/text-field-base.styles.d.ts.map +1 -0
  429. package/shared/text-field-base/text-field-base.styles.js +11 -0
  430. package/shared/text-field-base/text-field-base.styles.js.map +1 -0
  431. package/snackbar/snackbar.d.ts +40 -0
  432. package/snackbar/snackbar.d.ts.map +1 -0
  433. package/snackbar/snackbar.js +133 -0
  434. package/snackbar/snackbar.js.map +1 -0
  435. package/snackbar/snackbar.styles.d.ts +2 -0
  436. package/snackbar/snackbar.styles.d.ts.map +1 -0
  437. package/snackbar/snackbar.styles.js +81 -0
  438. package/snackbar/snackbar.styles.js.map +1 -0
  439. package/switch/switch-list-item.d.ts +11 -0
  440. package/switch/switch-list-item.d.ts.map +1 -0
  441. package/switch/switch-list-item.js +11 -0
  442. package/switch/switch-list-item.js.map +1 -0
  443. package/switch/switch.d.ts +14 -0
  444. package/switch/switch.d.ts.map +1 -0
  445. package/switch/switch.js +26 -0
  446. package/switch/switch.js.map +1 -0
  447. package/switch/switch.styles.d.ts +2 -0
  448. package/switch/switch.styles.d.ts.map +1 -0
  449. package/switch/switch.styles.js +78 -0
  450. package/switch/switch.styles.js.map +1 -0
  451. package/tab-bar/tab-bar.d.ts +28 -0
  452. package/tab-bar/tab-bar.d.ts.map +1 -0
  453. package/tab-bar/tab-bar.js +200 -0
  454. package/tab-bar/tab-bar.js.map +1 -0
  455. package/tab-bar/tab-bar.styles.d.ts +2 -0
  456. package/tab-bar/tab-bar.styles.d.ts.map +1 -0
  457. package/tab-bar/tab-bar.styles.js +72 -0
  458. package/tab-bar/tab-bar.styles.js.map +1 -0
  459. package/tab-bar/tab.d.ts +22 -0
  460. package/tab-bar/tab.d.ts.map +1 -0
  461. package/tab-bar/tab.js +91 -0
  462. package/tab-bar/tab.js.map +1 -0
  463. package/tab-bar/tab.styles.d.ts +2 -0
  464. package/tab-bar/tab.styles.d.ts.map +1 -0
  465. package/tab-bar/tab.styles.js +56 -0
  466. package/tab-bar/tab.styles.js.map +1 -0
  467. package/text-area/text-area.d.ts +15 -0
  468. package/text-area/text-area.d.ts.map +1 -0
  469. package/text-area/text-area.js +46 -0
  470. package/text-area/text-area.js.map +1 -0
  471. package/text-area/text-area.styles.d.ts +2 -0
  472. package/text-area/text-area.styles.d.ts.map +1 -0
  473. package/text-area/text-area.styles.js +39 -0
  474. package/text-area/text-area.styles.js.map +1 -0
  475. package/text-field/text-field.d.ts +19 -0
  476. package/text-field/text-field.d.ts.map +1 -0
  477. package/text-field/text-field.js +66 -0
  478. package/text-field/text-field.js.map +1 -0
  479. package/text-field/text-field.styles.d.ts +2 -0
  480. package/text-field/text-field.styles.d.ts.map +1 -0
  481. package/text-field/text-field.styles.js +41 -0
  482. package/text-field/text-field.styles.js.map +1 -0
  483. package/theme/color.d.ts +7 -0
  484. package/theme/color.d.ts.map +1 -0
  485. package/theme/color.js +2 -0
  486. package/theme/color.js.map +1 -0
  487. package/theme/css-var-builder.d.ts +10 -0
  488. package/theme/css-var-builder.d.ts.map +1 -0
  489. package/theme/css-var-builder.js +27 -0
  490. package/theme/css-var-builder.js.map +1 -0
  491. package/theme/index.d.ts +2 -0
  492. package/theme/index.d.ts.map +1 -0
  493. package/theme/index.js +2 -0
  494. package/theme/index.js.map +1 -0
  495. package/theme/neutral-colors.d.ts +4 -0
  496. package/theme/neutral-colors.d.ts.map +1 -0
  497. package/theme/neutral-colors.js +24 -0
  498. package/theme/neutral-colors.js.map +1 -0
  499. package/theme/theme-builder.d.ts +26 -0
  500. package/theme/theme-builder.d.ts.map +1 -0
  501. package/theme/theme-builder.js +146 -0
  502. package/theme/theme-builder.js.map +1 -0
  503. package/theme/theme-color.d.ts +6 -0
  504. package/theme/theme-color.d.ts.map +1 -0
  505. package/theme/theme-color.js +2 -0
  506. package/theme/theme-color.js.map +1 -0
  507. package/typeahead/highlight.d.ts +24 -0
  508. package/typeahead/highlight.d.ts.map +1 -0
  509. package/typeahead/highlight.js +69 -0
  510. package/typeahead/highlight.js.map +1 -0
  511. package/typeahead/highlight.styles.d.ts +2 -0
  512. package/typeahead/highlight.styles.d.ts.map +1 -0
  513. package/typeahead/highlight.styles.js +7 -0
  514. package/typeahead/highlight.styles.js.map +1 -0
  515. package/typeahead/typeahead.d.ts +94 -0
  516. package/typeahead/typeahead.d.ts.map +1 -0
  517. package/typeahead/typeahead.js +362 -0
  518. package/typeahead/typeahead.js.map +1 -0
  519. package/typeahead/typeahead.styles.d.ts +2 -0
  520. package/typeahead/typeahead.styles.d.ts.map +1 -0
  521. package/typeahead/typeahead.styles.js +11 -0
  522. package/typeahead/typeahead.styles.js.map +1 -0
  523. package/.editorconfig +0 -8
  524. package/.eleventy.cjs +0 -21
  525. package/.vscode/extensions.json +0 -9
  526. package/CHANGELOG.md +0 -98
  527. package/LICENSE +0 -28
  528. package/add-custom-elements-schemas.cjs +0 -75
  529. package/change-compiler-to-add-custom-elements.js +0 -26
  530. package/change-schematics-to-generate-pug.js +0 -32
  531. package/docs/angular.json +0 -110
  532. package/docs/src/app/app.component.pug +0 -199
  533. package/docs/src/app/app.component.scss +0 -109
  534. package/docs/src/app/app.component.ts +0 -158
  535. package/docs/src/app/app.config.ts +0 -26
  536. package/docs/src/app/app.routes.ts +0 -140
  537. package/docs/src/app/components/button-set/button-set.component.pug +0 -13
  538. package/docs/src/app/components/button-set/button-set.component.scss +0 -0
  539. package/docs/src/app/components/button-set/button-set.component.ts +0 -29
  540. package/docs/src/app/components/button-set/examples/alignment.html +0 -29
  541. package/docs/src/app/components/button-set/examples/stack.html +0 -5
  542. package/docs/src/app/components/button-set/examples/usage.html +0 -35
  543. package/docs/src/app/components/cards/cards.component.pug +0 -15
  544. package/docs/src/app/components/cards/cards.component.scss +0 -0
  545. package/docs/src/app/components/cards/cards.component.ts +0 -29
  546. package/docs/src/app/components/cards/examples/card-media.html +0 -39
  547. package/docs/src/app/components/cards/examples/card-with-actions.html +0 -40
  548. package/docs/src/app/components/cards/examples/simple-card.html +0 -5
  549. package/docs/src/app/components/checkbox/checkbox.component.pug +0 -5
  550. package/docs/src/app/components/checkbox/checkbox.component.scss +0 -0
  551. package/docs/src/app/components/checkbox/checkbox.component.ts +0 -23
  552. package/docs/src/app/components/checkbox/examples/usage.html +0 -33
  553. package/docs/src/app/components/chip-field/chip-field.component.pug +0 -17
  554. package/docs/src/app/components/chip-field/chip-field.component.scss +0 -0
  555. package/docs/src/app/components/chip-field/chip-field.component.ts +0 -42
  556. package/docs/src/app/components/chip-field/examples/object-values.html +0 -15
  557. package/docs/src/app/components/chip-field/examples/simple.html +0 -1
  558. package/docs/src/app/components/chips/chips.component.pug +0 -69
  559. package/docs/src/app/components/chips/chips.component.scss +0 -0
  560. package/docs/src/app/components/chips/chips.component.ts +0 -131
  561. package/docs/src/app/components/common-buttons/common-buttons.component.pug +0 -23
  562. package/docs/src/app/components/common-buttons/common-buttons.component.scss +0 -0
  563. package/docs/src/app/components/common-buttons/common-buttons.component.ts +0 -35
  564. package/docs/src/app/components/common-buttons/examples/anchor-buttons.html +0 -6
  565. package/docs/src/app/components/common-buttons/examples/buttons-icons.html +0 -24
  566. package/docs/src/app/components/common-buttons/examples/buttons-trailing-icons.html +0 -25
  567. package/docs/src/app/components/common-buttons/examples/buttons-variants.html +0 -6
  568. package/docs/src/app/components/common-buttons/examples/filled-colors.html +0 -4
  569. package/docs/src/app/components/context-test/context-test.component.pug +0 -11
  570. package/docs/src/app/components/context-test/context-test.component.scss +0 -0
  571. package/docs/src/app/components/context-test/context-test.component.ts +0 -23
  572. package/docs/src/app/components/datepicker/datepicker.component.pug +0 -1
  573. package/docs/src/app/components/datepicker/datepicker.component.scss +0 -0
  574. package/docs/src/app/components/datepicker/datepicker.component.ts +0 -20
  575. package/docs/src/app/components/dialogs/dialogs.component.pug +0 -24
  576. package/docs/src/app/components/dialogs/dialogs.component.scss +0 -0
  577. package/docs/src/app/components/dialogs/dialogs.component.ts +0 -33
  578. package/docs/src/app/components/dialogs/examples/example.html +0 -3
  579. package/docs/src/app/components/expansion-panel/expansion-panel.component.pug +0 -1
  580. package/docs/src/app/components/expansion-panel/expansion-panel.component.scss +0 -0
  581. package/docs/src/app/components/expansion-panel/expansion-panel.component.ts +0 -20
  582. package/docs/src/app/components/fab/examples/button-colors.html +0 -18
  583. package/docs/src/app/components/fab/examples/button-sizes.html +0 -11
  584. package/docs/src/app/components/fab/examples/extended-buttons.html +0 -18
  585. package/docs/src/app/components/fab/examples/floating-action-area.html +0 -5
  586. package/docs/src/app/components/fab/examples/floating-menu.html +0 -10
  587. package/docs/src/app/components/fab/examples/lowered-buttons.html +0 -6
  588. package/docs/src/app/components/fab/fab.component.pug +0 -27
  589. package/docs/src/app/components/fab/fab.component.scss +0 -0
  590. package/docs/src/app/components/fab/fab.component.ts +0 -38
  591. package/docs/src/app/components/icon-buttons/examples/anchor-buttons.html +0 -15
  592. package/docs/src/app/components/icon-buttons/examples/buttons-variants.html +0 -15
  593. package/docs/src/app/components/icon-buttons/examples/toggle-buttons-manual.html +0 -4
  594. package/docs/src/app/components/icon-buttons/examples/toggle-buttons.html +0 -48
  595. package/docs/src/app/components/icon-buttons/icon-buttons.component.pug +0 -19
  596. package/docs/src/app/components/icon-buttons/icon-buttons.component.scss +0 -0
  597. package/docs/src/app/components/icon-buttons/icon-buttons.component.ts +0 -32
  598. package/docs/src/app/components/lists/examples/list-avatars.html +0 -14
  599. package/docs/src/app/components/lists/examples/list-custom-dividers.html +0 -23
  600. package/docs/src/app/components/lists/examples/list-dividers.html +0 -17
  601. package/docs/src/app/components/lists/examples/list-dynamic.html +0 -26
  602. package/docs/src/app/components/lists/examples/list-hover.html +0 -17
  603. package/docs/src/app/components/lists/examples/list-icons.html +0 -17
  604. package/docs/src/app/components/lists/examples/list-indexed.html +0 -123
  605. package/docs/src/app/components/lists/examples/list-sections.html +0 -16
  606. package/docs/src/app/components/lists/examples/list-three-lines.html +0 -20
  607. package/docs/src/app/components/lists/examples/list-two-lines.html +0 -20
  608. package/docs/src/app/components/lists/examples/list-with-action.html +0 -26
  609. package/docs/src/app/components/lists/examples/list-with-activated-item.html +0 -17
  610. package/docs/src/app/components/lists/examples/simple-list.html +0 -17
  611. package/docs/src/app/components/lists/lists.component.pug +0 -19
  612. package/docs/src/app/components/lists/lists.component.scss +0 -0
  613. package/docs/src/app/components/lists/lists.component.ts +0 -20
  614. package/docs/src/app/components/menus/examples/down-end.html +0 -15
  615. package/docs/src/app/components/menus/examples/down-left.html +0 -10
  616. package/docs/src/app/components/menus/examples/down-right.html +0 -10
  617. package/docs/src/app/components/menus/examples/down-start.html +0 -10
  618. package/docs/src/app/components/menus/examples/down.html +0 -10
  619. package/docs/src/app/components/menus/examples/up-end.html +0 -10
  620. package/docs/src/app/components/menus/examples/up-left.html +0 -10
  621. package/docs/src/app/components/menus/examples/up-right.html +0 -10
  622. package/docs/src/app/components/menus/examples/up-start.html +0 -10
  623. package/docs/src/app/components/menus/examples/up.html +0 -10
  624. package/docs/src/app/components/menus/menus.component.pug +0 -43
  625. package/docs/src/app/components/menus/menus.component.scss +0 -15
  626. package/docs/src/app/components/menus/menus.component.ts +0 -60
  627. package/docs/src/app/components/navigation-item.model.ts +0 -4
  628. package/docs/src/app/components/progress/examples/circular-progress.html +0 -13
  629. package/docs/src/app/components/progress/examples/determinate-progress.html +0 -3
  630. package/docs/src/app/components/progress/examples/indeterminate-progress.html +0 -3
  631. package/docs/src/app/components/progress/examples/progress-color.html +0 -3
  632. package/docs/src/app/components/progress/progress.component.pug +0 -34
  633. package/docs/src/app/components/progress/progress.component.scss +0 -0
  634. package/docs/src/app/components/progress/progress.component.ts +0 -34
  635. package/docs/src/app/components/ripple/examples/usage.html +0 -9
  636. package/docs/src/app/components/ripple/ripple.component.pug +0 -7
  637. package/docs/src/app/components/ripple/ripple.component.scss +0 -0
  638. package/docs/src/app/components/ripple/ripple.component.ts +0 -23
  639. package/docs/src/app/components/select/select.component.pug +0 -175
  640. package/docs/src/app/components/select/select.component.scss +0 -3
  641. package/docs/src/app/components/select/select.component.ts +0 -35
  642. package/docs/src/app/components/selection-controls/examples/checkbox.html +0 -22
  643. package/docs/src/app/components/selection-controls/examples/radio-button.html +0 -36
  644. package/docs/src/app/components/selection-controls/examples/switch.html +0 -12
  645. package/docs/src/app/components/selection-controls/selection-controls.component.pug +0 -13
  646. package/docs/src/app/components/selection-controls/selection-controls.component.scss +0 -0
  647. package/docs/src/app/components/selection-controls/selection-controls.component.ts +0 -29
  648. package/docs/src/app/components/sliders/examples/example.html +0 -42
  649. package/docs/src/app/components/sliders/sliders.component.pug +0 -5
  650. package/docs/src/app/components/sliders/sliders.component.scss +0 -0
  651. package/docs/src/app/components/sliders/sliders.component.ts +0 -23
  652. package/docs/src/app/components/snackbars/examples/example.html +0 -35
  653. package/docs/src/app/components/snackbars/snackbars.component.pug +0 -5
  654. package/docs/src/app/components/snackbars/snackbars.component.scss +0 -0
  655. package/docs/src/app/components/snackbars/snackbars.component.ts +0 -23
  656. package/docs/src/app/components/steppers/steppers.component.pug +0 -1
  657. package/docs/src/app/components/steppers/steppers.component.scss +0 -0
  658. package/docs/src/app/components/steppers/steppers.component.ts +0 -20
  659. package/docs/src/app/components/tables/examples/overview.html +0 -49
  660. package/docs/src/app/components/tables/examples/table-hover.html +0 -67
  661. package/docs/src/app/components/tables/tables.component.pug +0 -74
  662. package/docs/src/app/components/tables/tables.component.scss +0 -0
  663. package/docs/src/app/components/tables/tables.component.ts +0 -29
  664. package/docs/src/app/components/tabs/examples/example.html +0 -45
  665. package/docs/src/app/components/tabs/tabs.component.pug +0 -14
  666. package/docs/src/app/components/tabs/tabs.component.scss +0 -0
  667. package/docs/src/app/components/tabs/tabs.component.ts +0 -32
  668. package/docs/src/app/components/text-fields/text-fields.component.pug +0 -122
  669. package/docs/src/app/components/text-fields/text-fields.component.scss +0 -3
  670. package/docs/src/app/components/text-fields/text-fields.component.ts +0 -130
  671. package/docs/src/app/components/toolbars/examples/simple-toolbar.html +0 -33
  672. package/docs/src/app/components/toolbars/toolbars.component.pug +0 -5
  673. package/docs/src/app/components/toolbars/toolbars.component.scss +0 -0
  674. package/docs/src/app/components/toolbars/toolbars.component.ts +0 -23
  675. package/docs/src/app/components/typeahead/examples/handling-selection.html +0 -27
  676. package/docs/src/app/components/typeahead/examples/object-results.html +0 -9
  677. package/docs/src/app/components/typeahead/examples/simple.html +0 -8
  678. package/docs/src/app/components/typeahead/typeahead.component.pug +0 -43
  679. package/docs/src/app/components/typeahead/typeahead.component.scss +0 -0
  680. package/docs/src/app/components/typeahead/typeahead.component.ts +0 -52
  681. package/docs/src/app/content/typography/examples/typos.html +0 -17
  682. package/docs/src/app/content/typography/typography.component.pug +0 -4
  683. package/docs/src/app/content/typography/typography.component.scss +0 -0
  684. package/docs/src/app/content/typography/typography.component.ts +0 -21
  685. package/docs/src/app/docs/apis-table/apis-table.component.pug +0 -26
  686. package/docs/src/app/docs/apis-table/apis-table.component.scss +0 -9
  687. package/docs/src/app/docs/apis-table/apis-table.component.ts +0 -26
  688. package/docs/src/app/docs/example/example.component.pug +0 -17
  689. package/docs/src/app/docs/example/example.component.scss +0 -21
  690. package/docs/src/app/docs/example/example.component.ts +0 -39
  691. package/docs/src/app/docs/link-active.directive.ts +0 -38
  692. package/docs/src/app/docs/shared/title-to-hash.ts +0 -7
  693. package/docs/src/app/docs/submenu/submenu.component.pug +0 -7
  694. package/docs/src/app/docs/submenu/submenu.component.scss +0 -9
  695. package/docs/src/app/docs/submenu/submenu.component.ts +0 -21
  696. package/docs/src/app/docs/title/title.component.pug +0 -5
  697. package/docs/src/app/docs/title/title.component.scss +0 -3
  698. package/docs/src/app/docs/title/title.component.ts +0 -19
  699. package/docs/src/app/dummy/dummy.component.pug +0 -1
  700. package/docs/src/app/dummy/dummy.component.scss +0 -0
  701. package/docs/src/app/dummy/dummy.component.ts +0 -14
  702. package/docs/src/app/introduction/introduction.component.pug +0 -26
  703. package/docs/src/app/introduction/introduction.component.scss +0 -7
  704. package/docs/src/app/introduction/introduction.component.ts +0 -58
  705. package/docs/src/app/layout/container/container.component.pug +0 -77
  706. package/docs/src/app/layout/container/container.component.scss +0 -0
  707. package/docs/src/app/layout/container/container.component.ts +0 -32
  708. package/docs/src/app/layout/container/examples/default-container.html +0 -3
  709. package/docs/src/app/layout/container/examples/fluid-container.html +0 -3
  710. package/docs/src/app/layout/container/overview.md +0 -5
  711. package/docs/src/app/layout/grid/examples/overview.html +0 -12
  712. package/docs/src/app/layout/grid/grid.component.pug +0 -47
  713. package/docs/src/app/layout/grid/grid.component.scss +0 -0
  714. package/docs/src/app/layout/grid/grid.component.ts +0 -26
  715. package/docs/src/app/shared/states.model.ts +0 -61
  716. package/docs/src/app/utilities/background-colors/background-colors.component.pug +0 -9
  717. package/docs/src/app/utilities/background-colors/background-colors.component.scss +0 -0
  718. package/docs/src/app/utilities/background-colors/background-colors.component.ts +0 -27
  719. package/docs/src/app/utilities/background-colors/examples/colors.html +0 -31
  720. package/docs/src/app/utilities/dividers/dividers.component.pug +0 -37
  721. package/docs/src/app/utilities/dividers/dividers.component.scss +0 -0
  722. package/docs/src/app/utilities/dividers/dividers.component.ts +0 -29
  723. package/docs/src/app/utilities/dividers/examples/no-margin.html +0 -9
  724. package/docs/src/app/utilities/dividers/examples/usage.html +0 -21
  725. package/docs/src/app/utilities/text-and-background-colors/examples/colors.html +0 -30
  726. package/docs/src/app/utilities/text-and-background-colors/text-and-background-colors.component.pug +0 -9
  727. package/docs/src/app/utilities/text-and-background-colors/text-and-background-colors.component.scss +0 -0
  728. package/docs/src/app/utilities/text-and-background-colors/text-and-background-colors.component.ts +0 -26
  729. package/docs/src/app/utilities/text-colors/examples/colors.html +0 -39
  730. package/docs/src/app/utilities/text-colors/text-colors.component.pug +0 -9
  731. package/docs/src/app/utilities/text-colors/text-colors.component.scss +0 -0
  732. package/docs/src/app/utilities/text-colors/text-colors.component.ts +0 -28
  733. package/docs/src/app/utilities/text-emphasis/examples/usage.html +0 -17
  734. package/docs/src/app/utilities/text-emphasis/text-emphasis.component.pug +0 -5
  735. package/docs/src/app/utilities/text-emphasis/text-emphasis.component.scss +0 -0
  736. package/docs/src/app/utilities/text-emphasis/text-emphasis.component.ts +0 -19
  737. package/docs/src/favicon.ico +0 -0
  738. package/docs/src/index.html +0 -20
  739. package/docs/src/main.ts +0 -13
  740. package/docs/src/styles.scss +0 -129
  741. package/docs/tsconfig.app.json +0 -14
  742. package/docs/tsconfig.json +0 -40
  743. package/eslint.config.mjs +0 -457
  744. package/gulp-tasks/docs-api.js +0 -76
  745. package/gulp-tasks/docs.js +0 -59
  746. package/gulp-tasks/sass.js +0 -31
  747. package/gulp-tasks/scripts.js +0 -52
  748. package/gulpfile.js +0 -3
  749. package/index.html +0 -11
  750. package/remove-scripts-from-package.js +0 -9
  751. package/rollup.config.js +0 -42
  752. package/src/app-bar/top-app-bar.styles.scss +0 -108
  753. package/src/app-bar/top-app-bar.ts +0 -198
  754. package/src/button/button-base.styles.scss +0 -12
  755. package/src/button/button-base.ts +0 -57
  756. package/src/button/button-set.styles.scss +0 -16
  757. package/src/button/button-set.ts +0 -23
  758. package/src/button/button.styles.scss +0 -104
  759. package/src/button/button.ts +0 -60
  760. package/src/button/fab.styles.scss +0 -90
  761. package/src/button/fab.ts +0 -54
  762. package/src/button/icon-button.styles.scss +0 -80
  763. package/src/button/icon-button.ts +0 -75
  764. package/src/button-field/button-field.styles.scss +0 -13
  765. package/src/button-field/button-field.ts +0 -53
  766. package/src/calendar/calendar-adapter.ts +0 -5
  767. package/src/calendar/calendar-base.styles.scss +0 -82
  768. package/src/calendar/calendar-base.ts +0 -225
  769. package/src/calendar/calendar.styles.scss +0 -0
  770. package/src/calendar/calendar.ts +0 -44
  771. package/src/calendar/default-calendar-adapter.ts +0 -40
  772. package/src/calendar/range-calendar.styles.scss +0 -119
  773. package/src/calendar/range-calendar.ts +0 -135
  774. package/src/card/card-content.styles.scss +0 -15
  775. package/src/card/card-content.ts +0 -45
  776. package/src/card/card-media.styles.scss +0 -9
  777. package/src/card/card-media.ts +0 -24
  778. package/src/card/card.styles.scss +0 -30
  779. package/src/card/card.ts +0 -38
  780. package/src/checkbox/checkbox-list-item.ts +0 -15
  781. package/src/checkbox/checkbox.styles.scss +0 -69
  782. package/src/checkbox/checkbox.ts +0 -64
  783. package/src/chip/chip-set.styles.scss +0 -3
  784. package/src/chip/chip-set.ts +0 -15
  785. package/src/chip/chip.styles.scss +0 -185
  786. package/src/chip/chip.ts +0 -186
  787. package/src/chip-field/chip-field.styles.scss +0 -22
  788. package/src/chip-field/chip-field.ts +0 -182
  789. package/src/config.ts +0 -28
  790. package/src/datepicker/datepicker.styles.scss +0 -0
  791. package/src/datepicker/datepicker.ts +0 -0
  792. package/src/dialog/confirm-dialog-builder.ts +0 -43
  793. package/src/dialog/dialog-builder.ts +0 -57
  794. package/src/dialog/dialog-button-def.ts +0 -6
  795. package/src/dialog/dialog.styles.scss +0 -176
  796. package/src/dialog/dialog.ts +0 -255
  797. package/src/dialog/message-dialog-builder.ts +0 -25
  798. package/src/elevation/elevation.styles.scss +0 -31
  799. package/src/elevation/elevation.ts +0 -20
  800. package/src/field/field-base.styles.scss +0 -429
  801. package/src/field/field-base.ts +0 -184
  802. package/src/field/field-defaults-context.ts +0 -5
  803. package/src/field/field-defaults.ts +0 -5
  804. package/src/field/field-variant.ts +0 -1
  805. package/src/field/field.ts +0 -48
  806. package/src/index.ts +0 -81
  807. package/src/list/list-item.styles.scss +0 -38
  808. package/src/list/list-item.ts +0 -39
  809. package/src/list/list.styles.scss +0 -4
  810. package/src/list/list.ts +0 -19
  811. package/src/menu/menu-item.styles.scss +0 -50
  812. package/src/menu/menu-item.ts +0 -101
  813. package/src/menu/menu.styles.scss +0 -70
  814. package/src/menu/menu.ts +0 -423
  815. package/src/navigation/_side-navigation-base.styles.scss +0 -101
  816. package/src/navigation/drawer-item.styles.scss +0 -49
  817. package/src/navigation/drawer-item.ts +0 -94
  818. package/src/navigation/drawer.styles.scss +0 -21
  819. package/src/navigation/drawer.ts +0 -27
  820. package/src/navigation/side-navigation-swiper.styles.scss +0 -53
  821. package/src/navigation/side-navigation.styles.scss +0 -47
  822. package/src/navigation/side-navigation.ts +0 -149
  823. package/src/progress/circular-progress.styles.scss +0 -83
  824. package/src/progress/circular-progress.ts +0 -83
  825. package/src/progress/progress-bar.styles.scss +0 -159
  826. package/src/progress/progress-bar.ts +0 -50
  827. package/src/radio/radio-list-item.ts +0 -15
  828. package/src/radio/radio.styles.scss +0 -34
  829. package/src/radio/radio.ts +0 -164
  830. package/src/ripple/ripple.styles.scss +0 -81
  831. package/src/ripple/ripple.ts +0 -158
  832. package/src/select/extended-option.ts +0 -3
  833. package/src/select/extended-select.ts +0 -6
  834. package/src/select/option.styles.scss +0 -16
  835. package/src/select/option.ts +0 -165
  836. package/src/select/select-navigation-controller.ts +0 -113
  837. package/src/select/select.styles.scss +0 -36
  838. package/src/select/select.ts +0 -333
  839. package/src/shared/base.styles.scss +0 -29
  840. package/src/shared/button-wrapper.styles.scss +0 -64
  841. package/src/shared/button-wrapper.ts +0 -144
  842. package/src/shared/char-count-text-field/native-text-field-wrapper.ts +0 -54
  843. package/src/shared/compare-text.ts +0 -6
  844. package/src/shared/events/dispatch-event.ts +0 -0
  845. package/src/shared/events/redispatch-event.ts +0 -16
  846. package/src/shared/extract-template-html.ts +0 -9
  847. package/src/shared/menu-field/menu-field-navigation-controller.ts +0 -152
  848. package/src/shared/menu-field/menu-field.ts +0 -7
  849. package/src/shared/mixin-attribute-properties.ts +0 -33
  850. package/src/shared/mixin.ts +0 -11
  851. package/src/shared/normalize-text.ts +0 -9
  852. package/src/shared/selection-control/checkbox-base.ts +0 -5
  853. package/src/shared/selection-control/selection-control-list-item.ts +0 -44
  854. package/src/shared/selection-control/selection-control.styles.scss +0 -74
  855. package/src/shared/selection-control/selection-control.ts +0 -180
  856. package/src/shared/sets/set-base.styles.scss +0 -18
  857. package/src/shared/sets/set-base.ts +0 -21
  858. package/src/shared/text-field-base/text-field-base.styles.scss +0 -11
  859. package/src/shared/text-field-base/text-field-base.ts +0 -36
  860. package/src/snackbar/snackbar.styles.scss +0 -88
  861. package/src/snackbar/snackbar.ts +0 -156
  862. package/src/switch/switch-list-item.ts +0 -15
  863. package/src/switch/switch.styles.scss +0 -87
  864. package/src/switch/switch.ts +0 -32
  865. package/src/tab-bar/tab-bar.styles.scss +0 -77
  866. package/src/tab-bar/tab-bar.ts +0 -232
  867. package/src/tab-bar/tab.styles.scss +0 -53
  868. package/src/tab-bar/tab.ts +0 -113
  869. package/src/text-area/text-area.styles.scss +0 -46
  870. package/src/text-area/text-area.ts +0 -46
  871. package/src/text-field/text-field.styles.scss +0 -55
  872. package/src/text-field/text-field.ts +0 -57
  873. package/src/theme/color.ts +0 -6
  874. package/src/theme/css-var-builder.ts +0 -39
  875. package/src/theme/index.ts +0 -1
  876. package/src/theme/neutral-colors.ts +0 -26
  877. package/src/theme/theme-builder.ts +0 -197
  878. package/src/theme/theme-color.ts +0 -7
  879. package/src/typeahead/highlight.styles.scss +0 -3
  880. package/src/typeahead/highlight.ts +0 -79
  881. package/src/typeahead/typeahead.styles.scss +0 -9
  882. package/src/typeahead/typeahead.ts +0 -440
  883. package/tsconfig.json +0 -49
  884. package/vendor/ngx-pug-builders-19.0.0.tgz +0 -0
  885. package/web-dev-server.config.js +0 -25
  886. package/web-test-runner.config.js +0 -120
  887. /package/{src/scss → scss}/_api.scss +0 -0
  888. /package/{src/scss → scss}/_colors.scss +0 -0
  889. /package/{src/scss → scss}/_css-vars.scss +0 -0
  890. /package/{src/scss → scss}/_functions.scss +0 -0
  891. /package/{src/scss → scss}/_global.scss +0 -0
  892. /package/{src/scss → scss}/_layout.scss +0 -0
  893. /package/{src/scss → scss}/_mixins.scss +0 -0
  894. /package/{src/scss → scss}/_reboot.scss +0 -0
  895. /package/{src/scss → scss}/_utilities.scss +0 -0
  896. /package/{src/scss → scss}/_variables.scss +0 -0
  897. /package/{src/scss → scss}/colors/_text-bg.scss +0 -0
  898. /package/{src/scss → scss}/colors/_text.scss +0 -0
  899. /package/{src/scss → scss}/functions/_font.scss +0 -0
  900. /package/{src/scss → scss}/layout/_container.scss +0 -0
  901. /package/{src/scss → scss}/layout/_grid.scss +0 -0
  902. /package/{src/scss → scss}/layout/_margin-and-gutters.scss +0 -0
  903. /package/{src/scss → scss}/mixins/_breakpoints.scss +0 -0
  904. /package/{src/scss → scss}/mixins/_colors.scss +0 -0
  905. /package/{src/scss → scss}/mixins/_text-bg.scss +0 -0
  906. /package/{src/scss → scss}/mixins/_typo.scss +0 -0
  907. /package/{src/scss → scss}/table/_table.scss +0 -0
  908. /package/{src/scss → scss}/typo/_font.scss +0 -0
  909. /package/{src/scss → scss}/typo/_typo.scss +0 -0
  910. /package/{src/scss → scss}/typo/_variables.scss +0 -0
  911. /package/{src/scss → scss}/universal-material.scss +0 -0
  912. /package/{src/scss → scss}/utilities/_divider.scss +0 -0
  913. /package/{src/scss → scss}/utilities/_scheme.scss +0 -0
  914. /package/{src/scss → scss}/utilities/_spacing.scss +0 -0
  915. /package/{src/scss → scss}/utilities/_text.scss +0 -0
package/menu/menu.js ADDED
@@ -0,0 +1,328 @@
1
+ import { __decorate } from "tslib";
2
+ import { html, LitElement } from 'lit';
3
+ import { customElement, property, query } from 'lit/decorators.js';
4
+ import { classMap } from 'lit/directives/class-map.js';
5
+ import { styles as baseStyles } from '../shared/base.styles.js';
6
+ import { styles } from './menu.styles.js';
7
+ import '../elevation/elevation.js';
8
+ let UmMenu = class UmMenu extends LitElement {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.#open = false;
12
+ this.#preInitOpen = false;
13
+ this.positioning = 'relative';
14
+ this.manualFocus = false;
15
+ /**
16
+ * The corner of the anchor which to align the menu in the standard logical
17
+ * property style of <block>-<inline> e.g. `'end-start'`.
18
+ */
19
+ this.anchorCorner = 'end-start';
20
+ /**
21
+ * The direction of the menu. e.g. `'down-end'`.
22
+ *
23
+ * NOTE: This value may not be respected by the menu positioning algorithm
24
+ * if the menu would render outside the viewport.
25
+ */
26
+ this.direction = 'down-end';
27
+ /**
28
+ * Don't limit the height of the menu
29
+ */
30
+ this.allowOverflow = false;
31
+ this.#onOpened = () => this.dispatchEvent(new Event('opened'));
32
+ this.#onClosed = () => {
33
+ this.menu.style.display = 'none';
34
+ this.dispatchEvent(new Event('closed'));
35
+ };
36
+ this.toggle = () => {
37
+ if (this.open) {
38
+ this.close();
39
+ return;
40
+ }
41
+ this.show();
42
+ };
43
+ this.close = () => {
44
+ this.open = false;
45
+ };
46
+ }
47
+ static { this.styles = [baseStyles, styles]; }
48
+ #open;
49
+ #preInitOpen;
50
+ /**
51
+ * Opens the menu and makes it visible. Alternative to the `.show()`, `.close()` and `.toggle()` methods
52
+ */
53
+ get open() {
54
+ return this.#open;
55
+ }
56
+ set open(open) {
57
+ if (!this.menu) {
58
+ this.#preInitOpen = open;
59
+ return;
60
+ }
61
+ if (this.open === open) {
62
+ return;
63
+ }
64
+ this.menu.removeEventListener('transitionend', this.#onClosed, true);
65
+ this.menu.removeEventListener('transitionend', this.#onOpened, true);
66
+ if (!open) {
67
+ const closePrevented = !this.dispatchEvent(new Event('close', { cancelable: true }));
68
+ if (closePrevented) {
69
+ return;
70
+ }
71
+ this.#open = open;
72
+ this.#hide();
73
+ return;
74
+ }
75
+ const openPrevented = !this.dispatchEvent(new Event('open', { cancelable: true }));
76
+ if (openPrevented) {
77
+ return;
78
+ }
79
+ this.#open = open;
80
+ this.#show();
81
+ }
82
+ #show() {
83
+ this.menu.style.display = '';
84
+ this.calcDropdownPositioning();
85
+ this.menu.addEventListener('transitionend', this.#onOpened, {
86
+ capture: true,
87
+ once: true,
88
+ });
89
+ setTimeout(() => document.addEventListener('click', this.close));
90
+ if (this.manualFocus) {
91
+ return;
92
+ }
93
+ setTimeout(() => this.querySelector('u-menu-item:not([disabled])')?.focus());
94
+ }
95
+ #hide() {
96
+ document.removeEventListener('click', this.close);
97
+ this.menu.addEventListener('transitionend', this.#onClosed, {
98
+ capture: true,
99
+ once: true,
100
+ });
101
+ }
102
+ get scrollContainer() {
103
+ return this.menu;
104
+ }
105
+ #onOpened;
106
+ #onClosed;
107
+ #anchorElement;
108
+ get anchorElement() {
109
+ return this.#anchorElement ?? this.parentElement ?? this.getRootNode().host;
110
+ }
111
+ set anchorElement(anchorElement) {
112
+ this.#anchorElement = anchorElement;
113
+ }
114
+ render() {
115
+ const menuClasses = { open: this.open };
116
+ return html `
117
+ <div class="ref"></div>
118
+ <div class="menu ${classMap(menuClasses)}" part="menu" style="display: none" ?inert=${!this.open}>
119
+ <u-elevation></u-elevation>
120
+ <div role="menu" class="content" part="content">
121
+ <slot></slot>
122
+ </div>
123
+ </div>
124
+ `;
125
+ }
126
+ connectedCallback() {
127
+ super.connectedCallback();
128
+ this.role = 'listbox';
129
+ this.#setInitOpen();
130
+ }
131
+ show() {
132
+ this.open = true;
133
+ }
134
+ async #setInitOpen() {
135
+ await this.updateComplete;
136
+ if (this.#preInitOpen) {
137
+ this.open = true;
138
+ }
139
+ }
140
+ calcDropdownPositioning() {
141
+ if (!this.anchorElement) {
142
+ return;
143
+ }
144
+ const menuPosition = this.getMenuPosition();
145
+ const menuSize = this.getMenuSize();
146
+ this.#resetMenu();
147
+ this.#setToOpenUpOrDown(menuPosition, menuSize);
148
+ this.#setToOpenToStartOrEnd(menuPosition, menuSize);
149
+ }
150
+ #resetMenu() {
151
+ this.menu.className = 'menu';
152
+ this.menu.style.top = '';
153
+ this.menu.style.bottom = '';
154
+ this.menu.style.left = '';
155
+ this.menu.style.right = '';
156
+ this.menu.style.maxHeight = '';
157
+ }
158
+ #setToOpenUpOrDown(menuPosition, menuSize) {
159
+ if (this.anchorCorner.startsWith('auto-')) {
160
+ this.#openBlockAuto(menuPosition, menuSize);
161
+ return;
162
+ }
163
+ const side = this.anchorCorner.startsWith('start-') ? menuPosition.bounds.top : menuPosition.bounds.bottom;
164
+ if (this.direction.startsWith('up-')) {
165
+ this.#tryOpenUp(side, menuSize);
166
+ return;
167
+ }
168
+ this.#tryOpenDown(side, menuSize);
169
+ }
170
+ #openBlockAuto(menuPosition, menuSize) {
171
+ const topSide = menuPosition.bounds.top;
172
+ const bottomSide = menuPosition.bounds.bottom;
173
+ const viewPortHeight = window.innerHeight;
174
+ if (bottomSide.bottom >= topSide.top || viewPortHeight - (bottomSide.top + menuSize.height) >= 0) {
175
+ this.#openDown(bottomSide);
176
+ return;
177
+ }
178
+ this.#openUp(topSide);
179
+ }
180
+ #tryOpenUp(side, menuSize) {
181
+ if (side.top === side.bottom || side.top - menuSize.height >= 0) {
182
+ this.#openUp(side);
183
+ return;
184
+ }
185
+ this.#openToLargestBlockSide(side);
186
+ }
187
+ #tryOpenDown(side, menuSize) {
188
+ const viewPortHeight = window.innerHeight;
189
+ if (side.top === side.bottom || viewPortHeight - (side.top + menuSize.height) >= 0) {
190
+ this.#openDown(side);
191
+ return;
192
+ }
193
+ this.#openToLargestBlockSide(side);
194
+ }
195
+ #openToLargestBlockSide(side) {
196
+ if (side.top > side.bottom) {
197
+ this.#openUp(side);
198
+ return;
199
+ }
200
+ this.#openDown(side);
201
+ }
202
+ #setToOpenToStartOrEnd(menuPosition, menuSize) {
203
+ const openStart = menuPosition.isRtl ? this.#tryOpenRight.bind(this) : this.#tryOpenLeft.bind(this);
204
+ const openEnd = menuPosition.isRtl ? this.#tryOpenLeft.bind(this) : this.#tryOpenRight.bind(this);
205
+ const side = this.anchorCorner.endsWith('-start') ? menuPosition.bounds.start : menuPosition.bounds.end;
206
+ if (this.direction.endsWith('-start')) {
207
+ openStart(side, menuSize);
208
+ return;
209
+ }
210
+ openEnd(side, menuSize);
211
+ }
212
+ #tryOpenLeft(side, menuSize) {
213
+ if (side.left === side.right || side.left - menuSize.width >= 0) {
214
+ this.menu.style.right = `${side.relativeX * -1}px`;
215
+ return;
216
+ }
217
+ this.#openToLargestInlineSide(side);
218
+ }
219
+ #tryOpenRight(side, menuSize) {
220
+ const viewPortWidth = window.innerWidth;
221
+ if (side.left === side.right || viewPortWidth - (side.left + menuSize.width) >= 0) {
222
+ this.menu.style.left = `${side.relativeX}px`;
223
+ return;
224
+ }
225
+ this.#openToLargestInlineSide(side);
226
+ }
227
+ #openToLargestInlineSide(side) {
228
+ if (side.left > side.right) {
229
+ this.menu.style.right = `${side.relativeX * -1}px`;
230
+ return;
231
+ }
232
+ this.menu.style.left = `${side.relativeX}px`;
233
+ }
234
+ #openUp(side) {
235
+ const viewPortHeight = window.innerHeight;
236
+ this.menu.style.bottom = `${side.relativeY * -1}px`;
237
+ this.menu.classList.add('up');
238
+ this.menu.style.maxHeight = this.allowOverflow ? '' : `${viewPortHeight - side.bottom}px`;
239
+ }
240
+ #openDown(side) {
241
+ const viewPortHeight = window.innerHeight;
242
+ this.menu.style.top = `${side.relativeY}px`;
243
+ this.menu.style.maxHeight = this.allowOverflow ? '' : `${viewPortHeight - side.top}px`;
244
+ }
245
+ getMenuPosition() {
246
+ const viewPortWidth = window.innerWidth;
247
+ const viewPortHeight = window.innerHeight;
248
+ const anchorElement = this.anchorElement;
249
+ const anchorRect = anchorElement.getBoundingClientRect();
250
+ const refRect = this.ref.getBoundingClientRect();
251
+ const anchorStyles = getComputedStyle(anchorElement);
252
+ const isRtl = anchorStyles.direction === 'rtl';
253
+ const width = parseInt(anchorStyles.width, 10);
254
+ const height = parseInt(anchorStyles.height, 10);
255
+ const rectX = refRect.left;
256
+ const rectY = refRect.top;
257
+ const leftPoint = {
258
+ left: anchorRect.left,
259
+ right: viewPortWidth - anchorRect.left,
260
+ relativeX: anchorRect.left - rectX,
261
+ };
262
+ const rightPoint = {
263
+ left: anchorRect.right,
264
+ right: viewPortWidth - anchorRect.right,
265
+ relativeX: leftPoint.relativeX + width,
266
+ };
267
+ const topPoint = {
268
+ top: anchorRect.top,
269
+ relativeY: anchorRect.top - rectY,
270
+ bottom: viewPortHeight - anchorRect.top,
271
+ };
272
+ const anchorBounds = {
273
+ top: topPoint,
274
+ bottom: {
275
+ top: anchorRect.bottom,
276
+ relativeY: topPoint.relativeY + height,
277
+ bottom: viewPortHeight - anchorRect.bottom,
278
+ },
279
+ start: isRtl ? rightPoint : leftPoint,
280
+ end: isRtl ? leftPoint : rightPoint,
281
+ width,
282
+ height,
283
+ };
284
+ return {
285
+ isRtl,
286
+ bounds: anchorBounds,
287
+ };
288
+ }
289
+ getMenuSize() {
290
+ const menu = this.menu;
291
+ const menuStyles = getComputedStyle(menu);
292
+ const width = parseInt(menuStyles.width, 10);
293
+ const height = parseInt(menuStyles.height, 10);
294
+ return {
295
+ width,
296
+ height,
297
+ };
298
+ }
299
+ };
300
+ __decorate([
301
+ property({ type: Boolean, reflect: true })
302
+ ], UmMenu.prototype, "open", null);
303
+ __decorate([
304
+ property({ reflect: true })
305
+ ], UmMenu.prototype, "positioning", void 0);
306
+ __decorate([
307
+ property({ type: Boolean })
308
+ ], UmMenu.prototype, "manualFocus", void 0);
309
+ __decorate([
310
+ property({ attribute: 'anchor-corner', reflect: true })
311
+ ], UmMenu.prototype, "anchorCorner", void 0);
312
+ __decorate([
313
+ property({ reflect: true })
314
+ ], UmMenu.prototype, "direction", void 0);
315
+ __decorate([
316
+ property({ type: Boolean, attribute: 'allow-overflow', reflect: true })
317
+ ], UmMenu.prototype, "allowOverflow", void 0);
318
+ __decorate([
319
+ query('.menu')
320
+ ], UmMenu.prototype, "menu", void 0);
321
+ __decorate([
322
+ query('.ref')
323
+ ], UmMenu.prototype, "ref", void 0);
324
+ UmMenu = __decorate([
325
+ customElement('u-menu')
326
+ ], UmMenu);
327
+ export { UmMenu };
328
+ //# sourceMappingURL=menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.js","sourceRoot":"","sources":["../../src/menu/menu.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, HTMLTemplateResult, LitElement } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { styles as baseStyles } from '../shared/base.styles.js';\nimport { styles } from './menu.styles.js';\n\nimport '../elevation/elevation.js';\n\ninterface AnchorCornerBlockSide {\n top: number;\n bottom: number;\n relativeY: number;\n}\n\ninterface AnchorCornerInlineSide {\n left: number;\n right: number;\n relativeX: number;\n}\n\ninterface AnchorBounds {\n top: AnchorCornerBlockSide;\n bottom: AnchorCornerBlockSide;\n start: AnchorCornerInlineSide;\n end: AnchorCornerInlineSide;\n width: number;\n height: number;\n}\n\ninterface MenuPosition {\n bounds: AnchorBounds;\n isRtl: boolean;\n}\n\ninterface MenuSize {\n width: number;\n height: number;\n}\n\n@customElement('u-menu')\nexport class UmMenu extends LitElement {\n static override styles = [baseStyles, styles];\n\n #open = false;\n #preInitOpen = false;\n\n /**\n * Opens the menu and makes it visible. Alternative to the `.show()`, `.close()` and `.toggle()` methods\n */\n @property({ type: Boolean, reflect: true })\n get open(): boolean {\n return this.#open;\n }\n\n set open(open: boolean) {\n if (!this.menu) {\n this.#preInitOpen = open;\n return;\n }\n\n if (this.open === open) {\n return;\n }\n\n this.menu.removeEventListener('transitionend', this.#onClosed, true);\n this.menu.removeEventListener('transitionend', this.#onOpened, true);\n\n if (!open) {\n const closePrevented = !this.dispatchEvent(new Event('close', { cancelable: true }));\n\n if (closePrevented) {\n return;\n }\n\n this.#open = open;\n\n this.#hide();\n\n return;\n }\n\n const openPrevented = !this.dispatchEvent(new Event('open', { cancelable: true }));\n\n if (openPrevented) {\n return;\n }\n\n this.#open = open;\n\n this.#show();\n }\n\n #show() {\n this.menu.style.display = '';\n this.calcDropdownPositioning();\n\n this.menu.addEventListener('transitionend', this.#onOpened, {\n capture: true,\n once: true,\n });\n\n setTimeout(() => document.addEventListener('click', this.close));\n\n if (this.manualFocus) {\n return;\n }\n\n setTimeout(() => this.querySelector<HTMLElement>('u-menu-item:not([disabled])')?.focus());\n }\n\n #hide() {\n document.removeEventListener('click', this.close);\n\n this.menu.addEventListener('transitionend', this.#onClosed, {\n capture: true,\n once: true,\n });\n }\n\n @property({ reflect: true }) positioning: 'relative' | 'fixed' = 'relative';\n\n @property({ type: Boolean }) manualFocus = false;\n\n /**\n * The corner of the anchor which to align the menu in the standard logical\n * property style of <block>-<inline> e.g. `'end-start'`.\n */\n @property({ attribute: 'anchor-corner', reflect: true })\n anchorCorner: 'auto-start' | 'auto-end' | 'start-start' | 'start-end' | 'end-start' | 'end-end' = 'end-start';\n\n /**\n * The direction of the menu. e.g. `'down-end'`.\n *\n * NOTE: This value may not be respected by the menu positioning algorithm\n * if the menu would render outside the viewport.\n */\n @property({ reflect: true }) direction: 'up-start' | 'up-end' | 'down-start' | 'down-end' = 'down-end';\n\n /**\n * Don't limit the height of the menu\n */\n @property({ type: Boolean, attribute: 'allow-overflow', reflect: true }) allowOverflow = false;\n\n @query('.menu') menu!: HTMLElement;\n @query('.ref') ref!: HTMLElement;\n\n get scrollContainer(): HTMLElement {\n return this.menu;\n }\n\n readonly #onOpened = () => this.dispatchEvent(new Event('opened'));\n\n readonly #onClosed = () => {\n this.menu.style.display = 'none';\n this.dispatchEvent(new Event('closed'));\n };\n\n #anchorElement: HTMLElement | null | undefined;\n\n get anchorElement(): HTMLElement | null | undefined {\n return this.#anchorElement ?? this.parentElement! ?? (this.getRootNode() as ShadowRoot).host;\n }\n\n set anchorElement(anchorElement: HTMLElement | null | undefined) {\n this.#anchorElement = anchorElement;\n }\n\n protected override render(): HTMLTemplateResult {\n const menuClasses = { open: this.open };\n\n return html`\n <div class=\"ref\"></div>\n <div class=\"menu ${classMap(menuClasses)}\" part=\"menu\" style=\"display: none\" ?inert=${!this.open}>\n <u-elevation></u-elevation>\n <div role=\"menu\" class=\"content\" part=\"content\">\n <slot></slot>\n </div>\n </div>\n `;\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.role = 'listbox';\n\n this.#setInitOpen();\n }\n\n toggle = () => {\n if (this.open) {\n this.close();\n return;\n }\n\n this.show();\n };\n\n show(): void {\n this.open = true;\n }\n\n close = () => {\n this.open = false;\n };\n\n async #setInitOpen() {\n await this.updateComplete;\n\n if (this.#preInitOpen) {\n this.open = true;\n }\n }\n\n private calcDropdownPositioning() {\n if (!this.anchorElement) {\n return;\n }\n\n const menuPosition = this.getMenuPosition();\n const menuSize = this.getMenuSize();\n\n this.#resetMenu();\n this.#setToOpenUpOrDown(menuPosition, menuSize);\n this.#setToOpenToStartOrEnd(menuPosition, menuSize);\n }\n\n #resetMenu() {\n this.menu.className = 'menu';\n this.menu.style.top = '';\n this.menu.style.bottom = '';\n this.menu.style.left = '';\n this.menu.style.right = '';\n this.menu.style.maxHeight = '';\n }\n\n #setToOpenUpOrDown(menuPosition: MenuPosition, menuSize: MenuSize): void {\n if (this.anchorCorner.startsWith('auto-')) {\n this.#openBlockAuto(menuPosition, menuSize);\n return;\n }\n\n const side = this.anchorCorner.startsWith('start-') ? menuPosition.bounds.top : menuPosition.bounds.bottom;\n\n if (this.direction.startsWith('up-')) {\n this.#tryOpenUp(side, menuSize);\n return;\n }\n\n this.#tryOpenDown(side, menuSize);\n }\n\n #openBlockAuto(menuPosition: MenuPosition, menuSize: MenuSize): void {\n const topSide = menuPosition.bounds.top;\n const bottomSide = menuPosition.bounds.bottom;\n\n const viewPortHeight = window.innerHeight;\n\n if (bottomSide.bottom >= topSide.top || viewPortHeight - (bottomSide.top + menuSize.height) >= 0) {\n this.#openDown(bottomSide);\n return;\n }\n\n this.#openUp(topSide);\n }\n\n #tryOpenUp(side: AnchorCornerBlockSide, menuSize: MenuSize): void {\n if (side.top === side.bottom || side.top - menuSize.height >= 0) {\n this.#openUp(side);\n return;\n }\n\n this.#openToLargestBlockSide(side);\n }\n\n #tryOpenDown(side: AnchorCornerBlockSide, menuSize: MenuSize): void {\n const viewPortHeight = window.innerHeight;\n\n if (side.top === side.bottom || viewPortHeight - (side.top + menuSize.height) >= 0) {\n this.#openDown(side);\n return;\n }\n\n this.#openToLargestBlockSide(side);\n }\n\n #openToLargestBlockSide(side: AnchorCornerBlockSide) {\n if (side.top > side.bottom) {\n this.#openUp(side);\n return;\n }\n\n this.#openDown(side);\n }\n\n #setToOpenToStartOrEnd(menuPosition: MenuPosition, menuSize: MenuSize): void {\n const openStart = menuPosition.isRtl ? this.#tryOpenRight.bind(this) : this.#tryOpenLeft.bind(this);\n const openEnd = menuPosition.isRtl ? this.#tryOpenLeft.bind(this) : this.#tryOpenRight.bind(this);\n\n const side = this.anchorCorner.endsWith('-start') ? menuPosition.bounds.start : menuPosition.bounds.end;\n\n if (this.direction.endsWith('-start')) {\n openStart(side, menuSize);\n return;\n }\n\n openEnd(side, menuSize);\n }\n\n #tryOpenLeft(side: AnchorCornerInlineSide, menuSize: MenuSize): void {\n if (side.left === side.right || side.left - menuSize.width >= 0) {\n this.menu.style.right = `${side.relativeX * -1}px`;\n return;\n }\n\n this.#openToLargestInlineSide(side);\n }\n\n #tryOpenRight(side: AnchorCornerInlineSide, menuSize: MenuSize): void {\n const viewPortWidth = window.innerWidth;\n\n if (side.left === side.right || viewPortWidth - (side.left + menuSize.width) >= 0) {\n this.menu.style.left = `${side.relativeX}px`;\n return;\n }\n\n this.#openToLargestInlineSide(side);\n }\n\n #openToLargestInlineSide(side: AnchorCornerInlineSide) {\n if (side.left > side.right) {\n this.menu.style.right = `${side.relativeX * -1}px`;\n return;\n }\n\n this.menu.style.left = `${side.relativeX}px`;\n }\n\n #openUp(side: AnchorCornerBlockSide) {\n const viewPortHeight = window.innerHeight;\n\n this.menu.style.bottom = `${side.relativeY * -1}px`;\n this.menu.classList.add('up');\n this.menu.style.maxHeight = this.allowOverflow ? '' : `${viewPortHeight - side.bottom}px`;\n }\n\n #openDown(side: AnchorCornerBlockSide) {\n const viewPortHeight = window.innerHeight;\n this.menu.style.top = `${side.relativeY}px`;\n this.menu.style.maxHeight = this.allowOverflow ? '' : `${viewPortHeight - side.top}px`;\n }\n\n private getMenuPosition(): MenuPosition {\n const viewPortWidth = window.innerWidth;\n const viewPortHeight = window.innerHeight;\n\n const anchorElement = this.anchorElement!;\n const anchorRect = anchorElement.getBoundingClientRect();\n const refRect = this.ref.getBoundingClientRect();\n const anchorStyles = getComputedStyle(anchorElement);\n const isRtl = anchorStyles.direction === 'rtl';\n\n const width = parseInt(anchorStyles.width, 10);\n const height = parseInt(anchorStyles.height, 10);\n\n const rectX = refRect.left;\n const rectY = refRect.top;\n\n const leftPoint: AnchorCornerInlineSide = {\n left: anchorRect.left,\n right: viewPortWidth - anchorRect.left,\n relativeX: anchorRect.left - rectX,\n };\n\n const rightPoint: AnchorCornerInlineSide = {\n left: anchorRect.right,\n right: viewPortWidth - anchorRect.right,\n relativeX: leftPoint.relativeX + width,\n };\n\n const topPoint: AnchorCornerBlockSide = {\n top: anchorRect.top,\n relativeY: anchorRect.top - rectY,\n bottom: viewPortHeight - anchorRect.top,\n };\n\n const anchorBounds: AnchorBounds = {\n top: topPoint,\n bottom: {\n top: anchorRect.bottom,\n relativeY: topPoint.relativeY + height,\n bottom: viewPortHeight - anchorRect.bottom,\n },\n start: isRtl ? rightPoint : leftPoint,\n end: isRtl ? leftPoint : rightPoint,\n width,\n height,\n };\n\n return {\n isRtl,\n bounds: anchorBounds,\n };\n }\n\n private getMenuSize(): MenuSize {\n const menu = this.menu;\n const menuStyles = getComputedStyle(menu);\n const width = parseInt(menuStyles.width, 10);\n const height = parseInt(menuStyles.height, 10);\n\n return {\n width,\n height,\n };\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-menu': UmMenu;\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const styles: import("lit").CSSResult;
2
+ //# sourceMappingURL=menu.styles.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.styles.d.ts","sourceRoot":"","sources":["../../src/menu/menu.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAkElB,CAAC"}
@@ -0,0 +1,69 @@
1
+ import { css } from 'lit';
2
+ export const styles = css `
3
+ :host {
4
+ --u-elevation-level: var(--u-menu-elevation-level, 2);
5
+ display: block;
6
+ width: 0;
7
+ }
8
+
9
+ :host([positioning=relative]) {
10
+ position: relative;
11
+ }
12
+
13
+ :host([positioning=fixed]) {
14
+ position: fixed;
15
+ }
16
+
17
+ .ref {
18
+ position: absolute;
19
+ inset-inline-start: 0;
20
+ pointer-events: none;
21
+ }
22
+
23
+ .content {
24
+ width: 100%;
25
+ padding-block: var(--u-menu-padding, 8px);
26
+ opacity: 0;
27
+ transition: opacity 1ms 400ms;
28
+ scroll-padding-block: 32px;
29
+ overflow: auto;
30
+ }
31
+
32
+ .menu {
33
+ position: absolute;
34
+ display: flex;
35
+ min-width: var(--u-menu-min-width, 112px);
36
+ max-width: var(--u-menu-max-width, 280px);
37
+ background: var(--u-menu-bg-color, var(--u-color-surface-container, rgb(243, 237, 247)));
38
+ border-radius: var(--u-menu-shape-corner, var(--u-shape-corner-extra-small, 4px));
39
+ opacity: 0;
40
+ transition: transform 350ms cubic-bezier(0.19, 1, 0.22, 1) 350ms, opacity 350ms;
41
+ transform: scale3d(1, 0, 0);
42
+ transform-origin: top;
43
+ z-index: var(--u-menu-z-index, 1020);
44
+ }
45
+ .menu.up {
46
+ transform-origin: bottom;
47
+ }
48
+ .menu.open {
49
+ opacity: 1;
50
+ transition: transform 350ms cubic-bezier(0.19, 1, 0.22, 1), opacity 250ms;
51
+ transform: scale3d(1, 1, 1);
52
+ }
53
+ .menu.open .content {
54
+ opacity: 1;
55
+ transition: opacity 300ms 150ms;
56
+ }
57
+
58
+ @keyframes menu-open {
59
+ from {
60
+ opacity: 0;
61
+ transform: scale3d(1, 0, 0);
62
+ }
63
+ to {
64
+ opacity: 1;
65
+ transform: scale3d(1, 1, 1);
66
+ }
67
+ }
68
+ `;
69
+ //# sourceMappingURL=menu.styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.styles.js","sourceRoot":"","sources":["../../src/menu/menu.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkEzB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const styles = css `\n :host {\n --u-elevation-level: var(--u-menu-elevation-level, 2);\n display: block;\n width: 0;\n }\n\n :host([positioning=relative]) {\n position: relative;\n }\n\n :host([positioning=fixed]) {\n position: fixed;\n }\n\n .ref {\n position: absolute;\n inset-inline-start: 0;\n pointer-events: none;\n }\n\n .content {\n width: 100%;\n padding-block: var(--u-menu-padding, 8px);\n opacity: 0;\n transition: opacity 1ms 400ms;\n scroll-padding-block: 32px;\n overflow: auto;\n }\n\n .menu {\n position: absolute;\n display: flex;\n min-width: var(--u-menu-min-width, 112px);\n max-width: var(--u-menu-max-width, 280px);\n background: var(--u-menu-bg-color, var(--u-color-surface-container, rgb(243, 237, 247)));\n border-radius: var(--u-menu-shape-corner, var(--u-shape-corner-extra-small, 4px));\n opacity: 0;\n transition: transform 350ms cubic-bezier(0.19, 1, 0.22, 1) 350ms, opacity 350ms;\n transform: scale3d(1, 0, 0);\n transform-origin: top;\n z-index: var(--u-menu-z-index, 1020);\n }\n .menu.up {\n transform-origin: bottom;\n }\n .menu.open {\n opacity: 1;\n transition: transform 350ms cubic-bezier(0.19, 1, 0.22, 1), opacity 250ms;\n transform: scale3d(1, 1, 1);\n }\n .menu.open .content {\n opacity: 1;\n transition: opacity 300ms 150ms;\n }\n\n @keyframes menu-open {\n from {\n opacity: 0;\n transform: scale3d(1, 0, 0);\n }\n to {\n opacity: 1;\n transform: scale3d(1, 1, 1);\n }\n }\n`;\n"]}
@@ -0,0 +1,40 @@
1
+ import { HTMLTemplateResult } from 'lit';
2
+ import { UmButtonWrapper } from '../shared/button-wrapper.js';
3
+ export declare class UmDrawerItem extends UmButtonWrapper {
4
+ static styles: import("lit").CSSResultGroup[];
5
+ /**
6
+ * Whether the drawer item has icon or not
7
+ *
8
+ * _Note:_ Readonly
9
+ */
10
+ hasIcon: boolean;
11
+ /**
12
+ * Whether the drawer item has badge or not
13
+ *
14
+ * _Note:_ Readonly
15
+ */
16
+ hasBadge: boolean;
17
+ /**
18
+ * Whether the drawer item is active or not
19
+ *
20
+ * _Note:_ Readonly
21
+ */
22
+ active: boolean;
23
+ /**
24
+ * If true, it will not attempt to close de navigation drawer on click
25
+ */
26
+ keepDrawerOpen: boolean;
27
+ private readonly assignedIcons;
28
+ private readonly assignedBadges;
29
+ connectedCallback(): void;
30
+ protected renderContent(): HTMLTemplateResult;
31
+ private handleIconSlotChange;
32
+ private handleBadgeSlotChange;
33
+ handleClick(): void;
34
+ }
35
+ declare global {
36
+ interface HTMLElementTagNameMap {
37
+ 'u-drawer-item': UmDrawerItem;
38
+ }
39
+ }
40
+ //# sourceMappingURL=drawer-item.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drawer-item.d.ts","sourceRoot":"","sources":["../../src/navigation/drawer-item.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,kBAAkB,EAAE,MAAM,KAAK,CAAC;AAG/C,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAG9D,qBACa,YAAa,SAAQ,eAAe;IAE/C,OAAgB,MAAM,iCAGpB;IAEF;;;;OAIG;IACgE,OAAO,UAAS;IAEnF;;;;OAIG;IACiE,QAAQ,UAAS;IAErF;;;;OAIG;IACyC,MAAM,UAAS;IAE3D;;OAEG;IACwE,cAAc,UAAS;IAGlG,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAiB;IAG/C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAEvC,iBAAiB;cAKP,aAAa,IAAI,kBAAkB;IAiBtD,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,qBAAqB;IAIpB,WAAW,IAAI,IAAI;CAW7B;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,eAAe,EAAE,YAAY,CAAC;KAC/B;CACF"}
@@ -0,0 +1,94 @@
1
+ import { __decorate } from "tslib";
2
+ import { html } from 'lit';
3
+ import { customElement, property, queryAssignedElements } from 'lit/decorators.js';
4
+ import { UmButtonWrapper } from '../shared/button-wrapper.js';
5
+ import { styles } from './drawer-item.styles.js';
6
+ let UmDrawerItem = class UmDrawerItem extends UmButtonWrapper {
7
+ constructor() {
8
+ super(...arguments);
9
+ /**
10
+ * Whether the drawer item has icon or not
11
+ *
12
+ * _Note:_ Readonly
13
+ */
14
+ this.hasIcon = false;
15
+ /**
16
+ * Whether the drawer item has badge or not
17
+ *
18
+ * _Note:_ Readonly
19
+ */
20
+ this.hasBadge = false;
21
+ /**
22
+ * Whether the drawer item is active or not
23
+ *
24
+ * _Note:_ Readonly
25
+ */
26
+ this.active = false;
27
+ /**
28
+ * If true, it will not attempt to close de navigation drawer on click
29
+ */
30
+ this.keepDrawerOpen = false;
31
+ }
32
+ static { this.styles = [
33
+ UmButtonWrapper.styles,
34
+ styles,
35
+ ]; }
36
+ connectedCallback() {
37
+ super.connectedCallback();
38
+ this.setAttribute('aria-labelledby', 'label');
39
+ }
40
+ renderContent() {
41
+ return html `
42
+ <div class="icon">
43
+ <slot
44
+ name="icon"
45
+ aria-hidden="true"
46
+ @slotchange="${this.handleIconSlotChange}"></slot>
47
+ </div>
48
+ <span class="label" id="text"><slot></slot></span>
49
+ <span class="badge">
50
+ <slot
51
+ name="badge"
52
+ @slotchange="${this.handleBadgeSlotChange}"></slot>
53
+ </span>
54
+ `;
55
+ }
56
+ handleIconSlotChange() {
57
+ this.hasIcon = this.assignedIcons.length > 0;
58
+ }
59
+ handleBadgeSlotChange() {
60
+ this.hasBadge = this.assignedBadges.length > 0;
61
+ }
62
+ handleClick() {
63
+ if (this.keepDrawerOpen) {
64
+ return;
65
+ }
66
+ const sideNavigation = this.closest('u-side-navigation');
67
+ if (sideNavigation) {
68
+ sideNavigation.toggleDrawer = false;
69
+ }
70
+ }
71
+ };
72
+ __decorate([
73
+ property({ type: Boolean, attribute: 'has-icon', reflect: true })
74
+ ], UmDrawerItem.prototype, "hasIcon", void 0);
75
+ __decorate([
76
+ property({ type: Boolean, attribute: 'has-badge', reflect: true })
77
+ ], UmDrawerItem.prototype, "hasBadge", void 0);
78
+ __decorate([
79
+ property({ type: Boolean, reflect: true })
80
+ ], UmDrawerItem.prototype, "active", void 0);
81
+ __decorate([
82
+ property({ type: Boolean, attribute: 'keep-drawer-open', reflect: true })
83
+ ], UmDrawerItem.prototype, "keepDrawerOpen", void 0);
84
+ __decorate([
85
+ queryAssignedElements({ slot: 'icon', flatten: true })
86
+ ], UmDrawerItem.prototype, "assignedIcons", void 0);
87
+ __decorate([
88
+ queryAssignedElements({ slot: 'badge', flatten: true })
89
+ ], UmDrawerItem.prototype, "assignedBadges", void 0);
90
+ UmDrawerItem = __decorate([
91
+ customElement('u-drawer-item')
92
+ ], UmDrawerItem);
93
+ export { UmDrawerItem };
94
+ //# sourceMappingURL=drawer-item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drawer-item.js","sourceRoot":"","sources":["../../src/navigation/drawer-item.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAsB,MAAM,KAAK,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAEnF,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AAG1C,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,eAAe;IAA1C;;QAOL;;;;WAIG;QACgE,YAAO,GAAG,KAAK,CAAC;QAEnF;;;;WAIG;QACiE,aAAQ,GAAG,KAAK,CAAC;QAErF;;;;WAIG;QACyC,WAAM,GAAG,KAAK,CAAC;QAE3D;;WAEG;QACwE,mBAAc,GAAG,KAAK,CAAC;IAiDpG,CAAC;aA9EiB,WAAM,GAAG;QACvB,eAAe,CAAC,MAAM;QACtB,MAAM;KACP,AAHqB,CAGpB;IAkCO,iBAAiB;QACxB,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC;IAChD,CAAC;IAEkB,aAAa;QAC9B,OAAO,IAAI,CAAA;;;;;yBAKU,IAAI,CAAC,oBAAoB;;;;;;yBAMzB,IAAI,CAAC,qBAAqB;;KAE9C,CAAC;IACJ,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/C,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;IACjD,CAAC;IAEQ,WAAW;QAClB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;QAEzD,IAAI,cAAc,EAAE,CAAC;YACnB,cAAc,CAAC,YAAY,GAAG,KAAK,CAAC;QACtC,CAAC;IACH,CAAC;;AAnEkE;IAAlE,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;6CAAiB;AAOf;IAAnE,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;8CAAkB;AAOzC;IAA3C,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;4CAAgB;AAKgB;IAA1E,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;oDAAwB;AAGjF;IADhB,qBAAqB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;mDACR;AAG9B;IADhB,qBAAqB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;oDACR;AArCrC,YAAY;IADxB,aAAa,CAAC,eAAe,CAAC;GAClB,YAAY,CAgFxB","sourcesContent":["import { html, HTMLTemplateResult } from 'lit';\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js';\n\nimport { UmButtonWrapper } from '../shared/button-wrapper.js';\nimport { styles } from './drawer-item.styles.js';\n\n@customElement('u-drawer-item')\nexport class UmDrawerItem extends UmButtonWrapper {\n\n static override styles = [\n UmButtonWrapper.styles,\n styles,\n ];\n\n /**\n * Whether the drawer item has icon or not\n *\n * _Note:_ Readonly\n */\n @property({ type: Boolean, attribute: 'has-icon', reflect: true }) hasIcon = false;\n\n /**\n * Whether the drawer item has badge or not\n *\n * _Note:_ Readonly\n */\n @property({ type: Boolean, attribute: 'has-badge', reflect: true }) hasBadge = false;\n\n /**\n * Whether the drawer item is active or not\n *\n * _Note:_ Readonly\n */\n @property({ type: Boolean, reflect: true }) active = false;\n\n /**\n * If true, it will not attempt to close de navigation drawer on click\n */\n @property({ type: Boolean, attribute: 'keep-drawer-open', reflect: true }) keepDrawerOpen = false;\n\n @queryAssignedElements({ slot: 'icon', flatten: true })\n private readonly assignedIcons!: HTMLElement[];\n\n @queryAssignedElements({ slot: 'badge', flatten: true })\n private readonly assignedBadges!: HTMLElement[];\n\n override connectedCallback() {\n super.connectedCallback();\n this.setAttribute('aria-labelledby', 'label');\n }\n\n protected override renderContent(): HTMLTemplateResult {\n return html`\n <div class=\"icon\">\n <slot\n name=\"icon\"\n aria-hidden=\"true\"\n @slotchange=\"${this.handleIconSlotChange}\"></slot>\n </div>\n <span class=\"label\" id=\"text\"><slot></slot></span>\n <span class=\"badge\">\n <slot\n name=\"badge\"\n @slotchange=\"${this.handleBadgeSlotChange}\"></slot>\n </span>\n `;\n }\n\n private handleIconSlotChange() {\n this.hasIcon = this.assignedIcons.length > 0;\n }\n\n private handleBadgeSlotChange() {\n this.hasBadge = this.assignedBadges.length > 0;\n }\n\n override handleClick(): void {\n if (this.keepDrawerOpen) {\n return;\n }\n\n const sideNavigation = this.closest('u-side-navigation');\n\n if (sideNavigation) {\n sideNavigation.toggleDrawer = false;\n }\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-drawer-item': UmDrawerItem;\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const styles: import("lit").CSSResult;
2
+ //# sourceMappingURL=drawer-item.styles.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drawer-item.styles.d.ts","sourceRoot":"","sources":["../../src/navigation/drawer-item.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAiDlB,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { css } from 'lit';
2
+ export const styles = css `
3
+ :host {
4
+ display: block;
5
+ --_drawer-item-icon-size: var(--u-drawer-item-icon-size, 1.125rem);
6
+ --_drawer-item-padding: var(--u-drawer-item-padding, 16px);
7
+ font-family: var(--u-font-family, var(--u-font-family, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"));
8
+ line-height: var(--u-drawer-item-line-height, var(--u-label-l-line-height, 1.25rem));
9
+ font-size: var(--u-drawer-item-font-size, var(--u-label-l-font-size, 0.875rem));
10
+ letter-spacing: var(--u-drawer-item-letter-spacing, var(--u-label-l-letter-spacing, 0.0071428571rem));
11
+ font-weight: var(--u-drawer-item-font-weight, var(--u-label-l-font-weight, var(--u-font-weight-medium, 500)));
12
+ height: var(--u-drawer-item-height, 56px);
13
+ padding-inline: var(--_drawer-item-padding);
14
+ margin-inline: calc(var(--_drawer-item-padding) * -1);
15
+ border-radius: var(--u-drawer-item-shape-corner, var(--u-shape-corner-full, 9999px));
16
+ color: var(--u-drawer-item-label-inactive-color, var(--u-color-on-surface-variant, rgb(73, 69, 79)));
17
+ }
18
+
19
+ :host(.active),
20
+ :host([active]) {
21
+ color: var(--u-drawer-item-label-active-color, var(--_color-primary));
22
+ }
23
+
24
+ :host(:not([has-icon])) .icon,
25
+ :host(:not([has-badge])) .badge {
26
+ display: none;
27
+ }
28
+
29
+ .icon {
30
+ display: flex;
31
+ width: 1em;
32
+ height: 1em;
33
+ align-items: center;
34
+ justify-content: center;
35
+ font-size: var(--_drawer-item-icon-size);
36
+ line-height: 1em;
37
+ margin-inline-end: var(--u-drawer-item-icon-margin, 16px);
38
+ }
39
+
40
+ .badge {
41
+ display: flex;
42
+ justify-content: center;
43
+ align-items: center;
44
+ margin-inline-start: auto;
45
+ padding-inline: var(--u-drawer-item-badge-padding, 12px 8px);
46
+ }
47
+
48
+ .content {
49
+ justify-content: flex-start;
50
+ }
51
+ `;
52
+ //# sourceMappingURL=drawer-item.styles.js.map