@nanoporetech-digital/components 1.15.6 → 2.0.0

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 (981) hide show
  1. package/CHANGELOG.md +43 -0
  2. package/dist/cjs/active-element-2f9bf0aa.js +21 -0
  3. package/dist/cjs/active-element-2f9bf0aa.js.map +1 -0
  4. package/dist/cjs/{algoliasearch.umd-0ccd70ce.js → algoliasearch.umd-4d15f5e0.js} +3 -3
  5. package/dist/cjs/{algoliasearch.umd-0ccd70ce.js.map → algoliasearch.umd-4d15f5e0.js.map} +1 -1
  6. package/dist/cjs/{dom-5f3fae1a.js → dom-52f9b8b7.js} +25 -6
  7. package/dist/cjs/dom-52f9b8b7.js.map +1 -0
  8. package/dist/cjs/form-control-3bc82e3e.js +80 -0
  9. package/dist/cjs/form-control-3bc82e3e.js.map +1 -0
  10. package/dist/cjs/{index-117f36a4.js → index-53d02e05.js} +12 -27
  11. package/dist/cjs/index-53d02e05.js.map +1 -0
  12. package/dist/cjs/index-cb62df44.js +12 -12
  13. package/dist/cjs/index.cjs.js +3 -3
  14. package/dist/cjs/index.cjs.js.map +1 -1
  15. package/dist/cjs/loader.cjs.js +1 -1
  16. package/dist/cjs/{modal-01eed1bf.js → modal-f09e431f.js} +2 -2
  17. package/dist/cjs/{modal-01eed1bf.js.map → modal-f09e431f.js.map} +1 -1
  18. package/dist/cjs/nano-accordion.cjs.entry.js +2 -4
  19. package/dist/cjs/nano-accordion.cjs.entry.js.map +1 -1
  20. package/dist/cjs/nano-alert.cjs.entry.js +6 -6
  21. package/dist/cjs/nano-alert.cjs.entry.js.map +1 -1
  22. package/dist/cjs/nano-algolia-filter.cjs.entry.js +1 -1
  23. package/dist/cjs/nano-algolia-filter.cjs.entry.js.map +1 -1
  24. package/dist/cjs/nano-algolia-input.cjs.entry.js +1 -1
  25. package/dist/cjs/nano-algolia.cjs.entry.js +9 -5
  26. package/dist/cjs/nano-algolia.cjs.entry.js.map +1 -1
  27. package/dist/cjs/nano-aspect-ratio.cjs.entry.js +1 -1
  28. package/dist/cjs/nano-aspect-ratio.cjs.entry.js.map +1 -1
  29. package/dist/cjs/nano-checkbox-group.cjs.entry.js +4 -1
  30. package/dist/cjs/nano-checkbox-group.cjs.entry.js.map +1 -1
  31. package/dist/cjs/nano-checkbox.cjs.entry.js +1 -1
  32. package/dist/cjs/nano-checkbox.cjs.entry.js.map +1 -1
  33. package/dist/cjs/nano-components.cjs.js +1 -1
  34. package/dist/cjs/nano-datalist_3.cjs.entry.js +776 -0
  35. package/dist/cjs/nano-datalist_3.cjs.entry.js.map +1 -0
  36. package/dist/cjs/nano-date-input.cjs.entry.js +9 -5
  37. package/dist/cjs/nano-date-input.cjs.entry.js.map +1 -1
  38. package/dist/cjs/{nano-date-picker_2.cjs.entry.js → nano-date-picker.cjs.entry.js} +2 -274
  39. package/dist/cjs/nano-date-picker.cjs.entry.js.map +1 -0
  40. package/dist/cjs/nano-details.cjs.entry.js +2 -2
  41. package/dist/cjs/nano-details.cjs.entry.js.map +1 -1
  42. package/dist/cjs/nano-dialog.cjs.entry.js +5 -5
  43. package/dist/cjs/nano-dialog.cjs.entry.js.map +1 -1
  44. package/dist/cjs/nano-drawer.cjs.entry.js +5 -5
  45. package/dist/cjs/nano-drawer.cjs.entry.js.map +1 -1
  46. package/dist/cjs/nano-dropdown.cjs.entry.js +307 -0
  47. package/dist/cjs/nano-dropdown.cjs.entry.js.map +1 -0
  48. package/dist/cjs/nano-file-upload.cjs.entry.js +1 -1
  49. package/dist/cjs/nano-file-upload.cjs.entry.js.map +1 -1
  50. package/dist/cjs/nano-global-nav.cjs.entry.js +19 -24
  51. package/dist/cjs/nano-global-nav.cjs.entry.js.map +1 -1
  52. package/dist/cjs/nano-global-search-results.cjs.entry.js +200 -115
  53. package/dist/cjs/nano-global-search-results.cjs.entry.js.map +1 -1
  54. package/dist/cjs/nano-grid_3.cjs.entry.js +15 -7
  55. package/dist/cjs/nano-grid_3.cjs.entry.js.map +1 -1
  56. package/dist/cjs/nano-hero.cjs.entry.js +13 -5
  57. package/dist/cjs/nano-hero.cjs.entry.js.map +1 -1
  58. package/dist/cjs/nano-icon-button.cjs.entry.js +2 -2
  59. package/dist/cjs/nano-icon-button.cjs.entry.js.map +1 -1
  60. package/dist/cjs/nano-icon.cjs.entry.js +1 -1
  61. package/dist/cjs/nano-icon.cjs.entry.js.map +1 -1
  62. package/dist/cjs/nano-input.cjs.entry.js +80 -75
  63. package/dist/cjs/nano-input.cjs.entry.js.map +1 -1
  64. package/dist/cjs/nano-menu-drawer.cjs.entry.js +2 -2
  65. package/dist/cjs/nano-menu-drawer.cjs.entry.js.map +1 -1
  66. package/dist/cjs/nano-nav-item_2.cjs.entry.js +284 -533
  67. package/dist/cjs/nano-nav-item_2.cjs.entry.js.map +1 -1
  68. package/dist/cjs/nano-range.cjs.entry.js +2 -2
  69. package/dist/cjs/nano-range.cjs.entry.js.map +1 -1
  70. package/dist/cjs/nano-rating.cjs.entry.js +2 -2
  71. package/dist/cjs/nano-rating.cjs.entry.js.map +1 -1
  72. package/dist/cjs/nano-resize-observe_2.cjs.entry.js +1 -1
  73. package/dist/cjs/nano-resize-observe_2.cjs.entry.js.map +1 -1
  74. package/dist/cjs/nano-slide.cjs.entry.js +1 -1
  75. package/dist/cjs/nano-slide.cjs.entry.js.map +1 -1
  76. package/dist/cjs/nano-slides.cjs.entry.js +1 -1
  77. package/dist/cjs/nano-slides.cjs.entry.js.map +1 -1
  78. package/dist/cjs/nano-spinner.cjs.entry.js +1 -1
  79. package/dist/cjs/nano-spinner.cjs.entry.js.map +1 -1
  80. package/dist/cjs/nano-sticker.cjs.entry.js +3 -3
  81. package/dist/cjs/nano-sticker.cjs.entry.js.map +1 -1
  82. package/dist/cjs/nano-tab-content.cjs.entry.js +2 -2
  83. package/dist/cjs/nano-tab-content.cjs.entry.js.map +1 -1
  84. package/dist/cjs/nano-tab-group.cjs.entry.js +66 -33
  85. package/dist/cjs/nano-tab-group.cjs.entry.js.map +1 -1
  86. package/dist/cjs/nano-tab.cjs.entry.js +9 -2
  87. package/dist/cjs/nano-tab.cjs.entry.js.map +1 -1
  88. package/dist/cjs/nano-tooltip.cjs.entry.js +2 -2
  89. package/dist/cjs/nano-tooltip.cjs.entry.js.map +1 -1
  90. package/dist/cjs/{popover-d033efa2.js → popover-86f1775c.js} +10 -1
  91. package/dist/cjs/popover-86f1775c.js.map +1 -0
  92. package/dist/cjs/{scroll-d7753eed.js → scroll-6b9e6870.js} +2 -2
  93. package/dist/cjs/{scroll-d7753eed.js.map → scroll-6b9e6870.js.map} +1 -1
  94. package/dist/cjs/{tabbable-615c30e1.js → tabbable-de4c23d8.js} +8 -6
  95. package/dist/cjs/tabbable-de4c23d8.js.map +1 -0
  96. package/dist/collection/collection-manifest.json +3 -2
  97. package/dist/collection/components/accordion/accordion.css +3 -0
  98. package/dist/collection/components/accordion/accordion.js +2 -5
  99. package/dist/collection/components/accordion/accordion.js.map +1 -1
  100. package/dist/collection/components/alert/alert.css +5 -6
  101. package/dist/collection/components/alert/alert.helpers.js +2 -2
  102. package/dist/collection/components/alert/alert.helpers.js.map +1 -1
  103. package/dist/collection/components/alert/alert.js +1 -1
  104. package/dist/collection/components/algolia/algolia-filter.css +3 -0
  105. package/dist/collection/components/algolia/algolia-filter.js +2 -2
  106. package/dist/collection/components/algolia/algolia-input.js +5 -5
  107. package/dist/collection/components/algolia/algolia-results.js +1 -1
  108. package/dist/collection/components/algolia/algolia.css +3 -0
  109. package/dist/collection/components/algolia/algolia.js +6 -6
  110. package/dist/collection/components/aspect-ratio/aspect-ratio.css +3 -0
  111. package/dist/collection/components/checkbox/checkbox-group.css +3 -0
  112. package/dist/collection/components/checkbox/checkbox-group.js +5 -2
  113. package/dist/collection/components/checkbox/checkbox-group.js.map +1 -1
  114. package/dist/collection/components/checkbox/checkbox.css +3 -0
  115. package/dist/collection/components/checkbox/checkbox.js +3 -3
  116. package/dist/collection/components/datalist/datalist.css +55 -0
  117. package/dist/collection/components/datalist/datalist.js +782 -0
  118. package/dist/collection/components/datalist/datalist.js.map +1 -0
  119. package/dist/collection/components/date-input/date-input.css +3 -0
  120. package/dist/collection/components/date-input/date-input.js +18 -10
  121. package/dist/collection/components/date-input/date-input.js.map +1 -1
  122. package/dist/collection/components/date-picker/date-picker.css +3 -0
  123. package/dist/collection/components/date-picker/date-picker.js +5 -5
  124. package/dist/collection/components/details/details.css +3 -0
  125. package/dist/collection/components/details/details.js +2 -3
  126. package/dist/collection/components/details/details.js.map +1 -1
  127. package/dist/collection/components/dialog/dialog.css +4 -1
  128. package/dist/collection/components/dialog/dialog.helpers.js.map +1 -1
  129. package/dist/collection/components/dialog/dialog.js +1 -1
  130. package/dist/collection/components/drawer/drawer.css +3 -0
  131. package/dist/collection/components/dropdown/dropdown.css +19 -2
  132. package/dist/collection/components/dropdown/dropdown.js +56 -39
  133. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  134. package/dist/collection/components/file-upload/file-upload.css +5 -2
  135. package/dist/collection/components/file-upload/file-upload.js +4 -4
  136. package/dist/collection/components/form-control/form-control.js +73 -0
  137. package/dist/collection/components/form-control/form-control.js.map +1 -0
  138. package/dist/collection/components/global-nav/global-nav.css +43 -37
  139. package/dist/collection/components/global-nav/global-nav.js +21 -26
  140. package/dist/collection/components/global-nav/global-nav.js.map +1 -1
  141. package/dist/collection/components/global-search-results/global-search-results.css +299 -18
  142. package/dist/collection/components/global-search-results/global-search-results.js +200 -113
  143. package/dist/collection/components/global-search-results/global-search-results.js.map +1 -1
  144. package/dist/collection/components/grid/grid-item.css +3 -0
  145. package/dist/collection/components/grid/grid-item.js +1 -1
  146. package/dist/collection/components/grid/grid.css +3 -0
  147. package/dist/collection/components/grid/grid.js +37 -6
  148. package/dist/collection/components/grid/grid.js.map +1 -1
  149. package/dist/collection/components/hero/hero.css +13 -5
  150. package/dist/collection/components/hero/hero.js +32 -22
  151. package/dist/collection/components/hero/hero.js.map +1 -1
  152. package/dist/collection/components/icon/icon.css +3 -0
  153. package/dist/collection/components/icon/icon.js +1 -1
  154. package/dist/collection/components/icon-button/icon-button.css +6 -1
  155. package/dist/collection/components/icon-button/icon-button.js +1 -1
  156. package/dist/collection/components/icon-button/icon-button.js.map +1 -1
  157. package/dist/collection/components/img/img.css +3 -0
  158. package/dist/collection/components/input/input.css +242 -232
  159. package/dist/collection/components/input/input.js +111 -114
  160. package/dist/collection/components/input/input.js.map +1 -1
  161. package/dist/collection/components/menu/menu.css +27 -35
  162. package/dist/collection/components/menu/menu.js +222 -48
  163. package/dist/collection/components/menu/menu.js.map +1 -1
  164. package/dist/collection/components/menu-drawer/menu-drawer.css +3 -0
  165. package/dist/collection/components/nav-item/nav-item.css +3 -0
  166. package/dist/collection/components/nav-item/nav-item.js +5 -5
  167. package/dist/collection/components/nav-item/nav-item.js.map +1 -1
  168. package/dist/collection/components/option/option-interface.js +5 -0
  169. package/dist/collection/components/option/option-interface.js.map +1 -0
  170. package/dist/collection/components/option/option.css +187 -0
  171. package/dist/collection/components/option/option.js +242 -0
  172. package/dist/collection/components/option/option.js.map +1 -0
  173. package/dist/collection/components/range/range.css +3 -0
  174. package/dist/collection/components/range/range.js +4 -4
  175. package/dist/collection/components/rating/rating.css +3 -0
  176. package/dist/collection/components/resize-observe/resize-observe.js +1 -1
  177. package/dist/collection/components/select/select.css +458 -391
  178. package/dist/collection/components/select/select.js +364 -607
  179. package/dist/collection/components/select/select.js.map +1 -1
  180. package/dist/collection/components/skeleton/skeleton.css +3 -0
  181. package/dist/collection/components/slides/slide.css +3 -0
  182. package/dist/collection/components/slides/slides.css +3 -0
  183. package/dist/collection/components/slides/slides.js +7 -7
  184. package/dist/collection/components/spinner/spinner.css +3 -0
  185. package/dist/collection/components/sticky/sticker.css +3 -0
  186. package/dist/collection/components/tabs/tab-content.css +3 -0
  187. package/dist/collection/components/tabs/tab-content.js +3 -3
  188. package/dist/collection/components/tabs/tab-content.js.map +1 -1
  189. package/dist/collection/components/tabs/tab-group.css +16 -5
  190. package/dist/collection/components/tabs/tab-group.js +125 -38
  191. package/dist/collection/components/tabs/tab-group.js.map +1 -1
  192. package/dist/collection/components/tabs/tab.css +36 -6
  193. package/dist/collection/components/tabs/tab.js +45 -2
  194. package/dist/collection/components/tabs/tab.js.map +1 -1
  195. package/dist/collection/components/tooltip/tooltip.css +3 -0
  196. package/dist/collection/utils/active-element.js +16 -0
  197. package/dist/collection/utils/active-element.js.map +1 -0
  198. package/dist/collection/utils/dom.js +24 -5
  199. package/dist/collection/utils/dom.js.map +1 -1
  200. package/dist/collection/utils/index.js +13 -13
  201. package/dist/collection/utils/index.js.map +1 -1
  202. package/dist/collection/utils/popover.js +9 -0
  203. package/dist/collection/utils/popover.js.map +1 -1
  204. package/dist/collection/utils/tabbable.js +7 -5
  205. package/dist/collection/utils/tabbable.js.map +1 -1
  206. package/dist/collection/utils/template.js +5 -1
  207. package/dist/collection/utils/template.js.map +1 -1
  208. package/dist/collection/utils/testing/index.js +11 -1
  209. package/dist/collection/utils/testing/index.js.map +1 -1
  210. package/dist/components/ResizeObserver.es.js +933 -0
  211. package/dist/components/ResizeObserver.es.js.map +1 -0
  212. package/dist/components/_commonjsHelpers.js +41 -0
  213. package/dist/components/_commonjsHelpers.js.map +1 -0
  214. package/dist/components/active-element.js +19 -0
  215. package/dist/components/active-element.js.map +1 -0
  216. package/dist/components/algolia-data.js +49 -0
  217. package/dist/components/algolia-data.js.map +1 -0
  218. package/dist/components/algolia.js +906 -0
  219. package/dist/components/algolia.js.map +1 -0
  220. package/dist/components/algoliasearch.umd.js +13 -0
  221. package/dist/components/algoliasearch.umd.js.map +1 -0
  222. package/dist/components/component-store.js +2234 -0
  223. package/dist/components/component-store.js.map +1 -0
  224. package/dist/components/datalist.js +543 -0
  225. package/dist/components/datalist.js.map +1 -0
  226. package/dist/components/date-picker.js +624 -0
  227. package/dist/components/date-picker.js.map +1 -0
  228. package/dist/{esm/dom-a791b223.js → components/dom.js} +25 -6
  229. package/dist/components/dom.js.map +1 -0
  230. package/dist/components/dropdown.js +332 -0
  231. package/dist/components/dropdown.js.map +1 -0
  232. package/dist/components/focus-visible.js +66 -0
  233. package/dist/components/focus-visible.js.map +1 -0
  234. package/dist/components/form-control.js +77 -0
  235. package/dist/components/form-control.js.map +1 -0
  236. package/dist/components/grid-item.js +112 -0
  237. package/dist/components/grid-item.js.map +1 -0
  238. package/dist/components/grid.js +276 -0
  239. package/dist/components/grid.js.map +1 -0
  240. package/dist/components/icon-button.js +70 -0
  241. package/dist/components/icon-button.js.map +1 -0
  242. package/dist/components/icon.js +269 -0
  243. package/dist/components/icon.js.map +1 -0
  244. package/dist/components/img.js +184 -0
  245. package/dist/components/img.js.map +1 -0
  246. package/dist/components/index.d.ts +26 -0
  247. package/dist/components/index.js +251 -0
  248. package/dist/components/index.js.map +1 -0
  249. package/dist/{esm/index-f41ae118.js → components/index2.js} +13 -27
  250. package/dist/components/index2.js.map +1 -0
  251. package/dist/components/index3.js +1075 -0
  252. package/dist/components/index3.js.map +1 -0
  253. package/dist/components/index4.js +637 -0
  254. package/dist/components/index4.js.map +1 -0
  255. package/dist/components/input.js +474 -0
  256. package/dist/components/input.js.map +1 -0
  257. package/dist/components/intersection-observer.js +985 -0
  258. package/dist/components/intersection-observer.js.map +1 -0
  259. package/dist/components/local-my-account.js +353 -0
  260. package/dist/components/local-my-account.js.map +1 -0
  261. package/dist/components/menu.js +235 -0
  262. package/dist/components/menu.js.map +1 -0
  263. package/dist/components/modal.js +48 -0
  264. package/dist/components/modal.js.map +1 -0
  265. package/dist/components/nano-accordion.d.ts +11 -0
  266. package/dist/components/nano-accordion.js +63 -0
  267. package/dist/components/nano-accordion.js.map +1 -0
  268. package/dist/components/nano-alert.d.ts +11 -0
  269. package/dist/components/nano-alert.js +296 -0
  270. package/dist/components/nano-alert.js.map +1 -0
  271. package/dist/components/nano-algolia-filter.d.ts +11 -0
  272. package/dist/components/nano-algolia-filter.js +317 -0
  273. package/dist/components/nano-algolia-filter.js.map +1 -0
  274. package/dist/components/nano-algolia-input.d.ts +11 -0
  275. package/dist/components/nano-algolia-input.js +224 -0
  276. package/dist/components/nano-algolia-input.js.map +1 -0
  277. package/dist/components/nano-algolia-pagination.d.ts +11 -0
  278. package/dist/components/nano-algolia-pagination.js +104 -0
  279. package/dist/components/nano-algolia-pagination.js.map +1 -0
  280. package/dist/components/nano-algolia-results.d.ts +11 -0
  281. package/dist/components/nano-algolia-results.js +224 -0
  282. package/dist/components/nano-algolia-results.js.map +1 -0
  283. package/dist/components/nano-algolia.d.ts +11 -0
  284. package/dist/components/nano-algolia.js +11 -0
  285. package/dist/components/nano-algolia.js.map +1 -0
  286. package/dist/components/nano-aspect-ratio.d.ts +11 -0
  287. package/dist/components/nano-aspect-ratio.js +74 -0
  288. package/dist/components/nano-aspect-ratio.js.map +1 -0
  289. package/dist/components/nano-checkbox-group.d.ts +11 -0
  290. package/dist/components/nano-checkbox-group.js +235 -0
  291. package/dist/components/nano-checkbox-group.js.map +1 -0
  292. package/dist/components/nano-checkbox.d.ts +11 -0
  293. package/dist/components/nano-checkbox.js +231 -0
  294. package/dist/components/nano-checkbox.js.map +1 -0
  295. package/dist/components/nano-datalist.d.ts +11 -0
  296. package/dist/components/nano-datalist.js +11 -0
  297. package/dist/components/nano-datalist.js.map +1 -0
  298. package/dist/components/nano-date-input.d.ts +11 -0
  299. package/dist/components/nano-date-input.js +408 -0
  300. package/dist/components/nano-date-input.js.map +1 -0
  301. package/dist/components/nano-date-picker.d.ts +11 -0
  302. package/dist/components/nano-date-picker.js +11 -0
  303. package/dist/components/nano-date-picker.js.map +1 -0
  304. package/dist/components/nano-details.d.ts +11 -0
  305. package/dist/components/nano-details.js +162 -0
  306. package/dist/components/nano-details.js.map +1 -0
  307. package/dist/components/nano-dialog.d.ts +11 -0
  308. package/dist/components/nano-dialog.js +231 -0
  309. package/dist/components/nano-dialog.js.map +1 -0
  310. package/dist/components/nano-drawer.d.ts +11 -0
  311. package/dist/components/nano-drawer.js +217 -0
  312. package/dist/components/nano-drawer.js.map +1 -0
  313. package/dist/components/nano-dropdown.d.ts +11 -0
  314. package/dist/components/nano-dropdown.js +11 -0
  315. package/dist/components/nano-dropdown.js.map +1 -0
  316. package/dist/components/nano-file-upload.d.ts +11 -0
  317. package/dist/components/nano-file-upload.js +421 -0
  318. package/dist/components/nano-file-upload.js.map +1 -0
  319. package/dist/components/nano-global-nav.d.ts +11 -0
  320. package/dist/components/nano-global-nav.js +1221 -0
  321. package/dist/components/nano-global-nav.js.map +1 -0
  322. package/dist/components/nano-global-search-results.d.ts +11 -0
  323. package/dist/components/nano-global-search-results.js +608 -0
  324. package/dist/components/nano-global-search-results.js.map +1 -0
  325. package/dist/components/nano-grid-item.d.ts +11 -0
  326. package/dist/components/nano-grid-item.js +11 -0
  327. package/dist/components/nano-grid-item.js.map +1 -0
  328. package/dist/components/nano-grid.d.ts +11 -0
  329. package/dist/components/nano-grid.js +11 -0
  330. package/dist/components/nano-grid.js.map +1 -0
  331. package/dist/components/nano-hero.d.ts +11 -0
  332. package/dist/components/nano-hero.js +187 -0
  333. package/dist/components/nano-hero.js.map +1 -0
  334. package/dist/components/nano-icon-button.d.ts +11 -0
  335. package/dist/components/nano-icon-button.js +11 -0
  336. package/dist/components/nano-icon-button.js.map +1 -0
  337. package/dist/components/nano-icon.d.ts +11 -0
  338. package/dist/components/nano-icon.js +11 -0
  339. package/dist/components/nano-icon.js.map +1 -0
  340. package/dist/components/nano-img.d.ts +11 -0
  341. package/dist/components/nano-img.js +11 -0
  342. package/dist/components/nano-img.js.map +1 -0
  343. package/dist/components/nano-input.d.ts +11 -0
  344. package/dist/components/nano-input.js +11 -0
  345. package/dist/components/nano-input.js.map +1 -0
  346. package/dist/components/nano-menu-drawer.d.ts +11 -0
  347. package/dist/components/nano-menu-drawer.js +221 -0
  348. package/dist/components/nano-menu-drawer.js.map +1 -0
  349. package/dist/components/nano-menu.d.ts +11 -0
  350. package/dist/components/nano-menu.js +11 -0
  351. package/dist/components/nano-menu.js.map +1 -0
  352. package/dist/components/nano-nav-item.d.ts +11 -0
  353. package/dist/components/nano-nav-item.js +11 -0
  354. package/dist/components/nano-nav-item.js.map +1 -0
  355. package/dist/components/nano-option.d.ts +11 -0
  356. package/dist/components/nano-option.js +11 -0
  357. package/dist/components/nano-option.js.map +1 -0
  358. package/dist/components/nano-range.d.ts +11 -0
  359. package/dist/components/nano-range.js +430 -0
  360. package/dist/components/nano-range.js.map +1 -0
  361. package/dist/components/nano-rating.d.ts +11 -0
  362. package/dist/components/nano-rating.js +240 -0
  363. package/dist/components/nano-rating.js.map +1 -0
  364. package/dist/components/nano-resize-observe.d.ts +11 -0
  365. package/dist/components/nano-resize-observe.js +11 -0
  366. package/dist/components/nano-resize-observe.js.map +1 -0
  367. package/dist/components/nano-select.d.ts +11 -0
  368. package/dist/components/nano-select.js +11 -0
  369. package/dist/components/nano-select.js.map +1 -0
  370. package/dist/components/nano-skeleton.d.ts +11 -0
  371. package/dist/components/nano-skeleton.js +11 -0
  372. package/dist/components/nano-skeleton.js.map +1 -0
  373. package/dist/components/nano-slide.d.ts +11 -0
  374. package/dist/components/nano-slide.js +66 -0
  375. package/dist/components/nano-slide.js.map +1 -0
  376. package/dist/components/nano-slides.d.ts +11 -0
  377. package/dist/components/nano-slides.js +4335 -0
  378. package/dist/components/nano-slides.js.map +1 -0
  379. package/dist/components/nano-spinner.d.ts +11 -0
  380. package/dist/components/nano-spinner.js +11 -0
  381. package/dist/components/nano-spinner.js.map +1 -0
  382. package/dist/components/nano-sticker.d.ts +11 -0
  383. package/dist/components/nano-sticker.js +11 -0
  384. package/dist/components/nano-sticker.js.map +1 -0
  385. package/dist/components/nano-tab-content.d.ts +11 -0
  386. package/dist/components/nano-tab-content.js +49 -0
  387. package/dist/components/nano-tab-content.js.map +1 -0
  388. package/dist/components/nano-tab-group.d.ts +11 -0
  389. package/dist/components/nano-tab-group.js +457 -0
  390. package/dist/components/nano-tab-group.js.map +1 -0
  391. package/dist/components/nano-tab.d.ts +11 -0
  392. package/dist/components/nano-tab.js +86 -0
  393. package/dist/components/nano-tab.js.map +1 -0
  394. package/dist/components/nano-tooltip.d.ts +11 -0
  395. package/dist/components/nano-tooltip.js +11 -0
  396. package/dist/components/nano-tooltip.js.map +1 -0
  397. package/dist/components/nav-item.js +327 -0
  398. package/dist/components/nav-item.js.map +1 -0
  399. package/dist/components/option.js +120 -0
  400. package/dist/components/option.js.map +1 -0
  401. package/dist/{esm/popover-2c7b2326.js → components/popover.js} +10 -1
  402. package/dist/components/popover.js.map +1 -0
  403. package/dist/components/resize-observe.js +162 -0
  404. package/dist/components/resize-observe.js.map +1 -0
  405. package/dist/{esm/scroll-5cd0ab13.js → components/scroll.js} +2 -2
  406. package/dist/components/scroll.js.map +1 -0
  407. package/dist/components/select.js +667 -0
  408. package/dist/components/select.js.map +1 -0
  409. package/dist/components/skeleton.js +43 -0
  410. package/dist/components/skeleton.js.map +1 -0
  411. package/dist/components/slot.js +48 -0
  412. package/dist/components/slot.js.map +1 -0
  413. package/dist/components/spinner.js +49 -0
  414. package/dist/components/spinner.js.map +1 -0
  415. package/dist/components/sticker.js +665 -0
  416. package/dist/components/sticker.js.map +1 -0
  417. package/dist/{esm/tabbable-e21f860a.js → components/tabbable.js} +8 -6
  418. package/dist/components/tabbable.js.map +1 -0
  419. package/dist/components/theme.js +29 -0
  420. package/dist/components/theme.js.map +1 -0
  421. package/dist/components/throttle.js +55 -0
  422. package/dist/components/throttle.js.map +1 -0
  423. package/dist/components/tooltip.js +216 -0
  424. package/dist/components/tooltip.js.map +1 -0
  425. package/dist/custom-elements/index.d.ts +12 -6
  426. package/dist/custom-elements/index.js +1722 -1113
  427. package/dist/custom-elements/index.js.map +1 -1
  428. package/dist/esm/active-element-75b7c8a0.js +19 -0
  429. package/dist/esm/active-element-75b7c8a0.js.map +1 -0
  430. package/dist/esm/{algoliasearch.umd-8e5aff52.js → algoliasearch.umd-adbc4aa5.js} +3 -3
  431. package/dist/esm/{algoliasearch.umd-8e5aff52.js.map → algoliasearch.umd-adbc4aa5.js.map} +1 -1
  432. package/dist/esm/dom-faa69d29.js +75 -0
  433. package/dist/esm/dom-faa69d29.js.map +1 -0
  434. package/dist/esm/form-control-67eeb108.js +77 -0
  435. package/dist/esm/form-control-67eeb108.js.map +1 -0
  436. package/dist/esm/index-5f8d16e7.js +12 -12
  437. package/dist/esm/index-bf53664b.js +74 -0
  438. package/dist/esm/{index-f41ae118.js.map → index-bf53664b.js.map} +1 -1
  439. package/dist/esm/index.js +4 -4
  440. package/dist/esm/index.js.map +1 -1
  441. package/dist/esm/loader.js +1 -1
  442. package/dist/esm/{modal-eb0a9bb3.js → modal-215df46b.js} +2 -2
  443. package/dist/esm/{modal-eb0a9bb3.js.map → modal-215df46b.js.map} +1 -1
  444. package/dist/esm/nano-accordion.entry.js +2 -4
  445. package/dist/esm/nano-accordion.entry.js.map +1 -1
  446. package/dist/esm/nano-alert.entry.js +6 -6
  447. package/dist/esm/nano-alert.entry.js.map +1 -1
  448. package/dist/esm/nano-algolia-filter.entry.js +1 -1
  449. package/dist/esm/nano-algolia-filter.entry.js.map +1 -1
  450. package/dist/esm/nano-algolia-input.entry.js +1 -1
  451. package/dist/esm/nano-algolia.entry.js +9 -5
  452. package/dist/esm/nano-algolia.entry.js.map +1 -1
  453. package/dist/esm/nano-aspect-ratio.entry.js +1 -1
  454. package/dist/esm/nano-aspect-ratio.entry.js.map +1 -1
  455. package/dist/esm/nano-checkbox-group.entry.js +4 -1
  456. package/dist/esm/nano-checkbox-group.entry.js.map +1 -1
  457. package/dist/esm/nano-checkbox.entry.js +1 -1
  458. package/dist/esm/nano-checkbox.entry.js.map +1 -1
  459. package/dist/esm/nano-components.js +1 -1
  460. package/dist/esm/nano-datalist_3.entry.js +770 -0
  461. package/dist/esm/nano-datalist_3.entry.js.map +1 -0
  462. package/dist/esm/nano-date-input.entry.js +9 -5
  463. package/dist/esm/nano-date-input.entry.js.map +1 -1
  464. package/dist/esm/{nano-date-picker_2.entry.js → nano-date-picker.entry.js} +3 -274
  465. package/dist/esm/nano-date-picker.entry.js.map +1 -0
  466. package/dist/esm/nano-details.entry.js +2 -2
  467. package/dist/esm/nano-details.entry.js.map +1 -1
  468. package/dist/esm/nano-dialog.entry.js +5 -5
  469. package/dist/esm/nano-dialog.entry.js.map +1 -1
  470. package/dist/esm/nano-drawer.entry.js +5 -5
  471. package/dist/esm/nano-drawer.entry.js.map +1 -1
  472. package/dist/esm/nano-dropdown.entry.js +303 -0
  473. package/dist/esm/nano-dropdown.entry.js.map +1 -0
  474. package/dist/esm/nano-file-upload.entry.js +1 -1
  475. package/dist/esm/nano-file-upload.entry.js.map +1 -1
  476. package/dist/esm/nano-global-nav.entry.js +19 -24
  477. package/dist/esm/nano-global-nav.entry.js.map +1 -1
  478. package/dist/esm/nano-global-search-results.entry.js +200 -115
  479. package/dist/esm/nano-global-search-results.entry.js.map +1 -1
  480. package/dist/esm/nano-grid_3.entry.js +16 -8
  481. package/dist/esm/nano-grid_3.entry.js.map +1 -1
  482. package/dist/esm/nano-hero.entry.js +14 -6
  483. package/dist/esm/nano-hero.entry.js.map +1 -1
  484. package/dist/esm/nano-icon-button.entry.js +2 -2
  485. package/dist/esm/nano-icon-button.entry.js.map +1 -1
  486. package/dist/esm/nano-icon.entry.js +1 -1
  487. package/dist/esm/nano-icon.entry.js.map +1 -1
  488. package/dist/esm/nano-input.entry.js +80 -75
  489. package/dist/esm/nano-input.entry.js.map +1 -1
  490. package/dist/esm/nano-menu-drawer.entry.js +2 -2
  491. package/dist/esm/nano-menu-drawer.entry.js.map +1 -1
  492. package/dist/esm/nano-nav-item_2.entry.js +284 -533
  493. package/dist/esm/nano-nav-item_2.entry.js.map +1 -1
  494. package/dist/esm/nano-range.entry.js +2 -2
  495. package/dist/esm/nano-range.entry.js.map +1 -1
  496. package/dist/esm/nano-rating.entry.js +2 -2
  497. package/dist/esm/nano-rating.entry.js.map +1 -1
  498. package/dist/esm/nano-resize-observe_2.entry.js +1 -1
  499. package/dist/esm/nano-resize-observe_2.entry.js.map +1 -1
  500. package/dist/esm/nano-slide.entry.js +1 -1
  501. package/dist/esm/nano-slide.entry.js.map +1 -1
  502. package/dist/esm/nano-slides.entry.js +1 -1
  503. package/dist/esm/nano-slides.entry.js.map +1 -1
  504. package/dist/esm/nano-spinner.entry.js +1 -1
  505. package/dist/esm/nano-spinner.entry.js.map +1 -1
  506. package/dist/esm/nano-sticker.entry.js +3 -3
  507. package/dist/esm/nano-sticker.entry.js.map +1 -1
  508. package/dist/esm/nano-tab-content.entry.js +2 -2
  509. package/dist/esm/nano-tab-content.entry.js.map +1 -1
  510. package/dist/esm/nano-tab-group.entry.js +66 -33
  511. package/dist/esm/nano-tab-group.entry.js.map +1 -1
  512. package/dist/esm/nano-tab.entry.js +10 -3
  513. package/dist/esm/nano-tab.entry.js.map +1 -1
  514. package/dist/esm/nano-tooltip.entry.js +2 -2
  515. package/dist/esm/nano-tooltip.entry.js.map +1 -1
  516. package/dist/esm/popover-db86a392.js +1893 -0
  517. package/dist/esm/popover-db86a392.js.map +1 -0
  518. package/dist/esm/scroll-881feb46.js +76 -0
  519. package/dist/esm/{scroll-5cd0ab13.js.map → scroll-881feb46.js.map} +1 -1
  520. package/dist/esm/tabbable-614f515e.js +94 -0
  521. package/dist/esm/tabbable-614f515e.js.map +1 -0
  522. package/dist/esm-es5/active-element-75b7c8a0.js +5 -0
  523. package/dist/esm-es5/active-element-75b7c8a0.js.map +1 -0
  524. package/dist/esm-es5/{algoliasearch.umd-8e5aff52.js → algoliasearch.umd-adbc4aa5.js} +3 -3
  525. package/dist/esm-es5/{algoliasearch.umd-8e5aff52.js.map → algoliasearch.umd-adbc4aa5.js.map} +1 -1
  526. package/dist/esm-es5/dom-faa69d29.js +5 -0
  527. package/dist/esm-es5/dom-faa69d29.js.map +1 -0
  528. package/dist/esm-es5/form-control-67eeb108.js +5 -0
  529. package/dist/esm-es5/form-control-67eeb108.js.map +1 -0
  530. package/dist/esm-es5/index-5f8d16e7.js +1 -1
  531. package/dist/esm-es5/index-bf53664b.js +5 -0
  532. package/dist/esm-es5/index-bf53664b.js.map +1 -0
  533. package/dist/esm-es5/index.js +1 -1
  534. package/dist/esm-es5/index.js.map +1 -1
  535. package/dist/esm-es5/loader.js +1 -1
  536. package/dist/esm-es5/loader.js.map +1 -1
  537. package/dist/esm-es5/{modal-eb0a9bb3.js → modal-215df46b.js} +2 -2
  538. package/dist/esm-es5/{modal-eb0a9bb3.js.map → modal-215df46b.js.map} +0 -0
  539. package/dist/esm-es5/nano-accordion.entry.js +1 -1
  540. package/dist/esm-es5/nano-accordion.entry.js.map +1 -1
  541. package/dist/esm-es5/nano-alert.entry.js +1 -1
  542. package/dist/esm-es5/nano-alert.entry.js.map +1 -1
  543. package/dist/esm-es5/nano-algolia-filter.entry.js +1 -1
  544. package/dist/esm-es5/nano-algolia-filter.entry.js.map +1 -1
  545. package/dist/esm-es5/nano-algolia-input.entry.js +1 -1
  546. package/dist/esm-es5/nano-algolia.entry.js +1 -1
  547. package/dist/esm-es5/nano-algolia.entry.js.map +1 -1
  548. package/dist/esm-es5/nano-aspect-ratio.entry.js +1 -1
  549. package/dist/esm-es5/nano-aspect-ratio.entry.js.map +1 -1
  550. package/dist/esm-es5/nano-checkbox-group.entry.js +1 -1
  551. package/dist/esm-es5/nano-checkbox-group.entry.js.map +1 -1
  552. package/dist/esm-es5/nano-checkbox.entry.js +1 -1
  553. package/dist/esm-es5/nano-checkbox.entry.js.map +1 -1
  554. package/dist/esm-es5/nano-components.js +1 -1
  555. package/dist/esm-es5/nano-components.js.map +1 -1
  556. package/dist/esm-es5/nano-datalist_3.entry.js +5 -0
  557. package/dist/esm-es5/nano-datalist_3.entry.js.map +1 -0
  558. package/dist/esm-es5/nano-date-input.entry.js +1 -1
  559. package/dist/esm-es5/nano-date-input.entry.js.map +1 -1
  560. package/dist/esm-es5/nano-date-picker.entry.js +5 -0
  561. package/dist/esm-es5/nano-date-picker.entry.js.map +1 -0
  562. package/dist/esm-es5/nano-details.entry.js +1 -1
  563. package/dist/esm-es5/nano-details.entry.js.map +1 -1
  564. package/dist/esm-es5/nano-dialog.entry.js +1 -1
  565. package/dist/esm-es5/nano-dialog.entry.js.map +1 -1
  566. package/dist/esm-es5/nano-drawer.entry.js +1 -1
  567. package/dist/esm-es5/nano-drawer.entry.js.map +1 -1
  568. package/dist/esm-es5/nano-dropdown.entry.js +5 -0
  569. package/dist/esm-es5/nano-dropdown.entry.js.map +1 -0
  570. package/dist/esm-es5/nano-file-upload.entry.js +1 -1
  571. package/dist/esm-es5/nano-file-upload.entry.js.map +1 -1
  572. package/dist/esm-es5/nano-global-nav.entry.js +1 -1
  573. package/dist/esm-es5/nano-global-nav.entry.js.map +1 -1
  574. package/dist/esm-es5/nano-global-search-results.entry.js +2 -2
  575. package/dist/esm-es5/nano-global-search-results.entry.js.map +1 -1
  576. package/dist/esm-es5/nano-grid_3.entry.js +1 -1
  577. package/dist/esm-es5/nano-grid_3.entry.js.map +1 -1
  578. package/dist/esm-es5/nano-hero.entry.js +1 -1
  579. package/dist/esm-es5/nano-hero.entry.js.map +1 -1
  580. package/dist/esm-es5/nano-icon-button.entry.js +1 -1
  581. package/dist/esm-es5/nano-icon-button.entry.js.map +1 -1
  582. package/dist/esm-es5/nano-icon.entry.js +1 -1
  583. package/dist/esm-es5/nano-icon.entry.js.map +1 -1
  584. package/dist/esm-es5/nano-input.entry.js +2 -2
  585. package/dist/esm-es5/nano-input.entry.js.map +1 -1
  586. package/dist/esm-es5/nano-menu-drawer.entry.js +1 -1
  587. package/dist/esm-es5/nano-menu-drawer.entry.js.map +1 -1
  588. package/dist/esm-es5/nano-nav-item_2.entry.js +1 -1
  589. package/dist/esm-es5/nano-nav-item_2.entry.js.map +1 -1
  590. package/dist/esm-es5/nano-range.entry.js +1 -1
  591. package/dist/esm-es5/nano-range.entry.js.map +1 -1
  592. package/dist/esm-es5/nano-rating.entry.js +1 -1
  593. package/dist/esm-es5/nano-rating.entry.js.map +1 -1
  594. package/dist/esm-es5/nano-resize-observe_2.entry.js +2 -2
  595. package/dist/esm-es5/nano-resize-observe_2.entry.js.map +1 -1
  596. package/dist/esm-es5/nano-slide.entry.js +1 -1
  597. package/dist/esm-es5/nano-slide.entry.js.map +1 -1
  598. package/dist/esm-es5/nano-slides.entry.js +1 -1
  599. package/dist/esm-es5/nano-slides.entry.js.map +1 -1
  600. package/dist/esm-es5/nano-spinner.entry.js +1 -1
  601. package/dist/esm-es5/nano-spinner.entry.js.map +1 -1
  602. package/dist/esm-es5/nano-sticker.entry.js +1 -1
  603. package/dist/esm-es5/nano-sticker.entry.js.map +1 -1
  604. package/dist/esm-es5/nano-tab-content.entry.js +1 -1
  605. package/dist/esm-es5/nano-tab-content.entry.js.map +1 -1
  606. package/dist/esm-es5/nano-tab-group.entry.js +2 -2
  607. package/dist/esm-es5/nano-tab-group.entry.js.map +1 -1
  608. package/dist/esm-es5/nano-tab.entry.js +2 -2
  609. package/dist/esm-es5/nano-tab.entry.js.map +1 -1
  610. package/dist/esm-es5/nano-tooltip.entry.js +1 -1
  611. package/dist/esm-es5/nano-tooltip.entry.js.map +1 -1
  612. package/dist/esm-es5/{popover-2c7b2326.js → popover-db86a392.js} +2 -2
  613. package/dist/esm-es5/popover-db86a392.js.map +1 -0
  614. package/dist/esm-es5/{scroll-5cd0ab13.js → scroll-881feb46.js} +2 -2
  615. package/dist/esm-es5/{scroll-5cd0ab13.js.map → scroll-881feb46.js.map} +0 -0
  616. package/dist/esm-es5/tabbable-614f515e.js +5 -0
  617. package/dist/esm-es5/tabbable-614f515e.js.map +1 -0
  618. package/dist/nano-components/index.esm.js +1 -1
  619. package/dist/nano-components/index.esm.js.map +1 -1
  620. package/dist/nano-components/nano-components.css +1 -1
  621. package/dist/nano-components/nano-components.esm.js +1 -1
  622. package/dist/nano-components/nano-components.esm.js.map +1 -1
  623. package/dist/nano-components/{p-2f21a443.system.entry.js → p-033296c7.system.entry.js} +2 -2
  624. package/dist/nano-components/{p-2f21a443.system.entry.js.map → p-033296c7.system.entry.js.map} +1 -1
  625. package/dist/nano-components/p-040b6cda.entry.js +5 -0
  626. package/dist/nano-components/{p-61565b5a.entry.js.map → p-040b6cda.entry.js.map} +1 -1
  627. package/dist/nano-components/p-05c7bde1.system.entry.js +5 -0
  628. package/dist/nano-components/{p-30df44d9.system.entry.js.map → p-05c7bde1.system.entry.js.map} +1 -1
  629. package/dist/nano-components/p-07bdf44d.entry.js +5 -0
  630. package/dist/nano-components/{p-88bcf55b.entry.js.map → p-07bdf44d.entry.js.map} +1 -1
  631. package/dist/nano-components/p-09066701.system.entry.js +5 -0
  632. package/dist/nano-components/p-09066701.system.entry.js.map +1 -0
  633. package/dist/nano-components/p-090f22a9.system.entry.js +5 -0
  634. package/dist/nano-components/{p-854df906.system.entry.js.map → p-090f22a9.system.entry.js.map} +1 -1
  635. package/dist/nano-components/p-096682d9.system.js +1 -1
  636. package/dist/nano-components/p-096682d9.system.js.map +1 -1
  637. package/dist/nano-components/p-09d2d944.system.js +5 -0
  638. package/dist/nano-components/p-09d2d944.system.js.map +1 -0
  639. package/dist/nano-components/p-14402794.entry.js +5 -0
  640. package/dist/nano-components/p-14402794.entry.js.map +1 -0
  641. package/dist/nano-components/{p-21c2a9a5.system.entry.js → p-173bae15.system.entry.js} +2 -2
  642. package/dist/nano-components/{p-21c2a9a5.system.entry.js.map → p-173bae15.system.entry.js.map} +1 -1
  643. package/dist/nano-components/p-17ebff74.system.entry.js +5 -0
  644. package/dist/nano-components/p-17ebff74.system.entry.js.map +1 -0
  645. package/dist/nano-components/{p-731935b1.js → p-1805d59a.js} +2 -2
  646. package/dist/nano-components/{p-731935b1.js.map → p-1805d59a.js.map} +0 -0
  647. package/dist/nano-components/p-1a293bd0.entry.js +5 -0
  648. package/dist/nano-components/{p-8b7f8ef4.entry.js.map → p-1a293bd0.entry.js.map} +1 -1
  649. package/dist/nano-components/p-1c216ca4.system.js +5 -0
  650. package/dist/{esm-es5/index-f41ae118.js.map → nano-components/p-1c216ca4.system.js.map} +1 -1
  651. package/dist/nano-components/p-1d13dbdf.system.js +5 -0
  652. package/dist/nano-components/p-1d13dbdf.system.js.map +1 -0
  653. package/dist/nano-components/p-1e974cad.entry.js +5 -0
  654. package/dist/nano-components/{p-7e60c331.entry.js.map → p-1e974cad.entry.js.map} +1 -1
  655. package/dist/nano-components/p-20387cde.system.entry.js +5 -0
  656. package/dist/nano-components/{p-91778977.system.entry.js.map → p-20387cde.system.entry.js.map} +1 -1
  657. package/dist/nano-components/p-20db18f3.entry.js +5 -0
  658. package/dist/nano-components/{p-a9dd7cf9.entry.js.map → p-20db18f3.entry.js.map} +1 -1
  659. package/dist/nano-components/p-22884654.system.entry.js +5 -0
  660. package/dist/nano-components/{p-3d0fbd0e.system.entry.js.map → p-22884654.system.entry.js.map} +1 -1
  661. package/dist/nano-components/p-239cc7ff.system.entry.js +5 -0
  662. package/dist/nano-components/p-239cc7ff.system.entry.js.map +1 -0
  663. package/dist/nano-components/p-2559e9c1.entry.js +5 -0
  664. package/dist/nano-components/p-2559e9c1.entry.js.map +1 -0
  665. package/dist/nano-components/p-289aa03f.js +5 -0
  666. package/dist/nano-components/p-289aa03f.js.map +1 -0
  667. package/dist/nano-components/p-2e6c55e2.entry.js +5 -0
  668. package/dist/nano-components/{p-6f3d20fe.entry.js.map → p-2e6c55e2.entry.js.map} +1 -1
  669. package/dist/nano-components/{p-8757b4eb.js → p-305abcb0.js} +3 -3
  670. package/dist/nano-components/{p-8757b4eb.js.map → p-305abcb0.js.map} +1 -1
  671. package/dist/nano-components/{p-60c9b580.system.js → p-3258c568.system.js} +2 -2
  672. package/dist/nano-components/p-3258c568.system.js.map +1 -0
  673. package/dist/nano-components/p-3456db01.entry.js +5 -0
  674. package/dist/nano-components/p-3456db01.entry.js.map +1 -0
  675. package/dist/nano-components/p-346588cc.entry.js +5 -0
  676. package/dist/nano-components/p-346588cc.entry.js.map +1 -0
  677. package/dist/nano-components/p-394c3c19.entry.js +5 -0
  678. package/dist/nano-components/{p-217f71aa.entry.js.map → p-394c3c19.entry.js.map} +1 -1
  679. package/dist/nano-components/p-3a13948a.system.entry.js +5 -0
  680. package/dist/nano-components/p-3a13948a.system.entry.js.map +1 -0
  681. package/dist/nano-components/p-3aa1d07d.entry.js +5 -0
  682. package/dist/nano-components/{p-6a1c69d3.entry.js.map → p-3aa1d07d.entry.js.map} +1 -1
  683. package/dist/nano-components/p-3ad1d5aa.system.entry.js +5 -0
  684. package/dist/nano-components/p-3ad1d5aa.system.entry.js.map +1 -0
  685. package/dist/nano-components/p-3ef30ded.system.entry.js +5 -0
  686. package/dist/nano-components/{p-9bf4a6e0.system.entry.js.map → p-3ef30ded.system.entry.js.map} +1 -1
  687. package/dist/nano-components/p-4429caac.system.entry.js +5 -0
  688. package/dist/nano-components/p-4429caac.system.entry.js.map +1 -0
  689. package/dist/nano-components/p-4535e3bb.entry.js +5 -0
  690. package/dist/nano-components/{p-143bca0d.entry.js.map → p-4535e3bb.entry.js.map} +1 -1
  691. package/dist/nano-components/p-462ad4f1.entry.js +5 -0
  692. package/dist/nano-components/p-462ad4f1.entry.js.map +1 -0
  693. package/dist/nano-components/p-5066e563.system.entry.js +5 -0
  694. package/dist/nano-components/{p-006f2fd3.system.entry.js.map → p-5066e563.system.entry.js.map} +1 -1
  695. package/dist/nano-components/p-52ab579e.system.entry.js +5 -0
  696. package/dist/nano-components/p-52ab579e.system.entry.js.map +1 -0
  697. package/dist/nano-components/p-531d5275.system.entry.js +5 -0
  698. package/dist/nano-components/{p-b79dc23a.system.entry.js.map → p-531d5275.system.entry.js.map} +1 -1
  699. package/dist/nano-components/p-55535a0c.system.entry.js +5 -0
  700. package/dist/nano-components/p-55535a0c.system.entry.js.map +1 -0
  701. package/dist/nano-components/p-5653961d.system.entry.js +5 -0
  702. package/dist/nano-components/{p-18f49ebf.system.entry.js.map → p-5653961d.system.entry.js.map} +1 -1
  703. package/dist/nano-components/p-56ba0d63.entry.js +5 -0
  704. package/dist/nano-components/p-56ba0d63.entry.js.map +1 -0
  705. package/dist/nano-components/p-593de29b.system.entry.js +5 -0
  706. package/dist/nano-components/{p-76b13c27.system.entry.js.map → p-593de29b.system.entry.js.map} +1 -1
  707. package/dist/nano-components/{p-8a608e6d.entry.js → p-5e7c7d3d.entry.js} +2 -2
  708. package/dist/nano-components/{p-8a608e6d.entry.js.map → p-5e7c7d3d.entry.js.map} +1 -1
  709. package/dist/nano-components/p-672e5547.js +5 -0
  710. package/dist/nano-components/p-672e5547.js.map +1 -0
  711. package/dist/nano-components/p-69439aa1.system.entry.js +5 -0
  712. package/dist/nano-components/p-69439aa1.system.entry.js.map +1 -0
  713. package/dist/nano-components/p-6ade3290.entry.js +5 -0
  714. package/dist/nano-components/{p-1e03f9bf.entry.js.map → p-6ade3290.entry.js.map} +1 -1
  715. package/dist/nano-components/p-70dec19f.entry.js +5 -0
  716. package/dist/nano-components/{p-d0e9b177.entry.js.map → p-70dec19f.entry.js.map} +1 -1
  717. package/dist/nano-components/p-7232c046.system.entry.js +5 -0
  718. package/dist/nano-components/{p-92b3f99b.system.entry.js.map → p-7232c046.system.entry.js.map} +1 -1
  719. package/dist/nano-components/p-730f60ea.entry.js +5 -0
  720. package/dist/nano-components/{p-78cf9d39.entry.js.map → p-730f60ea.entry.js.map} +1 -1
  721. package/dist/nano-components/{p-a16651a6.system.js → p-7319fa52.system.js} +3 -3
  722. package/dist/nano-components/{p-a16651a6.system.js.map → p-7319fa52.system.js.map} +1 -1
  723. package/dist/nano-components/p-74a7fc4f.js +5 -0
  724. package/dist/nano-components/p-74a7fc4f.js.map +1 -0
  725. package/dist/nano-components/{p-981cc614.entry.js → p-7a9aeeb5.entry.js} +2 -2
  726. package/dist/nano-components/{p-981cc614.entry.js.map → p-7a9aeeb5.entry.js.map} +0 -0
  727. package/dist/nano-components/{p-d31761c8.system.js → p-7be6b7f3.system.js} +2 -2
  728. package/dist/nano-components/p-7be6b7f3.system.js.map +1 -0
  729. package/dist/nano-components/p-7d2e2685.entry.js +5 -0
  730. package/dist/nano-components/p-7d2e2685.entry.js.map +1 -0
  731. package/dist/nano-components/p-820d9e23.system.entry.js +5 -0
  732. package/dist/nano-components/p-820d9e23.system.entry.js.map +1 -0
  733. package/dist/nano-components/p-8278c5d2.system.entry.js +5 -0
  734. package/dist/nano-components/{p-badf69ee.system.entry.js.map → p-8278c5d2.system.entry.js.map} +1 -1
  735. package/dist/nano-components/p-82f4b071.entry.js +5 -0
  736. package/dist/nano-components/p-82f4b071.entry.js.map +1 -0
  737. package/dist/nano-components/p-88f17c86.system.entry.js +5 -0
  738. package/dist/nano-components/p-88f17c86.system.entry.js.map +1 -0
  739. package/dist/nano-components/p-8a8f893b.system.entry.js +5 -0
  740. package/dist/nano-components/{p-cc668975.system.entry.js.map → p-8a8f893b.system.entry.js.map} +1 -1
  741. package/dist/nano-components/p-93448bcd.system.entry.js +5 -0
  742. package/dist/nano-components/{p-02e82e14.system.entry.js.map → p-93448bcd.system.entry.js.map} +1 -1
  743. package/dist/nano-components/p-94593617.system.entry.js +5 -0
  744. package/dist/nano-components/{p-2442eda0.system.entry.js.map → p-94593617.system.entry.js.map} +1 -1
  745. package/dist/nano-components/{p-56113dd3.js → p-9a385481.js} +2 -2
  746. package/dist/nano-components/p-9a385481.js.map +1 -0
  747. package/dist/nano-components/{p-8134c14e.system.js → p-9de508a5.system.js} +2 -2
  748. package/dist/nano-components/p-9de508a5.system.js.map +1 -0
  749. package/dist/nano-components/p-a315ed2c.entry.js +5 -0
  750. package/dist/nano-components/{p-13801651.entry.js.map → p-a315ed2c.entry.js.map} +1 -1
  751. package/dist/nano-components/{p-18411914.system.js → p-b370e3ef.system.js} +2 -2
  752. package/dist/nano-components/{p-18411914.system.js.map → p-b370e3ef.system.js.map} +0 -0
  753. package/dist/nano-components/p-b59d2bd5.entry.js +5 -0
  754. package/dist/nano-components/p-b59d2bd5.entry.js.map +1 -0
  755. package/dist/nano-components/p-b619500f.js +5 -0
  756. package/dist/nano-components/p-b619500f.js.map +1 -0
  757. package/dist/nano-components/{p-23f65b34.entry.js → p-ba13bb56.entry.js} +2 -2
  758. package/dist/nano-components/{p-23f65b34.entry.js.map → p-ba13bb56.entry.js.map} +1 -1
  759. package/dist/nano-components/p-c0ddb4c3.entry.js +5 -0
  760. package/dist/nano-components/{p-78569d39.entry.js.map → p-c0ddb4c3.entry.js.map} +1 -1
  761. package/dist/nano-components/p-c475b57f.system.entry.js +5 -0
  762. package/dist/nano-components/p-c475b57f.system.entry.js.map +1 -0
  763. package/dist/nano-components/{p-bfc12324.system.entry.js → p-c7c50a7d.system.entry.js} +2 -2
  764. package/dist/nano-components/{p-bfc12324.system.entry.js.map → p-c7c50a7d.system.entry.js.map} +0 -0
  765. package/dist/nano-components/p-c9c1a345.system.entry.js +5 -0
  766. package/dist/nano-components/{p-38a3e791.system.entry.js.map → p-c9c1a345.system.entry.js.map} +1 -1
  767. package/dist/nano-components/{p-8c8963f6.js → p-cb79d1ec.js} +2 -2
  768. package/dist/nano-components/{p-8c8963f6.js.map → p-cb79d1ec.js.map} +0 -0
  769. package/dist/nano-components/p-cce0806e.entry.js +5 -0
  770. package/dist/nano-components/p-cce0806e.entry.js.map +1 -0
  771. package/dist/nano-components/p-d6569144.entry.js +5 -0
  772. package/dist/nano-components/{p-c7b7f7ab.entry.js.map → p-d6569144.entry.js.map} +1 -1
  773. package/dist/nano-components/{p-2d1a856e.system.js → p-d84ef175.system.js} +2 -2
  774. package/dist/nano-components/{p-2d1a856e.system.js.map → p-d84ef175.system.js.map} +0 -0
  775. package/dist/nano-components/p-d857f3ed.entry.js +5 -0
  776. package/dist/nano-components/p-d857f3ed.entry.js.map +1 -0
  777. package/dist/nano-components/p-d9c7909e.js +5 -0
  778. package/dist/nano-components/p-d9c7909e.js.map +1 -0
  779. package/dist/nano-components/p-dfe50fff.entry.js +5 -0
  780. package/dist/nano-components/p-dfe50fff.entry.js.map +1 -0
  781. package/dist/nano-components/p-e11bd40d.entry.js +5 -0
  782. package/dist/nano-components/{p-a21d90aa.entry.js.map → p-e11bd40d.entry.js.map} +1 -1
  783. package/dist/nano-components/p-e15be516.system.entry.js +5 -0
  784. package/dist/nano-components/p-e15be516.system.entry.js.map +1 -0
  785. package/dist/nano-components/p-e35eac75.entry.js +5 -0
  786. package/dist/nano-components/p-e35eac75.entry.js.map +1 -0
  787. package/dist/nano-components/p-e562bffd.entry.js +5 -0
  788. package/dist/nano-components/p-e562bffd.entry.js.map +1 -0
  789. package/dist/nano-components/p-e64daa92.entry.js +5 -0
  790. package/dist/nano-components/p-e64daa92.entry.js.map +1 -0
  791. package/dist/nano-components/p-e6f41b97.entry.js +5 -0
  792. package/dist/nano-components/p-e6f41b97.entry.js.map +1 -0
  793. package/dist/nano-components/p-e6f8f9f7.system.entry.js +5 -0
  794. package/dist/nano-components/p-e6f8f9f7.system.entry.js.map +1 -0
  795. package/dist/nano-components/p-ea5eb591.system.js +5 -0
  796. package/dist/nano-components/p-ea5eb591.system.js.map +1 -0
  797. package/dist/nano-components/p-ef4e0912.system.entry.js +5 -0
  798. package/dist/nano-components/{p-2aed806d.system.entry.js.map → p-ef4e0912.system.entry.js.map} +1 -1
  799. package/dist/nano-components/p-f2e7d2f9.system.entry.js +5 -0
  800. package/dist/nano-components/p-f2e7d2f9.system.entry.js.map +1 -0
  801. package/dist/nano-components/p-f3bf942d.entry.js +5 -0
  802. package/dist/nano-components/p-f3bf942d.entry.js.map +1 -0
  803. package/dist/nano-components/p-f53989c3.system.entry.js +5 -0
  804. package/dist/nano-components/{p-6621e4f1.system.entry.js.map → p-f53989c3.system.entry.js.map} +1 -1
  805. package/dist/nano-components/p-f84998c9.system.entry.js +5 -0
  806. package/dist/nano-components/p-f84998c9.system.entry.js.map +1 -0
  807. package/dist/themes/nanopore.css +1 -1
  808. package/dist/themes/nanopore.css.map +1 -1
  809. package/dist/types/components/accordion/accordion.d.ts +0 -1
  810. package/dist/types/components/checkbox/checkbox-group.d.ts +1 -0
  811. package/dist/types/components/datalist/datalist.d.ts +98 -0
  812. package/dist/types/components/date-input/date-input.d.ts +2 -0
  813. package/dist/types/components/dialog/dialog.helpers.d.ts +2 -2
  814. package/dist/types/components/dropdown/dropdown.d.ts +8 -4
  815. package/dist/types/components/form-control/form-control.d.ts +35 -0
  816. package/dist/types/components/global-search-results/global-search-results.d.ts +1 -0
  817. package/dist/types/components/grid/grid.d.ts +7 -1
  818. package/dist/types/components/hero/hero.d.ts +2 -0
  819. package/dist/types/components/input/input.d.ts +13 -9
  820. package/dist/types/components/menu/menu.d.ts +22 -8
  821. package/dist/types/components/option/option-interface.d.ts +7 -0
  822. package/dist/types/components/option/option.d.ts +45 -0
  823. package/dist/types/components/select/select.d.ts +43 -49
  824. package/dist/types/components/tabs/tab-group.d.ts +26 -6
  825. package/dist/types/components/tabs/tab.d.ts +6 -1
  826. package/dist/types/components.d.ts +241 -70
  827. package/dist/types/interface.d.ts +1 -0
  828. package/dist/types/utils/active-element.d.ts +1 -0
  829. package/dist/types/utils/dom.d.ts +9 -1
  830. package/dist/types/utils/index.d.ts +2 -1
  831. package/dist/types/utils/tabbable.d.ts +2 -2
  832. package/dist/types/utils/testing/index.d.ts +3 -2
  833. package/docs-json.json +1223 -261
  834. package/docs-vscode.json +102 -33
  835. package/package.json +5 -5
  836. package/dist/cjs/dom-5f3fae1a.js.map +0 -1
  837. package/dist/cjs/index-117f36a4.js.map +0 -1
  838. package/dist/cjs/nano-date-picker_2.cjs.entry.js.map +0 -1
  839. package/dist/cjs/nano-menu.cjs.entry.js +0 -156
  840. package/dist/cjs/nano-menu.cjs.entry.js.map +0 -1
  841. package/dist/cjs/nano-select-option.cjs.entry.js +0 -43
  842. package/dist/cjs/nano-select-option.cjs.entry.js.map +0 -1
  843. package/dist/cjs/popover-d033efa2.js.map +0 -1
  844. package/dist/cjs/tabbable-615c30e1.js.map +0 -1
  845. package/dist/collection/components/select/select-option.css +0 -15
  846. package/dist/collection/components/select/select-option.js +0 -127
  847. package/dist/collection/components/select/select-option.js.map +0 -1
  848. package/dist/esm/dom-a791b223.js.map +0 -1
  849. package/dist/esm/nano-date-picker_2.entry.js.map +0 -1
  850. package/dist/esm/nano-menu.entry.js +0 -152
  851. package/dist/esm/nano-menu.entry.js.map +0 -1
  852. package/dist/esm/nano-select-option.entry.js +0 -39
  853. package/dist/esm/nano-select-option.entry.js.map +0 -1
  854. package/dist/esm/popover-2c7b2326.js.map +0 -1
  855. package/dist/esm/tabbable-e21f860a.js.map +0 -1
  856. package/dist/esm-es5/dom-a791b223.js +0 -5
  857. package/dist/esm-es5/dom-a791b223.js.map +0 -1
  858. package/dist/esm-es5/index-f41ae118.js +0 -5
  859. package/dist/esm-es5/nano-date-picker_2.entry.js +0 -5
  860. package/dist/esm-es5/nano-date-picker_2.entry.js.map +0 -1
  861. package/dist/esm-es5/nano-menu.entry.js +0 -5
  862. package/dist/esm-es5/nano-menu.entry.js.map +0 -1
  863. package/dist/esm-es5/nano-select-option.entry.js +0 -5
  864. package/dist/esm-es5/nano-select-option.entry.js.map +0 -1
  865. package/dist/esm-es5/popover-2c7b2326.js.map +0 -1
  866. package/dist/esm-es5/tabbable-e21f860a.js +0 -5
  867. package/dist/esm-es5/tabbable-e21f860a.js.map +0 -1
  868. package/dist/nano-components/p-006f2fd3.system.entry.js +0 -5
  869. package/dist/nano-components/p-02e82e14.system.entry.js +0 -5
  870. package/dist/nano-components/p-05a8014a.entry.js +0 -5
  871. package/dist/nano-components/p-05a8014a.entry.js.map +0 -1
  872. package/dist/nano-components/p-13801651.entry.js +0 -5
  873. package/dist/nano-components/p-13fa75fc.entry.js +0 -5
  874. package/dist/nano-components/p-13fa75fc.entry.js.map +0 -1
  875. package/dist/nano-components/p-143bca0d.entry.js +0 -5
  876. package/dist/nano-components/p-18f49ebf.system.entry.js +0 -5
  877. package/dist/nano-components/p-19428228.system.entry.js +0 -5
  878. package/dist/nano-components/p-19428228.system.entry.js.map +0 -1
  879. package/dist/nano-components/p-1e03f9bf.entry.js +0 -5
  880. package/dist/nano-components/p-217f71aa.entry.js +0 -5
  881. package/dist/nano-components/p-2442eda0.system.entry.js +0 -5
  882. package/dist/nano-components/p-2946bd70.system.entry.js +0 -5
  883. package/dist/nano-components/p-2946bd70.system.entry.js.map +0 -1
  884. package/dist/nano-components/p-2aed806d.system.entry.js +0 -5
  885. package/dist/nano-components/p-30df44d9.system.entry.js +0 -5
  886. package/dist/nano-components/p-38a3e791.system.entry.js +0 -5
  887. package/dist/nano-components/p-3a49ceab.entry.js +0 -5
  888. package/dist/nano-components/p-3a49ceab.entry.js.map +0 -1
  889. package/dist/nano-components/p-3d0fbd0e.system.entry.js +0 -5
  890. package/dist/nano-components/p-3f00179c.js +0 -5
  891. package/dist/nano-components/p-3f00179c.js.map +0 -1
  892. package/dist/nano-components/p-48e6bea3.entry.js +0 -5
  893. package/dist/nano-components/p-48e6bea3.entry.js.map +0 -1
  894. package/dist/nano-components/p-4d62ec32.system.js +0 -5
  895. package/dist/nano-components/p-4d62ec32.system.js.map +0 -1
  896. package/dist/nano-components/p-4e451498.entry.js +0 -5
  897. package/dist/nano-components/p-4e451498.entry.js.map +0 -1
  898. package/dist/nano-components/p-51d9570d.entry.js +0 -5
  899. package/dist/nano-components/p-51d9570d.entry.js.map +0 -1
  900. package/dist/nano-components/p-51fa04a6.entry.js +0 -5
  901. package/dist/nano-components/p-51fa04a6.entry.js.map +0 -1
  902. package/dist/nano-components/p-55189485.system.entry.js +0 -5
  903. package/dist/nano-components/p-55189485.system.entry.js.map +0 -1
  904. package/dist/nano-components/p-56113dd3.js.map +0 -1
  905. package/dist/nano-components/p-5bbd6c81.entry.js +0 -5
  906. package/dist/nano-components/p-5bbd6c81.entry.js.map +0 -1
  907. package/dist/nano-components/p-5e9170ae.entry.js +0 -5
  908. package/dist/nano-components/p-5e9170ae.entry.js.map +0 -1
  909. package/dist/nano-components/p-60c9b580.system.js.map +0 -1
  910. package/dist/nano-components/p-61565b5a.entry.js +0 -5
  911. package/dist/nano-components/p-621750cc.js +0 -5
  912. package/dist/nano-components/p-621750cc.js.map +0 -1
  913. package/dist/nano-components/p-6621e4f1.system.entry.js +0 -5
  914. package/dist/nano-components/p-6a1c69d3.entry.js +0 -5
  915. package/dist/nano-components/p-6ab8d211.system.entry.js +0 -5
  916. package/dist/nano-components/p-6ab8d211.system.entry.js.map +0 -1
  917. package/dist/nano-components/p-6e9b3d60.system.entry.js +0 -5
  918. package/dist/nano-components/p-6e9b3d60.system.entry.js.map +0 -1
  919. package/dist/nano-components/p-6f3d20fe.entry.js +0 -5
  920. package/dist/nano-components/p-6feac35e.entry.js +0 -5
  921. package/dist/nano-components/p-6feac35e.entry.js.map +0 -1
  922. package/dist/nano-components/p-723c212f.system.entry.js +0 -5
  923. package/dist/nano-components/p-723c212f.system.entry.js.map +0 -1
  924. package/dist/nano-components/p-76b13c27.system.entry.js +0 -5
  925. package/dist/nano-components/p-78569d39.entry.js +0 -5
  926. package/dist/nano-components/p-78cf9d39.entry.js +0 -5
  927. package/dist/nano-components/p-7e60c331.entry.js +0 -5
  928. package/dist/nano-components/p-8134c14e.system.js.map +0 -1
  929. package/dist/nano-components/p-81b4ed2a.system.entry.js +0 -5
  930. package/dist/nano-components/p-81b4ed2a.system.entry.js.map +0 -1
  931. package/dist/nano-components/p-854df906.system.entry.js +0 -5
  932. package/dist/nano-components/p-88bcf55b.entry.js +0 -5
  933. package/dist/nano-components/p-8b7f8ef4.entry.js +0 -5
  934. package/dist/nano-components/p-8c3993ff.entry.js +0 -5
  935. package/dist/nano-components/p-8c3993ff.entry.js.map +0 -1
  936. package/dist/nano-components/p-91778977.system.entry.js +0 -5
  937. package/dist/nano-components/p-92b3f99b.system.entry.js +0 -5
  938. package/dist/nano-components/p-9bd73d1d.js +0 -5
  939. package/dist/nano-components/p-9bd73d1d.js.map +0 -1
  940. package/dist/nano-components/p-9bf4a6e0.system.entry.js +0 -5
  941. package/dist/nano-components/p-9df226fd.system.entry.js +0 -5
  942. package/dist/nano-components/p-9df226fd.system.entry.js.map +0 -1
  943. package/dist/nano-components/p-a0b55c38.system.entry.js +0 -5
  944. package/dist/nano-components/p-a0b55c38.system.entry.js.map +0 -1
  945. package/dist/nano-components/p-a21d90aa.entry.js +0 -5
  946. package/dist/nano-components/p-a9dd7cf9.entry.js +0 -5
  947. package/dist/nano-components/p-ad069ba4.entry.js +0 -5
  948. package/dist/nano-components/p-ad069ba4.entry.js.map +0 -1
  949. package/dist/nano-components/p-b246a7bb.entry.js +0 -5
  950. package/dist/nano-components/p-b246a7bb.entry.js.map +0 -1
  951. package/dist/nano-components/p-b45d4be9.entry.js +0 -5
  952. package/dist/nano-components/p-b45d4be9.entry.js.map +0 -1
  953. package/dist/nano-components/p-b79dc23a.system.entry.js +0 -5
  954. package/dist/nano-components/p-b86fc6b7.system.js +0 -5
  955. package/dist/nano-components/p-b86fc6b7.system.js.map +0 -1
  956. package/dist/nano-components/p-badf69ee.system.entry.js +0 -5
  957. package/dist/nano-components/p-bde0deae.system.entry.js +0 -5
  958. package/dist/nano-components/p-bde0deae.system.entry.js.map +0 -1
  959. package/dist/nano-components/p-be3df2e8.system.entry.js +0 -5
  960. package/dist/nano-components/p-be3df2e8.system.entry.js.map +0 -1
  961. package/dist/nano-components/p-c39c1e8d.entry.js +0 -5
  962. package/dist/nano-components/p-c39c1e8d.entry.js.map +0 -1
  963. package/dist/nano-components/p-c7b7f7ab.entry.js +0 -5
  964. package/dist/nano-components/p-c82ccbc8.entry.js +0 -5
  965. package/dist/nano-components/p-c82ccbc8.entry.js.map +0 -1
  966. package/dist/nano-components/p-cc668975.system.entry.js +0 -5
  967. package/dist/nano-components/p-cfd4c9de.system.entry.js +0 -5
  968. package/dist/nano-components/p-cfd4c9de.system.entry.js.map +0 -1
  969. package/dist/nano-components/p-d0e9b177.entry.js +0 -5
  970. package/dist/nano-components/p-d31761c8.system.js.map +0 -1
  971. package/dist/nano-components/p-d47d297b.system.entry.js +0 -5
  972. package/dist/nano-components/p-d47d297b.system.entry.js.map +0 -1
  973. package/dist/nano-components/p-e48a53f5.system.entry.js +0 -5
  974. package/dist/nano-components/p-e48a53f5.system.entry.js.map +0 -1
  975. package/dist/nano-components/p-e5f01860.entry.js +0 -5
  976. package/dist/nano-components/p-e5f01860.entry.js.map +0 -1
  977. package/dist/nano-components/p-f2b2cd38.system.entry.js +0 -5
  978. package/dist/nano-components/p-f2b2cd38.system.entry.js.map +0 -1
  979. package/dist/nano-components/p-fcb5ffaf.system.entry.js +0 -5
  980. package/dist/nano-components/p-fcb5ffaf.system.entry.js.map +0 -1
  981. package/dist/types/components/select/select-option.d.ts +0 -23
@@ -0,0 +1,776 @@
1
+ /*!
2
+ * Web Components for Nanopore digital Web Apps
3
+ */
4
+ 'use strict';
5
+
6
+ Object.defineProperty(exports, '__esModule', { value: true });
7
+
8
+ const index = require('./index-cb62df44.js');
9
+ const index$1 = require('./index-53d02e05.js');
10
+ const throttle = require('./throttle-3c97f7c6.js');
11
+ const dom = require('./dom-52f9b8b7.js');
12
+ const slot = require('./slot-9f5a87b6.js');
13
+ const activeElement = require('./active-element-2f9bf0aa.js');
14
+
15
+ const datalistCss = ":host{-webkit-box-sizing:border-box;box-sizing:border-box}*,*::before,*::after{-webkit-box-sizing:border-box;box-sizing:border-box}[hidden]{display:none !important}:host{--padding-top:var(--nano-spacing-small, 8px);--padding-bottom:var(--nano-spacing-small, 8px);--padding-start:var(--nano-spacing-xlarge, 24px);--padding-end:var(--nano-spacing-xlarge, 24px);--font-size:0.8em;--color:#b5aea7;color:var(--color)}.dlist--isfiltered ::slotted(*:not(nano-option):not([slot=no-result]):not([slot=list-top]):not([slot=list-bottom])){display:none !important}.dlist__dropdown{--min-width:100%;--overflow:auto}.dlist__status{clip:rect(1px, 1px, 1px, 1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute}.dlist__menu{--padding-top:inherit;--padding-bottom:inherit;--padding-start:inherit;--padding-end:inherit;--font-size:inherit}";
16
+
17
+ function findLabel(formCtrl) {
18
+ let foundLabel;
19
+ if (formCtrl.id) {
20
+ foundLabel = document.querySelector(`label[for='${formCtrl.id}']`);
21
+ }
22
+ if (!foundLabel) {
23
+ foundLabel = formCtrl.closest('label');
24
+ }
25
+ return foundLabel;
26
+ }
27
+ let listIds = 0;
28
+ let DataList = class {
29
+ constructor(hostRef) {
30
+ index.registerInstance(this, hostRef);
31
+ this.nanoSelect = index.createEvent(this, "nanoSelect", 7);
32
+ this.nanoDeselect = index.createEvent(this, "nanoDeselect", 7);
33
+ this.nanoOptionsUpdated = index.createEvent(this, "nanoOptionsUpdated", 7);
34
+ // Private State
35
+ this.isNanoInput = false;
36
+ this.typeToSelect = '';
37
+ // options set via `options` prop
38
+ this.optionEles = [];
39
+ this.listId = `nano-datalist-${listIds++}`;
40
+ this.isFiltered = false;
41
+ this._allOptEles = [];
42
+ // active option eles that are not hidden.
43
+ this.actvOptEles = [];
44
+ this.canOpen = true;
45
+ this.optionIds = [];
46
+ // Public API
47
+ /** By default, items in the list will appear 'selected' when the value in the linked input control matches.
48
+ * However you can add other selected options via the the selected prop. */
49
+ this.selected = [];
50
+ this._dropDownConfig = {
51
+ skidding: -1,
52
+ };
53
+ /** Provide an option list.
54
+ * Options can be defined declaratively by nesting `<nano-option>` elements or imperatively using this prop */
55
+ this.options = [];
56
+ /** Tweaks the datalist behaviour and linked control semantics and behaviour.
57
+ * e.g. 'select' will make the linked input control readonly.
58
+ */
59
+ this.type = 'input';
60
+ /** Force datalist open */
61
+ this.open = false;
62
+ /** Use this option to disable to default filtering. This is useful if filtering happens
63
+ * externally via another method (e.g. via ajax)
64
+ */
65
+ this.disableFilter = false;
66
+ /** Activate / deactivate the datalist control */
67
+ this.disabled = false;
68
+ // a new option has been picked
69
+ this.optSelected = (e) => {
70
+ e.stopPropagation();
71
+ this.changeInputValue(e.detail);
72
+ index$1.raf(() => this.inputChange());
73
+ if (this.type === 'select')
74
+ this.shouldOpen = false;
75
+ };
76
+ // sets focus immediately on open when 'select' - mirroring native behaviour
77
+ this.handleShow = async () => {
78
+ if (this.type === 'select')
79
+ this.listBox.setFocus();
80
+ };
81
+ this.inputClick = () => {
82
+ this.shouldOpen = true;
83
+ // open dropdown if possible
84
+ this.manageDropdownDisplay();
85
+ };
86
+ this.inputKeydown = (e) => {
87
+ const ignoreKeys = [
88
+ 'Shift',
89
+ 'ArrowRight',
90
+ 'ArrowLeft',
91
+ 'Escape',
92
+ 'Enter',
93
+ 'Tab',
94
+ ];
95
+ if (ignoreKeys.includes(e.key)) {
96
+ if (e.key === 'Tab')
97
+ this.shouldOpen = false;
98
+ return;
99
+ }
100
+ // When select, mirror native select behaviour. Search on closed list
101
+ if (this.type === 'select' &&
102
+ !['ArrowDown', 'ArrowUp'].includes(e.key) &&
103
+ (e.key !== ' ' || this.typeToSelectTimeout)) {
104
+ if (e.key === ' ' || /^[a-z0-9]+$/i.test(e.key)) {
105
+ clearTimeout(this.typeToSelectTimeout);
106
+ this.typeToSelectTimeout = window.setTimeout(() => {
107
+ this.typeToSelect = '';
108
+ this.typeToSelectTimeout = 0;
109
+ }, 750);
110
+ this.typeToSelect += e.key;
111
+ this.setOptStartsWith();
112
+ }
113
+ return;
114
+ }
115
+ this.shouldOpen = true;
116
+ // open dropdown if possible
117
+ this.manageDropdownDisplay();
118
+ };
119
+ // handles key down on options. Either 'picks'
120
+ // an option or passes event back to input for search / filter
121
+ this.optionKeyDown = (e) => {
122
+ const ignoreKeys = [
123
+ 'Shift',
124
+ 'ArrowUp',
125
+ 'ArrowDown',
126
+ 'Escape',
127
+ 'Enter',
128
+ 'Tab',
129
+ 'Space',
130
+ ' ',
131
+ ];
132
+ if (ignoreKeys.includes(e.key)) {
133
+ if (e.key === 'Escape')
134
+ this.connectedInput.focus();
135
+ return;
136
+ }
137
+ const deleteKeys = ['Delete', 'Backspace'];
138
+ // this passes whatever's typed back to our input control
139
+ if (this.type !== 'select' &&
140
+ (!this.exactMatch || deleteKeys.includes(e.key))) {
141
+ this.connectedInput.focus();
142
+ }
143
+ };
144
+ this.inputChange = throttle.debounce(this.inputChange.bind(this), 50);
145
+ }
146
+ // all potential option eles. Set via slot or `options` prop.
147
+ // Some may get hidden due to filtering
148
+ get allOptEles() {
149
+ return this._allOptEles;
150
+ }
151
+ set allOptEles(opts) {
152
+ var _a;
153
+ // when allOptEles are initially set (on slot change / options) -
154
+ // add options to 'selected' and fire selected event *if*
155
+ // value isn't set on the input
156
+ this._allOptEles = opts;
157
+ if ((_a = this.connectedInput) === null || _a === void 0 ? void 0 : _a.value)
158
+ return;
159
+ opts.forEach((opt) => {
160
+ if (opt.selected && !this.selected.includes(opt.value)) {
161
+ this.changeInputValue(opt);
162
+ }
163
+ });
164
+ }
165
+ /** nano-dropdown config options you can pass to the nested dropdown component */
166
+ get dropDownConfig() {
167
+ return this._dropDownConfig;
168
+ }
169
+ set dropDownConfig(ddc) {
170
+ this._dropDownConfig = Object.assign(Object.assign({}, this._dropDownConfig), ddc);
171
+ }
172
+ /** return all the active options currently within the datalist. Can be useful for validation */
173
+ get activeOptions() {
174
+ return this.allOptEles;
175
+ }
176
+ openWatcher() {
177
+ index.writeTask(() => {
178
+ this.nanoDropdown.open = this.open;
179
+ this.connectedInput.setAttribute('aria-expanded', this.open.toString());
180
+ });
181
+ }
182
+ // State change watchers
183
+ async watchInputChange() {
184
+ let nanoInput;
185
+ if ((nanoInput = this.host.closest('nano-input'))) {
186
+ this.isNanoInput = true;
187
+ this.connectedInput = await nanoInput.getInputElement();
188
+ }
189
+ else if (this.input &&
190
+ typeof this.input === 'string' &&
191
+ (nanoInput = document.querySelector(this.input))) {
192
+ this.isNanoInput = false;
193
+ this.connectedInput = nanoInput;
194
+ }
195
+ else if (this.input instanceof HTMLElement) {
196
+ this.connectedInput = this.input;
197
+ }
198
+ }
199
+ manageSlotChangeListener() {
200
+ var _a;
201
+ if (!this.host)
202
+ return;
203
+ // we're not using `options` - setup new MO
204
+ if ((!this.options || !this.options.length) && !this.mo) {
205
+ {
206
+ const mo = (this.mo = new MutationObserver(() => this.processSlottedContent()));
207
+ mo.observe(this.host, { childList: true, subtree: true });
208
+ }
209
+ this.processSlottedContent();
210
+ return;
211
+ }
212
+ // we're using `options` - trash current MO
213
+ if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.length) {
214
+ if (!!this.mo) {
215
+ this.mo.disconnect();
216
+ this.mo = undefined;
217
+ }
218
+ setTimeout(() => {
219
+ var _a;
220
+ if (((_a = this.connectedInput) === null || _a === void 0 ? void 0 : _a.value.length) && this.type !== 'select') {
221
+ this.inputChange();
222
+ }
223
+ else
224
+ this.actvOptEles = [...this.allOptEles];
225
+ }, 50);
226
+ }
227
+ index.forceUpdate(this.host);
228
+ }
229
+ watchTypeChange() {
230
+ if (!this.connectedInput)
231
+ return;
232
+ let dwConfig = { closeOnSelect: false };
233
+ let autocompleteType = 'both';
234
+ let readonly = false;
235
+ switch (this.type) {
236
+ case 'selctMulti':
237
+ // dwConfig.closeOnSelect = false;
238
+ break;
239
+ case 'select':
240
+ autocompleteType = 'list';
241
+ readonly = true;
242
+ break;
243
+ }
244
+ if (!this.isNanoInput) {
245
+ dwConfig.tetherTo = this.connectedInput;
246
+ }
247
+ this.dropDownConfig = Object.assign(Object.assign({}, this.dropDownConfig), dwConfig);
248
+ this.connectedInput.setAttribute('aria-autocomplete', autocompleteType);
249
+ this.connectedInput.readOnly = readonly;
250
+ }
251
+ manageInputEvents(newInput, oldInput) {
252
+ var _a;
253
+ if (!!oldInput) {
254
+ const nanoInput = oldInput.closest('nano-input');
255
+ if (nanoInput) {
256
+ nanoInput.removeEventListener('nanoChange', this.inputChange);
257
+ }
258
+ oldInput.removeEventListener('change', this.inputChange);
259
+ oldInput.removeEventListener('click', this.inputClick);
260
+ oldInput.removeEventListener('keydown', this.inputKeydown);
261
+ oldInput.removeEventListener('input', this.inputChange);
262
+ this.inputLabel = null;
263
+ index.writeTask(() => {
264
+ oldInput.removeAttribute('role');
265
+ oldInput.removeAttribute('aria-expanded');
266
+ oldInput.removeAttribute('aria-controls');
267
+ oldInput.removeAttribute('aria-owns');
268
+ oldInput.removeAttribute('aria-haspopup');
269
+ oldInput.removeAttribute('aria-autocomplete');
270
+ oldInput.removeAttribute('autocomplete');
271
+ });
272
+ }
273
+ if (!!newInput) {
274
+ const nanoInput = newInput.closest('nano-input');
275
+ if (nanoInput) {
276
+ nanoInput.addEventListener('nanoChange', this.inputChange);
277
+ }
278
+ newInput.addEventListener('change', this.inputChange);
279
+ newInput.addEventListener('click', this.inputClick);
280
+ newInput.addEventListener('keydown', this.inputKeydown);
281
+ newInput.addEventListener('input', this.inputChange);
282
+ this.listId = this.host.id || this.listId;
283
+ this.inputLabel = ((_a = newInput === null || newInput === void 0 ? void 0 : newInput.labels) === null || _a === void 0 ? void 0 : _a.item(0)) || findLabel(newInput);
284
+ index.writeTask(() => {
285
+ this.host.id = this.listId;
286
+ newInput.setAttribute('role', 'combobox');
287
+ newInput.setAttribute('aria-expanded', 'false');
288
+ newInput.setAttribute('aria-controls', this.listId);
289
+ newInput.setAttribute('aria-owns', this.listId);
290
+ newInput.setAttribute('aria-haspopup', 'listbox');
291
+ newInput.setAttribute('autocomplete', 'off');
292
+ });
293
+ }
294
+ }
295
+ watchActvOptChange() {
296
+ var _a;
297
+ let c = 0;
298
+ const val = ((_a = this.connectedInput) === null || _a === void 0 ? void 0 : _a.value) || '';
299
+ const optIds = [];
300
+ index.writeTask(() => {
301
+ this.allOptEles.forEach((opt, i) => {
302
+ if (this.actvOptEles.includes(opt)) {
303
+ c++;
304
+ opt.setAttribute('aria-posinset', c + '');
305
+ opt.setAttribute('aria-setsize', this.actvOptEles.length + '');
306
+ opt.hidden = false;
307
+ this.isSelected(opt, val);
308
+ }
309
+ else {
310
+ opt.removeAttribute('aria-posinset');
311
+ opt.removeAttribute('aria-setsize');
312
+ opt.hidden = true;
313
+ opt.selected = false;
314
+ }
315
+ opt.id = this.listId + '-option-' + i;
316
+ optIds.push(opt.id);
317
+ });
318
+ this.optionIds = optIds;
319
+ });
320
+ }
321
+ manageCanOpen() {
322
+ if (this.actvOptEles.length || this.hasNoResult)
323
+ this.canOpen = true;
324
+ else
325
+ this.canOpen = false;
326
+ }
327
+ /**
328
+ * Opens the dropdown if it can, it should and there are items to display.
329
+ */
330
+ manageDropdownDisplay() {
331
+ if (this.shouldOpen && this.canOpen && !this.disabled)
332
+ this.open = true;
333
+ if (!this.shouldOpen || !this.canOpen)
334
+ this.open = false;
335
+ }
336
+ fireActiveOptsEvent() {
337
+ this.nanoOptionsUpdated.emit(this.actvOptEles);
338
+ }
339
+ // Private logic
340
+ isSelected(opt, val) {
341
+ if (val === opt.value || this.selected.includes(opt.value)) {
342
+ opt.selected = true;
343
+ }
344
+ else
345
+ opt.selected = false;
346
+ }
347
+ get dropwdownOpen() {
348
+ if (!this.nanoDropdown || !this.open)
349
+ return false;
350
+ return true;
351
+ }
352
+ get exactMatch() {
353
+ return this.allOptEles.find((opt) => this.connectedInput.value === opt.value);
354
+ }
355
+ /** reflect value back to the connected input unless the event is cancelled */
356
+ changeInputValue(opt) {
357
+ var _a;
358
+ let nanoSelected;
359
+ if (this.selected.includes(opt.value)) {
360
+ // deselect option
361
+ this.selected = this.selected.filter((val) => val !== opt.value);
362
+ nanoSelected = this.nanoDeselect.emit(opt);
363
+ }
364
+ else {
365
+ // select new option
366
+ this.selected = [...this.selected];
367
+ nanoSelected = this.nanoSelect.emit(opt);
368
+ }
369
+ if (!nanoSelected.defaultPrevented) {
370
+ if (this.connectedInput)
371
+ this.connectedInput.value = opt.value;
372
+ const event = new window.Event('change');
373
+ (_a = this.connectedInput) === null || _a === void 0 ? void 0 : _a.dispatchEvent(event);
374
+ }
375
+ }
376
+ // this is for type="select" only.
377
+ // Filter options that start with text - aggregates letters (as opposed to getting the value from input)
378
+ setOptStartsWith() {
379
+ const attrFind = (toFind) => toFind.toLowerCase().substring(0, this.typeToSelect.length) ===
380
+ this.typeToSelect;
381
+ const foundEle = this.allOptEles.find((opt) => opt.value.trim().length > 0 &&
382
+ !opt.disabled &&
383
+ (attrFind(opt.textContent) ||
384
+ attrFind(opt.value) ||
385
+ attrFind(opt.label) ||
386
+ attrFind(opt.filterMeta)));
387
+ if (foundEle)
388
+ this.changeInputValue(foundEle);
389
+ }
390
+ // Event handlers
391
+ processSlottedContent() {
392
+ index$1.raf(() => {
393
+ var _a;
394
+ this.allOptEles = Array.from(this.host.querySelectorAll('nano-option'));
395
+ this.hasNoResult = !!this.host.querySelector('[slot="no-result"]');
396
+ if (((_a = this.connectedInput) === null || _a === void 0 ? void 0 : _a.value.length) && this.type !== 'select') {
397
+ this.inputChange();
398
+ }
399
+ else
400
+ this.actvOptEles = this.allOptEles;
401
+ });
402
+ }
403
+ // any changes to the connected input value will filter the list of active options
404
+ inputChange() {
405
+ if (this.disableFilter) {
406
+ this.actvOptEles = this.allOptEles;
407
+ return;
408
+ }
409
+ const val = this.connectedInput.value;
410
+ const valStr = val.trim().toLowerCase();
411
+ let exactMatch = false;
412
+ const activeEles = [];
413
+ const attrFind = (toFind) => toFind.toLowerCase().indexOf(valStr) > -1;
414
+ this.allOptEles.forEach((opt) => {
415
+ if ((val === opt.value || val === opt.label) &&
416
+ this.type !== 'selctMulti') {
417
+ opt.selected = true;
418
+ exactMatch = true;
419
+ }
420
+ else
421
+ this.isSelected(opt, val);
422
+ });
423
+ this.allOptEles.forEach((opt) => {
424
+ if (!valStr.length || exactMatch) {
425
+ activeEles.push(opt);
426
+ }
427
+ else if (opt.value.trim().length > 0 &&
428
+ !opt.disabled &&
429
+ (attrFind(opt.textContent) ||
430
+ attrFind(opt.value) ||
431
+ attrFind(opt.label) ||
432
+ attrFind(opt.filterMeta))) {
433
+ activeEles.push(opt);
434
+ }
435
+ });
436
+ this.isFiltered = valStr.length && !exactMatch;
437
+ this.actvOptEles = activeEles;
438
+ }
439
+ // Component lifecycle
440
+ connectedCallback() {
441
+ this.watchInputChange();
442
+ }
443
+ componentDidLoad() {
444
+ this.manageSlotChangeListener();
445
+ this.openWatcher();
446
+ }
447
+ componentDidRender() {
448
+ var _a;
449
+ setTimeout(() => {
450
+ if (!this.connectedInput)
451
+ console.warn('no `nano-input` found. `nano-datalist` should be nested within an `nano-input` or linked via `input` prop', this.host);
452
+ }, 500);
453
+ // if user is using 'options' prop (as oppsed to slot)
454
+ // add those options now - a single source of truth for options and <slot>
455
+ if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.length)
456
+ this.allOptEles = this.optionEles;
457
+ }
458
+ render() {
459
+ this.optionEles = [];
460
+ return (index.h(index.Host, { role: "listbox", "aria-owns": this.optionIds.join(' '), "aria-label": "Select options from the list below" }, index.h("nano-dropdown", Object.assign({}, this.dropDownConfig, { ref: (el) => (this.nanoDropdown = el), dialogTitle: "Select options from the list below", class: {
461
+ dlist__dropdown: true,
462
+ 'dlist--isfiltered': this.isFiltered,
463
+ }, onNanoAfterShow: this.handleShow, onNanoAfterHide: (_) => (this.open = false) }), index.h("nano-menu", { hidden: !this.actvOptEles.length, type: "listbox", label: this.inputLabel ? this.inputLabel.textContent : undefined, class: {
464
+ dlist__menu: true,
465
+ 'dlist__menu--open': this.dropwdownOpen,
466
+ }, tabIndex: -1, onNanoSelect: this.optSelected, onKeyDown: this.optionKeyDown, ref: (el) => (this.listBox = el) }, index.h("slot", { name: "list-top" }), !this.options.length && index.h("slot", null), !!this.options.length && (index.h("slot", null, this.options.map((option, i) => {
467
+ if (option.value || option.label) {
468
+ return (index.h("nano-option", { ref: (el) => this.optionEles.push(el), key: option.label + i, label: option.label, value: option.value, "aria-posinset": i, "aria-setsize": this.options.length, selected: option.selected, id: this.listId + '-option-' + i }, option.label ? option.label : option.value));
469
+ }
470
+ }))), index.h("slot", { name: "list-bottom" })), index.h("nano-menu", { type: "listbox", label: "No results found", hidden: !!this.actvOptEles.length, class: {
471
+ dlist__menu: true,
472
+ 'dlist__menu--open': this.dropwdownOpen,
473
+ } }, index.h("slot", { name: "no-result" })), !!this.actvOptEles && (index.h("div", { "aria-live": "polite", role: "status", class: "dlist__status" }, this.actvOptEles.length, " result", this.actvOptEles.length > 1 ? 's' : '', " available.")))));
474
+ }
475
+ get host() { return index.getElement(this); }
476
+ static get watchers() { return {
477
+ "open": ["openWatcher"],
478
+ "input": ["watchInputChange"],
479
+ "options": ["manageSlotChangeListener"],
480
+ "type": ["watchTypeChange"],
481
+ "connectedInput": ["watchTypeChange", "manageInputEvents"],
482
+ "selected": ["watchActvOptChange"],
483
+ "actvOptEles": ["watchActvOptChange", "manageCanOpen", "fireActiveOptsEvent"],
484
+ "hasNoResult": ["manageCanOpen"],
485
+ "shouldOpen": ["manageDropdownDisplay"],
486
+ "canOpen": ["manageDropdownDisplay"]
487
+ }; }
488
+ };
489
+ DataList.style = datalistCss;
490
+
491
+ const menuCss = ":host{-webkit-box-sizing:border-box;box-sizing:border-box}*,*::before,*::after{-webkit-box-sizing:border-box;box-sizing:border-box}[hidden]{display:none !important}:host{--padding-start:var(--nano-spacing-medium, 16px);--padding-end:var(--nano-spacing-medium, 16px);--padding-top:var(--nano-spacing-small, 8px);--padding-bottom:var(--nano-spacing-small, 8px);--secondary-padding-top:0;--secondary-padding-bottom:0;--bg-color-hover:#f2f7f9;--bg-color-focus:#f2f7f9;--bg-color-selected:#f2f7f9;--color-hover:#007495;--color-selected:#007495;--color-focus:#007495;--focus-outline:none;--font-size:0.9em;display:block}.menu{font-size:var(--font-size, 0.9em);-ms-scroll-chaining:none;overscroll-behavior:none;min-width:var(--width);position:relative}.menu:focus{outline:none}::slotted(*:not(nano-nav-item):not(nano-option):not(hr):not(slot)){padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:block}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){::slotted(*:not(nano-nav-item):not(nano-option):not(hr):not(slot)){padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}";
492
+
493
+ const CANSHADOW = !!document.head.attachShadow;
494
+ let Menu = class {
495
+ constructor(hostRef) {
496
+ index.registerInstance(this, hostRef);
497
+ this.nanoFocus = index.createEvent(this, "nanoFocus", 7);
498
+ this.nanoBlur = index.createEvent(this, "nanoBlur", 7);
499
+ this.nanoSelect = index.createEvent(this, "nanoSelect", 7);
500
+ this.ignoreMouseEvents = false;
501
+ this.typeToSelect = '';
502
+ this._hasFocus = false;
503
+ /** changes the role of the underlying control - sometimes required for semantics */
504
+ this.type = 'menu';
505
+ this.handleFocus = () => {
506
+ this.setActiveFocusItem(this.selectedItem || this.getItems[0]);
507
+ this._hasFocus = true;
508
+ this.nanoFocus.emit();
509
+ };
510
+ this.handleClick = (event) => {
511
+ const target = event.target;
512
+ const item = target.closest('nano-nav-item');
513
+ if (item && !item.disabled) {
514
+ this.nanoSelect.emit(item);
515
+ }
516
+ };
517
+ this.handleKeyDown = (event) => {
518
+ // When keying through the menu, if the mouse happens to be hovering over a menu item and the menu scrolls, the
519
+ // mouseout/mouseover event will fire causing the selection to be different than what the user expects. This gives
520
+ // us a way to temporarily ignore mouse events while the user is interacting with a keyboard.
521
+ clearTimeout(this.ignoreMouseTimeout);
522
+ this.ignoreMouseTimeout = setTimeout(() => (this.ignoreMouseEvents = false), 500);
523
+ this.ignoreMouseEvents = true;
524
+ // Make a selection when pressing enter
525
+ switch (event.key) {
526
+ case ' ':
527
+ if (this.activeItem)
528
+ this.activeItem.click();
529
+ break;
530
+ case 'ArrowDown':
531
+ case 'ArrowUp':
532
+ case 'PageDown':
533
+ case 'PageUp':
534
+ case 'Home':
535
+ case 'End':
536
+ const items = this.getItems;
537
+ const selectedItem = this.activeItem;
538
+ let index = items.indexOf(selectedItem);
539
+ if (items.length) {
540
+ event.preventDefault();
541
+ if (event.key === 'ArrowDown') {
542
+ index++;
543
+ }
544
+ else if (event.key === 'ArrowUp') {
545
+ index--;
546
+ }
547
+ else if (event.key === 'Home' || event.key === 'PageUp') {
548
+ index = 0;
549
+ }
550
+ else if (event.key === 'End' || event.key === 'PageDown') {
551
+ index = items.length - 1;
552
+ }
553
+ if (index < 0)
554
+ index = items.length - 1;
555
+ if (index > items.length - 1)
556
+ index = 0;
557
+ this.setActiveFocusItem(items[index]);
558
+ if (items[index])
559
+ items[index].scrollIntoView({ block: 'nearest' });
560
+ return;
561
+ }
562
+ break;
563
+ }
564
+ // Handle type-to-search behavior when non-control characters are entered
565
+ if (event.key === ' ' || /^[a-z0-9]+$/i.test(event.key)) {
566
+ clearTimeout(this.typeToSelectTimeout);
567
+ this.typeToSelectTimeout = setTimeout(() => (this.typeToSelect = ''), 750);
568
+ this.typeToSelect += event.key;
569
+ const items = this.getItems;
570
+ for (const item of items) {
571
+ const slot$1 = item.shadowRoot.querySelector('slot:not([name])');
572
+ const label = slot.getTextContent(slot$1).toLowerCase().trim();
573
+ if (label.substring(0, this.typeToSelect.length) === this.typeToSelect) {
574
+ this.setActiveFocusItem(item);
575
+ break;
576
+ }
577
+ }
578
+ }
579
+ };
580
+ this.handleMouseOver = (event) => {
581
+ const target = event.target;
582
+ const item = target.closest('nano-nav-item') || target.closest('nano-option');
583
+ if (item && !this.ignoreMouseEvents) {
584
+ this.setActiveFocusItem(item);
585
+ }
586
+ };
587
+ }
588
+ // Public API
589
+ /** get the focus state of the menu @readonly */
590
+ get hasFocus() {
591
+ return this._hasFocus;
592
+ }
593
+ // Public Methods
594
+ /** Sets focus on the menu. */
595
+ async setFocus() {
596
+ var _a;
597
+ if ((_a = this.menu) === null || _a === void 0 ? void 0 : _a.focus)
598
+ this.menu.focus({ preventScroll: true });
599
+ }
600
+ /** Removes focus from the menu. */
601
+ async removeFocus() {
602
+ var _a;
603
+ if ((_a = this.menu) === null || _a === void 0 ? void 0 : _a.blur)
604
+ this.menu.blur();
605
+ }
606
+ /** Sets the current active item */
607
+ async showActiveElement() {
608
+ if (this.selectedItem)
609
+ this.selectedItem.scrollIntoView({ block: 'nearest' });
610
+ }
611
+ /** Removes any active item's state */
612
+ async resetActiveItem() {
613
+ this.getItems
614
+ .filter((i) => i.tagName.toLowerCase() === 'nano-option')
615
+ .map((i) => i.setAttribute('tabindex', '-1'));
616
+ }
617
+ // Private methods
618
+ get getItems() {
619
+ let items;
620
+ let opened = this.el.querySelectorAll('nano-nav-item.secondary-open');
621
+ if (opened.length) {
622
+ const ctx = opened[opened.length - 1];
623
+ items = Array.from(ctx.querySelectorAll('nano-nav-item, nano-option'));
624
+ }
625
+ else {
626
+ items = dom.getDirectChildren(this.el, 'nano-nav-item, nano-option', 'slot');
627
+ }
628
+ return items.filter((el) => !el.disabled && !el.hidden);
629
+ }
630
+ get activeItem() {
631
+ const activeElement$1 = activeElement.getActiveElement();
632
+ return this.getItems.find((i) => i.getAttribute('tabindex') === '0' ||
633
+ i === activeElement$1 ||
634
+ i.classList.contains('has-focus'));
635
+ }
636
+ get selectedItem() {
637
+ const activeElement$1 = activeElement.getActiveElement();
638
+ return this.getItems.find((i) => i.selected || i === activeElement$1);
639
+ }
640
+ async setActiveFocusItem(item, focus = true) {
641
+ const items = this.getItems;
642
+ let activeItem = !item || item.disabled ? items.find((i) => i.selected) || items[0] : item;
643
+ items
644
+ .filter((i) => i.tagName.toLowerCase() === 'nano-option')
645
+ .map((i) => i.setAttribute('tabindex', i === activeItem ? '0' : '-1'));
646
+ if (!focus)
647
+ return;
648
+ if (activeItem) {
649
+ activeItem.setFocus
650
+ ? activeItem.setFocus()
651
+ : activeItem.focus();
652
+ }
653
+ else
654
+ this.menu.focus();
655
+ }
656
+ // Event Handlers
657
+ handleBlur(e) {
658
+ if (!this.hasFocus)
659
+ return;
660
+ const kev = e;
661
+ let found;
662
+ if (kev.key) {
663
+ if (kev.key !== 'Tab')
664
+ return;
665
+ found =
666
+ activeElement.getActiveElement() &&
667
+ activeElement.getActiveElement().closest(this.el.tagName.toLowerCase()) === this.el;
668
+ }
669
+ else
670
+ found = !!e.composedPath().find((el) => el === this.el);
671
+ if (!found) {
672
+ this.resetActiveItem();
673
+ this._hasFocus = false;
674
+ this.nanoBlur.emit();
675
+ }
676
+ }
677
+ // Component Lifecycle
678
+ render() {
679
+ return (index.h(index.Host, { class: {
680
+ legacy: !CANSHADOW,
681
+ } }, index.h("div", { onClick: this.handleClick, onKeyDown: this.handleKeyDown, onMouseOver: this.handleMouseOver, onFocus: this.handleFocus, "aria-label": this.label ? this.label : undefined, role: this.type, ref: (el) => (this.menu = el), part: "base", class: {
682
+ menu: true,
683
+ ['menu--' + this.type]: true,
684
+ 'menu--has-focus': this.hasFocus,
685
+ }, tabIndex: -1 }, index.h("slot", null))));
686
+ }
687
+ get el() { return index.getElement(this); }
688
+ };
689
+ Menu.style = menuCss;
690
+
691
+ const optionCss = ":host{-webkit-box-sizing:border-box;box-sizing:border-box}*,*::before,*::after{-webkit-box-sizing:border-box;box-sizing:border-box}[hidden]{display:none !important}:host{--bg:none;--bg-selected:var(--nano-select-opt-bg, #f2f7f9);--bg-focus:var(--nano-color-base, var(--nano-color-primary-tint, #2689a5));--bg-disabled:none;--color:var(--input-text-color, var(--nano-input-text-color, #4a4a4a));--color-selected:var(--nano-color-base, var(--nano-color-primary, #007495));--color-focus:var(--nano-color-contrast, var(--nano-color-primary-contrast, #fff));--color-disabled:#b5aea7;--opt-icon-size:1.6em;display:block;color:var(--color);overflow:hidden;font-size:14px;font-size:clamp(12px, .9em, 16px)}:host(:focus){outline:none}.option{position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch;width:100%;background:var(--bg);padding-left:var(--padding-start);padding-right:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom)}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.option{padding-left:unset;padding-right:unset;-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end)}}:host(:focus) .option:not(.option--disabled),:host .option.option--selected{outline:none;background:var(--bg-selected);color:var(--color-selected)}:host(:focus) .option:not(.option--disabled){background:var(--bg-focus);color:var(--color-focus)}.option.option--disabled{outline:none;color:var(--color-disabled);cursor:not-allowed;background:var(--bg-disabled)}.option.option--novalue{font-style:italic;opacity:0.7}.option__label{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.option__start{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.option__start ::slotted(nano-icon){font-size:var(--opt-icon-size)}.option__start ::slotted(:last-child){margin-right:0.5em}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.option__start ::slotted(:last-child){margin-right:unset;-webkit-margin-end:0.5em;margin-inline-end:0.5em}}.option__end{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.option__end ::slotted(nano-icon){font-size:var(--opt-icon-size)}.option__end ::slotted(:first-child){margin-left:0.5em}@supports ((-webkit-margin-start: 0) or (margin-inline-start: 0)) or (-webkit-margin-start: 0){.option__end ::slotted(:first-child){margin-left:unset;-webkit-margin-start:0.5em;margin-inline-start:0.5em;}}.option__check{visibility:hidden;display:-webkit-box;display:-ms-flexbox;display:flex;position:absolute;left:0.6em;top:calc(50% - 0.6em);-webkit-box-align:center;-ms-flex-align:center;align-items:center;font-size:0.9em}.option--selected:not(.option--novalue) .option__check{visibility:visible}";
692
+
693
+ let optIds = 0;
694
+ let Option = class {
695
+ constructor(hostRef) {
696
+ index.registerInstance(this, hostRef);
697
+ this.nanoSelect = index.createEvent(this, "nanoSelect", 7);
698
+ this.optId = `nano-option-${optIds++}`;
699
+ this.hasFocus = false;
700
+ // Public API
701
+ /**
702
+ * Value of the option
703
+ */
704
+ this.value = '';
705
+ /**
706
+ * Label of the option
707
+ */
708
+ this.label = '';
709
+ /**
710
+ * Whether this option is selected
711
+ */
712
+ this.selected = false;
713
+ /**
714
+ * Whether this option should be disabled
715
+ */
716
+ this.disabled = false;
717
+ /** You can add extra meta for this option. When displayed in a list, users
718
+ * search / filter via extra related terms. Another usecase is 'endonyms'
719
+ */
720
+ this.filterMeta = '';
721
+ this.handleClick = throttle.debounce(this.handleClick.bind(this), 5);
722
+ }
723
+ valueChanged() {
724
+ if (!this.value || !this.value.length)
725
+ this.value = this.labelContent;
726
+ }
727
+ labelChanged() {
728
+ if (!this.label || !this.label.length)
729
+ this.label = this.labelContent.length ? this.labelContent : this.value;
730
+ }
731
+ // Event handlers
732
+ // stop scrolling on select
733
+ handleKeyDown(e) {
734
+ if (e.key !== ' ' && e.key !== 'Enter')
735
+ return;
736
+ e.preventDefault();
737
+ this.nanoSelect.emit(this.host);
738
+ }
739
+ handleClick() {
740
+ if (this.disabled)
741
+ return;
742
+ this.nanoSelect.emit(this.host);
743
+ }
744
+ // Private logic
745
+ get labelContent() {
746
+ return dom.getDirectChildren(this.host, '*:not([slot])', false)
747
+ .map((el) => el.textContent)
748
+ .join(' ')
749
+ .trim();
750
+ }
751
+ // Component lifecycle
752
+ componentWillLoad() {
753
+ this.valueChanged();
754
+ this.labelChanged();
755
+ }
756
+ render() {
757
+ return (index.h(index.Host, { role: "option", "aria-selected": this.selected ? 'true' : 'false', "aria-disabled": this.disabled ? 'true' : 'false' }, index.h("div", { onMouseDown: this.handleClick, id: this.optId, class: {
758
+ option: true,
759
+ 'option--selected': this.selected,
760
+ 'option--disabled': this.disabled,
761
+ 'option--novalue': !this.value,
762
+ } }, index.h("div", { part: "check-icon", class: "option__check" }, index.h("slot", { name: "check-icon" }, index.h("nano-icon", { name: "light/check", "aria-hidden": "true" }))), index.h("div", { part: "start", class: "option__start" }, index.h("slot", { name: "start" })), index.h("div", { part: "label", class: "option__label" }, index.h("slot", null, this.label || this.value)), index.h("div", { part: "end", class: "option__end" }, index.h("slot", { name: "end" })))));
763
+ }
764
+ get host() { return index.getElement(this); }
765
+ static get watchers() { return {
766
+ "value": ["valueChanged"],
767
+ "label": ["labelChanged"]
768
+ }; }
769
+ };
770
+ Option.style = optionCss;
771
+
772
+ exports.nano_datalist = DataList;
773
+ exports.nano_menu = Menu;
774
+ exports.nano_option = Option;
775
+
776
+ //# sourceMappingURL=nano-datalist_3.cjs.entry.js.map