@universal-material/web 3.0.139 → 3.0.140

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/.editorconfig +8 -0
  2. package/.eleventy.cjs +21 -0
  3. package/.vscode/extensions.json +9 -0
  4. package/CHANGELOG.md +98 -0
  5. package/LICENSE +28 -0
  6. package/add-custom-elements-schemas.cjs +75 -0
  7. package/change-compiler-to-add-custom-elements.js +26 -0
  8. package/change-schematics-to-generate-pug.js +32 -0
  9. package/docs/angular.json +110 -0
  10. package/docs/src/app/app.component.pug +199 -0
  11. package/docs/src/app/app.component.scss +109 -0
  12. package/docs/src/app/app.component.ts +158 -0
  13. package/docs/src/app/app.config.ts +26 -0
  14. package/docs/src/app/app.routes.ts +140 -0
  15. package/docs/src/app/components/button-set/button-set.component.pug +13 -0
  16. package/docs/src/app/components/button-set/button-set.component.scss +0 -0
  17. package/docs/src/app/components/button-set/button-set.component.ts +29 -0
  18. package/docs/src/app/components/button-set/examples/alignment.html +29 -0
  19. package/docs/src/app/components/button-set/examples/stack.html +5 -0
  20. package/docs/src/app/components/button-set/examples/usage.html +35 -0
  21. package/docs/src/app/components/cards/cards.component.pug +15 -0
  22. package/docs/src/app/components/cards/cards.component.scss +0 -0
  23. package/docs/src/app/components/cards/cards.component.ts +29 -0
  24. package/docs/src/app/components/cards/examples/card-media.html +39 -0
  25. package/docs/src/app/components/cards/examples/card-with-actions.html +40 -0
  26. package/docs/src/app/components/cards/examples/simple-card.html +5 -0
  27. package/docs/src/app/components/checkbox/checkbox.component.pug +5 -0
  28. package/docs/src/app/components/checkbox/checkbox.component.scss +0 -0
  29. package/docs/src/app/components/checkbox/checkbox.component.ts +23 -0
  30. package/docs/src/app/components/checkbox/examples/usage.html +33 -0
  31. package/docs/src/app/components/chip-field/chip-field.component.pug +17 -0
  32. package/docs/src/app/components/chip-field/chip-field.component.scss +0 -0
  33. package/docs/src/app/components/chip-field/chip-field.component.ts +42 -0
  34. package/docs/src/app/components/chip-field/examples/object-values.html +15 -0
  35. package/docs/src/app/components/chip-field/examples/simple.html +1 -0
  36. package/docs/src/app/components/chips/chips.component.pug +69 -0
  37. package/docs/src/app/components/chips/chips.component.scss +0 -0
  38. package/docs/src/app/components/chips/chips.component.ts +131 -0
  39. package/docs/src/app/components/common-buttons/common-buttons.component.pug +23 -0
  40. package/docs/src/app/components/common-buttons/common-buttons.component.scss +0 -0
  41. package/docs/src/app/components/common-buttons/common-buttons.component.ts +35 -0
  42. package/docs/src/app/components/common-buttons/examples/anchor-buttons.html +6 -0
  43. package/docs/src/app/components/common-buttons/examples/buttons-icons.html +24 -0
  44. package/docs/src/app/components/common-buttons/examples/buttons-trailing-icons.html +25 -0
  45. package/docs/src/app/components/common-buttons/examples/buttons-variants.html +6 -0
  46. package/docs/src/app/components/common-buttons/examples/filled-colors.html +4 -0
  47. package/docs/src/app/components/context-test/context-test.component.pug +11 -0
  48. package/docs/src/app/components/context-test/context-test.component.scss +0 -0
  49. package/docs/src/app/components/context-test/context-test.component.ts +23 -0
  50. package/docs/src/app/components/datepicker/datepicker.component.pug +1 -0
  51. package/docs/src/app/components/datepicker/datepicker.component.scss +0 -0
  52. package/docs/src/app/components/datepicker/datepicker.component.ts +20 -0
  53. package/docs/src/app/components/dialogs/dialogs.component.pug +24 -0
  54. package/docs/src/app/components/dialogs/dialogs.component.scss +0 -0
  55. package/docs/src/app/components/dialogs/dialogs.component.ts +33 -0
  56. package/docs/src/app/components/dialogs/examples/example.html +3 -0
  57. package/docs/src/app/components/expansion-panel/expansion-panel.component.pug +1 -0
  58. package/docs/src/app/components/expansion-panel/expansion-panel.component.scss +0 -0
  59. package/docs/src/app/components/expansion-panel/expansion-panel.component.ts +20 -0
  60. package/docs/src/app/components/fab/examples/button-colors.html +18 -0
  61. package/docs/src/app/components/fab/examples/button-sizes.html +11 -0
  62. package/docs/src/app/components/fab/examples/extended-buttons.html +18 -0
  63. package/docs/src/app/components/fab/examples/floating-action-area.html +5 -0
  64. package/docs/src/app/components/fab/examples/floating-menu.html +10 -0
  65. package/docs/src/app/components/fab/examples/lowered-buttons.html +6 -0
  66. package/docs/src/app/components/fab/fab.component.pug +27 -0
  67. package/docs/src/app/components/fab/fab.component.scss +0 -0
  68. package/docs/src/app/components/fab/fab.component.ts +38 -0
  69. package/docs/src/app/components/icon-buttons/examples/anchor-buttons.html +15 -0
  70. package/docs/src/app/components/icon-buttons/examples/buttons-variants.html +15 -0
  71. package/docs/src/app/components/icon-buttons/examples/toggle-buttons-manual.html +4 -0
  72. package/docs/src/app/components/icon-buttons/examples/toggle-buttons.html +48 -0
  73. package/docs/src/app/components/icon-buttons/icon-buttons.component.pug +19 -0
  74. package/docs/src/app/components/icon-buttons/icon-buttons.component.scss +0 -0
  75. package/docs/src/app/components/icon-buttons/icon-buttons.component.ts +32 -0
  76. package/docs/src/app/components/lists/examples/list-avatars.html +14 -0
  77. package/docs/src/app/components/lists/examples/list-custom-dividers.html +23 -0
  78. package/docs/src/app/components/lists/examples/list-dividers.html +17 -0
  79. package/docs/src/app/components/lists/examples/list-dynamic.html +26 -0
  80. package/docs/src/app/components/lists/examples/list-hover.html +17 -0
  81. package/docs/src/app/components/lists/examples/list-icons.html +17 -0
  82. package/docs/src/app/components/lists/examples/list-indexed.html +123 -0
  83. package/docs/src/app/components/lists/examples/list-sections.html +16 -0
  84. package/docs/src/app/components/lists/examples/list-three-lines.html +20 -0
  85. package/docs/src/app/components/lists/examples/list-two-lines.html +20 -0
  86. package/docs/src/app/components/lists/examples/list-with-action.html +26 -0
  87. package/docs/src/app/components/lists/examples/list-with-activated-item.html +17 -0
  88. package/docs/src/app/components/lists/examples/simple-list.html +17 -0
  89. package/docs/src/app/components/lists/lists.component.pug +19 -0
  90. package/docs/src/app/components/lists/lists.component.scss +0 -0
  91. package/docs/src/app/components/lists/lists.component.ts +20 -0
  92. package/docs/src/app/components/menus/examples/down-end.html +15 -0
  93. package/docs/src/app/components/menus/examples/down-left.html +10 -0
  94. package/docs/src/app/components/menus/examples/down-right.html +10 -0
  95. package/docs/src/app/components/menus/examples/down-start.html +10 -0
  96. package/docs/src/app/components/menus/examples/down.html +10 -0
  97. package/docs/src/app/components/menus/examples/up-end.html +10 -0
  98. package/docs/src/app/components/menus/examples/up-left.html +10 -0
  99. package/docs/src/app/components/menus/examples/up-right.html +10 -0
  100. package/docs/src/app/components/menus/examples/up-start.html +10 -0
  101. package/docs/src/app/components/menus/examples/up.html +10 -0
  102. package/docs/src/app/components/menus/menus.component.pug +43 -0
  103. package/docs/src/app/components/menus/menus.component.scss +15 -0
  104. package/docs/src/app/components/menus/menus.component.ts +60 -0
  105. package/docs/src/app/components/navigation-item.model.ts +4 -0
  106. package/docs/src/app/components/progress/examples/circular-progress.html +13 -0
  107. package/docs/src/app/components/progress/examples/determinate-progress.html +3 -0
  108. package/docs/src/app/components/progress/examples/indeterminate-progress.html +3 -0
  109. package/docs/src/app/components/progress/examples/progress-color.html +3 -0
  110. package/docs/src/app/components/progress/progress.component.pug +34 -0
  111. package/docs/src/app/components/progress/progress.component.scss +0 -0
  112. package/docs/src/app/components/progress/progress.component.ts +34 -0
  113. package/docs/src/app/components/ripple/examples/usage.html +9 -0
  114. package/docs/src/app/components/ripple/ripple.component.pug +7 -0
  115. package/docs/src/app/components/ripple/ripple.component.scss +0 -0
  116. package/docs/src/app/components/ripple/ripple.component.ts +23 -0
  117. package/docs/src/app/components/select/select.component.pug +175 -0
  118. package/docs/src/app/components/select/select.component.scss +3 -0
  119. package/docs/src/app/components/select/select.component.ts +35 -0
  120. package/docs/src/app/components/selection-controls/examples/checkbox.html +22 -0
  121. package/docs/src/app/components/selection-controls/examples/radio-button.html +36 -0
  122. package/docs/src/app/components/selection-controls/examples/switch.html +12 -0
  123. package/docs/src/app/components/selection-controls/selection-controls.component.pug +13 -0
  124. package/docs/src/app/components/selection-controls/selection-controls.component.scss +0 -0
  125. package/docs/src/app/components/selection-controls/selection-controls.component.ts +29 -0
  126. package/docs/src/app/components/sliders/examples/example.html +42 -0
  127. package/docs/src/app/components/sliders/sliders.component.pug +5 -0
  128. package/docs/src/app/components/sliders/sliders.component.scss +0 -0
  129. package/docs/src/app/components/sliders/sliders.component.ts +23 -0
  130. package/docs/src/app/components/snackbars/examples/example.html +35 -0
  131. package/docs/src/app/components/snackbars/snackbars.component.pug +5 -0
  132. package/docs/src/app/components/snackbars/snackbars.component.scss +0 -0
  133. package/docs/src/app/components/snackbars/snackbars.component.ts +23 -0
  134. package/docs/src/app/components/steppers/steppers.component.pug +1 -0
  135. package/docs/src/app/components/steppers/steppers.component.scss +0 -0
  136. package/docs/src/app/components/steppers/steppers.component.ts +20 -0
  137. package/docs/src/app/components/tables/examples/overview.html +49 -0
  138. package/docs/src/app/components/tables/examples/table-hover.html +67 -0
  139. package/docs/src/app/components/tables/tables.component.pug +74 -0
  140. package/docs/src/app/components/tables/tables.component.scss +0 -0
  141. package/docs/src/app/components/tables/tables.component.ts +29 -0
  142. package/docs/src/app/components/tabs/examples/example.html +45 -0
  143. package/docs/src/app/components/tabs/tabs.component.pug +14 -0
  144. package/docs/src/app/components/tabs/tabs.component.scss +0 -0
  145. package/docs/src/app/components/tabs/tabs.component.ts +32 -0
  146. package/docs/src/app/components/text-fields/text-fields.component.pug +122 -0
  147. package/docs/src/app/components/text-fields/text-fields.component.scss +3 -0
  148. package/docs/src/app/components/text-fields/text-fields.component.ts +130 -0
  149. package/docs/src/app/components/toolbars/examples/simple-toolbar.html +33 -0
  150. package/docs/src/app/components/toolbars/toolbars.component.pug +5 -0
  151. package/docs/src/app/components/toolbars/toolbars.component.scss +0 -0
  152. package/docs/src/app/components/toolbars/toolbars.component.ts +23 -0
  153. package/docs/src/app/components/typeahead/examples/handling-selection.html +27 -0
  154. package/docs/src/app/components/typeahead/examples/object-results.html +9 -0
  155. package/docs/src/app/components/typeahead/examples/simple.html +8 -0
  156. package/docs/src/app/components/typeahead/typeahead.component.pug +43 -0
  157. package/docs/src/app/components/typeahead/typeahead.component.scss +0 -0
  158. package/docs/src/app/components/typeahead/typeahead.component.ts +52 -0
  159. package/docs/src/app/content/typography/examples/typos.html +17 -0
  160. package/docs/src/app/content/typography/typography.component.pug +4 -0
  161. package/docs/src/app/content/typography/typography.component.scss +0 -0
  162. package/docs/src/app/content/typography/typography.component.ts +21 -0
  163. package/docs/src/app/docs/apis-table/apis-table.component.pug +26 -0
  164. package/docs/src/app/docs/apis-table/apis-table.component.scss +9 -0
  165. package/docs/src/app/docs/apis-table/apis-table.component.ts +26 -0
  166. package/docs/src/app/docs/example/example.component.pug +17 -0
  167. package/docs/src/app/docs/example/example.component.scss +21 -0
  168. package/docs/src/app/docs/example/example.component.ts +39 -0
  169. package/docs/src/app/docs/link-active.directive.ts +38 -0
  170. package/docs/src/app/docs/shared/title-to-hash.ts +7 -0
  171. package/docs/src/app/docs/submenu/submenu.component.pug +7 -0
  172. package/docs/src/app/docs/submenu/submenu.component.scss +9 -0
  173. package/docs/src/app/docs/submenu/submenu.component.ts +21 -0
  174. package/docs/src/app/docs/title/title.component.pug +5 -0
  175. package/docs/src/app/docs/title/title.component.scss +3 -0
  176. package/docs/src/app/docs/title/title.component.ts +19 -0
  177. package/docs/src/app/dummy/dummy.component.pug +1 -0
  178. package/docs/src/app/dummy/dummy.component.scss +0 -0
  179. package/docs/src/app/dummy/dummy.component.ts +14 -0
  180. package/docs/src/app/introduction/introduction.component.pug +26 -0
  181. package/docs/src/app/introduction/introduction.component.scss +7 -0
  182. package/docs/src/app/introduction/introduction.component.ts +58 -0
  183. package/docs/src/app/layout/container/container.component.pug +77 -0
  184. package/docs/src/app/layout/container/container.component.scss +0 -0
  185. package/docs/src/app/layout/container/container.component.ts +32 -0
  186. package/docs/src/app/layout/container/examples/default-container.html +3 -0
  187. package/docs/src/app/layout/container/examples/fluid-container.html +3 -0
  188. package/docs/src/app/layout/container/overview.md +5 -0
  189. package/docs/src/app/layout/grid/examples/overview.html +12 -0
  190. package/docs/src/app/layout/grid/grid.component.pug +47 -0
  191. package/docs/src/app/layout/grid/grid.component.scss +0 -0
  192. package/docs/src/app/layout/grid/grid.component.ts +26 -0
  193. package/docs/src/app/shared/states.model.ts +61 -0
  194. package/docs/src/app/utilities/background-colors/background-colors.component.pug +9 -0
  195. package/docs/src/app/utilities/background-colors/background-colors.component.scss +0 -0
  196. package/docs/src/app/utilities/background-colors/background-colors.component.ts +27 -0
  197. package/docs/src/app/utilities/background-colors/examples/colors.html +31 -0
  198. package/docs/src/app/utilities/dividers/dividers.component.pug +37 -0
  199. package/docs/src/app/utilities/dividers/dividers.component.scss +0 -0
  200. package/docs/src/app/utilities/dividers/dividers.component.ts +29 -0
  201. package/docs/src/app/utilities/dividers/examples/no-margin.html +9 -0
  202. package/docs/src/app/utilities/dividers/examples/usage.html +21 -0
  203. package/docs/src/app/utilities/text-and-background-colors/examples/colors.html +30 -0
  204. package/docs/src/app/utilities/text-and-background-colors/text-and-background-colors.component.pug +9 -0
  205. package/docs/src/app/utilities/text-and-background-colors/text-and-background-colors.component.scss +0 -0
  206. package/docs/src/app/utilities/text-and-background-colors/text-and-background-colors.component.ts +26 -0
  207. package/docs/src/app/utilities/text-colors/examples/colors.html +39 -0
  208. package/docs/src/app/utilities/text-colors/text-colors.component.pug +9 -0
  209. package/docs/src/app/utilities/text-colors/text-colors.component.scss +0 -0
  210. package/docs/src/app/utilities/text-colors/text-colors.component.ts +28 -0
  211. package/docs/src/app/utilities/text-emphasis/examples/usage.html +17 -0
  212. package/docs/src/app/utilities/text-emphasis/text-emphasis.component.pug +5 -0
  213. package/docs/src/app/utilities/text-emphasis/text-emphasis.component.scss +0 -0
  214. package/docs/src/app/utilities/text-emphasis/text-emphasis.component.ts +19 -0
  215. package/docs/src/favicon.ico +0 -0
  216. package/docs/src/index.html +20 -0
  217. package/docs/src/main.ts +13 -0
  218. package/docs/src/styles.scss +129 -0
  219. package/docs/tsconfig.app.json +14 -0
  220. package/docs/tsconfig.json +40 -0
  221. package/eslint.config.mjs +457 -0
  222. package/gulp-tasks/docs-api.js +76 -0
  223. package/gulp-tasks/docs.js +59 -0
  224. package/gulp-tasks/sass.js +31 -0
  225. package/gulp-tasks/scripts.js +52 -0
  226. package/gulpfile.js +3 -0
  227. package/index.html +11 -0
  228. package/package.json +1 -1
  229. package/remove-scripts-from-package.js +9 -0
  230. package/rollup.config.js +42 -0
  231. package/src/app-bar/top-app-bar.styles.scss +108 -0
  232. package/src/app-bar/top-app-bar.ts +198 -0
  233. package/src/button/button-base.styles.scss +12 -0
  234. package/src/button/button-base.ts +57 -0
  235. package/src/button/button-set.styles.scss +16 -0
  236. package/src/button/button-set.ts +23 -0
  237. package/src/button/button.styles.scss +104 -0
  238. package/src/button/button.ts +60 -0
  239. package/src/button/fab.styles.scss +90 -0
  240. package/src/button/fab.ts +54 -0
  241. package/src/button/icon-button.styles.scss +80 -0
  242. package/src/button/icon-button.ts +75 -0
  243. package/src/button-field/button-field.styles.scss +13 -0
  244. package/src/button-field/button-field.ts +53 -0
  245. package/src/calendar/calendar-adapter.ts +5 -0
  246. package/src/calendar/calendar-base.styles.scss +82 -0
  247. package/src/calendar/calendar-base.ts +225 -0
  248. package/src/calendar/calendar.styles.scss +0 -0
  249. package/src/calendar/calendar.ts +44 -0
  250. package/src/calendar/default-calendar-adapter.ts +40 -0
  251. package/src/calendar/range-calendar.styles.scss +119 -0
  252. package/src/calendar/range-calendar.ts +135 -0
  253. package/src/card/card-content.styles.scss +15 -0
  254. package/src/card/card-content.ts +45 -0
  255. package/src/card/card-media.styles.scss +9 -0
  256. package/src/card/card-media.ts +24 -0
  257. package/src/card/card.styles.scss +30 -0
  258. package/src/card/card.ts +38 -0
  259. package/src/checkbox/checkbox-list-item.ts +15 -0
  260. package/src/checkbox/checkbox.styles.scss +69 -0
  261. package/src/checkbox/checkbox.ts +64 -0
  262. package/src/chip/chip-set.styles.scss +3 -0
  263. package/src/chip/chip-set.ts +15 -0
  264. package/src/chip/chip.styles.scss +185 -0
  265. package/src/chip/chip.ts +186 -0
  266. package/src/chip-field/chip-field.styles.scss +22 -0
  267. package/src/chip-field/chip-field.ts +182 -0
  268. package/src/config.ts +28 -0
  269. package/src/datepicker/datepicker.styles.scss +0 -0
  270. package/src/datepicker/datepicker.ts +0 -0
  271. package/src/dialog/confirm-dialog-builder.ts +43 -0
  272. package/src/dialog/dialog-builder.ts +57 -0
  273. package/src/dialog/dialog-button-def.ts +6 -0
  274. package/src/dialog/dialog.styles.scss +176 -0
  275. package/src/dialog/dialog.ts +255 -0
  276. package/src/dialog/message-dialog-builder.ts +25 -0
  277. package/src/elevation/elevation.styles.scss +31 -0
  278. package/src/elevation/elevation.ts +20 -0
  279. package/src/field/field-base.styles.scss +429 -0
  280. package/src/field/field-base.ts +184 -0
  281. package/src/field/field-defaults-context.ts +5 -0
  282. package/src/field/field-defaults.ts +5 -0
  283. package/src/field/field-variant.ts +1 -0
  284. package/src/field/field.ts +48 -0
  285. package/src/index.ts +81 -0
  286. package/src/list/list-item.styles.scss +38 -0
  287. package/src/list/list-item.ts +39 -0
  288. package/src/list/list.styles.scss +4 -0
  289. package/src/list/list.ts +19 -0
  290. package/src/menu/menu-item.styles.scss +50 -0
  291. package/src/menu/menu-item.ts +101 -0
  292. package/src/menu/menu.styles.scss +70 -0
  293. package/src/menu/menu.ts +423 -0
  294. package/src/navigation/_side-navigation-base.styles.scss +101 -0
  295. package/src/navigation/drawer-item.styles.scss +49 -0
  296. package/src/navigation/drawer-item.ts +94 -0
  297. package/src/navigation/drawer.styles.scss +21 -0
  298. package/src/navigation/drawer.ts +27 -0
  299. package/src/navigation/side-navigation-swiper.styles.scss +53 -0
  300. package/src/navigation/side-navigation.styles.scss +47 -0
  301. package/src/navigation/side-navigation.ts +149 -0
  302. package/src/progress/circular-progress.styles.scss +83 -0
  303. package/src/progress/circular-progress.ts +83 -0
  304. package/src/progress/progress-bar.styles.scss +159 -0
  305. package/src/progress/progress-bar.ts +50 -0
  306. package/src/radio/radio-list-item.ts +15 -0
  307. package/src/radio/radio.styles.scss +34 -0
  308. package/src/radio/radio.ts +164 -0
  309. package/src/ripple/ripple.styles.scss +81 -0
  310. package/src/ripple/ripple.ts +158 -0
  311. package/src/select/extended-option.ts +3 -0
  312. package/src/select/extended-select.ts +6 -0
  313. package/src/select/option.styles.scss +16 -0
  314. package/src/select/option.ts +165 -0
  315. package/src/select/select-navigation-controller.ts +113 -0
  316. package/src/select/select.styles.scss +36 -0
  317. package/src/select/select.ts +333 -0
  318. package/src/shared/base.styles.scss +29 -0
  319. package/src/shared/button-wrapper.styles.scss +64 -0
  320. package/src/shared/button-wrapper.ts +144 -0
  321. package/src/shared/char-count-text-field/native-text-field-wrapper.ts +54 -0
  322. package/src/shared/compare-text.ts +6 -0
  323. package/src/shared/events/dispatch-event.ts +0 -0
  324. package/src/shared/events/redispatch-event.ts +16 -0
  325. package/src/shared/extract-template-html.ts +9 -0
  326. package/src/shared/menu-field/menu-field-navigation-controller.ts +152 -0
  327. package/src/shared/menu-field/menu-field.ts +7 -0
  328. package/src/shared/mixin-attribute-properties.ts +33 -0
  329. package/src/shared/mixin.ts +11 -0
  330. package/src/shared/normalize-text.ts +9 -0
  331. package/src/shared/selection-control/checkbox-base.ts +5 -0
  332. package/src/shared/selection-control/selection-control-list-item.ts +44 -0
  333. package/src/shared/selection-control/selection-control.styles.scss +74 -0
  334. package/src/shared/selection-control/selection-control.ts +180 -0
  335. package/src/shared/sets/set-base.styles.scss +18 -0
  336. package/src/shared/sets/set-base.ts +21 -0
  337. package/src/shared/text-field-base/text-field-base.styles.scss +11 -0
  338. package/src/shared/text-field-base/text-field-base.ts +36 -0
  339. package/src/snackbar/snackbar.styles.scss +88 -0
  340. package/src/snackbar/snackbar.ts +156 -0
  341. package/src/switch/switch-list-item.ts +15 -0
  342. package/src/switch/switch.styles.scss +87 -0
  343. package/src/switch/switch.ts +32 -0
  344. package/src/tab-bar/tab-bar.styles.scss +77 -0
  345. package/src/tab-bar/tab-bar.ts +232 -0
  346. package/src/tab-bar/tab.styles.scss +53 -0
  347. package/src/tab-bar/tab.ts +113 -0
  348. package/src/text-area/text-area.styles.scss +46 -0
  349. package/src/text-area/text-area.ts +46 -0
  350. package/src/text-field/text-field.styles.scss +55 -0
  351. package/src/text-field/text-field.ts +57 -0
  352. package/src/theme/color.ts +6 -0
  353. package/src/theme/css-var-builder.ts +39 -0
  354. package/src/theme/index.ts +1 -0
  355. package/src/theme/neutral-colors.ts +26 -0
  356. package/src/theme/theme-builder.ts +197 -0
  357. package/src/theme/theme-color.ts +7 -0
  358. package/src/typeahead/highlight.styles.scss +3 -0
  359. package/src/typeahead/highlight.ts +79 -0
  360. package/src/typeahead/typeahead.styles.scss +9 -0
  361. package/src/typeahead/typeahead.ts +440 -0
  362. package/tsconfig.json +49 -0
  363. package/vendor/ngx-pug-builders-19.0.0.tgz +0 -0
  364. package/web-dev-server.config.js +25 -0
  365. package/web-test-runner.config.js +120 -0
  366. package/app-bar/top-app-bar.d.ts +0 -47
  367. package/app-bar/top-app-bar.d.ts.map +0 -1
  368. package/app-bar/top-app-bar.js +0 -174
  369. package/app-bar/top-app-bar.js.map +0 -1
  370. package/app-bar/top-app-bar.styles.d.ts +0 -2
  371. package/app-bar/top-app-bar.styles.d.ts.map +0 -1
  372. package/app-bar/top-app-bar.styles.js +0 -117
  373. package/app-bar/top-app-bar.styles.js.map +0 -1
  374. package/button/button-base.d.ts +0 -12
  375. package/button/button-base.d.ts.map +0 -1
  376. package/button/button-base.js +0 -46
  377. package/button/button-base.js.map +0 -1
  378. package/button/button-base.styles.d.ts +0 -2
  379. package/button/button-base.styles.d.ts.map +0 -1
  380. package/button/button-base.styles.js +0 -16
  381. package/button/button-base.styles.js.map +0 -1
  382. package/button/button-set.d.ts +0 -15
  383. package/button/button-set.d.ts.map +0 -1
  384. package/button/button-set.js +0 -23
  385. package/button/button-set.js.map +0 -1
  386. package/button/button-set.styles.d.ts +0 -2
  387. package/button/button-set.styles.d.ts.map +0 -1
  388. package/button/button-set.styles.js +0 -20
  389. package/button/button-set.styles.js.map +0 -1
  390. package/button/button.d.ts +0 -33
  391. package/button/button.d.ts.map +0 -1
  392. package/button/button.js +0 -55
  393. package/button/button.js.map +0 -1
  394. package/button/button.styles.d.ts +0 -2
  395. package/button/button.styles.d.ts.map +0 -1
  396. package/button/button.styles.js +0 -103
  397. package/button/button.styles.js.map +0 -1
  398. package/button/fab.d.ts +0 -31
  399. package/button/fab.d.ts.map +0 -1
  400. package/button/fab.js +0 -57
  401. package/button/fab.js.map +0 -1
  402. package/button/fab.styles.d.ts +0 -2
  403. package/button/fab.styles.d.ts.map +0 -1
  404. package/button/fab.styles.js +0 -89
  405. package/button/fab.styles.js.map +0 -1
  406. package/button/icon-button.d.ts +0 -34
  407. package/button/icon-button.d.ts.map +0 -1
  408. package/button/icon-button.js +0 -75
  409. package/button/icon-button.js.map +0 -1
  410. package/button/icon-button.styles.d.ts +0 -2
  411. package/button/icon-button.styles.d.ts.map +0 -1
  412. package/button/icon-button.styles.js +0 -77
  413. package/button/icon-button.styles.js.map +0 -1
  414. package/button-field/button-field.d.ts +0 -18
  415. package/button-field/button-field.d.ts.map +0 -1
  416. package/button-field/button-field.js +0 -54
  417. package/button-field/button-field.js.map +0 -1
  418. package/button-field/button-field.styles.d.ts +0 -2
  419. package/button-field/button-field.styles.d.ts.map +0 -1
  420. package/button-field/button-field.styles.js +0 -17
  421. package/button-field/button-field.styles.js.map +0 -1
  422. package/calendar/calendar-adapter.d.ts +0 -6
  423. package/calendar/calendar-adapter.d.ts.map +0 -1
  424. package/calendar/calendar-adapter.js +0 -2
  425. package/calendar/calendar-adapter.js.map +0 -1
  426. package/calendar/calendar-base.d.ts +0 -30
  427. package/calendar/calendar-base.d.ts.map +0 -1
  428. package/calendar/calendar-base.js +0 -188
  429. package/calendar/calendar-base.js.map +0 -1
  430. package/calendar/calendar-base.styles.d.ts +0 -2
  431. package/calendar/calendar-base.styles.d.ts.map +0 -1
  432. package/calendar/calendar-base.styles.js +0 -81
  433. package/calendar/calendar-base.styles.js.map +0 -1
  434. package/calendar/calendar.d.ts +0 -11
  435. package/calendar/calendar.d.ts.map +0 -1
  436. package/calendar/calendar.js +0 -43
  437. package/calendar/calendar.js.map +0 -1
  438. package/calendar/calendar.styles.d.ts +0 -2
  439. package/calendar/calendar.styles.d.ts.map +0 -1
  440. package/calendar/calendar.styles.js +0 -5
  441. package/calendar/calendar.styles.js.map +0 -1
  442. package/calendar/default-calendar-adapter.d.ts +0 -10
  443. package/calendar/default-calendar-adapter.d.ts.map +0 -1
  444. package/calendar/default-calendar-adapter.js +0 -32
  445. package/calendar/default-calendar-adapter.js.map +0 -1
  446. package/calendar/range-calendar.d.ts +0 -16
  447. package/calendar/range-calendar.d.ts.map +0 -1
  448. package/calendar/range-calendar.js +0 -113
  449. package/calendar/range-calendar.js.map +0 -1
  450. package/calendar/range-calendar.styles.d.ts +0 -2
  451. package/calendar/range-calendar.styles.d.ts.map +0 -1
  452. package/calendar/range-calendar.styles.js +0 -41
  453. package/calendar/range-calendar.styles.js.map +0 -1
  454. package/card/card-content.d.ts +0 -13
  455. package/card/card-content.d.ts.map +0 -1
  456. package/card/card-content.js +0 -39
  457. package/card/card-content.js.map +0 -1
  458. package/card/card-content.styles.d.ts +0 -2
  459. package/card/card-content.styles.d.ts.map +0 -1
  460. package/card/card-content.styles.js +0 -19
  461. package/card/card-content.styles.js.map +0 -1
  462. package/card/card-media.d.ts +0 -12
  463. package/card/card-media.d.ts.map +0 -1
  464. package/card/card-media.js +0 -24
  465. package/card/card-media.js.map +0 -1
  466. package/card/card-media.styles.d.ts +0 -2
  467. package/card/card-media.styles.d.ts.map +0 -1
  468. package/card/card-media.styles.js +0 -13
  469. package/card/card-media.styles.js.map +0 -1
  470. package/card/card.d.ts +0 -19
  471. package/card/card.d.ts.map +0 -1
  472. package/card/card.js +0 -36
  473. package/card/card.js.map +0 -1
  474. package/card/card.styles.d.ts +0 -2
  475. package/card/card.styles.d.ts.map +0 -1
  476. package/card/card.styles.js +0 -31
  477. package/card/card.styles.js.map +0 -1
  478. package/checkbox/checkbox-list-item.d.ts +0 -11
  479. package/checkbox/checkbox-list-item.d.ts.map +0 -1
  480. package/checkbox/checkbox-list-item.js +0 -11
  481. package/checkbox/checkbox-list-item.js.map +0 -1
  482. package/checkbox/checkbox.d.ts +0 -21
  483. package/checkbox/checkbox.d.ts.map +0 -1
  484. package/checkbox/checkbox.js +0 -53
  485. package/checkbox/checkbox.js.map +0 -1
  486. package/checkbox/checkbox.styles.d.ts +0 -2
  487. package/checkbox/checkbox.styles.d.ts.map +0 -1
  488. package/checkbox/checkbox.styles.js +0 -62
  489. package/checkbox/checkbox.styles.js.map +0 -1
  490. package/chip/chip-set.d.ts +0 -10
  491. package/chip/chip-set.d.ts.map +0 -1
  492. package/chip/chip-set.js +0 -12
  493. package/chip/chip-set.js.map +0 -1
  494. package/chip/chip-set.styles.d.ts +0 -2
  495. package/chip/chip-set.styles.d.ts.map +0 -1
  496. package/chip/chip-set.styles.js +0 -7
  497. package/chip/chip-set.styles.js.map +0 -1
  498. package/chip/chip.d.ts +0 -64
  499. package/chip/chip.d.ts.map +0 -1
  500. package/chip/chip.js +0 -187
  501. package/chip/chip.js.map +0 -1
  502. package/chip/chip.styles.d.ts +0 -2
  503. package/chip/chip.styles.d.ts.map +0 -1
  504. package/chip/chip.styles.js +0 -168
  505. package/chip/chip.styles.js.map +0 -1
  506. package/chip-field/chip-field.d.ts +0 -42
  507. package/chip-field/chip-field.d.ts.map +0 -1
  508. package/chip-field/chip-field.js +0 -145
  509. package/chip-field/chip-field.js.map +0 -1
  510. package/chip-field/chip-field.styles.d.ts +0 -2
  511. package/chip-field/chip-field.styles.d.ts.map +0 -1
  512. package/chip-field/chip-field.styles.js +0 -22
  513. package/chip-field/chip-field.styles.js.map +0 -1
  514. package/config.d.ts +0 -16
  515. package/config.d.ts.map +0 -1
  516. package/config.js +0 -25
  517. package/config.js.map +0 -1
  518. package/custom-elements.json +0 -21401
  519. package/datepicker/datepicker.d.ts +0 -1
  520. package/datepicker/datepicker.d.ts.map +0 -1
  521. package/datepicker/datepicker.js +0 -2
  522. package/datepicker/datepicker.js.map +0 -1
  523. package/datepicker/datepicker.styles.d.ts +0 -2
  524. package/datepicker/datepicker.styles.d.ts.map +0 -1
  525. package/datepicker/datepicker.styles.js +0 -5
  526. package/datepicker/datepicker.styles.js.map +0 -1
  527. package/dialog/confirm-dialog-builder.d.ts +0 -12
  528. package/dialog/confirm-dialog-builder.d.ts.map +0 -1
  529. package/dialog/confirm-dialog-builder.js +0 -26
  530. package/dialog/confirm-dialog-builder.js.map +0 -1
  531. package/dialog/dialog-builder.d.ts +0 -15
  532. package/dialog/dialog-builder.d.ts.map +0 -1
  533. package/dialog/dialog-builder.js +0 -42
  534. package/dialog/dialog-builder.js.map +0 -1
  535. package/dialog/dialog-button-def.d.ts +0 -6
  536. package/dialog/dialog-button-def.d.ts.map +0 -1
  537. package/dialog/dialog-button-def.js +0 -2
  538. package/dialog/dialog-button-def.js.map +0 -1
  539. package/dialog/dialog.d.ts +0 -44
  540. package/dialog/dialog.d.ts.map +0 -1
  541. package/dialog/dialog.js +0 -216
  542. package/dialog/dialog.js.map +0 -1
  543. package/dialog/dialog.styles.d.ts +0 -2
  544. package/dialog/dialog.styles.d.ts.map +0 -1
  545. package/dialog/dialog.styles.js +0 -165
  546. package/dialog/dialog.styles.js.map +0 -1
  547. package/dialog/message-dialog-builder.d.ts +0 -10
  548. package/dialog/message-dialog-builder.d.ts.map +0 -1
  549. package/dialog/message-dialog-builder.js +0 -16
  550. package/dialog/message-dialog-builder.js.map +0 -1
  551. package/elevation/elevation.d.ts +0 -11
  552. package/elevation/elevation.d.ts.map +0 -1
  553. package/elevation/elevation.js +0 -16
  554. package/elevation/elevation.js.map +0 -1
  555. package/elevation/elevation.styles.d.ts +0 -2
  556. package/elevation/elevation.styles.d.ts.map +0 -1
  557. package/elevation/elevation.styles.js +0 -28
  558. package/elevation/elevation.styles.js.map +0 -1
  559. package/field/field-base.d.ts +0 -68
  560. package/field/field-base.d.ts.map +0 -1
  561. package/field/field-base.js +0 -174
  562. package/field/field-base.js.map +0 -1
  563. package/field/field-base.styles.d.ts +0 -2
  564. package/field/field-base.styles.d.ts.map +0 -1
  565. package/field/field-base.styles.js +0 -372
  566. package/field/field-base.styles.js.map +0 -1
  567. package/field/field-defaults-context.d.ts +0 -5
  568. package/field/field-defaults-context.d.ts.map +0 -1
  569. package/field/field-defaults-context.js +0 -3
  570. package/field/field-defaults-context.js.map +0 -1
  571. package/field/field-defaults.d.ts +0 -5
  572. package/field/field-defaults.d.ts.map +0 -1
  573. package/field/field-defaults.js +0 -2
  574. package/field/field-defaults.js.map +0 -1
  575. package/field/field-variant.d.ts +0 -2
  576. package/field/field-variant.d.ts.map +0 -1
  577. package/field/field-variant.js +0 -2
  578. package/field/field-variant.js.map +0 -1
  579. package/field/field.d.ts +0 -15
  580. package/field/field.d.ts.map +0 -1
  581. package/field/field.js +0 -44
  582. package/field/field.js.map +0 -1
  583. package/index.d.ts +0 -80
  584. package/index.d.ts.map +0 -1
  585. package/index.js +0 -80
  586. package/index.js.map +0 -1
  587. package/list/list-item.d.ts +0 -13
  588. package/list/list-item.d.ts.map +0 -1
  589. package/list/list-item.js +0 -38
  590. package/list/list-item.js.map +0 -1
  591. package/list/list-item.styles.d.ts +0 -2
  592. package/list/list-item.styles.d.ts.map +0 -1
  593. package/list/list-item.styles.js +0 -48
  594. package/list/list-item.styles.js.map +0 -1
  595. package/list/list.d.ts +0 -11
  596. package/list/list.d.ts.map +0 -1
  597. package/list/list.js +0 -15
  598. package/list/list.js.map +0 -1
  599. package/list/list.styles.d.ts +0 -2
  600. package/list/list.styles.d.ts.map +0 -1
  601. package/list/list.styles.js +0 -8
  602. package/list/list.styles.js.map +0 -1
  603. package/menu/menu-item.d.ts +0 -40
  604. package/menu/menu-item.d.ts.map +0 -1
  605. package/menu/menu-item.js +0 -98
  606. package/menu/menu-item.js.map +0 -1
  607. package/menu/menu-item.styles.d.ts +0 -2
  608. package/menu/menu-item.styles.d.ts.map +0 -1
  609. package/menu/menu-item.styles.js +0 -54
  610. package/menu/menu-item.styles.js.map +0 -1
  611. package/menu/menu.d.ts +0 -48
  612. package/menu/menu.d.ts.map +0 -1
  613. package/menu/menu.js +0 -328
  614. package/menu/menu.js.map +0 -1
  615. package/menu/menu.styles.d.ts +0 -2
  616. package/menu/menu.styles.d.ts.map +0 -1
  617. package/menu/menu.styles.js +0 -69
  618. package/menu/menu.styles.js.map +0 -1
  619. package/navigation/drawer-item.d.ts +0 -40
  620. package/navigation/drawer-item.d.ts.map +0 -1
  621. package/navigation/drawer-item.js +0 -94
  622. package/navigation/drawer-item.js.map +0 -1
  623. package/navigation/drawer-item.styles.d.ts +0 -2
  624. package/navigation/drawer-item.styles.d.ts.map +0 -1
  625. package/navigation/drawer-item.styles.js +0 -52
  626. package/navigation/drawer-item.styles.js.map +0 -1
  627. package/navigation/drawer.d.ts +0 -11
  628. package/navigation/drawer.d.ts.map +0 -1
  629. package/navigation/drawer.js +0 -23
  630. package/navigation/drawer.js.map +0 -1
  631. package/navigation/drawer.styles.d.ts +0 -2
  632. package/navigation/drawer.styles.d.ts.map +0 -1
  633. package/navigation/drawer.styles.js +0 -22
  634. package/navigation/drawer.styles.js.map +0 -1
  635. package/navigation/side-navigation-swiper.styles.d.ts +0 -2
  636. package/navigation/side-navigation-swiper.styles.d.ts.map +0 -1
  637. package/navigation/side-navigation-swiper.styles.js +0 -131
  638. package/navigation/side-navigation-swiper.styles.js.map +0 -1
  639. package/navigation/side-navigation.d.ts +0 -33
  640. package/navigation/side-navigation.d.ts.map +0 -1
  641. package/navigation/side-navigation.js +0 -138
  642. package/navigation/side-navigation.js.map +0 -1
  643. package/navigation/side-navigation.styles.d.ts +0 -2
  644. package/navigation/side-navigation.styles.d.ts.map +0 -1
  645. package/navigation/side-navigation.styles.js +0 -124
  646. package/navigation/side-navigation.styles.js.map +0 -1
  647. package/progress/circular-progress.d.ts +0 -14
  648. package/progress/circular-progress.d.ts.map +0 -1
  649. package/progress/circular-progress.js +0 -80
  650. package/progress/circular-progress.js.map +0 -1
  651. package/progress/circular-progress.styles.d.ts +0 -2
  652. package/progress/circular-progress.styles.d.ts.map +0 -1
  653. package/progress/circular-progress.styles.js +0 -75
  654. package/progress/circular-progress.styles.js.map +0 -1
  655. package/progress/progress-bar.d.ts +0 -14
  656. package/progress/progress-bar.d.ts.map +0 -1
  657. package/progress/progress-bar.js +0 -49
  658. package/progress/progress-bar.js.map +0 -1
  659. package/progress/progress-bar.styles.d.ts +0 -2
  660. package/progress/progress-bar.styles.d.ts.map +0 -1
  661. package/progress/progress-bar.styles.js +0 -152
  662. package/progress/progress-bar.styles.js.map +0 -1
  663. package/radio/radio-list-item.d.ts +0 -11
  664. package/radio/radio-list-item.d.ts.map +0 -1
  665. package/radio/radio-list-item.js +0 -11
  666. package/radio/radio-list-item.js.map +0 -1
  667. package/radio/radio.d.ts +0 -24
  668. package/radio/radio.d.ts.map +0 -1
  669. package/radio/radio.js +0 -125
  670. package/radio/radio.js.map +0 -1
  671. package/radio/radio.styles.d.ts +0 -2
  672. package/radio/radio.styles.d.ts.map +0 -1
  673. package/radio/radio.styles.js +0 -33
  674. package/radio/radio.styles.js.map +0 -1
  675. package/ripple/ripple.d.ts +0 -28
  676. package/ripple/ripple.d.ts.map +0 -1
  677. package/ripple/ripple.js +0 -120
  678. package/ripple/ripple.js.map +0 -1
  679. package/ripple/ripple.styles.d.ts +0 -2
  680. package/ripple/ripple.styles.d.ts.map +0 -1
  681. package/ripple/ripple.styles.js +0 -74
  682. package/ripple/ripple.styles.js.map +0 -1
  683. package/select/extended-option.d.ts +0 -5
  684. package/select/extended-option.d.ts.map +0 -1
  685. package/select/extended-option.js +0 -2
  686. package/select/extended-option.js.map +0 -1
  687. package/select/extended-select.d.ts +0 -6
  688. package/select/extended-select.d.ts.map +0 -1
  689. package/select/extended-select.js +0 -2
  690. package/select/extended-select.js.map +0 -1
  691. package/select/option.d.ts +0 -27
  692. package/select/option.d.ts.map +0 -1
  693. package/select/option.js +0 -132
  694. package/select/option.js.map +0 -1
  695. package/select/option.styles.d.ts +0 -2
  696. package/select/option.styles.d.ts.map +0 -1
  697. package/select/option.styles.js +0 -15
  698. package/select/option.styles.js.map +0 -1
  699. package/select/select-navigation-controller.d.ts +0 -14
  700. package/select/select-navigation-controller.d.ts.map +0 -1
  701. package/select/select-navigation-controller.js +0 -82
  702. package/select/select-navigation-controller.js.map +0 -1
  703. package/select/select.d.ts +0 -47
  704. package/select/select.d.ts.map +0 -1
  705. package/select/select.js +0 -268
  706. package/select/select.js.map +0 -1
  707. package/select/select.styles.d.ts +0 -2
  708. package/select/select.styles.d.ts.map +0 -1
  709. package/select/select.styles.js +0 -39
  710. package/select/select.styles.js.map +0 -1
  711. package/shared/base.styles.d.ts +0 -2
  712. package/shared/base.styles.d.ts.map +0 -1
  713. package/shared/base.styles.js +0 -31
  714. package/shared/base.styles.js.map +0 -1
  715. package/shared/button-wrapper.d.ts +0 -39
  716. package/shared/button-wrapper.d.ts.map +0 -1
  717. package/shared/button-wrapper.js +0 -123
  718. package/shared/button-wrapper.js.map +0 -1
  719. package/shared/button-wrapper.styles.d.ts +0 -2
  720. package/shared/button-wrapper.styles.d.ts.map +0 -1
  721. package/shared/button-wrapper.styles.js +0 -63
  722. package/shared/button-wrapper.styles.js.map +0 -1
  723. package/shared/char-count-text-field/native-text-field-wrapper.d.ts +0 -15
  724. package/shared/char-count-text-field/native-text-field-wrapper.d.ts.map +0 -1
  725. package/shared/char-count-text-field/native-text-field-wrapper.js +0 -54
  726. package/shared/char-count-text-field/native-text-field-wrapper.js.map +0 -1
  727. package/shared/compare-text.d.ts +0 -2
  728. package/shared/compare-text.d.ts.map +0 -1
  729. package/shared/compare-text.js +0 -5
  730. package/shared/compare-text.js.map +0 -1
  731. package/shared/events/dispatch-event.d.ts +0 -1
  732. package/shared/events/dispatch-event.d.ts.map +0 -1
  733. package/shared/events/dispatch-event.js +0 -2
  734. package/shared/events/dispatch-event.js.map +0 -1
  735. package/shared/events/redispatch-event.d.ts +0 -2
  736. package/shared/events/redispatch-event.d.ts.map +0 -1
  737. package/shared/events/redispatch-event.js +0 -14
  738. package/shared/events/redispatch-event.js.map +0 -1
  739. package/shared/extract-template-html.d.ts +0 -2
  740. package/shared/extract-template-html.d.ts.map +0 -1
  741. package/shared/extract-template-html.js +0 -8
  742. package/shared/extract-template-html.js.map +0 -1
  743. package/shared/menu-field/menu-field-navigation-controller.d.ts +0 -20
  744. package/shared/menu-field/menu-field-navigation-controller.d.ts.map +0 -1
  745. package/shared/menu-field/menu-field-navigation-controller.js +0 -108
  746. package/shared/menu-field/menu-field-navigation-controller.js.map +0 -1
  747. package/shared/menu-field/menu-field.d.ts +0 -7
  748. package/shared/menu-field/menu-field.d.ts.map +0 -1
  749. package/shared/menu-field/menu-field.js +0 -2
  750. package/shared/menu-field/menu-field.js.map +0 -1
  751. package/shared/mixin-attribute-properties.d.ts +0 -4
  752. package/shared/mixin-attribute-properties.d.ts.map +0 -1
  753. package/shared/mixin-attribute-properties.js +0 -27
  754. package/shared/mixin-attribute-properties.js.map +0 -1
  755. package/shared/mixin.d.ts +0 -3
  756. package/shared/mixin.d.ts.map +0 -1
  757. package/shared/mixin.js +0 -2
  758. package/shared/mixin.js.map +0 -1
  759. package/shared/normalize-text.d.ts +0 -2
  760. package/shared/normalize-text.d.ts.map +0 -1
  761. package/shared/normalize-text.js +0 -9
  762. package/shared/normalize-text.js.map +0 -1
  763. package/shared/selection-control/checkbox-base.d.ts +0 -1
  764. package/shared/selection-control/checkbox-base.d.ts.map +0 -1
  765. package/shared/selection-control/checkbox-base.js +0 -7
  766. package/shared/selection-control/checkbox-base.js.map +0 -1
  767. package/shared/selection-control/selection-control-list-item.d.ts +0 -4
  768. package/shared/selection-control/selection-control-list-item.d.ts.map +0 -1
  769. package/shared/selection-control/selection-control-list-item.js +0 -44
  770. package/shared/selection-control/selection-control-list-item.js.map +0 -1
  771. package/shared/selection-control/selection-control.d.ts +0 -36
  772. package/shared/selection-control/selection-control.d.ts.map +0 -1
  773. package/shared/selection-control/selection-control.js +0 -155
  774. package/shared/selection-control/selection-control.js.map +0 -1
  775. package/shared/selection-control/selection-control.styles.d.ts +0 -2
  776. package/shared/selection-control/selection-control.styles.d.ts.map +0 -1
  777. package/shared/selection-control/selection-control.styles.js +0 -67
  778. package/shared/selection-control/selection-control.styles.js.map +0 -1
  779. package/shared/sets/set-base.d.ts +0 -11
  780. package/shared/sets/set-base.d.ts.map +0 -1
  781. package/shared/sets/set-base.js +0 -22
  782. package/shared/sets/set-base.js.map +0 -1
  783. package/shared/sets/set-base.styles.d.ts +0 -2
  784. package/shared/sets/set-base.styles.d.ts.map +0 -1
  785. package/shared/sets/set-base.styles.js +0 -22
  786. package/shared/sets/set-base.styles.js.map +0 -1
  787. package/shared/text-field-base/text-field-base.d.ts +0 -16
  788. package/shared/text-field-base/text-field-base.d.ts.map +0 -1
  789. package/shared/text-field-base/text-field-base.js +0 -29
  790. package/shared/text-field-base/text-field-base.js.map +0 -1
  791. package/shared/text-field-base/text-field-base.styles.d.ts +0 -2
  792. package/shared/text-field-base/text-field-base.styles.d.ts.map +0 -1
  793. package/shared/text-field-base/text-field-base.styles.js +0 -11
  794. package/shared/text-field-base/text-field-base.styles.js.map +0 -1
  795. package/snackbar/snackbar.d.ts +0 -40
  796. package/snackbar/snackbar.d.ts.map +0 -1
  797. package/snackbar/snackbar.js +0 -133
  798. package/snackbar/snackbar.js.map +0 -1
  799. package/snackbar/snackbar.styles.d.ts +0 -2
  800. package/snackbar/snackbar.styles.d.ts.map +0 -1
  801. package/snackbar/snackbar.styles.js +0 -81
  802. package/snackbar/snackbar.styles.js.map +0 -1
  803. package/switch/switch-list-item.d.ts +0 -11
  804. package/switch/switch-list-item.d.ts.map +0 -1
  805. package/switch/switch-list-item.js +0 -11
  806. package/switch/switch-list-item.js.map +0 -1
  807. package/switch/switch.d.ts +0 -14
  808. package/switch/switch.d.ts.map +0 -1
  809. package/switch/switch.js +0 -26
  810. package/switch/switch.js.map +0 -1
  811. package/switch/switch.styles.d.ts +0 -2
  812. package/switch/switch.styles.d.ts.map +0 -1
  813. package/switch/switch.styles.js +0 -78
  814. package/switch/switch.styles.js.map +0 -1
  815. package/tab-bar/tab-bar.d.ts +0 -28
  816. package/tab-bar/tab-bar.d.ts.map +0 -1
  817. package/tab-bar/tab-bar.js +0 -200
  818. package/tab-bar/tab-bar.js.map +0 -1
  819. package/tab-bar/tab-bar.styles.d.ts +0 -2
  820. package/tab-bar/tab-bar.styles.d.ts.map +0 -1
  821. package/tab-bar/tab-bar.styles.js +0 -72
  822. package/tab-bar/tab-bar.styles.js.map +0 -1
  823. package/tab-bar/tab.d.ts +0 -22
  824. package/tab-bar/tab.d.ts.map +0 -1
  825. package/tab-bar/tab.js +0 -91
  826. package/tab-bar/tab.js.map +0 -1
  827. package/tab-bar/tab.styles.d.ts +0 -2
  828. package/tab-bar/tab.styles.d.ts.map +0 -1
  829. package/tab-bar/tab.styles.js +0 -56
  830. package/tab-bar/tab.styles.js.map +0 -1
  831. package/text-area/text-area.d.ts +0 -15
  832. package/text-area/text-area.d.ts.map +0 -1
  833. package/text-area/text-area.js +0 -46
  834. package/text-area/text-area.js.map +0 -1
  835. package/text-area/text-area.styles.d.ts +0 -2
  836. package/text-area/text-area.styles.d.ts.map +0 -1
  837. package/text-area/text-area.styles.js +0 -39
  838. package/text-area/text-area.styles.js.map +0 -1
  839. package/text-field/text-field.d.ts +0 -19
  840. package/text-field/text-field.d.ts.map +0 -1
  841. package/text-field/text-field.js +0 -66
  842. package/text-field/text-field.js.map +0 -1
  843. package/text-field/text-field.styles.d.ts +0 -2
  844. package/text-field/text-field.styles.d.ts.map +0 -1
  845. package/text-field/text-field.styles.js +0 -41
  846. package/text-field/text-field.styles.js.map +0 -1
  847. package/theme/color.d.ts +0 -7
  848. package/theme/color.d.ts.map +0 -1
  849. package/theme/color.js +0 -2
  850. package/theme/color.js.map +0 -1
  851. package/theme/css-var-builder.d.ts +0 -10
  852. package/theme/css-var-builder.d.ts.map +0 -1
  853. package/theme/css-var-builder.js +0 -27
  854. package/theme/css-var-builder.js.map +0 -1
  855. package/theme/index.d.ts +0 -2
  856. package/theme/index.d.ts.map +0 -1
  857. package/theme/index.js +0 -2
  858. package/theme/index.js.map +0 -1
  859. package/theme/neutral-colors.d.ts +0 -4
  860. package/theme/neutral-colors.d.ts.map +0 -1
  861. package/theme/neutral-colors.js +0 -24
  862. package/theme/neutral-colors.js.map +0 -1
  863. package/theme/theme-builder.d.ts +0 -26
  864. package/theme/theme-builder.d.ts.map +0 -1
  865. package/theme/theme-builder.js +0 -146
  866. package/theme/theme-builder.js.map +0 -1
  867. package/theme/theme-color.d.ts +0 -6
  868. package/theme/theme-color.d.ts.map +0 -1
  869. package/theme/theme-color.js +0 -2
  870. package/theme/theme-color.js.map +0 -1
  871. package/typeahead/highlight.d.ts +0 -24
  872. package/typeahead/highlight.d.ts.map +0 -1
  873. package/typeahead/highlight.js +0 -69
  874. package/typeahead/highlight.js.map +0 -1
  875. package/typeahead/highlight.styles.d.ts +0 -2
  876. package/typeahead/highlight.styles.d.ts.map +0 -1
  877. package/typeahead/highlight.styles.js +0 -7
  878. package/typeahead/highlight.styles.js.map +0 -1
  879. package/typeahead/typeahead.d.ts +0 -94
  880. package/typeahead/typeahead.d.ts.map +0 -1
  881. package/typeahead/typeahead.js +0 -362
  882. package/typeahead/typeahead.js.map +0 -1
  883. package/typeahead/typeahead.styles.d.ts +0 -2
  884. package/typeahead/typeahead.styles.d.ts.map +0 -1
  885. package/typeahead/typeahead.styles.js +0 -11
  886. package/typeahead/typeahead.styles.js.map +0 -1
  887. /package/{scss → src/scss}/_api.scss +0 -0
  888. /package/{scss → src/scss}/_colors.scss +0 -0
  889. /package/{scss → src/scss}/_css-vars.scss +0 -0
  890. /package/{scss → src/scss}/_functions.scss +0 -0
  891. /package/{scss → src/scss}/_global.scss +0 -0
  892. /package/{scss → src/scss}/_layout.scss +0 -0
  893. /package/{scss → src/scss}/_mixins.scss +0 -0
  894. /package/{scss → src/scss}/_reboot.scss +0 -0
  895. /package/{scss → src/scss}/_utilities.scss +0 -0
  896. /package/{scss → src/scss}/_variables.scss +0 -0
  897. /package/{scss → src/scss}/colors/_text-bg.scss +0 -0
  898. /package/{scss → src/scss}/colors/_text.scss +0 -0
  899. /package/{scss → src/scss}/functions/_font.scss +0 -0
  900. /package/{scss → src/scss}/layout/_container.scss +0 -0
  901. /package/{scss → src/scss}/layout/_grid.scss +0 -0
  902. /package/{scss → src/scss}/layout/_margin-and-gutters.scss +0 -0
  903. /package/{scss → src/scss}/mixins/_breakpoints.scss +0 -0
  904. /package/{scss → src/scss}/mixins/_colors.scss +0 -0
  905. /package/{scss → src/scss}/mixins/_text-bg.scss +0 -0
  906. /package/{scss → src/scss}/mixins/_typo.scss +0 -0
  907. /package/{scss → src/scss}/table/_table.scss +0 -0
  908. /package/{scss → src/scss}/typo/_font.scss +0 -0
  909. /package/{scss → src/scss}/typo/_typo.scss +0 -0
  910. /package/{scss → src/scss}/typo/_variables.scss +0 -0
  911. /package/{scss → src/scss}/universal-material.scss +0 -0
  912. /package/{scss → src/scss}/utilities/_divider.scss +0 -0
  913. /package/{scss → src/scss}/utilities/_scheme.scss +0 -0
  914. /package/{scss → src/scss}/utilities/_spacing.scss +0 -0
  915. /package/{scss → src/scss}/utilities/_text.scss +0 -0
@@ -1,362 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { html, LitElement } from 'lit';
3
- import { unsafeHTML } from 'lit-html/directives/unsafe-html.js';
4
- import { customElement, property, query, queryAll, state } from 'lit/decorators.js';
5
- import { MenuFieldNavigationController } from '../shared/menu-field/menu-field-navigation-controller.js';
6
- import { normalizeText } from '../shared/normalize-text.js';
7
- import { styles } from './typeahead.styles.js';
8
- import '../menu/menu.js';
9
- import '../menu/menu-item.js';
10
- import './highlight.js';
11
- let UmTypeahead = class UmTypeahead extends LitElement {
12
- static { this.formAssociated = true; }
13
- static { this.styles = styles; }
14
- #targetId;
15
- #connected;
16
- #documentMutationObserver;
17
- #navigationController;
18
- #termNormalized;
19
- #debounceTimeout;
20
- #value;
21
- #elementInternals;
22
- get form() {
23
- return this.#elementInternals.form;
24
- }
25
- /**
26
- * Gets or sets the current value of the typeahead.
27
- */
28
- get value() {
29
- return this.#value;
30
- }
31
- set value(value) {
32
- this.#value = value;
33
- this.#elementInternals.setFormValue(value);
34
- if (this.#connected) {
35
- this.#setValueOnTarget();
36
- }
37
- }
38
- focus() {
39
- this.target?.focus();
40
- }
41
- clear() {
42
- if (!this.target) {
43
- return;
44
- }
45
- this.#termNormalized = '';
46
- this.setTargetValue('');
47
- }
48
- /**
49
- * The id of the target element to attach the typeahead.
50
- */
51
- get targetId() {
52
- return this.#targetId;
53
- }
54
- set targetId(value) {
55
- this.#targetId = value;
56
- if (this.#connected) {
57
- this.#attach();
58
- }
59
- }
60
- get _menuItems() {
61
- return Array.from(this.menuItems);
62
- }
63
- constructor() {
64
- super();
65
- this.#connected = false;
66
- this.target = null;
67
- this.#documentMutationObserver = null;
68
- this.#navigationController = new MenuFieldNavigationController(this);
69
- this.#termNormalized = '';
70
- this.#debounceTimeout = null;
71
- /**
72
- * The time in milliseconds before triggering an update in the results.
73
- */
74
- this.debounce = 300;
75
- /**
76
- * The number of suggestions to show
77
- */
78
- this.limit = 10;
79
- /**
80
- * How many characters must be typed before show suggestions
81
- *
82
- * _Note:_ Not used when the source is a `Promise`
83
- */
84
- this.minLength = 2;
85
- /**
86
- * Whether the menu will be show when the target get focus.
87
- *
88
- * _Note:_ The `minLength` will still be applied
89
- */
90
- this.openOnFocus = false;
91
- /**
92
- * If `true`, model values will not be restricted only to items selected from the menu.
93
- */
94
- this.editable = false;
95
- /**
96
- * The value for the `autocomplete` attribute for the target element.
97
- */
98
- this.autocomplete = 'off';
99
- /**
100
- * The value for the `spellcheck` attribute for the target element.
101
- */
102
- this.spellcheck = false;
103
- this.#handleFocus = async () => {
104
- if (this.openOnFocus) {
105
- await this.#updateResults();
106
- }
107
- };
108
- this.#handleInput = () => {
109
- if (this.#debounceTimeout) {
110
- clearTimeout(this.#debounceTimeout);
111
- }
112
- this.#setValueAndDispatchEvents(this.editable ? this.getTargetValue() : null, true);
113
- this.#debounceTimeout = setTimeout(async () => await this.#updateResults(true), this.debounce);
114
- };
115
- this.#elementInternals = this.attachInternals();
116
- }
117
- attributeChangedCallback(name, _old, value) {
118
- super.attributeChangedCallback(name, _old, value);
119
- if (!this.target) {
120
- return;
121
- }
122
- if (name === 'autocomplete') {
123
- this.target.autocomplete = value;
124
- }
125
- if (name === 'spellcheck') {
126
- this.target.spellcheck = value === 'true';
127
- }
128
- }
129
- connectedCallback() {
130
- super.connectedCallback();
131
- this.#connected = true;
132
- this.#attach();
133
- this.#documentMutationObserver = new MutationObserver(() => this.#attach());
134
- this.#documentMutationObserver.observe(document, {
135
- attributes: true,
136
- childList: true,
137
- });
138
- }
139
- disconnectedCallback() {
140
- super.disconnectedCallback();
141
- this.#connected = false;
142
- this.#detach();
143
- this.#documentMutationObserver.disconnect();
144
- this.#documentMutationObserver = null;
145
- }
146
- #attach() {
147
- if (!this.targetId) {
148
- this.#detach();
149
- return;
150
- }
151
- const newTarget = document.getElementById(this.targetId);
152
- if (newTarget === this.target) {
153
- return;
154
- }
155
- this.#detach();
156
- if (!newTarget) {
157
- return;
158
- }
159
- // @ts-ignore
160
- this.target = newTarget;
161
- newTarget.role = 'combobox';
162
- newTarget.autocomplete = this.autocomplete;
163
- newTarget.spellcheck = this.spellcheck;
164
- newTarget.autocapitalize = 'off';
165
- newTarget.addEventListener('click', this.#handleClick);
166
- newTarget.addEventListener('input', this.#handleInput);
167
- this.#navigationController.attach(newTarget);
168
- newTarget.addEventListener('focus', this.#handleFocus);
169
- if (this.value) {
170
- this.#setValueOnTarget();
171
- }
172
- }
173
- #detach() {
174
- this.target?.removeEventListener('click', this.#handleClick);
175
- this.target?.removeEventListener('input', this.#handleInput);
176
- this.#navigationController.detach();
177
- this.target?.removeEventListener('focus', this.#handleFocus);
178
- }
179
- #handleItemMouseDown(e) {
180
- e.preventDefault();
181
- }
182
- #handleClick(e) {
183
- e.stopPropagation();
184
- }
185
- #handleFocus;
186
- #handleInput;
187
- #getItemClickHandler(data) {
188
- return () => {
189
- const selectedEvent = new CustomEvent('selected', {
190
- cancelable: true,
191
- detail: data.value,
192
- });
193
- this.dispatchEvent(selectedEvent);
194
- if (selectedEvent.defaultPrevented) {
195
- return;
196
- }
197
- this.#setValueAndDispatchEvents(data.value);
198
- };
199
- }
200
- #setValueAndDispatchEvents(value, direct = false) {
201
- if (!direct) {
202
- this.value = value;
203
- }
204
- else {
205
- this.#value = value;
206
- this.#elementInternals.setFormValue(value);
207
- }
208
- this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));
209
- this.dispatchEvent(new Event('change', { bubbles: true }));
210
- }
211
- render() {
212
- if (!this.results?.length) {
213
- return html ``;
214
- }
215
- setTimeout(() => {
216
- this._menu.anchorElement = this.getMenuAnchor();
217
- this._menu.open = true;
218
- this.#navigationController.focusMenu(this._menuItems[0], 0);
219
- });
220
- return html `
221
- <u-menu manualFocus manualClose anchor-corner="auto-start">
222
- ${this.results.map(result => {
223
- const content = this.template
224
- ? unsafeHTML(this.template(this.#termNormalized, result.value))
225
- : html `
226
- <u-highlight .term=${this.#termNormalized} .result=${result.label}></u-highlight>
227
- `;
228
- return html `
229
- <u-menu-item
230
- @mousedown=${this.#handleItemMouseDown}
231
- @click=${this.#getItemClickHandler(result)}
232
- tabindex="-1">
233
- ${content}
234
- </u-menu-item>
235
- `;
236
- })}
237
- </u-menu>
238
- `;
239
- }
240
- async #updateResults(lazy = false) {
241
- const term = this.getTargetValue();
242
- const termNormalized = normalizeText(term).toLowerCase();
243
- if (lazy && termNormalized === this.#termNormalized && this._menu?.open === true) {
244
- return;
245
- }
246
- this.#termNormalized = termNormalized;
247
- if (termNormalized.length < this.minLength) {
248
- this.results = [];
249
- return;
250
- }
251
- this.results = await this.#getData();
252
- this.results = this.results.slice(0, this.limit || this.results.length);
253
- }
254
- async #getData() {
255
- if (!this.source) {
256
- return [];
257
- }
258
- let values;
259
- let filter = false;
260
- if (this.source instanceof Array) {
261
- values = this.source;
262
- filter = true;
263
- }
264
- else {
265
- const source = this.source;
266
- values = await source(this.#termNormalized);
267
- }
268
- const result = values.map(source => ({
269
- label: this.formatter ? this.formatter(source) : source.toString(),
270
- value: source,
271
- }));
272
- if (!filter) {
273
- return result;
274
- }
275
- return result.filter(t => normalizeText(t.label).toLowerCase()
276
- .includes(this.#termNormalized));
277
- }
278
- #setValueOnTarget() {
279
- if (!this.target) {
280
- return;
281
- }
282
- const textValue = this.getTextValue();
283
- this.#termNormalized = normalizeText(textValue)?.toLowerCase();
284
- if (this.target.tagName === 'U-TEXT-FIELD') {
285
- this.target.value = textValue;
286
- return;
287
- }
288
- if (this.target.input) {
289
- this.target.input.value = textValue;
290
- return;
291
- }
292
- this.target.value = textValue;
293
- }
294
- getTargetValue() {
295
- return this.target.input?.value ?? this.target.value;
296
- }
297
- setTargetValue(value) {
298
- const targetInput = this.target?.input ?? this.target;
299
- if (targetInput) {
300
- targetInput.value = value;
301
- }
302
- }
303
- getMenuAnchor() {
304
- if (!this.target) {
305
- return null;
306
- }
307
- if (this.target.tagName === 'U-CHIP-FIELD') {
308
- return this.target.input;
309
- }
310
- if (this.target.tagName === 'U-TEXT-FIELD') {
311
- return this.target.container;
312
- }
313
- return this.target;
314
- }
315
- getTextValue() {
316
- if (!this.value) {
317
- return '';
318
- }
319
- return this.formatter ? this.formatter(this.value) : this.value;
320
- }
321
- };
322
- __decorate([
323
- state()
324
- ], UmTypeahead.prototype, "results", void 0);
325
- __decorate([
326
- state()
327
- ], UmTypeahead.prototype, "source", void 0);
328
- __decorate([
329
- property({ type: Number, reflect: true })
330
- ], UmTypeahead.prototype, "debounce", void 0);
331
- __decorate([
332
- property({ type: Number, reflect: true })
333
- ], UmTypeahead.prototype, "limit", void 0);
334
- __decorate([
335
- property({ type: Number, reflect: true })
336
- ], UmTypeahead.prototype, "minLength", void 0);
337
- __decorate([
338
- property({ type: Boolean, attribute: 'open-on-focus', reflect: true })
339
- ], UmTypeahead.prototype, "openOnFocus", void 0);
340
- __decorate([
341
- property({ type: Boolean, reflect: true })
342
- ], UmTypeahead.prototype, "editable", void 0);
343
- __decorate([
344
- property({ reflect: true })
345
- ], UmTypeahead.prototype, "autocomplete", void 0);
346
- __decorate([
347
- property({ reflect: true })
348
- ], UmTypeahead.prototype, "spellcheck", void 0);
349
- __decorate([
350
- property({ reflect: true, attribute: 'target-id' })
351
- ], UmTypeahead.prototype, "targetId", null);
352
- __decorate([
353
- query('u-menu')
354
- ], UmTypeahead.prototype, "_menu", void 0);
355
- __decorate([
356
- queryAll('u-menu-item')
357
- ], UmTypeahead.prototype, "menuItems", void 0);
358
- UmTypeahead = __decorate([
359
- customElement('u-typeahead')
360
- ], UmTypeahead);
361
- export { UmTypeahead };
362
- //# sourceMappingURL=typeahead.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typeahead.js","sourceRoot":"","sources":["../../src/typeahead/typeahead.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, HTMLTemplateResult, LitElement } from 'lit';\nimport { unsafeHTML } from 'lit-html/directives/unsafe-html.js';\nimport { customElement, property, query, queryAll, state } from 'lit/decorators.js';\n\nimport { UmMenuItem } from '../menu/menu-item.js';\nimport { UmMenu } from '../menu/menu.js';\nimport { MenuFieldNavigationController } from '../shared/menu-field/menu-field-navigation-controller.js';\nimport { normalizeText } from '../shared/normalize-text.js';\nimport { styles } from './typeahead.styles.js';\n\nimport '../menu/menu.js';\nimport '../menu/menu-item.js';\nimport './highlight.js';\n\nexport interface Data {\n label: string;\n value: any;\n}\n\n@customElement('u-typeahead')\nexport class UmTypeahead extends LitElement {\n static readonly formAssociated = true;\n\n static override styles = styles;\n\n #targetId: string | undefined;\n\n #connected = false;\n private target:\n | (HTMLElement & {\n autocomplete: 'on' | 'off' | string | null;\n input?: HTMLInputElement;\n container?: HTMLElement;\n value: string;\n })\n | null = null;\n #documentMutationObserver: MutationObserver | null = null;\n readonly #navigationController = new MenuFieldNavigationController(this);\n #termNormalized = '';\n #debounceTimeout: number | null = null;\n #value: any;\n readonly #elementInternals: ElementInternals;\n\n // @ts-ignore\n @state() private results: Data[];\n\n /**\n * The datasource of the typeahead. Accepts an `Array` or a `Promise<[]>`.\n */\n @state() source: (any[] | ((term: string) => Promise<any[]>)) | undefined;\n\n /**\n * A function return a string based on a result from the `source`. Useful when the source results are objects.\n */\n formatter: ((value: any) => string) | undefined;\n\n /**\n * A string representing an HTML to be rendered inside the menu item. If set, it will replace the `u-highlight`.\n *\n * _Note:_ Subject to signature change\n */\n template: ((term: string, value: any) => string) | undefined;\n\n /**\n * The time in milliseconds before triggering an update in the results.\n */\n @property({ type: Number, reflect: true }) debounce = 300;\n\n /**\n * The number of suggestions to show\n */\n @property({ type: Number, reflect: true }) limit = 10;\n\n /**\n * How many characters must be typed before show suggestions\n *\n * _Note:_ Not used when the source is a `Promise`\n */\n @property({ type: Number, reflect: true }) minLength = 2;\n\n /**\n * Whether the menu will be show when the target get focus.\n *\n * _Note:_ The `minLength` will still be applied\n */\n @property({ type: Boolean, attribute: 'open-on-focus', reflect: true })\n openOnFocus = false;\n\n /**\n * If `true`, model values will not be restricted only to items selected from the menu.\n */\n @property({ type: Boolean, reflect: true }) editable = false;\n\n /**\n * The value for the `autocomplete` attribute for the target element.\n */\n @property({ reflect: true }) autocomplete: 'on' | 'off' | string = 'off';\n\n /**\n * The value for the `spellcheck` attribute for the target element.\n */\n @property({ reflect: true }) override spellcheck = false;\n\n get form(): HTMLFormElement | null {\n return this.#elementInternals.form;\n }\n\n /**\n * Gets or sets the current value of the typeahead.\n */\n get value(): any {\n return this.#value;\n }\n\n set value(value: any) {\n this.#value = value;\n this.#elementInternals.setFormValue(value);\n\n if (this.#connected) {\n this.#setValueOnTarget();\n }\n }\n\n override focus() {\n this.target?.focus();\n }\n\n clear() {\n if (!this.target) {\n return;\n }\n\n this.#termNormalized = '';\n this.setTargetValue('');\n }\n\n /**\n * The id of the target element to attach the typeahead.\n */\n @property({ reflect: true, attribute: 'target-id' })\n get targetId(): string | undefined {\n return this.#targetId;\n }\n\n set targetId(value: string | undefined) {\n this.#targetId = value;\n\n if (this.#connected) {\n this.#attach();\n }\n }\n\n @query('u-menu') _menu!: UmMenu;\n @queryAll('u-menu-item') menuItems!: NodeListOf<UmMenuItem>;\n\n get _menuItems(): UmMenuItem[] {\n return Array.from(this.menuItems);\n }\n\n constructor() {\n super();\n this.#elementInternals = this.attachInternals();\n }\n\n override attributeChangedCallback(name: string, _old: string | null, value: string | null) {\n super.attributeChangedCallback(name, _old, value);\n\n if (!this.target) {\n return;\n }\n\n if (name === 'autocomplete') {\n this.target.autocomplete = value;\n }\n\n if (name === 'spellcheck') {\n this.target.spellcheck = value === 'true';\n }\n }\n\n override connectedCallback() {\n super.connectedCallback();\n this.#connected = true;\n this.#attach();\n this.#documentMutationObserver = new MutationObserver(() => this.#attach());\n this.#documentMutationObserver.observe(document, {\n attributes: true,\n childList: true,\n });\n }\n\n override disconnectedCallback() {\n super.disconnectedCallback();\n this.#connected = false;\n this.#detach();\n this.#documentMutationObserver!.disconnect();\n this.#documentMutationObserver = null;\n }\n\n #attach() {\n if (!this.targetId) {\n this.#detach();\n return;\n }\n\n const newTarget = document.getElementById(this.targetId) as HTMLInputElement;\n\n if (newTarget === this.target) {\n return;\n }\n\n this.#detach();\n\n if (!newTarget) {\n return;\n }\n\n // @ts-ignore\n this.target = newTarget;\n newTarget.role = 'combobox';\n newTarget.autocomplete = this.autocomplete as any;\n newTarget.spellcheck = this.spellcheck;\n newTarget.autocapitalize = 'off';\n\n newTarget.addEventListener('click', this.#handleClick);\n newTarget.addEventListener('input', this.#handleInput);\n this.#navigationController.attach(newTarget);\n newTarget.addEventListener('focus', this.#handleFocus);\n\n if (this.value) {\n this.#setValueOnTarget();\n }\n }\n\n #detach() {\n this.target?.removeEventListener('click', this.#handleClick);\n this.target?.removeEventListener('input', this.#handleInput);\n this.#navigationController.detach();\n this.target?.removeEventListener('focus', this.#handleFocus);\n }\n\n #handleItemMouseDown(e: Event) {\n e.preventDefault();\n }\n\n #handleClick(e: Event) {\n e.stopPropagation();\n }\n\n readonly #handleFocus = async () => {\n if (this.openOnFocus) {\n await this.#updateResults();\n }\n };\n\n readonly #handleInput = () => {\n if (this.#debounceTimeout) {\n clearTimeout(this.#debounceTimeout);\n }\n\n this.#setValueAndDispatchEvents(this.editable ? this.getTargetValue() : null, true);\n\n this.#debounceTimeout = setTimeout(async () => await this.#updateResults(true), this.debounce);\n };\n\n #getItemClickHandler(data: Data) {\n return () => {\n const selectedEvent = new CustomEvent('selected', {\n cancelable: true,\n detail: data.value,\n });\n\n this.dispatchEvent(selectedEvent);\n\n if (selectedEvent.defaultPrevented) {\n return;\n }\n\n this.#setValueAndDispatchEvents(data.value);\n };\n }\n\n #setValueAndDispatchEvents(value: any, direct = false) {\n if (!direct) {\n this.value = value;\n } else {\n this.#value = value;\n this.#elementInternals.setFormValue(value);\n }\n\n this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n this.dispatchEvent(new Event('change', { bubbles: true }));\n }\n\n protected override render(): HTMLTemplateResult {\n if (!this.results?.length) {\n return html``;\n }\n\n setTimeout(() => {\n this._menu.anchorElement = this.getMenuAnchor();\n this._menu.open = true;\n this.#navigationController.focusMenu(this._menuItems[0], 0);\n });\n\n return html`\n <u-menu manualFocus manualClose anchor-corner=\"auto-start\">\n ${this.results.map(result => {\n const content = this.template\n ? unsafeHTML(this.template(this.#termNormalized, result.value))\n : html`\n <u-highlight .term=${this.#termNormalized} .result=${result.label}></u-highlight>\n `;\n\n return html`\n <u-menu-item\n @mousedown=${this.#handleItemMouseDown}\n @click=${this.#getItemClickHandler(result)}\n tabindex=\"-1\">\n ${content}\n </u-menu-item>\n `;\n })}\n </u-menu>\n `;\n }\n\n async #updateResults(lazy = false) {\n const term = this.getTargetValue();\n\n const termNormalized = normalizeText(term).toLowerCase();\n\n if (lazy && termNormalized === this.#termNormalized && this._menu?.open === true) {\n return;\n }\n\n this.#termNormalized = termNormalized;\n\n if (termNormalized.length < this.minLength) {\n this.results = [];\n return;\n }\n\n this.results = await this.#getData();\n this.results = this.results.slice(0, this.limit || this.results.length);\n }\n\n async #getData(): Promise<Data[]> {\n if (!this.source) {\n return [];\n }\n\n let values: any[];\n\n let filter = false;\n\n if (this.source instanceof Array) {\n values = this.source;\n filter = true;\n } else {\n const source = this.source as (term: string) => Promise<any[]>;\n values = await source(this.#termNormalized);\n }\n\n const result = values.map(source => ({\n label: this.formatter ? this.formatter(source) : source.toString(),\n value: source,\n }));\n\n if (!filter) {\n return result;\n }\n\n return result.filter(t => normalizeText(t.label).toLowerCase()\n .includes(this.#termNormalized));\n }\n\n #setValueOnTarget() {\n if (!this.target) {\n return;\n }\n\n const textValue = this.getTextValue();\n this.#termNormalized = normalizeText(textValue)?.toLowerCase();\n\n if (this.target.tagName === 'U-TEXT-FIELD') {\n this.target.value = textValue;\n return;\n }\n\n if (this.target.input) {\n this.target.input.value = textValue;\n return;\n }\n\n this.target.value = textValue;\n }\n\n private getTargetValue(): string {\n return this.target!.input?.value ?? this.target!.value;\n }\n\n private setTargetValue(value: string): void {\n const targetInput = this.target?.input ?? this.target;\n\n if (targetInput) {\n targetInput.value = value;\n }\n }\n\n private getMenuAnchor() {\n if (!this.target) {\n return null;\n }\n\n if (this.target.tagName === 'U-CHIP-FIELD') {\n return this.target.input;\n }\n\n if (this.target.tagName === 'U-TEXT-FIELD') {\n return this.target.container;\n }\n\n return this.target;\n }\n\n private getTextValue(): string {\n if (!this.value) {\n return '';\n }\n\n return this.formatter ? this.formatter(this.value) : this.value;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-typeahead': UmTypeahead;\n }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export declare const styles: import("lit").CSSResult;
2
- //# sourceMappingURL=typeahead.styles.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typeahead.styles.d.ts","sourceRoot":"","sources":["../../src/typeahead/typeahead.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAQlB,CAAC"}
@@ -1,11 +0,0 @@
1
- import { css } from 'lit';
2
- export const styles = css `
3
- :host {
4
- display: block;
5
- }
6
-
7
- u-menu-item {
8
- font-weight: var(--u-typeahead-item-font-weight, var(--u-font-weight-regular, 400));
9
- }
10
- `;
11
- //# sourceMappingURL=typeahead.styles.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typeahead.styles.js","sourceRoot":"","sources":["../../src/typeahead/typeahead.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC;;;;;;;;CAQzB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const styles = css `\n :host {\n display: block;\n }\n\n u-menu-item {\n font-weight: var(--u-typeahead-item-font-weight, var(--u-font-weight-regular, 400));\n }\n`;\n"]}
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes