@roadtrip/components 3.11.0 → 3.11.2

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 (635) hide show
  1. package/dist/cjs/{focus-visible-6771892b.js → focus-visible-6f34b3f4.js} +1 -1
  2. package/dist/cjs/focus-visible-6f34b3f4.js.map +1 -0
  3. package/dist/cjs/{index-e4bd5b5f.js → index-12592729.js} +411 -207
  4. package/dist/cjs/index-12592729.js.map +1 -0
  5. package/dist/cjs/{index-fd07207a.js → index-fb57f684.js} +1 -1
  6. package/dist/cjs/index-fb57f684.js.map +1 -0
  7. package/dist/cjs/index.cjs.js +3 -3
  8. package/dist/cjs/loader.cjs.js +3 -29
  9. package/dist/cjs/loader.cjs.js.map +1 -1
  10. package/dist/cjs/{polyfill-9453e116.js → polyfill-b1fff766.js} +2 -2
  11. package/dist/cjs/polyfill-b1fff766.js.map +1 -0
  12. package/dist/cjs/road-accordion.cjs.entry.js +3 -3
  13. package/dist/cjs/road-accordion.cjs.entry.js.map +1 -1
  14. package/dist/cjs/road-alert.cjs.entry.js +1 -1
  15. package/dist/cjs/road-alert.cjs.entry.js.map +1 -1
  16. package/dist/cjs/road-area-code.cjs.entry.js +9 -13
  17. package/dist/cjs/road-area-code.cjs.entry.js.map +1 -1
  18. package/dist/cjs/road-autocomplete.cjs.entry.js +1 -1
  19. package/dist/cjs/road-autocomplete.cjs.entry.js.map +1 -1
  20. package/dist/cjs/road-avatar.cjs.entry.js +1 -1
  21. package/dist/cjs/road-avatar.cjs.entry.js.map +1 -1
  22. package/dist/cjs/road-badge_14.cjs.entry.js +7 -12
  23. package/dist/cjs/road-badge_14.cjs.entry.js.map +1 -1
  24. package/dist/cjs/road-banner.cjs.entry.js +2 -2
  25. package/dist/cjs/road-banner.cjs.entry.js.map +1 -1
  26. package/dist/cjs/road-button-floating.cjs.entry.js +2 -2
  27. package/dist/cjs/road-button-floating.cjs.entry.js.map +1 -1
  28. package/dist/cjs/road-card.cjs.entry.js +1 -1
  29. package/dist/cjs/road-card.cjs.entry.js.map +1 -1
  30. package/dist/cjs/road-carousel-item.cjs.entry.js +1 -1
  31. package/dist/cjs/road-carousel-item.cjs.entry.js.map +1 -1
  32. package/dist/cjs/road-carousel.cjs.entry.js +2 -2
  33. package/dist/cjs/road-carousel.cjs.entry.js.map +1 -1
  34. package/dist/cjs/road-checkbox.cjs.entry.js +3 -3
  35. package/dist/cjs/road-checkbox.cjs.entry.js.map +1 -1
  36. package/dist/cjs/road-chip.cjs.entry.js +3 -3
  37. package/dist/cjs/road-chip.cjs.entry.js.map +1 -1
  38. package/dist/cjs/road-collapse.cjs.entry.js +1 -1
  39. package/dist/cjs/road-collapse.cjs.entry.js.map +1 -1
  40. package/dist/cjs/road-dialog.cjs.entry.js +2 -2
  41. package/dist/cjs/road-dialog.cjs.entry.js.map +1 -1
  42. package/dist/cjs/road-dropdown.cjs.entry.js +1 -1
  43. package/dist/cjs/road-dropdown.cjs.entry.js.map +1 -1
  44. package/dist/cjs/road-duration.cjs.entry.js +1 -1
  45. package/dist/cjs/road-duration.cjs.entry.js.map +1 -1
  46. package/dist/cjs/road-flap.cjs.entry.js +1 -1
  47. package/dist/cjs/road-flap.cjs.entry.js.map +1 -1
  48. package/dist/cjs/road-global-navigation.cjs.entry.js +2 -2
  49. package/dist/cjs/road-global-navigation.cjs.entry.js.map +1 -1
  50. package/dist/cjs/road-illustration.cjs.entry.js +2 -2
  51. package/dist/cjs/road-illustration.cjs.entry.js.map +1 -1
  52. package/dist/cjs/road-img.cjs.entry.js +1 -1
  53. package/dist/cjs/road-img.cjs.entry.js.map +1 -1
  54. package/dist/cjs/road-modal.cjs.entry.js +2 -2
  55. package/dist/cjs/road-modal.cjs.entry.js.map +1 -1
  56. package/dist/cjs/road-navbar-item.cjs.entry.js +1 -1
  57. package/dist/cjs/road-navbar-item.cjs.entry.js.map +1 -1
  58. package/dist/cjs/road-navbar.cjs.entry.js +2 -2
  59. package/dist/cjs/road-navbar.cjs.entry.js.map +1 -1
  60. package/dist/cjs/road-phone-number-input.cjs.entry.js +22 -16
  61. package/dist/cjs/road-phone-number-input.cjs.entry.js.map +1 -1
  62. package/dist/cjs/road-plate-number.cjs.entry.js +2 -2
  63. package/dist/cjs/road-plate-number.cjs.entry.js.map +1 -1
  64. package/dist/cjs/road-profil-dropdown.cjs.entry.js +1 -1
  65. package/dist/cjs/road-profil-dropdown.cjs.entry.js.map +1 -1
  66. package/dist/cjs/road-progress-indicator-horizontal.cjs.entry.js +1 -1
  67. package/dist/cjs/road-progress-indicator-horizontal.cjs.entry.js.map +1 -1
  68. package/dist/cjs/road-progress-indicator-vertical-item.cjs.entry.js +1 -1
  69. package/dist/cjs/road-progress-indicator-vertical-item.cjs.entry.js.map +1 -1
  70. package/dist/cjs/road-progress-indicator-vertical.cjs.entry.js +1 -1
  71. package/dist/cjs/road-progress-indicator-vertical.cjs.entry.js.map +1 -1
  72. package/dist/cjs/road-progress-tracker-item.cjs.entry.js +1 -1
  73. package/dist/cjs/road-progress-tracker-item.cjs.entry.js.map +1 -1
  74. package/dist/cjs/road-progress-tracker.cjs.entry.js +1 -1
  75. package/dist/cjs/road-progress-tracker.cjs.entry.js.map +1 -1
  76. package/dist/cjs/road-progress.cjs.entry.js +1 -1
  77. package/dist/cjs/road-progress.cjs.entry.js.map +1 -1
  78. package/dist/cjs/road-radio-group.cjs.entry.js +1 -1
  79. package/dist/cjs/road-radio-group.cjs.entry.js.map +1 -1
  80. package/dist/cjs/road-radio.cjs.entry.js +2 -2
  81. package/dist/cjs/road-radio.cjs.entry.js.map +1 -1
  82. package/dist/cjs/road-range.cjs.entry.js +2 -2
  83. package/dist/cjs/road-range.cjs.entry.js.map +1 -1
  84. package/dist/cjs/road-rating.cjs.entry.js +2 -2
  85. package/dist/cjs/road-rating.cjs.entry.js.map +1 -1
  86. package/dist/cjs/road-segmented-button-bar.cjs.entry.js +2 -2
  87. package/dist/cjs/road-segmented-button-bar.cjs.entry.js.map +1 -1
  88. package/dist/cjs/road-segmented-button.cjs.entry.js +1 -1
  89. package/dist/cjs/road-segmented-button.cjs.entry.js.map +1 -1
  90. package/dist/cjs/road-segmented-buttons.cjs.entry.js +1 -1
  91. package/dist/cjs/road-segmented-buttons.cjs.entry.js.map +1 -1
  92. package/dist/cjs/road-select-filter.cjs.entry.js +1 -1
  93. package/dist/cjs/road-select-filter.cjs.entry.js.map +1 -1
  94. package/dist/cjs/road-select.cjs.entry.js +2 -2
  95. package/dist/cjs/road-select.cjs.entry.js.map +1 -1
  96. package/dist/cjs/road-skeleton.cjs.entry.js +1 -1
  97. package/dist/cjs/road-skeleton.cjs.entry.js.map +1 -1
  98. package/dist/cjs/road-spinner.cjs.entry.js +1 -1
  99. package/dist/cjs/road-spinner.cjs.entry.js.map +1 -1
  100. package/dist/cjs/road-switch.cjs.entry.js +2 -2
  101. package/dist/cjs/road-switch.cjs.entry.js.map +1 -1
  102. package/dist/cjs/road-tab-bar.cjs.entry.js +2 -2
  103. package/dist/cjs/road-tab-bar.cjs.entry.js.map +1 -1
  104. package/dist/cjs/road-tab-button.cjs.entry.js +1 -1
  105. package/dist/cjs/road-tab-button.cjs.entry.js.map +1 -1
  106. package/dist/cjs/road-tab.cjs.entry.js +1 -1
  107. package/dist/cjs/road-tab.cjs.entry.js.map +1 -1
  108. package/dist/cjs/road-table.cjs.entry.js +1 -1
  109. package/dist/cjs/road-table.cjs.entry.js.map +1 -1
  110. package/dist/cjs/road-tabs.cjs.entry.js +1 -1
  111. package/dist/cjs/road-tabs.cjs.entry.js.map +1 -1
  112. package/dist/cjs/road-tag.cjs.entry.js +2 -2
  113. package/dist/cjs/road-tag.cjs.entry.js.map +1 -1
  114. package/dist/cjs/road-text.cjs.entry.js +1 -1
  115. package/dist/cjs/road-text.cjs.entry.js.map +1 -1
  116. package/dist/cjs/road-textarea.cjs.entry.js +1 -1
  117. package/dist/cjs/road-textarea.cjs.entry.js.map +1 -1
  118. package/dist/cjs/road-toast.cjs.entry.js +2 -2
  119. package/dist/cjs/road-toast.cjs.entry.js.map +1 -1
  120. package/dist/cjs/road-toggle.cjs.entry.js +2 -2
  121. package/dist/cjs/road-toggle.cjs.entry.js.map +1 -1
  122. package/dist/cjs/road-toolbar-title-page.cjs.entry.js +1 -1
  123. package/dist/cjs/road-toolbar-title-page.cjs.entry.js.map +1 -1
  124. package/dist/cjs/road-toolbar-title.cjs.entry.js +1 -1
  125. package/dist/cjs/road-toolbar-title.cjs.entry.js.map +1 -1
  126. package/dist/cjs/road-tooltip.cjs.entry.js +1 -1
  127. package/dist/cjs/road-tooltip.cjs.entry.js.map +1 -1
  128. package/dist/cjs/roadtrip.cjs.js +6 -103
  129. package/dist/cjs/roadtrip.cjs.js.map +1 -1
  130. package/dist/cjs/{utils-5203d152.js → utils-8db00648.js} +2 -2
  131. package/dist/cjs/utils-8db00648.js.map +1 -0
  132. package/dist/cjs/{utils-a450bad3.js → utils-90ef554a.js} +2 -2
  133. package/dist/cjs/utils-90ef554a.js.map +1 -0
  134. package/dist/collection/collection-manifest.json +74 -74
  135. package/dist/collection/components/accordion/accordion.js +3 -3
  136. package/dist/collection/components/alert/alert.js +3 -2
  137. package/dist/collection/components/alert/alert.js.map +1 -1
  138. package/dist/collection/components/area-code/area-code.js +19 -38
  139. package/dist/collection/components/area-code/area-code.js.map +1 -1
  140. package/dist/collection/components/autocomplete/autocomplete.js +3 -2
  141. package/dist/collection/components/autocomplete/autocomplete.js.map +1 -1
  142. package/dist/collection/components/avatar/avatar.js +1 -1
  143. package/dist/collection/components/badge/badge.js +3 -2
  144. package/dist/collection/components/badge/badge.js.map +1 -1
  145. package/dist/collection/components/banner/banner.js +4 -3
  146. package/dist/collection/components/banner/banner.js.map +1 -1
  147. package/dist/collection/components/button/button.js +2 -2
  148. package/dist/collection/components/button-floating/button-floating.js +2 -2
  149. package/dist/collection/components/card/card.js +1 -1
  150. package/dist/collection/components/carousel/carousel.js +34 -18
  151. package/dist/collection/components/carousel/carousel.js.map +1 -1
  152. package/dist/collection/components/carousel-item/carousel-item.js +1 -1
  153. package/dist/collection/components/checkbox/checkbox.js +3 -3
  154. package/dist/collection/components/chip/chip.js +3 -3
  155. package/dist/collection/components/col/col.js +1 -1
  156. package/dist/collection/components/collapse/collapse.js +1 -1
  157. package/dist/collection/components/counter/counter.js +1 -1
  158. package/dist/collection/components/dialog/dialog.js +8 -5
  159. package/dist/collection/components/dialog/dialog.js.map +1 -1
  160. package/dist/collection/components/drawer/{drawer.light.css → drawer.css} +0 -1
  161. package/dist/collection/components/drawer/drawer.js +11 -11
  162. package/dist/collection/components/drawer/drawer.js.map +1 -1
  163. package/dist/collection/components/drawer/drawer.stories.js +6 -7
  164. package/dist/collection/components/dropdown/dropdown.js +1 -1
  165. package/dist/collection/components/duration/duration.js +5 -3
  166. package/dist/collection/components/duration/duration.js.map +1 -1
  167. package/dist/collection/components/flap/flap.js +1 -1
  168. package/dist/collection/components/global-navigation/global-navigation.js +2 -2
  169. package/dist/collection/components/grid/grid.js +1 -1
  170. package/dist/collection/components/icon/icon.js +5 -4
  171. package/dist/collection/components/icon/icon.js.map +1 -1
  172. package/dist/collection/components/icon/request.js +1 -1
  173. package/dist/collection/components/icon/svg/vehicle-car-search-color.svg +1 -1
  174. package/dist/collection/components/icon/utils.js +1 -1
  175. package/dist/collection/components/icon/validate.js +1 -1
  176. package/dist/collection/components/illustration/illustration.js +3 -3
  177. package/dist/collection/components/illustration/request.js +1 -1
  178. package/dist/collection/components/illustration/utils.js +1 -1
  179. package/dist/collection/components/illustration/validate.js +1 -1
  180. package/dist/collection/components/img/img.js +1 -1
  181. package/dist/collection/components/input/input.js +9 -5
  182. package/dist/collection/components/input/input.js.map +1 -1
  183. package/dist/collection/components/input-group/input-group.js +1 -1
  184. package/dist/collection/components/item/item.js +2 -2
  185. package/dist/collection/components/label/label.js +1 -1
  186. package/dist/collection/components/list/list.js +1 -1
  187. package/dist/collection/components/modal/modal.js +6 -4
  188. package/dist/collection/components/modal/modal.js.map +1 -1
  189. package/dist/collection/components/navbar/navbar.js +2 -2
  190. package/dist/collection/components/navbar-item/navbar-item.js +1 -1
  191. package/dist/collection/components/phone-number-input/phone-number-input.js +27 -19
  192. package/dist/collection/components/phone-number-input/phone-number-input.js.map +1 -1
  193. package/dist/collection/components/plate-number/plate-number.js +6 -4
  194. package/dist/collection/components/plate-number/plate-number.js.map +1 -1
  195. package/dist/collection/components/profil-dropdown/profil-dropdown.js +1 -1
  196. package/dist/collection/components/progress/progress.js +1 -1
  197. package/dist/collection/components/progress-indicator-horizontal/progress-indicator-horizontal.js +1 -1
  198. package/dist/collection/components/progress-indicator-vertical/progress-indicator-vertical.js +1 -1
  199. package/dist/collection/components/progress-indicator-vertical-item/progress-indicator-vertical-item.js +1 -1
  200. package/dist/collection/components/progress-tracker/progress-tracker.js +1 -1
  201. package/dist/collection/components/progress-tracker-item/progress-tracker-item.js +1 -1
  202. package/dist/collection/components/radio/radio.js +2 -2
  203. package/dist/collection/components/radio-group/radio-group.js +1 -1
  204. package/dist/collection/components/range/range.js +2 -2
  205. package/dist/collection/components/rating/rating.js +2 -2
  206. package/dist/collection/components/row/row.js +1 -1
  207. package/dist/collection/components/segmented-button/segmented-button.js +1 -1
  208. package/dist/collection/components/segmented-button-bar/segmented-button-bar.js +2 -2
  209. package/dist/collection/components/segmented-buttons/segmented-buttons.js +11 -6
  210. package/dist/collection/components/segmented-buttons/segmented-buttons.js.map +1 -1
  211. package/dist/collection/components/select/select.css +7 -3
  212. package/dist/collection/components/select/select.js +3 -2
  213. package/dist/collection/components/select/select.js.map +1 -1
  214. package/dist/collection/components/select-filter/select-filter.js +4 -3
  215. package/dist/collection/components/select-filter/select-filter.js.map +1 -1
  216. package/dist/collection/components/skeleton/skeleton.js +1 -1
  217. package/dist/collection/components/spinner/spinner.js +1 -1
  218. package/dist/collection/components/switch/switch.js +4 -3
  219. package/dist/collection/components/switch/switch.js.map +1 -1
  220. package/dist/collection/components/tab/tab.js +3 -2
  221. package/dist/collection/components/tab/tab.js.map +1 -1
  222. package/dist/collection/components/tab-bar/tab-bar.js +2 -2
  223. package/dist/collection/components/tab-button/tab-button.js +1 -1
  224. package/dist/collection/components/table/table.js +1 -1
  225. package/dist/collection/components/tabs/tabs.js +11 -6
  226. package/dist/collection/components/tabs/tabs.js.map +1 -1
  227. package/dist/collection/components/tag/tag.js +2 -2
  228. package/dist/collection/components/text/text.js +1 -1
  229. package/dist/collection/components/textarea/textarea.js +5 -3
  230. package/dist/collection/components/textarea/textarea.js.map +1 -1
  231. package/dist/collection/components/toast/toast.js +8 -5
  232. package/dist/collection/components/toast/toast.js.map +1 -1
  233. package/dist/collection/components/toggle/toggle.js +4 -3
  234. package/dist/collection/components/toggle/toggle.js.map +1 -1
  235. package/dist/collection/components/toolbar/toolbar.js +1 -1
  236. package/dist/collection/components/toolbar-title/toolbar-title.js +1 -1
  237. package/dist/collection/components/toolbar-title-page/toolbar-title-page.js +1 -1
  238. package/dist/collection/components/tooltip/tooltip.js +5 -3
  239. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  240. package/dist/collection/global/app.js +1 -5
  241. package/dist/collection/global/app.js.map +1 -1
  242. package/dist/esm/{focus-visible-75a2ea2a.js → focus-visible-32bc70bb.js} +1 -1
  243. package/dist/esm/focus-visible-32bc70bb.js.map +1 -0
  244. package/dist/esm/{index-4b484f35.js → index-52302079.js} +412 -202
  245. package/dist/esm/index-52302079.js.map +1 -0
  246. package/dist/esm/{index-8f45025b.js → index-891decf5.js} +1 -1
  247. package/dist/esm/index-891decf5.js.map +1 -0
  248. package/dist/esm/index.js +3 -3
  249. package/dist/esm/loader.js +4 -30
  250. package/dist/esm/loader.js.map +1 -1
  251. package/dist/esm/polyfill-dc7c89b2.js +7 -0
  252. package/dist/esm/polyfill-dc7c89b2.js.map +1 -0
  253. package/dist/esm/road-accordion.entry.js +3 -3
  254. package/dist/esm/road-accordion.entry.js.map +1 -1
  255. package/dist/esm/road-alert.entry.js +1 -1
  256. package/dist/esm/road-alert.entry.js.map +1 -1
  257. package/dist/esm/road-area-code.entry.js +9 -13
  258. package/dist/esm/road-area-code.entry.js.map +1 -1
  259. package/dist/esm/road-autocomplete.entry.js +1 -1
  260. package/dist/esm/road-autocomplete.entry.js.map +1 -1
  261. package/dist/esm/road-avatar.entry.js +1 -1
  262. package/dist/esm/road-avatar.entry.js.map +1 -1
  263. package/dist/esm/road-badge_14.entry.js +7 -12
  264. package/dist/esm/road-badge_14.entry.js.map +1 -1
  265. package/dist/esm/road-banner.entry.js +2 -2
  266. package/dist/esm/road-banner.entry.js.map +1 -1
  267. package/dist/esm/road-button-floating.entry.js +2 -2
  268. package/dist/esm/road-button-floating.entry.js.map +1 -1
  269. package/dist/esm/road-card.entry.js +1 -1
  270. package/dist/esm/road-card.entry.js.map +1 -1
  271. package/dist/esm/road-carousel-item.entry.js +1 -1
  272. package/dist/esm/road-carousel-item.entry.js.map +1 -1
  273. package/dist/esm/road-carousel.entry.js +2 -2
  274. package/dist/esm/road-carousel.entry.js.map +1 -1
  275. package/dist/esm/road-checkbox.entry.js +3 -3
  276. package/dist/esm/road-checkbox.entry.js.map +1 -1
  277. package/dist/esm/road-chip.entry.js +3 -3
  278. package/dist/esm/road-chip.entry.js.map +1 -1
  279. package/dist/esm/road-collapse.entry.js +1 -1
  280. package/dist/esm/road-collapse.entry.js.map +1 -1
  281. package/dist/esm/road-dialog.entry.js +2 -2
  282. package/dist/esm/road-dialog.entry.js.map +1 -1
  283. package/dist/esm/road-dropdown.entry.js +1 -1
  284. package/dist/esm/road-dropdown.entry.js.map +1 -1
  285. package/dist/esm/road-duration.entry.js +1 -1
  286. package/dist/esm/road-duration.entry.js.map +1 -1
  287. package/dist/esm/road-flap.entry.js +1 -1
  288. package/dist/esm/road-flap.entry.js.map +1 -1
  289. package/dist/esm/road-global-navigation.entry.js +2 -2
  290. package/dist/esm/road-global-navigation.entry.js.map +1 -1
  291. package/dist/esm/road-illustration.entry.js +2 -2
  292. package/dist/esm/road-illustration.entry.js.map +1 -1
  293. package/dist/esm/road-img.entry.js +1 -1
  294. package/dist/esm/road-img.entry.js.map +1 -1
  295. package/dist/esm/road-modal.entry.js +2 -2
  296. package/dist/esm/road-modal.entry.js.map +1 -1
  297. package/dist/esm/road-navbar-item.entry.js +1 -1
  298. package/dist/esm/road-navbar-item.entry.js.map +1 -1
  299. package/dist/esm/road-navbar.entry.js +2 -2
  300. package/dist/esm/road-navbar.entry.js.map +1 -1
  301. package/dist/esm/road-phone-number-input.entry.js +22 -16
  302. package/dist/esm/road-phone-number-input.entry.js.map +1 -1
  303. package/dist/esm/road-plate-number.entry.js +2 -2
  304. package/dist/esm/road-plate-number.entry.js.map +1 -1
  305. package/dist/esm/road-profil-dropdown.entry.js +1 -1
  306. package/dist/esm/road-profil-dropdown.entry.js.map +1 -1
  307. package/dist/esm/road-progress-indicator-horizontal.entry.js +1 -1
  308. package/dist/esm/road-progress-indicator-horizontal.entry.js.map +1 -1
  309. package/dist/esm/road-progress-indicator-vertical-item.entry.js +1 -1
  310. package/dist/esm/road-progress-indicator-vertical-item.entry.js.map +1 -1
  311. package/dist/esm/road-progress-indicator-vertical.entry.js +1 -1
  312. package/dist/esm/road-progress-indicator-vertical.entry.js.map +1 -1
  313. package/dist/esm/road-progress-tracker-item.entry.js +1 -1
  314. package/dist/esm/road-progress-tracker-item.entry.js.map +1 -1
  315. package/dist/esm/road-progress-tracker.entry.js +1 -1
  316. package/dist/esm/road-progress-tracker.entry.js.map +1 -1
  317. package/dist/esm/road-progress.entry.js +1 -1
  318. package/dist/esm/road-progress.entry.js.map +1 -1
  319. package/dist/esm/road-radio-group.entry.js +1 -1
  320. package/dist/esm/road-radio-group.entry.js.map +1 -1
  321. package/dist/esm/road-radio.entry.js +2 -2
  322. package/dist/esm/road-radio.entry.js.map +1 -1
  323. package/dist/esm/road-range.entry.js +2 -2
  324. package/dist/esm/road-range.entry.js.map +1 -1
  325. package/dist/esm/road-rating.entry.js +2 -2
  326. package/dist/esm/road-rating.entry.js.map +1 -1
  327. package/dist/esm/road-segmented-button-bar.entry.js +2 -2
  328. package/dist/esm/road-segmented-button-bar.entry.js.map +1 -1
  329. package/dist/esm/road-segmented-button.entry.js +1 -1
  330. package/dist/esm/road-segmented-button.entry.js.map +1 -1
  331. package/dist/esm/road-segmented-buttons.entry.js +1 -1
  332. package/dist/esm/road-segmented-buttons.entry.js.map +1 -1
  333. package/dist/esm/road-select-filter.entry.js +1 -1
  334. package/dist/esm/road-select-filter.entry.js.map +1 -1
  335. package/dist/esm/road-select.entry.js +2 -2
  336. package/dist/esm/road-select.entry.js.map +1 -1
  337. package/dist/esm/road-skeleton.entry.js +1 -1
  338. package/dist/esm/road-skeleton.entry.js.map +1 -1
  339. package/dist/esm/road-spinner.entry.js +1 -1
  340. package/dist/esm/road-spinner.entry.js.map +1 -1
  341. package/dist/esm/road-switch.entry.js +2 -2
  342. package/dist/esm/road-switch.entry.js.map +1 -1
  343. package/dist/esm/road-tab-bar.entry.js +2 -2
  344. package/dist/esm/road-tab-bar.entry.js.map +1 -1
  345. package/dist/esm/road-tab-button.entry.js +1 -1
  346. package/dist/esm/road-tab-button.entry.js.map +1 -1
  347. package/dist/esm/road-tab.entry.js +1 -1
  348. package/dist/esm/road-tab.entry.js.map +1 -1
  349. package/dist/esm/road-table.entry.js +1 -1
  350. package/dist/esm/road-table.entry.js.map +1 -1
  351. package/dist/esm/road-tabs.entry.js +1 -1
  352. package/dist/esm/road-tabs.entry.js.map +1 -1
  353. package/dist/esm/road-tag.entry.js +2 -2
  354. package/dist/esm/road-tag.entry.js.map +1 -1
  355. package/dist/esm/road-text.entry.js +1 -1
  356. package/dist/esm/road-text.entry.js.map +1 -1
  357. package/dist/esm/road-textarea.entry.js +1 -1
  358. package/dist/esm/road-textarea.entry.js.map +1 -1
  359. package/dist/esm/road-toast.entry.js +2 -2
  360. package/dist/esm/road-toast.entry.js.map +1 -1
  361. package/dist/esm/road-toggle.entry.js +2 -2
  362. package/dist/esm/road-toggle.entry.js.map +1 -1
  363. package/dist/esm/road-toolbar-title-page.entry.js +1 -1
  364. package/dist/esm/road-toolbar-title-page.entry.js.map +1 -1
  365. package/dist/esm/road-toolbar-title.entry.js +1 -1
  366. package/dist/esm/road-toolbar-title.entry.js.map +1 -1
  367. package/dist/esm/road-tooltip.entry.js +1 -1
  368. package/dist/esm/road-tooltip.entry.js.map +1 -1
  369. package/dist/esm/roadtrip.js +7 -104
  370. package/dist/esm/roadtrip.js.map +1 -1
  371. package/dist/esm/{utils-ff713b72.js → utils-79ac6aaf.js} +2 -2
  372. package/dist/esm/utils-79ac6aaf.js.map +1 -0
  373. package/dist/esm/{utils-7f4988b4.js → utils-8c28c2e1.js} +2 -2
  374. package/dist/esm/utils-8c28c2e1.js.map +1 -0
  375. package/dist/html.html-data.json +71 -87
  376. package/dist/loader/index.d.ts +1 -1
  377. package/dist/roadtrip/index.esm.js +1 -1
  378. package/dist/roadtrip/{p-ff52872b.entry.js → p-00e51171.entry.js} +2 -2
  379. package/dist/roadtrip/p-00e51171.entry.js.map +1 -0
  380. package/dist/roadtrip/p-028243c1.entry.js +2 -0
  381. package/dist/roadtrip/p-028243c1.entry.js.map +1 -0
  382. package/dist/roadtrip/{p-c259efd7.js → p-08ff1520.js} +2 -2
  383. package/dist/roadtrip/p-08ff1520.js.map +1 -0
  384. package/dist/roadtrip/p-0f8966f4.entry.js +2 -0
  385. package/dist/roadtrip/p-0f8966f4.entry.js.map +1 -0
  386. package/dist/roadtrip/{p-e68a3ae5.entry.js → p-0fca389a.entry.js} +2 -2
  387. package/dist/roadtrip/p-0fca389a.entry.js.map +1 -0
  388. package/dist/roadtrip/{p-a484102a.entry.js → p-13d54b3e.entry.js} +2 -2
  389. package/dist/roadtrip/p-13d54b3e.entry.js.map +1 -0
  390. package/dist/roadtrip/p-1a761fc0.entry.js +2 -0
  391. package/dist/roadtrip/p-1a761fc0.entry.js.map +1 -0
  392. package/dist/roadtrip/{p-9036a1e6.entry.js → p-1c5ac353.entry.js} +2 -2
  393. package/dist/roadtrip/p-1c5ac353.entry.js.map +1 -0
  394. package/dist/roadtrip/p-1ccae339.js +2 -0
  395. package/dist/roadtrip/p-1ccae339.js.map +1 -0
  396. package/dist/roadtrip/p-20b115ed.entry.js +2 -0
  397. package/dist/roadtrip/p-20b115ed.entry.js.map +1 -0
  398. package/dist/roadtrip/{p-0d99a5e7.entry.js → p-25683dc7.entry.js} +2 -2
  399. package/dist/roadtrip/p-25683dc7.entry.js.map +1 -0
  400. package/dist/roadtrip/{p-2d01d350.entry.js → p-25ade729.entry.js} +2 -2
  401. package/dist/roadtrip/p-25ade729.entry.js.map +1 -0
  402. package/dist/roadtrip/{p-7c4b331c.entry.js → p-2b5974fc.entry.js} +2 -2
  403. package/dist/roadtrip/p-2b5974fc.entry.js.map +1 -0
  404. package/dist/roadtrip/{p-b4dc061d.entry.js → p-2c8a6854.entry.js} +2 -2
  405. package/dist/roadtrip/p-2c8a6854.entry.js.map +1 -0
  406. package/dist/roadtrip/{p-7ec2d494.js → p-2d45ef28.js} +2 -2
  407. package/dist/roadtrip/p-2d45ef28.js.map +1 -0
  408. package/dist/roadtrip/{p-ee0196ea.entry.js → p-30fa62f4.entry.js} +2 -2
  409. package/dist/roadtrip/p-30fa62f4.entry.js.map +1 -0
  410. package/dist/roadtrip/{p-21c20210.entry.js → p-39d1c90a.entry.js} +2 -2
  411. package/dist/roadtrip/p-39d1c90a.entry.js.map +1 -0
  412. package/dist/roadtrip/{p-c8e9807b.entry.js → p-40daa53b.entry.js} +2 -2
  413. package/dist/roadtrip/p-40daa53b.entry.js.map +1 -0
  414. package/dist/roadtrip/p-414a2791.entry.js +2 -0
  415. package/dist/roadtrip/p-414a2791.entry.js.map +1 -0
  416. package/dist/roadtrip/p-46cccafc.entry.js +2 -0
  417. package/dist/roadtrip/p-46cccafc.entry.js.map +1 -0
  418. package/dist/roadtrip/{p-91e92e99.entry.js → p-4ba769a9.entry.js} +2 -2
  419. package/dist/roadtrip/p-4ba769a9.entry.js.map +1 -0
  420. package/dist/roadtrip/{p-093973f5.entry.js → p-4f47f4f7.entry.js} +2 -2
  421. package/dist/roadtrip/p-4f47f4f7.entry.js.map +1 -0
  422. package/dist/roadtrip/{p-1baffcc2.entry.js → p-4f5e8cc2.entry.js} +2 -2
  423. package/dist/roadtrip/p-4f5e8cc2.entry.js.map +1 -0
  424. package/dist/roadtrip/{p-8e216f6a.entry.js → p-5483109e.entry.js} +2 -2
  425. package/dist/roadtrip/p-5483109e.entry.js.map +1 -0
  426. package/dist/roadtrip/{p-9419bdaf.entry.js → p-5ab03aa4.entry.js} +2 -2
  427. package/dist/roadtrip/p-5ab03aa4.entry.js.map +1 -0
  428. package/dist/roadtrip/p-60e25858.entry.js +2 -0
  429. package/dist/roadtrip/p-60e25858.entry.js.map +1 -0
  430. package/dist/roadtrip/{p-93030cec.entry.js → p-6177bb46.entry.js} +2 -2
  431. package/dist/roadtrip/p-6177bb46.entry.js.map +1 -0
  432. package/dist/roadtrip/{p-4fd8c4db.entry.js → p-64aa6fd0.entry.js} +2 -2
  433. package/dist/roadtrip/p-64aa6fd0.entry.js.map +1 -0
  434. package/dist/roadtrip/{p-ff473633.entry.js → p-68599145.entry.js} +2 -2
  435. package/dist/roadtrip/p-68599145.entry.js.map +1 -0
  436. package/dist/roadtrip/p-6a27b5fc.entry.js +2 -0
  437. package/dist/roadtrip/p-6a27b5fc.entry.js.map +1 -0
  438. package/dist/roadtrip/{p-1974c993.entry.js → p-6f170c25.entry.js} +2 -2
  439. package/dist/roadtrip/p-6f170c25.entry.js.map +1 -0
  440. package/dist/roadtrip/{p-3604d557.entry.js → p-7048f786.entry.js} +2 -2
  441. package/dist/roadtrip/p-7048f786.entry.js.map +1 -0
  442. package/dist/roadtrip/{p-37ab7c7f.js → p-73fe2357.js} +1 -1
  443. package/dist/roadtrip/p-73fe2357.js.map +1 -0
  444. package/dist/roadtrip/{p-35ffaa87.entry.js → p-744198aa.entry.js} +2 -2
  445. package/dist/roadtrip/p-744198aa.entry.js.map +1 -0
  446. package/dist/roadtrip/{p-b5727aae.entry.js → p-76ccfc61.entry.js} +2 -2
  447. package/dist/roadtrip/p-76ccfc61.entry.js.map +1 -0
  448. package/dist/roadtrip/{p-1caeda78.entry.js → p-78e9bbd5.entry.js} +2 -2
  449. package/dist/roadtrip/p-78e9bbd5.entry.js.map +1 -0
  450. package/dist/roadtrip/{p-8f802447.entry.js → p-82919e58.entry.js} +2 -2
  451. package/dist/roadtrip/p-82919e58.entry.js.map +1 -0
  452. package/dist/roadtrip/p-90b35d7e.entry.js +2 -0
  453. package/dist/roadtrip/p-90b35d7e.entry.js.map +1 -0
  454. package/dist/roadtrip/{p-0bcf6d63.entry.js → p-90fac6e5.entry.js} +2 -2
  455. package/dist/roadtrip/p-90fac6e5.entry.js.map +1 -0
  456. package/dist/roadtrip/{p-73df1bef.entry.js → p-96abbe85.entry.js} +2 -2
  457. package/dist/roadtrip/p-96abbe85.entry.js.map +1 -0
  458. package/dist/roadtrip/{p-48596f8f.entry.js → p-995e1e53.entry.js} +2 -2
  459. package/dist/roadtrip/p-995e1e53.entry.js.map +1 -0
  460. package/dist/roadtrip/{p-5f4779b1.entry.js → p-9b170273.entry.js} +2 -2
  461. package/dist/roadtrip/p-9b170273.entry.js.map +1 -0
  462. package/dist/roadtrip/{p-43bdbf0a.entry.js → p-9bef58e1.entry.js} +2 -2
  463. package/dist/roadtrip/p-9bef58e1.entry.js.map +1 -0
  464. package/dist/roadtrip/p-9fefc8af.entry.js +2 -0
  465. package/dist/roadtrip/p-9fefc8af.entry.js.map +1 -0
  466. package/dist/roadtrip/p-a2a9a650.entry.js +2 -0
  467. package/dist/roadtrip/{p-7589e2bb.entry.js.map → p-a2a9a650.entry.js.map} +1 -1
  468. package/dist/roadtrip/p-b09c076d.entry.js +2 -0
  469. package/dist/roadtrip/p-b09c076d.entry.js.map +1 -0
  470. package/dist/roadtrip/{p-b7d3dc1a.entry.js → p-b2e7bfcb.entry.js} +2 -2
  471. package/dist/roadtrip/p-b2e7bfcb.entry.js.map +1 -0
  472. package/dist/roadtrip/p-b614a9fb.entry.js +2 -0
  473. package/dist/roadtrip/p-b614a9fb.entry.js.map +1 -0
  474. package/dist/roadtrip/{p-ebe3c26a.entry.js → p-b65f0a62.entry.js} +2 -2
  475. package/dist/roadtrip/p-b65f0a62.entry.js.map +1 -0
  476. package/dist/roadtrip/{p-29ff2bcd.entry.js → p-bfcedcfb.entry.js} +2 -2
  477. package/dist/roadtrip/p-bfcedcfb.entry.js.map +1 -0
  478. package/dist/roadtrip/{p-b259fee3.entry.js → p-c33f5249.entry.js} +2 -2
  479. package/dist/roadtrip/p-c33f5249.entry.js.map +1 -0
  480. package/dist/roadtrip/{p-439e1124.entry.js → p-cbe0c628.entry.js} +2 -2
  481. package/dist/roadtrip/p-cbe0c628.entry.js.map +1 -0
  482. package/dist/roadtrip/p-d651deea.entry.js +2 -0
  483. package/dist/roadtrip/p-d651deea.entry.js.map +1 -0
  484. package/dist/roadtrip/p-d794a8d4.entry.js +2 -0
  485. package/dist/roadtrip/p-d794a8d4.entry.js.map +1 -0
  486. package/dist/roadtrip/{p-295a97d7.entry.js → p-db7cb1c8.entry.js} +2 -2
  487. package/dist/roadtrip/p-db7cb1c8.entry.js.map +1 -0
  488. package/dist/roadtrip/{p-6598e293.entry.js → p-dcb280e3.entry.js} +2 -2
  489. package/dist/roadtrip/p-dcb280e3.entry.js.map +1 -0
  490. package/dist/roadtrip/{p-cb254685.entry.js → p-e2149bdf.entry.js} +2 -2
  491. package/dist/roadtrip/p-e2149bdf.entry.js.map +1 -0
  492. package/dist/roadtrip/{p-650eb7fb.entry.js → p-e2c6d81f.entry.js} +2 -2
  493. package/dist/roadtrip/p-e2c6d81f.entry.js.map +1 -0
  494. package/dist/roadtrip/{p-66a9a6e8.entry.js → p-e42a9ec4.entry.js} +2 -2
  495. package/dist/roadtrip/p-e42a9ec4.entry.js.map +1 -0
  496. package/dist/roadtrip/{p-9dd06f01.entry.js → p-ea28a425.entry.js} +2 -2
  497. package/dist/roadtrip/p-ea28a425.entry.js.map +1 -0
  498. package/dist/roadtrip/p-f3d586b3.js +3 -0
  499. package/dist/roadtrip/p-f3d586b3.js.map +1 -0
  500. package/dist/roadtrip/{p-9432708d.entry.js → p-f5cce766.entry.js} +2 -2
  501. package/dist/roadtrip/p-f5cce766.entry.js.map +1 -0
  502. package/dist/roadtrip/{p-5a4f9085.entry.js → p-f6d47cda.entry.js} +2 -2
  503. package/dist/roadtrip/p-f6d47cda.entry.js.map +1 -0
  504. package/dist/roadtrip/{p-b34aba1a.js → p-faa60880.js} +2 -2
  505. package/dist/roadtrip/p-faa60880.js.map +1 -0
  506. package/dist/roadtrip/roadtrip.esm.js +1 -1
  507. package/dist/roadtrip/roadtrip.esm.js.map +1 -1
  508. package/dist/roadtrip/svg/vehicle-car-search-color.svg +1 -1
  509. package/dist/types/components/area-code/area-code.d.ts +4 -7
  510. package/dist/types/components/drawer/drawer.d.ts +0 -1
  511. package/dist/types/components.d.ts +571 -20
  512. package/dist/types/global/app.d.ts +0 -1
  513. package/dist/types/stencil-public-runtime.d.ts +38 -5
  514. package/hydrate/index.d.ts +6 -6
  515. package/hydrate/index.js +285 -235
  516. package/package.json +2 -2
  517. package/dist/cjs/app-d9e5adfa.js +0 -9
  518. package/dist/cjs/app-d9e5adfa.js.map +0 -1
  519. package/dist/cjs/css-shim-68410b74.js +0 -8
  520. package/dist/cjs/css-shim-68410b74.js.map +0 -1
  521. package/dist/cjs/dom-225fc508.js +0 -77
  522. package/dist/cjs/dom-225fc508.js.map +0 -1
  523. package/dist/cjs/focus-visible-6771892b.js.map +0 -1
  524. package/dist/cjs/index-e4bd5b5f.js.map +0 -1
  525. package/dist/cjs/index-fd07207a.js.map +0 -1
  526. package/dist/cjs/polyfill-9453e116.js.map +0 -1
  527. package/dist/cjs/shadow-css-3c339190.js +0 -391
  528. package/dist/cjs/shadow-css-3c339190.js.map +0 -1
  529. package/dist/cjs/utils-5203d152.js.map +0 -1
  530. package/dist/cjs/utils-a450bad3.js.map +0 -1
  531. package/dist/collection/components/drawer/drawer.dark.css +0 -252
  532. package/dist/esm/app-a8a6f02a.js +0 -7
  533. package/dist/esm/app-a8a6f02a.js.map +0 -1
  534. package/dist/esm/css-shim-fa54d62f.js +0 -6
  535. package/dist/esm/css-shim-fa54d62f.js.map +0 -1
  536. package/dist/esm/dom-8de30773.js +0 -75
  537. package/dist/esm/dom-8de30773.js.map +0 -1
  538. package/dist/esm/focus-visible-75a2ea2a.js.map +0 -1
  539. package/dist/esm/index-4b484f35.js.map +0 -1
  540. package/dist/esm/index-8f45025b.js.map +0 -1
  541. package/dist/esm/polyfill-ab80527b.js +0 -7
  542. package/dist/esm/polyfill-ab80527b.js.map +0 -1
  543. package/dist/esm/polyfills/css-shim.js +0 -1
  544. package/dist/esm/shadow-css-af2290df.js +0 -389
  545. package/dist/esm/shadow-css-af2290df.js.map +0 -1
  546. package/dist/esm/utils-7f4988b4.js.map +0 -1
  547. package/dist/esm/utils-ff713b72.js.map +0 -1
  548. package/dist/roadtrip/p-00cfef9b.js +0 -22
  549. package/dist/roadtrip/p-00cfef9b.js.map +0 -1
  550. package/dist/roadtrip/p-093973f5.entry.js.map +0 -1
  551. package/dist/roadtrip/p-0bcf6d63.entry.js.map +0 -1
  552. package/dist/roadtrip/p-0d99a5e7.entry.js.map +0 -1
  553. package/dist/roadtrip/p-125c777f.entry.js +0 -2
  554. package/dist/roadtrip/p-125c777f.entry.js.map +0 -1
  555. package/dist/roadtrip/p-16285738.entry.js +0 -2
  556. package/dist/roadtrip/p-16285738.entry.js.map +0 -1
  557. package/dist/roadtrip/p-170a82e1.entry.js +0 -2
  558. package/dist/roadtrip/p-170a82e1.entry.js.map +0 -1
  559. package/dist/roadtrip/p-1974c993.entry.js.map +0 -1
  560. package/dist/roadtrip/p-198f586b.entry.js +0 -2
  561. package/dist/roadtrip/p-198f586b.entry.js.map +0 -1
  562. package/dist/roadtrip/p-1baffcc2.entry.js.map +0 -1
  563. package/dist/roadtrip/p-1caeda78.entry.js.map +0 -1
  564. package/dist/roadtrip/p-214218dd.entry.js +0 -2
  565. package/dist/roadtrip/p-214218dd.entry.js.map +0 -1
  566. package/dist/roadtrip/p-21c20210.entry.js.map +0 -1
  567. package/dist/roadtrip/p-295a97d7.entry.js.map +0 -1
  568. package/dist/roadtrip/p-298a51a3.js +0 -2
  569. package/dist/roadtrip/p-298a51a3.js.map +0 -1
  570. package/dist/roadtrip/p-29ff2bcd.entry.js.map +0 -1
  571. package/dist/roadtrip/p-2d01d350.entry.js.map +0 -1
  572. package/dist/roadtrip/p-35ffaa87.entry.js.map +0 -1
  573. package/dist/roadtrip/p-3604d557.entry.js.map +0 -1
  574. package/dist/roadtrip/p-37ab7c7f.js.map +0 -1
  575. package/dist/roadtrip/p-38597e21.entry.js +0 -2
  576. package/dist/roadtrip/p-38597e21.entry.js.map +0 -1
  577. package/dist/roadtrip/p-439e1124.entry.js.map +0 -1
  578. package/dist/roadtrip/p-43bdbf0a.entry.js.map +0 -1
  579. package/dist/roadtrip/p-48596f8f.entry.js.map +0 -1
  580. package/dist/roadtrip/p-4993da93.entry.js +0 -2
  581. package/dist/roadtrip/p-4993da93.entry.js.map +0 -1
  582. package/dist/roadtrip/p-4fd8c4db.entry.js.map +0 -1
  583. package/dist/roadtrip/p-50daca95.js +0 -13
  584. package/dist/roadtrip/p-50daca95.js.map +0 -1
  585. package/dist/roadtrip/p-564f4f31.entry.js +0 -2
  586. package/dist/roadtrip/p-564f4f31.entry.js.map +0 -1
  587. package/dist/roadtrip/p-5a4f9085.entry.js.map +0 -1
  588. package/dist/roadtrip/p-5f4779b1.entry.js.map +0 -1
  589. package/dist/roadtrip/p-62c563db.entry.js +0 -2
  590. package/dist/roadtrip/p-62c563db.entry.js.map +0 -1
  591. package/dist/roadtrip/p-650eb7fb.entry.js.map +0 -1
  592. package/dist/roadtrip/p-6598e293.entry.js.map +0 -1
  593. package/dist/roadtrip/p-66a9a6e8.entry.js.map +0 -1
  594. package/dist/roadtrip/p-73df1bef.entry.js.map +0 -1
  595. package/dist/roadtrip/p-7589e2bb.entry.js +0 -2
  596. package/dist/roadtrip/p-7c4b331c.entry.js.map +0 -1
  597. package/dist/roadtrip/p-7ec2d494.js.map +0 -1
  598. package/dist/roadtrip/p-8e216f6a.entry.js.map +0 -1
  599. package/dist/roadtrip/p-8f802447.entry.js.map +0 -1
  600. package/dist/roadtrip/p-9036a1e6.entry.js.map +0 -1
  601. package/dist/roadtrip/p-91e92e99.entry.js.map +0 -1
  602. package/dist/roadtrip/p-93030cec.entry.js.map +0 -1
  603. package/dist/roadtrip/p-9419bdaf.entry.js.map +0 -1
  604. package/dist/roadtrip/p-9432708d.entry.js.map +0 -1
  605. package/dist/roadtrip/p-9dd06f01.entry.js.map +0 -1
  606. package/dist/roadtrip/p-a32c7889.entry.js +0 -2
  607. package/dist/roadtrip/p-a32c7889.entry.js.map +0 -1
  608. package/dist/roadtrip/p-a484102a.entry.js.map +0 -1
  609. package/dist/roadtrip/p-abdbf6ac.js +0 -3
  610. package/dist/roadtrip/p-abdbf6ac.js.map +0 -1
  611. package/dist/roadtrip/p-b259fee3.entry.js.map +0 -1
  612. package/dist/roadtrip/p-b2cc540b.entry.js +0 -2
  613. package/dist/roadtrip/p-b2cc540b.entry.js.map +0 -1
  614. package/dist/roadtrip/p-b34aba1a.js.map +0 -1
  615. package/dist/roadtrip/p-b4dc061d.entry.js.map +0 -1
  616. package/dist/roadtrip/p-b5727aae.entry.js.map +0 -1
  617. package/dist/roadtrip/p-b7d3dc1a.entry.js.map +0 -1
  618. package/dist/roadtrip/p-c259efd7.js.map +0 -1
  619. package/dist/roadtrip/p-c56fe023.entry.js +0 -2
  620. package/dist/roadtrip/p-c56fe023.entry.js.map +0 -1
  621. package/dist/roadtrip/p-c8e9807b.entry.js.map +0 -1
  622. package/dist/roadtrip/p-cb254685.entry.js.map +0 -1
  623. package/dist/roadtrip/p-cd2e8f0a.entry.js +0 -2
  624. package/dist/roadtrip/p-cd2e8f0a.entry.js.map +0 -1
  625. package/dist/roadtrip/p-e68a3ae5.entry.js.map +0 -1
  626. package/dist/roadtrip/p-e8c090a5.js +0 -2
  627. package/dist/roadtrip/p-e8c090a5.js.map +0 -1
  628. package/dist/roadtrip/p-ebe3c26a.entry.js.map +0 -1
  629. package/dist/roadtrip/p-ee0196ea.entry.js.map +0 -1
  630. package/dist/roadtrip/p-f671758f.entry.js +0 -2
  631. package/dist/roadtrip/p-f671758f.entry.js.map +0 -1
  632. package/dist/roadtrip/p-fa98320c.js +0 -2
  633. package/dist/roadtrip/p-fa98320c.js.map +0 -1
  634. package/dist/roadtrip/p-ff473633.entry.js.map +0 -1
  635. package/dist/roadtrip/p-ff52872b.entry.js.map +0 -1
@@ -1,2 +0,0 @@
1
- import{r,e,h as a,f as n}from"./p-abdbf6ac.js";import{h as o,i}from"./p-37ab7c7f.js";const t='.sc-road-range-h{display:block}.form-group.sc-road-range{width:100%}.form-range.sc-road-range{position:relative;display:flex;flex-direction:column;width:100%;margin-bottom:6px}.form-range-input.sc-road-range{position:relative;z-index:1;width:100%;background:transparent;outline:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-range.sc-road-range>output.sc-road-range::after{display:block;font-size:var(--road-label-medium);text-align:right;content:counter(variable);counter-reset:variable var(--value)}.form-range-progress.sc-road-range{position:relative;z-index:0;display:block;width:100%;margin-top:-1rem}.form-range-input.sc-road-range::-webkit-slider-runnable-track{border:0;-webkit-appearance:none;appearance:none}.form-range-input.sc-road-range::-moz-range-track{height:0.5rem;border:0;-moz-appearance:none;appearance:none}.form-range-progress.sc-road-range::before{display:block;height:0.5rem;content:"";background-color:var(--road-on-surface-disabled);border:0;border-radius:1.125rem}.form-range-progress.sc-road-range::after{position:absolute;top:0;right:0;left:0;display:block;width:calc((var(--value) * 100%) / var(--max));height:0.5rem;content:"";background:var(--road-primary);border-radius:1.125rem}.form-range-input.sc-road-range::-webkit-slider-thumb{position:relative;z-index:1;width:1.625rem;height:1.625rem;cursor:grab;background:var(--road-surface);border:none;border-radius:1.625rem;box-shadow:0 0.1875rem 0.375rem rgba(0, 0, 0, 0.24);-webkit-appearance:none;appearance:none}.form-range-input.sc-road-range::-moz-range-thumb{position:relative;z-index:1;box-sizing:border-box;width:1.625rem;height:1.625rem;margin-top:-0.625rem;cursor:grab;background:var(--road-surface);border:none;border-radius:1.625rem;box-shadow:0 0.1875rem 0.375rem rgba(0, 0, 0, 0.24);-moz-appearance:none;appearance:none}.focus-visible.sc-road-range-h .form-range-input.sc-road-range::-webkit-slider-thumb,.sc-road-range-h:active .form-range-input.sc-road-range::-webkit-slider-thumb{background:var(--road-input-surface-variant);border:0.5rem solid var(--road-grey-100-new)}.focus-visible.sc-road-range-h .form-range-input.sc-road-range::-moz-range-thumb,.sc-road-range-h:active .form-range-input.sc-road-range::-moz-range-thumb{background:var(--road-input-surface-variant);border:0.5rem solid var(--road-grey-100-new)}.sc-road-range-s>datalist{display:flex;justify-content:space-between}.sc-road-range-s>datalist option{width:32px;margin:0;font-size:var(--road-label-medium);text-align:center}';const s=class{constructor(a){r(this,a);this.roadchange=e(this,"roadchange",7);this.roadChange=e(this,"roadChange",7);this.onInput=r=>{const e=r.target;if(e){this.value=e.value||""}if(this.value!==null&&this.value!==undefined){this.el.style.setProperty("--value",`${this.value}`)}};this.rangeId=`road-range-${d++}`;this.value="";this.min=undefined;this.max=undefined;this.step=undefined;this.showValue=false;this.showTick=false;this.showLabels=false}valueChanged(){this.roadchange.emit({value:this.value==null?this.value:this.value.toString()});this.roadChange.emit({value:this.value==null?this.value:this.value.toString()})}getValue(){return typeof this.value==="number"?this.value.toString():(this.value||"").toString()}render(){const r=this.getValue();const e=this.showLabels!==undefined?`tickmarks`:"";return a("div",{class:"form-group d-flex align-items-end"},this.showTick&&a("road-icon",{icon:i,class:"mr-8",size:"sm"}),a("div",{class:"form-range",style:{"--min:":this.min,"--max":this.max,"--value":r}},this.showValue&&a("output",null),this.showLabels&&a("slot",{name:"datalist"}),a("input",{type:"range",class:"form-range-input",id:this.rangeId,min:this.min,max:this.max,value:r,onInput:this.onInput,list:e}),a("div",{class:"form-range-progress"})),this.showTick&&a("road-icon",{icon:o,class:"ml-8",size:"sm"}))}get el(){return n(this)}static get watchers(){return{value:["valueChanged"]}}};let d=0;s.style=t;export{s as road_range};
2
- //# sourceMappingURL=p-b2cc540b.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["rangeCss","Range","this","onInput","ev","input","target","value","undefined","el","style","setProperty","rangeIds","valueChanged","roadchange","emit","toString","roadChange","getValue","render","datalist","showLabels","h","class","showTick","icon","navigationAddLessSolid","size","min","max","showValue","name","type","id","rangeId","list","navigationAddMoreSolid"],"sources":["./src/components/range/range.css?tag=road-range&encapsulation=scoped","./src/components/range/range.tsx"],"sourcesContent":["/*\n * Range\n *\n *\n * Index\n * - Input\n * - Value\n * - Slider\n * - Progress\n * - Cursor\n */\n\n:host {\n display: block;\n}\n\n.form-group{\n width: 100%;\n}\n\n.form-range {\n position: relative;\n display: flex;\n flex-direction: column;\n width: 100%;\n margin-bottom: 6px;\n}\n\n/* INPUT\n -------------------- */\n\n.form-range-input {\n position: relative;\n z-index: 1;\n width: 100%;\n background: transparent;\n outline: 0;\n appearance: none;\n}\n\n/* VALUE\n -------------------- */\n\n.form-range > output::after {\n display: block;\n font-size: var(--road-label-medium);\n text-align: right;\n content: counter(variable);\n counter-reset: variable var(--value);\n}\n\n/* SLIDER\n -------------------- */\n\n.form-range-progress {\n position: relative;\n z-index: 0;\n display: block;\n width: 100%;\n margin-top: -1rem;\n}\n\n.form-range-input::-webkit-slider-runnable-track {\n border: 0;\n appearance: none;\n}\n\n.form-range-input::-moz-range-track {\n height: 0.5rem;\n border: 0;\n appearance: none;\n}\n\n.form-range-progress::before {\n display: block;\n height: 0.5rem;\n content: \"\";\n background-color: var(--road-on-surface-disabled);\n border: 0;\n border-radius: 1.125rem;\n}\n\n/* PROGRESS\n -------------------- */\n\n.form-range-progress::after {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n display: block;\n width: calc((var(--value) * 100%) / var(--max));\n height: 0.5rem;\n content: \"\";\n background: var(--road-primary);\n border-radius: 1.125rem;\n}\n\n/* CURSOR\n-------------------- */\n\n.form-range-input::-webkit-slider-thumb {\n position: relative;\n z-index: 1;\n width: 1.625rem;\n height: 1.625rem;\n cursor: grab;\n background: var(--road-surface);\n border: none;\n border-radius: 1.625rem;\n box-shadow: 0 0.1875rem 0.375rem rgba(0, 0, 0, 0.24);\n appearance: none;\n}\n\n.form-range-input::-moz-range-thumb {\n position: relative;\n z-index: 1;\n box-sizing: border-box;\n width: 1.625rem;\n height: 1.625rem;\n margin-top: -0.625rem;\n cursor: grab;\n background: var(--road-surface);\n border: none;\n border-radius: 1.625rem;\n box-shadow: 0 0.1875rem 0.375rem rgba(0, 0, 0, 0.24);\n appearance: none;\n}\n\n/**\n * Focus state\n */\n\n:host(.focus-visible) .form-range-input::-webkit-slider-thumb,\n:host(:active) .form-range-input::-webkit-slider-thumb {\n background: var(--road-input-surface-variant);\n border: 0.5rem solid var(--road-grey-100-new);\n}\n\n:host(.focus-visible) .form-range-input::-moz-range-thumb,\n:host(:active) .form-range-input::-moz-range-thumb {\n background: var(--road-input-surface-variant);\n border: 0.5rem solid var(--road-grey-100-new);\n}\n\n/* DATALIST\n -------------------- */\n\n::slotted(datalist) {\n display: flex;\n justify-content: space-between;\n}\n\n::slotted(datalist) option {\n width: 32px;\n margin: 0;\n font-size: var(--road-label-medium);\n text-align: center;\n}\n\n","import { Component, h, Element, Prop, Event, EventEmitter, Watch } from '@stencil/core';\nimport { navigationAddLessSolid, navigationAddMoreSolid } from '../../../icons';\n\n/**\n * @slot datalist - list of labels. also put show-labels=\"true\" and max=\"10\" for this exemple\n * `<datalist id=\"tickmarks\" slot=\"datalist\" class=\"tickmarks\">`\n `<option value=\"0\" label=\"0%\"></option>`\n `<option value=\"10\" label=\"10%\"></option>`\n `<option value=\"20\" label=\"20%\"></option>`\n `<option value=\"30\" label=\"30%\"></option>`\n `<option value=\"40\" label=\"40%\"></option>`\n `<option value=\"50\" label=\"50%\"></option>`\n `<option value=\"60\" label=\"60%\"></option>`\n `<option value=\"70\" label=\"70%\"></option>`\n `<option value=\"80\" label=\"80%\"></option>`\n `<option value=\"90\" label=\"90%\"></option>`\n `<option value=\"100\" label=\"100%\"></option>`\n `</datalist>`\n */\n\n@Component({\n tag: 'road-range',\n styleUrl: 'range.css',\n scoped: true,\n})\nexport class Range {\n\n @Element() el!: HTMLRoadRangeElement;\n\n /**\n * The id of range\n */\n @Prop() rangeId: string = `road-range-${rangeIds++}`;\n\n /**\n * The value of the range.\n */\n @Prop({ mutable: true }) value?: string | number | null = '';\n\n /**\n * The minimum value, which must not be greater than its maximum (max attribute) value.\n */\n @Prop() min!: string;\n\n /**\n * The maximum value, which must not be less than its minimum (min attribute) value.\n */\n @Prop() max!: string;\n\n /**\n * Works with the min and max attributes to limit the increments at which a value can be set.\n * Possible values are: `\"any\"` or a positive floating point number.\n */\n @Prop() step?: string;\n\n /**\n * Display the current value of the range\n */\n @Prop() showValue: boolean = false;\n\n /**\n * Display Tick of the range\n */\n @Prop() showTick: boolean = false;\n\n /**\n * Display labels of the range\n */\n @Prop() showLabels: boolean = false;\n\n /**\n * Update the native input element when the value changes\n */\n @Watch('value')\n protected valueChanged() {\n this.roadchange.emit({ value: this.value == null ? this.value : this.value.toString() });\n this.roadChange.emit({ value: this.value == null ? this.value : this.value.toString() });\n }\n\n /**\n * Emitted when the value has changed.\n */\n @Event() roadchange!: EventEmitter<{\n value: string | undefined | null;\n }>;\n /** @internal */\n @Event() roadChange!: EventEmitter<{\n value: string | undefined | null;\n }>;\n\n private getValue(): string {\n return typeof this.value === 'number'\n ? this.value.toString()\n : (this.value || '').toString();\n }\n\n private onInput = (ev: Event) => {\n const input = ev.target as HTMLInputElement | null;\n if (input) {\n this.value = input.value || '';\n }\n if(this.value !== null && this.value !== undefined) {\n this.el.style.setProperty('--value', `${this.value}`);\n }\n };\n\n render() {\n const value = this.getValue();\n const datalist = this.showLabels !== undefined ? `tickmarks` : '';\n\n return (\n <div class=\"form-group d-flex align-items-end\">\n {this.showTick && <road-icon icon={navigationAddLessSolid} class=\"mr-8\" size='sm'></road-icon>}\n <div class=\"form-range\" style={{'--min:': this.min, '--max': this.max, '--value': value}}>\n {this.showValue && <output></output>}\n {this.showLabels && <slot name=\"datalist\"/>}\n <input\n type=\"range\"\n class=\"form-range-input\"\n id={this.rangeId}\n min={this.min}\n max={this.max}\n value={value}\n onInput={this.onInput}\n list={datalist}\n \n />\n <div class=\"form-range-progress\"></div>\n </div>\n {this.showTick && <road-icon icon={navigationAddMoreSolid} class=\"ml-8\" size='sm'></road-icon>}\n </div>\n );\n }\n\n}\n\nlet rangeIds = 0;\n"],"mappings":"qFAAA,MAAMA,EAAW,g9E,MCyBJC,EAAK,M,uGAuERC,KAAAC,QAAWC,IACjB,MAAMC,EAAQD,EAAGE,OACjB,GAAID,EAAO,CACTH,KAAKK,MAAQF,EAAME,OAAS,E,CAE9B,GAAGL,KAAKK,QAAU,MAAQL,KAAKK,QAAUC,UAAW,CAClDN,KAAKO,GAAGC,MAAMC,YAAY,UAAW,GAAGT,KAAKK,Q,gBAtEvB,cAAcK,M,WAKkB,G,yEAqB7B,M,cAKD,M,gBAKK,K,CAMvBC,eACRX,KAAKY,WAAWC,KAAK,CAAER,MAAOL,KAAKK,OAAS,KAAOL,KAAKK,MAAQL,KAAKK,MAAMS,aAC3Ed,KAAKe,WAAWF,KAAK,CAAER,MAAOL,KAAKK,OAAS,KAAOL,KAAKK,MAAQL,KAAKK,MAAMS,Y,CAcrEE,WACN,cAAchB,KAAKK,QAAU,SACzBL,KAAKK,MAAMS,YACVd,KAAKK,OAAS,IAAIS,U,CAazBG,SACE,MAAMZ,EAAQL,KAAKgB,WACnB,MAAME,EAAWlB,KAAKmB,aAAeb,UAAY,YAAc,GAE/D,OACEc,EAAA,OAAKC,MAAM,qCACRrB,KAAKsB,UAAYF,EAAA,aAAWG,KAAMC,EAAwBH,MAAM,OAAOI,KAAK,OAC7EL,EAAA,OAAKC,MAAM,aAAab,MAAO,CAAC,SAAUR,KAAK0B,IAAK,QAAS1B,KAAK2B,IAAK,UAAWtB,IAC/EL,KAAK4B,WAAaR,EAAA,eAClBpB,KAAKmB,YAAcC,EAAA,QAAMS,KAAK,aAC/BT,EAAA,SACEU,KAAK,QACLT,MAAM,mBACNU,GAAI/B,KAAKgC,QACTN,IAAK1B,KAAK0B,IACVC,IAAK3B,KAAK2B,IACVtB,MAAOA,EACPJ,QAASD,KAAKC,QACdgC,KAAMf,IAGRE,EAAA,OAAKC,MAAM,yBAEZrB,KAAKsB,UAAYF,EAAA,aAAWG,KAAMW,EAAwBb,MAAM,OAAOI,KAAK,O,gFAOrF,IAAIf,EAAW,E"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["CACHED_MAP","getIconMap","window","Map","win","Ionicons","map","addIcons","icons","Object","keys","forEach","name","set","getUrl","i","url","getSrc","src","getName","icon","getNamedUrl","iconName","get","getAssetPath","isSrc","isStr","toLower","trim","invalidChars","replace","str","length","test","val","toLowerCase"],"sources":["./src/components/icon/utils.ts"],"sourcesContent":["import { getAssetPath } from '@stencil/core';\nimport { Icon } from './icon';\n\n\nlet CACHED_MAP: Map<string, string>;\n\nexport const getIconMap = (): Map<string, string> => {\n if (typeof window === 'undefined') {\n return new Map();\n } else {\n if (!CACHED_MAP) {\n const win = window as any;\n win.Ionicons = win.Ionicons || {};\n CACHED_MAP = win.Ionicons.map = win.Ionicons.map || new Map();\n }\n return CACHED_MAP;\n }\n};\n\nexport const addIcons = (icons: { [name: string]: string; }) => {\n const map = getIconMap();\n Object.keys(icons).forEach(name => map.set(name, icons[name]));\n};\n\n\nexport const getUrl = (i: Icon) => {\n let url = getSrc(i.src);\n if (url) {\n return url;\n }\n\n url = getName(i.name, i.icon);\n if (url) {\n return getNamedUrl(url);\n }\n\n if (i.icon) {\n url = getSrc(i.icon);\n if (url) {\n return url;\n }\n }\n\n return null;\n};\n\n\nconst getNamedUrl = (iconName: string) => {\n const url = getIconMap().get(iconName);\n if (url) {\n return url;\n }\n return getAssetPath(`svg/${iconName}.svg`);\n};\n\n\nexport const getName = (\n iconName: string | undefined,\n icon: string | undefined\n) => {\n\n if (!iconName && icon && !isSrc(icon)) {\n iconName = icon;\n }\n if (isStr(iconName)) {\n iconName = toLower(iconName);\n }\n\n if (!isStr(iconName) || iconName.trim() === '') {\n return null;\n }\n\n // only allow alpha characters and dash\n const invalidChars = iconName.replace(/[a-z]|-|\\d/gi, '');\n if (invalidChars !== '') {\n return null;\n }\n\n return iconName;\n};\n\nexport const getSrc = (src: string | undefined) => {\n if (isStr(src)) {\n src = src.trim();\n if (isSrc(src)) {\n return src;\n }\n }\n return null;\n};\n\nexport const isSrc = (str: string) => str.length > 0 && /(\\/|\\.)/.test(str);\n\nexport const isStr = (val: any): val is string => typeof val === 'string';\n\nexport const toLower = (val: string) => val.toLowerCase();"],"mappings":"oCAIA,IAAIA,EAEG,MAAMC,EAAa,KACxB,UAAWC,SAAW,YAAa,CACjC,OAAO,IAAIC,G,KACN,CACL,IAAKH,EAAY,CACf,MAAMI,EAAMF,OACZE,EAAIC,SAAWD,EAAIC,UAAY,GAC/BL,EAAaI,EAAIC,SAASC,IAAMF,EAAIC,SAASC,KAAO,IAAIH,G,CAE1D,OAAOH,C,SAIEO,EAAYC,IACvB,MAAMF,EAAML,IACZQ,OAAOC,KAAKF,GAAOG,SAAQC,GAAQN,EAAIO,IAAID,EAAMJ,EAAMI,KAAO,E,MAInDE,EAAUC,IACrB,IAAIC,EAAMC,EAAOF,EAAEG,KACnB,GAAIF,EAAK,CACP,OAAOA,C,CAGTA,EAAMG,EAAQJ,EAAEH,KAAMG,EAAEK,MACxB,GAAIJ,EAAK,CACP,OAAOK,EAAYL,E,CAGrB,GAAID,EAAEK,KAAM,CACVJ,EAAMC,EAAOF,EAAEK,MACf,GAAIJ,EAAK,CACP,OAAOA,C,EAIX,OAAO,IAAI,EAIb,MAAMK,EAAeC,IACnB,MAAMN,EAAMf,IAAasB,IAAID,GAC7B,GAAIN,EAAK,CACP,OAAOA,C,CAET,OAAOQ,EAAa,OAAOF,QAAe,E,MAI/BH,EAAU,CACrBG,EACAF,KAGA,IAAKE,GAAYF,IAASK,EAAML,GAAO,CACrCE,EAAWF,C,CAEb,GAAIM,EAAMJ,GAAW,CACnBA,EAAWK,EAAQL,E,CAGrB,IAAKI,EAAMJ,IAAaA,EAASM,SAAW,GAAI,CAC9C,OAAO,I,CAIT,MAAMC,EAAeP,EAASQ,QAAQ,eAAgB,IACtD,GAAID,IAAiB,GAAI,CACvB,OAAO,I,CAGT,OAAOP,CAAQ,EAGV,MAAML,EAAUC,IACrB,GAAIQ,EAAMR,GAAM,CACdA,EAAMA,EAAIU,OACV,GAAIH,EAAMP,GAAM,CACd,OAAOA,C,EAGX,OAAO,IAAI,EAGN,MAAMO,EAASM,GAAgBA,EAAIC,OAAS,GAAK,UAAUC,KAAKF,G,MAE1DL,EAASQ,UAAmCA,IAAQ,SAE1D,MAAMP,EAAWO,GAAgBA,EAAIC,qB"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["profilDropdownCss","Dropdown","this","onClick","isOpen","render","h","class","open","tabindex","role","name","size"],"sources":["./src/components/profil-dropdown/profil-dropdown.css?tag=road-profil-dropdown&encapsulation=shadow","./src/components/profil-dropdown/profil-dropdown.tsx"],"sourcesContent":["/*\n * Profil Dropdown\n *\n * Index\n * - Dropdown\n * - Dropdown menu\n */\n\n/**\n * @prop --margin-top: Top margin of the menu\n */\n\n/* PROFIL DROPDOWN\n -------------------- */\n\n:host {\n --margin-top: 0.5rem;\n display: block;\n font-size: var(--road-font-size-16);\n}\n\n.dropdown {\n position: relative;\n width: max-content;\n font-family: var(--road-font);\n}\n\n.dropdown summary {\n display: block;\n cursor: pointer;\n outline: none;\n}\n\n.dropdown summary::-webkit-details-marker { /* remove native arrow */\n display: none;\n}\n\n.dropdown-button{\n position: relative;\n z-index: 1;\n height: 3.5rem;\n cursor: pointer;\n border-radius: 0.25rem;\n}\n\n.dropdown-button:hover{\n background: var(--road-grey-200);\n}\n\n/**\n * Open state\n */\n\n.dropdown[open] .dropdown-menu {\n transform: scaleY(1);\n}\n\n.dropdown[open] .dropdown-menu.direction-top {\n position: absolute;\n bottom: 0;\n left: 0;\n transform: translate3d(0, -56px, 0);\n will-change: transform;\n}\n\n/* MENU\n-------------------- */\n\n.dropdown-menu {\n position: absolute;\n top: 0;\n left: 5.5rem;\n z-index: 2;\n display: flex;\n flex-direction: column;\n min-width: 16.875rem;\n padding: 0.5rem 0;\n color: var(--road-on-surface);\n background: var(--road-surface);\n border: 1px solid;\n border-color: var(--road-outline-weak);\n border-radius: 0.25rem;\n box-shadow: var(--road-elevation-low);\n transition: transform 0.2s ease-in-out;\n transform: scaleY(0);\n transform-origin: 0 0;\n}\n\n/* ITEM\n -------------------- */\n\nroad-item {\n font-size: var(--road-button-medium);\n}\n\n.profil-item {\n display: flex;\n padding-bottom: 1rem;\n margin: 1rem;\n cursor: auto;\n border-bottom: 1px solid var(--road-outline);\n}\n\n.profil-item-info {\n display: flex;\n flex-direction: column;\n margin-left: 1rem;\n text-align: left;\n}\n\n.profil-item-info-name {\n font-weight: 700;\n}\n\n\n.profil-item road-avatar:hover{\n box-shadow: none;\n}\n\n.dropdown-item {\n display: flex;\n align-items: center;\n min-height: 40px;\n padding: 0 1rem;\n font-size: var(--road-button-medium);\n line-height: 1.5;\n color: var(--road-on-surface);\n text-align: left;\n text-decoration: none;\n cursor: pointer;\n background: var(--road-surface);\n border: none;\n outline: none;\n}\n\n.dropdown-item-border {\n border-color: var(--road-outline);\n border-bottom: 1px solid;\n}\n\n.dropdown-item road-icon{\n margin-right: 0.7rem;\n}\n\n/**\n * Hover state\n */\n\nroad-item:hover:first-child,\nroad-item.focus-visible:first-child {\n background: none;\n}\n\nroad-item:hover,\nroad-item.focus-visible {\n background: var(--road-surface-inverse);\n}\n","import { Component, h, Prop } from '@stencil/core';\n\n/**\n * @slot - Element how will open the dropdown when clicked\n * @slot list - List of item values (you can add border with lines=`full` but not on the last item)\n * @slot avatar - Content of the avatar (img or First letter) <road-img> or <road-label>.\n * @slot avatarItem - Content of the avatar item (img or First letter) <road-img> or <road-label>.\n * @slot name - Content First and Last Name.\n * @slot email - Content email.\n\n\n */\n\n@Component({\n tag: 'road-profil-dropdown',\n styleUrl: 'profil-dropdown.css',\n shadow: true,\n})\nexport class Dropdown {\n\n /**\n * Set to `true` to open the dropdown menu and to `false` to close it.\n */\n @Prop({ mutable: true }) isOpen : boolean = false;\n\n /**\n * Toggle the display when clicking element in slot\n */\n private onClick = () => {\n this.isOpen = !this.isOpen;\n };\n\n render() {\n\n return (\n <details class=\"dropdown\" open={this.isOpen}>\n <summary aria-expanded={`${this.isOpen}`} tabindex=\"0\" role=\"button\" onClick={this.onClick}>\n <div class={`d-flex`}>\n <div>\n <road-avatar>\n <slot name=\"avatar\"/>\n </road-avatar>\n </div>\n </div>\n </summary>\n <div class={`dropdown-menu`}>\n <div class=\"profil-item\">\n <road-avatar size=\"sm\">\n <slot name=\"avatarItem\"/>\n </road-avatar>\n <div class=\"profil-item-info\">\n <span class=\"profil-item-info-name\">\n <slot name=\"name\"/>\n </span>\n <road-label>\n <slot name=\"email\"/>\n </road-label>\n </div>\n </div>\n <slot name=\"list\"/>\n </div>\n </details>\n );\n }\n\n}\n"],"mappings":"2CAAA,MAAMA,EAAoB,k1D,MCkBbC,EAAQ,M,yBAUXC,KAAAC,QAAU,KAChBD,KAAKE,QAAUF,KAAKE,MAAM,E,YANgB,K,CAS5CC,SAEE,OACEC,EAAA,WAASC,MAAM,WAAWC,KAAMN,KAAKE,QACnCE,EAAA,2BAAwB,GAAGJ,KAAKE,SAAUK,SAAS,IAAIC,KAAK,SAASP,QAASD,KAAKC,SACjFG,EAAA,OAAKC,MAAO,UACVD,EAAA,WACEA,EAAA,mBACEA,EAAA,QAAMK,KAAK,eAKnBL,EAAA,OAAKC,MAAO,iBACVD,EAAA,OAAKC,MAAM,eACTD,EAAA,eAAaM,KAAK,MAChBN,EAAA,QAAMK,KAAK,gBAEbL,EAAA,OAAKC,MAAM,oBACTD,EAAA,QAAMC,MAAM,yBACVD,EAAA,QAAMK,KAAK,UAEbL,EAAA,kBACEA,EAAA,QAAMK,KAAK,aAIjBL,EAAA,QAAMK,KAAK,U"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["radioCss","Radio","this","radioGroup","updateState","checked","value","onFocus","roadfocus","emit","roadFocus","onBlur","roadblur","roadBlur","radioIds","radioId","connectedCallback","undefined","el","closest","disconnectedCallback","onRoadChangedChanged","render","labelId","inverseClass","inverse","isInvalidClass","error","inlineClass","inline","h","Host","class","type","id","name","required","disabled","htmlFor","label"],"sources":["./src/components/radio/radio.css?tag=road-radio&encapsulation=scoped","./src/components/radio/radio.tsx"],"sourcesContent":["/*\n * Radio\n *\n * For accessibility, we provide a style for focus only on Tab,\n * for that add the javascript polyfill for focus-visible\n * (https://github.com/WICG/focus-visible).\n *\n * Index\n * - Radio\n * - Label\n * - Error\n * - Position\n */\n\n/* RADIO\n -------------------- */\n\n:host {\n position: relative;\n display: block;\n margin-bottom: 1.5rem;\n font-family: var(--road-font, sans-serif);\n font-size: var(--road-body-medium);\n line-height: 1.5;\n color: var(--road-on-surface);\n}\n\n/**\n * Inline radio\n */\n\n:host(.form-radio-inline) {\n display: inline-flex;\n flex-wrap: wrap;\n align-items: center;\n margin-right: 1.5rem;\n margin-bottom: 0;\n}\n\n/**\n * Hide input\n */\n\n.form-radio-input {\n position: absolute;\n z-index: -1;\n width: 20px;\n height: 20px;\n opacity: 0;\n}\n\n.form-radio-input:disabled {\n z-index: 1;\n width: 100%;\n cursor: not-allowed;\n}\n\n/* LABEL\n -------------------- */\n\n.form-radio-label {\n position: relative;\n display: inline-flex;\n align-items: flex-start;\n margin: 0;\n cursor: pointer;\n -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n\n.form-radio-label::before {\n box-sizing: border-box;\n display: block;\n flex-shrink: 0;\n width: 1.25rem;\n height: 1.25rem;\n margin: 0.1rem 0.75rem 0 0;\n content: \"\";\n background: var(--road-surface);\n border: 1px solid var(--road-input-outline);\n border-radius: 50%;\n transition: border-color 0.2s ease-in-out;\n}\n\n.form-radio-label::after {\n position: absolute;\n top: 0.285rem;\n left: 0.1875rem;\n box-sizing: border-box;\n display: block;\n width: 0.875rem;\n height: 0.875rem;\n content: \"\";\n background: var(--road-grey-60);\n border: none;\n border-radius: 50%;\n transition: background 0.2s ease-in-out, transform 0.2s ease-in-out;\n transform: scale(0);\n transform-origin: 50% 50%;\n}\n\n/**\n * Hover state\n */\n\n@media (hover: hover) {\n\n .form-radio-input ~ .form-radio-label:hover::before {\n border-color: var(--road-input-surface);\n }\n\n .form-radio-input:checked ~ .form-radio-label:hover::after {\n background: var(--road-input-surface-variant);\n }\n}\n\n/**\n * Checked state\n */\n\n.form-radio-input:checked ~ .form-radio-label::after {\n background: var(--road-input-surface);\n opacity: 1;\n transform: scale(1);\n}\n\n/**\n * Focus on Tab\n */\n\n.form-radio-input.focus-visible ~ .form-radio-label::before {\n box-shadow: 0 0 0 0.125rem var(--road-grey-100-new), 0 0 0 0.1875rem var(--road-input-outline-variant);\n}\n\n.form-radio-input.focus-visible:checked ~ .form-radio-label::after {\n background: var(--road-primary-700);\n}\n\n/**\n * Disabled state\n */\n\n.form-radio-input:disabled ~ .form-radio-label,\n.form-radio-input[readonly] ~ .form-radio-label {\n cursor: not-allowed;\n}\n\n.form-radio-input:disabled ~ .form-radio-label::before,\n.form-radio-input[readonly] ~ .form-radio-label::before {\n background: var(--road-on-surface-disabled);\n border: none;\n}\n\n.form-radio-input:disabled ~ .form-radio-label::after,\n.form-radio-input[readonly] ~ .form-radio-label::after {\n background: var(--road-grey-60);\n}\n\n/* ERROR\n -------------------- */\n\n.form-radio-input.is-invalid ~ .form-radio-label::before {\n border-color: var(--road-danger-outline);\n}\n\n/* POSITION\n -------------------- */\n\n.form-radio-inverse {\n display: flex;\n flex-direction: row-reverse;\n justify-content: space-between;\n}\n\n.form-radio-inverse::before {\n margin: 0 0 0 1rem;\n}\n\n.form-radio-inverse::after {\n right: 0.1875rem;\n left: auto;\n}\n","import { Component, Element, Event, EventEmitter, Host, Prop, State, h, Listen } from '@stencil/core';\nimport './../../utils/polyfill';\n\n@Component({\n tag: 'road-radio',\n styleUrl: 'radio.css',\n scoped: true,\n})\nexport class Radio {\n\n private radioGroup: HTMLRoadRadioGroupElement | null = null;\n\n @Element() el!: HTMLRoadRadioElement;\n\n /**\n * The id of radio\n */\n @Prop() radioId: string = `road-radio-${radioIds++}`;\n\n /**\n * If `true`, the radio is selected.\n */\n @State() checked: boolean = false;\n\n /**\n * The name of the control, which is submitted with the form data.\n */\n @Prop() name: string = this.radioId;\n\n /**\n * If `true`, the user must fill in a value before submitting a form.\n */\n @Prop() required: boolean = false;\n\n /**\n * If `true`, the user cannot interact with the radio.\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Value the form will get\n */\n @Prop() value?: any | null;\n\n /**\n * Label for the field\n */\n @Prop() label: string = `${this.radioId}-label`;\n\n /**\n * If `true`, the label and the radio are inverse and spaced\n */\n @Prop() inverse: boolean = false;\n\n /**\n * Error message for the field\n */\n @Prop() error?: boolean;\n\n /**\n * Helper message for the field\n */\n @Prop() helper?: string;\n\n /**\n * Inline multiple radio\n */\n @Prop() inline: boolean = true;\n\n /**\n * Emitted when the radio button has focus.\n */\n @Event() roadfocus!: EventEmitter<void>;\n /** @internal */\n @Event() roadFocus!: EventEmitter<void>;\n\n /**\n * Emitted when the radio button loses focus.\n */\n @Event() roadblur!: EventEmitter<void>;\n /** @internal */\n @Event() roadBlur!: EventEmitter<void>;\n\n connectedCallback() {\n if (this.value === undefined) {\n this.value = this.radioId;\n }\n const radioGroup = this.radioGroup = this.el.closest('road-radio-group');\n if (radioGroup) {\n this.updateState();\n }\n }\n\n disconnectedCallback() {\n const radioGroup = this.radioGroup;\n if (radioGroup) {\n this.radioGroup = null;\n }\n }\n\n @Listen('roadChange', {target: 'window'})\n @Listen('roadchange', {target: 'window'})\n onRoadChangedChanged() {\n this.updateState();\n }\n\n private updateState = () => {\n if (this.radioGroup) {\n this.checked = this.radioGroup.value === this.value;\n }\n };\n\n private onFocus = () => {\n this.roadfocus.emit();\n this.roadFocus.emit();\n };\n\n private onBlur = () => {\n this.roadblur.emit();\n this.roadBlur.emit();\n };\n\n render() {\n const labelId = this.radioId + '-label';\n const inverseClass = this.inverse && 'form-radio-inverse';\n const isInvalidClass = this.error ? 'is-invalid' : '';\n const inlineClass = this.inline ? 'form-radio-inline' : '';\n\n return (\n <Host class={`form-radio ${inlineClass}`}>\n <input\n class={`form-radio-input ${isInvalidClass}`}\n type=\"radio\"\n id={this.radioId}\n name={this.name}\n required={this.required}\n disabled={this.disabled}\n aria-disabled={this.disabled ? 'true' : null}\n checked={this.checked}\n aria-checked={`${this.checked}`}\n aria-labelledby={labelId}\n value={this.value}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n />\n <label class={`form-radio-label ${inverseClass}`} id={labelId} htmlFor={this.radioId}>{this.label}</label>\n </Host>\n );\n }\n}\n\nlet radioIds = 0;\n"],"mappings":"mFAAA,MAAMA,EAAW,43F,MCQJC,EAAK,M,yKAERC,KAAAC,WAA+C,KAgG/CD,KAAAE,YAAc,KACpB,GAAIF,KAAKC,WAAY,CACnBD,KAAKG,QAAUH,KAAKC,WAAWG,QAAUJ,KAAKI,K,GAI1CJ,KAAAK,QAAU,KAChBL,KAAKM,UAAUC,OACfP,KAAKQ,UAAUD,MAAM,EAGfP,KAAAS,OAAS,KACfT,KAAKU,SAASH,OACdP,KAAKW,SAASJ,MAAM,E,aAtGI,cAAcK,M,aAKZ,M,UAKLZ,KAAKa,Q,cAKA,M,cAKA,M,gCAUJ,GAAGb,KAAKa,gB,aAKL,M,uDAeD,I,CAgB1BC,oBACE,GAAId,KAAKI,QAAUW,UAAW,CAC5Bf,KAAKI,MAAQJ,KAAKa,O,CAEpB,MAAMZ,EAAaD,KAAKC,WAAaD,KAAKgB,GAAGC,QAAQ,oBACrD,GAAIhB,EAAY,CACdD,KAAKE,a,EAITgB,uBACE,MAAMjB,EAAaD,KAAKC,WACxB,GAAIA,EAAY,CACdD,KAAKC,WAAa,I,EAMtBkB,uBACEnB,KAAKE,a,CAmBPkB,SACE,MAAMC,EAAUrB,KAAKa,QAAU,SAC/B,MAAMS,EAAetB,KAAKuB,SAAW,qBACrC,MAAMC,EAAiBxB,KAAKyB,MAAQ,aAAe,GACnD,MAAMC,EAAc1B,KAAK2B,OAAS,oBAAsB,GAExD,OACEC,EAACC,EAAI,CAACC,MAAO,cAAcJ,KACzBE,EAAA,SACEE,MAAO,oBAAoBN,IAC3BO,KAAK,QACLC,GAAIhC,KAAKa,QACToB,KAAMjC,KAAKiC,KACXC,SAAUlC,KAAKkC,SACfC,SAAUnC,KAAKmC,SAAQ,gBACRnC,KAAKmC,SAAW,OAAS,KACxChC,QAASH,KAAKG,QAAO,eACP,GAAGH,KAAKG,UAAS,kBACdkB,EACjBjB,MAAOJ,KAAKI,MACZC,QAASL,KAAKK,QACdI,OAAQT,KAAKS,SAEfmB,EAAA,SAAOE,MAAO,oBAAoBR,IAAgBU,GAAIX,EAASe,QAASpC,KAAKa,SAAUb,KAAKqC,O,2BAMpG,IAAIzB,EAAW,E"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["progressTrackerCss","ProgressTracker","render","h","Host"],"sources":["./src/components/progress-tracker/progress-tracker.css?tag=road-progress-tracker&encapsulation=shadow","./src/components/progress-tracker/progress-tracker.tsx"],"sourcesContent":["/*\n * Progress tracker\n *\n * Index\n * - Item\n * - Link\n * - Icon\n * - Title\n * - Completed\n */\n\n:host {\n display: block;\n}\n\n:host ul{\n padding-left: 0;\n}\n\n/* PROGRESS TRACKER\n -------------------- */\n\n.progress-tracker {\n display: flex;\n flex-direction: column;\n padding-left: 0;\n list-style: none;\n}\n\n","import { Component, Host, h } from '@stencil/core';\n\n/**\n * @slot - content of the progress stepper tracker item, it should be road-progress-tracker-item elements.\n * \n * if the state of the step is completed add the class `completed` on the road-progress-tracker-item\n * if the state of the step is in progress add the class `in-progress` on the road-progress-tracker-item\n * if the state of the step is current add the class `current` on the road-progress-tracker-item\n\n */\n\n@Component({\n tag: 'road-progress-tracker',\n styleUrl: 'progress-tracker.css',\n shadow: true,\n})\nexport class ProgressTracker {\n\n render() {\n\n return (\n <Host>\n <nav>\n <ul>\n <slot/>\n </ul>\n </nav>\n </Host>\n );\n }\n\n}\n"],"mappings":"kDAAA,MAAMA,EAAqB,mI,MCgBdC,EAAe,M,yBAEvBC,SAEE,OACEC,EAACC,EAAI,KACHD,EAAA,WACEA,EAAA,UACEA,EAAA,e"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["global","factory","this","applyFocusVisiblePolyfill","scope","hadKeyboardEvent","hadFocusVisibleRecently","hadFocusVisibleRecentlyTimeout","inputTypesAllowlist","text","search","url","tel","email","password","number","date","month","week","time","datetime","isValidFocusTarget","el","document","nodeName","classList","focusTriggersKeyboardModality","type","tagName","readOnly","isContentEditable","addFocusVisibleClass","contains","add","setAttribute","removeFocusVisibleClass","hasAttribute","remove","removeAttribute","onKeyDown","e","metaKey","altKey","ctrlKey","activeElement","onPointerDown","onFocus","target","onBlur","window","clearTimeout","setTimeout","onVisibilityChange","visibilityState","addInitialPointerMoveListeners","addEventListener","onInitialPointerMove","removeInitialPointerMoveListeners","removeEventListener","toLowerCase","nodeType","Node","DOCUMENT_FRAGMENT_NODE","host","DOCUMENT_NODE","documentElement","event","CustomEvent","error","createEvent","initCustomEvent","dispatchEvent"],"sources":["./node_modules/focus-visible/dist/focus-visible.js"],"sourcesContent":["(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (factory());\n}(this, (function () { 'use strict';\n\n /**\n * Applies the :focus-visible polyfill at the given scope.\n * A scope in this case is either the top-level Document or a Shadow Root.\n *\n * @param {(Document|ShadowRoot)} scope\n * @see https://github.com/WICG/focus-visible\n */\n function applyFocusVisiblePolyfill(scope) {\n var hadKeyboardEvent = true;\n var hadFocusVisibleRecently = false;\n var hadFocusVisibleRecentlyTimeout = null;\n\n var inputTypesAllowlist = {\n text: true,\n search: true,\n url: true,\n tel: true,\n email: true,\n password: true,\n number: true,\n date: true,\n month: true,\n week: true,\n time: true,\n datetime: true,\n 'datetime-local': true\n };\n\n /**\n * Helper function for legacy browsers and iframes which sometimes focus\n * elements like document, body, and non-interactive SVG.\n * @param {Element} el\n */\n function isValidFocusTarget(el) {\n if (\n el &&\n el !== document &&\n el.nodeName !== 'HTML' &&\n el.nodeName !== 'BODY' &&\n 'classList' in el &&\n 'contains' in el.classList\n ) {\n return true;\n }\n return false;\n }\n\n /**\n * Computes whether the given element should automatically trigger the\n * `focus-visible` class being added, i.e. whether it should always match\n * `:focus-visible` when focused.\n * @param {Element} el\n * @return {boolean}\n */\n function focusTriggersKeyboardModality(el) {\n var type = el.type;\n var tagName = el.tagName;\n\n if (tagName === 'INPUT' && inputTypesAllowlist[type] && !el.readOnly) {\n return true;\n }\n\n if (tagName === 'TEXTAREA' && !el.readOnly) {\n return true;\n }\n\n if (el.isContentEditable) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Add the `focus-visible` class to the given element if it was not added by\n * the author.\n * @param {Element} el\n */\n function addFocusVisibleClass(el) {\n if (el.classList.contains('focus-visible')) {\n return;\n }\n el.classList.add('focus-visible');\n el.setAttribute('data-focus-visible-added', '');\n }\n\n /**\n * Remove the `focus-visible` class from the given element if it was not\n * originally added by the author.\n * @param {Element} el\n */\n function removeFocusVisibleClass(el) {\n if (!el.hasAttribute('data-focus-visible-added')) {\n return;\n }\n el.classList.remove('focus-visible');\n el.removeAttribute('data-focus-visible-added');\n }\n\n /**\n * If the most recent user interaction was via the keyboard;\n * and the key press did not include a meta, alt/option, or control key;\n * then the modality is keyboard. Otherwise, the modality is not keyboard.\n * Apply `focus-visible` to any current active element and keep track\n * of our keyboard modality state with `hadKeyboardEvent`.\n * @param {KeyboardEvent} e\n */\n function onKeyDown(e) {\n if (e.metaKey || e.altKey || e.ctrlKey) {\n return;\n }\n\n if (isValidFocusTarget(scope.activeElement)) {\n addFocusVisibleClass(scope.activeElement);\n }\n\n hadKeyboardEvent = true;\n }\n\n /**\n * If at any point a user clicks with a pointing device, ensure that we change\n * the modality away from keyboard.\n * This avoids the situation where a user presses a key on an already focused\n * element, and then clicks on a different element, focusing it with a\n * pointing device, while we still think we're in keyboard modality.\n * @param {Event} e\n */\n function onPointerDown(e) {\n hadKeyboardEvent = false;\n }\n\n /**\n * On `focus`, add the `focus-visible` class to the target if:\n * - the target received focus as a result of keyboard navigation, or\n * - the event target is an element that will likely require interaction\n * via the keyboard (e.g. a text box)\n * @param {Event} e\n */\n function onFocus(e) {\n // Prevent IE from focusing the document or HTML element.\n if (!isValidFocusTarget(e.target)) {\n return;\n }\n\n if (hadKeyboardEvent || focusTriggersKeyboardModality(e.target)) {\n addFocusVisibleClass(e.target);\n }\n }\n\n /**\n * On `blur`, remove the `focus-visible` class from the target.\n * @param {Event} e\n */\n function onBlur(e) {\n if (!isValidFocusTarget(e.target)) {\n return;\n }\n\n if (\n e.target.classList.contains('focus-visible') ||\n e.target.hasAttribute('data-focus-visible-added')\n ) {\n // To detect a tab/window switch, we look for a blur event followed\n // rapidly by a visibility change.\n // If we don't see a visibility change within 100ms, it's probably a\n // regular focus change.\n hadFocusVisibleRecently = true;\n window.clearTimeout(hadFocusVisibleRecentlyTimeout);\n hadFocusVisibleRecentlyTimeout = window.setTimeout(function() {\n hadFocusVisibleRecently = false;\n }, 100);\n removeFocusVisibleClass(e.target);\n }\n }\n\n /**\n * If the user changes tabs, keep track of whether or not the previously\n * focused element had .focus-visible.\n * @param {Event} e\n */\n function onVisibilityChange(e) {\n if (document.visibilityState === 'hidden') {\n // If the tab becomes active again, the browser will handle calling focus\n // on the element (Safari actually calls it twice).\n // If this tab change caused a blur on an element with focus-visible,\n // re-apply the class when the user switches back to the tab.\n if (hadFocusVisibleRecently) {\n hadKeyboardEvent = true;\n }\n addInitialPointerMoveListeners();\n }\n }\n\n /**\n * Add a group of listeners to detect usage of any pointing devices.\n * These listeners will be added when the polyfill first loads, and anytime\n * the window is blurred, so that they are active when the window regains\n * focus.\n */\n function addInitialPointerMoveListeners() {\n document.addEventListener('mousemove', onInitialPointerMove);\n document.addEventListener('mousedown', onInitialPointerMove);\n document.addEventListener('mouseup', onInitialPointerMove);\n document.addEventListener('pointermove', onInitialPointerMove);\n document.addEventListener('pointerdown', onInitialPointerMove);\n document.addEventListener('pointerup', onInitialPointerMove);\n document.addEventListener('touchmove', onInitialPointerMove);\n document.addEventListener('touchstart', onInitialPointerMove);\n document.addEventListener('touchend', onInitialPointerMove);\n }\n\n function removeInitialPointerMoveListeners() {\n document.removeEventListener('mousemove', onInitialPointerMove);\n document.removeEventListener('mousedown', onInitialPointerMove);\n document.removeEventListener('mouseup', onInitialPointerMove);\n document.removeEventListener('pointermove', onInitialPointerMove);\n document.removeEventListener('pointerdown', onInitialPointerMove);\n document.removeEventListener('pointerup', onInitialPointerMove);\n document.removeEventListener('touchmove', onInitialPointerMove);\n document.removeEventListener('touchstart', onInitialPointerMove);\n document.removeEventListener('touchend', onInitialPointerMove);\n }\n\n /**\n * When the polfyill first loads, assume the user is in keyboard modality.\n * If any event is received from a pointing device (e.g. mouse, pointer,\n * touch), turn off keyboard modality.\n * This accounts for situations where focus enters the page from the URL bar.\n * @param {Event} e\n */\n function onInitialPointerMove(e) {\n // Work around a Safari quirk that fires a mousemove on <html> whenever the\n // window blurs, even if you're tabbing out of the page. ¯\\_(ツ)_/¯\n if (e.target.nodeName && e.target.nodeName.toLowerCase() === 'html') {\n return;\n }\n\n hadKeyboardEvent = false;\n removeInitialPointerMoveListeners();\n }\n\n // For some kinds of state, we are interested in changes at the global scope\n // only. For example, global pointer input, global key presses and global\n // visibility change should affect the state at every scope:\n document.addEventListener('keydown', onKeyDown, true);\n document.addEventListener('mousedown', onPointerDown, true);\n document.addEventListener('pointerdown', onPointerDown, true);\n document.addEventListener('touchstart', onPointerDown, true);\n document.addEventListener('visibilitychange', onVisibilityChange, true);\n\n addInitialPointerMoveListeners();\n\n // For focus and blur, we specifically care about state changes in the local\n // scope. This is because focus / blur events that originate from within a\n // shadow root are not re-dispatched from the host element if it was already\n // the active element in its own scope:\n scope.addEventListener('focus', onFocus, true);\n scope.addEventListener('blur', onBlur, true);\n\n // We detect that a node is a ShadowRoot by ensuring that it is a\n // DocumentFragment and also has a host property. This check covers native\n // implementation and polyfill implementation transparently. If we only cared\n // about the native implementation, we could just check if the scope was\n // an instance of a ShadowRoot.\n if (scope.nodeType === Node.DOCUMENT_FRAGMENT_NODE && scope.host) {\n // Since a ShadowRoot is a special kind of DocumentFragment, it does not\n // have a root element to add a class to. So, we add this attribute to the\n // host element instead:\n scope.host.setAttribute('data-js-focus-visible', '');\n } else if (scope.nodeType === Node.DOCUMENT_NODE) {\n document.documentElement.classList.add('js-focus-visible');\n document.documentElement.setAttribute('data-js-focus-visible', '');\n }\n }\n\n // It is important to wrap all references to global window and document in\n // these checks to support server-side rendering use cases\n // @see https://github.com/WICG/focus-visible/issues/199\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n // Make the polyfill helper globally available. This can be used as a signal\n // to interested libraries that wish to coordinate with the polyfill for e.g.,\n // applying the polyfill to a shadow root:\n window.applyFocusVisiblePolyfill = applyFocusVisiblePolyfill;\n\n // Notify interested libraries of the polyfill's presence, in case the\n // polyfill was loaded lazily:\n var event;\n\n try {\n event = new CustomEvent('focus-visible-polyfill-ready');\n } catch (error) {\n // IE11 does not support using CustomEvent as a constructor directly:\n event = document.createEvent('CustomEvent');\n event.initCustomEvent('focus-visible-polyfill-ready', false, false, {});\n }\n\n window.dispatchEvent(event);\n }\n\n if (typeof document !== 'undefined') {\n // Apply the polyfill to the global document, so that no JavaScript\n // coordination is required to use the polyfill in the top-level document:\n applyFocusVisiblePolyfill(document);\n }\n\n})));\n"],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- import{r as t,e,h as s,H as i,f as n}from"./p-abdbf6ac.js";function r(t){return!Array.isArray?M(t)==="[object Array]":Array.isArray(t)}const c=1/0;function o(t){if(typeof t=="string"){return t}let e=t+"";return e=="0"&&1/t==-c?"-0":e}function a(t){return t==null?"":o(t)}function l(t){return typeof t==="string"}function h(t){return typeof t==="number"}function u(t){return t===true||t===false||d(t)&&M(t)=="[object Boolean]"}function f(t){return typeof t==="object"}function d(t){return f(t)&&t!==null}function g(t){return t!==undefined&&t!==null}function m(t){return!t.trim().length}function M(t){return t==null?t===undefined?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const x="Extended search is not available";const p="Incorrect 'index' type";const v=t=>`Invalid value for key ${t}`;const y=t=>`Pattern length exceeds max of ${t}.`;const L=t=>`Missing ${t} property in key`;const w=t=>`Property 'weight' in key '${t}' must be a positive integer`;const b=Object.prototype.hasOwnProperty;class ${constructor(t){this._keys=[];this._keyMap={};let e=0;t.forEach((t=>{let s=k(t);e+=s.weight;this._keys.push(s);this._keyMap[s.id]=s;e+=s.weight}));this._keys.forEach((t=>{t.weight/=e}))}get(t){return this._keyMap[t]}keys(){return this._keys}toJSON(){return JSON.stringify(this._keys)}}function k(t){let e=null;let s=null;let i=null;let n=1;if(l(t)||r(t)){i=t;e=S(t);s=A(t)}else{if(!b.call(t,"name")){throw new Error(L("name"))}const r=t.name;i=r;if(b.call(t,"weight")){n=t.weight;if(n<=0){throw new Error(w(r))}}e=S(r);s=A(r)}return{path:e,id:s,weight:n,src:i}}function S(t){return r(t)?t:t.split(".")}function A(t){return r(t)?t.join("."):t}function C(t,e){let s=[];let i=false;const n=(t,e,c)=>{if(!g(t)){return}if(!e[c]){s.push(t)}else{let o=e[c];const f=t[o];if(!g(f)){return}if(c===e.length-1&&(l(f)||h(f)||u(f))){s.push(a(f))}else if(r(f)){i=true;for(let t=0,s=f.length;t<s;t+=1){n(f[t],e,c+1)}}else if(e.length){n(f,e,c+1)}}};n(t,l(e)?e.split("."):e,0);return i?s:s[0]}const R={includeMatches:false,findAllMatches:false,minMatchCharLength:1};const N={isCaseSensitive:false,includeScore:false,keys:[],shouldSort:true,sortFn:(t,e)=>t.score===e.score?t.idx<e.idx?-1:1:t.score<e.score?-1:1};const I={location:0,threshold:.6,distance:100};const F={useExtendedSearch:false,getFn:C,ignoreLocation:false,ignoreFieldNorm:false,fieldNormWeight:1};var j={...N,...R,...I,...F};const O=/[^ ]+/g;function E(t=1,e=3){const s=new Map;const i=Math.pow(10,e);return{get(e){const n=e.match(O).length;if(s.has(n)){return s.get(n)}const r=1/Math.pow(n,.5*t);const c=parseFloat(Math.round(r*i)/i);s.set(n,c);return c},clear(){s.clear()}}}class _{constructor({getFn:t=j.getFn,fieldNormWeight:e=j.fieldNormWeight}={}){this.norm=E(e,3);this.getFn=t;this.isCreated=false;this.setIndexRecords()}setSources(t=[]){this.docs=t}setIndexRecords(t=[]){this.records=t}setKeys(t=[]){this.keys=t;this._keysMap={};t.forEach(((t,e)=>{this._keysMap[t.id]=e}))}create(){if(this.isCreated||!this.docs.length){return}this.isCreated=true;if(l(this.docs[0])){this.docs.forEach(((t,e)=>{this._addString(t,e)}))}else{this.docs.forEach(((t,e)=>{this._addObject(t,e)}))}this.norm.clear()}add(t){const e=this.size();if(l(t)){this._addString(t,e)}else{this._addObject(t,e)}}removeAt(t){this.records.splice(t,1);for(let e=t,s=this.size();e<s;e+=1){this.records[e].i-=1}}getValueForItemAtKeyId(t,e){return t[this._keysMap[e]]}size(){return this.records.length}_addString(t,e){if(!g(t)||m(t)){return}let s={v:t,i:e,n:this.norm.get(t)};this.records.push(s)}_addObject(t,e){let s={i:e,$:{}};this.keys.forEach(((e,i)=>{let n=this.getFn(t,e.path);if(!g(n)){return}if(r(n)){let t=[];const e=[{nestedArrIndex:-1,value:n}];while(e.length){const{nestedArrIndex:s,value:i}=e.pop();if(!g(i)){continue}if(l(i)&&!m(i)){let e={v:i,i:s,n:this.norm.get(i)};t.push(e)}else if(r(i)){i.forEach(((t,s)=>{e.push({nestedArrIndex:s,value:t})}))}else;}s.$[i]=t}else if(!m(n)){let t={v:n,n:this.norm.get(n)};s.$[i]=t}}));this.records.push(s)}toJSON(){return{keys:this.keys,records:this.records}}}function W(t,e,{getFn:s=j.getFn,fieldNormWeight:i=j.fieldNormWeight}={}){const n=new _({getFn:s,fieldNormWeight:i});n.setKeys(t.map(k));n.setSources(e);n.create();return n}function z(t,{getFn:e=j.getFn,fieldNormWeight:s=j.fieldNormWeight}={}){const{keys:i,records:n}=t;const r=new _({getFn:e,fieldNormWeight:s});r.setKeys(i);r.setIndexRecords(n);return r}function P(t,{errors:e=0,currentLocation:s=0,expectedLocation:i=0,distance:n=j.distance,ignoreLocation:r=j.ignoreLocation}={}){const c=e/t.length;if(r){return c}const o=Math.abs(i-s);if(!n){return o?1:c}return c+o/n}function T(t=[],e=j.minMatchCharLength){let s=[];let i=-1;let n=-1;let r=0;for(let c=t.length;r<c;r+=1){let c=t[r];if(c&&i===-1){i=r}else if(!c&&i!==-1){n=r-1;if(n-i+1>=e){s.push([i,n])}i=-1}}if(t[r-1]&&r-i>=e){s.push([i,r-1])}return s}const H=32;function J(t,e,s,{location:i=j.location,distance:n=j.distance,threshold:r=j.threshold,findAllMatches:c=j.findAllMatches,minMatchCharLength:o=j.minMatchCharLength,includeMatches:a=j.includeMatches,ignoreLocation:l=j.ignoreLocation}={}){if(e.length>H){throw new Error(y(H))}const h=e.length;const u=t.length;const f=Math.max(0,Math.min(i,u));let d=r;let g=f;const m=o>1||a;const M=m?Array(u):[];let x;while((x=t.indexOf(e,g))>-1){let t=P(e,{currentLocation:x,expectedLocation:f,distance:n,ignoreLocation:l});d=Math.min(t,d);g=x+h;if(m){let t=0;while(t<h){M[x+t]=1;t+=1}}}g=-1;let p=[];let v=1;let L=h+u;const w=1<<h-1;for(let y=0;y<h;y+=1){let i=0;let r=L;while(i<r){const t=P(e,{errors:y,currentLocation:f+r,expectedLocation:f,distance:n,ignoreLocation:l});if(t<=d){i=r}else{L=r}r=Math.floor((L-i)/2+i)}L=r;let o=Math.max(1,f-r+1);let a=c?u:Math.min(f+r,u)+h;let x=Array(a+2);x[a+1]=(1<<y)-1;for(let c=a;c>=o;c-=1){let i=c-1;let r=s[t.charAt(i)];if(m){M[i]=+!!r}x[c]=(x[c+1]<<1|1)&r;if(y){x[c]|=(p[c+1]|p[c])<<1|1|p[c+1]}if(x[c]&w){v=P(e,{errors:y,currentLocation:i,expectedLocation:f,distance:n,ignoreLocation:l});if(v<=d){d=v;g=i;if(g<=f){break}o=Math.max(1,2*f-g)}}}const b=P(e,{errors:y+1,currentLocation:f,expectedLocation:f,distance:n,ignoreLocation:l});if(b>d){break}p=x}const b={isMatch:g>=0,score:Math.max(.001,v)};if(m){const t=T(M,o);if(!t.length){b.isMatch=false}else if(a){b.indices=t}}return b}function B(t){let e={};for(let s=0,i=t.length;s<i;s+=1){const n=t.charAt(s);e[n]=(e[n]||0)|1<<i-s-1}return e}class K{constructor(t,{location:e=j.location,threshold:s=j.threshold,distance:i=j.distance,includeMatches:n=j.includeMatches,findAllMatches:r=j.findAllMatches,minMatchCharLength:c=j.minMatchCharLength,isCaseSensitive:o=j.isCaseSensitive,ignoreLocation:a=j.ignoreLocation}={}){this.options={location:e,threshold:s,distance:i,includeMatches:n,findAllMatches:r,minMatchCharLength:c,isCaseSensitive:o,ignoreLocation:a};this.pattern=o?t:t.toLowerCase();this.chunks=[];if(!this.pattern.length){return}const l=(t,e)=>{this.chunks.push({pattern:t,alphabet:B(t),startIndex:e})};const h=this.pattern.length;if(h>H){let t=0;const e=h%H;const s=h-e;while(t<s){l(this.pattern.substr(t,H),t);t+=H}if(e){const t=h-H;l(this.pattern.substr(t),t)}}else{l(this.pattern,0)}}searchIn(t){const{isCaseSensitive:e,includeMatches:s}=this.options;if(!e){t=t.toLowerCase()}if(this.pattern===t){let e={isMatch:true,score:0};if(s){e.indices=[[0,t.length-1]]}return e}const{location:i,distance:n,threshold:r,findAllMatches:c,minMatchCharLength:o,ignoreLocation:a}=this.options;let l=[];let h=0;let u=false;this.chunks.forEach((({pattern:e,alphabet:f,startIndex:d})=>{const{isMatch:g,score:m,indices:M}=J(t,e,f,{location:i+d,distance:n,threshold:r,findAllMatches:c,minMatchCharLength:o,includeMatches:s,ignoreLocation:a});if(g){u=true}h+=m;if(g&&M){l=[...l,...M]}}));let f={isMatch:u,score:u?h/this.chunks.length:1};if(u&&s){f.indices=l}return f}}class D{constructor(t){this.pattern=t}static isMultiMatch(t){return U(t,this.multiRegex)}static isSingleMatch(t){return U(t,this.singleRegex)}search(){}}function U(t,e){const s=t.match(e);return s?s[1]:null}class V extends D{constructor(t){super(t)}static get type(){return"exact"}static get multiRegex(){return/^="(.*)"$/}static get singleRegex(){return/^=(.*)$/}search(t){const e=t===this.pattern;return{isMatch:e,score:e?0:1,indices:[0,this.pattern.length-1]}}}class q extends D{constructor(t){super(t)}static get type(){return"inverse-exact"}static get multiRegex(){return/^!"(.*)"$/}static get singleRegex(){return/^!(.*)$/}search(t){const e=t.indexOf(this.pattern);const s=e===-1;return{isMatch:s,score:s?0:1,indices:[0,t.length-1]}}}class G extends D{constructor(t){super(t)}static get type(){return"prefix-exact"}static get multiRegex(){return/^\^"(.*)"$/}static get singleRegex(){return/^\^(.*)$/}search(t){const e=t.startsWith(this.pattern);return{isMatch:e,score:e?0:1,indices:[0,this.pattern.length-1]}}}class Q extends D{constructor(t){super(t)}static get type(){return"inverse-prefix-exact"}static get multiRegex(){return/^!\^"(.*)"$/}static get singleRegex(){return/^!\^(.*)$/}search(t){const e=!t.startsWith(this.pattern);return{isMatch:e,score:e?0:1,indices:[0,t.length-1]}}}class X extends D{constructor(t){super(t)}static get type(){return"suffix-exact"}static get multiRegex(){return/^"(.*)"\$$/}static get singleRegex(){return/^(.*)\$$/}search(t){const e=t.endsWith(this.pattern);return{isMatch:e,score:e?0:1,indices:[t.length-this.pattern.length,t.length-1]}}}class Y extends D{constructor(t){super(t)}static get type(){return"inverse-suffix-exact"}static get multiRegex(){return/^!"(.*)"\$$/}static get singleRegex(){return/^!(.*)\$$/}search(t){const e=!t.endsWith(this.pattern);return{isMatch:e,score:e?0:1,indices:[0,t.length-1]}}}class Z extends D{constructor(t,{location:e=j.location,threshold:s=j.threshold,distance:i=j.distance,includeMatches:n=j.includeMatches,findAllMatches:r=j.findAllMatches,minMatchCharLength:c=j.minMatchCharLength,isCaseSensitive:o=j.isCaseSensitive,ignoreLocation:a=j.ignoreLocation}={}){super(t);this._bitapSearch=new K(t,{location:e,threshold:s,distance:i,includeMatches:n,findAllMatches:r,minMatchCharLength:c,isCaseSensitive:o,ignoreLocation:a})}static get type(){return"fuzzy"}static get multiRegex(){return/^"(.*)"$/}static get singleRegex(){return/^(.*)$/}search(t){return this._bitapSearch.searchIn(t)}}class tt extends D{constructor(t){super(t)}static get type(){return"include"}static get multiRegex(){return/^'"(.*)"$/}static get singleRegex(){return/^'(.*)$/}search(t){let e=0;let s;const i=[];const n=this.pattern.length;while((s=t.indexOf(this.pattern,e))>-1){e=s+n;i.push([s,e-1])}const r=!!i.length;return{isMatch:r,score:r?0:1,indices:i}}}const et=[V,tt,G,Q,Y,X,q,Z];const st=et.length;const it=/ +(?=([^\"]*\"[^\"]*\")*[^\"]*$)/;const nt="|";function rt(t,e={}){return t.split(nt).map((t=>{let s=t.trim().split(it).filter((t=>t&&!!t.trim()));let i=[];for(let n=0,r=s.length;n<r;n+=1){const t=s[n];let r=false;let c=-1;while(!r&&++c<st){const s=et[c];let n=s.isMultiMatch(t);if(n){i.push(new s(n,e));r=true}}if(r){continue}c=-1;while(++c<st){const s=et[c];let n=s.isSingleMatch(t);if(n){i.push(new s(n,e));break}}}return i}))}const ct=new Set([Z.type,tt.type]);class ot{constructor(t,{isCaseSensitive:e=j.isCaseSensitive,includeMatches:s=j.includeMatches,minMatchCharLength:i=j.minMatchCharLength,ignoreLocation:n=j.ignoreLocation,findAllMatches:r=j.findAllMatches,location:c=j.location,threshold:o=j.threshold,distance:a=j.distance}={}){this.query=null;this.options={isCaseSensitive:e,includeMatches:s,minMatchCharLength:i,findAllMatches:r,ignoreLocation:n,location:c,threshold:o,distance:a};this.pattern=e?t:t.toLowerCase();this.query=rt(this.pattern,this.options)}static condition(t,e){return e.useExtendedSearch}searchIn(t){const e=this.query;if(!e){return{isMatch:false,score:1}}const{includeMatches:s,isCaseSensitive:i}=this.options;t=i?t:t.toLowerCase();let n=0;let r=[];let c=0;for(let o=0,a=e.length;o<a;o+=1){const i=e[o];r.length=0;n=0;for(let e=0,o=i.length;e<o;e+=1){const o=i[e];const{isMatch:a,indices:l,score:h}=o.search(t);if(a){n+=1;c+=h;if(s){const t=o.constructor.type;if(ct.has(t)){r=[...r,...l]}else{r.push(l)}}}else{c=0;n=0;r.length=0;break}}if(n){let t={isMatch:true,score:c/n};if(s){t.indices=r}return t}}return{isMatch:false,score:1}}}const at=[];function lt(...t){at.push(...t)}function ht(t,e){for(let s=0,i=at.length;s<i;s+=1){let i=at[s];if(i.condition(t,e)){return new i(t,e)}}return new K(t,e)}const ut={AND:"$and",OR:"$or"};const ft={PATH:"$path",PATTERN:"$val"};const dt=t=>!!(t[ut.AND]||t[ut.OR]);const gt=t=>!!t[ft.PATH];const mt=t=>!r(t)&&f(t)&&!dt(t);const Mt=t=>({[ut.AND]:Object.keys(t).map((e=>({[e]:t[e]})))});function xt(t,e,{auto:s=true}={}){const i=t=>{let n=Object.keys(t);const c=gt(t);if(!c&&n.length>1&&!dt(t)){return i(Mt(t))}if(mt(t)){const i=c?t[ft.PATH]:n[0];const r=c?t[ft.PATTERN]:t[i];if(!l(r)){throw new Error(v(i))}const o={keyId:A(i),pattern:r};if(s){o.searcher=ht(r,e)}return o}let o={children:[],operator:n[0]};n.forEach((e=>{const s=t[e];if(r(s)){s.forEach((t=>{o.children.push(i(t))}))}}));return o};if(!dt(t)){t=Mt(t)}return i(t)}function pt(t,{ignoreFieldNorm:e=j.ignoreFieldNorm}){t.forEach((t=>{let s=1;t.matches.forEach((({key:t,norm:i,score:n})=>{const r=t?t.weight:null;s*=Math.pow(n===0&&r?Number.EPSILON:n,(r||1)*(e?1:i))}));t.score=s}))}function vt(t,e){const s=t.matches;e.matches=[];if(!g(s)){return}s.forEach((t=>{if(!g(t.indices)||!t.indices.length){return}const{indices:s,value:i}=t;let n={indices:s,value:i};if(t.key){n.key=t.key.src}if(t.idx>-1){n.refIndex=t.idx}e.matches.push(n)}))}function yt(t,e){e.score=t.score}function Lt(t,e,{includeMatches:s=j.includeMatches,includeScore:i=j.includeScore}={}){const n=[];if(s)n.push(vt);if(i)n.push(yt);return t.map((t=>{const{idx:s}=t;const i={item:e[s],refIndex:s};if(n.length){n.forEach((e=>{e(t,i)}))}return i}))}class wt{constructor(t,e={},s){this.options={...j,...e};if(this.options.useExtendedSearch&&!true){throw new Error(x)}this._keyStore=new $(this.options.keys);this.setCollection(t,s)}setCollection(t,e){this._docs=t;if(e&&!(e instanceof _)){throw new Error(p)}this._myIndex=e||W(this.options.keys,this._docs,{getFn:this.options.getFn,fieldNormWeight:this.options.fieldNormWeight})}add(t){if(!g(t)){return}this._docs.push(t);this._myIndex.add(t)}remove(t=(()=>false)){const e=[];for(let s=0,i=this._docs.length;s<i;s+=1){const n=this._docs[s];if(t(n,s)){this.removeAt(s);s-=1;i-=1;e.push(n)}}return e}removeAt(t){this._docs.splice(t,1);this._myIndex.removeAt(t)}getIndex(){return this._myIndex}search(t,{limit:e=-1}={}){const{includeMatches:s,includeScore:i,shouldSort:n,sortFn:r,ignoreFieldNorm:c}=this.options;let o=l(t)?l(this._docs[0])?this._searchStringList(t):this._searchObjectList(t):this._searchLogical(t);pt(o,{ignoreFieldNorm:c});if(n){o.sort(r)}if(h(e)&&e>-1){o=o.slice(0,e)}return Lt(o,this._docs,{includeMatches:s,includeScore:i})}_searchStringList(t){const e=ht(t,this.options);const{records:s}=this._myIndex;const i=[];s.forEach((({v:t,i:s,n})=>{if(!g(t)){return}const{isMatch:r,score:c,indices:o}=e.searchIn(t);if(r){i.push({item:t,idx:s,matches:[{score:c,value:t,norm:n,indices:o}]})}}));return i}_searchLogical(t){const e=xt(t,this.options);const s=(t,e,i)=>{if(!t.children){const{keyId:s,searcher:n}=t;const r=this._findMatches({key:this._keyStore.get(s),value:this._myIndex.getValueForItemAtKeyId(e,s),searcher:n});if(r&&r.length){return[{idx:i,item:e,matches:r}]}return[]}const n=[];for(let r=0,c=t.children.length;r<c;r+=1){const c=t.children[r];const o=s(c,e,i);if(o.length){n.push(...o)}else if(t.operator===ut.AND){return[]}}return n};const i=this._myIndex.records;const n={};const r=[];i.forEach((({$:t,i})=>{if(g(t)){let c=s(e,t,i);if(c.length){if(!n[i]){n[i]={idx:i,item:t,matches:[]};r.push(n[i])}c.forEach((({matches:t})=>{n[i].matches.push(...t)}))}}}));return r}_searchObjectList(t){const e=ht(t,this.options);const{keys:s,records:i}=this._myIndex;const n=[];i.forEach((({$:t,i})=>{if(!g(t)){return}let r=[];s.forEach(((s,i)=>{r.push(...this._findMatches({key:s,value:t[i],searcher:e}))}));if(r.length){n.push({idx:i,item:t,matches:r})}}));return n}_findMatches({key:t,value:e,searcher:s}){if(!g(e)){return[]}let i=[];if(r(e)){e.forEach((({v:e,i:n,n:r})=>{if(!g(e)){return}const{isMatch:c,score:o,indices:a}=s.searchIn(e);if(c){i.push({score:o,key:t,value:e,idx:n,norm:r,indices:a})}}))}else{const{v:n,n:r}=e;const{isMatch:c,score:o,indices:a}=s.searchIn(n);if(c){i.push({score:o,key:t,value:n,norm:r,indices:a})}}return i}}wt.version="6.5.3";wt.createIndex=W;wt.parseIndex=z;wt.config=j;{wt.parseQuery=xt}{lt(ot)}const bt=".sc-road-select-filter-h{--margin-top:3rem;position:relative;display:block}.select-filter-list.sc-road-select-filter{position:absolute;top:var(--margin-top);z-index:1;width:100%;max-height:16rem;padding:0.5rem 0;margin:0;overflow-y:scroll;font-family:var(--road-font, sans-serif);font-size:1rem;color:var(--road-on-surface);list-style-type:none;background:var(--road-surface);border-radius:0 0 0.25rem 0.25rem;box-shadow:var(--road-elevation-low)}.select-filter-list.not-active.sc-road-select-filter{opacity:0}.select-filter-item.sc-road-select-filter{display:flex;align-items:center;padding:0.75rem 1rem;cursor:pointer}.select-filter-item.sc-road-select-filter:hover,.select-filter-item.highlight.sc-road-select-filter{color:var(--road-on-primary);background:var(--road-primary)}";const $t=class{constructor(s){t(this,s);this.roadselected=e(this,"roadselected",7);this.roadSelected=e(this,"roadSelected",7);this.onClick=(t,e)=>{this.el.querySelector("road-input").value=e;if(document.getElementsByClassName("phone-number-label-icon").length>0){this.el.querySelector("road-icon").name="flag-"+e}this.isOpen=false;this.roadselected.emit({value:t.toString(),label:e});this.roadSelected.emit({value:t.toString(),label:e})};this.isOpen=false;this.currentValue="";this.options=[];this.parameters={keys:["value","label"],threshold:.3,ignoreLocation:true};this.isActive=false;this.onlySelect=true}handleFocus(){this.isOpen=true;this.isActive=true}handleBlur(){this.isActive=false}handleChange(t){this.currentValue=t.detail.value.toLowerCase()}onClickOutside(t){if(this.isOpen&&!this.el.contains(t.target)){this.isOpen=false;this.isActive=false;const t=this.el.querySelector("road-input").value;if(this.onlySelect&&!this.options.some((e=>e["label"]===t))){this.el.querySelector("road-input").value=""}}}render(){const t=new wt(this.options,this.parameters);const e=this.currentValue===""?this.options.map(((t,e)=>({item:t,score:1,refIndex:e}))):t.search(this.currentValue);const n=this.isActive?"true":"false";const r=this.isActive?"":"not-active";return s(i,{"is-active":n},s("slot",null),this.isOpen&&s("ul",{class:`${r} select-filter-list`,role:"listbox"},e.map((t=>s("li",{class:"select-filter-item",role:"option",onClick:()=>this.onClick(t.item.value,t.item.label.replace(/(<([^>]+)>)/gi,"")),innerHTML:t.item.label})))))}get el(){return n(this)}};$t.style=bt;export{$t as road_select_filter};
2
- //# sourceMappingURL=p-c56fe023.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["isArray","value","Array","getTag","INFINITY","baseToString","result","toString","isString","isNumber","isBoolean","isObjectLike","isObject","isDefined","undefined","isBlank","trim","length","Object","prototype","call","EXTENDED_SEARCH_UNAVAILABLE","INCORRECT_INDEX_TYPE","LOGICAL_SEARCH_INVALID_QUERY_FOR_KEY","key","PATTERN_LENGTH_TOO_LARGE","max","MISSING_KEY_PROPERTY","name","INVALID_KEY_WEIGHT_VALUE","hasOwn","hasOwnProperty","KeyStore","constructor","keys","this","_keys","_keyMap","totalWeight","forEach","obj","createKey","weight","push","id","get","keyId","toJSON","JSON","stringify","path","src","createKeyPath","createKeyId","Error","split","join","list","arr","deepGet","index","i","len","MatchOptions","includeMatches","findAllMatches","minMatchCharLength","BasicOptions","isCaseSensitive","includeScore","shouldSort","sortFn","a","b","score","idx","FuzzyOptions","location","threshold","distance","AdvancedOptions","useExtendedSearch","getFn","ignoreLocation","ignoreFieldNorm","fieldNormWeight","Config","SPACE","norm","mantissa","cache","Map","m","Math","pow","numTokens","match","has","n","parseFloat","round","set","clear","FuseIndex","isCreated","setIndexRecords","setSources","docs","records","setKeys","_keysMap","create","doc","docIndex","_addString","_addObject","add","size","removeAt","splice","getValueForItemAtKeyId","item","record","v","$","keyIndex","subRecords","stack","nestedArrIndex","pop","subRecord","k","createIndex","myIndex","map","parseIndex","data","computeScore$1","pattern","errors","currentLocation","expectedLocation","accuracy","proximity","abs","convertMaskToIndices","matchmask","indices","start","end","MAX_BITS","search","text","patternAlphabet","patternLen","textLen","min","currentThreshold","bestLocation","computeMatches","matchMask","indexOf","lastBitArr","finalScore","binMax","mask","binMin","binMid","floor","finish","bitArr","j","charMatch","charAt","isMatch","createPatternAlphabet","char","BitapSearch","options","toLowerCase","chunks","addChunk","startIndex","alphabet","remainder","substr","searchIn","allIndices","totalScore","hasMatches","BaseMatch","static","getMatch","multiRegex","singleRegex","exp","matches","ExactMatch","super","type","InverseExactMatch","PrefixExactMatch","startsWith","InversePrefixExactMatch","SuffixExactMatch","endsWith","InverseSuffixExactMatch","FuzzyMatch","_bitapSearch","IncludeMatch","searchers","searchersLen","SPACE_RE","OR_TOKEN","parseQuery","query","filter","results","queryItem","found","searcher","token","isMultiMatch","isSingleMatch","MultiMatchSet","Set","ExtendedSearch","_","numMatches","qLen","pLen","registeredSearchers","register","args","createSearcher","searcherClass","condition","LogicalOperator","AND","OR","KeyType","PATH","PATTERN","isExpression","isPath","isLeaf","convertToExplicit","parse","auto","next","isQueryPath","node","children","operator","computeScore","Number","EPSILON","transformMatches","refIndex","transformScore","format","transformers","transformer","Fuse","_keyStore","setCollection","_docs","_myIndex","remove","predicate","getIndex","limit","_searchStringList","_searchObjectList","_searchLogical","sort","slice","expression","evaluate","_findMatches","res","child","resultMap","expResults","version","config","selectFilterCss","SelectFilter","onClick","label","el","querySelector","document","getElementsByClassName","isOpen","roadselected","emit","roadSelected","handleFocus","isActive","handleBlur","handleChange","event","currentValue","detail","onClickOutside","contains","target","onlySelect","some","option","render","fuseSearch","parameters","notActive","h","Host","class","role","replace","innerHTML"],"sources":["./node_modules/fuse.js/dist/fuse.esm.js","./src/components/select-filter/select-filter.css?tag=road-select-filter&encapsulation=scoped","./src/components/select-filter/select-filter.tsx"],"sourcesContent":["/**\n * Fuse.js v6.5.3 - Lightweight fuzzy-search (http://fusejs.io)\n *\n * Copyright (c) 2021 Kiro Risk (http://kiro.me)\n * All Rights Reserved. Apache Software License 2.0\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nfunction isArray(value) {\n return !Array.isArray\n ? getTag(value) === '[object Array]'\n : Array.isArray(value)\n}\n\n// Adapted from: https://github.com/lodash/lodash/blob/master/.internal/baseToString.js\nconst INFINITY = 1 / 0;\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value\n }\n let result = value + '';\n return result == '0' && 1 / value == -INFINITY ? '-0' : result\n}\n\nfunction toString(value) {\n return value == null ? '' : baseToString(value)\n}\n\nfunction isString(value) {\n return typeof value === 'string'\n}\n\nfunction isNumber(value) {\n return typeof value === 'number'\n}\n\n// Adapted from: https://github.com/lodash/lodash/blob/master/isBoolean.js\nfunction isBoolean(value) {\n return (\n value === true ||\n value === false ||\n (isObjectLike(value) && getTag(value) == '[object Boolean]')\n )\n}\n\nfunction isObject(value) {\n return typeof value === 'object'\n}\n\n// Checks if `value` is object-like.\nfunction isObjectLike(value) {\n return isObject(value) && value !== null\n}\n\nfunction isDefined(value) {\n return value !== undefined && value !== null\n}\n\nfunction isBlank(value) {\n return !value.trim().length\n}\n\n// Gets the `toStringTag` of `value`.\n// Adapted from: https://github.com/lodash/lodash/blob/master/.internal/getTag.js\nfunction getTag(value) {\n return value == null\n ? value === undefined\n ? '[object Undefined]'\n : '[object Null]'\n : Object.prototype.toString.call(value)\n}\n\nconst EXTENDED_SEARCH_UNAVAILABLE = 'Extended search is not available';\n\nconst INCORRECT_INDEX_TYPE = \"Incorrect 'index' type\";\n\nconst LOGICAL_SEARCH_INVALID_QUERY_FOR_KEY = (key) =>\n `Invalid value for key ${key}`;\n\nconst PATTERN_LENGTH_TOO_LARGE = (max) =>\n `Pattern length exceeds max of ${max}.`;\n\nconst MISSING_KEY_PROPERTY = (name) => `Missing ${name} property in key`;\n\nconst INVALID_KEY_WEIGHT_VALUE = (key) =>\n `Property 'weight' in key '${key}' must be a positive integer`;\n\nconst hasOwn = Object.prototype.hasOwnProperty;\n\nclass KeyStore {\n constructor(keys) {\n this._keys = [];\n this._keyMap = {};\n\n let totalWeight = 0;\n\n keys.forEach((key) => {\n let obj = createKey(key);\n\n totalWeight += obj.weight;\n\n this._keys.push(obj);\n this._keyMap[obj.id] = obj;\n\n totalWeight += obj.weight;\n });\n\n // Normalize weights so that their sum is equal to 1\n this._keys.forEach((key) => {\n key.weight /= totalWeight;\n });\n }\n get(keyId) {\n return this._keyMap[keyId]\n }\n keys() {\n return this._keys\n }\n toJSON() {\n return JSON.stringify(this._keys)\n }\n}\n\nfunction createKey(key) {\n let path = null;\n let id = null;\n let src = null;\n let weight = 1;\n\n if (isString(key) || isArray(key)) {\n src = key;\n path = createKeyPath(key);\n id = createKeyId(key);\n } else {\n if (!hasOwn.call(key, 'name')) {\n throw new Error(MISSING_KEY_PROPERTY('name'))\n }\n\n const name = key.name;\n src = name;\n\n if (hasOwn.call(key, 'weight')) {\n weight = key.weight;\n\n if (weight <= 0) {\n throw new Error(INVALID_KEY_WEIGHT_VALUE(name))\n }\n }\n\n path = createKeyPath(name);\n id = createKeyId(name);\n }\n\n return { path, id, weight, src }\n}\n\nfunction createKeyPath(key) {\n return isArray(key) ? key : key.split('.')\n}\n\nfunction createKeyId(key) {\n return isArray(key) ? key.join('.') : key\n}\n\nfunction get(obj, path) {\n let list = [];\n let arr = false;\n\n const deepGet = (obj, path, index) => {\n if (!isDefined(obj)) {\n return\n }\n if (!path[index]) {\n // If there's no path left, we've arrived at the object we care about.\n list.push(obj);\n } else {\n let key = path[index];\n\n const value = obj[key];\n\n if (!isDefined(value)) {\n return\n }\n\n // If we're at the last value in the path, and if it's a string/number/bool,\n // add it to the list\n if (\n index === path.length - 1 &&\n (isString(value) || isNumber(value) || isBoolean(value))\n ) {\n list.push(toString(value));\n } else if (isArray(value)) {\n arr = true;\n // Search each item in the array.\n for (let i = 0, len = value.length; i < len; i += 1) {\n deepGet(value[i], path, index + 1);\n }\n } else if (path.length) {\n // An object. Recurse further.\n deepGet(value, path, index + 1);\n }\n }\n };\n\n // Backwards compatibility (since path used to be a string)\n deepGet(obj, isString(path) ? path.split('.') : path, 0);\n\n return arr ? list : list[0]\n}\n\nconst MatchOptions = {\n // Whether the matches should be included in the result set. When `true`, each record in the result\n // set will include the indices of the matched characters.\n // These can consequently be used for highlighting purposes.\n includeMatches: false,\n // When `true`, the matching function will continue to the end of a search pattern even if\n // a perfect match has already been located in the string.\n findAllMatches: false,\n // Minimum number of characters that must be matched before a result is considered a match\n minMatchCharLength: 1\n};\n\nconst BasicOptions = {\n // When `true`, the algorithm continues searching to the end of the input even if a perfect\n // match is found before the end of the same input.\n isCaseSensitive: false,\n // When true, the matching function will continue to the end of a search pattern even if\n includeScore: false,\n // List of properties that will be searched. This also supports nested properties.\n keys: [],\n // Whether to sort the result list, by score\n shouldSort: true,\n // Default sort function: sort by ascending score, ascending index\n sortFn: (a, b) =>\n a.score === b.score ? (a.idx < b.idx ? -1 : 1) : a.score < b.score ? -1 : 1\n};\n\nconst FuzzyOptions = {\n // Approximately where in the text is the pattern expected to be found?\n location: 0,\n // At what point does the match algorithm give up. A threshold of '0.0' requires a perfect match\n // (of both letters and location), a threshold of '1.0' would match anything.\n threshold: 0.6,\n // Determines how close the match must be to the fuzzy location (specified above).\n // An exact letter match which is 'distance' characters away from the fuzzy location\n // would score as a complete mismatch. A distance of '0' requires the match be at\n // the exact location specified, a threshold of '1000' would require a perfect match\n // to be within 800 characters of the fuzzy location to be found using a 0.8 threshold.\n distance: 100\n};\n\nconst AdvancedOptions = {\n // When `true`, it enables the use of unix-like search commands\n useExtendedSearch: false,\n // The get function to use when fetching an object's properties.\n // The default will search nested paths *ie foo.bar.baz*\n getFn: get,\n // When `true`, search will ignore `location` and `distance`, so it won't matter\n // where in the string the pattern appears.\n // More info: https://fusejs.io/concepts/scoring-theory.html#fuzziness-score\n ignoreLocation: false,\n // When `true`, the calculation for the relevance score (used for sorting) will\n // ignore the field-length norm.\n // More info: https://fusejs.io/concepts/scoring-theory.html#field-length-norm\n ignoreFieldNorm: false,\n // The weight to determine how much field length norm effects scoring.\n fieldNormWeight: 1\n};\n\nvar Config = {\n ...BasicOptions,\n ...MatchOptions,\n ...FuzzyOptions,\n ...AdvancedOptions\n};\n\nconst SPACE = /[^ ]+/g;\n\n// Field-length norm: the shorter the field, the higher the weight.\n// Set to 3 decimals to reduce index size.\nfunction norm(weight = 1, mantissa = 3) {\n const cache = new Map();\n const m = Math.pow(10, mantissa);\n\n return {\n get(value) {\n const numTokens = value.match(SPACE).length;\n\n if (cache.has(numTokens)) {\n return cache.get(numTokens)\n }\n\n // Default function is 1/sqrt(x), weight makes that variable\n const norm = 1 / Math.pow(numTokens, 0.5 * weight);\n\n // In place of `toFixed(mantissa)`, for faster computation\n const n = parseFloat(Math.round(norm * m) / m);\n\n cache.set(numTokens, n);\n\n return n\n },\n clear() {\n cache.clear();\n }\n }\n}\n\nclass FuseIndex {\n constructor({\n getFn = Config.getFn,\n fieldNormWeight = Config.fieldNormWeight\n } = {}) {\n this.norm = norm(fieldNormWeight, 3);\n this.getFn = getFn;\n this.isCreated = false;\n\n this.setIndexRecords();\n }\n setSources(docs = []) {\n this.docs = docs;\n }\n setIndexRecords(records = []) {\n this.records = records;\n }\n setKeys(keys = []) {\n this.keys = keys;\n this._keysMap = {};\n keys.forEach((key, idx) => {\n this._keysMap[key.id] = idx;\n });\n }\n create() {\n if (this.isCreated || !this.docs.length) {\n return\n }\n\n this.isCreated = true;\n\n // List is Array<String>\n if (isString(this.docs[0])) {\n this.docs.forEach((doc, docIndex) => {\n this._addString(doc, docIndex);\n });\n } else {\n // List is Array<Object>\n this.docs.forEach((doc, docIndex) => {\n this._addObject(doc, docIndex);\n });\n }\n\n this.norm.clear();\n }\n // Adds a doc to the end of the index\n add(doc) {\n const idx = this.size();\n\n if (isString(doc)) {\n this._addString(doc, idx);\n } else {\n this._addObject(doc, idx);\n }\n }\n // Removes the doc at the specified index of the index\n removeAt(idx) {\n this.records.splice(idx, 1);\n\n // Change ref index of every subsquent doc\n for (let i = idx, len = this.size(); i < len; i += 1) {\n this.records[i].i -= 1;\n }\n }\n getValueForItemAtKeyId(item, keyId) {\n return item[this._keysMap[keyId]]\n }\n size() {\n return this.records.length\n }\n _addString(doc, docIndex) {\n if (!isDefined(doc) || isBlank(doc)) {\n return\n }\n\n let record = {\n v: doc,\n i: docIndex,\n n: this.norm.get(doc)\n };\n\n this.records.push(record);\n }\n _addObject(doc, docIndex) {\n let record = { i: docIndex, $: {} };\n\n // Iterate over every key (i.e, path), and fetch the value at that key\n this.keys.forEach((key, keyIndex) => {\n // console.log(key)\n let value = this.getFn(doc, key.path);\n\n if (!isDefined(value)) {\n return\n }\n\n if (isArray(value)) {\n let subRecords = [];\n const stack = [{ nestedArrIndex: -1, value }];\n\n while (stack.length) {\n const { nestedArrIndex, value } = stack.pop();\n\n if (!isDefined(value)) {\n continue\n }\n\n if (isString(value) && !isBlank(value)) {\n let subRecord = {\n v: value,\n i: nestedArrIndex,\n n: this.norm.get(value)\n };\n\n subRecords.push(subRecord);\n } else if (isArray(value)) {\n value.forEach((item, k) => {\n stack.push({\n nestedArrIndex: k,\n value: item\n });\n });\n } else ;\n }\n record.$[keyIndex] = subRecords;\n } else if (!isBlank(value)) {\n let subRecord = {\n v: value,\n n: this.norm.get(value)\n };\n\n record.$[keyIndex] = subRecord;\n }\n });\n\n this.records.push(record);\n }\n toJSON() {\n return {\n keys: this.keys,\n records: this.records\n }\n }\n}\n\nfunction createIndex(\n keys,\n docs,\n { getFn = Config.getFn, fieldNormWeight = Config.fieldNormWeight } = {}\n) {\n const myIndex = new FuseIndex({ getFn, fieldNormWeight });\n myIndex.setKeys(keys.map(createKey));\n myIndex.setSources(docs);\n myIndex.create();\n return myIndex\n}\n\nfunction parseIndex(\n data,\n { getFn = Config.getFn, fieldNormWeight = Config.fieldNormWeight } = {}\n) {\n const { keys, records } = data;\n const myIndex = new FuseIndex({ getFn, fieldNormWeight });\n myIndex.setKeys(keys);\n myIndex.setIndexRecords(records);\n return myIndex\n}\n\nfunction computeScore$1(\n pattern,\n {\n errors = 0,\n currentLocation = 0,\n expectedLocation = 0,\n distance = Config.distance,\n ignoreLocation = Config.ignoreLocation\n } = {}\n) {\n const accuracy = errors / pattern.length;\n\n if (ignoreLocation) {\n return accuracy\n }\n\n const proximity = Math.abs(expectedLocation - currentLocation);\n\n if (!distance) {\n // Dodge divide by zero error.\n return proximity ? 1.0 : accuracy\n }\n\n return accuracy + proximity / distance\n}\n\nfunction convertMaskToIndices(\n matchmask = [],\n minMatchCharLength = Config.minMatchCharLength\n) {\n let indices = [];\n let start = -1;\n let end = -1;\n let i = 0;\n\n for (let len = matchmask.length; i < len; i += 1) {\n let match = matchmask[i];\n if (match && start === -1) {\n start = i;\n } else if (!match && start !== -1) {\n end = i - 1;\n if (end - start + 1 >= minMatchCharLength) {\n indices.push([start, end]);\n }\n start = -1;\n }\n }\n\n // (i-1 - start) + 1 => i - start\n if (matchmask[i - 1] && i - start >= minMatchCharLength) {\n indices.push([start, i - 1]);\n }\n\n return indices\n}\n\n// Machine word size\nconst MAX_BITS = 32;\n\nfunction search(\n text,\n pattern,\n patternAlphabet,\n {\n location = Config.location,\n distance = Config.distance,\n threshold = Config.threshold,\n findAllMatches = Config.findAllMatches,\n minMatchCharLength = Config.minMatchCharLength,\n includeMatches = Config.includeMatches,\n ignoreLocation = Config.ignoreLocation\n } = {}\n) {\n if (pattern.length > MAX_BITS) {\n throw new Error(PATTERN_LENGTH_TOO_LARGE(MAX_BITS))\n }\n\n const patternLen = pattern.length;\n // Set starting location at beginning text and initialize the alphabet.\n const textLen = text.length;\n // Handle the case when location > text.length\n const expectedLocation = Math.max(0, Math.min(location, textLen));\n // Highest score beyond which we give up.\n let currentThreshold = threshold;\n // Is there a nearby exact match? (speedup)\n let bestLocation = expectedLocation;\n\n // Performance: only computer matches when the minMatchCharLength > 1\n // OR if `includeMatches` is true.\n const computeMatches = minMatchCharLength > 1 || includeMatches;\n // A mask of the matches, used for building the indices\n const matchMask = computeMatches ? Array(textLen) : [];\n\n let index;\n\n // Get all exact matches, here for speed up\n while ((index = text.indexOf(pattern, bestLocation)) > -1) {\n let score = computeScore$1(pattern, {\n currentLocation: index,\n expectedLocation,\n distance,\n ignoreLocation\n });\n\n currentThreshold = Math.min(score, currentThreshold);\n bestLocation = index + patternLen;\n\n if (computeMatches) {\n let i = 0;\n while (i < patternLen) {\n matchMask[index + i] = 1;\n i += 1;\n }\n }\n }\n\n // Reset the best location\n bestLocation = -1;\n\n let lastBitArr = [];\n let finalScore = 1;\n let binMax = patternLen + textLen;\n\n const mask = 1 << (patternLen - 1);\n\n for (let i = 0; i < patternLen; i += 1) {\n // Scan for the best match; each iteration allows for one more error.\n // Run a binary search to determine how far from the match location we can stray\n // at this error level.\n let binMin = 0;\n let binMid = binMax;\n\n while (binMin < binMid) {\n const score = computeScore$1(pattern, {\n errors: i,\n currentLocation: expectedLocation + binMid,\n expectedLocation,\n distance,\n ignoreLocation\n });\n\n if (score <= currentThreshold) {\n binMin = binMid;\n } else {\n binMax = binMid;\n }\n\n binMid = Math.floor((binMax - binMin) / 2 + binMin);\n }\n\n // Use the result from this iteration as the maximum for the next.\n binMax = binMid;\n\n let start = Math.max(1, expectedLocation - binMid + 1);\n let finish = findAllMatches\n ? textLen\n : Math.min(expectedLocation + binMid, textLen) + patternLen;\n\n // Initialize the bit array\n let bitArr = Array(finish + 2);\n\n bitArr[finish + 1] = (1 << i) - 1;\n\n for (let j = finish; j >= start; j -= 1) {\n let currentLocation = j - 1;\n let charMatch = patternAlphabet[text.charAt(currentLocation)];\n\n if (computeMatches) {\n // Speed up: quick bool to int conversion (i.e, `charMatch ? 1 : 0`)\n matchMask[currentLocation] = +!!charMatch;\n }\n\n // First pass: exact match\n bitArr[j] = ((bitArr[j + 1] << 1) | 1) & charMatch;\n\n // Subsequent passes: fuzzy match\n if (i) {\n bitArr[j] |=\n ((lastBitArr[j + 1] | lastBitArr[j]) << 1) | 1 | lastBitArr[j + 1];\n }\n\n if (bitArr[j] & mask) {\n finalScore = computeScore$1(pattern, {\n errors: i,\n currentLocation,\n expectedLocation,\n distance,\n ignoreLocation\n });\n\n // This match will almost certainly be better than any existing match.\n // But check anyway.\n if (finalScore <= currentThreshold) {\n // Indeed it is\n currentThreshold = finalScore;\n bestLocation = currentLocation;\n\n // Already passed `loc`, downhill from here on in.\n if (bestLocation <= expectedLocation) {\n break\n }\n\n // When passing `bestLocation`, don't exceed our current distance from `expectedLocation`.\n start = Math.max(1, 2 * expectedLocation - bestLocation);\n }\n }\n }\n\n // No hope for a (better) match at greater error levels.\n const score = computeScore$1(pattern, {\n errors: i + 1,\n currentLocation: expectedLocation,\n expectedLocation,\n distance,\n ignoreLocation\n });\n\n if (score > currentThreshold) {\n break\n }\n\n lastBitArr = bitArr;\n }\n\n const result = {\n isMatch: bestLocation >= 0,\n // Count exact matches (those with a score of 0) to be \"almost\" exact\n score: Math.max(0.001, finalScore)\n };\n\n if (computeMatches) {\n const indices = convertMaskToIndices(matchMask, minMatchCharLength);\n if (!indices.length) {\n result.isMatch = false;\n } else if (includeMatches) {\n result.indices = indices;\n }\n }\n\n return result\n}\n\nfunction createPatternAlphabet(pattern) {\n let mask = {};\n\n for (let i = 0, len = pattern.length; i < len; i += 1) {\n const char = pattern.charAt(i);\n mask[char] = (mask[char] || 0) | (1 << (len - i - 1));\n }\n\n return mask\n}\n\nclass BitapSearch {\n constructor(\n pattern,\n {\n location = Config.location,\n threshold = Config.threshold,\n distance = Config.distance,\n includeMatches = Config.includeMatches,\n findAllMatches = Config.findAllMatches,\n minMatchCharLength = Config.minMatchCharLength,\n isCaseSensitive = Config.isCaseSensitive,\n ignoreLocation = Config.ignoreLocation\n } = {}\n ) {\n this.options = {\n location,\n threshold,\n distance,\n includeMatches,\n findAllMatches,\n minMatchCharLength,\n isCaseSensitive,\n ignoreLocation\n };\n\n this.pattern = isCaseSensitive ? pattern : pattern.toLowerCase();\n\n this.chunks = [];\n\n if (!this.pattern.length) {\n return\n }\n\n const addChunk = (pattern, startIndex) => {\n this.chunks.push({\n pattern,\n alphabet: createPatternAlphabet(pattern),\n startIndex\n });\n };\n\n const len = this.pattern.length;\n\n if (len > MAX_BITS) {\n let i = 0;\n const remainder = len % MAX_BITS;\n const end = len - remainder;\n\n while (i < end) {\n addChunk(this.pattern.substr(i, MAX_BITS), i);\n i += MAX_BITS;\n }\n\n if (remainder) {\n const startIndex = len - MAX_BITS;\n addChunk(this.pattern.substr(startIndex), startIndex);\n }\n } else {\n addChunk(this.pattern, 0);\n }\n }\n\n searchIn(text) {\n const { isCaseSensitive, includeMatches } = this.options;\n\n if (!isCaseSensitive) {\n text = text.toLowerCase();\n }\n\n // Exact match\n if (this.pattern === text) {\n let result = {\n isMatch: true,\n score: 0\n };\n\n if (includeMatches) {\n result.indices = [[0, text.length - 1]];\n }\n\n return result\n }\n\n // Otherwise, use Bitap algorithm\n const {\n location,\n distance,\n threshold,\n findAllMatches,\n minMatchCharLength,\n ignoreLocation\n } = this.options;\n\n let allIndices = [];\n let totalScore = 0;\n let hasMatches = false;\n\n this.chunks.forEach(({ pattern, alphabet, startIndex }) => {\n const { isMatch, score, indices } = search(text, pattern, alphabet, {\n location: location + startIndex,\n distance,\n threshold,\n findAllMatches,\n minMatchCharLength,\n includeMatches,\n ignoreLocation\n });\n\n if (isMatch) {\n hasMatches = true;\n }\n\n totalScore += score;\n\n if (isMatch && indices) {\n allIndices = [...allIndices, ...indices];\n }\n });\n\n let result = {\n isMatch: hasMatches,\n score: hasMatches ? totalScore / this.chunks.length : 1\n };\n\n if (hasMatches && includeMatches) {\n result.indices = allIndices;\n }\n\n return result\n }\n}\n\nclass BaseMatch {\n constructor(pattern) {\n this.pattern = pattern;\n }\n static isMultiMatch(pattern) {\n return getMatch(pattern, this.multiRegex)\n }\n static isSingleMatch(pattern) {\n return getMatch(pattern, this.singleRegex)\n }\n search(/*text*/) {}\n}\n\nfunction getMatch(pattern, exp) {\n const matches = pattern.match(exp);\n return matches ? matches[1] : null\n}\n\n// Token: 'file\n\nclass ExactMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'exact'\n }\n static get multiRegex() {\n return /^=\"(.*)\"$/\n }\n static get singleRegex() {\n return /^=(.*)$/\n }\n search(text) {\n const isMatch = text === this.pattern;\n\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices: [0, this.pattern.length - 1]\n }\n }\n}\n\n// Token: !fire\n\nclass InverseExactMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'inverse-exact'\n }\n static get multiRegex() {\n return /^!\"(.*)\"$/\n }\n static get singleRegex() {\n return /^!(.*)$/\n }\n search(text) {\n const index = text.indexOf(this.pattern);\n const isMatch = index === -1;\n\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices: [0, text.length - 1]\n }\n }\n}\n\n// Token: ^file\n\nclass PrefixExactMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'prefix-exact'\n }\n static get multiRegex() {\n return /^\\^\"(.*)\"$/\n }\n static get singleRegex() {\n return /^\\^(.*)$/\n }\n search(text) {\n const isMatch = text.startsWith(this.pattern);\n\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices: [0, this.pattern.length - 1]\n }\n }\n}\n\n// Token: !^fire\n\nclass InversePrefixExactMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'inverse-prefix-exact'\n }\n static get multiRegex() {\n return /^!\\^\"(.*)\"$/\n }\n static get singleRegex() {\n return /^!\\^(.*)$/\n }\n search(text) {\n const isMatch = !text.startsWith(this.pattern);\n\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices: [0, text.length - 1]\n }\n }\n}\n\n// Token: .file$\n\nclass SuffixExactMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'suffix-exact'\n }\n static get multiRegex() {\n return /^\"(.*)\"\\$$/\n }\n static get singleRegex() {\n return /^(.*)\\$$/\n }\n search(text) {\n const isMatch = text.endsWith(this.pattern);\n\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices: [text.length - this.pattern.length, text.length - 1]\n }\n }\n}\n\n// Token: !.file$\n\nclass InverseSuffixExactMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'inverse-suffix-exact'\n }\n static get multiRegex() {\n return /^!\"(.*)\"\\$$/\n }\n static get singleRegex() {\n return /^!(.*)\\$$/\n }\n search(text) {\n const isMatch = !text.endsWith(this.pattern);\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices: [0, text.length - 1]\n }\n }\n}\n\nclass FuzzyMatch extends BaseMatch {\n constructor(\n pattern,\n {\n location = Config.location,\n threshold = Config.threshold,\n distance = Config.distance,\n includeMatches = Config.includeMatches,\n findAllMatches = Config.findAllMatches,\n minMatchCharLength = Config.minMatchCharLength,\n isCaseSensitive = Config.isCaseSensitive,\n ignoreLocation = Config.ignoreLocation\n } = {}\n ) {\n super(pattern);\n this._bitapSearch = new BitapSearch(pattern, {\n location,\n threshold,\n distance,\n includeMatches,\n findAllMatches,\n minMatchCharLength,\n isCaseSensitive,\n ignoreLocation\n });\n }\n static get type() {\n return 'fuzzy'\n }\n static get multiRegex() {\n return /^\"(.*)\"$/\n }\n static get singleRegex() {\n return /^(.*)$/\n }\n search(text) {\n return this._bitapSearch.searchIn(text)\n }\n}\n\n// Token: 'file\n\nclass IncludeMatch extends BaseMatch {\n constructor(pattern) {\n super(pattern);\n }\n static get type() {\n return 'include'\n }\n static get multiRegex() {\n return /^'\"(.*)\"$/\n }\n static get singleRegex() {\n return /^'(.*)$/\n }\n search(text) {\n let location = 0;\n let index;\n\n const indices = [];\n const patternLen = this.pattern.length;\n\n // Get all exact matches\n while ((index = text.indexOf(this.pattern, location)) > -1) {\n location = index + patternLen;\n indices.push([index, location - 1]);\n }\n\n const isMatch = !!indices.length;\n\n return {\n isMatch,\n score: isMatch ? 0 : 1,\n indices\n }\n }\n}\n\n// ❗Order is important. DO NOT CHANGE.\nconst searchers = [\n ExactMatch,\n IncludeMatch,\n PrefixExactMatch,\n InversePrefixExactMatch,\n InverseSuffixExactMatch,\n SuffixExactMatch,\n InverseExactMatch,\n FuzzyMatch\n];\n\nconst searchersLen = searchers.length;\n\n// Regex to split by spaces, but keep anything in quotes together\nconst SPACE_RE = / +(?=([^\\\"]*\\\"[^\\\"]*\\\")*[^\\\"]*$)/;\nconst OR_TOKEN = '|';\n\n// Return a 2D array representation of the query, for simpler parsing.\n// Example:\n// \"^core go$ | rb$ | py$ xy$\" => [[\"^core\", \"go$\"], [\"rb$\"], [\"py$\", \"xy$\"]]\nfunction parseQuery(pattern, options = {}) {\n return pattern.split(OR_TOKEN).map((item) => {\n let query = item\n .trim()\n .split(SPACE_RE)\n .filter((item) => item && !!item.trim());\n\n let results = [];\n for (let i = 0, len = query.length; i < len; i += 1) {\n const queryItem = query[i];\n\n // 1. Handle multiple query match (i.e, once that are quoted, like `\"hello world\"`)\n let found = false;\n let idx = -1;\n while (!found && ++idx < searchersLen) {\n const searcher = searchers[idx];\n let token = searcher.isMultiMatch(queryItem);\n if (token) {\n results.push(new searcher(token, options));\n found = true;\n }\n }\n\n if (found) {\n continue\n }\n\n // 2. Handle single query matches (i.e, once that are *not* quoted)\n idx = -1;\n while (++idx < searchersLen) {\n const searcher = searchers[idx];\n let token = searcher.isSingleMatch(queryItem);\n if (token) {\n results.push(new searcher(token, options));\n break\n }\n }\n }\n\n return results\n })\n}\n\n// These extended matchers can return an array of matches, as opposed\n// to a singl match\nconst MultiMatchSet = new Set([FuzzyMatch.type, IncludeMatch.type]);\n\n/**\n * Command-like searching\n * ======================\n *\n * Given multiple search terms delimited by spaces.e.g. `^jscript .python$ ruby !java`,\n * search in a given text.\n *\n * Search syntax:\n *\n * | Token | Match type | Description |\n * | ----------- | -------------------------- | -------------------------------------- |\n * | `jscript` | fuzzy-match | Items that fuzzy match `jscript` |\n * | `=scheme` | exact-match | Items that are `scheme` |\n * | `'python` | include-match | Items that include `python` |\n * | `!ruby` | inverse-exact-match | Items that do not include `ruby` |\n * | `^java` | prefix-exact-match | Items that start with `java` |\n * | `!^earlang` | inverse-prefix-exact-match | Items that do not start with `earlang` |\n * | `.js$` | suffix-exact-match | Items that end with `.js` |\n * | `!.go$` | inverse-suffix-exact-match | Items that do not end with `.go` |\n *\n * A single pipe character acts as an OR operator. For example, the following\n * query matches entries that start with `core` and end with either`go`, `rb`,\n * or`py`.\n *\n * ```\n * ^core go$ | rb$ | py$\n * ```\n */\nclass ExtendedSearch {\n constructor(\n pattern,\n {\n isCaseSensitive = Config.isCaseSensitive,\n includeMatches = Config.includeMatches,\n minMatchCharLength = Config.minMatchCharLength,\n ignoreLocation = Config.ignoreLocation,\n findAllMatches = Config.findAllMatches,\n location = Config.location,\n threshold = Config.threshold,\n distance = Config.distance\n } = {}\n ) {\n this.query = null;\n this.options = {\n isCaseSensitive,\n includeMatches,\n minMatchCharLength,\n findAllMatches,\n ignoreLocation,\n location,\n threshold,\n distance\n };\n\n this.pattern = isCaseSensitive ? pattern : pattern.toLowerCase();\n this.query = parseQuery(this.pattern, this.options);\n }\n\n static condition(_, options) {\n return options.useExtendedSearch\n }\n\n searchIn(text) {\n const query = this.query;\n\n if (!query) {\n return {\n isMatch: false,\n score: 1\n }\n }\n\n const { includeMatches, isCaseSensitive } = this.options;\n\n text = isCaseSensitive ? text : text.toLowerCase();\n\n let numMatches = 0;\n let allIndices = [];\n let totalScore = 0;\n\n // ORs\n for (let i = 0, qLen = query.length; i < qLen; i += 1) {\n const searchers = query[i];\n\n // Reset indices\n allIndices.length = 0;\n numMatches = 0;\n\n // ANDs\n for (let j = 0, pLen = searchers.length; j < pLen; j += 1) {\n const searcher = searchers[j];\n const { isMatch, indices, score } = searcher.search(text);\n\n if (isMatch) {\n numMatches += 1;\n totalScore += score;\n if (includeMatches) {\n const type = searcher.constructor.type;\n if (MultiMatchSet.has(type)) {\n allIndices = [...allIndices, ...indices];\n } else {\n allIndices.push(indices);\n }\n }\n } else {\n totalScore = 0;\n numMatches = 0;\n allIndices.length = 0;\n break\n }\n }\n\n // OR condition, so if TRUE, return\n if (numMatches) {\n let result = {\n isMatch: true,\n score: totalScore / numMatches\n };\n\n if (includeMatches) {\n result.indices = allIndices;\n }\n\n return result\n }\n }\n\n // Nothing was matched\n return {\n isMatch: false,\n score: 1\n }\n }\n}\n\nconst registeredSearchers = [];\n\nfunction register(...args) {\n registeredSearchers.push(...args);\n}\n\nfunction createSearcher(pattern, options) {\n for (let i = 0, len = registeredSearchers.length; i < len; i += 1) {\n let searcherClass = registeredSearchers[i];\n if (searcherClass.condition(pattern, options)) {\n return new searcherClass(pattern, options)\n }\n }\n\n return new BitapSearch(pattern, options)\n}\n\nconst LogicalOperator = {\n AND: '$and',\n OR: '$or'\n};\n\nconst KeyType = {\n PATH: '$path',\n PATTERN: '$val'\n};\n\nconst isExpression = (query) =>\n !!(query[LogicalOperator.AND] || query[LogicalOperator.OR]);\n\nconst isPath = (query) => !!query[KeyType.PATH];\n\nconst isLeaf = (query) =>\n !isArray(query) && isObject(query) && !isExpression(query);\n\nconst convertToExplicit = (query) => ({\n [LogicalOperator.AND]: Object.keys(query).map((key) => ({\n [key]: query[key]\n }))\n});\n\n// When `auto` is `true`, the parse function will infer and initialize and add\n// the appropriate `Searcher` instance\nfunction parse(query, options, { auto = true } = {}) {\n const next = (query) => {\n let keys = Object.keys(query);\n\n const isQueryPath = isPath(query);\n\n if (!isQueryPath && keys.length > 1 && !isExpression(query)) {\n return next(convertToExplicit(query))\n }\n\n if (isLeaf(query)) {\n const key = isQueryPath ? query[KeyType.PATH] : keys[0];\n\n const pattern = isQueryPath ? query[KeyType.PATTERN] : query[key];\n\n if (!isString(pattern)) {\n throw new Error(LOGICAL_SEARCH_INVALID_QUERY_FOR_KEY(key))\n }\n\n const obj = {\n keyId: createKeyId(key),\n pattern\n };\n\n if (auto) {\n obj.searcher = createSearcher(pattern, options);\n }\n\n return obj\n }\n\n let node = {\n children: [],\n operator: keys[0]\n };\n\n keys.forEach((key) => {\n const value = query[key];\n\n if (isArray(value)) {\n value.forEach((item) => {\n node.children.push(next(item));\n });\n }\n });\n\n return node\n };\n\n if (!isExpression(query)) {\n query = convertToExplicit(query);\n }\n\n return next(query)\n}\n\n// Practical scoring function\nfunction computeScore(\n results,\n { ignoreFieldNorm = Config.ignoreFieldNorm }\n) {\n results.forEach((result) => {\n let totalScore = 1;\n\n result.matches.forEach(({ key, norm, score }) => {\n const weight = key ? key.weight : null;\n\n totalScore *= Math.pow(\n score === 0 && weight ? Number.EPSILON : score,\n (weight || 1) * (ignoreFieldNorm ? 1 : norm)\n );\n });\n\n result.score = totalScore;\n });\n}\n\nfunction transformMatches(result, data) {\n const matches = result.matches;\n data.matches = [];\n\n if (!isDefined(matches)) {\n return\n }\n\n matches.forEach((match) => {\n if (!isDefined(match.indices) || !match.indices.length) {\n return\n }\n\n const { indices, value } = match;\n\n let obj = {\n indices,\n value\n };\n\n if (match.key) {\n obj.key = match.key.src;\n }\n\n if (match.idx > -1) {\n obj.refIndex = match.idx;\n }\n\n data.matches.push(obj);\n });\n}\n\nfunction transformScore(result, data) {\n data.score = result.score;\n}\n\nfunction format(\n results,\n docs,\n {\n includeMatches = Config.includeMatches,\n includeScore = Config.includeScore\n } = {}\n) {\n const transformers = [];\n\n if (includeMatches) transformers.push(transformMatches);\n if (includeScore) transformers.push(transformScore);\n\n return results.map((result) => {\n const { idx } = result;\n\n const data = {\n item: docs[idx],\n refIndex: idx\n };\n\n if (transformers.length) {\n transformers.forEach((transformer) => {\n transformer(result, data);\n });\n }\n\n return data\n })\n}\n\nclass Fuse {\n constructor(docs, options = {}, index) {\n this.options = { ...Config, ...options };\n\n if (\n this.options.useExtendedSearch &&\n !true\n ) {\n throw new Error(EXTENDED_SEARCH_UNAVAILABLE)\n }\n\n this._keyStore = new KeyStore(this.options.keys);\n\n this.setCollection(docs, index);\n }\n\n setCollection(docs, index) {\n this._docs = docs;\n\n if (index && !(index instanceof FuseIndex)) {\n throw new Error(INCORRECT_INDEX_TYPE)\n }\n\n this._myIndex =\n index ||\n createIndex(this.options.keys, this._docs, {\n getFn: this.options.getFn,\n fieldNormWeight: this.options.fieldNormWeight\n });\n }\n\n add(doc) {\n if (!isDefined(doc)) {\n return\n }\n\n this._docs.push(doc);\n this._myIndex.add(doc);\n }\n\n remove(predicate = (/* doc, idx */) => false) {\n const results = [];\n\n for (let i = 0, len = this._docs.length; i < len; i += 1) {\n const doc = this._docs[i];\n if (predicate(doc, i)) {\n this.removeAt(i);\n i -= 1;\n len -= 1;\n\n results.push(doc);\n }\n }\n\n return results\n }\n\n removeAt(idx) {\n this._docs.splice(idx, 1);\n this._myIndex.removeAt(idx);\n }\n\n getIndex() {\n return this._myIndex\n }\n\n search(query, { limit = -1 } = {}) {\n const {\n includeMatches,\n includeScore,\n shouldSort,\n sortFn,\n ignoreFieldNorm\n } = this.options;\n\n let results = isString(query)\n ? isString(this._docs[0])\n ? this._searchStringList(query)\n : this._searchObjectList(query)\n : this._searchLogical(query);\n\n computeScore(results, { ignoreFieldNorm });\n\n if (shouldSort) {\n results.sort(sortFn);\n }\n\n if (isNumber(limit) && limit > -1) {\n results = results.slice(0, limit);\n }\n\n return format(results, this._docs, {\n includeMatches,\n includeScore\n })\n }\n\n _searchStringList(query) {\n const searcher = createSearcher(query, this.options);\n const { records } = this._myIndex;\n const results = [];\n\n // Iterate over every string in the index\n records.forEach(({ v: text, i: idx, n: norm }) => {\n if (!isDefined(text)) {\n return\n }\n\n const { isMatch, score, indices } = searcher.searchIn(text);\n\n if (isMatch) {\n results.push({\n item: text,\n idx,\n matches: [{ score, value: text, norm, indices }]\n });\n }\n });\n\n return results\n }\n\n _searchLogical(query) {\n\n const expression = parse(query, this.options);\n\n const evaluate = (node, item, idx) => {\n if (!node.children) {\n const { keyId, searcher } = node;\n\n const matches = this._findMatches({\n key: this._keyStore.get(keyId),\n value: this._myIndex.getValueForItemAtKeyId(item, keyId),\n searcher\n });\n\n if (matches && matches.length) {\n return [\n {\n idx,\n item,\n matches\n }\n ]\n }\n\n return []\n }\n\n const res = [];\n for (let i = 0, len = node.children.length; i < len; i += 1) {\n const child = node.children[i];\n const result = evaluate(child, item, idx);\n if (result.length) {\n res.push(...result);\n } else if (node.operator === LogicalOperator.AND) {\n return []\n }\n }\n return res\n };\n\n const records = this._myIndex.records;\n const resultMap = {};\n const results = [];\n\n records.forEach(({ $: item, i: idx }) => {\n if (isDefined(item)) {\n let expResults = evaluate(expression, item, idx);\n\n if (expResults.length) {\n // Dedupe when adding\n if (!resultMap[idx]) {\n resultMap[idx] = { idx, item, matches: [] };\n results.push(resultMap[idx]);\n }\n expResults.forEach(({ matches }) => {\n resultMap[idx].matches.push(...matches);\n });\n }\n }\n });\n\n return results\n }\n\n _searchObjectList(query) {\n const searcher = createSearcher(query, this.options);\n const { keys, records } = this._myIndex;\n const results = [];\n\n // List is Array<Object>\n records.forEach(({ $: item, i: idx }) => {\n if (!isDefined(item)) {\n return\n }\n\n let matches = [];\n\n // Iterate over every key (i.e, path), and fetch the value at that key\n keys.forEach((key, keyIndex) => {\n matches.push(\n ...this._findMatches({\n key,\n value: item[keyIndex],\n searcher\n })\n );\n });\n\n if (matches.length) {\n results.push({\n idx,\n item,\n matches\n });\n }\n });\n\n return results\n }\n _findMatches({ key, value, searcher }) {\n if (!isDefined(value)) {\n return []\n }\n\n let matches = [];\n\n if (isArray(value)) {\n value.forEach(({ v: text, i: idx, n: norm }) => {\n if (!isDefined(text)) {\n return\n }\n\n const { isMatch, score, indices } = searcher.searchIn(text);\n\n if (isMatch) {\n matches.push({\n score,\n key,\n value: text,\n idx,\n norm,\n indices\n });\n }\n });\n } else {\n const { v: text, n: norm } = value;\n\n const { isMatch, score, indices } = searcher.searchIn(text);\n\n if (isMatch) {\n matches.push({ score, key, value: text, norm, indices });\n }\n }\n\n return matches\n }\n}\n\nFuse.version = '6.5.3';\nFuse.createIndex = createIndex;\nFuse.parseIndex = parseIndex;\nFuse.config = Config;\n\n{\n Fuse.parseQuery = parse;\n}\n\n{\n register(ExtendedSearch);\n}\n\nexport { Fuse as default };\n","/*\n * Autocomplete\n *\n * Autocomplete layer for fields\n *\n * Index\n * - List\n * - Item\n */\n\n/**\n * @prop --margin-top: margin top of the select-filter (should equal the height of the field)\n */\n\n:host {\n --margin-top: 3rem;\n\n position: relative;\n display: block;\n}\n\n/* LIST\n -------------------- */\n\n.select-filter-list {\n position: absolute;\n top: var(--margin-top);\n z-index: 1;\n width: 100%;\n max-height: 16rem;\n padding: 0.5rem 0;\n margin: 0;\n overflow-y: scroll;\n font-family: var(--road-font, sans-serif);\n font-size: 1rem;\n color: var(--road-on-surface);\n list-style-type: none;\n background: var(--road-surface);\n border-radius: 0 0 0.25rem 0.25rem;\n box-shadow: var(--road-elevation-low);\n}\n\n.select-filter-list.not-active {\n opacity: 0;\n}\n\n/* ITEM\n -------------------- */\n\n.select-filter-item {\n display: flex;\n align-items: center;\n padding: 0.75rem 1rem;\n cursor: pointer;\n}\n\n/**\n * Hover state\n */\n\n.select-filter-item:hover,\n.select-filter-item.highlight {\n color: var(--road-on-primary);\n background: var(--road-primary);\n}\n","import { Component, Element, Host, Listen, Prop, State, h, Event, EventEmitter } from '@stencil/core';\nimport Fuse from 'fuse.js';\n\n/**\n * @slot - Input element for the widget, it should be a road-input element.\n */\n\n@Component({\n tag: 'road-select-filter',\n styleUrl: 'select-filter.css',\n scoped: true,\n})\nexport class SelectFilter {\n\n @Element() el!: HTMLRoadSelectFilterElement;\n\n @State() isOpen: boolean = false;\n\n @State() currentValue: string = '';\n\n /**\n * List of options of the select\n */\n @Prop() options: Array<{\n value: string | number;\n label: string;\n }> = [];\n\n /**\n * Options to pass to the fuse.js instance.\n * See https://fusejs.io/api/options.html for valid options\n */\n @Prop() parameters: any = {\n keys: [\"value\", \"label\"],\n threshold: 0.3,\n ignoreLocation: true,\n };\n\n /**\n * If `true`, add class Active\n */\n @Prop() isActive: boolean = false;\n\n /**\n * If `false`, the user can submit custom value\n */\n @Prop() onlySelect: boolean = true;\n\n @Listen('roadFocus')\n @Listen('roadfocus')\n handleFocus() {\n this.isOpen = true;\n this.isActive = true;\n }\n\n @Listen('roadBlur')\n @Listen('roadblur')\n handleBlur() {\n this.isActive = false;\n }\n\n @Listen('roadChange')\n @Listen('roadchange')\n handleChange(event: CustomEvent) {\n this.currentValue = event.detail.value.toLowerCase();\n }\n\n @Listen('click', { target: 'document' })\n onClickOutside(event: MouseEvent) {\n if (this.isOpen && !this.el.contains(event.target as Node)) {\n this.isOpen = false;\n this.isActive = false;\n const value = (this.el.querySelector('road-input') as HTMLRoadInputElement).value;\n if (this.onlySelect && !this.options.some(option => option['label'] === value)) {\n (this.el.querySelector('road-input') as HTMLRoadInputElement).value = '';\n }\n }\n }\n\n /**\n * Emitted the value and label of the option selected.\n */\n @Event() roadselected!: EventEmitter<{\n value: string | undefined | null,\n label: string\n }>;\n /** @internal */\n @Event() roadSelected!: EventEmitter<{\n value: string | undefined | null,\n label: string\n }>;\n\n private onClick = (value: string | number, label: string) => {\n (this.el.querySelector('road-input') as HTMLRoadInputElement).value = label;\n if (document.getElementsByClassName('phone-number-label-icon').length > 0) {\n (this.el.querySelector('road-icon') as HTMLRoadIconElement).name = 'flag-'+ label;\n }\n this.isOpen = false;\n this.roadselected.emit({\n value: value.toString(),\n label: label,\n });\n this.roadSelected.emit({\n value: value.toString(),\n label: label,\n });\n };\n\n render() {\n const fuseSearch = new Fuse(this.options, this.parameters);\n const options = this.currentValue === '' ? this.options.map((doc, idx) => ({ item: doc, score: 1, refIndex: idx })) : fuseSearch.search(this.currentValue);\n const isActive = this.isActive ? 'true' : 'false';\n const notActive = this.isActive ? '' : 'not-active';\n\n return (\n <Host is-active={isActive}>\n <slot/>\n {this.isOpen &&\n <ul class={`${notActive} select-filter-list`} role=\"listbox\">\n {options.map(option => (\n <li\n class=\"select-filter-item\"\n role=\"option\"\n onClick={() => this.onClick(option.item.value, option.item.label.replace(/(<([^>]+)>)/gi, \"\"))}\n innerHTML={option.item.label}\n >\n </li>\n ))}\n </ul>}\n </Host>\n );\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["globalNavigationCss","GlobalNavigation","selectedTabChanged","this","selectedTab","undefined","roadnavbarchanged","emit","tab","roadNavbarChanged","onNavbarChanged","ev","detail","componentWillLoad","render","h","Host","role"],"sources":["./src/components/global-navigation/global-navigation.css?tag=road-global-navigation&encapsulation=shadow","./src/components/global-navigation/global-navigation.tsx"],"sourcesContent":["/*\n * Global Navigation\n *\n */\n\n:host {\n position: fixed;\n top: 0;\n z-index: 2;\n width: 100%;\n}\n\n","import { Component, Host, h, Prop, Watch, Event, EventEmitter, Listen } from '@stencil/core';\nimport './../../utils/polyfill';\n\n/**\n * @slot navbar - it should be road-navbar-item elements. Max 5 items on Mobile or add them to the drawer\n */\n\n@Component({\n tag: 'road-global-navigation',\n styleUrl: 'global-navigation.css',\n shadow: true,\n})\nexport class GlobalNavigation {\n\n /**\n * The selected tab component\n */\n @Prop() selectedTab?: string;\n @Watch('selectedTab')\n selectedTabChanged() {\n if (this.selectedTab !== undefined) {\n this.roadnavbarchanged.emit({\n tab: this.selectedTab,\n });\n this.roadNavbarChanged.emit({\n tab: this.selectedTab,\n });\n }\n }\n\n /** @internal */\n @Event() roadnavbarchanged!: EventEmitter;\n /** @internal */\n @Event() roadNavbarChanged!: EventEmitter;\n\n @Listen('roadNavbarItemClick')\n @Listen('roadnavbaritemclick')\n onNavbarChanged(ev: CustomEvent) {\n this.selectedTab = ev.detail.tab;\n }\n\n componentWillLoad() {\n this.selectedTabChanged();\n }\n\n render() {\n return (\n <Host\n role=\"tablist\"\n >\n <slot/>\n </Host>\n );\n }\n\n}\n"],"mappings":"iFAAA,MAAMA,EAAsB,mD,MCYfC,EAAgB,M,8JAO3BC,qBACE,GAAIC,KAAKC,cAAgBC,UAAW,CAClCF,KAAKG,kBAAkBC,KAAK,CAC1BC,IAAKL,KAAKC,cAEZD,KAAKM,kBAAkBF,KAAK,CAC1BC,IAAKL,KAAKC,a,EAYhBM,gBAAgBC,GACdR,KAAKC,YAAcO,EAAGC,OAAOJ,G,CAG/BK,oBACEV,KAAKD,oB,CAGPY,SACE,OACEC,EAACC,EAAI,CACHC,KAAK,WAELF,EAAA,a"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["collapseCss","Collapse","this","onClick","isOpen","render","isOpenClass","buttonText","showLess","showMore","centerClass","centered","h","Host","class","name"],"sources":["./src/components/collapse/collapse.css?tag=road-collapse&encapsulation=shadow","./src/components/collapse/collapse.tsx"],"sourcesContent":["/*\n * Collapse\n *\n * Index\n * - Collapse\n * - Content\n * - Button\n */\n\n/**\n * @prop --btn-padding-start: Left padding of the button\n * @prop --btn-padding-end: Right padding of the button\n * @prop --btn-margin-bottom: Bottom margin of the button\n * @prop --btn-font-size: Font size of the text button\n * @prop --max-height: maximum height of the collapse content\n */\n\n/* COLLAPSE\n -------------------- */\n\n:host {\n --btn-margin-bottom: 1rem;\n --btn-padding-start: 1rem;\n --btn-padding-end: 1rem;\n --btn-font-size: 1rem;\n --max-height: 500px;\n\n display: block;\n}\n\n/* CONTENT\n -------------------- */\n\n.collapsed-content {\n max-height: 0;\n overflow: hidden;\n transition: max-height 0.4s ease-in-out;\n}\n\n/**\n * Open state\n */\n\n.collapse-open {\n max-height: var(--max-height);\n}\n\n/* BUTTON\n -------------------- */\n\n.collapse-btn {\n --margin-bottom: var(--btn-margin-bottom);\n --border-radius: var(--btn-border-radius);\n --padding-start: var(--btn-padding-start);\n --padding-end: var(--btn-padding-end);\n --font-size: var(--btn-font-size);\n}\n\n.collapse-btn-centered {\n display: flex;\n justify-content: center;\n}\n","import { Component, Host, h, Prop } from '@stencil/core';\n\n/**\n * @slot - Content visible when collapsed.\n * @slot collapsed-content - content not visible when collapsed.\n */\n\n@Component({\n tag: 'road-collapse',\n styleUrl: 'collapse.css',\n shadow: true,\n})\nexport class Collapse {\n\n /**\n * Set to `true` to display the collapsed part and to `false` to hide it.\n */\n @Prop({ mutable: true }) isOpen : boolean = false;\n\n /**\n * Text displayed in the button when the content is collapsed\n */\n @Prop() showMore : string = 'show more';\n\n /**\n * Text displayed in the button when the content is not collapsed\n */\n @Prop() showLess : string = 'show less';\n\n /**\n * if `true` the button will be centered\n */\n @Prop() centered: boolean = false;\n\n /**\n * Toggle the display when clicking header\n */\n private onClick = () => {\n this.isOpen = !this.isOpen;\n };\n\n render() {\n const isOpenClass = this.isOpen ? 'collapse-open' : '';\n const buttonText = this.isOpen ? this.showLess : this .showMore;\n const centerClass = this.centered ? 'collapse-btn-centered' : '';\n\n return (\n <Host>\n <slot/>\n <div class={`collapsed-content ${isOpenClass}`}>\n <slot name=\"collapsed-content\"/>\n </div>\n <div class={`collapse-btn-wrapper ${centerClass}`}>\n <road-button onClick={this.onClick} class=\"collapse-btn btn-link\">{buttonText}</road-button>\n </div>\n </Host>\n );\n }\n\n}\n"],"mappings":"kDAAA,MAAMA,EAAc,qhB,MCYPC,EAAQ,M,yBAyBXC,KAAAC,QAAU,KAChBD,KAAKE,QAAUF,KAAKE,MAAM,E,YArBgB,M,cAKhB,Y,cAKA,Y,cAKA,K,CAS5BC,SACE,MAAMC,EAAcJ,KAAKE,OAAS,gBAAkB,GACpD,MAAMG,EAAaL,KAAKE,OAASF,KAAKM,SAAWN,KAAMO,SACvD,MAAMC,EAAcR,KAAKS,SAAW,wBAA0B,GAE9D,OACEC,EAACC,EAAI,KACHD,EAAA,aACAA,EAAA,OAAKE,MAAO,qBAAqBR,KAC/BM,EAAA,QAAMG,KAAK,uBAEbH,EAAA,OAAKE,MAAO,wBAAwBJ,KAClCE,EAAA,eAAaT,QAASD,KAAKC,QAASW,MAAM,yBAAyBP,I"}
@@ -1,2 +0,0 @@
1
- import{r as a,h as r}from"./p-abdbf6ac.js";const o=".sc-road-table-h{box-sizing:border-box;display:block}.sc-road-table-s>table{width:100%;font-family:var(--road-font, sans-serif);font-size:var(--road-body-small);line-height:1.5;color:var(--road-on-surface);border-collapse:collapse;border-top:1px solid var(--road-outline);border-bottom:1px solid var(--road-outline)}.sc-road-table-s>table th,.sc-road-table-s>table td{padding:1.5rem 1.25rem;text-align:left}.sc-road-table-s>table thead tr,.sc-road-table-s>table tbody tr:nth-child(2n){background:var(--road-surface-inverse)}";const t=class{constructor(r){a(this,r)}render(){return r("slot",null)}};t.style=o;export{t as road_table};
2
- //# sourceMappingURL=p-cd2e8f0a.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["tableCss","Table","render","h"],"sources":["./src/components/table/table.css?tag=road-table&encapsulation=scoped","./src/components/table/table.tsx"],"sourcesContent":["/*\n * Table\n *\n */\n\n:host {\n box-sizing: border-box;\n display: block;\n}\n\n::slotted(table) {\n width: 100%;\n font-family: var(--road-font, sans-serif);\n font-size: var(--road-body-small);\n line-height: 1.5;\n color: var(--road-on-surface);\n border-collapse: collapse;\n border-top: 1px solid var(--road-outline);\n border-bottom: 1px solid var(--road-outline);\n}\n\n::slotted(table th),\n::slotted(table td) {\n padding: 1.5rem 1.25rem;\n text-align: left;\n}\n\n::slotted(table thead tr),\n::slotted(table tbody tr:nth-child(2n)) {\n background: var(--road-surface-inverse);\n}\n","import { Component, h } from '@stencil/core';\n\n/**\n * @slot - Content of table, it should be an html table (https://developer.mozilla.org/fr/docs/Web/HTML/Element/table).\n */\n@Component({\n tag: 'road-table',\n styleUrl: 'table.css',\n scoped: true,\n})\nexport class Table {\n\n render() {\n return (\n <slot/>\n );\n }\n\n}\n"],"mappings":"2CAAA,MAAMA,EAAW,+gB,MCUJC,EAAK,M,yBAEhBC,SACE,OACEC,EAAA,Y"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["carouselItemCss","CarouselItem","render","h","Host","class"],"sources":["./src/components/carousel-item/carousel-item.css?tag=road-carousel-item","./src/components/carousel-item/carousel-item.tsx"],"sourcesContent":["/*\n * Carousel Item\n *\n * Index\n * - Slide\n * - Image\n */\n\nroad-carousel-item {\n display: block;\n\n width: 100%;\n height: 100%;\n}\n\n/* SLIDE\n -------------------- */\n\n.slide-zoom {\n display: block;\n width: 100%;\n text-align: center;\n}\n\n.swiper-slide {\n position: relative;\n box-sizing: border-box;\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: 100%;\n font-size: 18px;\n text-align: center;\n}\n\n/* IMAGE\n -------------------- */\n\n.swiper-slide road-img {\n pointer-events: none;\n}\n\n.swiper-slide img {\n width: auto;\n max-width: 100%;\n height: auto;\n max-height: 100%;\n pointer-events: none;\n}\n","import { Component, Host, h } from '@stencil/core';\n\n/**\n * @slot - Content of the carousel item, it should be road-img or road-card.\n */\n\n@Component({\n tag: 'road-carousel-item',\n styleUrl: 'carousel-item.css',\n})\nexport class CarouselItem {\n\n render() {\n return (\n <Host\n class={{\n 'swiper-slide': true,\n 'swiper-zoom-container': true,\n }}\n >\n <slot/>\n </Host>\n );\n }\n}\n"],"mappings":"kDAAA,MAAMA,EAAkB,4a,MCUXC,EAAY,M,yBAEvBC,SACE,OACEC,EAACC,EAAI,CACHC,MAAO,CACL,eAAgB,KAChB,wBAAyB,OAG3BF,EAAA,a"}
@@ -1,2 +0,0 @@
1
- if(window.applyFocusVisiblePolyfill==null){__sc_import_roadtrip("./p-c259efd7.js").then((function(i){return i.f}))}
2
- //# sourceMappingURL=p-e8c090a5.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["window","applyFocusVisiblePolyfill","__sc_import_roadtrip","then","n","f"],"sources":["./src/utils/polyfill.ts"],"sourcesContent":["// @ts-ignore\nif (window.applyFocusVisiblePolyfill == null) {\n // @ts-ignore\n import('focus-visible');\n}"],"mappings":"AACA,GAAIA,OAAOC,2BAA6B,KAAM,CAE5CC,qBAAO,mBAAeC,MAAA,SAAAC,GAAA,OAAAA,EAAAC,CAAA,G"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["tabBarCss","TabBar","selectedTabChanged","this","selectedTab","undefined","roadtabbarchanged","emit","tab","roadTabBarChanged","componentWillLoad","render","expand","center","secondary","h","Host","role","class"],"sources":["./src/components/tab-bar/tab-bar.css?tag=road-tab-bar&encapsulation=shadow","./src/components/tab-bar/tab-bar.tsx"],"sourcesContent":["/*\n * Tab bar\n *\n */\n\n/**\n * @prop --tab-background: background color of the tab bar\n */\n\n\n:host {\n --tab-bar-background: var(--road-surface);\n --tab-color: var(--road-on-surface-weak);\n --tab-color-selected: var(--road-on-surface);\n --tab-underline-selected: var(--road-primary);\n --tab-background: var(--road-surface);\n --tab-background-hover: var(--road-surface-inverse);\n --tab-background-focused: var(--road-grey-70);\n\n display: flex;\n width: 100%;\n margin: 0;\n overflow: scroll;\n overflow-x: inherit;\n font-family: var(--road-font, sans-serif);\n line-height: 1.5;\n color: var(--road-on-surface-weak);\n list-style: none;\n background: var(--tab-bar-background);\n border-bottom: 1px solid var(--road-grey-70);\n fill: currentColor;\n scrollbar-width: none;\n}\n\n:host(::-webkit-scrollbar) {\n display: none;\n}\n\n:host(.tab-expand) ::slotted(road-tab-button) {\n flex-grow: 1;\n}\n\n:host(.tab-secondary) ::slotted(road-tab-button) {\n --tab-underline-selected: var(--road-secondary);\n}\n\n:host(.tab-center) {\n justify-content: center;\n}\n","import { Component, Element, Event, EventEmitter, Host, Prop, Watch, h } from '@stencil/core';\nimport './../../utils/polyfill';\n\n/**\n * @slot - Content of the tabBar, it should be road-tab-button elements.\n */\n\n@Component({\n tag: 'road-tab-bar',\n styleUrl: 'tab-bar.css',\n shadow: true,\n})\nexport class TabBar {\n\n @Element() el!: HTMLRoadTabBarElement;\n\n /**\n * The color to use the color Secondary from your application's color palette.\n */\n @Prop() secondary: boolean = false;\n\n /**\n * Set to `true` to expand buttons width to take the full size of the bar.\n */\n @Prop() expand: boolean = false;\n\n /**\n * Set to `true` to center buttons in the bar.\n */\n @Prop() center: boolean = false;\n\n /**\n * The selected tab component\n */\n @Prop() selectedTab?: string;\n @Watch('selectedTab')\n selectedTabChanged() {\n if (this.selectedTab !== undefined) {\n this.roadtabbarchanged.emit({\n tab: this.selectedTab,\n });\n this.roadTabBarChanged.emit({\n tab: this.selectedTab,\n });\n }\n }\n\n /** @internal */\n @Event() roadtabbarchanged!: EventEmitter;\n /** @internal */\n @Event() roadTabBarChanged!: EventEmitter;\n\n componentWillLoad() {\n this.selectedTabChanged();\n }\n\n render() {\n const { expand, center, secondary } = this;\n return (\n <Host\n role=\"tablist\"\n class={{\n 'tab-expand': expand,\n 'tab-center': center,\n 'tab-secondary': secondary,\n }}\n >\n <slot/>\n </Host>\n );\n }\n}"],"mappings":"wFAAA,MAAMA,EAAY,20B,MCYLC,EAAM,M,kJAOa,M,YAKJ,M,YAKA,M,2BAO1BC,qBACE,GAAIC,KAAKC,cAAgBC,UAAW,CAClCF,KAAKG,kBAAkBC,KAAK,CAC1BC,IAAKL,KAAKC,cAEZD,KAAKM,kBAAkBF,KAAK,CAC1BC,IAAKL,KAAKC,a,EAUhBM,oBACEP,KAAKD,oB,CAGPS,SACE,MAAMC,OAAEA,EAAMC,OAAEA,EAAMC,UAAEA,GAAcX,KACtC,OACEY,EAACC,EAAI,CACHC,KAAK,UACLC,MAAO,CACL,aAAcN,EACd,aAAcC,EACd,gBAAiBC,IAGnBC,EAAA,a"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["switchCss","Switch","this","onClick","checked","onFocus","roadfocus","emit","roadFocus","onBlur","roadBlur","roadblur","switchIds","switchId","checkedChanged","isChecked","roadchange","value","roadChange","render","labelId","textLabel","h","class","id","htmlFor","label","colorClass","color","undefined","isSpacedClass","isSpaced","rightSwitchClass","hasLeftLabel","Host","type","name","disabled","off","on"],"sources":["./src/components/switch/switch.css?tag=road-switch&encapsulation=scoped","./src/components/switch/switch.tsx"],"sourcesContent":["/*\n * Switch\n *\n * For accessibility, we provide a style for focus only on Tab,\n * for that add the javascript polyfill for focus-visible\n * (https://github.com/WICG/focus-visible).\n *\n * Index\n * - Switch\n * - Label\n * - Lever\n * - Feedback\n * - Position\n */\n\n/**\n * @prop --switch-lever-width: width of the lever\n */\n\n/* SWITCH\n -------------------- */\n\n:host {\n --switch-lever-width: 4.5rem;\n\n position: relative;\n display: block;\n margin-bottom: 1rem;\n font-family: var(--road-font, sans-serif);\n font-size: 1rem;\n color: var(--road-grey-900);\n}\n\n/**\n * Hide input\n */\n\n.form-switch-input {\n position: absolute;\n z-index: -1;\n opacity: 0;\n}\n\n/* LABEL\n -------------------- */\n\n.form-switch-label {\n display: inline-flex;\n align-items: center;\n cursor: pointer;\n -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n\n/* LEVER\n -------------------- */\n\n.form-switch-lever {\n position: relative;\n box-sizing: border-box;\n display: flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: flex-end;\n width: var(--switch-lever-width);\n height: 2rem;\n padding: 0.5rem 0.625rem;\n margin-right: 0.75rem;\n font-size: 0.625rem;\n font-weight: 700;\n line-height: 1.6;\n content: \"\";\n background: var(--road-grey-400);\n border: 0.125rem solid transparent;\n border-radius: 1.125rem;\n transition: background 0.2s ease-in-out;\n}\n\n/**\n * Text in the switch widget\n */\n\n.form-switch-lever::before {\n font-size: 0.625rem;\n font-weight: 700;\n color: var(--road-grey-000);\n text-transform: uppercase;\n content: attr(data-off);\n}\n\n/**\n * Round lever in the widget\n */\n\n.form-switch-lever::after {\n position: absolute;\n top: 0.0625rem;\n left: 0.0625rem;\n display: block;\n width: 1.625rem;\n height: 1.625rem;\n content: \"\";\n background: var(--road-grey-000);\n border-radius: 50%;\n box-shadow: 0 0.125rem 0.125rem rgba(0, 0, 0, 0.1);\n transition: transform 0.2s ease-in-out;\n}\n\n/**\n * Checked state\n */\n\n.form-switch-input:checked ~ .form-switch-label .form-switch-lever {\n justify-content: flex-start;\n}\n\n.form-switch-input:checked ~ .form-switch-label .form-switch-lever::before {\n content: attr(data-on);\n}\n\n.form-switch-input:checked ~ .form-switch-label .form-switch-lever::after {\n transform: translateX(calc(var(--switch-lever-width) - 2rem));\n}\n\n/**\n * Focus on Tab\n */\n\n.form-switch-input.focus-visible ~ .form-switch-label .form-switch-lever {\n box-shadow: 0 0 0 0.125rem var(--road-grey-000), 0 0 0 0.1875rem var(--road-primary-700);\n}\n\n/* FEEDBACK\n -------------------- */\n\n/**\n * Secondary\n */\n\n.form-switch-input:checked ~ .form-switch-secondary .form-switch-lever {\n background: var(--road-primary-500);\n}\n\n.form-switch-input:checked ~ .form-switch-secondary .form-switch-lever::before {\n color: var(--road-primary-contrast);\n}\n\n/**\n * Info\n */\n\n.form-switch-input:checked ~ .form-switch-info .form-switch-lever {\n background: var(--road-info-default);\n}\n\n.form-switch-input:checked ~ .form-switch-info .form-switch-lever::before {\n color: var(--road-info-contrast);\n}\n\n/**\n * Success\n */\n\n.form-switch-input:checked ~ .form-switch-success .form-switch-lever {\n background: var(--road-success-default);\n}\n\n.form-switch-input:checked ~ .form-switch-success .form-switch-lever::before {\n color: var(--road-success-contrast);\n}\n\n/**\n * Warning\n */\n\n.form-switch-input:checked ~ .form-switch-warning .form-switch-lever {\n background: var(--road-warning-default);\n}\n\n.form-switch-input:checked ~ .form-switch-warning .form-switch-lever::before {\n color: var(--road-warning-contrast);\n}\n\n/**\n * Danger\n */\n\n.form-switch-input:checked ~ .form-switch-danger .form-switch-lever {\n background: var(--road-danger-default);\n}\n\n.form-switch-input:checked ~ .form-switch-danger .form-switch-lever::before {\n color: var(--road-danger-contrast);\n}\n\n/* POSITION\n -------------------- */\n\n.form-switch-right {\n margin-right: 0;\n margin-left: 0.75rem;\n}\n\n.form-switch-spaced {\n display: flex;\n justify-content: space-between;\n}\n","import { Component, Event, EventEmitter, Host, Prop, Watch, h } from '@stencil/core';\nimport './../../utils/polyfill';\n\nimport { FeedbackColors } from '../../interface';\n\n@Component({\n tag: 'road-switch',\n styleUrl: 'switch.css',\n scoped: true,\n})\nexport class Switch {\n\n /**\n * The id of switch\n */\n @Prop() switchId: string = `road-switch-${switchIds++}`;\n\n /**\n * The name of the control, which is submitted with the form data.\n */\n @Prop() name: string = this.switchId;\n\n /**\n * If `true`, the switch is checked.\n */\n @Prop({ mutable: true }) checked = false;\n\n /**\n * If `true`, the user cannot interact with the switch.\n */\n @Prop() disabled = false;\n\n /**\n * Label for the field\n */\n @Prop() label: string = `${this.switchId}-label`;\n\n /**\n * Set the color of alert. e.g. info, success, warning, danger\n */\n @Prop() color?: 'secondary' | FeedbackColors = 'secondary';\n\n /**\n * If `true`, the label is at left of the switch\n */\n @Prop() hasLeftLabel: boolean = false;\n\n /**\n * Add space between label and switch element\n */\n @Prop() isSpaced: boolean = false;\n\n /**\n * Value the form will get\n */\n @Prop() value: string = 'on';\n\n /**\n * Text display for \"`on`\" state in the switch lever\n */\n @Prop() on: string = \"yes\";\n\n /**\n * Text display for \"`off`\" state in the switch lever\n */\n @Prop() off: string = \"no\";\n\n /**\n * Emitted when the checked property has changed.\n */\n @Event() roadchange!: EventEmitter<{\n checked: boolean;\n value: string | undefined | null\n }>;\n /** @internal */\n @Event() roadChange!: EventEmitter<{\n checked: boolean;\n value: string | undefined | null\n }>;\n\n /**\n * Emitted when the switch has focus.\n */\n @Event() roadfocus!: EventEmitter<void>;\n /** @internal */\n @Event() roadFocus!: EventEmitter<void>;\n\n /**\n * Emitted when the switch loses focus.\n */\n @Event() roadblur!: EventEmitter<void>;\n /** @internal */\n @Event() roadBlur!: EventEmitter<void>;\n\n @Watch('checked')\n checkedChanged(isChecked: boolean) {\n this.roadchange.emit({\n checked: isChecked,\n value: this.value,\n });\n this.roadChange.emit({\n checked: isChecked,\n value: this.value,\n });\n }\n\n private onClick = () => {\n this.checked = !this.checked;\n };\n\n private onFocus = () => {\n this.roadfocus.emit();\n this.roadFocus.emit();\n };\n\n private onBlur = () => {\n this.roadBlur.emit();\n this.roadblur.emit();\n };\n\n render() {\n const labelId = this.switchId + '-label';\n const textLabel = <label class=\"form-switch-label\" id={labelId} htmlFor={this.switchId}>{this.label}</label>;\n const colorClass = this.color !== undefined ? 'form-switch-' + this.color : '';\n const isSpacedClass = this.isSpaced && 'form-switch-spaced';\n const rightSwitchClass = this.hasLeftLabel ? 'form-switch-right' : '';\n\n return (\n <Host>\n <input\n class=\"form-switch-input\"\n type=\"checkbox\"\n id={this.switchId}\n name={this.name}\n checked={this.checked}\n disabled={this.disabled}\n value={this.value}\n aria-checked={`${this.checked}`}\n aria-disabled={this.disabled ? 'true' : null}\n aria-labelledby={labelId}\n onClick={this.onClick}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n />\n <label class={`form-switch-label ${isSpacedClass} ${colorClass}`} htmlFor={this.switchId}>\n {this.hasLeftLabel && textLabel}\n <div class={`form-switch-lever ${rightSwitchClass}`} data-off={this.off} data-on={this.on}></div>\n {this.hasLeftLabel ? '' : textLabel}\n </label>\n </Host>\n );\n }\n}\n\nlet switchIds = 0;\n"],"mappings":"iFAAA,MAAMA,EAAY,++G,MCULC,EAAM,M,uPAgGTC,KAAAC,QAAU,KAChBD,KAAKE,SAAWF,KAAKE,OAAO,EAGtBF,KAAAG,QAAU,KAChBH,KAAKI,UAAUC,OACfL,KAAKM,UAAUD,MAAM,EAGfL,KAAAO,OAAS,KACfP,KAAKQ,SAASH,OACdL,KAAKS,SAASJ,MAAM,E,cAtGK,eAAeK,M,UAKnBV,KAAKW,S,aAKO,M,cAKhB,M,WAKK,GAAGX,KAAKW,iB,WAKe,Y,kBAKf,M,cAKJ,M,WAKJ,K,QAKH,M,SAKC,I,CA8BtBC,eAAeC,GACbb,KAAKc,WAAWT,KAAK,CACnBH,QAASW,EACTE,MAAOf,KAAKe,QAEdf,KAAKgB,WAAWX,KAAK,CACnBH,QAASW,EACTE,MAAOf,KAAKe,O,CAkBhBE,SACE,MAAMC,EAAUlB,KAAKW,SAAW,SAChC,MAAMQ,EAAYC,EAAA,SAAOC,MAAM,oBAAoBC,GAAIJ,EAASK,QAASvB,KAAKW,UAAWX,KAAKwB,OAC9F,MAAMC,EAAazB,KAAK0B,QAAUC,UAAY,eAAiB3B,KAAK0B,MAAQ,GAC5E,MAAME,EAAgB5B,KAAK6B,UAAY,qBACvC,MAAMC,EAAmB9B,KAAK+B,aAAe,oBAAsB,GAEnE,OACEX,EAACY,EAAI,KACHZ,EAAA,SACEC,MAAM,oBACNY,KAAK,WACLX,GAAItB,KAAKW,SACTuB,KAAMlC,KAAKkC,KACXhC,QAASF,KAAKE,QACdiC,SAAUnC,KAAKmC,SACfpB,MAAOf,KAAKe,MAAK,eACH,GAAGf,KAAKE,UAAS,gBAChBF,KAAKmC,SAAW,OAAS,KAAI,kBAC3BjB,EACjBjB,QAASD,KAAKC,QACdE,QAASH,KAAKG,QACdI,OAAQP,KAAKO,SAEfa,EAAA,SAAOC,MAAO,qBAAqBO,KAAiBH,IAAcF,QAASvB,KAAKW,UAC7EX,KAAK+B,cAAgBZ,EACtBC,EAAA,OAAKC,MAAO,qBAAqBS,IAAkB,WAAY9B,KAAKoC,IAAG,UAAWpC,KAAKqC,KACtFrC,KAAK+B,aAAe,GAAKZ,G,4DAOpC,IAAIT,EAAY,E"}
@@ -1,2 +0,0 @@
1
- import{r as t,e,h as o,H as a}from"./p-abdbf6ac.js";import"./p-e8c090a5.js";const i=":host{--z-index:3;position:fixed;bottom:0;left:0;z-index:var(--z-index);box-sizing:border-box;display:flex;align-items:center;width:100%;height:5.125rem;padding-left:0;margin:0;text-align:center;-webkit-user-select:none;user-select:none;background-color:var(--road-surface);border-top:1px solid var(--road-outline)}@media (max-width: 576px){:host{overflow-x:auto}}@media (min-width: 1200px){:host{bottom:auto;flex-direction:column;width:104px;height:100%;border-top:0;border-right:1px solid var(--road-outline)}}::slotted(.drawer-button-save){position:absolute;bottom:0;width:100%}";const r=class{constructor(o){t(this,o);this.roadnavbarchanged=e(this,"roadnavbarchanged",7);this.roadNavbarChanged=e(this,"roadNavbarChanged",7);this.selectedTab=undefined}selectedTabChanged(){if(this.selectedTab!==undefined){this.roadnavbarchanged.emit({tab:this.selectedTab});this.roadNavbarChanged.emit({tab:this.selectedTab})}}onNavbarChanged(t){this.selectedTab=t.detail.tab}componentWillLoad(){this.selectedTabChanged()}render(){return o(a,{role:"tablist"},o("slot",null))}static get watchers(){return{selectedTab:["selectedTabChanged"]}}};r.style=i;export{r as road_navbar};
2
- //# sourceMappingURL=p-f671758f.entry.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["navbarCss","Navbar","selectedTabChanged","this","selectedTab","undefined","roadnavbarchanged","emit","tab","roadNavbarChanged","onNavbarChanged","ev","detail","componentWillLoad","render","h","Host","role"],"sources":["./src/components/navbar/navbar.css?tag=road-navbar&encapsulation=shadow","./src/components/navbar/navbar.tsx"],"sourcesContent":["/*\n * Navbar\n *\n */\n\n/**\n * @prop --z-index: The z-index of the Navbar.\n */\n\n:host {\n --z-index: 3;\n\n position: fixed;\n bottom: 0;\n left: 0;\n z-index: var(--z-index);\n box-sizing: border-box;\n display: flex;\n align-items: center;\n width: 100%;\n height: 5.125rem;\n padding-left: 0;\n margin: 0;\n text-align: center;\n user-select: none;\n background-color: var(--road-surface);\n border-top: 1px solid var(--road-outline);\n}\n\n@media (max-width: 576px) {\n\n :host {\n overflow-x: auto;\n }\n}\n\n@media (min-width: 1200px) {\n\n :host {\n bottom: auto;\n flex-direction: column;\n width: 104px;\n height: 100%;\n border-top: 0;\n border-right: 1px solid var(--road-outline);\n }\n}\n\n/**\n * Button save drawer.\n */\n\n::slotted(.drawer-button-save) {\n position: absolute;\n bottom: 0;\n width: 100%;\n}\n","import { Component, Host, h, Prop, Watch, Event, EventEmitter, Listen } from '@stencil/core';\nimport './../../utils/polyfill';\n\n/**\n * @slot - Content of the navbar, it should be road-navbar-item elements. Max 5 items on Mobile\n */\n\n@Component({\n tag: 'road-navbar',\n styleUrl: 'navbar.css',\n shadow: true,\n})\nexport class Navbar {\n\n /**\n * The selected tab component\n */\n @Prop() selectedTab?: string;\n @Watch('selectedTab')\n selectedTabChanged() {\n if (this.selectedTab !== undefined) {\n this.roadnavbarchanged.emit({\n tab: this.selectedTab,\n });\n this.roadNavbarChanged.emit({\n tab: this.selectedTab,\n });\n }\n }\n\n /** @internal */\n @Event() roadnavbarchanged!: EventEmitter;\n /** @internal */\n @Event() roadNavbarChanged!: EventEmitter;\n\n @Listen('roadNavbarItemClick')\n @Listen('roadnavbaritemclick')\n onNavbarChanged(ev: CustomEvent) {\n this.selectedTab = ev.detail.tab;\n }\n\n componentWillLoad() {\n this.selectedTabChanged();\n }\n\n render() {\n return (\n <Host\n role=\"tablist\"\n >\n <slot/>\n </Host>\n );\n }\n\n}\n"],"mappings":"4EAAA,MAAMA,EAAY,wkB,MCYLC,EAAM,M,8JAOjBC,qBACE,GAAIC,KAAKC,cAAgBC,UAAW,CAClCF,KAAKG,kBAAkBC,KAAK,CAC1BC,IAAKL,KAAKC,cAEZD,KAAKM,kBAAkBF,KAAK,CAC1BC,IAAKL,KAAKC,a,EAYhBM,gBAAgBC,GACdR,KAAKC,YAAcO,EAAGC,OAAOJ,G,CAG/BK,oBACEV,KAAKD,oB,CAGPY,SACE,OACEC,EAACC,EAAI,CACHC,KAAK,WAELF,EAAA,a"}
@@ -1,2 +0,0 @@
1
- import{c as a}from"./p-abdbf6ac.js";a((a=>a.mode||a.getAttribute("mode")||"light"));
2
- //# sourceMappingURL=p-fa98320c.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["setMode","elm","mode","getAttribute"],"sources":["./src/global/app.ts"],"sourcesContent":["import { setMode } from '@stencil/core';\n\nsetMode(elm => {\n return (elm as any).mode || elm.getAttribute('mode') || 'light';\n});"],"mappings":"oCAEAA,GAAQC,GACEA,EAAYC,MAAAD,EAAAE,aAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["progressIndicatorVerticalItemCss","ProgressIndicatorVerticalItem","render","h","Host"],"sources":["./src/components/progress-indicator-vertical-item/progress-indicator-vertical-item.css?tag=road-progress-indicator-vertical-item","./src/components/progress-indicator-vertical-item/progress-indicator-vertical-item.tsx"],"sourcesContent":["/*\n * Progress Indicator Vertical Item\n *\n */\n\n/* PROGRESS INDICATOR VERTICAL ITEM\n -------------------- */\n\nroad-progress-indicator-vertical-item {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n min-height: 65px;\n}\n\n.progress-indicator-vertical-item-content {\n display: inline-block;\n margin-left: 1rem;\n}\n\n/**\n* Disabled click for current and next steps\n*/\n\nroad-progress-indicator-vertical-item:not(.completed) .progress-indicator-vertical-link {\n cursor: not-allowed;\n}\n\n/* VERTICAL STEPPER LINK\n -------------------- */\n\n.progress-indicator-vertical-link {\n position: relative;\n z-index: 1;\n display: flex;\n}\n\n/* VERTICAL STEPPER ICON\n -------------------- */\n\n.progress-indicator-vertical-icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 1.5rem;\n height: 1.5rem;\n font-size: var(--road-font-size-12);\n font-weight: 700;\n color: var(--road-on-surface-disabled);\n background: var(--road-surface-disabled);\n border-radius: 50%;\n fill: currentColor;\n}\n\n.progress-indicator-vertical-icon road-icon{\n display: flex;\n}\n\n.progress-indicator-vertical-substep-link {\n position: relative;\n z-index: 1;\n display: flex;\n margin: 0 0.5rem;\n}\n\n.progress-indicator-vertical-line {\n position: absolute;\n top: 24px;\n left: 11px;\n z-index: -1;\n height: calc(100% - 24px);\n border-left: 2px solid var(--road-surface-disabled);\n}\n\nroad-progress-indicator-vertical-item:last-child .progress-indicator-vertical-line {\n border-left: 0;\n}\n\n.progress-indicator-vertical-substep-icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 0.5rem;\n height: 0.5rem;\n margin-top: 0.7rem;\n background: var(--road-surface-disabled);\n border-radius: 50%;\n}\n\n.progress-indicator-vertical-substep-beforeline {\n position: absolute;\n top: 0;\n left: 3px;\n z-index: -1;\n height: calc(30% - 8px);\n border-left: 2px solid var(--road-surface-disabled);\n}\n\n.progress-indicator-vertical-substep-line {\n position: absolute;\n top: 19px;\n left: 3px;\n z-index: -1;\n height: calc(83% - 8px);\n border-left: 2px solid var(--road-surface-disabled);\n}\n\n/* VERTICAL STEPPER TITLE\n -------------------- */\n\n.progress-indicator-vertical-title road-label{\n display: block;\n font-size: var(--road-body-large);\n font-weight: 700;\n color: var(--road-on-surface-disabled);\n}\n\n.progress-indicator-vertical-description{\n display: block;\n margin: 0;\n font-size: var(--road-label-small);\n font-weight: 400;\n color: var(--road-on-surface-disabled);\n}\n\n/* STEP CURRENT\n -------------------- */\n\n.current .progress-indicator-vertical-icon {\n color: var(--road-on-primary);\n background: var(--road-primary);\n}\n\n.current .progress-indicator-vertical-title road-label{\n font-weight: 700;\n color: var(--road-on-surface);\n}\n\n.current .progress-indicator-vertical-description{\n color: var(--road-on-surface-weak);\n}\n\n.current .progress-indicator-vertical-substep-icon {\n background: var(--road-primary);\n border: 0;\n}\n\n.current .progress-indicator-vertical-substep-beforeline {\n border-left: 2px solid var(--road-primary);\n}\n\n\n/* STEP IN PROGRESS\n -------------------- */\n\n.in-progress .progress-indicator-vertical-icon {\n color: var(--road-on-primary);\n background: var(--road-primary);\n border: 0;\n}\n\n.in-progress .progress-indicator-vertical-title road-label{\n font-weight: 700;\n color: var(--road-on-surface);\n}\n\n.in-progress .progress-indicator-vertical-description{\n color: var(--road-on-surface-weak);\n}\n\n.in-progress .progress-indicator-vertical-line {\n background: var(--road-primary);\n}\n\n/* STEP COMPLETED\n -------------------- */\n\n.completed:not(:last-child)::after {\n background: var(--road-primary);\n}\n\n.completed .progress-indicator-vertical-icon {\n color: var(--road-primary);\n background: none;\n border: 2px solid var(--road-primary);\n}\n\n.completed .progress-indicator-vertical-line {\n border-left: 2px solid var(--road-primary);\n}\n\n.completed .progress-indicator-vertical-substep-beforeline {\n border-left: 2px solid var(--road-primary);\n}\n\n.completed .progress-indicator-vertical-substep-line {\n border-left: 2px solid var(--road-primary);\n}\n\n.completed .progress-indicator-vertical-title road-label{\n font-weight: 700;\n color: var(--road-on-surface);\n}\n\n.completed .progress-indicator-vertical-description{\n color: var(--road-on-surface-weak);\n}\n\n.completed .progress-indicator-vertical-substep-icon {\n background: none;\n border: 2px solid var(--road-primary);\n}\n","import { Component, Host, h } from '@stencil/core';\n\n/**\n * @slot - Content of the progress indicator vertical item\n */\n\n@Component({\n tag: 'road-progress-indicator-vertical-item',\n styleUrl: 'progress-indicator-vertical-item.css',\n})\nexport class ProgressIndicatorVerticalItem {\n\n render() {\n return (\n <Host>\n <slot/>\n </Host>\n );\n }\n}\n"],"mappings":"6CAAA,MAAMA,EAAmC,s9G,MCU5BC,EAA6B,M,yBAExCC,SACE,OACEC,EAACC,EAAI,KACHD,EAAA,a"}
@@ -1 +0,0 @@
1
- {"version":3,"names":["dropdownCss","Dropdown","this","onClick","isOpen","render","isLightButtonDropDown","isLight","isMediumButtonDropDown","isMedium","positionClass","position","undefined","directionClass","direction","h","class","open","tabindex","role","name"],"sources":["./src/components/dropdown/dropdown.css?tag=road-dropdown&encapsulation=shadow","./src/components/dropdown/dropdown.tsx"],"sourcesContent":["/*\n * Dropdown\n *\n * Index\n * - Dropdown\n * - Dropdown menu\n */\n\n/**\n * @prop --margin-top: Top margin of the menu\n */\n\n/* DROPDOWN\n -------------------- */\n\n:host {\n --margin-top: 0.5rem;\n display: block;\n}\n\n.dropdown {\n position: relative;\n font-family: var(--road-font);\n}\n\n.dropdown summary {\n display: block;\n outline: none;\n}\n\n.dropdown summary::-webkit-details-marker { /* remove native arrow */\n display: none;\n}\n\n.dropdown-button{\n position: relative;\n z-index: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 3.5rem;\n height: 3.5rem;\n cursor: pointer;\n border-radius: 0.25rem;\n}\n\n.dropdown-medium-button{\n width: 2.5rem;\n height: 2.5rem;\n}\n\n.dropdown-button:hover{\n background: var(--road-grey-200);\n}\n\n.position-right{\n display: flex;\n justify-content: flex-end;\n}\n\n.bg-white{\n background: var(--road-grey-000);\n}\n\n.dropdown-button-icon{\n width: 2.5rem;\n height: 2.5rem;\n}\n\n.dropdown-medium-button .dropdown-button-icon{\n width: 1.75rem;\n height: 1.75rem;\n}\n\n/**\n * Open state\n */\n\n.dropdown[open] .dropdown-menu {\n transform: scaleY(1);\n}\n\n.dropdown[open] .dropdown-menu.direction-top {\n position: absolute;\n bottom: 0;\n left: 0;\n transform: translate3d(0, -56px, 0);\n will-change: transform;\n}\n\n/* MENU\n -------------------- */\n\n.dropdown-menu {\n position: relative;\n display: flex;\n flex-direction: column;\n width: 100%;\n min-width: 16.875rem;\n padding: 0.5rem 0;\n color: var(--road-on-surface);\n background: var(--road-surface);\n border: 1px solid;\n border-color: var(--road-outline-weak);\n border-radius: 0.25rem;\n box-shadow: var(--road-elevation-low);\n transition: transform 0.2s ease-in-out;\n transform: scaleY(0);\n transform-origin: 0 0;\n}\n\n/* ITEM\n -------------------- */\n\n.dropdown-item {\n min-height: 40px;\n padding: 0 1rem;\n font-size: var(--road-body-medium);\n line-height: 1.5;\n color: var(--road-on-surface);\n text-align: left;\n text-decoration: none;\n cursor: pointer;\n background: var(--road-surface);\n border: none;\n outline: none;\n}\n\n.dropdown-item-border {\n border-color: var(--road-outline-weak);\n border-bottom: 1px solid;\n}\n\n/**\n * Hover state\n */\n\n.dropdown-item:hover,\n.dropdown-item.focus-visible {\n background: var(--road-surface-inverse);\n}\n\n\n","import { Component, h, Prop } from '@stencil/core';\n\n/**\n * @slot - Element how will open the dropdown when clicked\n * @slot list - List of item values (you can add border with lines=`full` but not on the last item)\n)\n */\n\n@Component({\n tag: 'road-dropdown',\n styleUrl: 'dropdown.css',\n shadow: true,\n})\nexport class Dropdown {\n\n /**\n * Set to `true` to open the dropdown menu and to `false` to close it.\n */\n @Prop({ mutable: true }) isOpen : boolean = false;\n\n /**\n * If you want to remove background of the dropdown button\n */\n @Prop() isLight : boolean = false;\n \n /**\n * If you want to remove background of the dropdown button\n */\n @Prop() isMedium : boolean = false;\n\n /**\n * The button position.\n */\n @Prop({ reflect: true }) position?: 'left' | 'right';\n\n /**\n * The opening direction.\n */\n @Prop({ reflect: true }) direction?: 'top' | 'bottom' = 'bottom';\n\n /**\n * Toggle the display when clicking element in slot\n */\n private onClick = () => {\n this.isOpen = !this.isOpen;\n };\n\n render() {\n\n const isLightButtonDropDown = this.isLight == true ? `dropdown-button` : 'dropdown-button bg-white';\n const isMediumButtonDropDown = this.isMedium == true ? `dropdown-medium-button dropdown-button` : 'dropdown-button bg-white';\n const positionClass = this.position !== undefined ? `position-${this.position}` : '';\n const directionClass = this.direction !== undefined ? `direction-${this.direction}` : '';\n\n\n return (\n <details class=\"dropdown\" open={this.isOpen}>\n <summary aria-expanded={`${this.isOpen}`} tabindex=\"0\" role=\"button\" onClick={this.onClick}>\n <div class={`d-flex ${positionClass}`}>\n <div class={`${isLightButtonDropDown} ${isMediumButtonDropDown}`}>\n <road-icon name=\"navigation-more\" class=\"dropdown-button-icon\"></road-icon>\n </div>\n </div>\n </summary>\n <div class={`dropdown-menu ${directionClass}`}>\n <slot name=\"list\"/>\n </div>\n </details>\n );\n }\n\n}\n"],"mappings":"2CAAA,MAAMA,EAAc,onD,MCaPC,EAAQ,M,yBA8BXC,KAAAC,QAAU,KAChBD,KAAKE,QAAUF,KAAKE,MAAM,E,YA1BgB,M,aAKd,M,cAKC,M,uCAU2B,Q,CAS1DC,SAEE,MAAMC,EAAwBJ,KAAKK,SAAW,KAAO,kBAAoB,2BACzE,MAAMC,EAAyBN,KAAKO,UAAY,KAAO,yCAA2C,2BAClG,MAAMC,EAAgBR,KAAKS,WAAaC,UAAY,YAAYV,KAAKS,WAAa,GAClF,MAAME,EAAiBX,KAAKY,YAAcF,UAAY,aAAaV,KAAKY,YAAc,GAGtF,OACEC,EAAA,WAASC,MAAM,WAAWC,KAAMf,KAAKE,QACnCW,EAAA,2BAAwB,GAAGb,KAAKE,SAAUc,SAAS,IAAIC,KAAK,SAAShB,QAASD,KAAKC,SACjFY,EAAA,OAAKC,MAAO,UAAUN,KACpBK,EAAA,OAAKC,MAAO,GAAGV,KAAyBE,KACtCO,EAAA,aAAWK,KAAK,kBAAkBJ,MAAM,4BAI9CD,EAAA,OAAKC,MAAO,iBAAiBH,KAC3BE,EAAA,QAAMK,KAAK,U"}