@nanoporetech-digital/components 3.2.0 → 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (456) hide show
  1. package/CHANGELOG.md +21 -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 +10 -5
  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 +27 -14
  37. package/dist/cjs/nano-global-nav.cjs.entry.js.map +1 -1
  38. package/dist/cjs/nano-global-search-results.cjs.entry.js +1 -1
  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-2ddb22be.js} +23 -23
  77. package/dist/cjs/nano-table-2ddb22be.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-ec62a083.js} +2 -2
  84. package/dist/cjs/table.worker-ec62a083.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 +26 -13
  98. package/dist/collection/components/global-nav/global-nav.js.map +1 -1
  99. package/dist/collection/components/global-nav/style/global-nav.css +138 -298
  100. package/dist/collection/components/global-search-results/global-search-results.css +81 -248
  101. package/dist/collection/components/grid/grid.css +21 -76
  102. package/dist/collection/components/hero/hero.css +22 -63
  103. package/dist/collection/components/icon/icon.css +2 -5
  104. package/dist/collection/components/icon-button/icon-button.css +4 -15
  105. package/dist/collection/components/img/img.css +9 -19
  106. package/dist/collection/components/input/input.css +34 -148
  107. package/dist/collection/components/menu/menu.css +1 -2
  108. package/dist/collection/components/menu-drawer/menu-drawer.css +16 -47
  109. package/dist/collection/components/nav-item/nav-item.css +73 -147
  110. package/dist/collection/components/nav-item/nav-item.js +8 -3
  111. package/dist/collection/components/nav-item/nav-item.js.map +1 -1
  112. package/dist/collection/components/option/option.css +10 -40
  113. package/dist/collection/components/progress-bar/progress-bar.css +5 -26
  114. package/dist/collection/components/range/range.css +20 -56
  115. package/dist/collection/components/rating/rating.css +9 -28
  116. package/dist/collection/components/resize-observe/resize-observe.js +38 -12
  117. package/dist/collection/components/resize-observe/resize-observe.js.map +1 -1
  118. package/dist/collection/components/select/select.css +56 -210
  119. package/dist/collection/components/skeleton/skeleton.css +2 -17
  120. package/dist/collection/components/slides/slide.css +4 -13
  121. package/dist/collection/components/slides/slides.css +3 -14
  122. package/dist/collection/components/spinner/spinner.css +34 -122
  123. package/dist/collection/components/split-pane/split-pane.css +4 -18
  124. package/dist/collection/components/sticker/sticker.css +8 -18
  125. package/dist/collection/components/table/table.children.js +10 -10
  126. package/dist/collection/components/table/table.children.js.map +1 -1
  127. package/dist/collection/components/table/table.css +87 -41
  128. package/dist/collection/components/table/table.js +18 -17
  129. package/dist/collection/components/table/table.js.map +1 -1
  130. package/dist/collection/components/table/table.service.js +1 -1
  131. package/dist/collection/components/table/table.service.js.map +1 -1
  132. package/dist/collection/components/tabs/tab-content.css +11 -59
  133. package/dist/collection/components/tabs/tab-group.css +20 -77
  134. package/dist/collection/components/tabs/tab.css +11 -30
  135. package/dist/collection/components/tooltip/tooltip.css +26 -56
  136. package/dist/collection/utils/dom.js.map +1 -1
  137. package/dist/collection/utils/modal.js +1 -1
  138. package/dist/collection/utils/modal.js.map +1 -1
  139. package/dist/collection/utils/tabbable.js +12 -3
  140. package/dist/collection/utils/tabbable.js.map +1 -1
  141. package/dist/components/algolia.js +1 -1
  142. package/dist/components/algolia.js.map +1 -1
  143. package/dist/components/date-picker.js +1 -1
  144. package/dist/components/date-picker.js.map +1 -1
  145. package/dist/components/dom.js.map +1 -1
  146. package/dist/components/dropdown.js +1 -1
  147. package/dist/components/dropdown.js.map +1 -1
  148. package/dist/components/grid.js +1 -1
  149. package/dist/components/grid.js.map +1 -1
  150. package/dist/components/icon-button.js +1 -1
  151. package/dist/components/icon-button.js.map +1 -1
  152. package/dist/components/icon.js +1 -1
  153. package/dist/components/icon.js.map +1 -1
  154. package/dist/components/img.js +1 -1
  155. package/dist/components/img.js.map +1 -1
  156. package/dist/components/input.js +1 -1
  157. package/dist/components/input.js.map +1 -1
  158. package/dist/components/menu.js +1 -1
  159. package/dist/components/menu.js.map +1 -1
  160. package/dist/components/modal.js +1 -1
  161. package/dist/components/modal.js.map +1 -1
  162. package/dist/components/nano-alert.js +1 -1
  163. package/dist/components/nano-alert.js.map +1 -1
  164. package/dist/components/nano-aspect-ratio.js +1 -1
  165. package/dist/components/nano-aspect-ratio.js.map +1 -1
  166. package/dist/components/nano-checkbox-group.js +1 -1
  167. package/dist/components/nano-checkbox-group.js.map +1 -1
  168. package/dist/components/nano-checkbox.js +1 -1
  169. package/dist/components/nano-checkbox.js.map +1 -1
  170. package/dist/components/nano-date-input.js +1 -1
  171. package/dist/components/nano-date-input.js.map +1 -1
  172. package/dist/components/nano-details.js +1 -1
  173. package/dist/components/nano-details.js.map +1 -1
  174. package/dist/components/nano-dialog.js +1 -1
  175. package/dist/components/nano-dialog.js.map +1 -1
  176. package/dist/components/nano-drawer.js +1 -1
  177. package/dist/components/nano-drawer.js.map +1 -1
  178. package/dist/components/nano-file-upload.js +1 -1
  179. package/dist/components/nano-file-upload.js.map +1 -1
  180. package/dist/components/nano-global-nav.js +27 -14
  181. package/dist/components/nano-global-nav.js.map +1 -1
  182. package/dist/components/nano-global-search-results.js +1 -1
  183. package/dist/components/nano-global-search-results.js.map +1 -1
  184. package/dist/components/nano-hero.js +1 -1
  185. package/dist/components/nano-hero.js.map +1 -1
  186. package/dist/components/nano-menu-drawer.js +1 -1
  187. package/dist/components/nano-menu-drawer.js.map +1 -1
  188. package/dist/components/nano-range.js +1 -1
  189. package/dist/components/nano-range.js.map +1 -1
  190. package/dist/components/nano-rating.js +1 -1
  191. package/dist/components/nano-rating.js.map +1 -1
  192. package/dist/components/nano-slide.js +1 -1
  193. package/dist/components/nano-slide.js.map +1 -1
  194. package/dist/components/nano-slides.js +1 -1
  195. package/dist/components/nano-slides.js.map +1 -1
  196. package/dist/components/nano-split-pane.js +1 -1
  197. package/dist/components/nano-split-pane.js.map +1 -1
  198. package/dist/components/nano-tab-content.js +1 -1
  199. package/dist/components/nano-tab-content.js.map +1 -1
  200. package/dist/components/nano-tab-group.js +1 -1
  201. package/dist/components/nano-tab-group.js.map +1 -1
  202. package/dist/components/nano-tab.js +1 -1
  203. package/dist/components/nano-tab.js.map +1 -1
  204. package/dist/components/nano-table.js +21 -21
  205. package/dist/components/nano-table.js.map +1 -1
  206. package/dist/components/nav-item.js +9 -4
  207. package/dist/components/nav-item.js.map +1 -1
  208. package/dist/components/option.js +1 -1
  209. package/dist/components/option.js.map +1 -1
  210. package/dist/components/progress-bar.js +1 -1
  211. package/dist/components/progress-bar.js.map +1 -1
  212. package/dist/components/resize-observe.js +23 -13
  213. package/dist/components/resize-observe.js.map +1 -1
  214. package/dist/components/select.js +1 -1
  215. package/dist/components/select.js.map +1 -1
  216. package/dist/components/skeleton.js +1 -1
  217. package/dist/components/skeleton.js.map +1 -1
  218. package/dist/components/spinner.js +1 -1
  219. package/dist/components/spinner.js.map +1 -1
  220. package/dist/components/sticker.js +1 -1
  221. package/dist/components/sticker.js.map +1 -1
  222. package/dist/components/tabbable.js +12 -3
  223. package/dist/components/tabbable.js.map +1 -1
  224. package/dist/components/tooltip.js +1 -1
  225. package/dist/components/tooltip.js.map +1 -1
  226. package/dist/custom-elements/index.js +128 -91
  227. package/dist/custom-elements/index.js.map +1 -1
  228. package/dist/esm/dom-d3ad49e2.js.map +1 -1
  229. package/dist/esm/index.js +1 -1
  230. package/dist/esm/loader.js +1 -1
  231. package/dist/esm/{modal-215df46b.js → modal-5c9ce466.js} +3 -3
  232. package/dist/esm/{modal-215df46b.js.map → modal-5c9ce466.js.map} +1 -1
  233. package/dist/esm/nano-alert.entry.js +3 -3
  234. package/dist/esm/nano-alert.entry.js.map +1 -1
  235. package/dist/esm/nano-algolia.entry.js +1 -1
  236. package/dist/esm/nano-algolia.entry.js.map +1 -1
  237. package/dist/esm/nano-aspect-ratio.entry.js +1 -1
  238. package/dist/esm/nano-aspect-ratio.entry.js.map +1 -1
  239. package/dist/esm/nano-checkbox-group.entry.js +1 -1
  240. package/dist/esm/nano-checkbox-group.entry.js.map +1 -1
  241. package/dist/esm/nano-checkbox.entry.js +1 -1
  242. package/dist/esm/nano-checkbox.entry.js.map +1 -1
  243. package/dist/esm/nano-components.js +1 -1
  244. package/dist/esm/nano-datalist_3.entry.js +2 -2
  245. package/dist/esm/nano-datalist_3.entry.js.map +1 -1
  246. package/dist/esm/nano-date-input.entry.js +1 -1
  247. package/dist/esm/nano-date-input.entry.js.map +1 -1
  248. package/dist/esm/nano-date-picker.entry.js +1 -1
  249. package/dist/esm/nano-date-picker.entry.js.map +1 -1
  250. package/dist/esm/nano-details.entry.js +1 -1
  251. package/dist/esm/nano-details.entry.js.map +1 -1
  252. package/dist/esm/nano-dialog.entry.js +3 -3
  253. package/dist/esm/nano-dialog.entry.js.map +1 -1
  254. package/dist/esm/nano-drawer.entry.js +3 -3
  255. package/dist/esm/nano-drawer.entry.js.map +1 -1
  256. package/dist/esm/nano-dropdown.entry.js +2 -2
  257. package/dist/esm/nano-dropdown.entry.js.map +1 -1
  258. package/dist/esm/nano-file-upload.entry.js +1 -1
  259. package/dist/esm/nano-file-upload.entry.js.map +1 -1
  260. package/dist/esm/nano-global-nav-user-profile_3.entry.js +10 -5
  261. package/dist/esm/nano-global-nav-user-profile_3.entry.js.map +1 -1
  262. package/dist/esm/nano-global-nav.entry.js +27 -14
  263. package/dist/esm/nano-global-nav.entry.js.map +1 -1
  264. package/dist/esm/nano-global-search-results.entry.js +1 -1
  265. package/dist/esm/nano-global-search-results.entry.js.map +1 -1
  266. package/dist/esm/nano-grid_3.entry.js +2 -2
  267. package/dist/esm/nano-grid_3.entry.js.map +1 -1
  268. package/dist/esm/nano-hero.entry.js +1 -1
  269. package/dist/esm/nano-hero.entry.js.map +1 -1
  270. package/dist/esm/nano-icon-button.entry.js +1 -1
  271. package/dist/esm/nano-icon-button.entry.js.map +1 -1
  272. package/dist/esm/nano-icon.entry.js +1 -1
  273. package/dist/esm/nano-icon.entry.js.map +1 -1
  274. package/dist/esm/nano-input.entry.js +1 -1
  275. package/dist/esm/nano-input.entry.js.map +1 -1
  276. package/dist/esm/nano-menu-drawer.entry.js +1 -1
  277. package/dist/esm/nano-menu-drawer.entry.js.map +1 -1
  278. package/dist/esm/nano-progress-bar.entry.js +1 -1
  279. package/dist/esm/nano-progress-bar.entry.js.map +1 -1
  280. package/dist/esm/nano-range.entry.js +1 -1
  281. package/dist/esm/nano-range.entry.js.map +1 -1
  282. package/dist/esm/nano-rating.entry.js +1 -1
  283. package/dist/esm/nano-rating.entry.js.map +1 -1
  284. package/dist/esm/nano-resize-observe_2.entry.js +23 -12
  285. package/dist/esm/nano-resize-observe_2.entry.js.map +1 -1
  286. package/dist/esm/nano-slide.entry.js +1 -1
  287. package/dist/esm/nano-slide.entry.js.map +1 -1
  288. package/dist/esm/nano-slides.entry.js +1 -1
  289. package/dist/esm/nano-slides.entry.js.map +1 -1
  290. package/dist/esm/nano-spinner.entry.js +1 -1
  291. package/dist/esm/nano-spinner.entry.js.map +1 -1
  292. package/dist/esm/nano-split-pane.entry.js +1 -1
  293. package/dist/esm/nano-split-pane.entry.js.map +1 -1
  294. package/dist/esm/nano-sticker.entry.js +1 -1
  295. package/dist/esm/nano-sticker.entry.js.map +1 -1
  296. package/dist/esm/nano-tab-content.entry.js +1 -1
  297. package/dist/esm/nano-tab-content.entry.js.map +1 -1
  298. package/dist/esm/nano-tab-group.entry.js +1 -1
  299. package/dist/esm/nano-tab-group.entry.js.map +1 -1
  300. package/dist/esm/nano-tab.entry.js +1 -1
  301. package/dist/esm/nano-tab.entry.js.map +1 -1
  302. package/dist/esm/{nano-table-93d25a68.js → nano-table-9d4fbd41.js} +23 -23
  303. package/dist/esm/nano-table-9d4fbd41.js.map +1 -0
  304. package/dist/esm/nano-table.entry.js +1 -1
  305. package/dist/esm/nano-tooltip.entry.js +1 -1
  306. package/dist/esm/nano-tooltip.entry.js.map +1 -1
  307. package/dist/esm/{tabbable-614f515e.js → tabbable-31485ff7.js} +13 -4
  308. package/dist/esm/tabbable-31485ff7.js.map +1 -0
  309. package/dist/esm/{table.worker-5d681b97.js → table.worker-1ba8ac3f.js} +2 -2
  310. package/dist/esm/table.worker-1ba8ac3f.js.map +1 -0
  311. package/dist/nano-components/index.esm.js +1 -1
  312. package/dist/nano-components/nano-components.css +1 -1
  313. package/dist/nano-components/nano-components.esm.js +1 -1
  314. package/dist/nano-components/{p-35295332.entry.js → p-151aad1e.entry.js} +5 -5
  315. package/dist/nano-components/{p-35295332.entry.js.map → p-151aad1e.entry.js.map} +1 -1
  316. package/dist/nano-components/p-15543295.entry.js +5 -0
  317. package/dist/nano-components/{p-6e3412d2.entry.js.map → p-15543295.entry.js.map} +1 -1
  318. package/dist/nano-components/p-1e709f87.entry.js +5 -0
  319. package/dist/nano-components/p-1e709f87.entry.js.map +1 -0
  320. package/dist/nano-components/p-1f347342.entry.js +5 -0
  321. package/dist/nano-components/{p-02df1f62.entry.js.map → p-1f347342.entry.js.map} +1 -1
  322. package/dist/nano-components/p-216ece9a.js +5 -0
  323. package/dist/nano-components/{p-39124baa.entry.js.map → p-216ece9a.js.map} +0 -0
  324. package/dist/nano-components/p-23575705.entry.js +5 -0
  325. package/dist/nano-components/{p-6958df8c.entry.js.map → p-23575705.entry.js.map} +1 -1
  326. package/dist/nano-components/p-244223f0.entry.js +5 -0
  327. package/dist/nano-components/{p-6cd59e58.entry.js.map → p-244223f0.entry.js.map} +1 -1
  328. package/dist/nano-components/p-284dd9a2.entry.js +5 -0
  329. package/dist/nano-components/{p-5107646c.entry.js.map → p-284dd9a2.entry.js.map} +1 -1
  330. package/dist/nano-components/p-2cb4615b.entry.js +5 -0
  331. package/dist/nano-components/{p-e3730878.entry.js.map → p-2cb4615b.entry.js.map} +1 -1
  332. package/dist/nano-components/p-36842a50.entry.js +5 -0
  333. package/dist/nano-components/{p-f69f93e9.entry.js.map → p-36842a50.entry.js.map} +1 -1
  334. package/dist/nano-components/p-41addb3a.entry.js +5 -0
  335. package/dist/nano-components/{p-0a5ad0ef.entry.js.map → p-41addb3a.entry.js.map} +1 -1
  336. package/dist/nano-components/{p-9a385481.js → p-45abbbdd.js} +2 -2
  337. package/dist/nano-components/p-45abbbdd.js.map +1 -0
  338. package/dist/nano-components/p-46b348b7.entry.js +5 -0
  339. package/dist/nano-components/{p-28f713fb.entry.js.map → p-46b348b7.entry.js.map} +1 -1
  340. package/dist/nano-components/p-4b69178e.entry.js +5 -0
  341. package/dist/nano-components/{p-5e33798f.entry.js.map → p-4b69178e.entry.js.map} +1 -1
  342. package/dist/nano-components/p-4f0e14b5.entry.js +5 -0
  343. package/dist/nano-components/{p-8f5e0022.entry.js.map → p-4f0e14b5.entry.js.map} +1 -1
  344. package/dist/nano-components/p-559a6492.entry.js +5 -0
  345. package/dist/nano-components/p-559a6492.entry.js.map +1 -0
  346. package/dist/nano-components/p-601e18d5.entry.js +5 -0
  347. package/dist/nano-components/p-601e18d5.entry.js.map +1 -0
  348. package/dist/nano-components/p-69e5a37d.entry.js +5 -0
  349. package/dist/nano-components/{p-282987e6.entry.js.map → p-69e5a37d.entry.js.map} +1 -1
  350. package/dist/nano-components/p-751927d1.entry.js +5 -0
  351. package/dist/nano-components/{p-5d81773d.entry.js.map → p-751927d1.entry.js.map} +1 -1
  352. package/dist/nano-components/p-845ae77e.js.map +1 -1
  353. package/dist/nano-components/p-866e7e88.js +5 -0
  354. package/dist/nano-components/p-866e7e88.js.map +1 -0
  355. package/dist/nano-components/{p-39124baa.entry.js → p-89b8ce4f.entry.js} +2 -2
  356. package/dist/nano-components/{p-619a1c8e.js.map → p-89b8ce4f.entry.js.map} +0 -0
  357. package/dist/nano-components/p-9059c8c1.entry.js +5 -0
  358. package/dist/nano-components/{p-d8e8d7e3.entry.js.map → p-9059c8c1.entry.js.map} +1 -1
  359. package/dist/nano-components/p-92504f7f.entry.js +5 -0
  360. package/dist/nano-components/{p-50fcb11c.entry.js.map → p-92504f7f.entry.js.map} +1 -1
  361. package/dist/nano-components/p-99fbae74.entry.js +5 -0
  362. package/dist/nano-components/{p-8a52a411.entry.js.map → p-99fbae74.entry.js.map} +1 -1
  363. package/dist/nano-components/p-9eeed8f5.entry.js +5 -0
  364. package/dist/nano-components/{p-4c97f05f.entry.js.map → p-9eeed8f5.entry.js.map} +1 -1
  365. package/dist/nano-components/p-a183e3c7.entry.js +5 -0
  366. package/dist/nano-components/{p-b290a970.entry.js.map → p-a183e3c7.entry.js.map} +1 -1
  367. package/dist/nano-components/p-a2e38472.entry.js +5 -0
  368. package/dist/nano-components/p-a2e38472.entry.js.map +1 -0
  369. package/dist/nano-components/p-b87539f0.entry.js +5 -0
  370. package/dist/nano-components/{p-efa8c520.entry.js.map → p-b87539f0.entry.js.map} +1 -1
  371. package/dist/nano-components/p-b9c8b99f.entry.js +5 -0
  372. package/dist/nano-components/p-b9c8b99f.entry.js.map +1 -0
  373. package/dist/nano-components/{p-cb79d1ec.js → p-c9a7c7ea.js} +2 -2
  374. package/dist/nano-components/{p-cb79d1ec.js.map → p-c9a7c7ea.js.map} +1 -1
  375. package/dist/nano-components/{p-c45851c3.entry.js → p-d1c8eca4.entry.js} +2 -2
  376. package/dist/nano-components/{p-c45851c3.entry.js.map → p-d1c8eca4.entry.js.map} +1 -1
  377. package/dist/nano-components/p-d8678bdc.entry.js +5 -0
  378. package/dist/nano-components/p-d8678bdc.entry.js.map +1 -0
  379. package/dist/nano-components/p-db4b6602.entry.js +5 -0
  380. package/dist/nano-components/{p-716064b6.entry.js.map → p-db4b6602.entry.js.map} +1 -1
  381. package/dist/nano-components/{p-916e4b6b.entry.js → p-dba8a88d.entry.js} +2 -2
  382. package/dist/nano-components/{p-916e4b6b.entry.js.map → p-dba8a88d.entry.js.map} +1 -1
  383. package/dist/nano-components/p-e4e41e06.entry.js +5 -0
  384. package/dist/nano-components/p-e4e41e06.entry.js.map +1 -0
  385. package/dist/nano-components/p-e5408bc8.entry.js +5 -0
  386. package/dist/nano-components/{p-c5bb5540.entry.js.map → p-e5408bc8.entry.js.map} +1 -1
  387. package/dist/nano-components/p-f43d1d8e.entry.js +5 -0
  388. package/dist/nano-components/{p-66099557.entry.js.map → p-f43d1d8e.entry.js.map} +1 -1
  389. package/dist/nano-components/p-f7471cca.entry.js +5 -0
  390. package/dist/nano-components/{p-66ad1418.entry.js.map → p-f7471cca.entry.js.map} +1 -1
  391. package/dist/nano-components/p-fe94eeff.entry.js +5 -0
  392. package/dist/nano-components/{p-701e8ebf.entry.js.map → p-fe94eeff.entry.js.map} +1 -1
  393. package/dist/nano-components/p-feb9f164.entry.js +5 -0
  394. package/dist/nano-components/{p-81136f24.entry.js.map → p-feb9f164.entry.js.map} +1 -1
  395. package/dist/themes/nanopore.css +1 -1
  396. package/dist/themes/nanopore.css.map +1 -1
  397. package/dist/types/components/global-nav/global-nav.d.ts +8 -3
  398. package/dist/types/components/resize-observe/resize-observe.d.ts +5 -2
  399. package/dist/types/components/table/table.d.ts +8 -7
  400. package/dist/types/components.d.ts +4 -0
  401. package/dist/types/utils/dom.d.ts +1 -1
  402. package/docs-json.json +167 -7
  403. package/docs-vscode.json +1 -1
  404. package/package.json +2 -2
  405. package/dist/cjs/nano-table-7dbe799c.js.map +0 -1
  406. package/dist/cjs/tabbable-de4c23d8.js.map +0 -1
  407. package/dist/cjs/table.worker-fe960deb.js.map +0 -1
  408. package/dist/collection/components/global-nav/search-widget.js +0 -4
  409. package/dist/collection/components/global-nav/search-widget.js.map +0 -1
  410. package/dist/esm/nano-table-93d25a68.js.map +0 -1
  411. package/dist/esm/tabbable-614f515e.js.map +0 -1
  412. package/dist/esm/table.worker-5d681b97.js.map +0 -1
  413. package/dist/nano-components/p-02df1f62.entry.js +0 -5
  414. package/dist/nano-components/p-0a5ad0ef.entry.js +0 -5
  415. package/dist/nano-components/p-282987e6.entry.js +0 -5
  416. package/dist/nano-components/p-28b43ee9.entry.js +0 -5
  417. package/dist/nano-components/p-28b43ee9.entry.js.map +0 -1
  418. package/dist/nano-components/p-28f713fb.entry.js +0 -5
  419. package/dist/nano-components/p-37553477.entry.js +0 -5
  420. package/dist/nano-components/p-37553477.entry.js.map +0 -1
  421. package/dist/nano-components/p-42fa11c3.entry.js +0 -5
  422. package/dist/nano-components/p-42fa11c3.entry.js.map +0 -1
  423. package/dist/nano-components/p-4c386a43.js +0 -5
  424. package/dist/nano-components/p-4c386a43.js.map +0 -1
  425. package/dist/nano-components/p-4c97f05f.entry.js +0 -5
  426. package/dist/nano-components/p-50fcb11c.entry.js +0 -5
  427. package/dist/nano-components/p-5107646c.entry.js +0 -5
  428. package/dist/nano-components/p-5d81773d.entry.js +0 -5
  429. package/dist/nano-components/p-5e33798f.entry.js +0 -5
  430. package/dist/nano-components/p-619a1c8e.js +0 -5
  431. package/dist/nano-components/p-653a25f8.entry.js +0 -5
  432. package/dist/nano-components/p-653a25f8.entry.js.map +0 -1
  433. package/dist/nano-components/p-66099557.entry.js +0 -5
  434. package/dist/nano-components/p-66ad1418.entry.js +0 -5
  435. package/dist/nano-components/p-6958df8c.entry.js +0 -5
  436. package/dist/nano-components/p-6cd59e58.entry.js +0 -5
  437. package/dist/nano-components/p-6e3412d2.entry.js +0 -5
  438. package/dist/nano-components/p-701e8ebf.entry.js +0 -5
  439. package/dist/nano-components/p-716064b6.entry.js +0 -5
  440. package/dist/nano-components/p-81136f24.entry.js +0 -5
  441. package/dist/nano-components/p-8a52a411.entry.js +0 -5
  442. package/dist/nano-components/p-8f5e0022.entry.js +0 -5
  443. package/dist/nano-components/p-9a385481.js.map +0 -1
  444. package/dist/nano-components/p-a151dea5.entry.js +0 -5
  445. package/dist/nano-components/p-a151dea5.entry.js.map +0 -1
  446. package/dist/nano-components/p-b290a970.entry.js +0 -5
  447. package/dist/nano-components/p-c5bb5540.entry.js +0 -5
  448. package/dist/nano-components/p-d8e8d7e3.entry.js +0 -5
  449. package/dist/nano-components/p-e3730878.entry.js +0 -5
  450. package/dist/nano-components/p-efa8c520.entry.js +0 -5
  451. package/dist/nano-components/p-f69f93e9.entry.js +0 -5
  452. package/dist/nano-components/p-f71f69c9.entry.js +0 -5
  453. package/dist/nano-components/p-f71f69c9.entry.js.map +0 -1
  454. package/dist/nano-components/p-fa2a6733.entry.js +0 -5
  455. package/dist/nano-components/p-fa2a6733.entry.js.map +0 -1
  456. package/dist/types/components/global-nav/search-widget.d.ts +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"sources":["src/components/global-nav/global-nav-user-profile.tsx","src/components/nav-item/nav-item.scss?tag=nano-nav-item&encapsulation=shadow","src/components/nav-item/nav-item.tsx","src/components/select/select.scss?tag=nano-select&encapsulation=scoped","src/components/select/select.tsx"],"names":["GlobalNavUserProfile","[object Object]","h","href","this","userProfileUrl","class","src","myAccountUser","small_avatar_url","alt","height","width","is_nanopore_user","getAssetPath","name","job_title","company","slot","aria-label","navItemCss","NavItem","hasSecondarySlot","hasAnchorEle","didBlur","animating","closeSecondary","async","open","didOpen","nanoClosing","emit","secondaryMenu","secondaryDiv","status","displayTransition","openSecondary","window","innerWidth","secondaryActiveWidth","secondaryFallback","call","nanoOpening","toggleSecondary","handleFocus","hasFocus","nanoFocus","handleHostBlur","el","removeAttribute","nanoBlur","handleHostClick","ev","foundlink","target","closest","btn","click","handleMouseEnter","globalNavEle","classList","contains","timeToWait","getSiblings","length","clearTimeout","waitHide","fromHover","waitShow","setTimeout","handleMouseLeave","handleClick","querySelector","blur","closeOnBlur","relatedTarget","foundThisNavEle","focus","preventScroll","removeEventListener","nanoClose","panelio","IntersectionObserver","data","boundingClientRect","top","scrollIntoView","behavior","disconnect","threshold","observe","addEventListener","tabIndex","nanoOpen","found","parentElement","secondaryEle","link","getDirectChildren","isInGlobalNav","isInMenuDrawer","isInMenu","Host","has-secondary","secondary-open","selected","has-focus","disabled","nano-global-nav","nano-menu-drawer","nano-menu","onBlur","dir","ownerDocument","onMouseEnter","onMouseLeave","onClick","role","nav-item","ref","a","onFocus","notification","div","tabindex","selectCss","selectIds","Select","hostRef","valueItems","selectId","rtl","onInit","customError","_value","multiple","_options","customValidate","nativeSelect","setCustomValidity","required","valArray","allowCustomValues","isValidValues","max","min","showInlineValidation","validateOn","_invalid","showErrorMsg","errorMessage","validity","valid","validationMessage","nanoValidate","isValid","invalid","originalEvent","handleInvalid","showInlineError","preventDefault","requestAnimationFrame","setValue","e","value","detail","includes","currInsertIndex","slice","inputSearchVal","removeValue","toFind","filter","val","setFocus","setOptions","datalist","activeOptions","_eOptions","map","ao","label","filterMeta","handleDocumentKeyDown","rm","key","inputCtrl","previousElementSibling","dataset","nextElementSibling","previousSibling","nextSibling","event","Event","dispatchEvent","clearSelectValue","clearSelect","readonly","stopPropagation","onDragStart","ele","dragVal","onDragEnd","onDragLeave","spanVal","to","indexOf","from","tmpArr","tmpVal","onMultiInput","trim","nanoSearchChange","debounce","_inputCtrl","input","setDataListOpts","selectWrap","_selectWrap","_datalist","validityMessage","split","Array","isArray","options","opts","opt","debounceEvent","shouldValidate","nanoChange","currDWConfig","dropDownConfig","tetherTo","validateFirst","Promise","resolve","message","find","mo","MutationObserver","processSlottedContent","childList","subtree","hasLabelSlot","querySelectorAll","hasHelperSlot","hasHelperEndSlot","form","document","kev","getActiveElement","closestElement","tagName","toLowerCase","debounceChanged","CustomEvent","slotChangeObserver","labelId","moreId","helperEndId","compWrapOptions","floatLabel","hideLabel","placeholder","wrapOptions","hasValue","controlId","controlOptions","clearControl","type","aria-disabled","createColorClasses","color","has-value","is-invalid","has-label","has-float-label","has-multiple","has-clr-btn","masked","mask","FormControlWrap","FormControl","onClearText","control","endValueSlot","multipleValues","getLabel","id","aria-labelledby","readOnly","onNanoOptionsUpdated","onNanoSelect","onNanoDeselect","undefined","select","onInvalid","autoFocus","autofocus","autocomplete","onKeyDown","onInput","onTouchStart","onMouseDown","i","toReturn","onDragOver","draggable","data-value","span","push","onTouchEnd","onMouseUp"],"mappings":"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","sourcesContent":["import {\n Component,\n h,\n Prop,\n getAssetPath,\n ComponentInterface,\n} from '@stencil/core';\nimport { MyAccountUser } from './global-nav-interface';\n\n/**\n * Nanopore digital global navigation user profile.\n */\n@Component({\n tag: 'nano-global-nav-user-profile',\n assetsDirs: ['assets'],\n})\nexport class GlobalNavUserProfile implements ComponentInterface {\n /**\n * Logged in user details automatically populated from MyAccount\n */\n @Prop() myAccountUser: MyAccountUser = null;\n\n /**\n * Link to the user profile\n */\n @Prop() userProfileUrl: string = '';\n\n // Render output\n\n render() {\n return (\n <a href={this.userProfileUrl} class=\"user-profile\">\n <div class=\"left\">\n <div class=\"avatar-container\">\n <img\n class=\"avatar\"\n src={this.myAccountUser.small_avatar_url}\n alt=\"User Avatar\"\n height={75}\n width={75}\n />\n {this.myAccountUser.is_nanopore_user && (\n <img\n class=\"logo-small\"\n src={getAssetPath(`./assets/ont-wheel-light.svg`)}\n alt=\"Nanopore Logo\"\n />\n )}\n </div>\n\n <div class=\"user-details\">\n <span class=\"name\">{this.myAccountUser.name}</span>\n\n <span class=\"bio\">\n {this.myAccountUser.job_title} at {this.myAccountUser.company}\n </span>\n </div>\n </div>\n\n <div class=\"right\">\n <div class=\"chevron-right\">\n <nano-icon\n slot=\"icon-end\"\n name=\"light/chevron-right\"\n aria-label=\"navigate to ...\"\n ></nano-icon>\n </div>\n </div>\n </a>\n );\n }\n}\n","@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/form';\n\n:host {\n // These can be overwritten, but are automatically set from context components\n\n // --padding-top: inherit;\n // --padding-bottom: inherit;\n // --padding-start: inherit;\n // --padding-end: inherit;\n // --margin: inherit;\n\n // --secondary-padding-top: inherit;\n // --secondary-padding-bottom: inherit;\n // --secondary-padding-start: inherit;\n // --secondary-padding-end: inherit;\n\n // --border-bottom: inherit;\n // --icon-size: inherit;\n\n // --color: inherit;\n // --color-hover: inherit;\n // --color-focus: inherit;\n // --color-selected: inherit;\n // --color-open: inherit;\n\n // --bg-color: inherit;\n // --bg-color-hover: inherit;\n // --bg-color-selected: inherit;\n // --bg-color-open: inherit;\n // --bg-color-focus: inherit;\n\n // --secondary-bg-color: inherit;\n // --secondary-color: inherit;\n\n opacity: inherit;\n display: block;\n color: var(--color) !important;\n margin: var(--margin);\n\n ::slotted(*),\n * {\n box-sizing: border-box;\n }\n\n ::slotted(button),\n button {\n background: none;\n border: none;\n margin: 0;\n }\n\n ::slotted(button),\n ::slotted(a),\n ::slotted(a:visited),\n button,\n a,\n a:visited {\n @include text-inherit();\n\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: var(--padding-top) var(--padding-bottom);\n display: var(--display, block);\n white-space: nowrap;\n color: var(--color) !important;\n background-color: var(--bg-color);\n line-height: inherit;\n }\n\n ::slotted(nano-icon[slot='icon-start']) {\n padding-inline-end: var(--padding-end);\n }\n\n ::slotted(nano-icon[slot='icon-end']) {\n padding-inline-start: var(--padding-start);\n }\n\n .link {\n ::slotted(nano-icon[slot='icon-start']) {\n padding-inline-start: var(--padding-start);\n padding-inline-end: 0;\n }\n\n ::slotted(nano-icon[slot='icon-end']) {\n padding-inline-end: var(--padding-end);\n padding-inline-start: 0;\n }\n }\n\n .link,\n button,\n a {\n border-block-end: var(--border-bottom);\n display: flex;\n align-items: center;\n }\n\n .secondary-menu {\n display: none;\n }\n\n ::slotted(a:hover),\n ::slotted(button:hover),\n .link:hover,\n button:hover,\n a:hover {\n text-decoration: inherit !important;\n }\n\n button:focus,\n a:focus {\n color: var(--color-focus, var(--color-hover, var(--color))) !important;\n background-color:\n var(\n --bg-color-focus,\n var(--bg-color-hover, var(--bg-color))\n );\n outline: var(--focus-outline, none);\n }\n\n ::slotted(a:focus),\n ::slotted(button:focus) {\n color: var(--color-focus, var(--color-hover, var(--color))) !important;\n background-color:\n var(\n --bg-color-focus,\n var(--bg-color-hover, var(--bg-color))\n );\n outline: none;\n }\n}\n\n.nav-item {\n &.selected {\n .link,\n button,\n a {\n color: var(--color-selected, var(--color-open, var(--color))) !important;\n background-color:\n var(\n --bg-color-selected,\n var(--bg-color-open, var(--bg-color))\n );\n }\n }\n\n &.secondary-open {\n button,\n a {\n color: var(--color-open, var(--color-selected, var(--color))) !important;\n background-color:\n var(\n --bg-color-open,\n var(--secondary-bg-color, var(--bg-color-selected, var(--bg-color)))\n );\n }\n }\n\n &.disabled {\n opacity: 0.6;\n\n button,\n a {\n color: var(--color-disabled, var(--color)) !important;\n }\n }\n\n &:not(.nano-menu) {\n ::slotted(a:hover),\n ::slotted(button:hover),\n .link:hover,\n button:hover,\n a:hover {\n color: var(--color-hover, var(--color-hover, var(--color))) !important;\n background-color:\n var(\n --bg-color-hover,\n var(--bg-color-focus, var(--bg-color))\n );\n }\n }\n}\n\n:host(.has-focus) {\n .link {\n color: var(--color-focus, var(--color-hover, var(--color))) !important;\n background-color:\n var(\n --bg-color-focus,\n var(--bg-color-hover, var(--bg-color))\n );\n outline: var(--focus-outline, 5px auto -webkit-focus-ring-color);\n }\n}\n\n:host(.nano-global-nav-menu),\n:host(.nano-menu) {\n a,\n a:visited,\n button,\n .link {\n display: flex;\n justify-content: flex-start;\n flex-direction: row;\n align-items: center;\n color: 'currentColor';\n text-decoration: inherit;\n white-space: normal;\n cursor: pointer;\n line-height: 1.2;\n width: 100%;\n }\n\n .text {\n padding-inline-start: 0;\n padding-inline-end: var(--padding-end);\n flex: 1;\n }\n\n ::slotted(a),\n ::slotted(button) {\n flex: 1;\n }\n\n ::slotted(a:focus),\n ::slotted(button:focus) {\n box-shadow: none;\n }\n\n .secondary-menu {\n display: none;\n position: absolute;\n color: var(--secondary-color, 'currentColor');\n min-height: 100%;\n inset-block-start: 0;\n inset-inline-start: 0;\n width: 100%;\n z-index: 1;\n opacity: 0;\n transition: opacity 0.2s ease, transform 0.3s ease;\n background-color: var(--secondary-bg-color, white);\n transform: translateX(100%);\n\n &:focus {\n outline: none;\n }\n\n &.open {\n opacity: 1;\n transform: translateX(0);\n transition: opacity 0.3s ease, transform 0.2s ease;\n }\n }\n}\n\n:host(.nano-global-nav-menu) {\n ::slotted(nano-icon[slot='icon-start']) {\n padding-inline: 0 var(--padding-end);\n padding-block: 0;\n }\n\n ::slotted(nano-icon[slot='icon-end']) {\n padding-inline: 0 var(--padding-end);\n padding-block: 0;\n font-size: 10px;\n flex: 0 0 10px;\n pointer-events: none;\n }\n\n button,\n a {\n ::slotted(nano-icon[slot='icon-end']) {\n padding: 0;\n }\n }\n}\n\n:host(.nano-global-nav-menu[dir='rtl']),\n:host(.nano-menu[dir='rtl']) {\n .secondary-menu {\n transform: translateX(-100%);\n\n &.open {\n transform: translateX(0);\n }\n }\n}\n\n:host(.nano-menu) {\n .secondary-menu-content {\n padding-inline: var(--secondary-padding-start) var(--secondary-padding-end);\n padding-block: var(--secondary-padding-top) var(--secondary-padding-bottom);\n }\n}\n\n:host(.nano-global-nav-bar) {\n .link,\n a,\n button {\n display: flex;\n align-items: center;\n cursor: pointer;\n }\n\n .text {\n flex: 1 0 auto;\n }\n\n ::slotted(nano-icon[slot='icon-end']) {\n margin-inline: var(--padding-end) 0;\n margin-block: 0;\n }\n\n ::slotted(nano-icon[slot='icon-start']) {\n margin-inline: 0 var(--padding-start);\n margin-block: 0;\n }\n}\n\n:host(.nano-global-nav-bar.has-secondary) {\n button {\n position: relative;\n\n &::before {\n content: '';\n background-color: rgb(12, 90, 113);\n height: 9px;\n inset-inline: 0 5px;\n inset-block-end: -24px;\n position: absolute;\n transform: translateZ(0) scaleX(0);\n transform-origin: 0;\n transition: 0.2s ease transform;\n }\n }\n\n .selected button::before,\n .secondary-open button::before {\n transform: translateZ(0) scaleX(1);\n }\n\n .secondary-open button::before {\n opacity: 0.7;\n }\n\n .secondary-menu {\n display: none;\n transition: transform 0.3s ease;\n transform: translateY(-100%) translateZ(0);\n background-color: var(--secondary-bg-color, #196c82);\n color: var(--secondary-color);\n position: absolute;\n box-shadow: 0 1px 25px 0 rgba(0, 0, 0, 0.15);\n inset-inline: 0;\n z-index: -2;\n outline: none;\n\n &.open {\n transform: translateY(12px) translateZ(0);\n }\n }\n}\n\n:host(.nano-menu-drawer) {\n .link,\n a,\n button {\n padding-block-start: calc(var(--padding-top) / 2);\n padding-inline-end: 0;\n padding-block-end: calc(var(--padding-bottom) / 2);\n padding-inline-start: var(--padding-start);\n display: flex;\n justify-content: flex-start;\n flex-direction: row;\n align-items: center;\n color: currentColor;\n text-decoration: inherit;\n white-space: normal;\n border: none;\n cursor: pointer;\n line-height: 1.2;\n width: 100%;\n }\n\n .text {\n padding-inline-end: var(--padding-end);\n padding-inline-start: 0;\n text-align: start;\n flex: 0 1 auto;\n min-width: 130px;\n width: 130px;\n }\n\n ::slotted(nano-icon[slot='icon-start']) {\n padding-inline: 0 var(--padding-end);\n padding-block: 0;\n font-size: var(--icon-size);\n width: var(--icon-size);\n flex: 0 0 var(--icon-size);\n }\n\n ::slotted(nano-icon[slot='icon-end']) {\n padding: 0 var(--padding-end) 0 0;\n font-size: 10px;\n flex: 0 0 20px;\n min-width: 20px;\n }\n\n .secondary-menu {\n display: none;\n position: absolute;\n background-color: var(--secondary-bg-color);\n color: var(--secondary-color);\n height: 100vh;\n inset-inline: auto 0;\n inset-block: 0;\n transform: translateX(0);\n z-index: -1;\n transition: transform 0.3s ease, opacity 0.2s ease;\n overflow-y: auto;\n width: var(--secondary-width, 400px);\n max-width: 62vw;\n opacity: 1;\n padding-inline: var(--secondary-padding-start, var(--padding-start)) var(--secondary-padding-end, var(--padding-end));\n padding-block: var(--secondary-padding-top, var(--padding-top)) var(--secondary-padding-bottom, var(--padding-bottom));\n\n &:focus {\n outline: none;\n }\n\n &.open {\n transform: translateX(100%);\n // opacity: 1;\n }\n }\n\n .notification {\n position: relative;\n\n &::after {\n content: '';\n display: block;\n position: absolute;\n width: 6px;\n height: 6px;\n background-color: #ef4135;\n inset-inline-start: 10px;\n inset-block-start: 7px;\n border-radius: 50%;\n\n @media (min-width: 52em) {\n width: 7px;\n height: 7px;\n inset-inline-start: 8px;\n inset-block-start: 5px;\n }\n }\n }\n}\n\n:host(.nano-menu-drawer[dir='rtl']) {\n .secondary-menu {\n transform: translateX(0%);\n\n &.open {\n transform: translateX(-100%);\n opacity: 1;\n }\n }\n}\n","import {\n Component,\n h,\n Host,\n Element,\n Prop,\n Watch,\n EventEmitter,\n Event,\n State,\n Method,\n ComponentInterface,\n} from '@stencil/core';\nimport { getDirectChildren, getSiblings } from '../../utils/dom';\nimport { displayTransition } from '../../utils/transitions';\nimport type { NavItemEventDetail } from '../../interface';\n\n/**\n * Nav items to be used with the various nav items.\n * [Globla-Nav](/story/compounds-global-nav)\n * [Menu-Drawer](/story/components-menu-drawer)\n * [Dropdown](/story/components-dropdown)\n */\n@Component({\n tag: 'nano-nav-item',\n styleUrl: 'nav-item.scss',\n shadow: true,\n})\nexport class NavItem implements ComponentInterface {\n private hasSecondarySlot: boolean = false;\n private hasAnchorEle: boolean = false;\n private secondaryDiv: HTMLDivElement;\n private btn: HTMLButtonElement | HTMLAnchorElement;\n private didBlur: boolean = false;\n private fromHover: boolean;\n private animating: boolean = false;\n private waitHide: number;\n private waitShow: number;\n private globalNavEle?: HTMLNanoGlobalNavElement;\n\n @State() didOpen: boolean = false;\n @State() isInGlobalNav: boolean = false;\n @State() isInMenuDrawer: boolean = false;\n @State() isInMenu: boolean = false;\n @State() hasFocus: boolean = false;\n @Element() private el: HTMLNanoNavItemElement;\n\n /**\n * Href to link to\n */\n @Prop({ mutable: true }) href: string = null;\n\n /**\n * Target to use for links\n */\n @Prop() target: '_self' | '_blank' | '_parent' | '_top' = '_self';\n\n /**\n * Disable the nav item\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Whether a secondary menu should be or is currently open\n */\n @Prop({ mutable: true, reflect: true }) open: boolean = false;\n\n /**\n * Whether this menu item is currently 'selected'\n */\n @Prop({ reflect: true }) selected: boolean = false;\n\n /**\n * Screen pixel width to activate the secondary menu\n */\n @Prop() secondaryActiveWidth: number = 0;\n\n /**\n * Secondary fallback function for when the secondary menu is no longer active.\n */\n @Prop() secondaryFallback = () => {};\n\n /**\n * Whether secondary menus should close on blur\n */\n @Prop() closeOnBlur: boolean = true;\n\n /**\n * Will show an indicator badge - only when placed in a nano-menu-draw\n */\n @Prop() notification: boolean = false;\n\n /**\n * Emitted when the nav item closes it's secondary navigation.\n */\n @Event() nanoClose!: EventEmitter<NavItemEventDetail>;\n\n /**\n * Emitted when the nav item opens it's secondary navigation.\n */\n @Event() nanoOpen!: EventEmitter<NavItemEventDetail>;\n\n /**\n * Emitted when the nav item is about to open it's secondary navigation.\n */\n @Event() nanoOpening!: EventEmitter<NavItemEventDetail>;\n\n /**\n * Emitted when the nav item is about to close it's secondary navigation.\n */\n @Event() nanoClosing!: EventEmitter<NavItemEventDetail>;\n\n /**\n * Emitted when the nav item loses focus.\n */\n @Event() nanoBlur!: EventEmitter<void>;\n\n /**\n * Emitted when the nav item has focus.\n */\n @Event() nanoFocus!: EventEmitter<void>;\n\n /**\n * Sets focus on the first button or anchor present. Use this method instead of the global\n * `element.focus()`.\n */\n @Method()\n async setFocus() {\n if (!this.btn) return;\n this.btn.focus();\n }\n\n /**\n * Public open watcher\n */\n @Watch('open')\n openChange() {\n this.open ? this.openSecondary() : this.closeSecondary();\n }\n\n /**\n * Internal open watcher\n */\n @Watch('didOpen')\n didOpenChange() {\n if (!this.hasSecondarySlot) return;\n\n if (!this.didOpen) {\n /* the secondadry panel is not closing via hover,\n remove blur events, add focus back to originating button */\n if (!this.fromHover) {\n this.btn.removeEventListener('focusout', this.blur);\n this.secondaryDiv.removeEventListener('focusout', this.blur);\n }\n setTimeout(() => {\n if (!this.fromHover && !this.didBlur)\n this.btn.focus({ preventScroll: true });\n this.nanoClose.emit({ secondaryMenu: this.secondaryDiv });\n }, 50);\n } else {\n this.didBlur = false;\n\n /* the secondadry panel is not opening via hover,\n scroll content into view, focus on it and add blur events */\n if (!this.fromHover) {\n const panelio = new (window as any).IntersectionObserver(\n (data: IntersectionObserverEntry[]) => {\n if (data[0].boundingClientRect.top < 0) {\n this.secondaryDiv.scrollIntoView({\n behavior: 'smooth',\n });\n }\n panelio.disconnect();\n },\n { threshold: 1 }\n );\n panelio.observe(this.secondaryDiv);\n this.secondaryDiv.focus({ preventScroll: true });\n\n this.btn.addEventListener('focusout', this.blur);\n this.secondaryDiv.addEventListener('focusout', this.blur);\n window.addEventListener('blur', this.blur);\n\n this.el.tabIndex = -1;\n this.nanoOpen.emit({ secondaryMenu: this.secondaryDiv });\n }\n }\n }\n\n private closeSecondary = async () => {\n this.open = false;\n if (!this.hasSecondarySlot || !this.didOpen) return;\n\n this.nanoClosing.emit({ secondaryMenu: this.secondaryDiv });\n const status = await displayTransition(this.secondaryDiv, 'open', false);\n this.didOpen = status !== 'hidden';\n };\n\n private openSecondary = async () => {\n if (window.innerWidth < this.secondaryActiveWidth) {\n this.secondaryFallback.call(this);\n return;\n }\n this.open = true;\n if (!this.hasSecondarySlot || this.didOpen) return;\n\n this.nanoOpening.emit({ secondaryMenu: this.secondaryDiv });\n const status = await displayTransition(this.secondaryDiv, 'open', true);\n this.didOpen = status === 'shown';\n };\n\n private toggleSecondary = () => {\n if (!this.hasSecondarySlot) return;\n if (this.didOpen) this.closeSecondary();\n else this.openSecondary();\n };\n\n private handleFocus = () => {\n this.hasFocus = true;\n // opens secondary panel when activated via hover\n if (this.href && !this.animating && this.hasSecondarySlot)\n this.openSecondary();\n this.nanoFocus.emit();\n };\n\n private handleHostBlur = () => {\n if (this.animating) return;\n\n // tab index is added to host when secondary panel opens\n // to return focus after secondary panel closes. Remove now if it was added\n this.el.removeAttribute('tabindex');\n this.hasFocus = false;\n this.nanoBlur.emit();\n };\n\n // direct host clicks to internal button\n private handleHostClick = (ev: MouseEvent) => {\n if (!this.hasAnchorEle) return;\n const foundlink = (ev.target as HTMLElement).closest('a, button');\n if (!foundlink) this.btn.click();\n };\n\n // handles secondary menu hover behaviour.\n private handleMouseEnter = async () => {\n if (\n !this.href ||\n this.animating ||\n !this.hasSecondarySlot ||\n (this.globalNavEle && !this.globalNavEle.classList.contains('ready'))\n )\n return;\n\n // if there are sibling secondary panels currently open,\n // we need to wait before opening otherwise we get unwanted overlapping\n let timeToWait = 0;\n if (getSiblings(this.el, '.secondary-open.has-secondary').length)\n timeToWait = 300;\n\n clearTimeout(this.waitHide);\n this.fromHover = true;\n this.animating = true;\n this.waitShow = window.setTimeout(\n async () => await this.openSecondary(),\n timeToWait\n );\n this.animating = false;\n };\n\n // handles secondary menu hover-out behaviour.\n private handleMouseLeave = () => {\n if (!this.href) return;\n clearTimeout(this.waitShow);\n this.fromHover = true;\n this.animating = true;\n\n // prevent closing immediately - makes navigating to items within more forgiving\n this.waitHide = window.setTimeout(\n async () => await this.closeSecondary(),\n 300\n );\n this.animating = false;\n };\n\n private handleClick = () => {\n this.fromHover = false;\n if (this.hasSecondarySlot) this.toggleSecondary();\n else this.el.querySelector<HTMLElement>('*')?.click();\n };\n\n // utility to traverse up, to see if element is nested within current nav-item\n private foundThisNavEle(el: HTMLElement): boolean {\n let found = el.closest('nano-nav-item');\n found = found === el ? el.parentElement.closest('nano-nav-item') : found;\n\n if (!found) return false;\n if (found === this.el) return true;\n return this.foundThisNavEle(found);\n }\n\n private blur = (ev: FocusEvent) => {\n if (!this.didOpen || this.animating) return;\n if (!this.closeOnBlur) return;\n\n // if event is associated with this element don't close\n if (ev && ev.relatedTarget) {\n if (\n ev.relatedTarget === this.el ||\n ev.relatedTarget === this.btn ||\n this.foundThisNavEle(ev.relatedTarget as HTMLElement)\n ) {\n this.secondaryDiv.focus({ preventScroll: true });\n return;\n }\n }\n\n this.btn.removeEventListener('focusout', this.blur);\n this.secondaryDiv.removeEventListener('focusout', this.blur);\n window.removeEventListener('blur', this.blur);\n\n this.didBlur = true;\n\n this.open = false;\n if (!ev.relatedTarget)\n setTimeout(() => {\n this.el.focus({ preventScroll: true });\n }, 50);\n };\n\n componentWillLoad() {\n const secondaryEle = this.el.querySelector('[slot=\"secondary\"]');\n this.hasSecondarySlot = !!secondaryEle;\n\n const link = getDirectChildren(this.el, 'a, button')[0] as\n | HTMLAnchorElement\n | HTMLButtonElement;\n this.hasAnchorEle = !!link;\n\n if (link) {\n this.href = (link as HTMLAnchorElement).href\n ? (link as HTMLAnchorElement).href\n : null;\n this.btn = link;\n if (this.hasSecondarySlot)\n this.btn.addEventListener('click', this.toggleSecondary);\n\n this.btn.addEventListener('focus', this.handleFocus);\n this.btn.addEventListener('blur', this.handleHostBlur);\n }\n }\n\n connectedCallback() {\n this.isInGlobalNav = false;\n this.isInMenuDrawer = false;\n this.globalNavEle = this.el.closest('nano-global-nav');\n\n this.isInMenuDrawer = !!this.el.closest('nano-menu-drawer');\n this.isInMenu = !!this.el.closest('nano-menu');\n this.isInGlobalNav =\n this.el.parentElement === this.globalNavEle ||\n !!this.el.closest('.global-nav');\n }\n\n render() {\n return (\n <Host\n class={{\n 'has-secondary': this.hasSecondarySlot,\n 'secondary-open': this.open,\n selected: this.selected,\n 'has-focus': this.hasFocus,\n disabled: this.disabled,\n 'nano-global-nav': this.isInGlobalNav,\n 'nano-menu-drawer': this.isInMenuDrawer,\n 'nano-menu': this.isInMenu,\n }}\n onBlur={this.handleHostBlur}\n dir={(this.el.ownerDocument as Document).dir === 'rtl' ? 'rtl' : null}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n onClick={this.handleHostClick}\n role=\"menuitem\"\n >\n <div\n class={{\n 'nav-item': true,\n 'secondary-open': this.open,\n selected: this.selected,\n }}\n >\n {this.href && !this.hasAnchorEle && !this.disabled && (\n <a\n target={this.target}\n ref={(a) => (this.btn = a)}\n href={this.href}\n onFocus={this.handleFocus}\n class={{\n notification: this.notification,\n }}\n >\n <slot name=\"icon-start\" />\n <span class=\"text\">\n <slot />\n </span>\n <slot name=\"icon-end\" />\n </a>\n )}\n {((!this.hasAnchorEle && !this.href) || this.disabled) && (\n <button\n ref={(btn) => (this.btn = btn)}\n onClick={this.handleClick}\n onFocus={this.handleFocus}\n disabled={this.disabled}\n class={{\n notification: this.notification,\n }}\n >\n <slot name=\"icon-start\" />\n <span class=\"text\">\n <slot />\n </span>\n <slot name=\"icon-end\" />\n </button>\n )}\n {this.hasAnchorEle && !this.disabled && (\n <div class=\"link\">\n <slot name=\"icon-start\" />\n <slot />\n <slot name=\"icon-end\" />\n </div>\n )}\n {this.hasSecondarySlot && !this.disabled && (\n <div\n class=\"secondary-menu\"\n ref={(div) => (this.secondaryDiv = div)}\n tabindex=\"-1\"\n >\n <div class=\"secondary-menu-content\">\n <slot name=\"secondary\" />\n </div>\n <div\n class=\"secondary-menu-mask\"\n onClick={this.closeSecondary}\n ></div>\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n","@import '../../global/style/utilities/globals';\n@import '../../global/style/nano-theme/form';\n@import '../../global/style/nano-theme/layers';\n@import '../form-control/form-control';\n@import '../form-control/form-control-vars';\n\n:host {\n @include formControlVars;\n\n position: relative;\n width: 100%;\n padding: 0 !important;\n font-family: $font-family-base;\n display: block;\n}\n\n:host(.nano-color) {\n --input-border-style--focus: #{$input-border-style} var(--nano-color-tint, #{nano-color(primary, tint)});\n --multi-input-value-bg: var(--nano-color-tint-rgb);\n --multi-input-value-border: var(--nano-color-shade);\n --multi-input-value-text-color: var(--nano-color-contrast);\n\n color: current-color(base);\n}\n\n:host-context(nano-item:not(.item-label)) {\n --padding-start: 0;\n}\n\n:host([disabled]:not([disabled='false'])) {\n * {\n pointer-events: none !important;\n }\n}\n\nselect {\n display: none;\n}\n\n.select__native-input {\n @include text-inherit();\n\n padding: unset;\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: 0;\n border-radius: var(--input-border-radius);\n text-overflow: ellipsis;\n color: var(--input-text-color);\n display: inline-block;\n flex: 1;\n width: 100%;\n max-width: 100%;\n max-height: 100%;\n border: 0;\n outline: none;\n background: transparent;\n appearance: none;\n margin: 0;\n box-sizing: border-box;\n resize: none;\n overflow: hidden;\n cursor: default;\n line-height: 2.5em;\n min-height: 2.5em;\n\n .has-float-label & {\n line-height: 2.1em;\n min-height: 2.1em;\n padding-block-start: 1.4em;\n }\n\n &::selection {\n background: transparent;\n }\n\n &::-moz-selection {\n background: transparent;\n }\n\n &::placeholder {\n color: var(--placeholder-color);\n font-family: inherit;\n font-style: var(--placeholder-font-style);\n font-weight: var(--placeholder-font-weight);\n opacity: var(--placeholder-opacity);\n line-height: inherit;\n min-height: initial;\n }\n\n &::-moz-placeholder {\n line-height: 2.8em;\n text-overflow: ellipsis;\n }\n\n &:-webkit-autofill {\n background-color: transparent;\n }\n\n &::-webkit-search-decoration,\n &::-webkit-search-cancel-button,\n &::-webkit-search-results-button,\n &::-webkit-search-results-decoration {\n appearance: none;\n }\n\n &:invalid {\n box-shadow: none;\n }\n\n &::-ms-clear,\n &::-ms-reveal {\n display: none;\n }\n\n &.resizable {\n resize: vertical;\n overflow: auto;\n }\n\n .form-ctrl__textarea & {\n line-height: 1.5em;\n padding-block: var(--padding-top) var(--padding-bottom);\n white-space: pre-wrap;\n\n &::placeholder {\n line-height: 1.5em;\n }\n }\n\n .has-float-label.textarea & {\n padding-block-start: 1.8em;\n }\n\n :host(.masked) & {\n opacity: 0;\n position: absolute;\n inset-inline-start: 0;\n inset-block-start: 0;\n }\n}\n\n.select__mask {\n @include text-inherit();\n\n padding-inline: var(--padding-start) var(--padding-end);\n padding-block: 0;\n border-radius: var(--input-border-radius);\n pointer-events: none;\n line-height: 2.5em;\n min-height: 2.5em;\n}\n\n// multi stuff\n\n.select__multi {\n &-wrap {\n padding-block-start: 0;\n padding-inline-end: 0;\n padding-block-end: var(--padding-bottom);\n padding-inline-start: 0;\n display: flex;\n flex: 1;\n flex-wrap: wrap;\n overflow: hidden;\n\n :host(.has-float-label) & {\n padding-block-start: 1em;\n }\n }\n\n &-input {\n @include text-inherit();\n\n padding-block-start: var(--padding-top);\n padding-inline-end: var(--padding-end);\n padding-block-end: 0;\n padding-inline-start: var(--padding-start);\n min-width: 50px;\n width: 100%;\n max-height: 100%;\n appearance: none;\n border: 0;\n outline: none;\n display: inline-block;\n background: transparent;\n flex: 0;\n position: relative;\n min-height: calc(2.5em - var(--padding-bottom));\n box-sizing: border-box;\n\n &:last-child {\n flex: 1;\n }\n }\n\n &-value {\n margin-block-start: var(--padding-bottom);\n margin-inline-start: var(--padding-start);\n margin-inline-end: -3px;\n background: rgba(var(--multi-input-value-bg), 0.8);\n color: var(--multi-input-value-text-color);\n border: 1px solid;\n border-color: var(--multi-input-value-border);\n padding: 0.35em 0.5em;\n line-height: 1;\n max-width: 100%;\n display: flex;\n align-items: center;\n font-size: var(--input-font-size);\n letter-spacing: 1px;\n\n span {\n text-overflow: ellipsis;\n white-space: nowrap;\n max-width: 100%;\n overflow: hidden;\n line-height: 1.2;\n }\n }\n\n &-value-remove {\n @include background-position(center);\n\n padding-inline-start: 0.5em;\n margin: 0;\n color: inherit;\n border: 0;\n outline: none;\n background-color: transparent;\n background-repeat: no-repeat;\n appearance: none;\n display: flex;\n align-items: center;\n inset-block-start: 0;\n font-size: 1em;\n\n nano-icon {\n --color: var(--multi-input-value-text-color);\n }\n }\n}\n\n.form-ctrl__float-label {\n width: calc(100% - (1em + (var(--padding-start) * 2)));\n\n :host(.has-focus.has-multiple) & {\n transform: translateY(-110%);\n font-size: 0.8em;\n }\n\n :host(.has-value.has-multiple) & {\n transform: translateY(21%);\n inset-block-start: 0;\n }\n}\n\n:host(.has-focus) select,\n:host(.has-focus) a,\n:host(.has-focus) button {\n pointer-events: auto;\n}\n","import {\n Build,\n Component,\n ComponentInterface,\n Element,\n Event,\n EventEmitter,\n Host,\n Method,\n Prop,\n State,\n Watch,\n h,\n VNode,\n Listen,\n} from '@stencil/core';\n\nimport { getActiveElement } from '../../utils/active-element';\nimport { closestElement } from '../../utils/dom';\nimport { createColorClasses } from '../../utils/theme';\nimport { debounce, debounceEvent } from '../../utils/throttle';\nimport { FormControl, FormControlWrap } from '../form-control/form-control';\nimport { OptionInterface } from '../option/option-interface';\nimport type { Dropdown } from '../dropdown/dropdown';\nimport type {\n Color,\n SelectChangeEventDetail,\n InputChangeEventDetail,\n ControlValidityEventDetail,\n ControlValidity,\n} from '../../interface';\n\nlet selectIds = 0;\n\n/**\n * The select component is a wrapper to the HTML select element with custom styling and additional functionality.\n * It accepts most of the same properties as the HTML [select](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select).\n * It's multi selection functionality is vastly improved from the native solution. It allows for the control of\n * value order through drag and drop or changing the insertion point with arrow keys. It also can allow for user defined values.\n *\n * @slot start - suitable for inline action buttons or icons that may add extra contextual information\n * @slot end - suitable for inline action buttons or icons that may add extra contextual information\n * @slot value-start - similar to 'start', however clicking elements using this slot will activate the input control. This would be suitable to show a secodary 'value' for context or to show a dropdown arrow if using a datalist\n * @slot value-end - similar to 'end', however clicking elements using this slot will activate the input control. This would be suitable to show a secodary 'value' for context or to show a dropdown arrow if using a datalist\n * @slot label - if you do not set a label attribute, you can use this slot for more complex markup\n * @slot helper - helper text to accompany the form field underneath.\n * @slot helper-end - helper text to accompany the form field on the side.\n * @slot down-arrow - use this to replace the default down arrow\n * @slot - default slot; nest `nano-option` elements\n */\n@Component({\n tag: 'nano-select',\n styleUrl: 'select.scss',\n scoped: true,\n})\nexport class Select implements ComponentInterface {\n private nativeSelect?: HTMLSelectElement;\n private valueItems: Array<HTMLSpanElement> = [];\n private dragVal: string;\n private mo?: MutationObserver;\n private selectId = `nano-select-${selectIds++}`;\n private rtl: boolean = false;\n private onInit: boolean = true;\n private customError: string = '';\n\n private get inputCtrl() {\n return this._inputCtrl;\n }\n private set inputCtrl(input) {\n if (input === this._inputCtrl) return;\n this._inputCtrl = input;\n this.setDataListOpts();\n }\n private _inputCtrl?: HTMLInputElement;\n\n // we don't want these rendered eles decorated with @State\n // because that will cause re-renders. Use get/set to set datalist options\n private _selectWrap: HTMLElement;\n private get selectWrap() {\n return this._selectWrap;\n }\n private set selectWrap(ele: HTMLElement) {\n if (this._selectWrap === ele) return;\n this._selectWrap = ele;\n this.setDataListOpts();\n }\n\n private _datalist: HTMLNanoDatalistElement;\n private get datalist() {\n return this._datalist;\n }\n private set datalist(ele: HTMLNanoDatalistElement) {\n if (this._datalist === ele) return;\n this._datalist = ele;\n this.setDataListOpts();\n }\n\n constructor() {\n this.showInlineValidation = debounce(this.showInlineValidation, 50);\n }\n\n @State() currInsertIndex: number = -1;\n @State() showErrorMsg = false;\n @State() errorMessage: string = '';\n @State() hasFocus = false;\n @State() hasLabelSlot: boolean = false;\n @State() hasHelperSlot: boolean = false;\n @State() hasHelperEndSlot = false;\n @State() inputSearchVal: string = '';\n\n @Element() el!: HTMLNanoSelectElement;\n\n /**\n * This will be true when the control is in an invalid state.\n * Validity is determined by the `required` prop. Or if custom validity message is set.\n */\n @Prop({ reflect: true })\n get invalid() {\n return this._invalid;\n }\n @State() _invalid = false;\n\n /**\n * Current validation message - if any. @readonly\n */\n @Prop()\n get validityMessage() {\n if (!this.nativeSelect) return '';\n return this.nativeSelect.validationMessage;\n }\n\n /**\n * The color to use from your application's color palette.\n * Default options are: `\"primary\"`, `\"secondary\"`, `\"tertiary\"`, `\"success\"`, `\"warning\"`, `\"danger\"`, `\"light\"`, `\"medium\"`, and `\"dark\"`.\n */\n @Prop() color?: Color;\n\n /**\n * This Boolean attribute lets you specify that a form control should have select focus when the page loads.\n */\n @Prop() autofocus = false;\n\n /**\n * If `true`, the user cannot interact with the select.\n */\n @Prop({ reflect: true }) disabled = false;\n\n /**\n * When should the field perform validation\n */\n @Prop({ mutable: true }) validateOn?: 'dirty' | 'submit' | 'submitThenDirty' =\n 'submitThenDirty';\n\n /**\n * Whether to show validation errors underneath input\n */\n @Prop({ reflect: true }) showInlineError = true;\n\n /**\n * String to place within a label element. Alternatively use the 'label' slot\n */\n @Prop() label!: string;\n\n /**\n * Visually hide the label - but make it accessible.\n */\n @Prop() hideLabel?: boolean = false;\n\n /**\n * Enable floating label behaviour. Will disable placeholder if set.\n */\n @Prop() floatLabel: boolean = false;\n\n /**\n * If `true`, the user can enter more than one value. This attribute applies when the type attribute is set to `\"email\"` or `\"file\"`, otherwise it is ignored.\n */\n @Prop() multiple?: boolean = false;\n\n /**\n * The name of the control, which is submitted with the form data.\n */\n @Prop() name: string = this.selectId + '-name';\n\n /**\n * Instructional text that shows before the select has a value. Text set here will be placed inside the label when a value is set. If you don't want this behaviour just set the first option to have no value.\n */\n @Prop() placeholder?: string | null;\n\n /**\n * If `true`, the user cannot modify the value.\n */\n @Prop({ reflect: true }) readonly = false;\n\n /**\n * If `true`, the user must fill in a value before submitting a form.\n */\n @Prop() required = false;\n\n /**\n * The initial size of the control.\n */\n @Prop() size?: number;\n\n /**\n * Maximum number of options that can be selected when multiple is true\n */\n @Prop() max?: number;\n\n /**\n * Minimum number of options that can be selected when multiple is true\n */\n @Prop() min?: number;\n\n /**\n * The form element to associate the select with (its form owner). Must be the id of a form.\n */\n @Prop() form?: string | null;\n\n /**\n * in multiple mode, allow users to enter their own values\n */\n @Prop() allowCustomValues: boolean = false;\n\n /**\n * The value of the select.\n */\n @Prop()\n get value() {\n return this._value;\n }\n set value(val: string | string[]) {\n if (typeof val === 'string') {\n if (this.multiple) this._value = val.split(',');\n else this._value = val;\n } else if (Array.isArray(val)) {\n if (this.multiple) this._value = val;\n else this._value = val[0];\n }\n }\n private _value: Array<string> | string = this.multiple ? [] : '';\n\n /**\n * You can set options via js as an array of strings: `domElement.options = ['option 1', 'option 2']` or\n * objects `domElement.options = [{label: 'option 1', value: 'opt-1'}]`. See `nano-option` docs for all available properties.\n * Alternatively, you can nest `<nano-option>` elements within a `<nano-select>`\n * Regardless - reading `options` will return the current component options - slotted or otherwise\n */\n @Prop()\n get options(): Array<OptionInterface | string> {\n if (this._options.length) return this._options;\n\n if (!this.datalist || !this.datalist.activeOptions) return [];\n\n return this._eOptions.map((ao) => {\n const { value, selected, label, filterMeta } = ao;\n return { value, selected, label, filterMeta };\n });\n }\n set options(opts: Array<OptionInterface | string>) {\n this._options = opts.map((opt) => {\n if (typeof opt === 'string') return { value: opt, label: opt };\n else return opt;\n });\n }\n private _options: OptionInterface[] = [];\n @State() _eOptions: OptionInterface[] = [];\n\n /**\n * If `true`, a clear icon will appear in the select when there is a value. Clicking it clears the select.\n */\n @Prop() clearSelect = false;\n\n /**\n * Hide the native select element and cover with a value 'mask'.\n * Enables a fluid nano-select width upon value change (if required). Doesn't work with multiple=\"true\".\n */\n @Prop() mask = false;\n\n /**\n * Set the amount of time, in milliseconds, to wait to trigger the `nanoSearchChange` event after each keystroke.\n */\n @Prop() debounce = 0;\n\n @Watch('debounce')\n protected debounceChanged() {\n this.nanoSearchChange = debounceEvent(this.nanoSearchChange, this.debounce);\n }\n\n @Watch('required')\n @Watch('disabled')\n @Watch('min')\n @Watch('max')\n @Watch('readonly')\n protected shouldValidate() {\n if (this.onInit) return;\n if (this.invalid) this.showErrorMsg = this._invalid = false;\n\n this.customValidate();\n if (this.validateOn !== 'dirty') return;\n this.showInlineValidation();\n }\n\n /**\n * Update the native select element when the value changes\n */\n // eslint-disable-next-line @stencil/no-unused-watch\n @Watch('value')\n valueChanged() {\n this.customValidate();\n\n if (this.onInit) {\n if (this.multiple) this.currInsertIndex = this.value.length - 1;\n return;\n }\n requestAnimationFrame(() => {\n this.shouldValidate();\n this.nanoChange.emit({ value: this.value });\n });\n }\n\n /** nano-dropdown config options you can pass to the nested dropdown component */\n @Prop({ mutable: true }) dropDownConfig?: Partial<Dropdown> = {};\n\n @Watch('dropDownConfig')\n setDataListOpts() {\n if (!this.datalist || !this.selectWrap) return;\n\n this.datalist.input = this.inputCtrl;\n\n const currDWConfig = this.datalist.dropDownConfig || {};\n this.datalist.dropDownConfig = {\n ...currDWConfig,\n ...this.dropDownConfig,\n tetherTo: this.selectWrap,\n };\n }\n\n // Custom Events\n\n /**\n * Emitted when the value has changed.\n */\n @Event() nanoChange!: EventEmitter<SelectChangeEventDetail>;\n\n /**\n * Emitted when the select loses focus.\n */\n @Event() nanoBlur!: EventEmitter<void>;\n\n /**\n * Emitted when the select has focus.\n */\n @Event() nanoFocus!: EventEmitter<void>;\n\n /**\n * Emitted when the select has been created.\n * @internal\n */\n @Event() nanoDidLoad!: EventEmitter<void>;\n\n /**\n * Emitted when the select has been removed.\n * @internal\n */\n @Event() nanoDidUnload!: EventEmitter<void>;\n\n /**\n * Emitted when a keyboard input occurred on a multiple=\"true\" input\n */\n @Event() nanoSearchChange!: EventEmitter<InputChangeEventDetail>;\n\n /**\n * Called when validation is performed (which depends on `validateOn`).\n * @returns event.detail: `{ isValid: boolean, errorMessage: string, originalEvent: Event }`.\n */\n @Event() nanoValidate: EventEmitter<ControlValidityEventDetail>;\n\n // Public Methods\n\n /**\n * Get the current state of the control.\n * @param validateFirst - perform validation first before reporting\n * @returns `{ isValid: boolean, errorMessage: string }`\n */\n @Method()\n async reportValidity(validateFirst: boolean): Promise<ControlValidity> {\n return new Promise((resolve) => {\n if (validateFirst) {\n this.customValidate();\n this.showInlineValidation();\n }\n setTimeout(() => {\n resolve({\n isValid: !this._invalid,\n errorMessage: this.nativeSelect.validationMessage,\n });\n }, 50);\n });\n }\n\n /**\n * Sets focus on the specified `nano-select`. Use this method instead of the global\n * `select.focus()`.\n */\n @Method()\n async setFocus() {\n if (!this.inputCtrl) return;\n this.inputCtrl.focus();\n setTimeout(() => this.inputCtrl.click(), 50);\n }\n\n /**\n * @returns the native `<select>` element used under the hood.\n */\n @Method()\n getSelectElement(): Promise<HTMLSelectElement> {\n return Promise.resolve(this.nativeSelect!);\n }\n\n /**\n * Invalidate the field and show a custom error message.\n * To clear the error you will need to re-call this method with an empty string.\n */\n @Method()\n async showError(message: string) {\n if (this.nativeSelect) {\n this.customError = message;\n this.nativeSelect.setCustomValidity(message);\n this.showInlineValidation();\n }\n }\n\n /* Logic */\n\n private get valArray() {\n return typeof this.value === 'string'\n ? this.value.length\n ? [this.value]\n : []\n : this.value;\n }\n\n private isValidValues() {\n return this.valArray.find((val) =>\n (this.options as OptionInterface[]).find((opt) => opt.value === val)\n );\n }\n\n private customValidate = () => {\n if (!this.nativeSelect || !!this.customError) return;\n\n this.nativeSelect.setCustomValidity('');\n // add custom validations 'cos html5 validations are a bit rubbish on selects\n if (this.required && !this.valArray.length) {\n this.nativeSelect.setCustomValidity('Please fill in this field.');\n return true;\n }\n if (\n this.valArray.length &&\n !this.allowCustomValues &&\n !this.isValidValues()\n ) {\n this.nativeSelect.setCustomValidity(\n 'Please choose an item from this field.'\n );\n return true;\n }\n if (this.max && this.valArray.length > this.max) {\n this.nativeSelect.setCustomValidity(\n `Only up to ${this.max} values are allowed.`\n );\n return true;\n }\n if (this.min && this.valArray.length < this.min) {\n this.nativeSelect.setCustomValidity(\n `You must select a minimum of ${this.min} values.`\n );\n return true;\n }\n return false;\n };\n\n private showInlineValidation = (ev?: Event) => {\n if (this.validateOn === 'submitThenDirty') this.validateOn = 'dirty';\n\n this._invalid = false;\n this.showErrorMsg = false;\n this.errorMessage = '';\n\n if (!this.nativeSelect.validity.valid) {\n this.errorMessage = this.nativeSelect.validationMessage;\n this._invalid = true;\n this.showErrorMsg = true;\n }\n this.nanoValidate.emit({\n isValid: !this.invalid,\n errorMessage: this.errorMessage,\n originalEvent: ev,\n });\n };\n\n private handleInvalid = (ev: Event) => {\n this._invalid = true;\n\n if (this.validateOn === 'submit') {\n this._invalid = this.showErrorMsg = this.customValidate();\n }\n if (this.showInlineError) ev.preventDefault();\n\n requestAnimationFrame(() => this.showInlineValidation(ev));\n };\n\n private setValue = (e: CustomEvent<HTMLNanoOptionElement>) => {\n e.preventDefault();\n\n if (!this.multiple) {\n this.value = e.detail.value;\n return;\n }\n if (this.value && this.value.length && this.value.includes(e.detail.value))\n return;\n if (this.max && this.value.length === this.max) return;\n\n this.currInsertIndex++;\n this.value = [\n ...this.value.slice(0, this.currInsertIndex),\n e.detail.value,\n ...this.value.slice(this.currInsertIndex),\n ];\n this.inputSearchVal = '';\n // this.selectWrap.clientWidth; // force reflow\n };\n\n private removeValue = (toFind?: string) => {\n if (!this.multiple || !this.value.length) return;\n\n if (!toFind) toFind = this.value[this.value.length - 1];\n this.value = (this.value as Array<string>).filter((val) => val !== toFind);\n\n this.currInsertIndex--;\n // this.selectWrap.clientWidth; // force reflow\n this.setFocus();\n };\n\n private slotChangeObserver() {\n const mo = (this.mo = new MutationObserver(() =>\n this.processSlottedContent()\n ));\n mo.observe(this.el, { childList: true, subtree: true });\n }\n\n private processSlottedContent() {\n // see if we have label / helper content\n this.hasLabelSlot = !!this.el.querySelectorAll('[slot=\"label\"]').length;\n this.hasHelperSlot = !!this.el.querySelector('[slot=\"helper\"]');\n this.hasHelperEndSlot = !!this.el.querySelector('[slot=\"helper-end\"]');\n }\n\n private getLabel(toFind: string) {\n const label = (this.options as OptionInterface[]).find((opt) => {\n return !opt.disabled && opt.value?.length && opt.value === toFind;\n });\n return label && label.label ? label.label : toFind;\n }\n\n /* Event handling */\n\n @Listen('reset', { target: 'body' })\n onReset(e) {\n const form = this.form\n ? document.querySelector('#' + this.form)\n : this.el.closest('form');\n if (!form || e.target !== this.el.closest('form')) return;\n\n this.clearSelectValue();\n }\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 target: Element;\n\n requestAnimationFrame(() => {\n if (kev.key) {\n if (kev.key !== 'Tab') return;\n target = getActiveElement();\n } else target = e.target as Element;\n\n if (closestElement(this.el.tagName.toLowerCase(), target) !== this.el) {\n this.onBlur();\n }\n });\n }\n\n private setOptions = () => {\n if (\n !this.datalist ||\n !this.datalist.activeOptions ||\n !this.datalist.activeOptions.length\n )\n return;\n\n this._eOptions = this.datalist.activeOptions.map((ao) => {\n const { value, selected, label, filterMeta } = ao;\n return { value, selected, label, filterMeta };\n });\n this.customValidate();\n };\n\n private handleDocumentKeyDown = (ev: KeyboardEvent) => {\n if (!this.multiple || !this.hasFocus) return;\n\n if (!this.inputSearchVal) {\n let rm: HTMLSpanElement;\n\n switch (ev.key) {\n case 'Backspace':\n if (this.inputCtrl.previousElementSibling)\n rm = this.inputCtrl.previousElementSibling as HTMLSpanElement;\n else break;\n\n this.removeValue(rm.dataset.value || null);\n break;\n\n case 'Delete':\n if (this.inputCtrl.nextElementSibling)\n rm = this.inputCtrl.nextElementSibling as HTMLSpanElement;\n else break;\n\n this.removeValue(rm.dataset.value || null);\n break;\n\n case 'ArrowLeft':\n case 'ArrowRight':\n if (!this.value.length) break;\n\n if (ev.key === 'ArrowLeft' && this.inputCtrl.previousSibling)\n this.currInsertIndex--;\n if (ev.key === 'ArrowRight' && this.inputCtrl.nextSibling)\n this.currInsertIndex++;\n\n setTimeout(() => {\n this.inputCtrl.focus();\n }, 20);\n ev.preventDefault();\n break;\n }\n }\n };\n\n private onBlur = () => {\n this.hasFocus = false;\n\n requestAnimationFrame(() => {\n if (this.validateOn === 'dirty' && !this.hasFocus)\n this.showInlineValidation();\n });\n this.nanoBlur.emit();\n\n if (!this.allowCustomValues && this.multiple) {\n this.inputSearchVal = '';\n const event = new window.Event('change');\n this.inputCtrl.dispatchEvent(event);\n }\n };\n\n private onFocus = () => {\n this.hasFocus = true;\n this.nanoFocus.emit();\n };\n\n private clearSelectValue = (ev?: Event) => {\n if (this.clearSelect && !this.readonly && !this.disabled && ev) {\n ev.preventDefault();\n ev.stopPropagation();\n }\n\n if (this.multiple) {\n this.value = [];\n this.currInsertIndex = -1;\n } else this.value = '';\n\n this.inputCtrl.value = '';\n const event = new window.Event('change');\n this.inputCtrl.dispatchEvent(event);\n };\n\n private onClick = () => {\n this.setFocus();\n };\n\n /* Multi event handlers */\n\n private onDragStart = (ev: MouseEvent) => {\n const ele = ev.target as HTMLSpanElement;\n this.dragVal = ele.dataset.value;\n };\n\n private onDragEnd = (ev) => {\n this.dragVal = null;\n ev.preventDefault();\n };\n\n private onDragLeave = (ev: MouseEvent) => {\n const ele = ev.target as HTMLSpanElement;\n const spanVal: string =\n ele.dataset && ele.dataset.value ? ele.dataset.value : null;\n\n if (\n !spanVal ||\n this.dragVal === spanVal ||\n !this.value.includes(this.dragVal)\n ) {\n ev.preventDefault();\n return;\n }\n\n const to = this.value.indexOf(spanVal);\n const from = this.value.indexOf(this.dragVal);\n const tmpArr = this.value as Array<string>;\n const tmpVal = tmpArr[to];\n\n tmpArr[to] = tmpArr[from];\n tmpArr[from] = tmpVal;\n this.value = [...tmpArr];\n };\n\n private onMultiInput = (ev) => {\n this.inputSearchVal = ev.target.value.trim();\n this.nanoSearchChange.emit({ value: ev.target.value.trim() });\n };\n\n /* Stencil Component lifecycle hooks */\n\n connectedCallback() {\n this.debounceChanged();\n\n if (!Build.isBrowser) return;\n\n this.el.dispatchEvent(\n new CustomEvent('nanoDidLoad', {\n detail: this.el,\n })\n );\n }\n\n disconnectedCallback() {\n document.dispatchEvent(\n new CustomEvent('nanoDidUnload', {\n detail: this.el,\n })\n );\n\n if (!Build.isBrowser) return;\n if (this.mo) this.mo.disconnect();\n }\n\n componentDidLoad() {\n this.slotChangeObserver();\n this.customValidate();\n this.setDataListOpts();\n requestAnimationFrame(() => (this.onInit = false));\n }\n\n componentWillLoad() {\n this.processSlottedContent();\n }\n\n render() {\n const labelId = this.selectId + '-lbl';\n const moreId =\n this.showInlineError || this.hasHelperSlot\n ? this.selectId + '-moreId'\n : '';\n const helperEndId = this.hasHelperEndSlot ? this.selectId + '-helper' : '';\n\n this.rtl = (this.el.ownerDocument as Document).dir === 'rtl';\n this.valueItems = [];\n\n const compWrapOptions = (({\n el,\n floatLabel,\n label,\n errorMessage,\n showInlineError,\n hasHelperSlot,\n hasHelperEndSlot,\n hasLabelSlot,\n hideLabel,\n placeholder,\n rtl,\n }) => ({\n el,\n floatLabel,\n label,\n errorMessage,\n showInlineError,\n hasHelperSlot,\n hasHelperEndSlot,\n hasLabelSlot,\n hideLabel,\n placeholder,\n rtl,\n }))(this);\n const wrapOptions = {\n ...compWrapOptions,\n labelId,\n moreId,\n helperEndId,\n hasValue: !!this.value.length || !!this.inputSearchVal.length,\n controlId: this.selectId,\n };\n\n const controlOptions = (({ readonly, disabled }) => ({\n readonly,\n disabled,\n clearControl: this.clearSelect,\n }))(this);\n\n return (\n <Host\n type={this.multiple ? 'select-multiple' : 'select-one'}\n aria-disabled={this.disabled ? 'true' : null}\n class={{\n ...createColorClasses(this.color),\n 'has-value': !!this.value.length || !!this.inputSearchVal.length,\n 'has-focus': this.hasFocus,\n 'is-invalid': this.invalid,\n 'has-label': this.label !== null && !this.floatLabel,\n 'has-float-label': this.label !== null && this.floatLabel,\n rtl: this.rtl,\n 'has-multiple': this.multiple,\n 'has-clr-btn': this.clearSelect,\n masked: this.mask,\n }}\n >\n <FormControlWrap {...wrapOptions}>\n <FormControl\n {...controlOptions}\n onClearText={this.clearSelectValue}\n control={this.el}\n ref={(el) => (this.selectWrap = el)}\n endValueSlot={\n <slot name=\"down-arrow\">\n <nano-icon slot=\"value-end\" name=\"light/chevron-down\" />\n </slot>\n }\n >\n {this.multiple && (\n <div class=\"select__multi-wrap select\">\n {this.multipleValues(labelId, moreId, helperEndId)}\n </div>\n )}\n {!this.multiple && [\n this.mask && (\n <div class=\"select__mask\">\n {this.getLabel(this.value as string)}\n </div>\n ),\n <input\n id={this.selectId}\n class=\"select__native-input\"\n ref={(input) => (this.inputCtrl = input)}\n aria-labelledby={labelId + ' ' + moreId + ' ' + helperEndId}\n disabled={this.disabled}\n form={this.form}\n placeholder={this.placeholder}\n readOnly={true}\n required={this.required}\n value={this.getLabel(this.value as string)}\n onFocus={this.onFocus}\n />,\n ]}\n </FormControl>\n </FormControlWrap>\n {!this.readonly && !this.disabled && (\n <nano-datalist\n onNanoOptionsUpdated={this.setOptions}\n ref={(el) => (this.datalist = el)}\n selected={this.valArray}\n type={this.multiple ? 'selctMulti' : 'select'}\n onNanoSelect={this.setValue}\n onNanoDeselect={(e) => {\n e.preventDefault();\n this.removeValue(e.detail.value);\n }}\n options={this._options.length ? this._options : undefined}\n >\n {this.allowCustomValues && this.multiple && !!this.inputSearchVal && (\n <nano-option\n slot=\"list-top\"\n value={this.inputSearchVal}\n selected={false}\n label={this.inputSearchVal}\n onNanoSelect={() => this.inputCtrl.focus()}\n >\n <span slot=\"check-icon\"></span>\n Add '{this.inputSearchVal}'\n </nano-option>\n )}\n <slot />\n </nano-datalist>\n )}\n\n <select\n id={this.selectId + '-hidden'}\n class=\"select__native-ctrl\"\n ref={(select) => (this.nativeSelect = select)}\n aria-labelledby={labelId + ' ' + moreId + ' ' + helperEndId}\n disabled={this.disabled}\n form={this.form}\n multiple={this.multiple}\n name={this.name}\n required={this.required}\n onInvalid={this.handleInvalid}\n >\n {this.allowCustomValues &&\n this.valArray.map((val) => {\n return (\n <option value={val} selected={true}>\n {val}\n </option>\n );\n })}\n {!this.allowCustomValues &&\n this.options.map((opt: OptionInterface) => {\n return (\n <option\n value={opt.value}\n selected={this.valArray.includes(opt.value)}\n disabled={opt.disabled}\n label={opt.label}\n >\n {this.valArray.includes(opt.value)}\n </option>\n );\n })}\n </select>\n </Host>\n );\n }\n\n private multipleValues(\n labelId: string,\n moreId: string,\n helperEndId: string\n ): VNode | (VNode | VNode[])[] {\n const input: VNode = (\n <input\n class=\"select__multi-input\"\n id={this.selectId}\n ref={(input) => (this.inputCtrl = input)}\n readOnly={this.readonly}\n disabled={this.disabled}\n autoFocus={this.autofocus}\n autocomplete=\"off\"\n onKeyDown={this.handleDocumentKeyDown}\n onInput={this.onMultiInput}\n value={this.inputSearchVal}\n onTouchStart={this.onClick}\n onMouseDown={this.onClick}\n onFocus={this.onFocus}\n placeholder={\n this.placeholder && !this.value.length ? this.placeholder : ''\n }\n aria-labelledby={labelId + ' ' + moreId + ' ' + helperEndId}\n />\n );\n if (!this.value.length) return input;\n\n return (this.value as Array<string>).map((val, i) => {\n let toReturn: VNode | VNode[] = (\n <span\n onDragStart={this.onDragStart}\n onDragLeave={this.onDragLeave}\n onDragEnd={this.onDragEnd}\n onDragOver={(e) => e.preventDefault()}\n draggable\n data-value={val}\n ref={(span) => this.valueItems.push(span)}\n class=\"select__multi-value\"\n >\n <span>{this.getLabel(val)}</span>\n <button\n class=\"select__multi-value-remove\"\n type=\"button\"\n tabindex=\"-1\"\n onTouchEnd={() => {\n this.removeValue(val);\n }}\n onMouseUp={() => {\n this.removeValue(val);\n }}\n >\n <nano-icon name=\"light/times\"></nano-icon>\n </button>\n </span>\n );\n if (i === 0 && this.currInsertIndex < 0)\n toReturn = [input, toReturn as VNode];\n else if (i === this.currInsertIndex)\n toReturn = [toReturn as VNode, input];\n return toReturn;\n });\n }\n}\n"]}