@nanoporetech-digital/components 3.2.0 → 3.3.1

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 (463) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/dist/cjs/dom-d7c33f11.js.map +1 -1
  3. package/dist/cjs/index.cjs.js +1 -1
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/{modal-f09e431f.js → modal-e4defcc3.js} +3 -3
  6. package/dist/cjs/{modal-f09e431f.js.map → modal-e4defcc3.js.map} +1 -1
  7. package/dist/cjs/nano-alert.cjs.entry.js +3 -3
  8. package/dist/cjs/nano-alert.cjs.entry.js.map +1 -1
  9. package/dist/cjs/nano-algolia.cjs.entry.js +1 -1
  10. package/dist/cjs/nano-algolia.cjs.entry.js.map +1 -1
  11. package/dist/cjs/nano-aspect-ratio.cjs.entry.js +1 -1
  12. package/dist/cjs/nano-aspect-ratio.cjs.entry.js.map +1 -1
  13. package/dist/cjs/nano-checkbox-group.cjs.entry.js +1 -1
  14. package/dist/cjs/nano-checkbox-group.cjs.entry.js.map +1 -1
  15. package/dist/cjs/nano-checkbox.cjs.entry.js +1 -1
  16. package/dist/cjs/nano-checkbox.cjs.entry.js.map +1 -1
  17. package/dist/cjs/nano-components.cjs.js +1 -1
  18. package/dist/cjs/nano-datalist_3.cjs.entry.js +2 -2
  19. package/dist/cjs/nano-datalist_3.cjs.entry.js.map +1 -1
  20. package/dist/cjs/nano-date-input.cjs.entry.js +1 -1
  21. package/dist/cjs/nano-date-input.cjs.entry.js.map +1 -1
  22. package/dist/cjs/nano-date-picker.cjs.entry.js +1 -1
  23. package/dist/cjs/nano-date-picker.cjs.entry.js.map +1 -1
  24. package/dist/cjs/nano-details.cjs.entry.js +1 -1
  25. package/dist/cjs/nano-details.cjs.entry.js.map +1 -1
  26. package/dist/cjs/nano-dialog.cjs.entry.js +3 -3
  27. package/dist/cjs/nano-dialog.cjs.entry.js.map +1 -1
  28. package/dist/cjs/nano-drawer.cjs.entry.js +3 -3
  29. package/dist/cjs/nano-drawer.cjs.entry.js.map +1 -1
  30. package/dist/cjs/nano-dropdown.cjs.entry.js +2 -2
  31. package/dist/cjs/nano-dropdown.cjs.entry.js.map +1 -1
  32. package/dist/cjs/nano-file-upload.cjs.entry.js +1 -1
  33. package/dist/cjs/nano-file-upload.cjs.entry.js.map +1 -1
  34. package/dist/cjs/nano-global-nav-user-profile_3.cjs.entry.js +13 -8
  35. package/dist/cjs/nano-global-nav-user-profile_3.cjs.entry.js.map +1 -1
  36. package/dist/cjs/nano-global-nav.cjs.entry.js +35 -15
  37. package/dist/cjs/nano-global-nav.cjs.entry.js.map +1 -1
  38. package/dist/cjs/nano-global-search-results.cjs.entry.js +6 -3
  39. package/dist/cjs/nano-global-search-results.cjs.entry.js.map +1 -1
  40. package/dist/cjs/nano-grid_3.cjs.entry.js +2 -2
  41. package/dist/cjs/nano-grid_3.cjs.entry.js.map +1 -1
  42. package/dist/cjs/nano-hero.cjs.entry.js +1 -1
  43. package/dist/cjs/nano-hero.cjs.entry.js.map +1 -1
  44. package/dist/cjs/nano-icon-button.cjs.entry.js +1 -1
  45. package/dist/cjs/nano-icon-button.cjs.entry.js.map +1 -1
  46. package/dist/cjs/nano-icon.cjs.entry.js +1 -1
  47. package/dist/cjs/nano-icon.cjs.entry.js.map +1 -1
  48. package/dist/cjs/nano-input.cjs.entry.js +1 -1
  49. package/dist/cjs/nano-input.cjs.entry.js.map +1 -1
  50. package/dist/cjs/nano-menu-drawer.cjs.entry.js +1 -1
  51. package/dist/cjs/nano-menu-drawer.cjs.entry.js.map +1 -1
  52. package/dist/cjs/nano-progress-bar.cjs.entry.js +1 -1
  53. package/dist/cjs/nano-progress-bar.cjs.entry.js.map +1 -1
  54. package/dist/cjs/nano-range.cjs.entry.js +1 -1
  55. package/dist/cjs/nano-range.cjs.entry.js.map +1 -1
  56. package/dist/cjs/nano-rating.cjs.entry.js +1 -1
  57. package/dist/cjs/nano-rating.cjs.entry.js.map +1 -1
  58. package/dist/cjs/nano-resize-observe_2.cjs.entry.js +23 -12
  59. package/dist/cjs/nano-resize-observe_2.cjs.entry.js.map +1 -1
  60. package/dist/cjs/nano-slide.cjs.entry.js +1 -1
  61. package/dist/cjs/nano-slide.cjs.entry.js.map +1 -1
  62. package/dist/cjs/nano-slides.cjs.entry.js +1 -1
  63. package/dist/cjs/nano-slides.cjs.entry.js.map +1 -1
  64. package/dist/cjs/nano-spinner.cjs.entry.js +1 -1
  65. package/dist/cjs/nano-spinner.cjs.entry.js.map +1 -1
  66. package/dist/cjs/nano-split-pane.cjs.entry.js +1 -1
  67. package/dist/cjs/nano-split-pane.cjs.entry.js.map +1 -1
  68. package/dist/cjs/nano-sticker.cjs.entry.js +1 -1
  69. package/dist/cjs/nano-sticker.cjs.entry.js.map +1 -1
  70. package/dist/cjs/nano-tab-content.cjs.entry.js +1 -1
  71. package/dist/cjs/nano-tab-content.cjs.entry.js.map +1 -1
  72. package/dist/cjs/nano-tab-group.cjs.entry.js +1 -1
  73. package/dist/cjs/nano-tab-group.cjs.entry.js.map +1 -1
  74. package/dist/cjs/nano-tab.cjs.entry.js +1 -1
  75. package/dist/cjs/nano-tab.cjs.entry.js.map +1 -1
  76. package/dist/cjs/{nano-table-7dbe799c.js → nano-table-10d45fe4.js} +36 -33
  77. package/dist/cjs/nano-table-10d45fe4.js.map +1 -0
  78. package/dist/cjs/nano-table.cjs.entry.js +1 -1
  79. package/dist/cjs/nano-tooltip.cjs.entry.js +1 -1
  80. package/dist/cjs/nano-tooltip.cjs.entry.js.map +1 -1
  81. package/dist/cjs/{tabbable-de4c23d8.js → tabbable-bdf10c84.js} +13 -4
  82. package/dist/cjs/tabbable-bdf10c84.js.map +1 -0
  83. package/dist/cjs/{table.worker-fe960deb.js → table.worker-a192a107.js} +2 -2
  84. package/dist/cjs/table.worker-a192a107.js.map +1 -0
  85. package/dist/collection/components/alert/alert.css +16 -56
  86. package/dist/collection/components/algolia/algolia.css +5 -22
  87. package/dist/collection/components/aspect-ratio/aspect-ratio.css +2 -4
  88. package/dist/collection/components/checkbox/checkbox-group.css +8 -19
  89. package/dist/collection/components/checkbox/checkbox.css +24 -61
  90. package/dist/collection/components/date-input/date-input.css +8 -29
  91. package/dist/collection/components/date-picker/date-picker.css +22 -61
  92. package/dist/collection/components/details/details.css +7 -27
  93. package/dist/collection/components/dialog/dialog.css +20 -79
  94. package/dist/collection/components/drawer/drawer.css +13 -42
  95. package/dist/collection/components/dropdown/dropdown.css +5 -13
  96. package/dist/collection/components/file-upload/file-upload.css +45 -127
  97. package/dist/collection/components/global-nav/global-nav.js +38 -17
  98. package/dist/collection/components/global-nav/global-nav.js.map +1 -1
  99. package/dist/collection/components/global-nav/style/global-nav.css +160 -320
  100. package/dist/collection/components/global-search-results/global-search-results.css +81 -248
  101. package/dist/collection/components/global-search-results/global-search-results.js +22 -2
  102. package/dist/collection/components/global-search-results/global-search-results.js.map +1 -1
  103. package/dist/collection/components/grid/grid.css +21 -76
  104. package/dist/collection/components/hero/hero.css +22 -63
  105. package/dist/collection/components/icon/icon.css +2 -5
  106. package/dist/collection/components/icon-button/icon-button.css +4 -15
  107. package/dist/collection/components/img/img.css +9 -19
  108. package/dist/collection/components/input/input.css +34 -148
  109. package/dist/collection/components/menu/menu.css +1 -2
  110. package/dist/collection/components/menu-drawer/menu-drawer.css +16 -47
  111. package/dist/collection/components/nav-item/nav-item.css +73 -147
  112. package/dist/collection/components/nav-item/nav-item.js +22 -6
  113. package/dist/collection/components/nav-item/nav-item.js.map +1 -1
  114. package/dist/collection/components/option/option.css +10 -40
  115. package/dist/collection/components/progress-bar/progress-bar.css +5 -26
  116. package/dist/collection/components/range/range.css +20 -56
  117. package/dist/collection/components/rating/rating.css +9 -28
  118. package/dist/collection/components/resize-observe/resize-observe.js +38 -12
  119. package/dist/collection/components/resize-observe/resize-observe.js.map +1 -1
  120. package/dist/collection/components/select/select.css +56 -210
  121. package/dist/collection/components/skeleton/skeleton.css +2 -17
  122. package/dist/collection/components/slides/slide.css +4 -13
  123. package/dist/collection/components/slides/slides.css +3 -14
  124. package/dist/collection/components/spinner/spinner.css +34 -122
  125. package/dist/collection/components/split-pane/split-pane.css +4 -18
  126. package/dist/collection/components/sticker/sticker.css +8 -18
  127. package/dist/collection/components/table/table.children.js +11 -11
  128. package/dist/collection/components/table/table.children.js.map +1 -1
  129. package/dist/collection/components/table/table.css +110 -50
  130. package/dist/collection/components/table/table.js +28 -24
  131. package/dist/collection/components/table/table.js.map +1 -1
  132. package/dist/collection/components/table/table.service.js +1 -1
  133. package/dist/collection/components/table/table.service.js.map +1 -1
  134. package/dist/collection/components/table/table.store.js +2 -2
  135. package/dist/collection/components/table/table.store.js.map +1 -1
  136. package/dist/collection/components/tabs/tab-content.css +11 -59
  137. package/dist/collection/components/tabs/tab-group.css +20 -77
  138. package/dist/collection/components/tabs/tab.css +11 -30
  139. package/dist/collection/components/tooltip/tooltip.css +26 -56
  140. package/dist/collection/utils/dom.js.map +1 -1
  141. package/dist/collection/utils/modal.js +1 -1
  142. package/dist/collection/utils/modal.js.map +1 -1
  143. package/dist/collection/utils/tabbable.js +12 -3
  144. package/dist/collection/utils/tabbable.js.map +1 -1
  145. package/dist/components/algolia.js +1 -1
  146. package/dist/components/algolia.js.map +1 -1
  147. package/dist/components/date-picker.js +1 -1
  148. package/dist/components/date-picker.js.map +1 -1
  149. package/dist/components/dom.js.map +1 -1
  150. package/dist/components/dropdown.js +1 -1
  151. package/dist/components/dropdown.js.map +1 -1
  152. package/dist/components/grid.js +1 -1
  153. package/dist/components/grid.js.map +1 -1
  154. package/dist/components/icon-button.js +1 -1
  155. package/dist/components/icon-button.js.map +1 -1
  156. package/dist/components/icon.js +1 -1
  157. package/dist/components/icon.js.map +1 -1
  158. package/dist/components/img.js +1 -1
  159. package/dist/components/img.js.map +1 -1
  160. package/dist/components/input.js +1 -1
  161. package/dist/components/input.js.map +1 -1
  162. package/dist/components/menu.js +1 -1
  163. package/dist/components/menu.js.map +1 -1
  164. package/dist/components/modal.js +1 -1
  165. package/dist/components/modal.js.map +1 -1
  166. package/dist/components/nano-alert.js +1 -1
  167. package/dist/components/nano-alert.js.map +1 -1
  168. package/dist/components/nano-aspect-ratio.js +1 -1
  169. package/dist/components/nano-aspect-ratio.js.map +1 -1
  170. package/dist/components/nano-checkbox-group.js +1 -1
  171. package/dist/components/nano-checkbox-group.js.map +1 -1
  172. package/dist/components/nano-checkbox.js +1 -1
  173. package/dist/components/nano-checkbox.js.map +1 -1
  174. package/dist/components/nano-date-input.js +1 -1
  175. package/dist/components/nano-date-input.js.map +1 -1
  176. package/dist/components/nano-details.js +1 -1
  177. package/dist/components/nano-details.js.map +1 -1
  178. package/dist/components/nano-dialog.js +1 -1
  179. package/dist/components/nano-dialog.js.map +1 -1
  180. package/dist/components/nano-drawer.js +1 -1
  181. package/dist/components/nano-drawer.js.map +1 -1
  182. package/dist/components/nano-file-upload.js +1 -1
  183. package/dist/components/nano-file-upload.js.map +1 -1
  184. package/dist/components/nano-global-nav.js +35 -15
  185. package/dist/components/nano-global-nav.js.map +1 -1
  186. package/dist/components/nano-global-search-results.js +7 -4
  187. package/dist/components/nano-global-search-results.js.map +1 -1
  188. package/dist/components/nano-hero.js +1 -1
  189. package/dist/components/nano-hero.js.map +1 -1
  190. package/dist/components/nano-menu-drawer.js +1 -1
  191. package/dist/components/nano-menu-drawer.js.map +1 -1
  192. package/dist/components/nano-range.js +1 -1
  193. package/dist/components/nano-range.js.map +1 -1
  194. package/dist/components/nano-rating.js +1 -1
  195. package/dist/components/nano-rating.js.map +1 -1
  196. package/dist/components/nano-slide.js +1 -1
  197. package/dist/components/nano-slide.js.map +1 -1
  198. package/dist/components/nano-slides.js +1 -1
  199. package/dist/components/nano-slides.js.map +1 -1
  200. package/dist/components/nano-split-pane.js +1 -1
  201. package/dist/components/nano-split-pane.js.map +1 -1
  202. package/dist/components/nano-tab-content.js +1 -1
  203. package/dist/components/nano-tab-content.js.map +1 -1
  204. package/dist/components/nano-tab-group.js +1 -1
  205. package/dist/components/nano-tab-group.js.map +1 -1
  206. package/dist/components/nano-tab.js +1 -1
  207. package/dist/components/nano-tab.js.map +1 -1
  208. package/dist/components/nano-table.js +34 -31
  209. package/dist/components/nano-table.js.map +1 -1
  210. package/dist/components/nav-item.js +12 -7
  211. package/dist/components/nav-item.js.map +1 -1
  212. package/dist/components/option.js +1 -1
  213. package/dist/components/option.js.map +1 -1
  214. package/dist/components/progress-bar.js +1 -1
  215. package/dist/components/progress-bar.js.map +1 -1
  216. package/dist/components/resize-observe.js +23 -13
  217. package/dist/components/resize-observe.js.map +1 -1
  218. package/dist/components/select.js +1 -1
  219. package/dist/components/select.js.map +1 -1
  220. package/dist/components/skeleton.js +1 -1
  221. package/dist/components/skeleton.js.map +1 -1
  222. package/dist/components/spinner.js +1 -1
  223. package/dist/components/spinner.js.map +1 -1
  224. package/dist/components/sticker.js +1 -1
  225. package/dist/components/sticker.js.map +1 -1
  226. package/dist/components/tabbable.js +12 -3
  227. package/dist/components/tabbable.js.map +1 -1
  228. package/dist/components/tooltip.js +1 -1
  229. package/dist/components/tooltip.js.map +1 -1
  230. package/dist/custom-elements/index.js +157 -107
  231. package/dist/custom-elements/index.js.map +1 -1
  232. package/dist/esm/dom-d3ad49e2.js.map +1 -1
  233. package/dist/esm/index.js +1 -1
  234. package/dist/esm/loader.js +1 -1
  235. package/dist/esm/{modal-215df46b.js → modal-5c9ce466.js} +3 -3
  236. package/dist/esm/{modal-215df46b.js.map → modal-5c9ce466.js.map} +1 -1
  237. package/dist/esm/nano-alert.entry.js +3 -3
  238. package/dist/esm/nano-alert.entry.js.map +1 -1
  239. package/dist/esm/nano-algolia.entry.js +1 -1
  240. package/dist/esm/nano-algolia.entry.js.map +1 -1
  241. package/dist/esm/nano-aspect-ratio.entry.js +1 -1
  242. package/dist/esm/nano-aspect-ratio.entry.js.map +1 -1
  243. package/dist/esm/nano-checkbox-group.entry.js +1 -1
  244. package/dist/esm/nano-checkbox-group.entry.js.map +1 -1
  245. package/dist/esm/nano-checkbox.entry.js +1 -1
  246. package/dist/esm/nano-checkbox.entry.js.map +1 -1
  247. package/dist/esm/nano-components.js +1 -1
  248. package/dist/esm/nano-datalist_3.entry.js +2 -2
  249. package/dist/esm/nano-datalist_3.entry.js.map +1 -1
  250. package/dist/esm/nano-date-input.entry.js +1 -1
  251. package/dist/esm/nano-date-input.entry.js.map +1 -1
  252. package/dist/esm/nano-date-picker.entry.js +1 -1
  253. package/dist/esm/nano-date-picker.entry.js.map +1 -1
  254. package/dist/esm/nano-details.entry.js +1 -1
  255. package/dist/esm/nano-details.entry.js.map +1 -1
  256. package/dist/esm/nano-dialog.entry.js +3 -3
  257. package/dist/esm/nano-dialog.entry.js.map +1 -1
  258. package/dist/esm/nano-drawer.entry.js +3 -3
  259. package/dist/esm/nano-drawer.entry.js.map +1 -1
  260. package/dist/esm/nano-dropdown.entry.js +2 -2
  261. package/dist/esm/nano-dropdown.entry.js.map +1 -1
  262. package/dist/esm/nano-file-upload.entry.js +1 -1
  263. package/dist/esm/nano-file-upload.entry.js.map +1 -1
  264. package/dist/esm/nano-global-nav-user-profile_3.entry.js +13 -8
  265. package/dist/esm/nano-global-nav-user-profile_3.entry.js.map +1 -1
  266. package/dist/esm/nano-global-nav.entry.js +35 -15
  267. package/dist/esm/nano-global-nav.entry.js.map +1 -1
  268. package/dist/esm/nano-global-search-results.entry.js +7 -4
  269. package/dist/esm/nano-global-search-results.entry.js.map +1 -1
  270. package/dist/esm/nano-grid_3.entry.js +2 -2
  271. package/dist/esm/nano-grid_3.entry.js.map +1 -1
  272. package/dist/esm/nano-hero.entry.js +1 -1
  273. package/dist/esm/nano-hero.entry.js.map +1 -1
  274. package/dist/esm/nano-icon-button.entry.js +1 -1
  275. package/dist/esm/nano-icon-button.entry.js.map +1 -1
  276. package/dist/esm/nano-icon.entry.js +1 -1
  277. package/dist/esm/nano-icon.entry.js.map +1 -1
  278. package/dist/esm/nano-input.entry.js +1 -1
  279. package/dist/esm/nano-input.entry.js.map +1 -1
  280. package/dist/esm/nano-menu-drawer.entry.js +1 -1
  281. package/dist/esm/nano-menu-drawer.entry.js.map +1 -1
  282. package/dist/esm/nano-progress-bar.entry.js +1 -1
  283. package/dist/esm/nano-progress-bar.entry.js.map +1 -1
  284. package/dist/esm/nano-range.entry.js +1 -1
  285. package/dist/esm/nano-range.entry.js.map +1 -1
  286. package/dist/esm/nano-rating.entry.js +1 -1
  287. package/dist/esm/nano-rating.entry.js.map +1 -1
  288. package/dist/esm/nano-resize-observe_2.entry.js +23 -12
  289. package/dist/esm/nano-resize-observe_2.entry.js.map +1 -1
  290. package/dist/esm/nano-slide.entry.js +1 -1
  291. package/dist/esm/nano-slide.entry.js.map +1 -1
  292. package/dist/esm/nano-slides.entry.js +1 -1
  293. package/dist/esm/nano-slides.entry.js.map +1 -1
  294. package/dist/esm/nano-spinner.entry.js +1 -1
  295. package/dist/esm/nano-spinner.entry.js.map +1 -1
  296. package/dist/esm/nano-split-pane.entry.js +1 -1
  297. package/dist/esm/nano-split-pane.entry.js.map +1 -1
  298. package/dist/esm/nano-sticker.entry.js +1 -1
  299. package/dist/esm/nano-sticker.entry.js.map +1 -1
  300. package/dist/esm/nano-tab-content.entry.js +1 -1
  301. package/dist/esm/nano-tab-content.entry.js.map +1 -1
  302. package/dist/esm/nano-tab-group.entry.js +1 -1
  303. package/dist/esm/nano-tab-group.entry.js.map +1 -1
  304. package/dist/esm/nano-tab.entry.js +1 -1
  305. package/dist/esm/nano-tab.entry.js.map +1 -1
  306. package/dist/esm/{nano-table-93d25a68.js → nano-table-a7a5a3f8.js} +36 -33
  307. package/dist/esm/nano-table-a7a5a3f8.js.map +1 -0
  308. package/dist/esm/nano-table.entry.js +1 -1
  309. package/dist/esm/nano-tooltip.entry.js +1 -1
  310. package/dist/esm/nano-tooltip.entry.js.map +1 -1
  311. package/dist/esm/{tabbable-614f515e.js → tabbable-31485ff7.js} +13 -4
  312. package/dist/esm/tabbable-31485ff7.js.map +1 -0
  313. package/dist/esm/{table.worker-5d681b97.js → table.worker-d2b4d395.js} +2 -2
  314. package/dist/esm/table.worker-d2b4d395.js.map +1 -0
  315. package/dist/nano-components/index.esm.js +1 -1
  316. package/dist/nano-components/nano-components.css +1 -1
  317. package/dist/nano-components/nano-components.esm.js +1 -1
  318. package/dist/nano-components/p-11d3a90b.js +5 -0
  319. package/dist/nano-components/p-11d3a90b.js.map +1 -0
  320. package/dist/nano-components/p-14329940.entry.js +5 -0
  321. package/dist/nano-components/p-14329940.entry.js.map +1 -0
  322. package/dist/nano-components/{p-35295332.entry.js → p-151aad1e.entry.js} +5 -5
  323. package/dist/nano-components/{p-35295332.entry.js.map → p-151aad1e.entry.js.map} +1 -1
  324. package/dist/nano-components/p-15543295.entry.js +5 -0
  325. package/dist/nano-components/{p-6e3412d2.entry.js.map → p-15543295.entry.js.map} +1 -1
  326. package/dist/nano-components/p-1e709f87.entry.js +5 -0
  327. package/dist/nano-components/p-1e709f87.entry.js.map +1 -0
  328. package/dist/nano-components/p-1f347342.entry.js +5 -0
  329. package/dist/nano-components/{p-02df1f62.entry.js.map → p-1f347342.entry.js.map} +1 -1
  330. package/dist/nano-components/p-23575705.entry.js +5 -0
  331. package/dist/nano-components/{p-6958df8c.entry.js.map → p-23575705.entry.js.map} +1 -1
  332. package/dist/nano-components/p-244223f0.entry.js +5 -0
  333. package/dist/nano-components/{p-6cd59e58.entry.js.map → p-244223f0.entry.js.map} +1 -1
  334. package/dist/nano-components/p-284dd9a2.entry.js +5 -0
  335. package/dist/nano-components/{p-5107646c.entry.js.map → p-284dd9a2.entry.js.map} +1 -1
  336. package/dist/nano-components/p-2cb4615b.entry.js +5 -0
  337. package/dist/nano-components/{p-e3730878.entry.js.map → p-2cb4615b.entry.js.map} +1 -1
  338. package/dist/nano-components/p-36842a50.entry.js +5 -0
  339. package/dist/nano-components/{p-f69f93e9.entry.js.map → p-36842a50.entry.js.map} +1 -1
  340. package/dist/nano-components/p-3a1026d1.entry.js +5 -0
  341. package/dist/nano-components/p-3a1026d1.entry.js.map +1 -0
  342. package/dist/nano-components/p-40e13cd4.entry.js +5 -0
  343. package/dist/nano-components/p-40e13cd4.entry.js.map +1 -0
  344. package/dist/nano-components/p-41addb3a.entry.js +5 -0
  345. package/dist/nano-components/{p-0a5ad0ef.entry.js.map → p-41addb3a.entry.js.map} +1 -1
  346. package/dist/nano-components/{p-9a385481.js → p-45abbbdd.js} +2 -2
  347. package/dist/nano-components/p-45abbbdd.js.map +1 -0
  348. package/dist/nano-components/p-46b348b7.entry.js +5 -0
  349. package/dist/nano-components/{p-28f713fb.entry.js.map → p-46b348b7.entry.js.map} +1 -1
  350. package/dist/nano-components/p-4b69178e.entry.js +5 -0
  351. package/dist/nano-components/{p-5e33798f.entry.js.map → p-4b69178e.entry.js.map} +1 -1
  352. package/dist/nano-components/p-4f0e14b5.entry.js +5 -0
  353. package/dist/nano-components/{p-8f5e0022.entry.js.map → p-4f0e14b5.entry.js.map} +1 -1
  354. package/dist/nano-components/p-559a6492.entry.js +5 -0
  355. package/dist/nano-components/p-559a6492.entry.js.map +1 -0
  356. package/dist/nano-components/p-601e18d5.entry.js +5 -0
  357. package/dist/nano-components/p-601e18d5.entry.js.map +1 -0
  358. package/dist/nano-components/{p-619a1c8e.js → p-64200e25.js} +2 -2
  359. package/dist/nano-components/{p-39124baa.entry.js.map → p-64200e25.js.map} +0 -0
  360. package/dist/nano-components/p-69e5a37d.entry.js +5 -0
  361. package/dist/nano-components/{p-282987e6.entry.js.map → p-69e5a37d.entry.js.map} +1 -1
  362. package/dist/nano-components/p-751927d1.entry.js +5 -0
  363. package/dist/nano-components/{p-5d81773d.entry.js.map → p-751927d1.entry.js.map} +1 -1
  364. package/dist/nano-components/p-845ae77e.js.map +1 -1
  365. package/dist/nano-components/p-9059c8c1.entry.js +5 -0
  366. package/dist/nano-components/{p-d8e8d7e3.entry.js.map → p-9059c8c1.entry.js.map} +1 -1
  367. package/dist/nano-components/p-92504f7f.entry.js +5 -0
  368. package/dist/nano-components/{p-50fcb11c.entry.js.map → p-92504f7f.entry.js.map} +1 -1
  369. package/dist/nano-components/p-99fbae74.entry.js +5 -0
  370. package/dist/nano-components/{p-8a52a411.entry.js.map → p-99fbae74.entry.js.map} +1 -1
  371. package/dist/nano-components/p-9eeed8f5.entry.js +5 -0
  372. package/dist/nano-components/{p-4c97f05f.entry.js.map → p-9eeed8f5.entry.js.map} +1 -1
  373. package/dist/nano-components/p-a183e3c7.entry.js +5 -0
  374. package/dist/nano-components/{p-b290a970.entry.js.map → p-a183e3c7.entry.js.map} +1 -1
  375. package/dist/nano-components/p-a2e38472.entry.js +5 -0
  376. package/dist/nano-components/p-a2e38472.entry.js.map +1 -0
  377. package/dist/nano-components/p-b87539f0.entry.js +5 -0
  378. package/dist/nano-components/{p-efa8c520.entry.js.map → p-b87539f0.entry.js.map} +1 -1
  379. package/dist/nano-components/p-b9c8b99f.entry.js +5 -0
  380. package/dist/nano-components/p-b9c8b99f.entry.js.map +1 -0
  381. package/dist/nano-components/{p-cb79d1ec.js → p-c9a7c7ea.js} +2 -2
  382. package/dist/nano-components/{p-cb79d1ec.js.map → p-c9a7c7ea.js.map} +1 -1
  383. package/dist/nano-components/{p-c45851c3.entry.js → p-d1c8eca4.entry.js} +2 -2
  384. package/dist/nano-components/{p-c45851c3.entry.js.map → p-d1c8eca4.entry.js.map} +1 -1
  385. package/dist/nano-components/{p-39124baa.entry.js → p-d9d2807a.entry.js} +2 -2
  386. package/dist/nano-components/{p-619a1c8e.js.map → p-d9d2807a.entry.js.map} +0 -0
  387. package/dist/nano-components/{p-916e4b6b.entry.js → p-dba8a88d.entry.js} +2 -2
  388. package/dist/nano-components/{p-916e4b6b.entry.js.map → p-dba8a88d.entry.js.map} +1 -1
  389. package/dist/nano-components/p-e5408bc8.entry.js +5 -0
  390. package/dist/nano-components/{p-c5bb5540.entry.js.map → p-e5408bc8.entry.js.map} +1 -1
  391. package/dist/nano-components/p-f43d1d8e.entry.js +5 -0
  392. package/dist/nano-components/{p-66099557.entry.js.map → p-f43d1d8e.entry.js.map} +1 -1
  393. package/dist/nano-components/p-f7471cca.entry.js +5 -0
  394. package/dist/nano-components/{p-66ad1418.entry.js.map → p-f7471cca.entry.js.map} +1 -1
  395. package/dist/nano-components/p-fe94eeff.entry.js +5 -0
  396. package/dist/nano-components/{p-701e8ebf.entry.js.map → p-fe94eeff.entry.js.map} +1 -1
  397. package/dist/nano-components/p-feb9f164.entry.js +5 -0
  398. package/dist/nano-components/{p-81136f24.entry.js.map → p-feb9f164.entry.js.map} +1 -1
  399. package/dist/themes/nanopore.css +1 -1
  400. package/dist/themes/nanopore.css.map +1 -1
  401. package/dist/types/components/global-nav/global-nav.d.ts +11 -6
  402. package/dist/types/components/global-search-results/global-search-results.d.ts +5 -1
  403. package/dist/types/components/nav-item/nav-item.d.ts +11 -0
  404. package/dist/types/components/resize-observe/resize-observe.d.ts +5 -2
  405. package/dist/types/components/table/table.d.ts +9 -8
  406. package/dist/types/components/table/table.store.d.ts +1 -1
  407. package/dist/types/components.d.ts +12 -0
  408. package/dist/types/utils/dom.d.ts +1 -1
  409. package/docs-json.json +313 -52
  410. package/docs-vscode.json +2 -2
  411. package/package.json +2 -2
  412. package/dist/cjs/nano-table-7dbe799c.js.map +0 -1
  413. package/dist/cjs/tabbable-de4c23d8.js.map +0 -1
  414. package/dist/cjs/table.worker-fe960deb.js.map +0 -1
  415. package/dist/collection/components/global-nav/search-widget.js +0 -4
  416. package/dist/collection/components/global-nav/search-widget.js.map +0 -1
  417. package/dist/esm/nano-table-93d25a68.js.map +0 -1
  418. package/dist/esm/tabbable-614f515e.js.map +0 -1
  419. package/dist/esm/table.worker-5d681b97.js.map +0 -1
  420. package/dist/nano-components/p-02df1f62.entry.js +0 -5
  421. package/dist/nano-components/p-0a5ad0ef.entry.js +0 -5
  422. package/dist/nano-components/p-282987e6.entry.js +0 -5
  423. package/dist/nano-components/p-28b43ee9.entry.js +0 -5
  424. package/dist/nano-components/p-28b43ee9.entry.js.map +0 -1
  425. package/dist/nano-components/p-28f713fb.entry.js +0 -5
  426. package/dist/nano-components/p-37553477.entry.js +0 -5
  427. package/dist/nano-components/p-37553477.entry.js.map +0 -1
  428. package/dist/nano-components/p-42fa11c3.entry.js +0 -5
  429. package/dist/nano-components/p-42fa11c3.entry.js.map +0 -1
  430. package/dist/nano-components/p-4c386a43.js +0 -5
  431. package/dist/nano-components/p-4c386a43.js.map +0 -1
  432. package/dist/nano-components/p-4c97f05f.entry.js +0 -5
  433. package/dist/nano-components/p-50fcb11c.entry.js +0 -5
  434. package/dist/nano-components/p-5107646c.entry.js +0 -5
  435. package/dist/nano-components/p-5d81773d.entry.js +0 -5
  436. package/dist/nano-components/p-5e33798f.entry.js +0 -5
  437. package/dist/nano-components/p-653a25f8.entry.js +0 -5
  438. package/dist/nano-components/p-653a25f8.entry.js.map +0 -1
  439. package/dist/nano-components/p-66099557.entry.js +0 -5
  440. package/dist/nano-components/p-66ad1418.entry.js +0 -5
  441. package/dist/nano-components/p-6958df8c.entry.js +0 -5
  442. package/dist/nano-components/p-6cd59e58.entry.js +0 -5
  443. package/dist/nano-components/p-6e3412d2.entry.js +0 -5
  444. package/dist/nano-components/p-701e8ebf.entry.js +0 -5
  445. package/dist/nano-components/p-716064b6.entry.js +0 -5
  446. package/dist/nano-components/p-716064b6.entry.js.map +0 -1
  447. package/dist/nano-components/p-81136f24.entry.js +0 -5
  448. package/dist/nano-components/p-8a52a411.entry.js +0 -5
  449. package/dist/nano-components/p-8f5e0022.entry.js +0 -5
  450. package/dist/nano-components/p-9a385481.js.map +0 -1
  451. package/dist/nano-components/p-a151dea5.entry.js +0 -5
  452. package/dist/nano-components/p-a151dea5.entry.js.map +0 -1
  453. package/dist/nano-components/p-b290a970.entry.js +0 -5
  454. package/dist/nano-components/p-c5bb5540.entry.js +0 -5
  455. package/dist/nano-components/p-d8e8d7e3.entry.js +0 -5
  456. package/dist/nano-components/p-e3730878.entry.js +0 -5
  457. package/dist/nano-components/p-efa8c520.entry.js +0 -5
  458. package/dist/nano-components/p-f69f93e9.entry.js +0 -5
  459. package/dist/nano-components/p-f71f69c9.entry.js +0 -5
  460. package/dist/nano-components/p-f71f69c9.entry.js.map +0 -1
  461. package/dist/nano-components/p-fa2a6733.entry.js +0 -5
  462. package/dist/nano-components/p-fa2a6733.entry.js.map +0 -1
  463. package/dist/types/components/global-nav/search-widget.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["src/utils/modal.ts"],"names":["activeModals","Modal","[object Object]","element","this","tabDirection","handleFocusIn","bind","handleKeyDown","push","document","addEventListener","filter","modal","removeEventListener","length","event","path","composedPath","isActive","includes","tabbableElements","getTabbableElements","index","focus","preventScroll","key","shiftKey","setTimeout"],"mappings":";;;oCAEA,IAAIA,EAA8B,SAEbC,EAInBC,YAAYC,GAFZC,KAAAC,aAAuC,UAGrCD,KAAKD,QAAUA,EACfC,KAAKE,cAAgBF,KAAKE,cAAcC,KAAKH,MAC7CA,KAAKI,cAAgBJ,KAAKI,cAAcD,KAAKH,MAG/CF,WACEF,EAAaS,KAAKL,KAAKD,SACvBO,SAASC,iBAAiB,UAAWP,KAAKE,eAC1CI,SAASC,iBAAiB,UAAWP,KAAKI,eAG5CN,aACEF,EAAeA,EAAaY,QAAQC,GAAUA,IAAUT,KAAKD,UAC7DO,SAASI,oBAAoB,UAAWV,KAAKE,eAC7CI,SAASI,oBAAoB,UAAWV,KAAKI,eAG/CN,WAEE,OAAOF,EAAaA,EAAae,OAAS,KAAOX,KAAKD,QAGxDD,cAAcc,GACZ,MAAMC,EAAOD,EAAME,eAGnB,GAAId,KAAKe,aAAeF,EAAKG,SAAShB,KAAKD,SAAU,CACnD,MAAMkB,EAAmBC,EAAoBlB,KAAKD,SAClD,MAAMoB,EACJnB,KAAKC,eAAiB,WAAagB,EAAiBN,OAAS,EAAI,EACnEM,EAAiBE,GAAOC,MAAM,CAAEC,cAAe,QAInDvB,cAAcc,GAEZ,GAAIA,EAAMU,MAAQ,OAASV,EAAMW,SAAU,CACzCvB,KAAKC,aAAe,WACpBuB,YAAW,IAAOxB,KAAKC,aAAe","sourcesContent":["import { getTabbableElements } from './tabbable';\n\nlet activeModals: HTMLElement[] = [];\n\nexport default class Modal {\n element: HTMLElement;\n tabDirection: 'forward' | 'backward' = 'forward';\n\n constructor(element: HTMLElement) {\n this.element = element;\n this.handleFocusIn = this.handleFocusIn.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n }\n\n activate() {\n activeModals.push(this.element);\n document.addEventListener('focusin', this.handleFocusIn);\n document.addEventListener('keydown', this.handleKeyDown);\n }\n\n deactivate() {\n activeModals = activeModals.filter((modal) => modal !== this.element);\n document.removeEventListener('focusin', this.handleFocusIn);\n document.removeEventListener('keydown', this.handleKeyDown);\n }\n\n isActive() {\n // The \"active\" modal is always the most recent one shown\n return activeModals[activeModals.length - 1] === this.element;\n }\n\n handleFocusIn(event: Event) {\n const path = event.composedPath();\n\n // Trap focus so it doesn't go out of the modal's boundary\n if (this.isActive() && !path.includes(this.element)) {\n const tabbableElements = getTabbableElements(this.element);\n const index =\n this.tabDirection === 'backward' ? tabbableElements.length - 1 : 0;\n tabbableElements[index].focus({ preventScroll: true });\n }\n }\n\n handleKeyDown(event: KeyboardEvent) {\n // Quick hack to determine tab direction\n if (event.key === 'Tab' && event.shiftKey) {\n this.tabDirection = 'backward';\n setTimeout(() => (this.tabDirection = 'forward'));\n }\n }\n}\n"]}
1
+ {"version":3,"sources":["src/utils/modal.ts"],"names":["activeModals","Modal","[object Object]","element","this","tabDirection","handleFocusIn","bind","handleKeyDown","push","document","addEventListener","filter","modal","removeEventListener","length","event","path","composedPath","isActive","includes","tabbableElements","getTabbableElements","index","focus","preventScroll","key","shiftKey","setTimeout"],"mappings":";;;oCAEA,IAAIA,EAA8B,SAEbC,EAInBC,YAAYC,GAFZC,KAAAC,aAAuC,UAGrCD,KAAKD,QAAUA,EACfC,KAAKE,cAAgBF,KAAKE,cAAcC,KAAKH,MAC7CA,KAAKI,cAAgBJ,KAAKI,cAAcD,KAAKH,MAG/CF,WACEF,EAAaS,KAAKL,KAAKD,SACvBO,SAASC,iBAAiB,UAAWP,KAAKE,eAC1CI,SAASC,iBAAiB,UAAWP,KAAKI,eAG5CN,aACEF,EAAeA,EAAaY,QAAQC,GAAUA,IAAUT,KAAKD,UAC7DO,SAASI,oBAAoB,UAAWV,KAAKE,eAC7CI,SAASI,oBAAoB,UAAWV,KAAKI,eAG/CN,WAEE,OAAOF,EAAaA,EAAae,OAAS,KAAOX,KAAKD,QAGxDD,cAAcc,GACZ,MAAMC,EAAOD,EAAME,eAGnB,GAAId,KAAKe,aAAeF,EAAKG,SAAShB,KAAKD,SAAU,CACnD,MAAMkB,EAAmBC,EAAoBlB,KAAKD,SAClD,MAAMoB,EACJnB,KAAKC,eAAiB,WAAagB,EAAiBN,OAAS,EAAI,EACnEM,EAAiBE,IAAQC,MAAM,CAAEC,cAAe,QAIpDvB,cAAcc,GAEZ,GAAIA,EAAMU,MAAQ,OAASV,EAAMW,SAAU,CACzCvB,KAAKC,aAAe,WACpBuB,YAAW,IAAOxB,KAAKC,aAAe","sourcesContent":["import { getTabbableElements } from './tabbable';\n\nlet activeModals: HTMLElement[] = [];\n\nexport default class Modal {\n element: HTMLElement;\n tabDirection: 'forward' | 'backward' = 'forward';\n\n constructor(element: HTMLElement) {\n this.element = element;\n this.handleFocusIn = this.handleFocusIn.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n }\n\n activate() {\n activeModals.push(this.element);\n document.addEventListener('focusin', this.handleFocusIn);\n document.addEventListener('keydown', this.handleKeyDown);\n }\n\n deactivate() {\n activeModals = activeModals.filter((modal) => modal !== this.element);\n document.removeEventListener('focusin', this.handleFocusIn);\n document.removeEventListener('keydown', this.handleKeyDown);\n }\n\n isActive() {\n // The \"active\" modal is always the most recent one shown\n return activeModals[activeModals.length - 1] === this.element;\n }\n\n handleFocusIn(event: Event) {\n const path = event.composedPath();\n\n // Trap focus so it doesn't go out of the modal's boundary\n if (this.isActive() && !path.includes(this.element)) {\n const tabbableElements = getTabbableElements(this.element);\n const index =\n this.tabDirection === 'backward' ? tabbableElements.length - 1 : 0;\n tabbableElements[index]?.focus({ preventScroll: true });\n }\n }\n\n handleKeyDown(event: KeyboardEvent) {\n // Quick hack to determine tab direction\n if (event.key === 'Tab' && event.shiftKey) {\n this.tabDirection = 'backward';\n setTimeout(() => (this.tabDirection = 'forward'));\n }\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /*!
2
2
  * Web Components for Nanopore digital Web Apps
3
3
  */
4
- import{r as t,c as i,w as s,h as e,a as n,g as o}from"./p-1fe12320.js";import{g as a}from"./p-74a7fc4f.js";import{d as h}from"./p-9746b0a5.js";import{g as l}from"./p-845ae77e.js";import{g as r}from"./p-b933f3c8.js";const c=":host{box-sizing:border-box}*,*::before,*::after{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%);block-size:1px;inline-size: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}";function d(t){let i;if(t.id){i=document.querySelector(`label[for='${t.id}']`)}if(!i){i=t.closest("label")}return i}let p=0;const f=class{constructor(s){t(this,s);this.nanoSelect=i(this,"nanoSelect",7);this.nanoDeselect=i(this,"nanoDeselect",7);this.nanoOptionsUpdated=i(this,"nanoOptionsUpdated",7);this.isNanoInput=false;this.typeToSelect="";this.listId=`nano-datalist-${p++}`;this.isFiltered=false;this.shouldFocus=false;this._allOptEles=[];this._dropDownConfig={skidding:-1};this.optSelected=t=>{t.stopPropagation();this.changeInputValue(t.detail);requestAnimationFrame((()=>this.inputChange()));if(this.type!=="selctMulti")this.shouldOpen=false};this.handleShow=async()=>{if(this.shouldFocus){this.shouldFocus=false;this.listBox.setFocus()}else if(this.type==="select")this.listBox.showActiveElement()};this.handleHide=()=>{this.open=false;const t=a();if(t.closest(this.host.tagName.toLowerCase())){this.connectedInput.select()}};this.inputClick=()=>{this.shouldOpen=true;this.manageDropdownDisplay()};this.inputKeydown=t=>{const i=["Shift","ArrowRight","ArrowLeft","Escape","Enter","Tab"];if(i.includes(t.key)){if(t.key==="Tab")this.shouldOpen=false;return}if(this.type==="select"&&!["ArrowDown","ArrowUp"].includes(t.key)&&(t.key!==" "||this.typeToSelectTimeout)){if(t.key===" "||/^[a-z0-9]+$/i.test(t.key)){clearTimeout(this.typeToSelectTimeout);this.typeToSelectTimeout=window.setTimeout((()=>{this.typeToSelect="";this.typeToSelectTimeout=0}),750);this.typeToSelect+=t.key;this.setOptStartsWith()}return}this.shouldOpen=true;this.manageDropdownDisplay();if(["ArrowDown","ArrowUp"].includes(t.key)){t.preventDefault();this.shouldFocus=true}};this.optionKeyDown=t=>{const i=["Shift","ArrowUp","ArrowDown","Escape","Enter","Tab","Space","PageUp","PageDown","Home","End"," "];if(i.includes(t.key)){if(t.key==="Escape")this.connectedInput.focus();return}const s=["Delete","Backspace"];if(this.type!=="select"&&(!this.exactMatch||s.includes(t.key))){this.connectedInput.focus()}};this.actvOptEles=[];this.connectedInput=undefined;this.inputLabel=undefined;this.hasNoResult=undefined;this.shouldOpen=undefined;this.canOpen=true;this.optionIds=[];this.selected=[];this.options=[];this.input=undefined;this.type="input";this.open=false;this.disableFilter=false;this.disabled=false;this.inputChange=h(this.inputChange.bind(this),50)}get allOptEles(){return this._allOptEles}set allOptEles(t){this._allOptEles=t;if(this.connectedInput?.value)return;t.forEach((t=>{if(t.selected&&!this.selected.includes(t.value)){this.changeInputValue(t)}}))}get dropDownConfig(){return this._dropDownConfig}set dropDownConfig(t){this._dropDownConfig={...this._dropDownConfig,...t}}get activeOptions(){return this.allOptEles}openWatcher(){s((()=>{this.nanoDropdown.open=this.open;this.connectedInput.setAttribute("aria-expanded",this.open.toString())}))}async watchInputChange(){let t;if(t=this.host.closest("nano-input")){this.isNanoInput=true;this.connectedInput=await t.getInputElement()}else if(this.input&&typeof this.input==="string"&&(t=document.querySelector(this.input))){this.isNanoInput=false;this.connectedInput=t}else if(this.input instanceof HTMLElement){this.connectedInput=this.input}}manageSlotChangeListener(){if(!this.host)return;if((!this.options||!this.options.length)&&!this.mo){{const t=this.mo=new MutationObserver((()=>this.processSlottedContent()));t.observe(this.host,{childList:true,subtree:true})}this.processSlottedContent();return}if(this.options?.length){if(!!this.mo){this.mo.disconnect();this.mo=undefined}const t=this.host.querySelectorAll('[slot="internal-opts"]');s((()=>{if(t?.length)t.forEach((t=>t.remove()));this.allOptEles=this.options.flatMap(((t,i)=>{if(t.value||t.label){const s=Object.assign(document.createElement("nano-option"),{label:t.label,value:t.value,ariaPosinset:i,ariaSetsize:this.options.length,selected:t.selected,id:this.listId+"-option-"+i,textContent:t.label?t.label:t.value,slot:"internal-opts"});this.host.append(s);return s}}));if(this.connectedInput?.value.length&&this.type!=="select"){this.inputChange()}else{this.actvOptEles=[...this.allOptEles]}}))}}watchTypeChange(){if(!this.connectedInput)return;let t={closeOnSelect:false};let i="both";let s=false;switch(this.type){case"input":t={closeOnSelect:true};break;case"select":i="list";s=true;t={closeOnSelect:true,placement:"center"};break}if(!this.isNanoInput){t.tetherTo=this.connectedInput}this.dropDownConfig={...this.dropDownConfig,...t};this.connectedInput.setAttribute("aria-autocomplete",i);this.connectedInput.readOnly=s}manageInputEvents(t,i){if(!!i){const t=i.closest("nano-input");if(t){t.removeEventListener("nanoChange",this.inputChange)}i.removeEventListener("change",this.inputChange);i.removeEventListener("click",this.inputClick);i.removeEventListener("keydown",this.inputKeydown);i.removeEventListener("input",this.inputChange);this.inputLabel=null;s((()=>{i.removeAttribute("role");i.removeAttribute("aria-expanded");i.removeAttribute("aria-controls");i.removeAttribute("aria-owns");i.removeAttribute("aria-haspopup");i.removeAttribute("aria-autocomplete");i.removeAttribute("autocomplete")}))}if(!!t){const i=t.closest("nano-input");if(i){i.addEventListener("nanoChange",this.inputChange)}t.addEventListener("change",this.inputChange);t.addEventListener("click",this.inputClick);t.addEventListener("keydown",this.inputKeydown);t.addEventListener("input",this.inputChange);this.listId=this.host.id||this.listId;this.inputLabel=t?.labels?.item(0)||d(t);s((()=>{this.host.id=this.listId;t.setAttribute("role","combobox");t.setAttribute("aria-expanded","false");t.setAttribute("aria-controls",this.listId);t.setAttribute("aria-owns",this.listId);t.setAttribute("aria-haspopup","listbox");t.setAttribute("autocomplete","off")}))}}watchActvOptChange(){let t=0;const i=this.connectedInput?.value||"";const e=[];s((()=>{this.allOptEles.forEach(((s,n)=>{if(this.actvOptEles.includes(s)){t++;s.setAttribute("aria-posinset",t+"");s.setAttribute("aria-setsize",this.actvOptEles.length+"");s.hidden=false;this.isSelected(s,i)}else{s.removeAttribute("aria-posinset");s.removeAttribute("aria-setsize");s.hidden=true;s.selected=false}s.id=this.listId+"-option-"+n;e.push(s.id)}));this.optionIds=e}))}manageCanOpen(){if(this.actvOptEles.length||this.hasNoResult)this.canOpen=true;else this.canOpen=false}manageDropdownDisplay(){if(this.shouldOpen&&this.canOpen&&!this.disabled)this.open=true;if(!this.shouldOpen||!this.canOpen)this.open=false;this.openWatcher()}fireActiveOptsEvent(){this.nanoOptionsUpdated.emit(this.actvOptEles)}isSelected(t,i){if(i===t.value||this.selected.includes(t.value)){t.selected=true}else t.selected=false}get dropwdownOpen(){if(!this.nanoDropdown||!this.open)return false;return true}get exactMatch(){return this.allOptEles.find((t=>this.connectedInput.value===t.value))}changeInputValue(t){let i;if(this.selected.includes(t.value)){this.selected=this.selected.filter((i=>i!==t.value));i=this.nanoDeselect.emit(t)}else{this.selected=[...this.selected];i=this.nanoSelect.emit(t)}if(!i.defaultPrevented){if(this.connectedInput)this.connectedInput.value=t.value;const i=new window.Event("change");this.connectedInput?.dispatchEvent(i)}}setOptStartsWith(){const t=t=>t.toLowerCase().substring(0,this.typeToSelect.length)===this.typeToSelect;const i=this.allOptEles.find((i=>i.value.trim().length>0&&!i.disabled&&(t(i.textContent)||t(i.value)||t(i.label)||t(i.filterMeta))));if(i)this.changeInputValue(i)}processSlottedContent(){requestAnimationFrame((()=>{this.allOptEles=Array.from(this.host.querySelectorAll("nano-option"));this.hasNoResult=!!this.host.querySelector('[slot="no-result"]');if(this.connectedInput?.value.length&&this.type!=="select"){this.inputChange()}else this.actvOptEles=this.allOptEles}))}inputChange(){if(this.disableFilter){this.actvOptEles=this.allOptEles;return}const t=this.connectedInput.value;const i=t.trim().toLowerCase();let s=false;const e=[];const n=t=>t.toLowerCase().indexOf(i)>-1;this.allOptEles.forEach((i=>{if((t===i.value||t===i.label)&&this.type!=="selctMulti"){i.selected=true;s=true}else this.isSelected(i,t)}));this.allOptEles.forEach((t=>{if(!i.length||s){e.push(t)}else if(t.value.trim().length>0&&!t.disabled&&(n(t.textContent)||n(t.value)||n(t.label)||n(t.filterMeta))){e.push(t)}}));this.isFiltered=i.length&&!s;this.actvOptEles=e}connectedCallback(){this.watchInputChange()}componentDidLoad(){this.manageSlotChangeListener();this.openWatcher()}componentDidRender(){setTimeout((()=>{if(!this.connectedInput)console.warn("no `nano-input` found. `nano-datalist` should be nested within an `nano-input` or linked via `input` prop",this.host)}),500)}render(){return e(n,{role:this.actvOptEles.length?"listbox":undefined,"aria-owns":this.optionIds.length?this.optionIds.join(" "):undefined,"aria-label":this.optionIds.length?"Select options from the list below":undefined},e("nano-dropdown",{...this.dropDownConfig,ref:t=>this.nanoDropdown=t,dialogTitle:"Select options from the list below",class:{dlist__dropdown:true,"dlist--isfiltered":this.isFiltered},onNanoAfterShow:this.handleShow,onNanoAfterHide:this.handleHide},e("nano-menu",{hidden:!this.actvOptEles.length,type:"listbox",label:this.inputLabel?this.inputLabel.textContent:undefined,class:{dlist__menu:true,"dlist__menu--open":this.dropwdownOpen},tabIndex:-1,onNanoSelect:this.optSelected,onKeyDown:this.optionKeyDown,ref:t=>this.listBox=t},e("slot",{name:"list-top"}),!this.options.length&&e("slot",null),!!this.options.length&&e("slot",{name:"internal-opts"}),e("slot",{name:"list-bottom"})),e("nano-menu",{type:"listbox",label:"No results found",hidden:!!this.actvOptEles.length,class:{dlist__menu:true,"dlist__menu--open":this.dropwdownOpen}},e("slot",{name:"no-result"})),!!this.actvOptEles&&e("div",{"aria-live":"polite",role:"status",class:"dlist__status"},this.actvOptEles.length," result",this.actvOptEles.length>1?"s":""," available.")))}get host(){return o(this)}static get watchers(){return{open:["openWatcher"],input:["watchInputChange"],options:["manageSlotChangeListener"],type:["watchTypeChange"],connectedInput:["watchTypeChange","manageInputEvents"],selected:["watchActvOptChange"],actvOptEles:["watchActvOptChange","manageCanOpen","fireActiveOptsEvent"],hasNoResult:["manageCanOpen"],shouldOpen:["manageDropdownDisplay"],canOpen:["manageDropdownDisplay"]}}};f.style=c;const u=":host{box-sizing:border-box}*,*::before,*::after{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-inline:var(--padding-start) var(--padding-end);padding-block:var(--padding-top) var(--padding-bottom);display:block}";const b=class{constructor(s){t(this,s);this.nanoFocus=i(this,"nanoFocus",7);this.nanoBlur=i(this,"nanoBlur",7);this.nanoSelect=i(this,"nanoSelect",7);this.ignoreMouseEvents=false;this.typeToSelect="";this._hasFocus=false;this.handleFocus=()=>{this.setActiveFocusItem(this.selectedItem||this.getItems[0]);this._hasFocus=true;this.nanoFocus.emit()};this.handleClick=t=>{const i=t.target;const s=i.closest("nano-nav-item");if(s&&!s.disabled){this.nanoSelect.emit(s)}};this.handleKeyDown=t=>{clearTimeout(this.ignoreMouseTimeout);this.ignoreMouseTimeout=setTimeout((()=>this.ignoreMouseEvents=false),500);this.ignoreMouseEvents=true;switch(t.key){case" ":if(this.activeItem)this.activeItem.click();break;case"ArrowDown":case"ArrowUp":case"PageDown":case"PageUp":case"Home":case"End":const i=this.getItems;const s=this.activeItem;let e=i.indexOf(s);if(i.length){t.preventDefault();if(t.key==="ArrowDown"){e++}else if(t.key==="ArrowUp"){e--}else if(t.key==="Home"||t.key==="PageUp"){e=0}else if(t.key==="End"||t.key==="PageDown"){e=i.length-1}if(e<0)e=i.length-1;if(e>i.length-1)e=0;this.setActiveFocusItem(i[e]);if(i[e])i[e].scrollIntoView({block:"nearest"});return}break}if(t.key===" "||/^[a-z0-9]+$/i.test(t.key)){clearTimeout(this.typeToSelectTimeout);this.typeToSelectTimeout=setTimeout((()=>this.typeToSelect=""),750);this.typeToSelect+=t.key;const i=this.getItems;for(const t of i){const i=t.shadowRoot.querySelector("slot:not([name])");const s=r(i).toLowerCase().trim();if(s.substring(0,this.typeToSelect.length)===this.typeToSelect){this.setActiveFocusItem(t);break}}}};this.handleMouseOver=t=>{const i=t.target;const s=i.closest("nano-nav-item")||i.closest("nano-option");if(s&&!this.ignoreMouseEvents){this.setActiveFocusItem(s)}};this.type="menu";this.label=undefined}get hasFocus(){return this._hasFocus}async setFocus(){if(this.menu?.focus)this.menu.focus({preventScroll:true})}async removeFocus(){if(this.menu?.blur)this.menu.blur()}async showActiveElement(){if(this.selectedItem)this.selectedItem.scrollIntoView({block:"nearest"})}async resetActiveItem(){this.getItems.filter((t=>t.tagName.toLowerCase()==="nano-option")).map((t=>t.setAttribute("tabindex","-1")))}get getItems(){let t;const i=this.el.querySelectorAll("nano-nav-item.secondary-open");if(i.length){const s=i[i.length-1];t=Array.from(s.querySelectorAll("nano-nav-item, nano-option"))}else{t=l(this.el,"nano-nav-item, nano-option","slot")}return t.filter((t=>!t.disabled&&!t.hidden))}get activeItem(){const t=a();return this.getItems.find((i=>i.getAttribute("tabindex")==="0"||i===t||i.classList.contains("has-focus")))}get selectedItem(){return this.getItems.find((t=>t.selected))}async setActiveFocusItem(t,i=true){const s=this.getItems;const e=!t||t.disabled?s.find((t=>t.selected))||s[0]:t;s.filter((t=>t.tagName.toLowerCase()==="nano-option")).map((t=>t.setAttribute("tabindex",t===e?"0":"-1")));if(!i)return;if(e){e.setFocus?e.setFocus():e.focus()}else this.menu.focus()}handleBlur(t){if(!this.hasFocus)return;const i=t;let s;if(i.key){if(i.key!=="Tab")return;s=a()&&a().closest(this.el.tagName.toLowerCase())===this.el}else s=!!t.composedPath().find((t=>t===this.el));if(!s){this.resetActiveItem();this._hasFocus=false;this.nanoBlur.emit()}}render(){return e(n,null,e("div",{onClick:this.handleClick,onKeyDown:this.handleKeyDown,onMouseOver:this.handleMouseOver,onFocus:this.handleFocus,"aria-label":this.label?this.label:undefined,role:this.type,ref:t=>this.menu=t,part:"base",class:{menu:true,["menu--"+this.type]:true,"menu--has-focus":this.hasFocus},tabIndex:-1},e("slot",null)))}get el(){return o(this)}};b.style=u;const m=":host{box-sizing:border-box}*,*::before,*::after{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-inline:var(--padding-start) var(--padding-end);padding-block:var(--padding-top) var(--padding-bottom)}: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){-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){-webkit-margin-start:0.5em;margin-inline-start:0.5em}.option__check{visibility:hidden;display:-webkit-box;display:-ms-flexbox;display:flex;position:absolute;inset-inline-start:0.6em;inset-block-start: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}";let g=0;const v=class{constructor(s){t(this,s);this.nanoSelect=i(this,"nanoSelect",7);this.optId=`nano-option-${g++}`;this.hasFocus=false;this.value="";this.label="";this.selected=false;this.disabled=false;this.filterMeta="";this.handleClick=h(this.handleClick.bind(this),5)}valueChanged(){if(!this.value||!this.value.length)this.value=this.labelContent}labelChanged(){if(!this.label||!this.label.length)this.label=this.labelContent.length?this.labelContent:this.value}handleKeyDown(t){if(t.key!==" "&&t.key!=="Enter")return;t.preventDefault();this.nanoSelect.emit(this.host)}handleClick(){if(this.disabled)return;this.nanoSelect.emit(this.host)}get labelContent(){return l(this.host,"*:not([slot])",false).map((t=>t.textContent)).join(" ").trim()}componentWillLoad(){this.valueChanged();this.labelChanged()}render(){return e(n,{role:"option","aria-selected":this.selected?"true":"false","aria-disabled":this.disabled?"true":"false"},e("div",{onMouseDown:this.handleClick,id:this.optId,class:{option:true,"option--selected":this.selected,"option--disabled":this.disabled,"option--novalue":!this.value}},e("div",{part:"check-icon",class:"option__check"},e("slot",{name:"check-icon"},e("nano-icon",{name:"light/check","aria-hidden":"true"}))),e("div",{part:"start",class:"option__start"},e("slot",{name:"start"})),e("div",{part:"label",class:"option__label"},e("slot",null,this.label||this.value)),e("div",{part:"end",class:"option__end"},e("slot",{name:"end"}))))}get host(){return o(this)}static get watchers(){return{value:["valueChanged"],label:["labelChanged"]}}};v.style=m;export{f as nano_datalist,b as nano_menu,v as nano_option};
5
- //# sourceMappingURL=p-c45851c3.entry.js.map
4
+ import{r as t,c as i,w as s,h as e,a as n,g as o}from"./p-1fe12320.js";import{g as a}from"./p-74a7fc4f.js";import{d as h}from"./p-9746b0a5.js";import{g as r}from"./p-845ae77e.js";import{g as l}from"./p-b933f3c8.js";const c=":host{box-sizing:border-box}*,*::before,*::after{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%);block-size:1px;inline-size: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}";function d(t){let i;if(t.id){i=document.querySelector(`label[for='${t.id}']`)}if(!i){i=t.closest("label")}return i}let p=0;const f=class{constructor(s){t(this,s);this.nanoSelect=i(this,"nanoSelect",7);this.nanoDeselect=i(this,"nanoDeselect",7);this.nanoOptionsUpdated=i(this,"nanoOptionsUpdated",7);this.isNanoInput=false;this.typeToSelect="";this.listId=`nano-datalist-${p++}`;this.isFiltered=false;this.shouldFocus=false;this._allOptEles=[];this._dropDownConfig={skidding:-1};this.optSelected=t=>{t.stopPropagation();this.changeInputValue(t.detail);requestAnimationFrame((()=>this.inputChange()));if(this.type!=="selctMulti")this.shouldOpen=false};this.handleShow=async()=>{if(this.shouldFocus){this.shouldFocus=false;this.listBox.setFocus()}else if(this.type==="select")this.listBox.showActiveElement()};this.handleHide=()=>{this.open=false;const t=a();if(t.closest(this.host.tagName.toLowerCase())){this.connectedInput.select()}};this.inputClick=()=>{this.shouldOpen=true;this.manageDropdownDisplay()};this.inputKeydown=t=>{const i=["Shift","ArrowRight","ArrowLeft","Escape","Enter","Tab"];if(i.includes(t.key)){if(t.key==="Tab")this.shouldOpen=false;return}if(this.type==="select"&&!["ArrowDown","ArrowUp"].includes(t.key)&&(t.key!==" "||this.typeToSelectTimeout)){if(t.key===" "||/^[a-z0-9]+$/i.test(t.key)){clearTimeout(this.typeToSelectTimeout);this.typeToSelectTimeout=window.setTimeout((()=>{this.typeToSelect="";this.typeToSelectTimeout=0}),750);this.typeToSelect+=t.key;this.setOptStartsWith()}return}this.shouldOpen=true;this.manageDropdownDisplay();if(["ArrowDown","ArrowUp"].includes(t.key)){t.preventDefault();this.shouldFocus=true}};this.optionKeyDown=t=>{const i=["Shift","ArrowUp","ArrowDown","Escape","Enter","Tab","Space","PageUp","PageDown","Home","End"," "];if(i.includes(t.key)){if(t.key==="Escape")this.connectedInput.focus();return}const s=["Delete","Backspace"];if(this.type!=="select"&&(!this.exactMatch||s.includes(t.key))){this.connectedInput.focus()}};this.actvOptEles=[];this.connectedInput=undefined;this.inputLabel=undefined;this.hasNoResult=undefined;this.shouldOpen=undefined;this.canOpen=true;this.optionIds=[];this.selected=[];this.options=[];this.input=undefined;this.type="input";this.open=false;this.disableFilter=false;this.disabled=false;this.inputChange=h(this.inputChange.bind(this),50)}get allOptEles(){return this._allOptEles}set allOptEles(t){this._allOptEles=t;if(this.connectedInput?.value)return;t.forEach((t=>{if(t.selected&&!this.selected.includes(t.value)){this.changeInputValue(t)}}))}get dropDownConfig(){return this._dropDownConfig}set dropDownConfig(t){this._dropDownConfig={...this._dropDownConfig,...t}}get activeOptions(){return this.allOptEles}openWatcher(){s((()=>{this.nanoDropdown.open=this.open;this.connectedInput.setAttribute("aria-expanded",this.open.toString())}))}async watchInputChange(){let t;if(t=this.host.closest("nano-input")){this.isNanoInput=true;this.connectedInput=await t.getInputElement()}else if(this.input&&typeof this.input==="string"&&(t=document.querySelector(this.input))){this.isNanoInput=false;this.connectedInput=t}else if(this.input instanceof HTMLElement){this.connectedInput=this.input}}manageSlotChangeListener(){if(!this.host)return;if((!this.options||!this.options.length)&&!this.mo){{const t=this.mo=new MutationObserver((()=>this.processSlottedContent()));t.observe(this.host,{childList:true,subtree:true})}this.processSlottedContent();return}if(this.options?.length){if(!!this.mo){this.mo.disconnect();this.mo=undefined}const t=this.host.querySelectorAll('[slot="internal-opts"]');s((()=>{if(t?.length)t.forEach((t=>t.remove()));this.allOptEles=this.options.flatMap(((t,i)=>{if(t.value||t.label){const s=Object.assign(document.createElement("nano-option"),{label:t.label,value:t.value,ariaPosinset:i,ariaSetsize:this.options.length,selected:t.selected,id:this.listId+"-option-"+i,textContent:t.label?t.label:t.value,slot:"internal-opts"});this.host.append(s);return s}}));if(this.connectedInput?.value.length&&this.type!=="select"){this.inputChange()}else{this.actvOptEles=[...this.allOptEles]}}))}}watchTypeChange(){if(!this.connectedInput)return;let t={closeOnSelect:false};let i="both";let s=false;switch(this.type){case"input":t={closeOnSelect:true};break;case"select":i="list";s=true;t={closeOnSelect:true,placement:"center"};break}if(!this.isNanoInput){t.tetherTo=this.connectedInput}this.dropDownConfig={...this.dropDownConfig,...t};this.connectedInput.setAttribute("aria-autocomplete",i);this.connectedInput.readOnly=s}manageInputEvents(t,i){if(!!i){const t=i.closest("nano-input");if(t){t.removeEventListener("nanoChange",this.inputChange)}i.removeEventListener("change",this.inputChange);i.removeEventListener("click",this.inputClick);i.removeEventListener("keydown",this.inputKeydown);i.removeEventListener("input",this.inputChange);this.inputLabel=null;s((()=>{i.removeAttribute("role");i.removeAttribute("aria-expanded");i.removeAttribute("aria-controls");i.removeAttribute("aria-owns");i.removeAttribute("aria-haspopup");i.removeAttribute("aria-autocomplete");i.removeAttribute("autocomplete")}))}if(!!t){const i=t.closest("nano-input");if(i){i.addEventListener("nanoChange",this.inputChange)}t.addEventListener("change",this.inputChange);t.addEventListener("click",this.inputClick);t.addEventListener("keydown",this.inputKeydown);t.addEventListener("input",this.inputChange);this.listId=this.host.id||this.listId;this.inputLabel=t?.labels?.item(0)||d(t);s((()=>{this.host.id=this.listId;t.setAttribute("role","combobox");t.setAttribute("aria-expanded","false");t.setAttribute("aria-controls",this.listId);t.setAttribute("aria-owns",this.listId);t.setAttribute("aria-haspopup","listbox");t.setAttribute("autocomplete","off")}))}}watchActvOptChange(){let t=0;const i=this.connectedInput?.value||"";const e=[];s((()=>{this.allOptEles.forEach(((s,n)=>{if(this.actvOptEles.includes(s)){t++;s.setAttribute("aria-posinset",t+"");s.setAttribute("aria-setsize",this.actvOptEles.length+"");s.hidden=false;this.isSelected(s,i)}else{s.removeAttribute("aria-posinset");s.removeAttribute("aria-setsize");s.hidden=true;s.selected=false}s.id=this.listId+"-option-"+n;e.push(s.id)}));this.optionIds=e}))}manageCanOpen(){if(this.actvOptEles.length||this.hasNoResult)this.canOpen=true;else this.canOpen=false}manageDropdownDisplay(){if(this.shouldOpen&&this.canOpen&&!this.disabled)this.open=true;if(!this.shouldOpen||!this.canOpen)this.open=false;this.openWatcher()}fireActiveOptsEvent(){this.nanoOptionsUpdated.emit(this.actvOptEles)}isSelected(t,i){if(i===t.value||this.selected.includes(t.value)){t.selected=true}else t.selected=false}get dropwdownOpen(){if(!this.nanoDropdown||!this.open)return false;return true}get exactMatch(){return this.allOptEles.find((t=>this.connectedInput.value===t.value))}changeInputValue(t){let i;if(this.selected.includes(t.value)){this.selected=this.selected.filter((i=>i!==t.value));i=this.nanoDeselect.emit(t)}else{this.selected=[...this.selected];i=this.nanoSelect.emit(t)}if(!i.defaultPrevented){if(this.connectedInput)this.connectedInput.value=t.value;const i=new window.Event("change");this.connectedInput?.dispatchEvent(i)}}setOptStartsWith(){const t=t=>t.toLowerCase().substring(0,this.typeToSelect.length)===this.typeToSelect;const i=this.allOptEles.find((i=>i.value.trim().length>0&&!i.disabled&&(t(i.textContent)||t(i.value)||t(i.label)||t(i.filterMeta))));if(i)this.changeInputValue(i)}processSlottedContent(){requestAnimationFrame((()=>{this.allOptEles=Array.from(this.host.querySelectorAll("nano-option"));this.hasNoResult=!!this.host.querySelector('[slot="no-result"]');if(this.connectedInput?.value.length&&this.type!=="select"){this.inputChange()}else this.actvOptEles=this.allOptEles}))}inputChange(){if(this.disableFilter){this.actvOptEles=this.allOptEles;return}const t=this.connectedInput.value;const i=t.trim().toLowerCase();let s=false;const e=[];const n=t=>t.toLowerCase().indexOf(i)>-1;this.allOptEles.forEach((i=>{if((t===i.value||t===i.label)&&this.type!=="selctMulti"){i.selected=true;s=true}else this.isSelected(i,t)}));this.allOptEles.forEach((t=>{if(!i.length||s){e.push(t)}else if(t.value.trim().length>0&&!t.disabled&&(n(t.textContent)||n(t.value)||n(t.label)||n(t.filterMeta))){e.push(t)}}));this.isFiltered=i.length&&!s;this.actvOptEles=e}connectedCallback(){this.watchInputChange()}componentDidLoad(){this.manageSlotChangeListener();this.openWatcher()}componentDidRender(){setTimeout((()=>{if(!this.connectedInput)console.warn("no `nano-input` found. `nano-datalist` should be nested within an `nano-input` or linked via `input` prop",this.host)}),500)}render(){return e(n,{role:this.actvOptEles.length?"listbox":undefined,"aria-owns":this.optionIds.length?this.optionIds.join(" "):undefined,"aria-label":this.optionIds.length?"Select options from the list below":undefined},e("nano-dropdown",{...this.dropDownConfig,ref:t=>this.nanoDropdown=t,dialogTitle:"Select options from the list below",class:{dlist__dropdown:true,"dlist--isfiltered":this.isFiltered},onNanoAfterShow:this.handleShow,onNanoAfterHide:this.handleHide},e("nano-menu",{hidden:!this.actvOptEles.length,type:"listbox",label:this.inputLabel?this.inputLabel.textContent:undefined,class:{dlist__menu:true,"dlist__menu--open":this.dropwdownOpen},tabIndex:-1,onNanoSelect:this.optSelected,onKeyDown:this.optionKeyDown,ref:t=>this.listBox=t},e("slot",{name:"list-top"}),!this.options.length&&e("slot",null),!!this.options.length&&e("slot",{name:"internal-opts"}),e("slot",{name:"list-bottom"})),e("nano-menu",{type:"listbox",label:"No results found",hidden:!!this.actvOptEles.length,class:{dlist__menu:true,"dlist__menu--open":this.dropwdownOpen}},e("slot",{name:"no-result"})),!!this.actvOptEles&&e("div",{"aria-live":"polite",role:"status",class:"dlist__status"},this.actvOptEles.length," result",this.actvOptEles.length>1?"s":""," available.")))}get host(){return o(this)}static get watchers(){return{open:["openWatcher"],input:["watchInputChange"],options:["manageSlotChangeListener"],type:["watchTypeChange"],connectedInput:["watchTypeChange","manageInputEvents"],selected:["watchActvOptChange"],actvOptEles:["watchActvOptChange","manageCanOpen","fireActiveOptsEvent"],hasNoResult:["manageCanOpen"],shouldOpen:["manageDropdownDisplay"],canOpen:["manageDropdownDisplay"]}}};f.style=c;const u=":host{box-sizing:border-box}*,*::before,*::after{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);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-inline:var(--padding-start) var(--padding-end);padding-block:var(--padding-top) var(--padding-bottom);display:block}";const g=class{constructor(s){t(this,s);this.nanoFocus=i(this,"nanoFocus",7);this.nanoBlur=i(this,"nanoBlur",7);this.nanoSelect=i(this,"nanoSelect",7);this.ignoreMouseEvents=false;this.typeToSelect="";this._hasFocus=false;this.handleFocus=()=>{this.setActiveFocusItem(this.selectedItem||this.getItems[0]);this._hasFocus=true;this.nanoFocus.emit()};this.handleClick=t=>{const i=t.target;const s=i.closest("nano-nav-item");if(s&&!s.disabled){this.nanoSelect.emit(s)}};this.handleKeyDown=t=>{clearTimeout(this.ignoreMouseTimeout);this.ignoreMouseTimeout=setTimeout((()=>this.ignoreMouseEvents=false),500);this.ignoreMouseEvents=true;switch(t.key){case" ":if(this.activeItem)this.activeItem.click();break;case"ArrowDown":case"ArrowUp":case"PageDown":case"PageUp":case"Home":case"End":const i=this.getItems;const s=this.activeItem;let e=i.indexOf(s);if(i.length){t.preventDefault();if(t.key==="ArrowDown"){e++}else if(t.key==="ArrowUp"){e--}else if(t.key==="Home"||t.key==="PageUp"){e=0}else if(t.key==="End"||t.key==="PageDown"){e=i.length-1}if(e<0)e=i.length-1;if(e>i.length-1)e=0;this.setActiveFocusItem(i[e]);if(i[e])i[e].scrollIntoView({block:"nearest"});return}break}if(t.key===" "||/^[a-z0-9]+$/i.test(t.key)){clearTimeout(this.typeToSelectTimeout);this.typeToSelectTimeout=setTimeout((()=>this.typeToSelect=""),750);this.typeToSelect+=t.key;const i=this.getItems;for(const t of i){const i=t.shadowRoot.querySelector("slot:not([name])");const s=l(i).toLowerCase().trim();if(s.substring(0,this.typeToSelect.length)===this.typeToSelect){this.setActiveFocusItem(t);break}}}};this.handleMouseOver=t=>{const i=t.target;const s=i.closest("nano-nav-item")||i.closest("nano-option");if(s&&!this.ignoreMouseEvents){this.setActiveFocusItem(s)}};this.type="menu";this.label=undefined}get hasFocus(){return this._hasFocus}async setFocus(){if(this.menu?.focus)this.menu.focus({preventScroll:true})}async removeFocus(){if(this.menu?.blur)this.menu.blur()}async showActiveElement(){if(this.selectedItem)this.selectedItem.scrollIntoView({block:"nearest"})}async resetActiveItem(){this.getItems.filter((t=>t.tagName.toLowerCase()==="nano-option")).map((t=>t.setAttribute("tabindex","-1")))}get getItems(){let t;const i=this.el.querySelectorAll("nano-nav-item.secondary-open");if(i.length){const s=i[i.length-1];t=Array.from(s.querySelectorAll("nano-nav-item, nano-option"))}else{t=r(this.el,"nano-nav-item, nano-option","slot")}return t.filter((t=>!t.disabled&&!t.hidden))}get activeItem(){const t=a();return this.getItems.find((i=>i.getAttribute("tabindex")==="0"||i===t||i.classList.contains("has-focus")))}get selectedItem(){return this.getItems.find((t=>t.selected))}async setActiveFocusItem(t,i=true){const s=this.getItems;const e=!t||t.disabled?s.find((t=>t.selected))||s[0]:t;s.filter((t=>t.tagName.toLowerCase()==="nano-option")).map((t=>t.setAttribute("tabindex",t===e?"0":"-1")));if(!i)return;if(e){e.setFocus?e.setFocus():e.focus()}else this.menu.focus()}handleBlur(t){if(!this.hasFocus)return;const i=t;let s;if(i.key){if(i.key!=="Tab")return;s=a()&&a().closest(this.el.tagName.toLowerCase())===this.el}else s=!!t.composedPath().find((t=>t===this.el));if(!s){this.resetActiveItem();this._hasFocus=false;this.nanoBlur.emit()}}render(){return e(n,null,e("div",{onClick:this.handleClick,onKeyDown:this.handleKeyDown,onMouseOver:this.handleMouseOver,onFocus:this.handleFocus,"aria-label":this.label?this.label:undefined,role:this.type,ref:t=>this.menu=t,part:"base",class:{menu:true,["menu--"+this.type]:true,"menu--has-focus":this.hasFocus},tabIndex:-1},e("slot",null)))}get el(){return o(this)}};g.style=u;const m=":host{box-sizing:border-box}*,*::before,*::after{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;user-select:none;cursor:pointer;display:flex;align-items:stretch;width:100%;background:var(--bg);padding-inline:var(--padding-start) var(--padding-end);padding-block:var(--padding-top) var(--padding-bottom)}: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{flex:1 1 auto;display:flex;align-items:center}.option__start{flex:0 0 auto;display:flex;align-items:center}.option__start ::slotted(nano-icon){font-size:var(--opt-icon-size)}.option__start ::slotted(:last-child){margin-inline-end:0.5em}.option__end{flex:0 0 auto;display:flex;align-items:center}.option__end ::slotted(nano-icon){font-size:var(--opt-icon-size)}.option__end ::slotted(:first-child){margin-inline-start:0.5em}.option__check{visibility:hidden;display:flex;position:absolute;inset-inline-start:0.6em;inset-block-start:calc(50% - 0.6em);align-items:center;font-size:0.9em}.option--selected:not(.option--novalue) .option__check{visibility:visible}";let b=0;const v=class{constructor(s){t(this,s);this.nanoSelect=i(this,"nanoSelect",7);this.optId=`nano-option-${b++}`;this.hasFocus=false;this.value="";this.label="";this.selected=false;this.disabled=false;this.filterMeta="";this.handleClick=h(this.handleClick.bind(this),5)}valueChanged(){if(!this.value||!this.value.length)this.value=this.labelContent}labelChanged(){if(!this.label||!this.label.length)this.label=this.labelContent.length?this.labelContent:this.value}handleKeyDown(t){if(t.key!==" "&&t.key!=="Enter")return;t.preventDefault();this.nanoSelect.emit(this.host)}handleClick(){if(this.disabled)return;this.nanoSelect.emit(this.host)}get labelContent(){return r(this.host,"*:not([slot])",false).map((t=>t.textContent)).join(" ").trim()}componentWillLoad(){this.valueChanged();this.labelChanged()}render(){return e(n,{role:"option","aria-selected":this.selected?"true":"false","aria-disabled":this.disabled?"true":"false"},e("div",{onMouseDown:this.handleClick,id:this.optId,class:{option:true,"option--selected":this.selected,"option--disabled":this.disabled,"option--novalue":!this.value}},e("div",{part:"check-icon",class:"option__check"},e("slot",{name:"check-icon"},e("nano-icon",{name:"light/check","aria-hidden":"true"}))),e("div",{part:"start",class:"option__start"},e("slot",{name:"start"})),e("div",{part:"label",class:"option__label"},e("slot",null,this.label||this.value)),e("div",{part:"end",class:"option__end"},e("slot",{name:"end"}))))}get host(){return o(this)}static get watchers(){return{value:["valueChanged"],label:["labelChanged"]}}};v.style=m;export{f as nano_datalist,g as nano_menu,v as nano_option};
5
+ //# sourceMappingURL=p-d1c8eca4.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["src/components/datalist/datalist.scss?tag=nano-datalist&encapsulation=shadow","src/components/datalist/datalist.tsx","src/components/menu/menu.scss?tag=nano-menu&encapsulation=shadow","src/components/menu/menu.tsx","src/components/option/option.scss?tag=nano-option&encapsulation=shadow","src/components/option/option.tsx"],"names":["datalistCss","findLabel","formCtrl","foundLabel","id","document","querySelector","closest","listIds","DataList","[object Object]","hostRef","this","isNanoInput","typeToSelect","listId","isFiltered","shouldFocus","_allOptEles","_dropDownConfig","skidding","optSelected","e","stopPropagation","changeInputValue","detail","requestAnimationFrame","inputChange","type","shouldOpen","handleShow","async","listBox","setFocus","showActiveElement","handleHide","open","activeElement","getActiveElement","host","tagName","toLowerCase","connectedInput","select","inputClick","manageDropdownDisplay","inputKeydown","ignoreKeys","includes","key","typeToSelectTimeout","test","clearTimeout","window","setTimeout","setOptStartsWith","preventDefault","optionKeyDown","focus","deleteKeys","exactMatch","debounce","bind","allOptEles","opts","value","forEach","opt","selected","dropDownConfig","ddc","activeOptions","writeTask","nanoDropdown","setAttribute","toString","nanoInput","getInputElement","input","HTMLElement","options","length","mo","MutationObserver","processSlottedContent","observe","childList","subtree","disconnect","undefined","previousOptions","querySelectorAll","internalOpt","remove","flatMap","option","i","label","Object","assign","createElement","ariaPosinset","ariaSetsize","textContent","slot","append","actvOptEles","dwConfig","closeOnSelect","autocompleteType","readonly","placement","tetherTo","readOnly","newInput","oldInput","removeEventListener","inputLabel","removeAttribute","addEventListener","labels","item","c","val","optIds","hidden","isSelected","push","optionIds","hasNoResult","canOpen","disabled","openWatcher","nanoOptionsUpdated","emit","dropwdownOpen","find","nanoSelected","filter","nanoDeselect","nanoSelect","defaultPrevented","event","Event","dispatchEvent","attrFind","toFind","substring","foundEle","trim","filterMeta","Array","from","disableFilter","valStr","activeEles","indexOf","watchInputChange","manageSlotChangeListener","console","warn","h","Host","role","aria-owns","join","aria-label","ref","el","dialogTitle","class","dlist__dropdown","dlist--isfiltered","onNanoAfterShow","onNanoAfterHide","dlist__menu","dlist__menu--open","tabIndex","onNanoSelect","onKeyDown","name","aria-live","menuCss","Menu","ignoreMouseEvents","_hasFocus","handleFocus","setActiveFocusItem","selectedItem","getItems","nanoFocus","handleClick","target","handleKeyDown","ignoreMouseTimeout","activeItem","click","items","index","scrollIntoView","block","shadowRoot","getTextContent","handleMouseOver","hasFocus","menu","preventScroll","blur","map","opened","ctx","getDirectChildren","getAttribute","classList","contains","kev","found","composedPath","resetActiveItem","nanoBlur","onClick","onMouseOver","onFocus","part","menu--has-focus","optionCss","Option","optId","labelContent","valueChanged","labelChanged","aria-selected","aria-disabled","onMouseDown","option--selected","option--disabled","option--novalue","aria-hidden"],"mappings":"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","sourcesContent":["@use 'sass:map';\n@use 'sass:list';\n\n@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/form';\n@import '../../global/style/nano-theme/base';\n@import '../../global/style/nano-theme/layers';\n\n:host {\n /**\n * @prop --padding-top: for all nested `nano-option` elements. Defaults to #{$spacing-small};\n * @prop --padding-bottom: for all nested `nano-option` elements. Defaults to #{$spacing-small};\n * @prop --padding-start: for all nested `nano-option` elements. Defaults to #{$spacing-xlarge};\n * @prop --padding-end: for all nested `nano-option` elements. Defaults to #{$spacing-xlarge};\n * @prop --font-size: for all nested `nano-option` elements. Defaults to .8em;\n * @prop --color: default text color of content other than `nano-option`. Defaults to #{map.get($colors, palegrey)};\n */\n\n --padding-top: #{$spacing-small};\n --padding-bottom: #{$spacing-small};\n --padding-start: #{$spacing-xlarge};\n --padding-end: #{$spacing-xlarge};\n --font-size: 0.8em;\n --color: #{map.get($colors, palegrey)};\n\n color: var(--color);\n}\n\n.dlist {\n &--isfiltered {\n ::slotted(*:not(nano-option):not([slot='no-result']):not([slot='list-top']):not([slot='list-bottom'])) {\n display: none !important;\n }\n }\n\n &__dropdown {\n --min-width: 100%;\n --overflow: auto;\n }\n\n &__status {\n @include visually-hide();\n }\n\n &__menu {\n --padding-top: inherit;\n --padding-bottom: inherit;\n --padding-start: inherit;\n --padding-end: inherit;\n --font-size: inherit;\n }\n}\n","import {\n Component,\n ComponentInterface,\n h,\n Host,\n Element,\n State,\n Watch,\n Prop,\n Event,\n writeTask,\n Build,\n EventEmitter,\n} from '@stencil/core';\nimport { getActiveElement } from '../../utils/active-element';\nimport { debounce } from '../../utils/throttle';\nimport type { NanoMenuCustomEvent, OptionInterface } from '../../interface';\nimport type { Dropdown } from '../dropdown/dropdown';\n\nfunction findLabel(formCtrl: Element) {\n let foundLabel: HTMLLabelElement;\n\n if (formCtrl.id) {\n foundLabel = document.querySelector(`label[for='${formCtrl.id}']`);\n }\n if (!foundLabel) {\n foundLabel = formCtrl.closest('label');\n }\n return foundLabel;\n}\n\nlet listIds = 0;\n\n/**\n * `nano-datalist` a visually consistent and more flexible replacement for a native\n * [datalist](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/datalist). Can be nested within a `nano-input`\n * or linked to any input control via the `input` prop. Is used internally within `nano-select`.\n * Options can be defined declaratively by nesting `<nano-option>` elements or imperatively using the `options` prop\n *\n * @slot - use `<nano-option>` elements for more complex html. Alternatively use the `options` prop\n * @slot list-top - shows at the top of the list when there are options present\n * @slot list-bottom - shows at the bottom of the list when there are options present\n * @slot no-result - shown when there are no results otherwise nothing will be shown\n */\n@Component({\n tag: 'nano-datalist',\n styleUrl: 'datalist.scss',\n shadow: true,\n})\nexport class DataList implements ComponentInterface {\n // Private State\n\n private isNanoInput = false;\n private typeToSelect = '';\n private typeToSelectTimeout: number;\n private nanoDropdown: HTMLNanoDropdownElement;\n private listBox: HTMLNanoMenuElement;\n private mo?: MutationObserver;\n private listId = `nano-datalist-${listIds++}`;\n private isFiltered = false;\n private shouldFocus = false;\n // all potential option eles. Set via slot or `options` prop.\n // Some may get hidden due to filtering\n private get allOptEles() {\n return this._allOptEles;\n }\n private set allOptEles(opts) {\n // when allOptEles are initially set (on slot change / options) -\n // add options to 'selected' and fire selected event *if*\n // value isn't set on the input\n this._allOptEles = opts;\n if (this.connectedInput?.value) return;\n\n opts.forEach((opt) => {\n if (opt.selected && !this.selected.includes(opt.value)) {\n this.changeInputValue(opt);\n }\n });\n }\n private _allOptEles: HTMLNanoOptionElement[] = [];\n\n @Element() host: HTMLNanoDatalistElement;\n\n // active option eles that are not hidden.\n @State() actvOptEles: HTMLNanoOptionElement[] = [];\n @State() connectedInput: HTMLInputElement | HTMLTextAreaElement;\n @State() inputLabel: HTMLLabelElement;\n @State() hasNoResult: boolean;\n @State() shouldOpen: boolean;\n @State() canOpen: boolean = true;\n @State() optionIds: string[] = [];\n\n constructor() {\n this.inputChange = debounce(this.inputChange.bind(this), 50);\n }\n\n // Public API\n\n /** By default, items in the list will appear 'selected' when the value in the linked input control matches.\n * However you can add other selected options via the the selected prop. */\n @Prop({ mutable: true }) selected: string[] = [];\n\n /** nano-dropdown config options you can pass to the nested dropdown component */\n @Prop()\n get dropDownConfig() {\n return this._dropDownConfig;\n }\n set dropDownConfig(ddc: Partial<Dropdown>) {\n this._dropDownConfig = { ...this._dropDownConfig, ...ddc };\n }\n private _dropDownConfig: Partial<Dropdown> = {\n skidding: -1,\n };\n\n /** Provide an option list.\n * Options can be defined declaratively by nesting `<nano-option>` elements or imperatively using this prop */\n @Prop() options?: OptionInterface[] = [];\n\n /** A selector to a HTMLInputElement */\n @Prop() input?: string | HTMLInputElement;\n\n /** Tweaks the datalist behaviour and linked control semantics and behaviour.\n * e.g. 'select' will make the linked input control `readonly`.\n */\n @Prop() type: 'select' | 'selctMulti' | 'input' = 'input';\n\n /** return all the active options currently within the datalist. Can be useful for validation */\n @Prop()\n get activeOptions() {\n return this.allOptEles;\n }\n\n /** Force datalist open */\n @Prop({ mutable: true }) open: boolean = false;\n\n @Watch('open')\n openWatcher() {\n writeTask(() => {\n this.nanoDropdown.open = this.open;\n this.connectedInput.setAttribute('aria-expanded', this.open.toString());\n });\n }\n\n /** Use this option to disable to default filtering. This is useful if filtering happens\n * externally via another method (e.g. via ajax)\n */\n @Prop() disableFilter = false;\n\n /** Activate / deactivate the datalist control */\n @Prop() disabled = false;\n\n // State change watchers\n\n @Watch('input')\n async watchInputChange() {\n let nanoInput;\n if ((nanoInput = this.host.closest('nano-input'))) {\n this.isNanoInput = true;\n this.connectedInput = await nanoInput.getInputElement();\n } else if (\n this.input &&\n typeof this.input === 'string' &&\n (nanoInput = document.querySelector(this.input))\n ) {\n this.isNanoInput = false;\n this.connectedInput = nanoInput;\n } else if (this.input instanceof HTMLElement) {\n this.connectedInput = this.input;\n }\n }\n\n @Watch('options')\n manageSlotChangeListener() {\n if (!this.host) return;\n\n // we're not using `options` - setup new MO\n if ((!this.options || !this.options.length) && !this.mo) {\n if (Build.isBrowser) {\n const mo = (this.mo = new MutationObserver(() =>\n this.processSlottedContent()\n ));\n mo.observe(this.host, { childList: true, subtree: true });\n }\n this.processSlottedContent();\n return;\n }\n\n // we're using `options` - trash current MO\n if (this.options?.length) {\n if (!!this.mo) {\n this.mo.disconnect();\n this.mo = undefined;\n }\n\n const previousOptions = this.host.querySelectorAll(\n '[slot=\"internal-opts\"]'\n );\n\n // add imperative `options`\n writeTask(() => {\n // clear all previous\n if (previousOptions?.length)\n previousOptions.forEach((internalOpt) => internalOpt.remove());\n\n this.allOptEles = this.options.flatMap((option, i) => {\n if (option.value || option.label) {\n const opt = Object.assign(document.createElement('nano-option'), {\n label: option.label,\n value: option.value,\n ariaPosinset: i,\n ariaSetsize: this.options.length,\n selected: option.selected,\n id: this.listId + '-option-' + i,\n textContent: option.label ? option.label : option.value,\n slot: 'internal-opts',\n });\n this.host.append(opt);\n return opt;\n }\n });\n\n if (this.connectedInput?.value.length && this.type !== 'select') {\n this.inputChange();\n } else {\n this.actvOptEles = [...this.allOptEles];\n }\n });\n }\n // forceUpdate(this.host);\n }\n\n @Watch('type')\n @Watch('connectedInput')\n watchTypeChange() {\n if (!this.connectedInput) return;\n\n let dwConfig: Partial<Dropdown> = { closeOnSelect: false };\n let autocompleteType: 'list' | 'both' = 'both';\n let readonly = false;\n\n switch (this.type) {\n case 'input':\n dwConfig = { closeOnSelect: true };\n break;\n case 'select':\n autocompleteType = 'list';\n readonly = true;\n dwConfig = { closeOnSelect: true, placement: 'center' };\n break;\n }\n\n if (!this.isNanoInput) {\n dwConfig.tetherTo = this.connectedInput;\n }\n\n this.dropDownConfig = { ...this.dropDownConfig, ...dwConfig };\n this.connectedInput.setAttribute('aria-autocomplete', autocompleteType);\n this.connectedInput.readOnly = readonly;\n }\n\n @Watch('connectedInput')\n manageInputEvents(newInput?: HTMLInputElement, oldInput?: HTMLInputElement) {\n if (!!oldInput) {\n const nanoInput = oldInput.closest('nano-input');\n if (nanoInput) {\n nanoInput.removeEventListener('nanoChange', this.inputChange);\n }\n oldInput.removeEventListener('change', this.inputChange);\n oldInput.removeEventListener('click', this.inputClick);\n oldInput.removeEventListener('keydown', this.inputKeydown);\n oldInput.removeEventListener('input', this.inputChange);\n\n this.inputLabel = null;\n\n writeTask(() => {\n oldInput.removeAttribute('role');\n oldInput.removeAttribute('aria-expanded');\n oldInput.removeAttribute('aria-controls');\n oldInput.removeAttribute('aria-owns');\n oldInput.removeAttribute('aria-haspopup');\n oldInput.removeAttribute('aria-autocomplete');\n oldInput.removeAttribute('autocomplete');\n });\n }\n if (!!newInput) {\n const nanoInput = newInput.closest('nano-input');\n if (nanoInput) {\n nanoInput.addEventListener('nanoChange', this.inputChange);\n }\n newInput.addEventListener('change', this.inputChange);\n newInput.addEventListener('click', this.inputClick);\n newInput.addEventListener('keydown', this.inputKeydown);\n newInput.addEventListener('input', this.inputChange);\n this.listId = this.host.id || this.listId;\n\n this.inputLabel = newInput?.labels?.item(0) || findLabel(newInput);\n\n writeTask(() => {\n this.host.id = this.listId;\n newInput.setAttribute('role', 'combobox');\n newInput.setAttribute('aria-expanded', 'false');\n newInput.setAttribute('aria-controls', this.listId);\n newInput.setAttribute('aria-owns', this.listId);\n newInput.setAttribute('aria-haspopup', 'listbox');\n newInput.setAttribute('autocomplete', 'off');\n });\n }\n }\n\n @Watch('selected')\n @Watch('actvOptEles')\n watchActvOptChange() {\n let c = 0;\n const val = this.connectedInput?.value || '';\n const optIds = [];\n\n writeTask(() => {\n this.allOptEles.forEach((opt, i) => {\n if (this.actvOptEles.includes(opt)) {\n c++;\n opt.setAttribute('aria-posinset', c + '');\n opt.setAttribute('aria-setsize', this.actvOptEles.length + '');\n opt.hidden = false;\n this.isSelected(opt, val);\n } else {\n opt.removeAttribute('aria-posinset');\n opt.removeAttribute('aria-setsize');\n opt.hidden = true;\n opt.selected = false;\n }\n opt.id = this.listId + '-option-' + i;\n optIds.push(opt.id);\n });\n this.optionIds = optIds;\n });\n }\n\n @Watch('actvOptEles')\n @Watch('hasNoResult')\n manageCanOpen() {\n if (this.actvOptEles.length || this.hasNoResult) this.canOpen = true;\n else this.canOpen = false;\n }\n\n /**\n * Opens the dropdown if it can, it should and there are items to display.\n */\n @Watch('shouldOpen')\n @Watch('canOpen')\n manageDropdownDisplay() {\n if (this.shouldOpen && this.canOpen && !this.disabled) this.open = true;\n if (!this.shouldOpen || !this.canOpen) this.open = false;\n this.openWatcher();\n }\n\n @Watch('actvOptEles')\n fireActiveOptsEvent() {\n this.nanoOptionsUpdated.emit(this.actvOptEles);\n }\n\n // Events\n\n /** Fired when an item is selected. */\n @Event() nanoSelect: EventEmitter<HTMLNanoOptionElement>;\n\n /** Fired when a currently selected item is reselected. */\n @Event() nanoDeselect: EventEmitter<HTMLNanoOptionElement>;\n\n /** Fired when active options change */\n @Event() nanoOptionsUpdated: EventEmitter<HTMLNanoOptionElement[]>;\n\n // Private logic\n\n private isSelected(opt: HTMLNanoOptionElement, val: string) {\n if (val === opt.value || this.selected.includes(opt.value)) {\n opt.selected = true;\n } else opt.selected = false;\n }\n\n private get dropwdownOpen() {\n if (!this.nanoDropdown || !this.open) return false;\n return true;\n }\n\n private get exactMatch() {\n return this.allOptEles.find(\n (opt) => this.connectedInput.value === opt.value\n );\n }\n\n /** reflect value back to the connected input unless the event is cancelled */\n private changeInputValue(opt: HTMLNanoOptionElement) {\n let nanoSelected;\n\n if (this.selected.includes(opt.value)) {\n // deselect option\n this.selected = this.selected.filter((val) => val !== opt.value);\n nanoSelected = this.nanoDeselect.emit(opt);\n } else {\n // select new option\n this.selected = [...this.selected];\n nanoSelected = this.nanoSelect.emit(opt);\n }\n\n if (!nanoSelected.defaultPrevented) {\n if (this.connectedInput) this.connectedInput.value = opt.value;\n\n const event = new window.Event('change');\n this.connectedInput?.dispatchEvent(event);\n }\n }\n\n // a new option has been picked\n private optSelected = (e: NanoMenuCustomEvent<HTMLNanoOptionElement>) => {\n e.stopPropagation();\n this.changeInputValue(e.detail);\n requestAnimationFrame(() => this.inputChange());\n\n if (this.type !== 'selctMulti') this.shouldOpen = false;\n };\n\n // this is for type=\"select\" only.\n // Filter options that start with text - aggregates letters (as opposed to getting the value from input)\n private setOptStartsWith() {\n const attrFind = (toFind: string) =>\n toFind.toLowerCase().substring(0, this.typeToSelect.length) ===\n this.typeToSelect;\n\n const foundEle = this.allOptEles.find(\n (opt) =>\n opt.value.trim().length > 0 &&\n !opt.disabled &&\n (attrFind(opt.textContent) ||\n attrFind(opt.value) ||\n attrFind(opt.label) ||\n attrFind(opt.filterMeta))\n );\n if (foundEle) this.changeInputValue(foundEle);\n }\n\n // Event handlers\n\n private processSlottedContent() {\n requestAnimationFrame(() => {\n this.allOptEles = Array.from(this.host.querySelectorAll('nano-option'));\n this.hasNoResult = !!this.host.querySelector('[slot=\"no-result\"]');\n\n if (this.connectedInput?.value.length && this.type !== 'select') {\n this.inputChange();\n } else this.actvOptEles = this.allOptEles;\n });\n }\n\n // sets focus immediately on open when 'select' - mirroring native behaviour\n private handleShow = async () => {\n if (this.shouldFocus) {\n this.shouldFocus = false;\n this.listBox.setFocus();\n } else if (this.type === 'select') this.listBox.showActiveElement();\n };\n\n private handleHide = () => {\n this.open = false;\n const activeElement = getActiveElement();\n if (activeElement.closest(this.host.tagName.toLowerCase())) {\n this.connectedInput.select();\n }\n };\n\n // any changes to the connected input value will filter the list of active options\n private inputChange() {\n if (this.disableFilter) {\n this.actvOptEles = this.allOptEles;\n return;\n }\n\n const val = this.connectedInput.value;\n const valStr = val.trim().toLowerCase();\n\n let exactMatch = false;\n const activeEles = [];\n const attrFind = (toFind: string) =>\n toFind.toLowerCase().indexOf(valStr) > -1;\n\n this.allOptEles.forEach((opt) => {\n if (\n (val === opt.value || val === opt.label) &&\n this.type !== 'selctMulti'\n ) {\n opt.selected = true;\n exactMatch = true;\n } else this.isSelected(opt, val);\n });\n\n this.allOptEles.forEach((opt) => {\n if (!valStr.length || exactMatch) {\n activeEles.push(opt);\n } else if (\n opt.value.trim().length > 0 &&\n !opt.disabled &&\n (attrFind(opt.textContent) ||\n attrFind(opt.value) ||\n attrFind(opt.label) ||\n attrFind(opt.filterMeta))\n ) {\n activeEles.push(opt);\n }\n });\n\n this.isFiltered = valStr.length && !exactMatch;\n this.actvOptEles = activeEles;\n }\n\n private inputClick = () => {\n this.shouldOpen = true;\n // open dropdown if possible\n this.manageDropdownDisplay();\n };\n\n private inputKeydown = (e: KeyboardEvent) => {\n const ignoreKeys = [\n 'Shift',\n 'ArrowRight',\n 'ArrowLeft',\n 'Escape',\n 'Enter',\n 'Tab',\n ];\n if (ignoreKeys.includes(e.key)) {\n if (e.key === 'Tab') this.shouldOpen = false;\n return;\n }\n\n // When select, mirror native select behaviour. Search on closed list\n if (\n this.type === 'select' &&\n !['ArrowDown', 'ArrowUp'].includes(e.key) &&\n (e.key !== ' ' || this.typeToSelectTimeout)\n ) {\n if (e.key === ' ' || /^[a-z0-9]+$/i.test(e.key)) {\n clearTimeout(this.typeToSelectTimeout);\n this.typeToSelectTimeout = window.setTimeout(() => {\n this.typeToSelect = '';\n this.typeToSelectTimeout = 0;\n }, 750);\n this.typeToSelect += e.key;\n this.setOptStartsWith();\n }\n return;\n }\n\n this.shouldOpen = true;\n // open dropdown if possible\n this.manageDropdownDisplay();\n if (['ArrowDown', 'ArrowUp'].includes(e.key)) {\n e.preventDefault();\n this.shouldFocus = true;\n }\n };\n\n // handles key down on options. Either 'picks'\n // an option or passes event back to input for search / filter\n private optionKeyDown = (\n e: KeyboardEvent & { target: HTMLNanoOptionElement }\n ) => {\n const ignoreKeys = [\n 'Shift',\n 'ArrowUp',\n 'ArrowDown',\n 'Escape',\n 'Enter',\n 'Tab',\n 'Space',\n 'PageUp',\n 'PageDown',\n 'Home',\n 'End',\n ' ',\n ];\n if (ignoreKeys.includes(e.key)) {\n if (e.key === 'Escape') this.connectedInput.focus();\n return;\n }\n\n const deleteKeys = ['Delete', 'Backspace'];\n // this passes whatever's typed back to our input control\n if (\n this.type !== 'select' &&\n (!this.exactMatch || deleteKeys.includes(e.key))\n ) {\n this.connectedInput.focus();\n }\n };\n\n // Component lifecycle\n\n connectedCallback() {\n this.watchInputChange();\n }\n\n componentDidLoad() {\n this.manageSlotChangeListener();\n this.openWatcher();\n }\n\n componentDidRender(): void {\n setTimeout(() => {\n if (!this.connectedInput)\n console.warn(\n 'no `nano-input` found. `nano-datalist` should be nested within an `nano-input` or linked via `input` prop',\n this.host\n );\n }, 500);\n }\n\n render() {\n return (\n <Host\n role={this.actvOptEles.length ? 'listbox' : undefined}\n aria-owns={this.optionIds.length ? this.optionIds.join(' ') : undefined}\n aria-label={\n this.optionIds.length\n ? 'Select options from the list below'\n : undefined\n }\n >\n <nano-dropdown\n {...this.dropDownConfig}\n ref={(el) => (this.nanoDropdown = el)}\n dialogTitle=\"Select options from the list below\"\n class={{\n dlist__dropdown: true,\n 'dlist--isfiltered': this.isFiltered,\n }}\n onNanoAfterShow={this.handleShow}\n onNanoAfterHide={this.handleHide}\n >\n <nano-menu\n hidden={!this.actvOptEles.length}\n type=\"listbox\"\n label={this.inputLabel ? this.inputLabel.textContent : undefined}\n class={{\n dlist__menu: true,\n 'dlist__menu--open': this.dropwdownOpen,\n }}\n tabIndex={-1}\n onNanoSelect={this.optSelected}\n onKeyDown={this.optionKeyDown}\n ref={(el) => (this.listBox = el)}\n >\n <slot name=\"list-top\" />\n {!this.options.length && <slot />}\n {!!this.options.length && <slot name=\"internal-opts\" />}\n <slot name=\"list-bottom\" />\n </nano-menu>\n <nano-menu\n type=\"listbox\"\n label=\"No results found\"\n hidden={!!this.actvOptEles.length}\n class={{\n dlist__menu: true,\n 'dlist__menu--open': this.dropwdownOpen,\n }}\n >\n <slot name=\"no-result\" />\n </nano-menu>\n {!!this.actvOptEles && (\n <div aria-live=\"polite\" role=\"status\" class=\"dlist__status\">\n {this.actvOptEles.length} result\n {this.actvOptEles.length > 1 ? 's' : ''} available.\n </div>\n )}\n </nano-dropdown>\n </Host>\n );\n }\n}\n","@use 'sass:map';\n@use 'sass:list';\n\n@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/colours';\n@import '../../global/style/nano-theme/layers';\n\n:host {\n /**\n * @prop --padding-start: padding at the start of nav-items (left r2l / right l2r). Defaults to '10px'\n * @prop --padding-end: padding at the end of nav-items (right r2l / left l2r). Defaults to '10px'\n * @prop --padding-top: padding at the top of nav-items. Defaults to '10px'\n * @prop --padding-bottom: padding at the bottom of nav-items. Defaults to '10px'\n\n * @prop --secondary-padding-top: padding at the top of nested nav-items. Defaults to 0\n * @prop --secondary-padding-bottom: padding at the bottom of nested nav-items. Defaults to 0\n\n * @prop --bg-color-hover: bg hover color of nav-items. Defaults to #{map.get($colors, blue--faded)};\n * @prop --bg-color-focus: bg focus color of nav-items. Defaults to #{map.get($colors, blue--faded)};\n * @prop --bg-color-selected: bg selected color of nav-items. Defaults to #{map.get($colors, blue--faded)};\n\n * @prop --color-hover: text hover color of nav-items. Defaults to #{map.get($colors, blue)}\n * @prop --color-selected: text selected color of nav-items. Defaults to #{map.get($colors, blue)}\n * @prop --color-focus: text focus color of nav-items. Defaults to #{map.get($colors, blue)}\n\n * @prop --focus-outline: the focus style of nav-items. Defaults to 'none'\n * @prop --font-size: default font-size for all items. Defaults .9em;\n */\n\n --padding-start: #{$spacing-medium};\n --padding-end: #{$spacing-medium};\n --padding-top: #{$spacing-small};\n --padding-bottom: #{$spacing-small};\n --secondary-padding-top: 0;\n --secondary-padding-bottom: 0;\n --bg-color-hover: #{map.get($colors, blue--faded)};\n --bg-color-focus: #{map.get($colors, blue--faded)};\n --bg-color-selected: #{map.get($colors, blue--faded)};\n --color-hover: #{map.get($colors, blue)};\n --color-selected: #{map.get($colors, blue)};\n --color-focus: #{map.get($colors, blue)};\n --focus-outline: none;\n --font-size: 0.9em;\n\n display: block;\n}\n\n.menu {\n font-size: var(--font-size, 0.9em);\n overscroll-behavior: none;\n min-width: var(--width);\n position: relative;\n\n &:focus {\n outline: none;\n }\n}\n\n::slotted(*:not(nano-nav-item):not(nano-option):not(hr):not(slot)) {\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: var(--padding-top) var(--padding-bottom);\n display: block;\n}\n","import {\n Component,\n Event,\n EventEmitter,\n Method,\n h,\n Host,\n Element,\n Prop,\n Listen,\n} from '@stencil/core';\nimport { getActiveElement } from '../../utils/active-element';\nimport { getDirectChildren } from '../../utils/dom';\nimport { getTextContent } from '../../utils/slot';\n\ntype ValidElement = HTMLNanoNavItemElement | HTMLNanoOptionElement;\ntype NNI = HTMLNanoNavItemElement;\n\n/**\n * Menu element. Commonly wrapped by `nano-dropdown` with `nano-option` and `nano-nav-item` elements nested.\n * Manages focus state / active.\n * @slot - The menu's content; `nano-option`, `nano-nav-item` elements as well as <hr> and more.\n */\n@Component({\n tag: 'nano-menu',\n styleUrl: 'menu.scss',\n shadow: true,\n})\nexport class Menu {\n private ignoreMouseEvents = false;\n private ignoreMouseTimeout: any;\n private menu: HTMLElement;\n private typeToSelect = '';\n private typeToSelectTimeout: any;\n\n @Element() private el: HTMLNanoMenuElement;\n\n // Public API\n\n /** get the focus state of the menu @readonly */\n @Prop()\n get hasFocus() {\n return this._hasFocus;\n }\n private _hasFocus = false;\n\n /** changes the role of the underlying control - sometimes required for semantics */\n @Prop() type: 'menu' | 'listbox' = 'menu';\n\n /** an accessible label */\n @Prop() label: string;\n\n // Events\n\n /** Emitted when the menu gains focus. */\n @Event() nanoFocus: EventEmitter;\n\n /** Emitted when the menu loses focus. */\n @Event() nanoBlur: EventEmitter;\n\n /** Emitted when a menu item is selected. */\n @Event() nanoSelect: EventEmitter<\n HTMLNanoOptionElement | HTMLNanoNavItemElement\n >;\n\n // Public Methods\n\n /** Sets focus on the menu. */\n @Method()\n async setFocus() {\n if (this.menu?.focus) this.menu.focus({ preventScroll: true });\n }\n\n /** Removes focus from the menu. */\n @Method()\n async removeFocus() {\n if (this.menu?.blur) this.menu.blur();\n }\n\n /** Sets the current active item */\n @Method()\n async showActiveElement() {\n if (this.selectedItem)\n this.selectedItem.scrollIntoView({ block: 'nearest' });\n }\n\n /** Removes any active item's state */\n @Method()\n async resetActiveItem() {\n this.getItems\n .filter((i) => i.tagName.toLowerCase() === 'nano-option')\n .map((i) => i.setAttribute('tabindex', '-1'));\n }\n\n // Private methods\n\n get getItems() {\n let items: ValidElement[];\n const opened = this.el.querySelectorAll('nano-nav-item.secondary-open');\n if (opened.length) {\n const ctx = opened[opened.length - 1] as HTMLNanoNavItemElement;\n items = Array.from(ctx.querySelectorAll('nano-nav-item, nano-option'));\n } else {\n items = getDirectChildren(\n this.el,\n 'nano-nav-item, nano-option',\n 'slot'\n ) as ValidElement[];\n }\n return items.filter((el) => !el.disabled && !el.hidden);\n }\n\n get activeItem() {\n const activeElement = getActiveElement();\n return this.getItems.find(\n (i) =>\n i.getAttribute('tabindex') === '0' ||\n i === activeElement ||\n i.classList.contains('has-focus')\n );\n }\n\n get selectedItem() {\n return this.getItems.find((i) => i.selected);\n }\n\n private async setActiveFocusItem(item?: ValidElement, focus = true) {\n const items = this.getItems;\n const activeItem =\n !item || item.disabled ? items.find((i) => i.selected) || items[0] : item;\n\n items\n .filter((i) => i.tagName.toLowerCase() === 'nano-option')\n .map((i: HTMLNanoOptionElement) =>\n i.setAttribute('tabindex', i === activeItem ? '0' : '-1')\n );\n\n if (!focus) return;\n\n if (activeItem) {\n (activeItem as NNI).setFocus\n ? (activeItem as NNI).setFocus()\n : activeItem.focus();\n } else this.menu.focus();\n }\n\n // Event Handlers\n\n @Listen('mousedown', { target: 'body' })\n @Listen('keydown')\n handleBlur(e: KeyboardEvent | MouseEvent) {\n if (!this.hasFocus) return;\n\n const kev = e as KeyboardEvent;\n let found: boolean;\n\n if (kev.key) {\n if (kev.key !== 'Tab') return;\n found =\n getActiveElement() &&\n getActiveElement().closest(this.el.tagName.toLowerCase()) === this.el;\n } else found = !!e.composedPath().find((el) => el === this.el);\n\n if (!found) {\n this.resetActiveItem();\n this._hasFocus = false;\n this.nanoBlur.emit();\n }\n }\n\n private handleFocus = () => {\n this.setActiveFocusItem(this.selectedItem || this.getItems[0]);\n\n this._hasFocus = true;\n this.nanoFocus.emit();\n };\n\n private handleClick = (event: MouseEvent) => {\n const target = event.target as HTMLElement;\n const item = target.closest('nano-nav-item');\n\n if (item && !item.disabled) {\n this.nanoSelect.emit(item);\n }\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n // When keying through the menu, if the mouse happens to be hovering over a menu item and the menu scrolls, the\n // mouseout/mouseover event will fire causing the selection to be different than what the user expects. This gives\n // us a way to temporarily ignore mouse events while the user is interacting with a keyboard.\n clearTimeout(this.ignoreMouseTimeout);\n this.ignoreMouseTimeout = setTimeout(\n () => (this.ignoreMouseEvents = false),\n 500\n );\n this.ignoreMouseEvents = true;\n\n // Make a selection when pressing enter\n switch (event.key) {\n case ' ':\n if (this.activeItem) this.activeItem.click();\n break;\n case 'ArrowDown':\n case 'ArrowUp':\n case 'PageDown':\n case 'PageUp':\n case 'Home':\n case 'End':\n const items = this.getItems;\n const selectedItem = this.activeItem;\n let index = items.indexOf(selectedItem);\n\n if (items.length) {\n event.preventDefault();\n\n if (event.key === 'ArrowDown') {\n index++;\n } else if (event.key === 'ArrowUp') {\n index--;\n } else if (event.key === 'Home' || event.key === 'PageUp') {\n index = 0;\n } else if (event.key === 'End' || event.key === 'PageDown') {\n index = items.length - 1;\n }\n\n if (index < 0) index = items.length - 1;\n if (index > items.length - 1) index = 0;\n\n this.setActiveFocusItem(items[index]);\n if (items[index]) items[index].scrollIntoView({ block: 'nearest' });\n return;\n }\n break;\n }\n\n // Handle type-to-search behavior when non-control characters are entered\n if (event.key === ' ' || /^[a-z0-9]+$/i.test(event.key)) {\n clearTimeout(this.typeToSelectTimeout);\n this.typeToSelectTimeout = setTimeout(\n () => (this.typeToSelect = ''),\n 750\n );\n this.typeToSelect += event.key;\n\n const items = this.getItems;\n for (const item of items) {\n const slot = item.shadowRoot.querySelector(\n 'slot:not([name])'\n ) as HTMLSlotElement;\n const label = getTextContent(slot).toLowerCase().trim();\n if (\n label.substring(0, this.typeToSelect.length) === this.typeToSelect\n ) {\n this.setActiveFocusItem(item);\n break;\n }\n }\n }\n };\n\n private handleMouseOver = (event: MouseEvent) => {\n const target = event.target as HTMLElement;\n const item =\n target.closest('nano-nav-item') || target.closest('nano-option');\n\n if (item && !this.ignoreMouseEvents) {\n this.setActiveFocusItem(item);\n }\n };\n\n // Component Lifecycle\n\n render() {\n return (\n <Host>\n <div\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n onMouseOver={this.handleMouseOver}\n onFocus={this.handleFocus}\n aria-label={this.label ? this.label : undefined}\n role={this.type}\n ref={(el) => (this.menu = el)}\n part=\"base\"\n class={{\n menu: true,\n ['menu--' + this.type]: true,\n 'menu--has-focus': this.hasFocus,\n }}\n tabIndex={-1}\n >\n <slot />\n </div>\n </Host>\n );\n }\n}\n","@use 'sass:map';\n@use 'sass:list';\n\n@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/form';\n@import '../../global/style/nano-theme/base';\n@import '../../global/style/nano-theme/layers';\n\n:host {\n /**\n * @prop --padding-top: Defaults to #{$spacing-small};\n * @prop --padding-bottom: Defaults to #{$spacing-small};\n * @prop --padding-start: Defaults to #{$spacing-small};\n * @prop --padding-end: Defaults to #{$spacing-small};\n\n * @prop --bg: default background. Defaults to none;\n * @prop --bg-selected: background when selected. Defaults to #{$select-opt-selected};\n * @prop --bg-focus: background when focused. Defaults to var(--nano-color-base, #{nano-color(primary, tint)});\n * @prop --bg-disabled: background when disabled. Defaults to none;\n\n * @prop --color: default text color. Defaults to var(--input-text-color, #{$input-text-color});\n * @prop --color-selected: text color when selected. Defaults to var(--nano-color-base, #{nano-color(primary, base)});\n * @prop --color-focus: text color when focused. Defaults to var(--nano-color-base, #{nano-color(primary, contrast)});\n * @prop --color-disabled: text color when disabled. Defaults to #{map.get($colors, palegrey)};\n\n * @prop --opt-icon-size: Sizes all icons within the option. Defaults to 1.4em;\n */\n\n --bg: none;\n --bg-selected: #{$select-opt-selected};\n --bg-focus: var(--nano-color-base, #{nano-color(primary, tint)});\n --bg-disabled: none;\n --color: var(--input-text-color, #{$input-text-color});\n --color-selected: var(--nano-color-base, #{nano-color(primary, base)});\n --color-focus: var(--nano-color-contrast, #{nano-color(primary, contrast)});\n --color-disabled: #{map.get($colors, palegrey)};\n --opt-icon-size: 1.6em;\n\n display: block;\n color: var(--color);\n overflow: hidden;\n font-size: 14px;\n font-size: #{'clamp(12px, .9em, 16px)'};\n}\n\n:host(:focus) {\n outline: none;\n}\n\n.option {\n $self: &;\n\n position: relative;\n user-select: none;\n cursor: pointer;\n display: flex;\n align-items: stretch;\n width: 100%;\n background: var(--bg);\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: var(--padding-top) var(--padding-bottom);\n\n // focus\n :host(:focus) &:not(.option--disabled),\n :host &.option--selected {\n outline: none;\n background: var(--bg-selected);\n color: var(--color-selected);\n }\n\n :host(:focus) &:not(.option--disabled) {\n background: var(--bg-focus);\n color: var(--color-focus);\n }\n\n // disabled\n &.option--disabled {\n outline: none;\n color: var(--color-disabled);\n cursor: not-allowed;\n background: var(--bg-disabled);\n }\n\n // no value\n &.option--novalue {\n font-style: italic;\n opacity: 0.7;\n }\n\n &__label {\n flex: 1 1 auto;\n display: flex;\n align-items: center;\n }\n\n &__start {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n\n ::slotted(nano-icon) {\n font-size: var(--opt-icon-size);\n }\n\n ::slotted(:last-child) {\n margin-inline-end: 0.5em;\n }\n }\n\n &__end {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n\n ::slotted(nano-icon) {\n font-size: var(--opt-icon-size);\n }\n\n ::slotted(:first-child) {\n margin-inline-start: 0.5em;\n }\n }\n\n &__check {\n visibility: hidden;\n display: flex;\n position: absolute;\n inset-inline-start: 0.6em;\n inset-block-start: calc(50% - 0.6em);\n align-items: center;\n font-size: 0.9em;\n\n #{$self}--selected:not(#{$self}--novalue) & {\n visibility: visible;\n }\n }\n}\n","import {\n Component,\n Prop,\n h,\n Host,\n State,\n Watch,\n Element,\n Listen,\n Event,\n EventEmitter,\n} from '@stencil/core';\nimport { getDirectChildren } from '../../utils/dom';\nimport { debounce } from '../../utils/throttle';\nimport type { OptionInterface } from '../../interface';\n\nlet optIds = 0;\n\n/**\n * Select options to be used with [nano-select](/story/nano-components-select) or [nano-datalist](/story/nano-components-select)\n *\n * @slot - main label. Defaults to `label` or `value` prop\n * @slot checked-icon - icon to indicated checked / selected state. Defaults to fontawesome light/check\n * @slot start - suitable for an icon or content displayed at the start of the main label\n * @slot end - suitable for an icon or content displayed at the end of the main label\n */\n@Component({\n tag: 'nano-option',\n styleUrl: 'option.scss',\n shadow: true,\n})\nexport class Option implements OptionInterface {\n private optId = `nano-option-${optIds++}`;\n @Element() host: HTMLNanoOptionElement;\n @State() hasFocus = false;\n\n constructor() {\n this.handleClick = debounce(this.handleClick.bind(this), 5);\n }\n\n // Public API\n\n /**\n * Value of the option\n */\n @Prop({ mutable: true, reflect: true }) value: string = '';\n\n @Watch('value')\n valueChanged() {\n if (!this.value || !this.value.length) this.value = this.labelContent;\n }\n\n /**\n * Label of the option\n */\n @Prop({ mutable: true, reflect: true }) label: string = '';\n\n @Watch('label')\n labelChanged() {\n if (!this.label || !this.label.length)\n this.label = this.labelContent.length ? this.labelContent : this.value;\n }\n\n /**\n * Whether this option is selected\n */\n @Prop({ reflect: true }) selected: boolean = false;\n\n /**\n * Whether this option should be disabled\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /** You can add extra meta for this option. When displayed in a list, users\n * search / filter via extra related terms. Another usecase is 'endonyms'\n */\n @Prop() filterMeta: string = '';\n\n /** Fired when an option is selected */\n @Event() nanoSelect!: EventEmitter<HTMLNanoOptionElement>;\n\n // Event handlers\n\n // stop scrolling on select\n @Listen('keydown')\n handleKeyDown(e: KeyboardEvent) {\n if (e.key !== ' ' && e.key !== 'Enter') return;\n e.preventDefault();\n this.nanoSelect.emit(this.host);\n }\n\n private handleClick() {\n if (this.disabled) return;\n this.nanoSelect.emit(this.host);\n }\n\n // Private logic\n\n private get labelContent() {\n return getDirectChildren(this.host, '*:not([slot])', false)\n .map((el) => el.textContent)\n .join(' ')\n .trim();\n }\n\n // Component lifecycle\n\n componentWillLoad() {\n this.valueChanged();\n this.labelChanged();\n }\n\n render() {\n return (\n <Host\n role=\"option\"\n aria-selected={this.selected ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n >\n <div\n onMouseDown={this.handleClick}\n id={this.optId}\n class={{\n option: true,\n 'option--selected': this.selected,\n 'option--disabled': this.disabled,\n 'option--novalue': !this.value,\n }}\n >\n <div part=\"check-icon\" class=\"option__check\">\n <slot name=\"check-icon\">\n <nano-icon name=\"light/check\" aria-hidden=\"true\" />\n </slot>\n </div>\n <div part=\"start\" class=\"option__start\">\n <slot name=\"start\"></slot>\n </div>\n <div part=\"label\" class=\"option__label\">\n <slot>{this.label || this.value}</slot>\n </div>\n <div part=\"end\" class=\"option__end\">\n <slot name=\"end\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["src/components/datalist/datalist.scss?tag=nano-datalist&encapsulation=shadow","src/components/datalist/datalist.tsx","src/components/menu/menu.scss?tag=nano-menu&encapsulation=shadow","src/components/menu/menu.tsx","src/components/option/option.scss?tag=nano-option&encapsulation=shadow","src/components/option/option.tsx"],"names":["datalistCss","findLabel","formCtrl","foundLabel","id","document","querySelector","closest","listIds","DataList","[object Object]","hostRef","this","isNanoInput","typeToSelect","listId","isFiltered","shouldFocus","_allOptEles","_dropDownConfig","skidding","optSelected","e","stopPropagation","changeInputValue","detail","requestAnimationFrame","inputChange","type","shouldOpen","handleShow","async","listBox","setFocus","showActiveElement","handleHide","open","activeElement","getActiveElement","host","tagName","toLowerCase","connectedInput","select","inputClick","manageDropdownDisplay","inputKeydown","ignoreKeys","includes","key","typeToSelectTimeout","test","clearTimeout","window","setTimeout","setOptStartsWith","preventDefault","optionKeyDown","focus","deleteKeys","exactMatch","debounce","bind","allOptEles","opts","value","forEach","opt","selected","dropDownConfig","ddc","activeOptions","writeTask","nanoDropdown","setAttribute","toString","nanoInput","getInputElement","input","HTMLElement","options","length","mo","MutationObserver","processSlottedContent","observe","childList","subtree","disconnect","undefined","previousOptions","querySelectorAll","internalOpt","remove","flatMap","option","i","label","Object","assign","createElement","ariaPosinset","ariaSetsize","textContent","slot","append","actvOptEles","dwConfig","closeOnSelect","autocompleteType","readonly","placement","tetherTo","readOnly","newInput","oldInput","removeEventListener","inputLabel","removeAttribute","addEventListener","labels","item","c","val","optIds","hidden","isSelected","push","optionIds","hasNoResult","canOpen","disabled","openWatcher","nanoOptionsUpdated","emit","dropwdownOpen","find","nanoSelected","filter","nanoDeselect","nanoSelect","defaultPrevented","event","Event","dispatchEvent","attrFind","toFind","substring","foundEle","trim","filterMeta","Array","from","disableFilter","valStr","activeEles","indexOf","watchInputChange","manageSlotChangeListener","console","warn","h","Host","role","aria-owns","join","aria-label","ref","el","dialogTitle","class","dlist__dropdown","dlist--isfiltered","onNanoAfterShow","onNanoAfterHide","dlist__menu","dlist__menu--open","tabIndex","onNanoSelect","onKeyDown","name","aria-live","menuCss","Menu","ignoreMouseEvents","_hasFocus","handleFocus","setActiveFocusItem","selectedItem","getItems","nanoFocus","handleClick","target","handleKeyDown","ignoreMouseTimeout","activeItem","click","items","index","scrollIntoView","block","shadowRoot","getTextContent","handleMouseOver","hasFocus","menu","preventScroll","blur","map","opened","ctx","getDirectChildren","getAttribute","classList","contains","kev","found","composedPath","resetActiveItem","nanoBlur","onClick","onMouseOver","onFocus","part","menu--has-focus","optionCss","Option","optId","labelContent","valueChanged","labelChanged","aria-selected","aria-disabled","onMouseDown","option--selected","option--disabled","option--novalue","aria-hidden"],"mappings":"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","sourcesContent":["@use 'sass:map';\n@use 'sass:list';\n\n@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/form';\n@import '../../global/style/nano-theme/base';\n@import '../../global/style/nano-theme/layers';\n\n:host {\n /**\n * @prop --padding-top: for all nested `nano-option` elements. Defaults to #{$spacing-small};\n * @prop --padding-bottom: for all nested `nano-option` elements. Defaults to #{$spacing-small};\n * @prop --padding-start: for all nested `nano-option` elements. Defaults to #{$spacing-xlarge};\n * @prop --padding-end: for all nested `nano-option` elements. Defaults to #{$spacing-xlarge};\n * @prop --font-size: for all nested `nano-option` elements. Defaults to .8em;\n * @prop --color: default text color of content other than `nano-option`. Defaults to #{map.get($colors, palegrey)};\n */\n\n --padding-top: #{$spacing-small};\n --padding-bottom: #{$spacing-small};\n --padding-start: #{$spacing-xlarge};\n --padding-end: #{$spacing-xlarge};\n --font-size: 0.8em;\n --color: #{map.get($colors, palegrey)};\n\n color: var(--color);\n}\n\n.dlist {\n &--isfiltered {\n ::slotted(*:not(nano-option):not([slot='no-result']):not([slot='list-top']):not([slot='list-bottom'])) {\n display: none !important;\n }\n }\n\n &__dropdown {\n --min-width: 100%;\n --overflow: auto;\n }\n\n &__status {\n @include visually-hide();\n }\n\n &__menu {\n --padding-top: inherit;\n --padding-bottom: inherit;\n --padding-start: inherit;\n --padding-end: inherit;\n --font-size: inherit;\n }\n}\n","import {\n Component,\n ComponentInterface,\n h,\n Host,\n Element,\n State,\n Watch,\n Prop,\n Event,\n writeTask,\n Build,\n EventEmitter,\n} from '@stencil/core';\nimport { getActiveElement } from '../../utils/active-element';\nimport { debounce } from '../../utils/throttle';\nimport type { NanoMenuCustomEvent, OptionInterface } from '../../interface';\nimport type { Dropdown } from '../dropdown/dropdown';\n\nfunction findLabel(formCtrl: Element) {\n let foundLabel: HTMLLabelElement;\n\n if (formCtrl.id) {\n foundLabel = document.querySelector(`label[for='${formCtrl.id}']`);\n }\n if (!foundLabel) {\n foundLabel = formCtrl.closest('label');\n }\n return foundLabel;\n}\n\nlet listIds = 0;\n\n/**\n * `nano-datalist` a visually consistent and more flexible replacement for a native\n * [datalist](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/datalist). Can be nested within a `nano-input`\n * or linked to any input control via the `input` prop. Is used internally within `nano-select`.\n * Options can be defined declaratively by nesting `<nano-option>` elements or imperatively using the `options` prop\n *\n * @slot - use `<nano-option>` elements for more complex html. Alternatively use the `options` prop\n * @slot list-top - shows at the top of the list when there are options present\n * @slot list-bottom - shows at the bottom of the list when there are options present\n * @slot no-result - shown when there are no results otherwise nothing will be shown\n */\n@Component({\n tag: 'nano-datalist',\n styleUrl: 'datalist.scss',\n shadow: true,\n})\nexport class DataList implements ComponentInterface {\n // Private State\n\n private isNanoInput = false;\n private typeToSelect = '';\n private typeToSelectTimeout: number;\n private nanoDropdown: HTMLNanoDropdownElement;\n private listBox: HTMLNanoMenuElement;\n private mo?: MutationObserver;\n private listId = `nano-datalist-${listIds++}`;\n private isFiltered = false;\n private shouldFocus = false;\n // all potential option eles. Set via slot or `options` prop.\n // Some may get hidden due to filtering\n private get allOptEles() {\n return this._allOptEles;\n }\n private set allOptEles(opts) {\n // when allOptEles are initially set (on slot change / options) -\n // add options to 'selected' and fire selected event *if*\n // value isn't set on the input\n this._allOptEles = opts;\n if (this.connectedInput?.value) return;\n\n opts.forEach((opt) => {\n if (opt.selected && !this.selected.includes(opt.value)) {\n this.changeInputValue(opt);\n }\n });\n }\n private _allOptEles: HTMLNanoOptionElement[] = [];\n\n @Element() host: HTMLNanoDatalistElement;\n\n // active option eles that are not hidden.\n @State() actvOptEles: HTMLNanoOptionElement[] = [];\n @State() connectedInput: HTMLInputElement | HTMLTextAreaElement;\n @State() inputLabel: HTMLLabelElement;\n @State() hasNoResult: boolean;\n @State() shouldOpen: boolean;\n @State() canOpen: boolean = true;\n @State() optionIds: string[] = [];\n\n constructor() {\n this.inputChange = debounce(this.inputChange.bind(this), 50);\n }\n\n // Public API\n\n /** By default, items in the list will appear 'selected' when the value in the linked input control matches.\n * However you can add other selected options via the the selected prop. */\n @Prop({ mutable: true }) selected: string[] = [];\n\n /** nano-dropdown config options you can pass to the nested dropdown component */\n @Prop()\n get dropDownConfig() {\n return this._dropDownConfig;\n }\n set dropDownConfig(ddc: Partial<Dropdown>) {\n this._dropDownConfig = { ...this._dropDownConfig, ...ddc };\n }\n private _dropDownConfig: Partial<Dropdown> = {\n skidding: -1,\n };\n\n /** Provide an option list.\n * Options can be defined declaratively by nesting `<nano-option>` elements or imperatively using this prop */\n @Prop() options?: OptionInterface[] = [];\n\n /** A selector to a HTMLInputElement */\n @Prop() input?: string | HTMLInputElement;\n\n /** Tweaks the datalist behaviour and linked control semantics and behaviour.\n * e.g. 'select' will make the linked input control `readonly`.\n */\n @Prop() type: 'select' | 'selctMulti' | 'input' = 'input';\n\n /** return all the active options currently within the datalist. Can be useful for validation */\n @Prop()\n get activeOptions() {\n return this.allOptEles;\n }\n\n /** Force datalist open */\n @Prop({ mutable: true }) open: boolean = false;\n\n @Watch('open')\n openWatcher() {\n writeTask(() => {\n this.nanoDropdown.open = this.open;\n this.connectedInput.setAttribute('aria-expanded', this.open.toString());\n });\n }\n\n /** Use this option to disable to default filtering. This is useful if filtering happens\n * externally via another method (e.g. via ajax)\n */\n @Prop() disableFilter = false;\n\n /** Activate / deactivate the datalist control */\n @Prop() disabled = false;\n\n // State change watchers\n\n @Watch('input')\n async watchInputChange() {\n let nanoInput;\n if ((nanoInput = this.host.closest('nano-input'))) {\n this.isNanoInput = true;\n this.connectedInput = await nanoInput.getInputElement();\n } else if (\n this.input &&\n typeof this.input === 'string' &&\n (nanoInput = document.querySelector(this.input))\n ) {\n this.isNanoInput = false;\n this.connectedInput = nanoInput;\n } else if (this.input instanceof HTMLElement) {\n this.connectedInput = this.input;\n }\n }\n\n @Watch('options')\n manageSlotChangeListener() {\n if (!this.host) return;\n\n // we're not using `options` - setup new MO\n if ((!this.options || !this.options.length) && !this.mo) {\n if (Build.isBrowser) {\n const mo = (this.mo = new MutationObserver(() =>\n this.processSlottedContent()\n ));\n mo.observe(this.host, { childList: true, subtree: true });\n }\n this.processSlottedContent();\n return;\n }\n\n // we're using `options` - trash current MO\n if (this.options?.length) {\n if (!!this.mo) {\n this.mo.disconnect();\n this.mo = undefined;\n }\n\n const previousOptions = this.host.querySelectorAll(\n '[slot=\"internal-opts\"]'\n );\n\n // add imperative `options`\n writeTask(() => {\n // clear all previous\n if (previousOptions?.length)\n previousOptions.forEach((internalOpt) => internalOpt.remove());\n\n this.allOptEles = this.options.flatMap((option, i) => {\n if (option.value || option.label) {\n const opt = Object.assign(document.createElement('nano-option'), {\n label: option.label,\n value: option.value,\n ariaPosinset: i,\n ariaSetsize: this.options.length,\n selected: option.selected,\n id: this.listId + '-option-' + i,\n textContent: option.label ? option.label : option.value,\n slot: 'internal-opts',\n });\n this.host.append(opt);\n return opt;\n }\n });\n\n if (this.connectedInput?.value.length && this.type !== 'select') {\n this.inputChange();\n } else {\n this.actvOptEles = [...this.allOptEles];\n }\n });\n }\n // forceUpdate(this.host);\n }\n\n @Watch('type')\n @Watch('connectedInput')\n watchTypeChange() {\n if (!this.connectedInput) return;\n\n let dwConfig: Partial<Dropdown> = { closeOnSelect: false };\n let autocompleteType: 'list' | 'both' = 'both';\n let readonly = false;\n\n switch (this.type) {\n case 'input':\n dwConfig = { closeOnSelect: true };\n break;\n case 'select':\n autocompleteType = 'list';\n readonly = true;\n dwConfig = { closeOnSelect: true, placement: 'center' };\n break;\n }\n\n if (!this.isNanoInput) {\n dwConfig.tetherTo = this.connectedInput;\n }\n\n this.dropDownConfig = { ...this.dropDownConfig, ...dwConfig };\n this.connectedInput.setAttribute('aria-autocomplete', autocompleteType);\n this.connectedInput.readOnly = readonly;\n }\n\n @Watch('connectedInput')\n manageInputEvents(newInput?: HTMLInputElement, oldInput?: HTMLInputElement) {\n if (!!oldInput) {\n const nanoInput = oldInput.closest('nano-input');\n if (nanoInput) {\n nanoInput.removeEventListener('nanoChange', this.inputChange);\n }\n oldInput.removeEventListener('change', this.inputChange);\n oldInput.removeEventListener('click', this.inputClick);\n oldInput.removeEventListener('keydown', this.inputKeydown);\n oldInput.removeEventListener('input', this.inputChange);\n\n this.inputLabel = null;\n\n writeTask(() => {\n oldInput.removeAttribute('role');\n oldInput.removeAttribute('aria-expanded');\n oldInput.removeAttribute('aria-controls');\n oldInput.removeAttribute('aria-owns');\n oldInput.removeAttribute('aria-haspopup');\n oldInput.removeAttribute('aria-autocomplete');\n oldInput.removeAttribute('autocomplete');\n });\n }\n if (!!newInput) {\n const nanoInput = newInput.closest('nano-input');\n if (nanoInput) {\n nanoInput.addEventListener('nanoChange', this.inputChange);\n }\n newInput.addEventListener('change', this.inputChange);\n newInput.addEventListener('click', this.inputClick);\n newInput.addEventListener('keydown', this.inputKeydown);\n newInput.addEventListener('input', this.inputChange);\n this.listId = this.host.id || this.listId;\n\n this.inputLabel = newInput?.labels?.item(0) || findLabel(newInput);\n\n writeTask(() => {\n this.host.id = this.listId;\n newInput.setAttribute('role', 'combobox');\n newInput.setAttribute('aria-expanded', 'false');\n newInput.setAttribute('aria-controls', this.listId);\n newInput.setAttribute('aria-owns', this.listId);\n newInput.setAttribute('aria-haspopup', 'listbox');\n newInput.setAttribute('autocomplete', 'off');\n });\n }\n }\n\n @Watch('selected')\n @Watch('actvOptEles')\n watchActvOptChange() {\n let c = 0;\n const val = this.connectedInput?.value || '';\n const optIds = [];\n\n writeTask(() => {\n this.allOptEles.forEach((opt, i) => {\n if (this.actvOptEles.includes(opt)) {\n c++;\n opt.setAttribute('aria-posinset', c + '');\n opt.setAttribute('aria-setsize', this.actvOptEles.length + '');\n opt.hidden = false;\n this.isSelected(opt, val);\n } else {\n opt.removeAttribute('aria-posinset');\n opt.removeAttribute('aria-setsize');\n opt.hidden = true;\n opt.selected = false;\n }\n opt.id = this.listId + '-option-' + i;\n optIds.push(opt.id);\n });\n this.optionIds = optIds;\n });\n }\n\n @Watch('actvOptEles')\n @Watch('hasNoResult')\n manageCanOpen() {\n if (this.actvOptEles.length || this.hasNoResult) this.canOpen = true;\n else this.canOpen = false;\n }\n\n /**\n * Opens the dropdown if it can, it should and there are items to display.\n */\n @Watch('shouldOpen')\n @Watch('canOpen')\n manageDropdownDisplay() {\n if (this.shouldOpen && this.canOpen && !this.disabled) this.open = true;\n if (!this.shouldOpen || !this.canOpen) this.open = false;\n this.openWatcher();\n }\n\n @Watch('actvOptEles')\n fireActiveOptsEvent() {\n this.nanoOptionsUpdated.emit(this.actvOptEles);\n }\n\n // Events\n\n /** Fired when an item is selected. */\n @Event() nanoSelect: EventEmitter<HTMLNanoOptionElement>;\n\n /** Fired when a currently selected item is reselected. */\n @Event() nanoDeselect: EventEmitter<HTMLNanoOptionElement>;\n\n /** Fired when active options change */\n @Event() nanoOptionsUpdated: EventEmitter<HTMLNanoOptionElement[]>;\n\n // Private logic\n\n private isSelected(opt: HTMLNanoOptionElement, val: string) {\n if (val === opt.value || this.selected.includes(opt.value)) {\n opt.selected = true;\n } else opt.selected = false;\n }\n\n private get dropwdownOpen() {\n if (!this.nanoDropdown || !this.open) return false;\n return true;\n }\n\n private get exactMatch() {\n return this.allOptEles.find(\n (opt) => this.connectedInput.value === opt.value\n );\n }\n\n /** reflect value back to the connected input unless the event is cancelled */\n private changeInputValue(opt: HTMLNanoOptionElement) {\n let nanoSelected;\n\n if (this.selected.includes(opt.value)) {\n // deselect option\n this.selected = this.selected.filter((val) => val !== opt.value);\n nanoSelected = this.nanoDeselect.emit(opt);\n } else {\n // select new option\n this.selected = [...this.selected];\n nanoSelected = this.nanoSelect.emit(opt);\n }\n\n if (!nanoSelected.defaultPrevented) {\n if (this.connectedInput) this.connectedInput.value = opt.value;\n\n const event = new window.Event('change');\n this.connectedInput?.dispatchEvent(event);\n }\n }\n\n // a new option has been picked\n private optSelected = (e: NanoMenuCustomEvent<HTMLNanoOptionElement>) => {\n e.stopPropagation();\n this.changeInputValue(e.detail);\n requestAnimationFrame(() => this.inputChange());\n\n if (this.type !== 'selctMulti') this.shouldOpen = false;\n };\n\n // this is for type=\"select\" only.\n // Filter options that start with text - aggregates letters (as opposed to getting the value from input)\n private setOptStartsWith() {\n const attrFind = (toFind: string) =>\n toFind.toLowerCase().substring(0, this.typeToSelect.length) ===\n this.typeToSelect;\n\n const foundEle = this.allOptEles.find(\n (opt) =>\n opt.value.trim().length > 0 &&\n !opt.disabled &&\n (attrFind(opt.textContent) ||\n attrFind(opt.value) ||\n attrFind(opt.label) ||\n attrFind(opt.filterMeta))\n );\n if (foundEle) this.changeInputValue(foundEle);\n }\n\n // Event handlers\n\n private processSlottedContent() {\n requestAnimationFrame(() => {\n this.allOptEles = Array.from(this.host.querySelectorAll('nano-option'));\n this.hasNoResult = !!this.host.querySelector('[slot=\"no-result\"]');\n\n if (this.connectedInput?.value.length && this.type !== 'select') {\n this.inputChange();\n } else this.actvOptEles = this.allOptEles;\n });\n }\n\n // sets focus immediately on open when 'select' - mirroring native behaviour\n private handleShow = async () => {\n if (this.shouldFocus) {\n this.shouldFocus = false;\n this.listBox.setFocus();\n } else if (this.type === 'select') this.listBox.showActiveElement();\n };\n\n private handleHide = () => {\n this.open = false;\n const activeElement = getActiveElement();\n if (activeElement.closest(this.host.tagName.toLowerCase())) {\n this.connectedInput.select();\n }\n };\n\n // any changes to the connected input value will filter the list of active options\n private inputChange() {\n if (this.disableFilter) {\n this.actvOptEles = this.allOptEles;\n return;\n }\n\n const val = this.connectedInput.value;\n const valStr = val.trim().toLowerCase();\n\n let exactMatch = false;\n const activeEles = [];\n const attrFind = (toFind: string) =>\n toFind.toLowerCase().indexOf(valStr) > -1;\n\n this.allOptEles.forEach((opt) => {\n if (\n (val === opt.value || val === opt.label) &&\n this.type !== 'selctMulti'\n ) {\n opt.selected = true;\n exactMatch = true;\n } else this.isSelected(opt, val);\n });\n\n this.allOptEles.forEach((opt) => {\n if (!valStr.length || exactMatch) {\n activeEles.push(opt);\n } else if (\n opt.value.trim().length > 0 &&\n !opt.disabled &&\n (attrFind(opt.textContent) ||\n attrFind(opt.value) ||\n attrFind(opt.label) ||\n attrFind(opt.filterMeta))\n ) {\n activeEles.push(opt);\n }\n });\n\n this.isFiltered = valStr.length && !exactMatch;\n this.actvOptEles = activeEles;\n }\n\n private inputClick = () => {\n this.shouldOpen = true;\n // open dropdown if possible\n this.manageDropdownDisplay();\n };\n\n private inputKeydown = (e: KeyboardEvent) => {\n const ignoreKeys = [\n 'Shift',\n 'ArrowRight',\n 'ArrowLeft',\n 'Escape',\n 'Enter',\n 'Tab',\n ];\n if (ignoreKeys.includes(e.key)) {\n if (e.key === 'Tab') this.shouldOpen = false;\n return;\n }\n\n // When select, mirror native select behaviour. Search on closed list\n if (\n this.type === 'select' &&\n !['ArrowDown', 'ArrowUp'].includes(e.key) &&\n (e.key !== ' ' || this.typeToSelectTimeout)\n ) {\n if (e.key === ' ' || /^[a-z0-9]+$/i.test(e.key)) {\n clearTimeout(this.typeToSelectTimeout);\n this.typeToSelectTimeout = window.setTimeout(() => {\n this.typeToSelect = '';\n this.typeToSelectTimeout = 0;\n }, 750);\n this.typeToSelect += e.key;\n this.setOptStartsWith();\n }\n return;\n }\n\n this.shouldOpen = true;\n // open dropdown if possible\n this.manageDropdownDisplay();\n if (['ArrowDown', 'ArrowUp'].includes(e.key)) {\n e.preventDefault();\n this.shouldFocus = true;\n }\n };\n\n // handles key down on options. Either 'picks'\n // an option or passes event back to input for search / filter\n private optionKeyDown = (\n e: KeyboardEvent & { target: HTMLNanoOptionElement }\n ) => {\n const ignoreKeys = [\n 'Shift',\n 'ArrowUp',\n 'ArrowDown',\n 'Escape',\n 'Enter',\n 'Tab',\n 'Space',\n 'PageUp',\n 'PageDown',\n 'Home',\n 'End',\n ' ',\n ];\n if (ignoreKeys.includes(e.key)) {\n if (e.key === 'Escape') this.connectedInput.focus();\n return;\n }\n\n const deleteKeys = ['Delete', 'Backspace'];\n // this passes whatever's typed back to our input control\n if (\n this.type !== 'select' &&\n (!this.exactMatch || deleteKeys.includes(e.key))\n ) {\n this.connectedInput.focus();\n }\n };\n\n // Component lifecycle\n\n connectedCallback() {\n this.watchInputChange();\n }\n\n componentDidLoad() {\n this.manageSlotChangeListener();\n this.openWatcher();\n }\n\n componentDidRender(): void {\n setTimeout(() => {\n if (!this.connectedInput)\n console.warn(\n 'no `nano-input` found. `nano-datalist` should be nested within an `nano-input` or linked via `input` prop',\n this.host\n );\n }, 500);\n }\n\n render() {\n return (\n <Host\n role={this.actvOptEles.length ? 'listbox' : undefined}\n aria-owns={this.optionIds.length ? this.optionIds.join(' ') : undefined}\n aria-label={\n this.optionIds.length\n ? 'Select options from the list below'\n : undefined\n }\n >\n <nano-dropdown\n {...this.dropDownConfig}\n ref={(el) => (this.nanoDropdown = el)}\n dialogTitle=\"Select options from the list below\"\n class={{\n dlist__dropdown: true,\n 'dlist--isfiltered': this.isFiltered,\n }}\n onNanoAfterShow={this.handleShow}\n onNanoAfterHide={this.handleHide}\n >\n <nano-menu\n hidden={!this.actvOptEles.length}\n type=\"listbox\"\n label={this.inputLabel ? this.inputLabel.textContent : undefined}\n class={{\n dlist__menu: true,\n 'dlist__menu--open': this.dropwdownOpen,\n }}\n tabIndex={-1}\n onNanoSelect={this.optSelected}\n onKeyDown={this.optionKeyDown}\n ref={(el) => (this.listBox = el)}\n >\n <slot name=\"list-top\" />\n {!this.options.length && <slot />}\n {!!this.options.length && <slot name=\"internal-opts\" />}\n <slot name=\"list-bottom\" />\n </nano-menu>\n <nano-menu\n type=\"listbox\"\n label=\"No results found\"\n hidden={!!this.actvOptEles.length}\n class={{\n dlist__menu: true,\n 'dlist__menu--open': this.dropwdownOpen,\n }}\n >\n <slot name=\"no-result\" />\n </nano-menu>\n {!!this.actvOptEles && (\n <div aria-live=\"polite\" role=\"status\" class=\"dlist__status\">\n {this.actvOptEles.length} result\n {this.actvOptEles.length > 1 ? 's' : ''} available.\n </div>\n )}\n </nano-dropdown>\n </Host>\n );\n }\n}\n","@use 'sass:map';\n@use 'sass:list';\n\n@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/colours';\n@import '../../global/style/nano-theme/layers';\n\n:host {\n /**\n * @prop --padding-start: padding at the start of nav-items (left r2l / right l2r). Defaults to '10px'\n * @prop --padding-end: padding at the end of nav-items (right r2l / left l2r). Defaults to '10px'\n * @prop --padding-top: padding at the top of nav-items. Defaults to '10px'\n * @prop --padding-bottom: padding at the bottom of nav-items. Defaults to '10px'\n\n * @prop --secondary-padding-top: padding at the top of nested nav-items. Defaults to 0\n * @prop --secondary-padding-bottom: padding at the bottom of nested nav-items. Defaults to 0\n\n * @prop --bg-color-hover: bg hover color of nav-items. Defaults to #{map.get($colors, blue--faded)};\n * @prop --bg-color-focus: bg focus color of nav-items. Defaults to #{map.get($colors, blue--faded)};\n * @prop --bg-color-selected: bg selected color of nav-items. Defaults to #{map.get($colors, blue--faded)};\n\n * @prop --color-hover: text hover color of nav-items. Defaults to #{map.get($colors, blue)}\n * @prop --color-selected: text selected color of nav-items. Defaults to #{map.get($colors, blue)}\n * @prop --color-focus: text focus color of nav-items. Defaults to #{map.get($colors, blue)}\n\n * @prop --focus-outline: the focus style of nav-items. Defaults to 'none'\n * @prop --font-size: default font-size for all items. Defaults .9em;\n */\n\n --padding-start: #{$spacing-medium};\n --padding-end: #{$spacing-medium};\n --padding-top: #{$spacing-small};\n --padding-bottom: #{$spacing-small};\n --secondary-padding-top: 0;\n --secondary-padding-bottom: 0;\n --bg-color-hover: #{map.get($colors, blue--faded)};\n --bg-color-focus: #{map.get($colors, blue--faded)};\n --bg-color-selected: #{map.get($colors, blue--faded)};\n --color-hover: #{map.get($colors, blue)};\n --color-selected: #{map.get($colors, blue)};\n --color-focus: #{map.get($colors, blue)};\n --focus-outline: none;\n --font-size: 0.9em;\n\n display: block;\n}\n\n.menu {\n font-size: var(--font-size, 0.9em);\n overscroll-behavior: none;\n min-width: var(--width);\n position: relative;\n\n &:focus {\n outline: none;\n }\n}\n\n::slotted(*:not(nano-nav-item):not(nano-option):not(hr):not(slot)) {\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: var(--padding-top) var(--padding-bottom);\n display: block;\n}\n","import {\n Component,\n Event,\n EventEmitter,\n Method,\n h,\n Host,\n Element,\n Prop,\n Listen,\n} from '@stencil/core';\nimport { getActiveElement } from '../../utils/active-element';\nimport { getDirectChildren } from '../../utils/dom';\nimport { getTextContent } from '../../utils/slot';\n\ntype ValidElement = HTMLNanoNavItemElement | HTMLNanoOptionElement;\ntype NNI = HTMLNanoNavItemElement;\n\n/**\n * Menu element. Commonly wrapped by `nano-dropdown` with `nano-option` and `nano-nav-item` elements nested.\n * Manages focus state / active.\n * @slot - The menu's content; `nano-option`, `nano-nav-item` elements as well as <hr> and more.\n */\n@Component({\n tag: 'nano-menu',\n styleUrl: 'menu.scss',\n shadow: true,\n})\nexport class Menu {\n private ignoreMouseEvents = false;\n private ignoreMouseTimeout: any;\n private menu: HTMLElement;\n private typeToSelect = '';\n private typeToSelectTimeout: any;\n\n @Element() private el: HTMLNanoMenuElement;\n\n // Public API\n\n /** get the focus state of the menu @readonly */\n @Prop()\n get hasFocus() {\n return this._hasFocus;\n }\n private _hasFocus = false;\n\n /** changes the role of the underlying control - sometimes required for semantics */\n @Prop() type: 'menu' | 'listbox' = 'menu';\n\n /** an accessible label */\n @Prop() label: string;\n\n // Events\n\n /** Emitted when the menu gains focus. */\n @Event() nanoFocus: EventEmitter;\n\n /** Emitted when the menu loses focus. */\n @Event() nanoBlur: EventEmitter;\n\n /** Emitted when a menu item is selected. */\n @Event() nanoSelect: EventEmitter<\n HTMLNanoOptionElement | HTMLNanoNavItemElement\n >;\n\n // Public Methods\n\n /** Sets focus on the menu. */\n @Method()\n async setFocus() {\n if (this.menu?.focus) this.menu.focus({ preventScroll: true });\n }\n\n /** Removes focus from the menu. */\n @Method()\n async removeFocus() {\n if (this.menu?.blur) this.menu.blur();\n }\n\n /** Sets the current active item */\n @Method()\n async showActiveElement() {\n if (this.selectedItem)\n this.selectedItem.scrollIntoView({ block: 'nearest' });\n }\n\n /** Removes any active item's state */\n @Method()\n async resetActiveItem() {\n this.getItems\n .filter((i) => i.tagName.toLowerCase() === 'nano-option')\n .map((i) => i.setAttribute('tabindex', '-1'));\n }\n\n // Private methods\n\n get getItems() {\n let items: ValidElement[];\n const opened = this.el.querySelectorAll('nano-nav-item.secondary-open');\n if (opened.length) {\n const ctx = opened[opened.length - 1] as HTMLNanoNavItemElement;\n items = Array.from(ctx.querySelectorAll('nano-nav-item, nano-option'));\n } else {\n items = getDirectChildren(\n this.el,\n 'nano-nav-item, nano-option',\n 'slot'\n ) as ValidElement[];\n }\n return items.filter((el) => !el.disabled && !el.hidden);\n }\n\n get activeItem() {\n const activeElement = getActiveElement();\n return this.getItems.find(\n (i) =>\n i.getAttribute('tabindex') === '0' ||\n i === activeElement ||\n i.classList.contains('has-focus')\n );\n }\n\n get selectedItem() {\n return this.getItems.find((i) => i.selected);\n }\n\n private async setActiveFocusItem(item?: ValidElement, focus = true) {\n const items = this.getItems;\n const activeItem =\n !item || item.disabled ? items.find((i) => i.selected) || items[0] : item;\n\n items\n .filter((i) => i.tagName.toLowerCase() === 'nano-option')\n .map((i: HTMLNanoOptionElement) =>\n i.setAttribute('tabindex', i === activeItem ? '0' : '-1')\n );\n\n if (!focus) return;\n\n if (activeItem) {\n (activeItem as NNI).setFocus\n ? (activeItem as NNI).setFocus()\n : activeItem.focus();\n } else this.menu.focus();\n }\n\n // Event Handlers\n\n @Listen('mousedown', { target: 'body' })\n @Listen('keydown')\n handleBlur(e: KeyboardEvent | MouseEvent) {\n if (!this.hasFocus) return;\n\n const kev = e as KeyboardEvent;\n let found: boolean;\n\n if (kev.key) {\n if (kev.key !== 'Tab') return;\n found =\n getActiveElement() &&\n getActiveElement().closest(this.el.tagName.toLowerCase()) === this.el;\n } else found = !!e.composedPath().find((el) => el === this.el);\n\n if (!found) {\n this.resetActiveItem();\n this._hasFocus = false;\n this.nanoBlur.emit();\n }\n }\n\n private handleFocus = () => {\n this.setActiveFocusItem(this.selectedItem || this.getItems[0]);\n\n this._hasFocus = true;\n this.nanoFocus.emit();\n };\n\n private handleClick = (event: MouseEvent) => {\n const target = event.target as HTMLElement;\n const item = target.closest('nano-nav-item');\n\n if (item && !item.disabled) {\n this.nanoSelect.emit(item);\n }\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n // When keying through the menu, if the mouse happens to be hovering over a menu item and the menu scrolls, the\n // mouseout/mouseover event will fire causing the selection to be different than what the user expects. This gives\n // us a way to temporarily ignore mouse events while the user is interacting with a keyboard.\n clearTimeout(this.ignoreMouseTimeout);\n this.ignoreMouseTimeout = setTimeout(\n () => (this.ignoreMouseEvents = false),\n 500\n );\n this.ignoreMouseEvents = true;\n\n // Make a selection when pressing enter\n switch (event.key) {\n case ' ':\n if (this.activeItem) this.activeItem.click();\n break;\n case 'ArrowDown':\n case 'ArrowUp':\n case 'PageDown':\n case 'PageUp':\n case 'Home':\n case 'End':\n const items = this.getItems;\n const selectedItem = this.activeItem;\n let index = items.indexOf(selectedItem);\n\n if (items.length) {\n event.preventDefault();\n\n if (event.key === 'ArrowDown') {\n index++;\n } else if (event.key === 'ArrowUp') {\n index--;\n } else if (event.key === 'Home' || event.key === 'PageUp') {\n index = 0;\n } else if (event.key === 'End' || event.key === 'PageDown') {\n index = items.length - 1;\n }\n\n if (index < 0) index = items.length - 1;\n if (index > items.length - 1) index = 0;\n\n this.setActiveFocusItem(items[index]);\n if (items[index]) items[index].scrollIntoView({ block: 'nearest' });\n return;\n }\n break;\n }\n\n // Handle type-to-search behavior when non-control characters are entered\n if (event.key === ' ' || /^[a-z0-9]+$/i.test(event.key)) {\n clearTimeout(this.typeToSelectTimeout);\n this.typeToSelectTimeout = setTimeout(\n () => (this.typeToSelect = ''),\n 750\n );\n this.typeToSelect += event.key;\n\n const items = this.getItems;\n for (const item of items) {\n const slot = item.shadowRoot.querySelector(\n 'slot:not([name])'\n ) as HTMLSlotElement;\n const label = getTextContent(slot).toLowerCase().trim();\n if (\n label.substring(0, this.typeToSelect.length) === this.typeToSelect\n ) {\n this.setActiveFocusItem(item);\n break;\n }\n }\n }\n };\n\n private handleMouseOver = (event: MouseEvent) => {\n const target = event.target as HTMLElement;\n const item =\n target.closest('nano-nav-item') || target.closest('nano-option');\n\n if (item && !this.ignoreMouseEvents) {\n this.setActiveFocusItem(item);\n }\n };\n\n // Component Lifecycle\n\n render() {\n return (\n <Host>\n <div\n onClick={this.handleClick}\n onKeyDown={this.handleKeyDown}\n onMouseOver={this.handleMouseOver}\n onFocus={this.handleFocus}\n aria-label={this.label ? this.label : undefined}\n role={this.type}\n ref={(el) => (this.menu = el)}\n part=\"base\"\n class={{\n menu: true,\n ['menu--' + this.type]: true,\n 'menu--has-focus': this.hasFocus,\n }}\n tabIndex={-1}\n >\n <slot />\n </div>\n </Host>\n );\n }\n}\n","@use 'sass:map';\n@use 'sass:list';\n\n@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/form';\n@import '../../global/style/nano-theme/base';\n@import '../../global/style/nano-theme/layers';\n\n:host {\n /**\n * @prop --padding-top: Defaults to #{$spacing-small};\n * @prop --padding-bottom: Defaults to #{$spacing-small};\n * @prop --padding-start: Defaults to #{$spacing-small};\n * @prop --padding-end: Defaults to #{$spacing-small};\n\n * @prop --bg: default background. Defaults to none;\n * @prop --bg-selected: background when selected. Defaults to #{$select-opt-selected};\n * @prop --bg-focus: background when focused. Defaults to var(--nano-color-base, #{nano-color(primary, tint)});\n * @prop --bg-disabled: background when disabled. Defaults to none;\n\n * @prop --color: default text color. Defaults to var(--input-text-color, #{$input-text-color});\n * @prop --color-selected: text color when selected. Defaults to var(--nano-color-base, #{nano-color(primary, base)});\n * @prop --color-focus: text color when focused. Defaults to var(--nano-color-base, #{nano-color(primary, contrast)});\n * @prop --color-disabled: text color when disabled. Defaults to #{map.get($colors, palegrey)};\n\n * @prop --opt-icon-size: Sizes all icons within the option. Defaults to 1.4em;\n */\n\n --bg: none;\n --bg-selected: #{$select-opt-selected};\n --bg-focus: var(--nano-color-base, #{nano-color(primary, tint)});\n --bg-disabled: none;\n --color: var(--input-text-color, #{$input-text-color});\n --color-selected: var(--nano-color-base, #{nano-color(primary, base)});\n --color-focus: var(--nano-color-contrast, #{nano-color(primary, contrast)});\n --color-disabled: #{map.get($colors, palegrey)};\n --opt-icon-size: 1.6em;\n\n display: block;\n color: var(--color);\n overflow: hidden;\n font-size: 14px;\n font-size: #{'clamp(12px, .9em, 16px)'};\n}\n\n:host(:focus) {\n outline: none;\n}\n\n.option {\n $self: &;\n\n position: relative;\n user-select: none;\n cursor: pointer;\n display: flex;\n align-items: stretch;\n width: 100%;\n background: var(--bg);\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: var(--padding-top) var(--padding-bottom);\n\n // focus\n :host(:focus) &:not(.option--disabled),\n :host &.option--selected {\n outline: none;\n background: var(--bg-selected);\n color: var(--color-selected);\n }\n\n :host(:focus) &:not(.option--disabled) {\n background: var(--bg-focus);\n color: var(--color-focus);\n }\n\n // disabled\n &.option--disabled {\n outline: none;\n color: var(--color-disabled);\n cursor: not-allowed;\n background: var(--bg-disabled);\n }\n\n // no value\n &.option--novalue {\n font-style: italic;\n opacity: 0.7;\n }\n\n &__label {\n flex: 1 1 auto;\n display: flex;\n align-items: center;\n }\n\n &__start {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n\n ::slotted(nano-icon) {\n font-size: var(--opt-icon-size);\n }\n\n ::slotted(:last-child) {\n margin-inline-end: 0.5em;\n }\n }\n\n &__end {\n flex: 0 0 auto;\n display: flex;\n align-items: center;\n\n ::slotted(nano-icon) {\n font-size: var(--opt-icon-size);\n }\n\n ::slotted(:first-child) {\n margin-inline-start: 0.5em;\n }\n }\n\n &__check {\n visibility: hidden;\n display: flex;\n position: absolute;\n inset-inline-start: 0.6em;\n inset-block-start: calc(50% - 0.6em);\n align-items: center;\n font-size: 0.9em;\n\n #{$self}--selected:not(#{$self}--novalue) & {\n visibility: visible;\n }\n }\n}\n","import {\n Component,\n Prop,\n h,\n Host,\n State,\n Watch,\n Element,\n Listen,\n Event,\n EventEmitter,\n} from '@stencil/core';\nimport { getDirectChildren } from '../../utils/dom';\nimport { debounce } from '../../utils/throttle';\nimport type { OptionInterface } from '../../interface';\n\nlet optIds = 0;\n\n/**\n * Select options to be used with [nano-select](/story/nano-components-select) or [nano-datalist](/story/nano-components-select)\n *\n * @slot - main label. Defaults to `label` or `value` prop\n * @slot checked-icon - icon to indicated checked / selected state. Defaults to fontawesome light/check\n * @slot start - suitable for an icon or content displayed at the start of the main label\n * @slot end - suitable for an icon or content displayed at the end of the main label\n */\n@Component({\n tag: 'nano-option',\n styleUrl: 'option.scss',\n shadow: true,\n})\nexport class Option implements OptionInterface {\n private optId = `nano-option-${optIds++}`;\n @Element() host: HTMLNanoOptionElement;\n @State() hasFocus = false;\n\n constructor() {\n this.handleClick = debounce(this.handleClick.bind(this), 5);\n }\n\n // Public API\n\n /**\n * Value of the option\n */\n @Prop({ mutable: true, reflect: true }) value: string = '';\n\n @Watch('value')\n valueChanged() {\n if (!this.value || !this.value.length) this.value = this.labelContent;\n }\n\n /**\n * Label of the option\n */\n @Prop({ mutable: true, reflect: true }) label: string = '';\n\n @Watch('label')\n labelChanged() {\n if (!this.label || !this.label.length)\n this.label = this.labelContent.length ? this.labelContent : this.value;\n }\n\n /**\n * Whether this option is selected\n */\n @Prop({ reflect: true }) selected: boolean = false;\n\n /**\n * Whether this option should be disabled\n */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /** You can add extra meta for this option. When displayed in a list, users\n * search / filter via extra related terms. Another usecase is 'endonyms'\n */\n @Prop() filterMeta: string = '';\n\n /** Fired when an option is selected */\n @Event() nanoSelect!: EventEmitter<HTMLNanoOptionElement>;\n\n // Event handlers\n\n // stop scrolling on select\n @Listen('keydown')\n handleKeyDown(e: KeyboardEvent) {\n if (e.key !== ' ' && e.key !== 'Enter') return;\n e.preventDefault();\n this.nanoSelect.emit(this.host);\n }\n\n private handleClick() {\n if (this.disabled) return;\n this.nanoSelect.emit(this.host);\n }\n\n // Private logic\n\n private get labelContent() {\n return getDirectChildren(this.host, '*:not([slot])', false)\n .map((el) => el.textContent)\n .join(' ')\n .trim();\n }\n\n // Component lifecycle\n\n componentWillLoad() {\n this.valueChanged();\n this.labelChanged();\n }\n\n render() {\n return (\n <Host\n role=\"option\"\n aria-selected={this.selected ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n >\n <div\n onMouseDown={this.handleClick}\n id={this.optId}\n class={{\n option: true,\n 'option--selected': this.selected,\n 'option--disabled': this.disabled,\n 'option--novalue': !this.value,\n }}\n >\n <div part=\"check-icon\" class=\"option__check\">\n <slot name=\"check-icon\">\n <nano-icon name=\"light/check\" aria-hidden=\"true\" />\n </slot>\n </div>\n <div part=\"start\" class=\"option__start\">\n <slot name=\"start\"></slot>\n </div>\n <div part=\"label\" class=\"option__label\">\n <slot>{this.label || this.value}</slot>\n </div>\n <div part=\"end\" class=\"option__end\">\n <slot name=\"end\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /*!
2
2
  * Web Components for Nanopore digital Web Apps
3
3
  */
4
- export{T as nano_table}from"./p-4c386a43.js";import"./p-1fe12320.js";import"./p-ee045579.js";import"./p-9746b0a5.js";import"./p-651b3264.js";
5
- //# sourceMappingURL=p-39124baa.entry.js.map
4
+ export{T as nano_table}from"./p-11d3a90b.js";import"./p-1fe12320.js";import"./p-ee045579.js";import"./p-9746b0a5.js";import"./p-651b3264.js";
5
+ //# sourceMappingURL=p-d9d2807a.entry.js.map
@@ -1,5 +1,5 @@
1
1
  /*!
2
2
  * Web Components for Nanopore digital Web Apps
3
3
  */
4
- import{r as t,h as o}from"./p-1fe12320.js";const e=":host{box-sizing:border-box}*,*::before,*::after{box-sizing:border-box}[hidden]{display:none !important}:host{display:block}.aspect-ratio{position:relative}.aspect-ratio ::slotted(*){position:absolute !important;inset-block-start:0 !important;inset-inline-start:0 !important;inline-size:100% !important;block-size:100% !important}.aspect-ratio--cover ::slotted(embed),.aspect-ratio--cover ::slotted(iframe),.aspect-ratio--cover ::slotted(img),.aspect-ratio--cover ::slotted(video){-o-object-fit:cover !important;object-fit:cover !important}.aspect-ratio--contain ::slotted(embed),.aspect-ratio--contain ::slotted(iframe),.aspect-ratio--contain ::slotted(img),.aspect-ratio--contain ::slotted(video){-o-object-fit:contain !important;object-fit:contain !important}";const i=class{constructor(o){t(this,o);this.handleSlotChange=()=>{this.setAspectRatio()};this.aspectRatio="16:9";this.fit="cover"}handleAspectRatioChange(){this.setAspectRatio()}setAspectRatio(){if(typeof this.aspectRatio!=="string"){console.warn("aspectRatio should be a string.");return}else if(!this.aspectRatio.match(/^([0-9]+:[0-9]+)$/)){console.warn('aspectRatio is an incorrect format. Should be e.g. "16:9"');return}const t=this.aspectRatio.split(":");const o=parseInt(t[0]);const e=parseInt(t[1]);this.base.style.paddingBottom=o&&e?`${e/o*100}%`:null}render(){return o("div",{ref:t=>this.base=t,part:"base",class:{"aspect-ratio":true,"aspect-ratio--cover":this.fit==="cover","aspect-ratio--contain":this.fit==="contain"}},o("slot",{onSlotchange:this.handleSlotChange}))}static get watchers(){return{aspectRatio:["handleAspectRatioChange"]}}};i.style=e;export{i as nano_aspect_ratio};
5
- //# sourceMappingURL=p-916e4b6b.entry.js.map
4
+ import{r as t,h as o}from"./p-1fe12320.js";const e=":host{box-sizing:border-box}*,*::before,*::after{box-sizing:border-box}[hidden]{display:none !important}:host{display:block}.aspect-ratio{position:relative}.aspect-ratio ::slotted(*){position:absolute !important;inset-block-start:0 !important;inset-inline-start:0 !important;inline-size:100% !important;block-size:100% !important}.aspect-ratio--cover ::slotted(embed),.aspect-ratio--cover ::slotted(iframe),.aspect-ratio--cover ::slotted(img),.aspect-ratio--cover ::slotted(video){object-fit:cover !important}.aspect-ratio--contain ::slotted(embed),.aspect-ratio--contain ::slotted(iframe),.aspect-ratio--contain ::slotted(img),.aspect-ratio--contain ::slotted(video){object-fit:contain !important}";const i=class{constructor(o){t(this,o);this.handleSlotChange=()=>{this.setAspectRatio()};this.aspectRatio="16:9";this.fit="cover"}handleAspectRatioChange(){this.setAspectRatio()}setAspectRatio(){if(typeof this.aspectRatio!=="string"){console.warn("aspectRatio should be a string.");return}else if(!this.aspectRatio.match(/^([0-9]+:[0-9]+)$/)){console.warn('aspectRatio is an incorrect format. Should be e.g. "16:9"');return}const t=this.aspectRatio.split(":");const o=parseInt(t[0]);const e=parseInt(t[1]);this.base.style.paddingBottom=o&&e?`${e/o*100}%`:null}render(){return o("div",{ref:t=>this.base=t,part:"base",class:{"aspect-ratio":true,"aspect-ratio--cover":this.fit==="cover","aspect-ratio--contain":this.fit==="contain"}},o("slot",{onSlotchange:this.handleSlotChange}))}static get watchers(){return{aspectRatio:["handleAspectRatioChange"]}}};i.style=e;export{i as nano_aspect_ratio};
5
+ //# sourceMappingURL=p-dba8a88d.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["src/components/aspect-ratio/aspect-ratio.scss?tag=nano-aspect-ratio&encapsulation=shadow","src/components/aspect-ratio/aspect-ratio.tsx"],"names":["aspectRatioCss","AspectRatio","this","handleSlotChange","setAspectRatio","[object Object]","aspectRatio","console","warn","match","split","x","parseInt","y","base","style","paddingBottom","h","ref","el","part","class","aspect-ratio","aspect-ratio--cover","fit","aspect-ratio--contain","onSlotchange"],"mappings":";;;2CAAA,MAAMA,EAAiB,mwBCaVC,EAAW,+BAedC,KAAAC,iBAAmB,KACzBD,KAAKE,mCAXe,gBAGa,QAGnCC,0BACEH,KAAKE,iBAOCC,iBACN,UAAWH,KAAKI,cAAgB,SAAU,CACxCC,QAAQC,KAAK,mCACb,YACK,IAAKN,KAAKI,YAAYG,MAAM,qBAAsB,CACvDF,QAAQC,KAAK,6DACb,OAEF,MAAME,EAAQR,KAAKI,YAAYI,MAAM,KACrC,MAAMC,EAAIC,SAASF,EAAM,IACzB,MAAMG,EAAID,SAASF,EAAM,IACzBR,KAAKY,KAAKC,MAAMC,cAAgBL,GAAKE,EAAI,GAAIA,EAAIF,EAAK,OAAS,KAGjEN,SACE,OACEY,EAAA,MAAA,CACEC,IAAMC,GAAQjB,KAAKY,KAAOK,EAC1BC,KAAK,OACLC,MAAO,CACLC,eAAgB,KAChBC,sBAAuBrB,KAAKsB,MAAQ,QACpCC,wBAAyBvB,KAAKsB,MAAQ,YAGxCP,EAAA,OAAA,CAAMS,aAAcxB,KAAKC","sourcesContent":[":host {\n display: block;\n}\n\n.aspect-ratio {\n position: relative;\n\n ::slotted(*) {\n position: absolute !important;\n inset-block-start: 0 !important;\n inset-inline-start: 0 !important;\n inline-size: 100% !important;\n block-size: 100% !important;\n }\n\n &--cover {\n ::slotted(embed),\n ::slotted(iframe),\n ::slotted(img),\n ::slotted(video) {\n object-fit: cover !important;\n }\n }\n\n &--contain {\n ::slotted(embed),\n ::slotted(iframe),\n ::slotted(img),\n ::slotted(video) {\n object-fit: contain !important;\n }\n }\n}\n","import { Component, Prop, Watch, h, ComponentInterface } from '@stencil/core';\n\n/**\n * Displays media in the desired aspect ratio.\n * You can slot in any replaced element, including `<iframe>`, `<img>`, and `<video>`.\n * As the element's width changes, its height will resize proportionally. Only one element should be slotted into the container.\n * The default aspect ratio is 16:9.\n */\n@Component({\n tag: 'nano-aspect-ratio',\n styleUrl: 'aspect-ratio.scss',\n shadow: true,\n})\nexport class AspectRatio implements ComponentInterface {\n private base: HTMLElement;\n\n /** The aspect ratio of the embedded media in the format of `width:height`, e.g. `16:9`, `4:3`, or `1:1`.\n * Ratios not in this format will be ignored. */\n @Prop() aspectRatio = '16:9';\n\n /** Determines how content will be resized to fit its container. */\n @Prop() fit: 'cover' | 'contain' = 'cover';\n\n @Watch('aspectRatio')\n handleAspectRatioChange() {\n this.setAspectRatio();\n }\n\n private handleSlotChange = () => {\n this.setAspectRatio();\n };\n\n private setAspectRatio() {\n if (typeof this.aspectRatio !== 'string') {\n console.warn('aspectRatio should be a string.');\n return;\n } else if (!this.aspectRatio.match(/^([0-9]+:[0-9]+)$/)) {\n console.warn('aspectRatio is an incorrect format. Should be e.g. \"16:9\"');\n return;\n }\n const split = this.aspectRatio.split(':');\n const x = parseInt(split[0]);\n const y = parseInt(split[1]);\n this.base.style.paddingBottom = x && y ? `${(y / x) * 100}%` : null;\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.base = el)}\n part=\"base\"\n class={{\n 'aspect-ratio': true,\n 'aspect-ratio--cover': this.fit === 'cover',\n 'aspect-ratio--contain': this.fit === 'contain',\n }}\n >\n <slot onSlotchange={this.handleSlotChange} />\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["src/components/aspect-ratio/aspect-ratio.scss?tag=nano-aspect-ratio&encapsulation=shadow","src/components/aspect-ratio/aspect-ratio.tsx"],"names":["aspectRatioCss","AspectRatio","this","handleSlotChange","setAspectRatio","[object Object]","aspectRatio","console","warn","match","split","x","parseInt","y","base","style","paddingBottom","h","ref","el","part","class","aspect-ratio","aspect-ratio--cover","fit","aspect-ratio--contain","onSlotchange"],"mappings":";;;2CAAA,MAAMA,EAAiB,msBCaVC,EAAW,+BAedC,KAAAC,iBAAmB,KACzBD,KAAKE,mCAXe,gBAGa,QAGnCC,0BACEH,KAAKE,iBAOCC,iBACN,UAAWH,KAAKI,cAAgB,SAAU,CACxCC,QAAQC,KAAK,mCACb,YACK,IAAKN,KAAKI,YAAYG,MAAM,qBAAsB,CACvDF,QAAQC,KAAK,6DACb,OAEF,MAAME,EAAQR,KAAKI,YAAYI,MAAM,KACrC,MAAMC,EAAIC,SAASF,EAAM,IACzB,MAAMG,EAAID,SAASF,EAAM,IACzBR,KAAKY,KAAKC,MAAMC,cAAgBL,GAAKE,EAAI,GAAIA,EAAIF,EAAK,OAAS,KAGjEN,SACE,OACEY,EAAA,MAAA,CACEC,IAAMC,GAAQjB,KAAKY,KAAOK,EAC1BC,KAAK,OACLC,MAAO,CACLC,eAAgB,KAChBC,sBAAuBrB,KAAKsB,MAAQ,QACpCC,wBAAyBvB,KAAKsB,MAAQ,YAGxCP,EAAA,OAAA,CAAMS,aAAcxB,KAAKC","sourcesContent":[":host {\n display: block;\n}\n\n.aspect-ratio {\n position: relative;\n\n ::slotted(*) {\n position: absolute !important;\n inset-block-start: 0 !important;\n inset-inline-start: 0 !important;\n inline-size: 100% !important;\n block-size: 100% !important;\n }\n\n &--cover {\n ::slotted(embed),\n ::slotted(iframe),\n ::slotted(img),\n ::slotted(video) {\n object-fit: cover !important;\n }\n }\n\n &--contain {\n ::slotted(embed),\n ::slotted(iframe),\n ::slotted(img),\n ::slotted(video) {\n object-fit: contain !important;\n }\n }\n}\n","import { Component, Prop, Watch, h, ComponentInterface } from '@stencil/core';\n\n/**\n * Displays media in the desired aspect ratio.\n * You can slot in any replaced element, including `<iframe>`, `<img>`, and `<video>`.\n * As the element's width changes, its height will resize proportionally. Only one element should be slotted into the container.\n * The default aspect ratio is 16:9.\n */\n@Component({\n tag: 'nano-aspect-ratio',\n styleUrl: 'aspect-ratio.scss',\n shadow: true,\n})\nexport class AspectRatio implements ComponentInterface {\n private base: HTMLElement;\n\n /** The aspect ratio of the embedded media in the format of `width:height`, e.g. `16:9`, `4:3`, or `1:1`.\n * Ratios not in this format will be ignored. */\n @Prop() aspectRatio = '16:9';\n\n /** Determines how content will be resized to fit its container. */\n @Prop() fit: 'cover' | 'contain' = 'cover';\n\n @Watch('aspectRatio')\n handleAspectRatioChange() {\n this.setAspectRatio();\n }\n\n private handleSlotChange = () => {\n this.setAspectRatio();\n };\n\n private setAspectRatio() {\n if (typeof this.aspectRatio !== 'string') {\n console.warn('aspectRatio should be a string.');\n return;\n } else if (!this.aspectRatio.match(/^([0-9]+:[0-9]+)$/)) {\n console.warn('aspectRatio is an incorrect format. Should be e.g. \"16:9\"');\n return;\n }\n const split = this.aspectRatio.split(':');\n const x = parseInt(split[0]);\n const y = parseInt(split[1]);\n this.base.style.paddingBottom = x && y ? `${(y / x) * 100}%` : null;\n }\n\n render() {\n return (\n <div\n ref={(el) => (this.base = el)}\n part=\"base\"\n class={{\n 'aspect-ratio': true,\n 'aspect-ratio--cover': this.fit === 'cover',\n 'aspect-ratio--contain': this.fit === 'contain',\n }}\n >\n <slot onSlotchange={this.handleSlotChange} />\n </div>\n );\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ /*!
2
+ * Web Components for Nanopore digital Web Apps
3
+ */
4
+ import{r as i,h as o,a as t,g as e}from"./p-1fe12320.js";const r=":host{box-sizing:border-box}*,*::before,*::after{box-sizing:border-box}[hidden]{display:none !important}:host{display:block;--nano-loader-base:#4a4a4a;--nano-loader-tint:#7d7d7d;--theme-color:#fff;--theme-tint-color:#90c6e7;--scrim-color:0, 0, 0;--scrim-direction:90deg;--scrim-opacity-from:0.25;--scrim-opacity-to:0.7;--padding:0;--quote-size:1.3rem;color:var(--theme-color)}:host(.is-xl){--quote-size:3rem}:host([theme=light]){--nano-loader-base:#fff;--nano-loader-tint:white;--theme-color:#4a4a4a;--scrim-color:255, 255, 255;--scrim-opacity-from:0.25;--scrim-opacity-to:1;--scrim-direction:270deg;color:var(--theme-color)}:host([theme=light]) .hero__primary-content{--color:#4a4a4a}.hero{position:relative}.hero--rtl{--scrim-direction:270deg}.hero--secondary:not(.hero--iconbox){--scrim-direction:0deg}.hero__bg-wrap{overflow:hidden}.hero__bg-slot{position:absolute;inset:0}.hero__ctas{display:flex;justify-content:flex-end;padding-block:32px 0;padding-inline:32px;margin-block-end:-64px;position:relative;z-index:1}@media (max-width: 52em){.hero__ctas{display:none}}@media (max-width: 58em){.hero__ctas{margin-block-end:-48px}}.hero__ctas ::slotted(a.button[slot=secondary-ctas]){padding-block:0.25rem !important;padding-inline:0.5rem !important;font-size:0.875rem !important;margin-block:0 !important;margin-inline:0.25rem !important}.hero__img{display:block;--padding:inherit}.hero__breadcrumbs{display:none;margin-block:20px 0;margin-inline:14px;line-height:14px}.hero--breadcrumb .hero__breadcrumbs{display:block}.is-xl .hero__breadcrumbs{margin-block:0;margin-inline:50px;max-inline-size:50%}.is-xxl .hero__breadcrumbs{margin-block:0;margin-inline:83px}.hero__breadcrumbs ::slotted(*[slot=breadcrumb]){font-size:0.85rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:600;font-stretch:125%;display:inline-block;margin-block-end:16px;position:relative;z-index:2}.hero--hasbg .hero__breadcrumbs ::slotted(*[slot=breadcrumb]){text-shadow:1px 1px rgba(0, 0, 0, 0.15)}.hero__breadcrumbs ::slotted(a[slot=breadcrumb]){color:var(--theme-tint-color) !important;cursor:pointer}.hero__breadcrumbs ::slotted(.slash[slot=breadcrumb]){color:var(--theme-color);position:relative;margin-block:0;margin-inline:0.5rem;display:inline-block}.hero__scrim{position:absolute;inset:0;z-index:0;background:linear-gradient(var(--scrim-direction), rgba(var(--scrim-color), var(--scrim-opacity-from)) 0%, rgba(var(--scrim-color), var(--scrim-opacity-to)) 100%)}.hero--scrim .hero__scrim{background:none}.hero__content{max-inline-size:1440px;--grid-row-gap:0;margin-block:0;margin-inline:auto;position:relative}.hero__content.is-xl{margin-block-start:50px;max-inline-size:1540px}.hero__content.is-xxl{margin-block-start:83px;max-inline-size:1606px}.hero__primary{margin:16px}.hero--breadcrumb .hero__primary{margin-block:0;margin-inline:16px}.hero--backbtn .hero__primary{margin-inline-start:0}.hero__primary ::slotted(nano-icon-button[slot=back-btn]){font-size:2rem}.is-xl .hero__primary{margin-block:0 50px;margin-inline:50px 0}.is-xl .hero__primary ::slotted(nano-icon-button[slot=back-btn]){margin-block:0;margin-inline:-3rem 0}.is-xxl .hero__primary{margin-block:0 83px;margin-inline:83px 0}.hero__primary-content{max-inline-size:45rem;--color:#fff;display:flex}.hero--backbtn .hero__primary-content>div{padding-block:10px 0;padding-inline:0}.hero__primary-content ::slotted(h1[slot=primary-content]){line-height:26px !important;margin-block:0 18px !important;font-size:2rem !important}.is-xl .hero__primary-content ::slotted(h1[slot=primary-content]){line-height:31px !important;margin-block-end:30px !important}.is-xl .hero__primary-content ::slotted(.button[slot=primary-content]){margin-block-start:20px !important}.hero__secondary{display:none;block-size:100%;padding-block:0 20px;padding-inline:14px}.hero--secondary .hero__secondary{display:flex;align-items:center}.is-xl .hero__secondary{padding-block:0 50px;padding-inline:50px;justify-content:flex-end}.is-xxl .hero__secondary{padding-block:0 83px;padding-inline:83px}.hero__icon-box{background:rgba(0, 0, 0, 0.7);padding:24px;inline-size:100%;margin-block-end:auto;display:flex;flex-direction:column;color:white}.is-xl .hero__icon-box{max-inline-size:410px;flex:0 1 410px}.hero__icon-box ::slotted([slot=icon-box-item]){--nano-color-base:var(--theme-tint-color);--nano-icon-size:32px;--nano-icon-margin-end:20px;display:flex;align-items:center;font-size:0.8125rem;margin-block-end:20px}.hero__icon-box ::slotted(.last[slot=icon-box-item]){margin-block-end:0}.hero__quote-content{margin-block-start:auto;text-align:center;inline-size:100%}.is-xl .hero__quote-content{max-inline-size:500px;flex:0 1 500px;text-align:initial}.hero__quote::before,.hero__quote::after{content:'\"';font-size:var(--quote-size);font-weight:700;font-style:italic;line-height:0;color:#abb6b8;display:inline;position:relative}.hero__quote ::slotted([slot=quote]){font-size:var(--quote-size);font-weight:300;font-style:italic;display:inline}.hero__quote-author{text-align:end;font-size:1rem;opacity:0.8}.hero--sub .hero__content.is-xl{margin-block-start:40px}.hero--sub .hero__content.is-xl .hero__primary{margin-block:0 40px;margin-inline:50px 0}.hero--sub .hero__content.is-xl .hero__secondary{padding-block:0 50px;padding-inline:40px 50px}.hero--sub .hero__content.is-xl ::slotted(.button[slot=primary-content]){margin-block-start:8px !important}.hero--sub .hero__content.is-xl ::slotted(h1[slot=primary-content]){margin-block-end:18px !important}.hero--sub .hero__content.is-xxl .hero__primary{margin-block:0 40px;margin-inline:83px 0}.hero--sub .hero__content.is-xxl .hero__secondary{padding-block:0 83px;padding-inline:40px 83px}";const n=class{constructor(t){i(this,t);this.handleGridChange=i=>{this.gridSizes=i.detail};this.HeroContent=()=>[!this.hasIconBox&&this.hasCtas?o("div",{class:"hero__ctas"},o("slot",{name:"secondary-ctas"})):"",o("div",{class:"hero__scrim"},o("slot",{name:"scrim"})),o("nano-grid",{onNanoBpChange:this.handleGridChange,class:"hero__content",xlCols:2,xlSize:this.largeScreenBP},o("nano-grid-item",{gridStates:"xl-col-span-2"},o("div",{class:"hero__breadcrumbs"},o("slot",{name:"breadcrumb"}))),o("nano-grid-item",{gridStates:this.hasSecondaryContent?"xl-col-span-1 xl-col-start-1 xl-row-start-2":"xl-col-span-2 xl-col-start-1 xl-row-start-2"},o("div",{class:"hero__primary"},o("div",{class:"hero__primary-content"},o("slot",{name:"back-btn"}),o("div",null,o("slot",{name:"primary-content"}))))),this.hasSecondaryContent&&o("nano-grid-item",{gridStates:"xl-col-span-1 xl-col-start-2 xl-row-start-2"},o("div",{class:"hero__secondary"},o("slot",{name:"secondary-content"}),this.hasIconBox&&o("div",{class:"hero__icon-box"},o("slot",{name:"icon-box"}),o("slot",{name:"icon-box-item"})),this.hasQuote&&o("div",{class:"hero__quote-content"},o("span",{class:"hero__quote"},o("slot",{name:"quote"})),o("div",{class:"hero__quote-author"},o("slot",{name:"quote-author"}))))))];this.gridSizes=[];this.hasIconBox=undefined;this.hasScrim=undefined;this.hasSecondaryContent=undefined;this.hasQuote=undefined;this.hasBg=undefined;this.hasBackBtn=undefined;this.hasCtas=undefined;this.breadCrumbs=undefined;this.iconBoxItems=undefined;this.imgSrc=undefined;this.imgSrcSet=null;this.largeScreenBP=900;this.theme="dark";this.level="top"}breadCrumbChange(){this.breadCrumbs.filter((i=>i.tagName==="A"&&!i.nextElementSibling.classList.contains("slash"))).forEach((i=>{i.insertAdjacentHTML("afterend",'<span slot="breadcrumb" class="slash">/</span>')}))}iconBoxItemChange(){this.iconBoxItems.forEach((i=>i.classList.remove("last")));if(this.iconBoxItems[this.iconBoxItems.length-1]&&this.iconBoxItems[this.iconBoxItems.length-1].classList)this.iconBoxItems[this.iconBoxItems.length-1].classList.add("last")}slotChangeObserver(){if(this.mo)this.mo.disconnect();const i=this.mo=new MutationObserver((()=>this.processSlottedContent()));i.observe(this.host,{childList:true})}processSlottedContent(){this.hasCtas=!!this.host.querySelector('[slot="secondary-ctas"]');this.iconBoxItems=Array.from(this.host.querySelectorAll('[slot="icon-box-item"]'));this.hasIconBox=!!this.host.querySelector('[slot="icon-box"]')||!!this.iconBoxItems.length;this.hasScrim=!!this.host.querySelector('[slot="scrim"]');this.breadCrumbs=Array.from(this.host.querySelectorAll('[slot="breadcrumb"]'));this.hasSecondaryContent=!!this.host.querySelector('[slot="icon-box"]')||!!this.host.querySelector('[slot="quote"]')||!!this.host.querySelector('[slot="icon-box-item"]')||!!this.host.querySelector('[slot="secondary-content"]');this.hasBg=!!this.host.querySelector('[slot="background"]')||!!this.imgSrc;this.hasBackBtn=!!this.host.querySelector('[slot="back-btn"]');this.hasQuote=!!this.host.querySelector('[slot="quote"]')}disconnectedCallback(){if(this.mo)this.mo.disconnect()}componentDidLoad(){this.slotChangeObserver()}componentWillLoad(){this.processSlottedContent()}render(){const i=this.host.dir==="rtl"||this.host.ownerDocument.dir==="rtl";return o(t,{class:{[this.gridSizes.join(" ")]:true}},o("div",{class:{hero:true,"hero--light":this.theme==="light","hero--secondary":this.hasSecondaryContent,"hero--iconbox":this.hasIconBox,"hero--rtl":i,"hero--scrim":this.hasScrim,"hero--breadcrumb":!!this.breadCrumbs.length,"hero--hasbg":this.hasBg,"hero--backbtn":this.hasBackBtn,"hero--sub":this.level==="sub"}},o("div",{class:"hero__bg-wrap"},!!this.imgSrc&&o("nano-img",{class:"hero__img",lazy:false,background:true,srcSet:this.imgSrcSet,src:this.imgSrc},o(this.HeroContent,null)),!this.imgSrc&&[o("div",{class:"hero__bg-slot"},o("slot",{name:"background"})),o(this.HeroContent,null)])))}get host(){return e(this)}static get watchers(){return{breadCrumbs:["breadCrumbChange"],iconBoxItems:["iconBoxItemChange"]}}};n.style=r;export{n as nano_hero};
5
+ //# sourceMappingURL=p-e5408bc8.entry.js.map