@empathyco/x-components 6.0.0-alpha.184 → 6.0.0-alpha.186

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/CHANGELOG.md +17 -0
  2. package/docs/API-reference/api/x-components.aioverview.md +22 -8
  3. package/docs/API-reference/api/x-components.allfilter.md +6 -4
  4. package/docs/API-reference/api/x-components.animatewidth.md +1 -1
  5. package/docs/API-reference/api/x-components.autoprogressbar.md +5 -5
  6. package/docs/API-reference/api/x-components.banner.md +5 -5
  7. package/docs/API-reference/api/x-components.bannerslist.md +5 -5
  8. package/docs/API-reference/api/x-components.baseaddtocart.md +6 -4
  9. package/docs/API-reference/api/x-components.basecolumnpickerdropdown.md +8 -6
  10. package/docs/API-reference/api/x-components.basecolumnpickerlist.md +7 -5
  11. package/docs/API-reference/api/x-components.basecurrency.md +4 -4
  12. package/docs/API-reference/api/x-components.basedropdown.md +12 -12
  13. package/docs/API-reference/api/x-components.baseeventbutton.md +5 -5
  14. package/docs/API-reference/api/x-components.baseeventsmodal.md +10 -8
  15. package/docs/API-reference/api/x-components.baseeventsmodalclose.md +7 -5
  16. package/docs/API-reference/api/x-components.baseeventsmodalopen.md +7 -5
  17. package/docs/API-reference/api/x-components.basegrid.md +9 -7
  18. package/docs/API-reference/api/x-components.baseheadertogglepanel.md +9 -7
  19. package/docs/API-reference/api/x-components.baseidmodal.md +8 -6
  20. package/docs/API-reference/api/x-components.baseidmodalclose.md +4 -4
  21. package/docs/API-reference/api/x-components.baseidmodalopen.md +4 -4
  22. package/docs/API-reference/api/x-components.baseidtogglepanel.md +8 -6
  23. package/docs/API-reference/api/x-components.baseidtogglepanelbutton.md +7 -5
  24. package/docs/API-reference/api/x-components.basekeyboardnavigation.md +6 -6
  25. package/docs/API-reference/api/x-components.basemodal.md +9 -9
  26. package/docs/API-reference/api/x-components.basepricefilterlabel.md +6 -4
  27. package/docs/API-reference/api/x-components.baserating.md +7 -5
  28. package/docs/API-reference/api/x-components.baseratingfilterlabel.md +7 -5
  29. package/docs/API-reference/api/x-components.baseresultcurrentprice.md +6 -4
  30. package/docs/API-reference/api/x-components.baseresultimage.md +9 -9
  31. package/docs/API-reference/api/x-components.baseresultlink.md +5 -5
  32. package/docs/API-reference/api/x-components.baseresultpreviousprice.md +5 -3
  33. package/docs/API-reference/api/x-components.baseresultrating.md +7 -5
  34. package/docs/API-reference/api/x-components.basescroll.md +7 -7
  35. package/docs/API-reference/api/x-components.baseslider.md +7 -7
  36. package/docs/API-reference/api/x-components.basesuggestion.md +8 -6
  37. package/docs/API-reference/api/x-components.basesuggestions.md +5 -5
  38. package/docs/API-reference/api/x-components.baseswitch.md +6 -6
  39. package/docs/API-reference/api/x-components.basetabspanel.md +6 -6
  40. package/docs/API-reference/api/x-components.baseteleport.md +6 -6
  41. package/docs/API-reference/api/x-components.basetogglepanel.md +4 -4
  42. package/docs/API-reference/api/x-components.basevariablecolumngrid.md +7 -5
  43. package/docs/API-reference/api/x-components.changeheight.md +2 -2
  44. package/docs/API-reference/api/x-components.clearfilters.md +7 -5
  45. package/docs/API-reference/api/x-components.clearhistoryqueries.md +3 -1
  46. package/docs/API-reference/api/x-components.clearsearchinput.md +7 -1
  47. package/docs/API-reference/api/x-components.closemainmodal.md +3 -1
  48. package/docs/API-reference/api/x-components.collapseheight.md +5 -5
  49. package/docs/API-reference/api/x-components.collapsewidth.md +5 -5
  50. package/docs/API-reference/api/x-components.crossfade.md +4 -4
  51. package/docs/API-reference/api/x-components.devicedetector.md +9 -5
  52. package/docs/API-reference/api/x-components.displayclickprovider.md +5 -5
  53. package/docs/API-reference/api/x-components.displayemitter.md +4 -4
  54. package/docs/API-reference/api/x-components.editablenumberrangefilter.md +7 -7
  55. package/docs/API-reference/api/x-components.empathize.md +6 -6
  56. package/docs/API-reference/api/x-components.excludefilterswithnoresults.md +4 -4
  57. package/docs/API-reference/api/x-components.experiencecontrols.md +1 -1
  58. package/docs/API-reference/api/x-components.extraparams.md +3 -3
  59. package/docs/API-reference/api/x-components.facets.md +5 -5
  60. package/docs/API-reference/api/x-components.facetsprovider.md +4 -4
  61. package/docs/API-reference/api/x-components.fade.md +4 -4
  62. package/docs/API-reference/api/x-components.fadeandslide.md +5 -5
  63. package/docs/API-reference/api/x-components.fallbackdisclaimer.md +1 -1
  64. package/docs/API-reference/api/x-components.filterslist.md +5 -5
  65. package/docs/API-reference/api/x-components.filterssearch.md +6 -6
  66. package/docs/API-reference/api/x-components.fixedheaderandasideslayout.md +9 -5
  67. package/docs/API-reference/api/x-components.globalxbus.md +3 -3
  68. package/docs/API-reference/api/x-components.hierarchicalfilter.md +8 -5
  69. package/docs/API-reference/api/x-components.highlight_2.md +5 -5
  70. package/docs/API-reference/api/x-components.historyqueries.md +4 -1
  71. package/docs/API-reference/api/x-components.historyqueriesswitch.md +3 -1
  72. package/docs/API-reference/api/x-components.historyquery.md +8 -5
  73. package/docs/API-reference/api/x-components.identifierresult.md +4 -4
  74. package/docs/API-reference/api/x-components.identifierresults.md +5 -5
  75. package/docs/API-reference/api/x-components.itemslist.md +5 -5
  76. package/docs/API-reference/api/x-components.locationprovider.md +4 -4
  77. package/docs/API-reference/api/x-components.mainmodal.md +6 -4
  78. package/docs/API-reference/api/x-components.mainscroll.md +5 -5
  79. package/docs/API-reference/api/x-components.mainscrollitem.md +6 -6
  80. package/docs/API-reference/api/x-components.md +1 -0
  81. package/docs/API-reference/api/x-components.multicolumnmaxwidthlayout.md +9 -5
  82. package/docs/API-reference/api/x-components.myhistory.md +8 -5
  83. package/docs/API-reference/api/x-components.nextqueries.md +8 -5
  84. package/docs/API-reference/api/x-components.nextquerieslist.md +5 -5
  85. package/docs/API-reference/api/x-components.nextquery.md +7 -5
  86. package/docs/API-reference/api/x-components.nextquerypreview.md +4 -4
  87. package/docs/API-reference/api/x-components.noanimation.md +2 -2
  88. package/docs/API-reference/api/x-components.numberrangefilter.md +7 -5
  89. package/docs/API-reference/api/x-components.openmainmodal.md +3 -1
  90. package/docs/API-reference/api/x-components.pageloaderbutton.md +7 -5
  91. package/docs/API-reference/api/x-components.pageselector.md +5 -5
  92. package/docs/API-reference/api/x-components.partialquerybutton.md +5 -5
  93. package/docs/API-reference/api/x-components.partialresultslist.md +5 -5
  94. package/docs/API-reference/api/x-components.popularsearch.md +6 -4
  95. package/docs/API-reference/api/x-components.popularsearches.md +4 -1
  96. package/docs/API-reference/api/x-components.preselectedfilters.md +5 -5
  97. package/docs/API-reference/api/x-components.promoted.md +4 -4
  98. package/docs/API-reference/api/x-components.promotedslist.md +5 -5
  99. package/docs/API-reference/api/x-components.querypreview.md +6 -6
  100. package/docs/API-reference/api/x-components.querypreviewbutton.md +6 -4
  101. package/docs/API-reference/api/x-components.querypreviewlist.md +8 -6
  102. package/docs/API-reference/api/x-components.querysuggestion.md +6 -4
  103. package/docs/API-reference/api/x-components.querysuggestions.md +4 -1
  104. package/docs/API-reference/api/x-components.recommendations.md +5 -5
  105. package/docs/API-reference/api/x-components.redirection.md +6 -6
  106. package/docs/API-reference/api/x-components.relatedprompt.md +9 -4
  107. package/docs/API-reference/api/x-components.relatedpromptslist.md +5 -5
  108. package/docs/API-reference/api/x-components.relatedpromptstaglist.md +11 -7
  109. package/docs/API-reference/api/x-components.relatedtag.md +6 -6
  110. package/docs/API-reference/api/x-components.relatedtags.md +7 -5
  111. package/docs/API-reference/api/x-components.removehistoryquery.md +6 -4
  112. package/docs/API-reference/api/x-components.renderlessextraparams.md +4 -4
  113. package/docs/API-reference/api/x-components.renderlessfilter.md +5 -5
  114. package/docs/API-reference/api/x-components.resultslist.md +6 -6
  115. package/docs/API-reference/api/x-components.resultvariantselector.md +6 -6
  116. package/docs/API-reference/api/x-components.resultvariantsprovider.md +5 -5
  117. package/docs/API-reference/api/x-components.scroll.md +8 -6
  118. package/docs/API-reference/api/x-components.scrolltotop.md +7 -5
  119. package/docs/API-reference/api/x-components.searchbutton.md +2 -2
  120. package/docs/API-reference/api/x-components.searchinput.md +6 -6
  121. package/docs/API-reference/api/x-components.searchinputplaceholder.md +6 -6
  122. package/docs/API-reference/api/x-components.selectedfilters.md +5 -5
  123. package/docs/API-reference/api/x-components.selectedfilterslist.md +7 -5
  124. package/docs/API-reference/api/x-components.semanticqueries.md +4 -1
  125. package/docs/API-reference/api/x-components.semanticquery.md +6 -4
  126. package/docs/API-reference/api/x-components.simplefilter.md +7 -5
  127. package/docs/API-reference/api/x-components.singlecolumnlayout.md +10 -5
  128. package/docs/API-reference/api/x-components.slicedfilters.md +6 -6
  129. package/docs/API-reference/api/x-components.slidingpanel.md +8 -8
  130. package/docs/API-reference/api/x-components.snippetcallbacks.md +3 -1
  131. package/docs/API-reference/api/x-components.snippetconfigextraparams.md +8 -6
  132. package/docs/API-reference/api/x-components.sortdropdown.md +8 -6
  133. package/docs/API-reference/api/x-components.sortedfilters.md +4 -4
  134. package/docs/API-reference/api/x-components.sortlist.md +7 -5
  135. package/docs/API-reference/api/x-components.sortpickerlist.md +7 -5
  136. package/docs/API-reference/api/x-components.spellcheck.md +1 -1
  137. package/docs/API-reference/api/x-components.spellcheckbutton.md +2 -2
  138. package/docs/API-reference/api/x-components.staggeredfadeandslide.md +5 -5
  139. package/docs/API-reference/api/x-components.tagging.md +4 -4
  140. package/docs/API-reference/api/x-components.typinghtmlelement.__timeoutid.md +11 -0
  141. package/docs/API-reference/api/x-components.typinghtmlelement.md +19 -0
  142. package/docs/API-reference/api/x-components.urlhandler.md +5 -1
  143. package/js/components/animations/animate-scale/animate-scale.style.scss.js +1 -1
  144. package/js/components/animations/animate-width.vue.js.map +1 -1
  145. package/js/components/animations/collapse-height.vue.js.map +1 -1
  146. package/js/components/animations/collapse-width.vue.js.map +1 -1
  147. package/js/components/animations/cross-fade.vue.js.map +1 -1
  148. package/js/components/animations/fade-and-slide.vue.js.map +1 -1
  149. package/js/components/animations/fade.vue.js.map +1 -1
  150. package/js/components/animations/staggered-fade-and-slide.vue.js.map +1 -1
  151. package/js/components/auto-progress-bar.vue.js.map +1 -1
  152. package/js/components/base-dropdown.vue.js.map +1 -1
  153. package/js/components/base-grid.vue.js.map +1 -1
  154. package/js/components/base-keyboard-navigation.vue.js.map +1 -1
  155. package/js/components/base-rating.vue.js.map +1 -1
  156. package/js/components/base-rating.vue3.js +1 -1
  157. package/js/components/base-slider.vue.js +16 -18
  158. package/js/components/base-slider.vue.js.map +1 -1
  159. package/js/components/base-switch.vue.js +10 -13
  160. package/js/components/base-switch.vue.js.map +1 -1
  161. package/js/components/base-teleport.vue.js.map +1 -1
  162. package/js/components/base-variable-column-grid.vue.js.map +1 -1
  163. package/js/components/column-picker/base-column-picker-dropdown.vue.js.map +1 -1
  164. package/js/components/column-picker/base-column-picker-list.vue.js.map +1 -1
  165. package/js/components/currency/base-currency.vue.js.map +1 -1
  166. package/js/components/filters/labels/base-rating-filter-label.vue.js.map +1 -1
  167. package/js/components/highlight.vue.js.map +1 -1
  168. package/js/components/icons/ai-star.vue.js +19 -22
  169. package/js/components/icons/ai-star.vue.js.map +1 -1
  170. package/js/components/icons/arrow-down.vue.js +16 -19
  171. package/js/components/icons/arrow-down.vue.js.map +1 -1
  172. package/js/components/icons/arrow-left.vue.js +16 -19
  173. package/js/components/icons/arrow-left.vue.js.map +1 -1
  174. package/js/components/icons/arrow-right.vue.js +16 -19
  175. package/js/components/icons/arrow-right.vue.js.map +1 -1
  176. package/js/components/icons/arrow-up.vue.js +16 -19
  177. package/js/components/icons/arrow-up.vue.js.map +1 -1
  178. package/js/components/icons/bag.vue.js +16 -19
  179. package/js/components/icons/bag.vue.js.map +1 -1
  180. package/js/components/icons/bar-code.vue.js +8 -10
  181. package/js/components/icons/bar-code.vue.js.map +1 -1
  182. package/js/components/icons/barcode-tiny.vue.js +8 -10
  183. package/js/components/icons/barcode-tiny.vue.js.map +1 -1
  184. package/js/components/icons/cart-filled.vue.js +21 -25
  185. package/js/components/icons/cart-filled.vue.js.map +1 -1
  186. package/js/components/icons/cart.vue.js +16 -19
  187. package/js/components/icons/cart.vue.js.map +1 -1
  188. package/js/components/icons/check-tiny.vue.js +9 -11
  189. package/js/components/icons/check-tiny.vue.js.map +1 -1
  190. package/js/components/icons/check.vue.js +9 -11
  191. package/js/components/icons/check.vue.js.map +1 -1
  192. package/js/components/icons/checkbox-selected-filled.vue.js +20 -23
  193. package/js/components/icons/checkbox-selected-filled.vue.js.map +1 -1
  194. package/js/components/icons/checkbox-selected.vue.js +19 -22
  195. package/js/components/icons/checkbox-selected.vue.js.map +1 -1
  196. package/js/components/icons/checkbox-unselected-filled.vue.js +13 -15
  197. package/js/components/icons/checkbox-unselected-filled.vue.js.map +1 -1
  198. package/js/components/icons/checkbox-unselected.vue.js +12 -14
  199. package/js/components/icons/checkbox-unselected.vue.js.map +1 -1
  200. package/js/components/icons/chevron-down.vue.js +9 -11
  201. package/js/components/icons/chevron-down.vue.js.map +1 -1
  202. package/js/components/icons/chevron-left.vue.js +9 -11
  203. package/js/components/icons/chevron-left.vue.js.map +1 -1
  204. package/js/components/icons/chevron-right.vue.js +9 -11
  205. package/js/components/icons/chevron-right.vue.js.map +1 -1
  206. package/js/components/icons/chevron-tiny-down.vue.js +9 -11
  207. package/js/components/icons/chevron-tiny-down.vue.js.map +1 -1
  208. package/js/components/icons/chevron-tiny-left.vue.js +9 -11
  209. package/js/components/icons/chevron-tiny-left.vue.js.map +1 -1
  210. package/js/components/icons/chevron-tiny-right.vue.js +9 -11
  211. package/js/components/icons/chevron-tiny-right.vue.js.map +1 -1
  212. package/js/components/icons/chevron-tiny-up.vue.js +9 -11
  213. package/js/components/icons/chevron-tiny-up.vue.js.map +1 -1
  214. package/js/components/icons/chevron-up.vue.js +9 -11
  215. package/js/components/icons/chevron-up.vue.js.map +1 -1
  216. package/js/components/icons/corner-arrow-left.vue.js +9 -11
  217. package/js/components/icons/corner-arrow-left.vue.js.map +1 -1
  218. package/js/components/icons/corner-arrow-right.vue.js +9 -11
  219. package/js/components/icons/corner-arrow-right.vue.js.map +1 -1
  220. package/js/components/icons/cross-tiny.vue.js +9 -11
  221. package/js/components/icons/cross-tiny.vue.js.map +1 -1
  222. package/js/components/icons/cross.vue.js +9 -11
  223. package/js/components/icons/cross.vue.js.map +1 -1
  224. package/js/components/icons/curated-check-filled.vue.js +19 -22
  225. package/js/components/icons/curated-check-filled.vue.js.map +1 -1
  226. package/js/components/icons/curated-check-tiny-filled.vue.js +19 -22
  227. package/js/components/icons/curated-check-tiny-filled.vue.js.map +1 -1
  228. package/js/components/icons/curated-check-tiny.vue.js +18 -21
  229. package/js/components/icons/curated-check-tiny.vue.js.map +1 -1
  230. package/js/components/icons/curated-check.vue.js +18 -21
  231. package/js/components/icons/curated-check.vue.js.map +1 -1
  232. package/js/components/icons/diagonal-arrow-left-down.vue.js +9 -11
  233. package/js/components/icons/diagonal-arrow-left-down.vue.js.map +1 -1
  234. package/js/components/icons/diagonal-arrow-left-top.vue.js +9 -11
  235. package/js/components/icons/diagonal-arrow-left-top.vue.js.map +1 -1
  236. package/js/components/icons/diagonal-arrow-right-down.vue.js +9 -11
  237. package/js/components/icons/diagonal-arrow-right-down.vue.js.map +1 -1
  238. package/js/components/icons/diagonal-arrow-right-top.vue.js +9 -11
  239. package/js/components/icons/diagonal-arrow-right-top.vue.js.map +1 -1
  240. package/js/components/icons/filters.vue.js +8 -10
  241. package/js/components/icons/filters.vue.js.map +1 -1
  242. package/js/components/icons/grid-1-col.vue.js +8 -10
  243. package/js/components/icons/grid-1-col.vue.js.map +1 -1
  244. package/js/components/icons/grid-2-col.vue.js +8 -10
  245. package/js/components/icons/grid-2-col.vue.js.map +1 -1
  246. package/js/components/icons/grid-2-rows.vue.js +19 -22
  247. package/js/components/icons/grid-2-rows.vue.js.map +1 -1
  248. package/js/components/icons/grid-4-col.vue.js +8 -10
  249. package/js/components/icons/grid-4-col.vue.js.map +1 -1
  250. package/js/components/icons/heart-filled.vue.js +10 -12
  251. package/js/components/icons/heart-filled.vue.js.map +1 -1
  252. package/js/components/icons/heart.vue.js +9 -11
  253. package/js/components/icons/heart.vue.js.map +1 -1
  254. package/js/components/icons/hide.vue.js +9 -11
  255. package/js/components/icons/hide.vue.js.map +1 -1
  256. package/js/components/icons/history-tiny.vue.js +16 -19
  257. package/js/components/icons/history-tiny.vue.js.map +1 -1
  258. package/js/components/icons/history.vue.js +16 -19
  259. package/js/components/icons/history.vue.js.map +1 -1
  260. package/js/components/icons/light-bulb-off.vue.js +14 -17
  261. package/js/components/icons/light-bulb-off.vue.js.map +1 -1
  262. package/js/components/icons/light-bulb-on.vue.js +20 -24
  263. package/js/components/icons/light-bulb-on.vue.js.map +1 -1
  264. package/js/components/icons/menu.vue.js +9 -11
  265. package/js/components/icons/menu.vue.js.map +1 -1
  266. package/js/components/icons/minus-tiny.vue.js +9 -11
  267. package/js/components/icons/minus-tiny.vue.js.map +1 -1
  268. package/js/components/icons/minus.vue.js +9 -11
  269. package/js/components/icons/minus.vue.js.map +1 -1
  270. package/js/components/icons/plus-tiny.vue.js +9 -11
  271. package/js/components/icons/plus-tiny.vue.js.map +1 -1
  272. package/js/components/icons/plus.vue.js +9 -11
  273. package/js/components/icons/plus.vue.js.map +1 -1
  274. package/js/components/icons/radiobutton-selected.vue.js +3 -5
  275. package/js/components/icons/radiobutton-selected.vue.js.map +1 -1
  276. package/js/components/icons/radiobutton-unselected.vue.js +20 -23
  277. package/js/components/icons/radiobutton-unselected.vue.js.map +1 -1
  278. package/js/components/icons/search-tiny.vue.js +9 -11
  279. package/js/components/icons/search-tiny.vue.js.map +1 -1
  280. package/js/components/icons/search.vue.js +9 -11
  281. package/js/components/icons/search.vue.js.map +1 -1
  282. package/js/components/icons/settings.vue.js +3 -5
  283. package/js/components/icons/settings.vue.js.map +1 -1
  284. package/js/components/icons/show.vue.js +18 -21
  285. package/js/components/icons/show.vue.js.map +1 -1
  286. package/js/components/icons/sort-az.vue.js +31 -36
  287. package/js/components/icons/sort-az.vue.js.map +1 -1
  288. package/js/components/icons/sort-price-down.vue.js +3 -5
  289. package/js/components/icons/sort-price-down.vue.js.map +1 -1
  290. package/js/components/icons/sort-price-up.vue.js +3 -5
  291. package/js/components/icons/sort-price-up.vue.js.map +1 -1
  292. package/js/components/icons/sort-relevancy.vue.js +23 -27
  293. package/js/components/icons/sort-relevancy.vue.js.map +1 -1
  294. package/js/components/icons/sort-za.vue.js +31 -36
  295. package/js/components/icons/sort-za.vue.js.map +1 -1
  296. package/js/components/icons/spinner.vue.js +3 -5
  297. package/js/components/icons/spinner.vue.js.map +1 -1
  298. package/js/components/icons/star-filled.vue.js +23 -26
  299. package/js/components/icons/star-filled.vue.js.map +1 -1
  300. package/js/components/icons/star.vue.js +11 -13
  301. package/js/components/icons/star.vue.js.map +1 -1
  302. package/js/components/icons/tag-filled.vue.js +17 -20
  303. package/js/components/icons/tag-filled.vue.js.map +1 -1
  304. package/js/components/icons/tag.vue.js +16 -19
  305. package/js/components/icons/tag.vue.js.map +1 -1
  306. package/js/components/icons/trash-open.vue.js +3 -5
  307. package/js/components/icons/trash-open.vue.js.map +1 -1
  308. package/js/components/icons/trash.vue.js +3 -5
  309. package/js/components/icons/trash.vue.js.map +1 -1
  310. package/js/components/icons/trending-tiny.vue.js +16 -19
  311. package/js/components/icons/trending-tiny.vue.js.map +1 -1
  312. package/js/components/icons/trending.vue.js +16 -19
  313. package/js/components/icons/trending.vue.js.map +1 -1
  314. package/js/components/icons/user-filled.vue.js +13 -16
  315. package/js/components/icons/user-filled.vue.js.map +1 -1
  316. package/js/components/icons/user.vue.js +9 -11
  317. package/js/components/icons/user.vue.js.map +1 -1
  318. package/js/components/items-list.vue.js.map +1 -1
  319. package/js/components/layouts/fixed-header-and-asides-layout.vue.js.map +1 -1
  320. package/js/components/layouts/multi-column-max-width-layout.vue.js.map +1 -1
  321. package/js/components/layouts/single-column-layout.vue.js.map +1 -1
  322. package/js/components/modals/base-events-modal-close.vue.js.map +1 -1
  323. package/js/components/modals/base-events-modal-open.vue.js.map +1 -1
  324. package/js/components/modals/base-events-modal.vue.js.map +1 -1
  325. package/js/components/modals/base-id-modal.vue.js.map +1 -1
  326. package/js/components/modals/base-modal.vue.js.map +1 -1
  327. package/js/components/modals/close-main-modal.vue.js.map +1 -1
  328. package/js/components/modals/main-modal.vue.js.map +1 -1
  329. package/js/components/modals/open-main-modal.vue.js.map +1 -1
  330. package/js/components/page-loader-button.vue.js +5 -1
  331. package/js/components/page-loader-button.vue.js.map +1 -1
  332. package/js/components/page-selector.vue.js +10 -2
  333. package/js/components/page-selector.vue.js.map +1 -1
  334. package/js/components/panels/base-header-toggle-panel.vue.js.map +1 -1
  335. package/js/components/panels/base-id-toggle-panel-button.vue.js.map +1 -1
  336. package/js/components/panels/base-id-toggle-panel.vue.js.map +1 -1
  337. package/js/components/panels/base-tabs-panel.vue.js.map +1 -1
  338. package/js/components/panels/base-toggle-panel.vue.js.map +1 -1
  339. package/js/components/result/base-result-add-to-cart.vue.js.map +1 -1
  340. package/js/components/result/base-result-current-price.vue.js.map +1 -1
  341. package/js/components/result/base-result-fallback-image.vue.js +15 -18
  342. package/js/components/result/base-result-fallback-image.vue.js.map +1 -1
  343. package/js/components/result/base-result-image.vue.js.map +1 -1
  344. package/js/components/result/base-result-link.vue.js.map +1 -1
  345. package/js/components/result/base-result-placeholder-image.vue.js +14 -17
  346. package/js/components/result/base-result-placeholder-image.vue.js.map +1 -1
  347. package/js/components/result/base-result-previous-price.vue.js.map +1 -1
  348. package/js/components/result/base-result-rating.vue.js.map +1 -1
  349. package/js/components/result/result-variant-selector.vue.js.map +1 -1
  350. package/js/components/sliding-panel.vue.js +10 -2
  351. package/js/components/sliding-panel.vue.js.map +1 -1
  352. package/js/components/sliding-panel.vue3.js +1 -1
  353. package/js/components/suggestions/base-suggestion.vue.js.map +1 -1
  354. package/js/components/suggestions/base-suggestions.vue.js.map +1 -1
  355. package/js/composables/use-on-display.js +1 -1
  356. package/js/composables/use-on-display.js.map +1 -1
  357. package/js/directives/infinite-scroll.js +1 -1
  358. package/js/directives/infinite-scroll.js.map +1 -1
  359. package/js/directives/typing.js.map +1 -1
  360. package/js/x-modules/ai/components/ai-overview.vue.js +25 -26
  361. package/js/x-modules/ai/components/ai-overview.vue.js.map +1 -1
  362. package/js/x-modules/device/components/device-detector.vue.js.map +1 -1
  363. package/js/x-modules/empathize/components/empathize.vue.js.map +1 -1
  364. package/js/x-modules/facets/components/clear-filters.vue.js.map +1 -1
  365. package/js/x-modules/facets/components/facets/facets.vue.js.map +1 -1
  366. package/js/x-modules/facets/components/filters/all-filter.vue.js +5 -1
  367. package/js/x-modules/facets/components/filters/all-filter.vue.js.map +1 -1
  368. package/js/x-modules/facets/components/filters/editable-number-range-filter.vue.js +10 -2
  369. package/js/x-modules/facets/components/filters/editable-number-range-filter.vue.js.map +1 -1
  370. package/js/x-modules/facets/components/filters/hierarchical-filter.vue.js +3 -3
  371. package/js/x-modules/facets/components/filters/hierarchical-filter.vue.js.map +1 -1
  372. package/js/x-modules/facets/components/filters/number-range-filter.vue.js.map +1 -1
  373. package/js/x-modules/facets/components/filters/simple-filter.vue.js.map +1 -1
  374. package/js/x-modules/facets/components/lists/filters-list.vue.js.map +1 -1
  375. package/js/x-modules/facets/components/lists/filters-search.vue.js.map +1 -1
  376. package/js/x-modules/facets/components/lists/filters-search.vue3.js +1 -1
  377. package/js/x-modules/facets/components/lists/selected-filters-list.vue.js.map +1 -1
  378. package/js/x-modules/facets/components/lists/sliced-filters.vue.js +20 -4
  379. package/js/x-modules/facets/components/lists/sliced-filters.vue.js.map +1 -1
  380. package/js/x-modules/history-queries/components/clear-history-queries.vue.js +5 -1
  381. package/js/x-modules/history-queries/components/clear-history-queries.vue.js.map +1 -1
  382. package/js/x-modules/history-queries/components/history-queries.vue.js.map +1 -1
  383. package/js/x-modules/history-queries/components/history-query.vue.js +5 -1
  384. package/js/x-modules/history-queries/components/history-query.vue.js.map +1 -1
  385. package/js/x-modules/history-queries/components/my-history.vue.js +3 -3
  386. package/js/x-modules/history-queries/components/my-history.vue.js.map +1 -1
  387. package/js/x-modules/history-queries/components/remove-history-query.vue.js.map +1 -1
  388. package/js/x-modules/identifier-results/components/identifier-result.vue.js.map +1 -1
  389. package/js/x-modules/identifier-results/components/identifier-results.vue.js.map +1 -1
  390. package/js/x-modules/next-queries/components/next-queries.vue.js.map +1 -1
  391. package/js/x-modules/next-queries/components/next-query-preview.vue.js.map +1 -1
  392. package/js/x-modules/next-queries/components/next-query.vue.js.map +1 -1
  393. package/js/x-modules/popular-searches/components/popular-search.vue.js.map +1 -1
  394. package/js/x-modules/popular-searches/components/popular-searches.vue.js.map +1 -1
  395. package/js/x-modules/queries-preview/components/query-preview-button.vue.js.map +1 -1
  396. package/js/x-modules/queries-preview/components/query-preview-list.vue.js.map +1 -1
  397. package/js/x-modules/queries-preview/components/query-preview.vue.js.map +1 -1
  398. package/js/x-modules/query-suggestions/components/query-suggestion.vue.js.map +1 -1
  399. package/js/x-modules/query-suggestions/components/query-suggestions.vue.js.map +1 -1
  400. package/js/x-modules/recommendations/components/recommendations.vue.js.map +1 -1
  401. package/js/x-modules/related-prompts/components/related-prompt.vue.js.map +1 -1
  402. package/js/x-modules/related-prompts/components/related-prompts-tag-list.vue.js.map +1 -1
  403. package/js/x-modules/related-tags/components/related-tag.vue.js.map +1 -1
  404. package/js/x-modules/related-tags/components/related-tags.vue.js +3 -3
  405. package/js/x-modules/related-tags/components/related-tags.vue.js.map +1 -1
  406. package/js/x-modules/scroll/components/main-scroll-item.vue.js.map +1 -1
  407. package/js/x-modules/scroll/components/scroll-to-top.vue.js.map +1 -1
  408. package/js/x-modules/scroll/components/scroll.vue.js.map +1 -1
  409. package/js/x-modules/search/components/banner.vue.js.map +1 -1
  410. package/js/x-modules/search/components/fallback-disclaimer.vue.js.map +1 -1
  411. package/js/x-modules/search/components/partial-query-button.vue.js.map +1 -1
  412. package/js/x-modules/search/components/partial-results-list.vue.js.map +1 -1
  413. package/js/x-modules/search/components/promoted.vue.js.map +1 -1
  414. package/js/x-modules/search/components/redirection.vue.js.map +1 -1
  415. package/js/x-modules/search/components/sort-dropdown.vue.js.map +1 -1
  416. package/js/x-modules/search/components/sort-list.vue.js.map +1 -1
  417. package/js/x-modules/search/components/sort-picker-list.vue.js.map +1 -1
  418. package/js/x-modules/search/components/spellcheck-button.vue.js.map +1 -1
  419. package/js/x-modules/search/components/spellcheck.vue.js.map +1 -1
  420. package/js/x-modules/search-box/components/clear-search-input.vue.js +5 -1
  421. package/js/x-modules/search-box/components/clear-search-input.vue.js.map +1 -1
  422. package/js/x-modules/search-box/components/search-button.vue.js +7 -8
  423. package/js/x-modules/search-box/components/search-button.vue.js.map +1 -1
  424. package/js/x-modules/search-box/components/search-input-placeholder.vue.js.map +1 -1
  425. package/js/x-modules/search-box/components/search-input.vue.js.map +1 -1
  426. package/js/x-modules/semantic-queries/components/semantic-queries.vue.js +3 -3
  427. package/js/x-modules/semantic-queries/components/semantic-queries.vue.js.map +1 -1
  428. package/js/x-modules/semantic-queries/components/semantic-query.vue.js.map +1 -1
  429. package/package.json +11 -11
  430. package/report/x-components.api.json +6216 -1603
  431. package/report/x-components.api.md +819 -647
  432. package/types/components/animations/animate-width.vue.d.ts +1 -1
  433. package/types/components/animations/change-height.vue.d.ts +2 -2
  434. package/types/components/animations/collapse-height.vue.d.ts +5 -5
  435. package/types/components/animations/collapse-width.vue.d.ts +5 -5
  436. package/types/components/animations/cross-fade.vue.d.ts +4 -4
  437. package/types/components/animations/fade-and-slide.vue.d.ts +5 -5
  438. package/types/components/animations/fade.vue.d.ts +4 -4
  439. package/types/components/animations/no-animation.vue.d.ts +2 -2
  440. package/types/components/animations/staggered-fade-and-slide.vue.d.ts +5 -5
  441. package/types/components/animations/staggered-fade-and-slide.vue.d.ts.map +1 -1
  442. package/types/components/auto-progress-bar.vue.d.ts +5 -5
  443. package/types/components/base-dropdown.vue.d.ts +12 -12
  444. package/types/components/base-event-button.vue.d.ts +5 -5
  445. package/types/components/base-grid.vue.d.ts +9 -7
  446. package/types/components/base-grid.vue.d.ts.map +1 -1
  447. package/types/components/base-keyboard-navigation.vue.d.ts +6 -6
  448. package/types/components/base-rating.vue.d.ts +7 -5
  449. package/types/components/base-rating.vue.d.ts.map +1 -1
  450. package/types/components/base-slider.vue.d.ts +7 -7
  451. package/types/components/base-switch.vue.d.ts +6 -6
  452. package/types/components/base-teleport.vue.d.ts +6 -6
  453. package/types/components/base-variable-column-grid.vue.d.ts +7 -5
  454. package/types/components/base-variable-column-grid.vue.d.ts.map +1 -1
  455. package/types/components/column-picker/base-column-picker-dropdown.vue.d.ts +8 -6
  456. package/types/components/column-picker/base-column-picker-dropdown.vue.d.ts.map +1 -1
  457. package/types/components/column-picker/base-column-picker-list.vue.d.ts +7 -5
  458. package/types/components/column-picker/base-column-picker-list.vue.d.ts.map +1 -1
  459. package/types/components/currency/base-currency.vue.d.ts +4 -4
  460. package/types/components/display-click-provider.vue.d.ts +5 -5
  461. package/types/components/display-emitter.vue.d.ts +4 -4
  462. package/types/components/filters/labels/base-price-filter-label.vue.d.ts +6 -4
  463. package/types/components/filters/labels/base-price-filter-label.vue.d.ts.map +1 -1
  464. package/types/components/filters/labels/base-rating-filter-label.vue.d.ts +7 -5
  465. package/types/components/filters/labels/base-rating-filter-label.vue.d.ts.map +1 -1
  466. package/types/components/global-x-bus.vue.d.ts +3 -3
  467. package/types/components/highlight.vue.d.ts +5 -5
  468. package/types/components/items-list.vue.d.ts +5 -5
  469. package/types/components/layouts/fixed-header-and-asides-layout.vue.d.ts +9 -5
  470. package/types/components/layouts/fixed-header-and-asides-layout.vue.d.ts.map +1 -1
  471. package/types/components/layouts/multi-column-max-width-layout.vue.d.ts +9 -5
  472. package/types/components/layouts/multi-column-max-width-layout.vue.d.ts.map +1 -1
  473. package/types/components/layouts/single-column-layout.vue.d.ts +10 -5
  474. package/types/components/layouts/single-column-layout.vue.d.ts.map +1 -1
  475. package/types/components/location-provider.vue.d.ts +4 -4
  476. package/types/components/modals/base-events-modal-close.vue.d.ts +7 -5
  477. package/types/components/modals/base-events-modal-close.vue.d.ts.map +1 -1
  478. package/types/components/modals/base-events-modal-open.vue.d.ts +7 -5
  479. package/types/components/modals/base-events-modal-open.vue.d.ts.map +1 -1
  480. package/types/components/modals/base-events-modal.vue.d.ts +10 -8
  481. package/types/components/modals/base-events-modal.vue.d.ts.map +1 -1
  482. package/types/components/modals/base-id-modal-close.vue.d.ts +4 -4
  483. package/types/components/modals/base-id-modal-open.vue.d.ts +4 -4
  484. package/types/components/modals/base-id-modal.vue.d.ts +8 -6
  485. package/types/components/modals/base-id-modal.vue.d.ts.map +1 -1
  486. package/types/components/modals/base-modal.vue.d.ts +9 -9
  487. package/types/components/modals/close-main-modal.vue.d.ts +3 -1
  488. package/types/components/modals/close-main-modal.vue.d.ts.map +1 -1
  489. package/types/components/modals/main-modal.vue.d.ts +6 -4
  490. package/types/components/modals/main-modal.vue.d.ts.map +1 -1
  491. package/types/components/modals/open-main-modal.vue.d.ts +3 -1
  492. package/types/components/modals/open-main-modal.vue.d.ts.map +1 -1
  493. package/types/components/page-loader-button.vue.d.ts +7 -5
  494. package/types/components/page-loader-button.vue.d.ts.map +1 -1
  495. package/types/components/page-selector.vue.d.ts +5 -5
  496. package/types/components/panels/base-header-toggle-panel.vue.d.ts +9 -7
  497. package/types/components/panels/base-header-toggle-panel.vue.d.ts.map +1 -1
  498. package/types/components/panels/base-id-toggle-panel-button.vue.d.ts +7 -5
  499. package/types/components/panels/base-id-toggle-panel-button.vue.d.ts.map +1 -1
  500. package/types/components/panels/base-id-toggle-panel.vue.d.ts +8 -6
  501. package/types/components/panels/base-id-toggle-panel.vue.d.ts.map +1 -1
  502. package/types/components/panels/base-tabs-panel.vue.d.ts +6 -6
  503. package/types/components/panels/base-toggle-panel.vue.d.ts +4 -4
  504. package/types/components/result/base-result-add-to-cart.vue.d.ts +6 -4
  505. package/types/components/result/base-result-add-to-cart.vue.d.ts.map +1 -1
  506. package/types/components/result/base-result-current-price.vue.d.ts +6 -4
  507. package/types/components/result/base-result-current-price.vue.d.ts.map +1 -1
  508. package/types/components/result/base-result-image.vue.d.ts +9 -9
  509. package/types/components/result/base-result-link.vue.d.ts +5 -5
  510. package/types/components/result/base-result-previous-price.vue.d.ts +5 -3
  511. package/types/components/result/base-result-previous-price.vue.d.ts.map +1 -1
  512. package/types/components/result/base-result-rating.vue.d.ts +7 -5
  513. package/types/components/result/base-result-rating.vue.d.ts.map +1 -1
  514. package/types/components/result/result-variant-selector.vue.d.ts +6 -6
  515. package/types/components/result/result-variants-provider.vue.d.ts +5 -5
  516. package/types/components/scroll/base-scroll.vue.d.ts +7 -7
  517. package/types/components/sliding-panel.vue.d.ts +8 -8
  518. package/types/components/snippet-callbacks.vue.d.ts +3 -1
  519. package/types/components/snippet-callbacks.vue.d.ts.map +1 -1
  520. package/types/components/suggestions/base-suggestion.vue.d.ts +8 -6
  521. package/types/components/suggestions/base-suggestion.vue.d.ts.map +1 -1
  522. package/types/components/suggestions/base-suggestions.vue.d.ts +5 -5
  523. package/types/directives/infinite-scroll.d.ts.map +1 -1
  524. package/types/directives/typing.d.ts +1 -2
  525. package/types/directives/typing.d.ts.map +1 -1
  526. package/types/x-modules/ai/components/ai-overview.vue.d.ts +22 -8
  527. package/types/x-modules/ai/components/ai-overview.vue.d.ts.map +1 -1
  528. package/types/x-modules/device/components/device-detector.vue.d.ts +9 -5
  529. package/types/x-modules/device/components/device-detector.vue.d.ts.map +1 -1
  530. package/types/x-modules/empathize/components/empathize.vue.d.ts +6 -6
  531. package/types/x-modules/experience-controls/components/experience-controls.vue.d.ts +1 -1
  532. package/types/x-modules/extra-params/components/extra-params.vue.d.ts +3 -3
  533. package/types/x-modules/extra-params/components/renderless-extra-param.vue.d.ts +4 -4
  534. package/types/x-modules/extra-params/components/snippet-config-extra-params.vue.d.ts +8 -6
  535. package/types/x-modules/extra-params/components/snippet-config-extra-params.vue.d.ts.map +1 -1
  536. package/types/x-modules/facets/components/clear-filters.vue.d.ts +7 -5
  537. package/types/x-modules/facets/components/clear-filters.vue.d.ts.map +1 -1
  538. package/types/x-modules/facets/components/facets/facets-provider.vue.d.ts +4 -4
  539. package/types/x-modules/facets/components/facets/facets.vue.d.ts +5 -5
  540. package/types/x-modules/facets/components/filters/all-filter.vue.d.ts +6 -4
  541. package/types/x-modules/facets/components/filters/all-filter.vue.d.ts.map +1 -1
  542. package/types/x-modules/facets/components/filters/editable-number-range-filter.vue.d.ts +7 -7
  543. package/types/x-modules/facets/components/filters/hierarchical-filter.vue.d.ts +8 -5
  544. package/types/x-modules/facets/components/filters/hierarchical-filter.vue.d.ts.map +1 -1
  545. package/types/x-modules/facets/components/filters/number-range-filter.vue.d.ts +7 -5
  546. package/types/x-modules/facets/components/filters/number-range-filter.vue.d.ts.map +1 -1
  547. package/types/x-modules/facets/components/filters/renderless-filter.vue.d.ts +5 -5
  548. package/types/x-modules/facets/components/filters/simple-filter.vue.d.ts +7 -5
  549. package/types/x-modules/facets/components/filters/simple-filter.vue.d.ts.map +1 -1
  550. package/types/x-modules/facets/components/lists/exclude-filters-with-no-results.vue.d.ts +4 -4
  551. package/types/x-modules/facets/components/lists/filters-list.vue.d.ts +5 -5
  552. package/types/x-modules/facets/components/lists/filters-search.vue.d.ts +6 -6
  553. package/types/x-modules/facets/components/lists/selected-filters-list.vue.d.ts +7 -5
  554. package/types/x-modules/facets/components/lists/selected-filters-list.vue.d.ts.map +1 -1
  555. package/types/x-modules/facets/components/lists/selected-filters.vue.d.ts +5 -5
  556. package/types/x-modules/facets/components/lists/sliced-filters.vue.d.ts +6 -6
  557. package/types/x-modules/facets/components/lists/sorted-filters.vue.d.ts +4 -4
  558. package/types/x-modules/facets/components/preselected-filters.vue.d.ts +5 -5
  559. package/types/x-modules/history-queries/components/clear-history-queries.vue.d.ts +3 -1
  560. package/types/x-modules/history-queries/components/clear-history-queries.vue.d.ts.map +1 -1
  561. package/types/x-modules/history-queries/components/history-queries-switch.vue.d.ts +3 -1
  562. package/types/x-modules/history-queries/components/history-queries-switch.vue.d.ts.map +1 -1
  563. package/types/x-modules/history-queries/components/history-queries.vue.d.ts +4 -1
  564. package/types/x-modules/history-queries/components/history-queries.vue.d.ts.map +1 -1
  565. package/types/x-modules/history-queries/components/history-query.vue.d.ts +8 -5
  566. package/types/x-modules/history-queries/components/history-query.vue.d.ts.map +1 -1
  567. package/types/x-modules/history-queries/components/my-history.vue.d.ts +8 -5
  568. package/types/x-modules/history-queries/components/my-history.vue.d.ts.map +1 -1
  569. package/types/x-modules/history-queries/components/remove-history-query.vue.d.ts +6 -4
  570. package/types/x-modules/history-queries/components/remove-history-query.vue.d.ts.map +1 -1
  571. package/types/x-modules/identifier-results/components/identifier-result.vue.d.ts +4 -4
  572. package/types/x-modules/identifier-results/components/identifier-results.vue.d.ts +5 -5
  573. package/types/x-modules/next-queries/components/next-queries-list.vue.d.ts +5 -5
  574. package/types/x-modules/next-queries/components/next-queries.vue.d.ts +8 -5
  575. package/types/x-modules/next-queries/components/next-queries.vue.d.ts.map +1 -1
  576. package/types/x-modules/next-queries/components/next-query-preview.vue.d.ts +4 -4
  577. package/types/x-modules/next-queries/components/next-query.vue.d.ts +7 -5
  578. package/types/x-modules/next-queries/components/next-query.vue.d.ts.map +1 -1
  579. package/types/x-modules/popular-searches/components/popular-search.vue.d.ts +6 -4
  580. package/types/x-modules/popular-searches/components/popular-search.vue.d.ts.map +1 -1
  581. package/types/x-modules/popular-searches/components/popular-searches.vue.d.ts +4 -1
  582. package/types/x-modules/popular-searches/components/popular-searches.vue.d.ts.map +1 -1
  583. package/types/x-modules/queries-preview/components/query-preview-button.vue.d.ts +6 -4
  584. package/types/x-modules/queries-preview/components/query-preview-button.vue.d.ts.map +1 -1
  585. package/types/x-modules/queries-preview/components/query-preview-list.vue.d.ts +8 -6
  586. package/types/x-modules/queries-preview/components/query-preview-list.vue.d.ts.map +1 -1
  587. package/types/x-modules/queries-preview/components/query-preview.vue.d.ts +6 -6
  588. package/types/x-modules/query-suggestions/components/query-suggestion.vue.d.ts +6 -4
  589. package/types/x-modules/query-suggestions/components/query-suggestion.vue.d.ts.map +1 -1
  590. package/types/x-modules/query-suggestions/components/query-suggestions.vue.d.ts +4 -1
  591. package/types/x-modules/query-suggestions/components/query-suggestions.vue.d.ts.map +1 -1
  592. package/types/x-modules/recommendations/components/recommendations.vue.d.ts +5 -5
  593. package/types/x-modules/related-prompts/components/related-prompt.vue.d.ts +9 -4
  594. package/types/x-modules/related-prompts/components/related-prompt.vue.d.ts.map +1 -1
  595. package/types/x-modules/related-prompts/components/related-prompts-list.vue.d.ts +5 -5
  596. package/types/x-modules/related-prompts/components/related-prompts-tag-list.vue.d.ts +11 -7
  597. package/types/x-modules/related-prompts/components/related-prompts-tag-list.vue.d.ts.map +1 -1
  598. package/types/x-modules/related-tags/components/related-tag.vue.d.ts +6 -6
  599. package/types/x-modules/related-tags/components/related-tags.vue.d.ts +7 -5
  600. package/types/x-modules/related-tags/components/related-tags.vue.d.ts.map +1 -1
  601. package/types/x-modules/scroll/components/main-scroll-item.vue.d.ts +6 -6
  602. package/types/x-modules/scroll/components/main-scroll.vue.d.ts +5 -5
  603. package/types/x-modules/scroll/components/scroll-to-top.vue.d.ts +7 -5
  604. package/types/x-modules/scroll/components/scroll-to-top.vue.d.ts.map +1 -1
  605. package/types/x-modules/scroll/components/scroll.vue.d.ts +8 -6
  606. package/types/x-modules/scroll/components/scroll.vue.d.ts.map +1 -1
  607. package/types/x-modules/search/components/banner.vue.d.ts +5 -5
  608. package/types/x-modules/search/components/banners-list.vue.d.ts +5 -5
  609. package/types/x-modules/search/components/fallback-disclaimer.vue.d.ts +1 -1
  610. package/types/x-modules/search/components/partial-query-button.vue.d.ts +5 -5
  611. package/types/x-modules/search/components/partial-results-list.vue.d.ts +5 -5
  612. package/types/x-modules/search/components/promoted.vue.d.ts +4 -4
  613. package/types/x-modules/search/components/promoteds-list.vue.d.ts +5 -5
  614. package/types/x-modules/search/components/redirection.vue.d.ts +6 -6
  615. package/types/x-modules/search/components/results-list.vue.d.ts +6 -6
  616. package/types/x-modules/search/components/sort-dropdown.vue.d.ts +8 -6
  617. package/types/x-modules/search/components/sort-dropdown.vue.d.ts.map +1 -1
  618. package/types/x-modules/search/components/sort-list.vue.d.ts +7 -5
  619. package/types/x-modules/search/components/sort-list.vue.d.ts.map +1 -1
  620. package/types/x-modules/search/components/sort-picker-list.vue.d.ts +7 -5
  621. package/types/x-modules/search/components/sort-picker-list.vue.d.ts.map +1 -1
  622. package/types/x-modules/search/components/spellcheck-button.vue.d.ts +2 -2
  623. package/types/x-modules/search/components/spellcheck.vue.d.ts +1 -1
  624. package/types/x-modules/search-box/components/clear-search-input.vue.d.ts +7 -1
  625. package/types/x-modules/search-box/components/clear-search-input.vue.d.ts.map +1 -1
  626. package/types/x-modules/search-box/components/search-button.vue.d.ts +2 -2
  627. package/types/x-modules/search-box/components/search-input-placeholder.vue.d.ts +6 -6
  628. package/types/x-modules/search-box/components/search-input.vue.d.ts +6 -6
  629. package/types/x-modules/semantic-queries/components/semantic-queries.vue.d.ts +4 -1
  630. package/types/x-modules/semantic-queries/components/semantic-queries.vue.d.ts.map +1 -1
  631. package/types/x-modules/semantic-queries/components/semantic-query.vue.d.ts +6 -4
  632. package/types/x-modules/semantic-queries/components/semantic-query.vue.d.ts.map +1 -1
  633. package/types/x-modules/tagging/components/tagging.vue.d.ts +4 -4
  634. package/types/x-modules/url/components/url-handler.vue.d.ts +5 -1
  635. package/types/x-modules/url/components/url-handler.vue.d.ts.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"facets.vue.js","sources":["../../../../../../src/x-modules/facets/components/facets/facets.vue"],"sourcesContent":["<template>\n <component :is=\"animation\" v-if=\"hasFacets\" class=\"x-facets-list\" data-test=\"facets\" tag=\"ul\">\n <li\n v-for=\"({ facet, slotNameById, slotNameByModelName }, facetId) in mappedFacets\"\n :key=\"facetId\"\n class=\"x-facets-list__item\"\n data-test=\"facets-facet\"\n >\n <!--\n @slot Customized Facet rendering. Specifying a slot with the facet's name will result in the\n facet using that slot composition to render.\n @binding {Facet} facet - Facet to render\n @binding {Filter[]} selectedFilters - List of selected filters of the given facet\n -->\n <slot\n v-if=\"hasSlot(slotNameById)\"\n v-bind=\"{\n facet,\n selectedFilters: selectedFiltersByFacet[facetId] || [],\n }\"\n :name=\"slotNameById\"\n />\n <!--\n @slot Customized Facet rendering. Specifying a slot with the facet's modelName will result\n in the facet using that slot composition to render.\n @binding {Facet} facet - Facet to render\n @binding {Filter[]} selectedFilters - List of selected filters of the given facet\n -->\n <slot\n v-else-if=\"hasSlot(slotNameByModelName)\"\n v-bind=\"{\n facet,\n selectedFilters: selectedFiltersByFacet[facetId] || [],\n }\"\n :name=\"slotNameByModelName\"\n />\n <!--\n @slot (required) Default Facet rendering. This slot will be used by default for rendering\n the facets without an specific slot implementation.\n @binding {Facet} facet - Facet to render\n @binding {Filter[]} selectedFilters - List of selected filters of the given facet\n -->\n <slot\n v-else\n v-bind=\"{\n facet,\n selectedFilters: selectedFiltersByFacet[facetId] || [],\n }\"\n >\n This is the {{ facet.label }} facet. Pass something into its slot to display content.\n </slot>\n </li>\n </component>\n</template>\n\n<script lang=\"ts\">\nimport type { Facet } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport { map, objectFilter } from '@empathyco/x-utils'\nimport { computed, defineComponent } from 'vue'\nimport { useGetter } from '../../../../composables/use-getter'\nimport { AnimationProp } from '../../../../types'\nimport { toKebabCase } from '../../../../utils/string'\nimport { useFacets } from '../../composables/use-facets'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Custom interface to provide a slot name to a Facet.\n *\n * @internal\n */\ninterface RenderFacet {\n slotNameById: string\n slotNameByModelName: string\n facet: Facet\n}\n\n/**\n * This component renders the list of facets stored in the Facets module. Facets can be rendered\n * differently based on their purpose and this can be achieved using the exposed slots:\n * - A default and required slot.\n * - A custom slot for each facet with the facetId as its name. This allows each facet to be\n * rendered differently based on its needs.\n *\n * @public\n */\nexport default defineComponent({\n name: 'Facets',\n xModule: facetsXModule.name,\n props: {\n /** Array of facets ids used to get the selected filters for those facets. */\n facetsIds: Array as PropType<Array<Facet['id']>>,\n /** Flag to render the component even if there are no filters selected. */\n alwaysVisible: Boolean,\n /** Animation component that will be used to animate the facets. */\n animation: {\n type: AnimationProp,\n default: 'ul',\n },\n /**\n * Discriminates the facets rendered by this component. It expects a string containing facets\n * ids, comma separated. This property will include or exclude facets based on its value.\n * The default value is an empty string and the component will render all existing facets.\n *\n * @remarks\n * To behave as a `include`, simply set the facets ids, comma separated:\n * `existingFacets=[{ brand: ... }, category: { ... }, color: { ... }, price: { ... }]`\n * `renderableFacets=\"brand, category\"`\n *\n * The component will render brand and category facets.\n *\n * On the other hand, to simulate an `exclude` behaviour and exclude a facet from being\n * rendered, append a '!' before its id:\n * `existingFacets=[{ brand: ... }, category: { ... }, color: { ... }, price: { ... }]`\n * `renderableFacets=\"!brand,!price\"`\n *\n * The component will render category and color facets.\n */\n renderableFacets: String,\n },\n setup(props, { slots }) {\n const { selectedFiltersByFacet } = useFacets(props)\n const { facets } = useGetter('facets')\n\n /**\n * The facets to be rendered after filtering {@link Facets.facets} by\n * {@link Facets.renderableFacets} content.\n *\n * @returns The list of facets to be rendered.\n */\n const facetsToRender = computed<Dictionary<Facet>>(() => {\n if (!props.renderableFacets) {\n return facets.value\n } else {\n const excludedRegExp = /^!/\n const facetIds: string[] = props.renderableFacets.split(',').map(facetId => facetId.trim())\n const included: string[] = []\n const excluded: string[] = []\n facetIds.forEach(facetId => {\n if (excludedRegExp.test(facetId)) {\n excluded.push(facetId.replace(excludedRegExp, ''))\n } else {\n included.push(facetId)\n }\n })\n\n return filterFacetsToRender(included, excluded)\n }\n })\n\n /**\n * Transforms a dictionary of Facets including the slot name.\n *\n * @returns A dictionary of facets with the slot name.\n */\n const mappedFacets = computed<Dictionary<RenderFacet>>(() => {\n return map(facetsToRender.value, (facetId, facet) => ({\n slotNameById: toKebabCase(facetId),\n slotNameByModelName: toKebabCase(facet.modelName),\n facet,\n }))\n })\n\n /**\n * Indicates if there are facets available to show.\n *\n * @returns True if there are facets available and false otherwise.\n */\n const hasFacets = computed<boolean>(() => !!Object.keys(facetsToRender.value).length)\n\n /**\n * Filter facets dictionary retrieving those included and/or removing excluded.\n *\n * @param included - List of facets to render.\n * @param excluded - List of not renderable facets.\n *\n * @returns The filtered list of facets to render.\n */\n function filterFacetsToRender(included: string[], excluded: string[]): Dictionary<Facet> {\n const hasAnyFacetIncluded = included.length > 0\n return objectFilter(facets.value, facetKey => {\n const isIncluded = included.includes(String(facetKey))\n const isExcluded = excluded.includes(String(facetKey))\n\n return hasAnyFacetIncluded ? isIncluded && !isExcluded : !isExcluded\n })\n }\n\n /**\n * Whether the slot is present in the template or not.\n *\n * @param name - The slot name.\n *\n * @returns True is the slot is present in the template. False otherwise.\n */\n function hasSlot(name: string): boolean {\n return !!slots[name]\n }\n\n return {\n selectedFiltersByFacet,\n hasFacets,\n mappedFacets,\n hasSlot,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-facets-list {\n display: flex;\n flex-flow: column nowrap;\n list-style-type: none;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Example\n\nThis component renders the list of facets stored in the Facets module. Facets can be rendered\ndifferently based on their purpose and this can be achieved using the exposed slots:\n\n- A default and required slot.\n- A custom slot for each facet with the facetId as its name. This allows each facet to be rendered\n differently based on its needs.\n\nBelow, there are some examples showing how to use the component with its different configurations.\n\n### Default usage\n\nThe default slot of this component is mandatory. If no other slot is defined, every Facet will be\nrendered as specified in the default slot.\n\n```vue\n<template>\n <Facets>\n <template #default=\"{ facet, selectedFilters }\">\n <h1>{{ ${facet.label} }}</h1>\n <span v-if=\"selectedFilters.length > 0\">{{ `${selectedFilters.length} selected` }}</span>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Customized usage\n\nCustomized compositions for a specific Facet can be achieved by using a slot with the same id as the\nfacet to customize. For example, the Facet with the id \"color\" requires a composition that differs\nfrom the rest of the Facets. Doing it in a slot with the name \"color\" will apply this customization\njust to the \"color\" Facet. The other facets will fallback to the composition of the default slot.\n\nIt is also possible to customize the Facet content by the facet \"model name\". For example, to\nconfigure different content for \"Hierarchical Facets\" the \"hierarchical-facet\" slot will apply that\ncustomization. This can be combined with the facets by facet id. If some hierarchical facet needs\nsome different customization from the rest of the hierarchical, it can be achieve using the slot\nwith the facet id.\n\n```vue\n<template>\n <Facets>\n <template #color=\"{ facet, selectedFilters }\">\n <span v-if=\"selectedFilters.length > 0\">{{ `${selectedFilters.length} colors chosen` }}</span>\n\n <ul v-for=\"filter in facet.filters\" :key=\"filter.id\">\n <li v-if=\"!filter.selected\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n\n <template #hierarchical-facet=\"{ facet, selectedFilters }\">\n <span v-if=\"selectedFilters.length > 0\">{{ `${selectedFilters.length} colors chosen` }}</span>\n\n <ul v-for=\"filter in facet.filters\" :key=\"filter.id\">\n <li v-if=\"!filter.selected\">\n {{ filter.label }}\n <ul v-for=\"childFilter in filter.children\" :key=\"filter.id\">\n <li v-if=\"!childFilter.selected\">\n {{ childFilter.label }}\n </li>\n </ul>\n </li>\n </ul>\n </template>\n\n <template #default=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Render specific facets I\n\nBy default, this component will render all existing facets. However, it has the renderableFacets\nprop to filter which facets will be rendered. Its value is a string containing the different facets\nids. This value is treated as an include or exclude list (to exclude a facet from being rendered,\njust prefix its id with a `!`). The component will only render included facets and discard excluded\nones. In the following example, the component will only render color and category facets.\n\n```vue\n<template>\n <Facets renderableFacets=\"color, category\">\n <template #default=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Render specific facets II\n\nExclude facets so the component does not render them. In the following example, the component will\nrender every facet except color and price.\n\n```vue\n<template>\n <Facets renderableFacets=\"!color, !price\">\n <template #default=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Integrating with the filters components\n\nThere are many components that will help you build your own awesome filters list. `Facets` just\nrenders the list, but what to render for each facet is up to you. Below you can see an example. of\nthe `Facets` component using the `FiltersSearch` `MultiSelectFilters`, `SimpleFilter`, `Filters`,\n`HierarchicalFilter`, `NumberRangeFilter` and `BasePriceFilterLabel`.\n\n```vue\n<template>\n <Facets>\n <template #default=\"{ facet, selectedFilters }\">\n <h1>{{ facet.label }}</h1>\n <FiltersSearch :filters=\"facet.filters\">\n <MultiSelectFilters v-slot=\"{ filter }\">\n <SimpleFilter :filter=\"filter\" />\n </MultiSelectFilters>\n </FiltersSearch>\n </template>\n\n <template #category=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <HierarchicalFilter :filter=\"filter\" />\n </Filters>\n </template>\n\n <template #price=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <NumberRangeFilter :filter=\"filter\">\n <BasePriceFilterLabel :filter=\"filter\" />\n </NumberRangeFilter>\n </Filters>\n </template>\n </Facets>\n</template>\n\n<script>\nimport {\n Facets,\n Filters,\n FiltersSearch,\n HierarchicalFilter,\n MultiSelectFilters,\n NumberRangeFilter,\n SimpleFilter,\n} from '@empathyco/x-components/facets'\n\nimport { BasePriceFilterLabel } from '@empathyco/x-components'\n\nexport default {\n components: {\n Facets,\n MultiSelectFilters,\n FiltersSearch,\n SimpleFilter,\n Filters,\n HierarchicalFilter,\n NumberRangeFilter,\n BasePriceFilterLabel,\n },\n}\n</script>\n```\n</docs>\n"],"names":["_openBlock","_createBlock","_resolveDynamicComponent","_withCtx","_createElementBlock","_Fragment","_renderList","_renderSlot","_mergeProps","_createTextVNode","_toDisplayString","_createCommentVNode"],"mappings":";;;;;;SACmC,IAAjC,CAAA,SAAA,IAAAA,SAAA,EAAA,EAAAC,WAAA,CAmDYC,wBAnDI,IAAS,CAAA,SAAA,CAAA,EAAA;AAAA,IAD3B,GAAA,EAAA,CAAA;AAAA,IAC8C,KAAM,EAAA,eAAA;AAAA,IAAgB,WAAU,EAAA,QAAA;AAAA,IAAS,GAAI,EAAA,IAAA;AAAA,GAAA,EAAA;AAD3F,IAAA,OAAA,EAAAC,OAAA,CAGM,MAA+E;AAAA,OADjFH,SAAA,CAAA,IAAA,CAAA,EAAAI,kBAAA;AAAA,QAiDKC,QAAA;AAAA,QAAA,IAAA;AAAA,QAnDTC,WAGwE,IAHxE,CAAA,YAAA,EAAA,CAAA,EAGgB,OAAO,YAAc,EAAA,mBAAA,IAAuB,OAAO,KAAA;8BAD/DF,kBAiDK,CAAA,IAAA,EAAA;AAAA,YA/CF,GAAK,EAAA,OAAA;AAAA,YACN,KAAM,EAAA,qBAAA;AAAA,YACN,WAAU,EAAA,cAAA;AAAA,WAAA,EAAA;AASF,YAAA,IAAA,CAAA,OAAA,CAAQ,YAAY,CAAA,GAD5BG,UAOE,CAAA,IAAA,CAAA,MAAA,EADO,cANTC,UAOE,CAAA;AAAA,cArBR,GAAA,EAAA,CAAA;AAAA,cAAA,OAAA,EAAA,IAAA;AAAA,aAAA,EAAA;AAgB4B,cAAA,KAAA;AAAA,cAAA,eAAA,EAAkC,4BAAuB,OAAO,CAAA,IAAA,EAAA;AAAA,aAAA,CAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA,GAazE,aAAQ,mBAAmB,CAAA,GADxCD,UAOE,CAAA,IAAA,CAAA,MAAA,EADO,qBANTC,UAOE,CAAA;AAAA,cAnCR,GAAA,EAAA,CAAA;AAAA,cAAA,OAAA,EAAA,IAAA;AAAA,aAAA,EAAA;AA8B4B,cAAA,KAAA;AAAA,cAAA,eAAA,EAAkC,4BAAuB,OAAO,CAAA,IAAA,EAAA;AAAA,aAYtF,CAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA,GAAAD,UAAA,CAQO,wBARPC,UAQO,CAAA;AAAA,cAlDb,GAAA,EAAA,CAAA;AAAA,cAAA,OAAA,EAAA,IAAA;AAAA,aAAA,EAAA;AA4C4B,cAAA,KAAA;AAAA,cAAA,eAAA,EAAkC,4BAAuB,OAAO,CAAA,IAAA,EAAA;AAAA,aAAA,CAAA,EAFtF,MAQO;AAAA,cAlDbC,eAAA;AAAA,gBAgDO,eACa,GAAAC,eAAA,CAAG,KAAM,CAAA,KAAK,CAAG,GAAA,2DAAA;AAAA,gBAC/B,CAAA;AAAA;AAAA,eAAA;AAAA,aAAA,EAAA,IAAA,CAAA;;;;;;;AAlDN,IAAA,CAAA,EAAA,CAAA;AAAA;AAAA,GAAA,CAAA,IAAAC,kBAAA,CAAA,MAAA,EAAA,IAAA,CAAA,CAAA;;;;;;"}
1
+ {"version":3,"file":"facets.vue.js","sources":["../../../../../../src/x-modules/facets/components/facets/facets.vue"],"sourcesContent":["<template>\n <component :is=\"animation\" v-if=\"hasFacets\" class=\"x-facets-list\" data-test=\"facets\" tag=\"ul\">\n <li\n v-for=\"({ facet, slotNameById, slotNameByModelName }, facetId) in mappedFacets\"\n :key=\"facetId\"\n class=\"x-facets-list__item\"\n data-test=\"facets-facet\"\n >\n <!--\n @slot Customized Facet rendering. Specifying a slot with the facet's name will result in the\n facet using that slot composition to render.\n @binding {Facet} facet - Facet to render\n @binding {Filter[]} selectedFilters - List of selected filters of the given facet\n -->\n <slot\n v-if=\"hasSlot(slotNameById)\"\n v-bind=\"{\n facet,\n selectedFilters: selectedFiltersByFacet[facetId] || [],\n }\"\n :name=\"slotNameById\"\n />\n <!--\n @slot Customized Facet rendering. Specifying a slot with the facet's modelName will result\n in the facet using that slot composition to render.\n @binding {Facet} facet - Facet to render\n @binding {Filter[]} selectedFilters - List of selected filters of the given facet\n -->\n <slot\n v-else-if=\"hasSlot(slotNameByModelName)\"\n v-bind=\"{\n facet,\n selectedFilters: selectedFiltersByFacet[facetId] || [],\n }\"\n :name=\"slotNameByModelName\"\n />\n <!--\n @slot (required) Default Facet rendering. This slot will be used by default for rendering\n the facets without an specific slot implementation.\n @binding {Facet} facet - Facet to render\n @binding {Filter[]} selectedFilters - List of selected filters of the given facet\n -->\n <slot\n v-else\n v-bind=\"{\n facet,\n selectedFilters: selectedFiltersByFacet[facetId] || [],\n }\"\n >\n This is the {{ facet.label }} facet. Pass something into its slot to display content.\n </slot>\n </li>\n </component>\n</template>\n\n<script lang=\"ts\">\nimport type { Facet } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport { map, objectFilter } from '@empathyco/x-utils'\nimport { computed, defineComponent } from 'vue'\nimport { useGetter } from '../../../../composables/use-getter'\nimport { AnimationProp } from '../../../../types'\nimport { toKebabCase } from '../../../../utils/string'\nimport { useFacets } from '../../composables/use-facets'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Custom interface to provide a slot name to a Facet.\n *\n * @internal\n */\ninterface RenderFacet {\n slotNameById: string\n slotNameByModelName: string\n facet: Facet\n}\n\n/**\n * This component renders the list of facets stored in the Facets module. Facets can be rendered\n * differently based on their purpose and this can be achieved using the exposed slots:\n * - A default and required slot.\n * - A custom slot for each facet with the facetId as its name. This allows each facet to be\n * rendered differently based on its needs.\n *\n * @public\n */\nexport default defineComponent({\n name: 'Facets',\n xModule: facetsXModule.name,\n props: {\n /** Array of facets ids used to get the selected filters for those facets. */\n facetsIds: Array as PropType<Array<Facet['id']>>,\n /** Flag to render the component even if there are no filters selected. */\n alwaysVisible: Boolean,\n /** Animation component that will be used to animate the facets. */\n animation: {\n type: AnimationProp,\n default: 'ul',\n },\n /**\n * Discriminates the facets rendered by this component. It expects a string containing facets\n * ids, comma separated. This property will include or exclude facets based on its value.\n * The default value is an empty string and the component will render all existing facets.\n *\n * @remarks\n * To behave as a `include`, simply set the facets ids, comma separated:\n * `existingFacets=[{ brand: ... }, category: { ... }, color: { ... }, price: { ... }]`\n * `renderableFacets=\"brand, category\"`\n *\n * The component will render brand and category facets.\n *\n * On the other hand, to simulate an `exclude` behaviour and exclude a facet from being\n * rendered, append a '!' before its id:\n * `existingFacets=[{ brand: ... }, category: { ... }, color: { ... }, price: { ... }]`\n * `renderableFacets=\"!brand,!price\"`\n *\n * The component will render category and color facets.\n */\n renderableFacets: String,\n },\n setup(props, { slots }) {\n const { selectedFiltersByFacet } = useFacets(props)\n const { facets } = useGetter('facets')\n\n /**\n * The facets to be rendered after filtering {@link Facets.facets} by\n * {@link Facets.renderableFacets} content.\n *\n * @returns The list of facets to be rendered.\n */\n const facetsToRender = computed<Dictionary<Facet>>(() => {\n if (!props.renderableFacets) {\n return facets.value\n } else {\n const excludedRegExp = /^!/\n const facetIds: string[] = props.renderableFacets.split(',').map(facetId => facetId.trim())\n const included: string[] = []\n const excluded: string[] = []\n facetIds.forEach(facetId => {\n if (excludedRegExp.test(facetId)) {\n excluded.push(facetId.replace(excludedRegExp, ''))\n } else {\n included.push(facetId)\n }\n })\n\n return filterFacetsToRender(included, excluded)\n }\n })\n\n /**\n * Transforms a dictionary of Facets including the slot name.\n *\n * @returns A dictionary of facets with the slot name.\n */\n const mappedFacets = computed<Dictionary<RenderFacet>>(() => {\n return map(facetsToRender.value, (facetId, facet) => ({\n slotNameById: toKebabCase(facetId),\n slotNameByModelName: toKebabCase(facet.modelName),\n facet,\n }))\n })\n\n /**\n * Indicates if there are facets available to show.\n *\n * @returns True if there are facets available and false otherwise.\n */\n const hasFacets = computed<boolean>(() => !!Object.keys(facetsToRender.value).length)\n\n /**\n * Filter facets dictionary retrieving those included and/or removing excluded.\n *\n * @param included - List of facets to render.\n * @param excluded - List of not renderable facets.\n *\n * @returns The filtered list of facets to render.\n */\n function filterFacetsToRender(included: string[], excluded: string[]): Dictionary<Facet> {\n const hasAnyFacetIncluded = included.length > 0\n return objectFilter(facets.value, facetKey => {\n const isIncluded = included.includes(String(facetKey))\n const isExcluded = excluded.includes(String(facetKey))\n\n return hasAnyFacetIncluded ? isIncluded && !isExcluded : !isExcluded\n })\n }\n\n /**\n * Whether the slot is present in the template or not.\n *\n * @param name - The slot name.\n *\n * @returns True is the slot is present in the template. False otherwise.\n */\n function hasSlot(name: string): boolean {\n return !!slots[name]\n }\n\n return {\n selectedFiltersByFacet,\n hasFacets,\n mappedFacets,\n hasSlot,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-facets-list {\n display: flex;\n flex-flow: column nowrap;\n list-style-type: none;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Example\n\nThis component renders the list of facets stored in the Facets module. Facets can be rendered\ndifferently based on their purpose and this can be achieved using the exposed slots:\n\n- A default and required slot.\n- A custom slot for each facet with the facetId as its name. This allows each facet to be rendered\n differently based on its needs.\n\nBelow, there are some examples showing how to use the component with its different configurations.\n\n### Default usage\n\nThe default slot of this component is mandatory. If no other slot is defined, every Facet will be\nrendered as specified in the default slot.\n\n```vue\n<template>\n <Facets>\n <template #default=\"{ facet, selectedFilters }\">\n <h1>{{ ${facet.label} }}</h1>\n <span v-if=\"selectedFilters.length > 0\">{{ `${selectedFilters.length} selected` }}</span>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Customized usage\n\nCustomized compositions for a specific Facet can be achieved by using a slot with the same id as the\nfacet to customize. For example, the Facet with the id \"color\" requires a composition that differs\nfrom the rest of the Facets. Doing it in a slot with the name \"color\" will apply this customization\njust to the \"color\" Facet. The other facets will fallback to the composition of the default slot.\n\nIt is also possible to customize the Facet content by the facet \"model name\". For example, to\nconfigure different content for \"Hierarchical Facets\" the \"hierarchical-facet\" slot will apply that\ncustomization. This can be combined with the facets by facet id. If some hierarchical facet needs\nsome different customization from the rest of the hierarchical, it can be achieve using the slot\nwith the facet id.\n\n```vue\n<template>\n <Facets>\n <template #color=\"{ facet, selectedFilters }\">\n <span v-if=\"selectedFilters.length > 0\">{{ `${selectedFilters.length} colors chosen` }}</span>\n\n <ul v-for=\"filter in facet.filters\" :key=\"filter.id\">\n <li v-if=\"!filter.selected\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n\n <template #hierarchical-facet=\"{ facet, selectedFilters }\">\n <span v-if=\"selectedFilters.length > 0\">{{ `${selectedFilters.length} colors chosen` }}</span>\n\n <ul v-for=\"filter in facet.filters\" :key=\"filter.id\">\n <li v-if=\"!filter.selected\">\n {{ filter.label }}\n <ul v-for=\"childFilter in filter.children\" :key=\"filter.id\">\n <li v-if=\"!childFilter.selected\">\n {{ childFilter.label }}\n </li>\n </ul>\n </li>\n </ul>\n </template>\n\n <template #default=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Render specific facets I\n\nBy default, this component will render all existing facets. However, it has the renderableFacets\nprop to filter which facets will be rendered. Its value is a string containing the different facets\nids. This value is treated as an include or exclude list (to exclude a facet from being rendered,\njust prefix its id with a `!`). The component will only render included facets and discard excluded\nones. In the following example, the component will only render color and category facets.\n\n```vue\n<template>\n <Facets renderableFacets=\"color, category\">\n <template #default=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Render specific facets II\n\nExclude facets so the component does not render them. In the following example, the component will\nrender every facet except color and price.\n\n```vue\n<template>\n <Facets renderableFacets=\"!color, !price\">\n <template #default=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n\n <ul>\n <li v-for=\"filter in facet.filters\" :key=\"filter.id\">\n {{ filter.label }}\n </li>\n </ul>\n </template>\n </Facets>\n</template>\n\n<script>\nimport { Facets } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n Facets,\n },\n}\n</script>\n```\n\n### Integrating with the filters components\n\nThere are many components that will help you build your own awesome filters list. `Facets` just\nrenders the list, but what to render for each facet is up to you. Below you can see an example. of\nthe `Facets` component using the `FiltersSearch` `MultiSelectFilters`, `SimpleFilter`, `Filters`,\n`HierarchicalFilter`, `NumberRangeFilter` and `BasePriceFilterLabel`.\n\n```vue\n<template>\n <Facets>\n <template #default=\"{ facet, selectedFilters }\">\n <h1>{{ facet.label }}</h1>\n <FiltersSearch :filters=\"facet.filters\">\n <MultiSelectFilters v-slot=\"{ filter }\">\n <SimpleFilter :filter=\"filter\" />\n </MultiSelectFilters>\n </FiltersSearch>\n </template>\n\n <template #category=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <HierarchicalFilter :filter=\"filter\" />\n </Filters>\n </template>\n\n <template #price=\"{ facet }\">\n <h1>{{ facet.label }}</h1>\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <NumberRangeFilter :filter=\"filter\">\n <BasePriceFilterLabel :filter=\"filter\" />\n </NumberRangeFilter>\n </Filters>\n </template>\n </Facets>\n</template>\n\n<script>\nimport {\n Facets,\n Filters,\n FiltersSearch,\n HierarchicalFilter,\n MultiSelectFilters,\n NumberRangeFilter,\n SimpleFilter,\n} from '@empathyco/x-components/facets'\n\nimport { BasePriceFilterLabel } from '@empathyco/x-components'\n\nexport default {\n components: {\n Facets,\n MultiSelectFilters,\n FiltersSearch,\n SimpleFilter,\n Filters,\n HierarchicalFilter,\n NumberRangeFilter,\n BasePriceFilterLabel,\n },\n}\n</script>\n```\n</docs>\n"],"names":["_openBlock","_createBlock","_resolveDynamicComponent","_createElementBlock","_Fragment","_renderList","_renderSlot","_mergeProps","_createTextVNode","_toDisplayString"],"mappings":";;;;;;SACmC,IAAjC,CAAA,SAAA,IAAAA,SAAA,EAAA,EAAAC,WAAA,CAmDYC,wBAnDI,IAAS,CAAA,SAAA,CAAA,EAAA;AAAA,IAAA,GAAA,EAAA,CAAA;IAAmB,KAAM,EAAA,eAAA;AAAA,IAAgB,WAAU,EAAA,QAAA;AAAA,IAAS,GAAI,EAAA,IAAA;AAAA,GAAA,EAAA;qBAErF,MAA+E;AAAA,OADjFF,SAAA,CAAA,IAAA,CAAA,EAAAG,kBAAA;AAAA,QAiDKC,QAAA;AAAA,QAAA,IAAA;AAAA,QAAAC,UAAA,CAhD+D,mBAAY,CAApE,EAAA,KAAA,EAAO,YAAc,EAAA,mBAAA,IAAuB,OAAO,KAAA;8BAD/DF,kBAiDK,CAAA,IAAA,EAAA;AAAA,YA/CF,GAAK,EAAA,OAAA;AAAA,YACN,KAAM,EAAA,qBAAA;AAAA,YACN,WAAU,EAAA,cAAA;AAAA,WAAA,EAAA;AASF,YAAA,IAAA,CAAA,OAAA,CAAQ,YAAY,CAAA,GAD5BG,UAOE,CAAA,IAAA,CAAA,MAAA,EADO,cANTC,UAOE,CAAA;AAAA,cAAA,GAAA,EAAA,CAAA;;;AALoB,cAAA,KAAA;AAAA,cAAA,eAAA,EAAkC,4BAAuB,OAAO,CAAA,IAAA,EAAA;AAAA,aAAA,CAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA,GAazE,aAAQ,mBAAmB,CAAA,GADxCD,UAOE,CAAA,IAAA,CAAA,MAAA,EADO,qBANTC,UAOE,CAAA;AAAA,cAAA,GAAA,EAAA,CAAA;;;AALoB,cAAA,KAAA;AAAA,cAAA,eAAA,EAAkC,4BAAuB,OAAO,CAAA,IAAA,EAAA;AAAA,aAYtF,CAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA,GAAAD,UAAA,CAQO,wBARPC,UAQO,CAAA;AAAA,cAAA,GAAA,EAAA,CAAA;;;AANe,cAAA,KAAA;AAAA,cAAA,eAAA,EAAkC,4BAAuB,OAAO,CAAA,IAAA,EAAA;AAAA,aAAA,CAAA,EAFtF,MAQO;AAAA,cAAAC,eAAA;gBAFN,eACa,GAAAC,eAAA,CAAG,KAAM,CAAA,KAAK,CAAG,GAAA,2DAAA;AAAA,gBAC/B,CAAA;AAAA;AAAA,eAAA;AAAA,aAAA,EAAA,IAAA,CAAA;;;;;;;;;;;;;;;"}
@@ -16,7 +16,11 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
16
16
  facet: _ctx.facet,
17
17
  isSelected: _ctx.isSelected
18
18
  }, () => [
19
- createTextVNode("all")
19
+ _cache[0] || (_cache[0] = createTextVNode(
20
+ "all",
21
+ -1
22
+ /* CACHED */
23
+ ))
20
24
  ])
21
25
  ]),
22
26
  _: 3
@@ -1 +1 @@
1
- {"version":3,"file":"all-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/all-filter.vue"],"sourcesContent":["<template>\n <BaseEventButton\n class=\"x-facet-filter x-all-filter\"\n data-test=\"all-filter\"\n role=\"checkbox\"\n :aria-checked=\"isSelected.toString()\"\n :events=\"clickEvent\"\n :class=\"cssClasses\"\n >\n <!--\n @slot The content to render inside the button\n @binding {Facet} Facet - The facet data\n -->\n <slot :facet=\"facet\" :is-selected=\"isSelected\">all</slot>\n </BaseEventButton>\n</template>\n\n<script lang=\"ts\">\nimport type { Facet } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { computed, defineComponent } from 'vue'\nimport BaseEventButton from '../../../../components/base-event-button.vue'\nimport { useGetter } from '../../../../composables/use-getter'\nimport { isArrayEmpty } from '../../../../utils/array'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * This component receives a required `facet` with\n * {@link @empathyco/x-types#BooleanFilter} as prop and renders a button, which\n * on clicked emits the {@link FacetsXEvents.UserClickedAllFilter} event. By default\n * the rendered button displays a message with the facet label but this content is customizable\n * through the default slot.\n *\n * @public\n */\nexport default defineComponent({\n name: 'AllFilter',\n components: {\n BaseEventButton,\n },\n xModule: facetsXModule.name,\n props: {\n /** The facet data. */\n facet: {\n type: Object as PropType<Facet>,\n required: true,\n },\n },\n setup(props) {\n /** The getter of the selectedFiltersByFacet. */\n const { selectedFiltersByFacet } = useGetter('facets')\n\n /**\n * The event that will be emitted when the all filter button is clicked.\n *\n * @returns The event to emit on click.\n * @internal\n */\n const clickEvent = computed((): Partial<XEventsTypes> => {\n return { UserClickedAllFilter: [props.facet.id] }\n })\n\n /**\n * Computed to retrieve the selected state of this component.\n *\n * @returns True if is selected false otherwise.\n */\n const isSelected = computed(() => {\n return isArrayEmpty(selectedFiltersByFacet.value?.[props.facet.id])\n })\n\n /**\n * Dynamic CSS classes to apply to the component.\n *\n * @remarks This is only valid considering that in the case of HierarchicalFilters, ancestors\n * of nested selected filters are also selected.\n *\n * @returns The dynamic CSS classes to apply to the component.\n * @internal\n */\n const cssClasses = computed(() => {\n return {\n 'x-selected x-all-filter--is-selected': isSelected.value,\n }\n })\n\n return {\n clickEvent,\n cssClasses,\n isSelected,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserClickedAllFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button. The event payload is the id of the facet\n that this `AllFilter` component corresponds to.\n\n## Examples\n\nThis component receives a required `facet` as prop and renders a button, which on clicked emits the\nUserClickedAllFilter event. By default the rendered button displays a message with the facet label\nbut this content is customizable through the default slot.\n\n### Basic usage\n\n```vue\n<AllFilter :facet=\"facet\" />\n```\n\n### Customizing its content\n\n```vue\n<AllFilter v-slot=\"{ facet }\" :facet=\"facet\">\n Select all {{ facet.label }}\n</AllFilter>\n```\n\n### Basic example within facets\n\n```vue\n<Facets>\n <template #default=\"{ facet }\">\n <AllFilter :facet=\"facet\" />\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <SimpleFilter :filter=\"filter\" />\n </Filters>\n </template>\n</Facets>\n```\n\n### Custom example within facets\n\n```vue\n<Facets>\n <template #default=\"{ facet }\">\n <AllFilter v-slot=\"{ facet }\" :facet=\"facet\">\n Select all {{ facet.label }}\n </AllFilter>\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <SimpleFilter :filter=\"filter\" />\n </Filters>\n </template>\n</Facets>\n```\n</docs>\n"],"names":["_createBlock","_normalizeClass","_withCtx","_renderSlot","_createTextVNode"],"mappings":";;;;;;sBACEA,WAakB,CAAA,0BAAA,EAAA;AAAA,IAZhB,KAAA,EAFJC,cAEU,CAAA,CAAA,6BAAA,EAKE,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,IAJlB,WAAU,EAAA,YAAA;AAAA,IACV,IAAK,EAAA,UAAA;AAAA,IACJ,cAAA,EAAc,gBAAW,QAAQ,EAAA;AAAA,IACjC,MAAQ,EAAA,IAAA,CAAA,UAAA;AAAA,GAAA,EAAA;AANb,IAAA,OAAA,EAAAC,OAAA,CAaI,MAAyD;AAAA,MAAzDC,UAAyD,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAA;AAAA,QAAlD,KAAO,EAAA,IAAA,CAAA,KAAA;AAAA,QAAQ,UAAa,EAAA,IAAA,CAAA,UAAA;AAAA,OAAA,EAAnC,MAAyD;AAAA,QAb7DC,gBAamD,KAAG,CAAA;AAAA,OAAA,CAAA;;AAbtD,IAAA,CAAA,EAAA,CAAA;AAAA;AAAA,GAAA,EAAA,CAAA,EAAA,CAAA,cAAA,EAAA,QAAA,EAAA,OAAA,CAAA,CAAA,CAAA;;;;;;"}
1
+ {"version":3,"file":"all-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/all-filter.vue"],"sourcesContent":["<template>\n <BaseEventButton\n class=\"x-facet-filter x-all-filter\"\n data-test=\"all-filter\"\n role=\"checkbox\"\n :aria-checked=\"isSelected.toString()\"\n :events=\"clickEvent\"\n :class=\"cssClasses\"\n >\n <!--\n @slot The content to render inside the button\n @binding {Facet} Facet - The facet data\n -->\n <slot :facet=\"facet\" :is-selected=\"isSelected\">all</slot>\n </BaseEventButton>\n</template>\n\n<script lang=\"ts\">\nimport type { Facet } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { computed, defineComponent } from 'vue'\nimport BaseEventButton from '../../../../components/base-event-button.vue'\nimport { useGetter } from '../../../../composables/use-getter'\nimport { isArrayEmpty } from '../../../../utils/array'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * This component receives a required `facet` with\n * {@link @empathyco/x-types#BooleanFilter} as prop and renders a button, which\n * on clicked emits the {@link FacetsXEvents.UserClickedAllFilter} event. By default\n * the rendered button displays a message with the facet label but this content is customizable\n * through the default slot.\n *\n * @public\n */\nexport default defineComponent({\n name: 'AllFilter',\n components: {\n BaseEventButton,\n },\n xModule: facetsXModule.name,\n props: {\n /** The facet data. */\n facet: {\n type: Object as PropType<Facet>,\n required: true,\n },\n },\n setup(props) {\n /** The getter of the selectedFiltersByFacet. */\n const { selectedFiltersByFacet } = useGetter('facets')\n\n /**\n * The event that will be emitted when the all filter button is clicked.\n *\n * @returns The event to emit on click.\n * @internal\n */\n const clickEvent = computed((): Partial<XEventsTypes> => {\n return { UserClickedAllFilter: [props.facet.id] }\n })\n\n /**\n * Computed to retrieve the selected state of this component.\n *\n * @returns True if is selected false otherwise.\n */\n const isSelected = computed(() => {\n return isArrayEmpty(selectedFiltersByFacet.value?.[props.facet.id])\n })\n\n /**\n * Dynamic CSS classes to apply to the component.\n *\n * @remarks This is only valid considering that in the case of HierarchicalFilters, ancestors\n * of nested selected filters are also selected.\n *\n * @returns The dynamic CSS classes to apply to the component.\n * @internal\n */\n const cssClasses = computed(() => {\n return {\n 'x-selected x-all-filter--is-selected': isSelected.value,\n }\n })\n\n return {\n clickEvent,\n cssClasses,\n isSelected,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserClickedAllFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button. The event payload is the id of the facet\n that this `AllFilter` component corresponds to.\n\n## Examples\n\nThis component receives a required `facet` as prop and renders a button, which on clicked emits the\nUserClickedAllFilter event. By default the rendered button displays a message with the facet label\nbut this content is customizable through the default slot.\n\n### Basic usage\n\n```vue\n<AllFilter :facet=\"facet\" />\n```\n\n### Customizing its content\n\n```vue\n<AllFilter v-slot=\"{ facet }\" :facet=\"facet\">\n Select all {{ facet.label }}\n</AllFilter>\n```\n\n### Basic example within facets\n\n```vue\n<Facets>\n <template #default=\"{ facet }\">\n <AllFilter :facet=\"facet\" />\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <SimpleFilter :filter=\"filter\" />\n </Filters>\n </template>\n</Facets>\n```\n\n### Custom example within facets\n\n```vue\n<Facets>\n <template #default=\"{ facet }\">\n <AllFilter v-slot=\"{ facet }\" :facet=\"facet\">\n Select all {{ facet.label }}\n </AllFilter>\n <Filters v-slot=\"{ filter }\" :filters=\"facet.filters\">\n <SimpleFilter :filter=\"filter\" />\n </Filters>\n </template>\n</Facets>\n```\n</docs>\n"],"names":["_createBlock","_normalizeClass","_renderSlot","_createTextVNode"],"mappings":";;;;;;sBACEA,WAakB,CAAA,0BAAA,EAAA;AAAA,IAZhB,KAAA,EAAKC,cAAC,CAAA,CAAA,6BAAA,EAKE,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,IAJlB,WAAU,EAAA,YAAA;AAAA,IACV,IAAK,EAAA,UAAA;AAAA,IACJ,cAAA,EAAc,gBAAW,QAAQ,EAAA;AAAA,IACjC,MAAQ,EAAA,IAAA,CAAA,UAAA;AAAA,GAAA,EAAA;qBAOT,MAAyD;AAAA,MAAzDC,UAAyD,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAA;AAAA,QAAlD,KAAO,EAAA,IAAA,CAAA,KAAA;AAAA,QAAQ,UAAa,EAAA,IAAA,CAAA,UAAA;AAAA,OAAA,EAAnC,MAAyD;AAAA,QAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAAC,eAAA;AAAV,UAAA,KAAA;AAAA,UAAG,CAAA,CAAA;AAAA;AAAA,SAAA,CAAA;AAAA,OAAA,CAAA;;;;;;;;;;"}
@@ -50,7 +50,11 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
50
50
  onClick: _cache[2] || (_cache[2] = (...args) => _ctx.emitUserModifiedFilter && _ctx.emitUserModifiedFilter(...args))
51
51
  }, [
52
52
  renderSlot(_ctx.$slots, "apply-content", {}, () => [
53
- createTextVNode("✓")
53
+ _cache[4] || (_cache[4] = createTextVNode(
54
+ "✓",
55
+ -1
56
+ /* CACHED */
57
+ ))
54
58
  ], true)
55
59
  ], 10, _hoisted_3)) : createCommentVNode("v-if", true),
56
60
  _ctx.renderClearButton ? (openBlock(), createElementBlock(
@@ -63,7 +67,11 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
63
67
  },
64
68
  [
65
69
  renderSlot(_ctx.$slots, "clear-content", {}, () => [
66
- createTextVNode("𐄂")
70
+ _cache[5] || (_cache[5] = createTextVNode(
71
+ "𐄂",
72
+ -1
73
+ /* CACHED */
74
+ ))
67
75
  ], true)
68
76
  ],
69
77
  2
@@ -1 +1 @@
1
- {"version":3,"file":"editable-number-range-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/editable-number-range-filter.vue"],"sourcesContent":["<template>\n <div\n class=\"x-editable-number-range-filter\"\n :class=\"cssClasses\"\n data-test=\"editable-number-range-filter\"\n >\n <!--\n @slot Empty slot used to customize the whole component.\n @binding {min} number - Component min value.\n @binding {max} number - Component max value.\n @binding {setMin} function - Component min setter.\n @binding {setMax} function - Component max setter.\n @binding {emitUserModifiedFilter} function - It emits the\n `UserModifiedEditableNumberRangeFilter` X event.\n @binding {clearValues} function - It sets component min and max values to null.\n @binding {hasError} boolean - Returns true when there is an error with component values.\n -->\n <slot\n v-bind=\"{\n min,\n max,\n setMin,\n setMax,\n emitUserModifiedFilter,\n clearValues,\n hasError,\n isAnyRange,\n }\"\n >\n <!-- eslint-disable max-len -->\n <input\n name=\"min\"\n type=\"number\"\n class=\"x-editable-number-range-filter__input x-editable-number-range-filter__input--min x-input\"\n :class=\"inputsClass\"\n :value=\"!isAnyRange ? min : null\"\n data-test=\"range-min\"\n :aria-label=\"rangeFilterMin\"\n @change=\"setMin($event.target.valueAsNumber)\"\n />\n\n <input\n name=\"max\"\n type=\"number\"\n class=\"x-editable-number-range-filter__input x-editable-number-range-filter__input--max x-input\"\n :class=\"inputsClass\"\n :value=\"max\"\n data-test=\"range-max\"\n :aria-label=\"rangeFilterMax\"\n @change=\"setMax($event.target.valueAsNumber)\"\n />\n <!-- eslint-enable max-len -->\n\n <button\n v-if=\"!isInstant\"\n class=\"x-editable-number-range-filter__apply x-button\"\n :class=\"buttonsClass\"\n :disabled=\"hasError\"\n data-test=\"range-apply\"\n @click=\"emitUserModifiedFilter\"\n >\n <!--\n @slot Slot used to customize the apply button content.\n -->\n <slot name=\"apply-content\">✓</slot>\n </button>\n\n <button\n v-if=\"renderClearButton\"\n class=\"x-editable-number-range-filter__clear x-button\"\n :class=\"buttonsClass\"\n data-test=\"range-clear\"\n @click=\"clearValues\"\n >\n <!--\n @slot Slot used to customize the clear button content.\n -->\n <slot name=\"clear-content\">𐄂</slot>\n </button>\n </slot>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport type {\n EditableNumberRangeFilter as EditableNumberRangeFilterModel,\n RangeValue,\n} from '@empathyco/x-types'\nimport type { PropType, Ref } from 'vue'\nimport { computed, defineComponent, ref, watch } from 'vue'\nimport { use$x } from '../../../../composables'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Renders an editable number range filter. It has two input fields to handle min and max values,\n * emitting the needed events when clicked.\n *\n * It provides a default slot, with some utils bind, to customize the whole component; and two\n * named slots `apply-content` and `clear-content` to override each button content.\n *\n * If `instant` prop is true, the needed events are emitted immediately; else, apply button is\n * rendered to confirm to do it. False by default.\n *\n * If `clear` prop is true, clear button, which sets to null component min and max values, is\n * rendered. True by default.\n *\n * @public\n */\nexport default defineComponent({\n name: 'EditableNumberRangeFilter',\n xModule: facetsXModule.name,\n props: {\n /**\n * The filter data to render and edit.\n *\n * @public\n */\n filter: {\n type: Object as PropType<EditableNumberRangeFilterModel>,\n required: true,\n },\n /**\n * If `instant` prop is true, the needed events are emitted immediately; else, apply button is\n * rendered to confirm to do it. False by default.\n *\n * @public\n */\n isInstant: Boolean,\n /**\n * If `clear` prop is true, clear button, which sets to null component min and max values, is\n * rendered. True by default.\n *\n * @public\n */\n hasClearButton: {\n type: Boolean,\n default: true,\n },\n /** Class inherited by content element. */\n inputsClass: String,\n /** Class inherited by content element. */\n buttonsClass: String,\n },\n setup(props) {\n const $x = use$x()\n\n const rangeFilterMin = 'minimum amount'\n const rangeFilterMax = 'maximum amount'\n /**\n * Component min value.\n *\n * @internal\n */\n const min: Ref<RangeValue['min']> = ref(null)\n /**\n * Component max value.\n *\n * @internal\n */\n const max: Ref<RangeValue['max']> = ref(null)\n\n /**\n * Returns {@link @empathyco/x-types#RangeValue} with component min and max\n * values.\n *\n * @returns Range value object with component values.\n *\n * @internal\n */\n const range = computed((): RangeValue => {\n return { min: min.value, max: max.value }\n })\n\n /**\n * It checks if component min and max values are valid.\n *\n * @returns True if there is any error in the component min and max values.\n *\n * @internal\n */\n const hasError = computed(\n () => min.value !== null && max.value !== null && min.value > max.value,\n )\n\n /**\n * It checks if component min and max values are different from the ones within the filter\n * provided as property.\n *\n * @returns True if they are different.\n *\n * @internal\n */\n const areValuesDifferent = computed(\n () => min.value !== props.filter.range.min || max.value !== props.filter.range.max,\n )\n\n /**\n * Dynamic CSS classes.\n *\n * @returns Object which contains dynamic CSS classes.\n *\n * @internal\n */\n const cssClasses = computed(() => {\n return { 'x-editable-number-range-filter--error': hasError.value }\n })\n\n /**\n * Checks if the range of the filter allows any value, which happens when the min is\n * null or 0 and the max is null.\n *\n * @returns True if the range of the filter allows any value.\n *\n * @internal\n */\n const isAnyRange = computed(() => !min.value && max.value === null)\n\n /**\n * It returns true if the property `hasClearButton` is true and there are values to clear.\n *\n * @returns True if the clear button has to be rendered.\n *\n * @internal\n */\n const renderClearButton = computed(() => props.hasClearButton && !isAnyRange.value)\n\n /**\n * It emits {@link FacetsXEvents.UserModifiedEditableNumberRangeFilter} event if there are no\n * errors and component `min` and `max` values are different than `filter.range` ones.\n *\n * @internal\n */\n const emitUserModifiedFilter = () => {\n if (!hasError.value && areValuesDifferent.value) {\n $x.emit('UserModifiedEditableNumberRangeFilter', {\n ...props.filter,\n range: range.value,\n })\n }\n }\n\n /**\n * It returns the number if possible or null otherwise.\n *\n * @param value - Value.\n * @returns The element value as a number if possible or null.\n *\n * @internal\n */\n const parseRangeValue = (value: number) => (Number.isNaN(value) ? null : value)\n\n /**\n * `min` setter.\n *\n * @param value - The component `min` value to be set.\n *\n * @internal\n */\n const setMin = (value: number) => {\n min.value = parseRangeValue(value)\n }\n\n /**\n * `max` setter.\n *\n * @param value - The component `max` value to be set.\n *\n * @internal\n */\n const setMax = (value: number) => {\n max.value = parseRangeValue(value)\n }\n\n /**\n * It sets component `min` and `max` values to null , and it emits the change if component is\n * working in instant mode.\n *\n * @internal\n */\n const clearValues = () => {\n min.value = null\n max.value = null\n }\n\n /**\n * It resets the min/max range values to null if the\n * {@link FacetsXEvents.UserClickedClearAllFilters} event is fired.\n *\n * @public\n */\n $x.on('UserClickedClearAllFilters', false).subscribe(clearValues)\n\n /**\n * It watches the filter range values passed as property and updates component range values if\n * they change.\n *\n * @param newRange - New range value.\n *\n * @internal\n */\n watch(\n () => props.filter.range,\n (newRange: RangeValue) => {\n min.value = newRange.min\n max.value = newRange.max\n },\n { immediate: true, deep: true },\n )\n\n /**\n * It watches range values in order to emit the event with the change if `isInstant`\n * property is true.\n *\n * @internal\n */\n watch(\n range,\n () => {\n if (props.isInstant) {\n emitUserModifiedFilter()\n }\n },\n { deep: true },\n )\n\n return {\n rangeFilterMin,\n rangeFilterMax,\n cssClasses,\n min,\n max,\n setMin,\n setMax,\n emitUserModifiedFilter,\n clearValues,\n hasError,\n isAnyRange,\n renderClearButton,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-editable-number-range-filter--error .x-editable-number-range-filter__input {\n border-color: red;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserModifiedEditableNumberRangeFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n this event is emitted instantly after typing the value or clicking the submit button. The event\n payload in both cases is an object containing the filter and the new value for the range.\n\n## Example\n\nRenders an editable number range filter. It has two input fields to handle min and max values,\nemitting the needed events when clicked.\n\nIt provides a default slot, with some utils bind, to customize the whole component; and two named\nslots `apply-content` and `clear-content` to override each button content.\n\nIf `instant` prop is true, the needed events are emitted immediately; else, apply button is rendered\nto confirm to do it. False by default.\n\nIf `clear` prop is true, clear button, which sets to null component min and max values, is rendered.\nTrue by default.\n\n### Basic usage\n\n```vue\n<template>\n <EditableNumberRangeFilter :filter=\"editableFilter\" />\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Properties\n\n```vue\n<template>\n <EditableNumberRangeFilter :filter=\"editableFilter\" :isInstant=\"true\" :hasClearButton=\"false\" />\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Customizing content slots\n\n```vue\n<template>\n <EditableNumberRangeFilter :filter=\"editableFilter\">\n <template name=\"apply-content\">Apply</template>\n <template name=\"clear-content\">Clear</template>\n </EditableNumberRangeFilter>\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Customizing default slot\n\n```vue\n<template>\n <EditableNumberRangeFilter\n :filter=\"editableFilter\"\n #default=\"{\n min,\n max,\n setMin,\n setMax,\n emitUserModifiedFilter,\n clearValues,\n hasError,\n isAnyRange,\n }\"\n >\n <button @click=\"emitUserModifiedFilter\">✅ Apply!</button>\n <button @click=\"clearValues\">🗑 Clear!</button>\n <input :value=\"!isAnyRange ? min : null\" @change=\"setMin($event.target.valueAsNumber)\" />\n <input :value=\"max\" @change=\"setMax($event.target.valueAsNumber)\" />\n <div class=\"has-error\" v-if=\"hasError\">⚠️ Invalid range values</div>\n </EditableNumberRangeFilter>\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the items with classes\n\nThe `buttonsClass` and `inputsClass` props can be used to add classes to the inputs and buttons of\nthe component.\n\n```\n<template>\n <EditableNumberRangeFilter\n :filter=\"editableFilter\"\n :inputsClass=\"'my-inputs-class'\"\n :buttonsClass=\"'my-buttons-class'\"\n />\n</template>\n\n<script>\n import { EditableNumberRangeFilter } from '@empathyco/x-components/facets';\n\n export default {\n components: {\n EditableNumberRangeFilter\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null\n }\n }\n };\n }\n };\n</script>\n```\n</docs>\n"],"names":["_openBlock","_createElementBlock","_normalizeClass","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_createTextVNode","_createCommentVNode"],"mappings":";;;;;AAAA,MAAA,UAAA,GAAA,CAAA,OAAA,EAAA,YAAA,CAAA,CAAA;AAAA,MAAA,UAAA,GAAA,CAAA,OAAA,EAAA,YAAA,CAAA,CAAA;AAAA,MAAA,UAAA,GAAA,CAAA,UAAA,CAAA,CAAA;;AACE,EAAA,OAAAA,SAAA,EAAA,EAAAC,kBAAA;AAAA,IA+EM,KAAA;AAAA,IAAA;AAAA,MA9EJ,KAAA,EAFJC,cAEU,CAAA,CAAA,gCAAA,EACE,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,MAClB,WAAU,EAAA,8BAAA;AAAA,KAAA;;AAaV,MAAAC,UAAA,CA8DO,IA/EX,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,QAkBwB,GAAA,EAAA,IAAA,CAAA,GAAA;AAAA,QAAa,GAAA,EAAA,IAAA,CAAA,GAAA;AAAA,QAAa,MAAA,EAAA,IAAA,CAAA,MAAA;AAAA,QAAgB,MAAA,EAAA,IAAA,CAAA,MAAA;AAAA,QAAgB,sBAAA,EAAA,IAAA,CAAA,sBAAA;AAAA,QAAgC,WAAA,EAAA,IAAA,CAAA,WAAA;AAAA,QAAqB,QAAA,EAAA,IAAA,CAAA,QAAA;AAAA,QAAkB,UAAA,EAAA,IAAA,CAAA,UAAA;AAAA,OAAA,CAAA,CAAA,EADrJ,MA8DO;AAAA,QAjDLC,kBASE,CAAA,OAAA,EAAA;AAAA,UARA,IAAK,EAAA,KAAA;AAAA,UACL,IAAK,EAAA,QAAA;AAAA,UACL,KAAA,EAjCRJ,cAiCc,CAAA,CAAA,0FAAA,EACE,IAAW,CAAA,WAAA,CAAA,CAAA;AAAA,UAClB,KAAA,EAAK,CAAG,IAAA,CAAA,UAAA,GAAa,IAAG,CAAA,GAAA,GAAA,IAAA;AAAA,UACzB,WAAU,EAAA,WAAA;AAAA,UACT,YAAY,EAAA,IAAA,CAAA,cAAA;AAAA,UACZ,QAAM,EAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,MAAA,KAAE,IAAO,CAAA,MAAA,CAAA,MAAA,CAAO,OAAO,aAAa,CAAA,CAAA;AAAA,SAtCnD,EAAA,IAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAAA,QAyCMI,kBASE,CAAA,OAAA,EAAA;AAAA,UARA,IAAK,EAAA,KAAA;AAAA,UACL,IAAK,EAAA,QAAA;AAAA,UACL,KAAA,EA5CRJ,cA4Cc,CAAA,CAAA,0FAAA,EACE,IAAW,CAAA,WAAA,CAAA,CAAA;AAAA,UAClB,KAAO,EAAA,IAAA,CAAA,GAAA;AAAA,UACR,WAAU,EAAA,WAAA;AAAA,UACT,YAAY,EAAA,IAAA,CAAA,cAAA;AAAA,UACZ,QAAM,EAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,MAAA,KAAE,IAAO,CAAA,MAAA,CAAA,MAAA,CAAO,OAAO,aAAa,CAAA,CAAA;AAAA,SAjDnD,EAAA,IAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAAA,QAAA,CAsDe,+BADTD,kBAYS,CAAA,QAAA,EAAA;AAAA,UAjEf,GAAA,EAAA,CAAA;AAAA,UAuDQ,KAAA,EAvDRC,cAuDc,CAAA,CAAA,gDAAA,EACE,IAAY,CAAA,YAAA,CAAA,CAAA;AAAA,UACnB,QAAU,EAAA,IAAA,CAAA,QAAA;AAAA,UACX,WAAU,EAAA,aAAA;AAAA,UACT,SAAK,MAAE,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,GAAA,IAAA,KAAA,IAAA,CAAA,sBAAA,IAAA,IAAA,CAAA,sBAAA,CAAA,GAAA,IAAA,CAAA,CAAA;AAAA,SAAA,EAAA;AAKR,UAAAC,UAAA,CAAmC,kCAAnC,MAAmC;AAAA,YAhE3CI,gBAgEmC,GAAC,CAAA;AAAA,WAAA,EAAA,IAAA,CAAA;AAhEpC,SAAA,EAAA,EAAA,EAAA,UAAA,CAAA,IAAAC,kBAAA,CAAA,MAAA,EAAA,IAAA,CAAA;AAAA,QAoEc,IADR,CAAA,iBAAA,IAAAR,SAAA,EAAA,EAAAC,kBAAA;AAAA,UAWS,QAAA;AAAA,UAAA;AAAA,YA9Ef,GAAA,EAAA,CAAA;AAAA,YAqEQ,KAAA,EArERC,cAqEc,CAAA,CAAA,gDAAA,EACE,IAAY,CAAA,YAAA,CAAA,CAAA;AAAA,YACpB,WAAU,EAAA,aAAA;AAAA,YACT,SAAK,MAAE,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,GAAA,IAAA,KAAA,IAAA,CAAA,WAAA,IAAA,IAAA,CAAA,WAAA,CAAA,GAAA,IAAA,CAAA,CAAA;AAAA,WAAA;;AAKR,YAAAC,UAAA,CAAoC,kCAApC,MAAoC;AAAA,cA7E5CI,gBA6EmC,IAAE,CAAA;AAAA,aAAA,EAAA,IAAA,CAAA;;;;AA7ErC,SAAA,IAAAC,kBAAA,CAAA,MAAA,EAAA,IAAA,CAAA;AAAA,OAAA,EAAA,IAAA,CAAA;;;;;;;;;;"}
1
+ {"version":3,"file":"editable-number-range-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/editable-number-range-filter.vue"],"sourcesContent":["<template>\n <div\n class=\"x-editable-number-range-filter\"\n :class=\"cssClasses\"\n data-test=\"editable-number-range-filter\"\n >\n <!--\n @slot Empty slot used to customize the whole component.\n @binding {min} number - Component min value.\n @binding {max} number - Component max value.\n @binding {setMin} function - Component min setter.\n @binding {setMax} function - Component max setter.\n @binding {emitUserModifiedFilter} function - It emits the\n `UserModifiedEditableNumberRangeFilter` X event.\n @binding {clearValues} function - It sets component min and max values to null.\n @binding {hasError} boolean - Returns true when there is an error with component values.\n -->\n <slot\n v-bind=\"{\n min,\n max,\n setMin,\n setMax,\n emitUserModifiedFilter,\n clearValues,\n hasError,\n isAnyRange,\n }\"\n >\n <!-- eslint-disable max-len -->\n <input\n name=\"min\"\n type=\"number\"\n class=\"x-editable-number-range-filter__input x-editable-number-range-filter__input--min x-input\"\n :class=\"inputsClass\"\n :value=\"!isAnyRange ? min : null\"\n data-test=\"range-min\"\n :aria-label=\"rangeFilterMin\"\n @change=\"setMin($event.target.valueAsNumber)\"\n />\n\n <input\n name=\"max\"\n type=\"number\"\n class=\"x-editable-number-range-filter__input x-editable-number-range-filter__input--max x-input\"\n :class=\"inputsClass\"\n :value=\"max\"\n data-test=\"range-max\"\n :aria-label=\"rangeFilterMax\"\n @change=\"setMax($event.target.valueAsNumber)\"\n />\n <!-- eslint-enable max-len -->\n\n <button\n v-if=\"!isInstant\"\n class=\"x-editable-number-range-filter__apply x-button\"\n :class=\"buttonsClass\"\n :disabled=\"hasError\"\n data-test=\"range-apply\"\n @click=\"emitUserModifiedFilter\"\n >\n <!--\n @slot Slot used to customize the apply button content.\n -->\n <slot name=\"apply-content\">✓</slot>\n </button>\n\n <button\n v-if=\"renderClearButton\"\n class=\"x-editable-number-range-filter__clear x-button\"\n :class=\"buttonsClass\"\n data-test=\"range-clear\"\n @click=\"clearValues\"\n >\n <!--\n @slot Slot used to customize the clear button content.\n -->\n <slot name=\"clear-content\">𐄂</slot>\n </button>\n </slot>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport type {\n EditableNumberRangeFilter as EditableNumberRangeFilterModel,\n RangeValue,\n} from '@empathyco/x-types'\nimport type { PropType, Ref } from 'vue'\nimport { computed, defineComponent, ref, watch } from 'vue'\nimport { use$x } from '../../../../composables'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Renders an editable number range filter. It has two input fields to handle min and max values,\n * emitting the needed events when clicked.\n *\n * It provides a default slot, with some utils bind, to customize the whole component; and two\n * named slots `apply-content` and `clear-content` to override each button content.\n *\n * If `instant` prop is true, the needed events are emitted immediately; else, apply button is\n * rendered to confirm to do it. False by default.\n *\n * If `clear` prop is true, clear button, which sets to null component min and max values, is\n * rendered. True by default.\n *\n * @public\n */\nexport default defineComponent({\n name: 'EditableNumberRangeFilter',\n xModule: facetsXModule.name,\n props: {\n /**\n * The filter data to render and edit.\n *\n * @public\n */\n filter: {\n type: Object as PropType<EditableNumberRangeFilterModel>,\n required: true,\n },\n /**\n * If `instant` prop is true, the needed events are emitted immediately; else, apply button is\n * rendered to confirm to do it. False by default.\n *\n * @public\n */\n isInstant: Boolean,\n /**\n * If `clear` prop is true, clear button, which sets to null component min and max values, is\n * rendered. True by default.\n *\n * @public\n */\n hasClearButton: {\n type: Boolean,\n default: true,\n },\n /** Class inherited by content element. */\n inputsClass: String,\n /** Class inherited by content element. */\n buttonsClass: String,\n },\n setup(props) {\n const $x = use$x()\n\n const rangeFilterMin = 'minimum amount'\n const rangeFilterMax = 'maximum amount'\n /**\n * Component min value.\n *\n * @internal\n */\n const min: Ref<RangeValue['min']> = ref(null)\n /**\n * Component max value.\n *\n * @internal\n */\n const max: Ref<RangeValue['max']> = ref(null)\n\n /**\n * Returns {@link @empathyco/x-types#RangeValue} with component min and max\n * values.\n *\n * @returns Range value object with component values.\n *\n * @internal\n */\n const range = computed((): RangeValue => {\n return { min: min.value, max: max.value }\n })\n\n /**\n * It checks if component min and max values are valid.\n *\n * @returns True if there is any error in the component min and max values.\n *\n * @internal\n */\n const hasError = computed(\n () => min.value !== null && max.value !== null && min.value > max.value,\n )\n\n /**\n * It checks if component min and max values are different from the ones within the filter\n * provided as property.\n *\n * @returns True if they are different.\n *\n * @internal\n */\n const areValuesDifferent = computed(\n () => min.value !== props.filter.range.min || max.value !== props.filter.range.max,\n )\n\n /**\n * Dynamic CSS classes.\n *\n * @returns Object which contains dynamic CSS classes.\n *\n * @internal\n */\n const cssClasses = computed(() => {\n return { 'x-editable-number-range-filter--error': hasError.value }\n })\n\n /**\n * Checks if the range of the filter allows any value, which happens when the min is\n * null or 0 and the max is null.\n *\n * @returns True if the range of the filter allows any value.\n *\n * @internal\n */\n const isAnyRange = computed(() => !min.value && max.value === null)\n\n /**\n * It returns true if the property `hasClearButton` is true and there are values to clear.\n *\n * @returns True if the clear button has to be rendered.\n *\n * @internal\n */\n const renderClearButton = computed(() => props.hasClearButton && !isAnyRange.value)\n\n /**\n * It emits {@link FacetsXEvents.UserModifiedEditableNumberRangeFilter} event if there are no\n * errors and component `min` and `max` values are different than `filter.range` ones.\n *\n * @internal\n */\n const emitUserModifiedFilter = () => {\n if (!hasError.value && areValuesDifferent.value) {\n $x.emit('UserModifiedEditableNumberRangeFilter', {\n ...props.filter,\n range: range.value,\n })\n }\n }\n\n /**\n * It returns the number if possible or null otherwise.\n *\n * @param value - Value.\n * @returns The element value as a number if possible or null.\n *\n * @internal\n */\n const parseRangeValue = (value: number) => (Number.isNaN(value) ? null : value)\n\n /**\n * `min` setter.\n *\n * @param value - The component `min` value to be set.\n *\n * @internal\n */\n const setMin = (value: number) => {\n min.value = parseRangeValue(value)\n }\n\n /**\n * `max` setter.\n *\n * @param value - The component `max` value to be set.\n *\n * @internal\n */\n const setMax = (value: number) => {\n max.value = parseRangeValue(value)\n }\n\n /**\n * It sets component `min` and `max` values to null , and it emits the change if component is\n * working in instant mode.\n *\n * @internal\n */\n const clearValues = () => {\n min.value = null\n max.value = null\n }\n\n /**\n * It resets the min/max range values to null if the\n * {@link FacetsXEvents.UserClickedClearAllFilters} event is fired.\n *\n * @public\n */\n $x.on('UserClickedClearAllFilters', false).subscribe(clearValues)\n\n /**\n * It watches the filter range values passed as property and updates component range values if\n * they change.\n *\n * @param newRange - New range value.\n *\n * @internal\n */\n watch(\n () => props.filter.range,\n (newRange: RangeValue) => {\n min.value = newRange.min\n max.value = newRange.max\n },\n { immediate: true, deep: true },\n )\n\n /**\n * It watches range values in order to emit the event with the change if `isInstant`\n * property is true.\n *\n * @internal\n */\n watch(\n range,\n () => {\n if (props.isInstant) {\n emitUserModifiedFilter()\n }\n },\n { deep: true },\n )\n\n return {\n rangeFilterMin,\n rangeFilterMax,\n cssClasses,\n min,\n max,\n setMin,\n setMax,\n emitUserModifiedFilter,\n clearValues,\n hasError,\n isAnyRange,\n renderClearButton,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-editable-number-range-filter--error .x-editable-number-range-filter__input {\n border-color: red;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserModifiedEditableNumberRangeFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n this event is emitted instantly after typing the value or clicking the submit button. The event\n payload in both cases is an object containing the filter and the new value for the range.\n\n## Example\n\nRenders an editable number range filter. It has two input fields to handle min and max values,\nemitting the needed events when clicked.\n\nIt provides a default slot, with some utils bind, to customize the whole component; and two named\nslots `apply-content` and `clear-content` to override each button content.\n\nIf `instant` prop is true, the needed events are emitted immediately; else, apply button is rendered\nto confirm to do it. False by default.\n\nIf `clear` prop is true, clear button, which sets to null component min and max values, is rendered.\nTrue by default.\n\n### Basic usage\n\n```vue\n<template>\n <EditableNumberRangeFilter :filter=\"editableFilter\" />\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Properties\n\n```vue\n<template>\n <EditableNumberRangeFilter :filter=\"editableFilter\" :isInstant=\"true\" :hasClearButton=\"false\" />\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Customizing content slots\n\n```vue\n<template>\n <EditableNumberRangeFilter :filter=\"editableFilter\">\n <template name=\"apply-content\">Apply</template>\n <template name=\"clear-content\">Clear</template>\n </EditableNumberRangeFilter>\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Customizing default slot\n\n```vue\n<template>\n <EditableNumberRangeFilter\n :filter=\"editableFilter\"\n #default=\"{\n min,\n max,\n setMin,\n setMax,\n emitUserModifiedFilter,\n clearValues,\n hasError,\n isAnyRange,\n }\"\n >\n <button @click=\"emitUserModifiedFilter\">✅ Apply!</button>\n <button @click=\"clearValues\">🗑 Clear!</button>\n <input :value=\"!isAnyRange ? min : null\" @change=\"setMin($event.target.valueAsNumber)\" />\n <input :value=\"max\" @change=\"setMax($event.target.valueAsNumber)\" />\n <div class=\"has-error\" v-if=\"hasError\">⚠️ Invalid range values</div>\n </EditableNumberRangeFilter>\n</template>\n\n<script>\nimport { EditableNumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n EditableNumberRangeFilter,\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null,\n },\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the items with classes\n\nThe `buttonsClass` and `inputsClass` props can be used to add classes to the inputs and buttons of\nthe component.\n\n```\n<template>\n <EditableNumberRangeFilter\n :filter=\"editableFilter\"\n :inputsClass=\"'my-inputs-class'\"\n :buttonsClass=\"'my-buttons-class'\"\n />\n</template>\n\n<script>\n import { EditableNumberRangeFilter } from '@empathyco/x-components/facets';\n\n export default {\n components: {\n EditableNumberRangeFilter\n },\n data() {\n return {\n editableFilter: {\n facetId: 'age',\n id: 'age:primary',\n label: 'primary',\n modelName: 'EditableNumberRangeFilter',\n range: {\n min: null,\n max: null\n }\n }\n };\n }\n };\n</script>\n```\n</docs>\n"],"names":["_openBlock","_createElementBlock","_normalizeClass","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_createTextVNode"],"mappings":";;;;;;;;;AACE,EAAA,OAAAA,SAAA,EAAA,EAAAC,kBAAA;AAAA,IA+EM,KAAA;AAAA,IAAA;AAAA,MA9EJ,KAAA,EAAKC,cAAC,CAAA,CAAA,gCAAA,EACE,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,MAClB,WAAU,EAAA,8BAAA;AAAA,KAAA;;MAaVC,UA8DO,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,QA7Da,GAAA,EAAA,IAAA,CAAA,GAAA;AAAA,QAAa,GAAA,EAAA,IAAA,CAAA,GAAA;AAAA,QAAa,MAAA,EAAA,IAAA,CAAA,MAAA;AAAA,QAAgB,MAAA,EAAA,IAAA,CAAA,MAAA;AAAA,QAAgB,sBAAA,EAAA,IAAA,CAAA,sBAAA;AAAA,QAAgC,WAAA,EAAA,IAAA,CAAA,WAAA;AAAA,QAAqB,QAAA,EAAA,IAAA,CAAA,QAAA;AAAA,QAAkB,UAAA,EAAA,IAAA,CAAA,UAAA;AAAA,OAAA,CAAA,CAAA,EADrJ,MA8DO;AAAA,QAjDLC,kBASE,CAAA,OAAA,EAAA;AAAA,UARA,IAAK,EAAA,KAAA;AAAA,UACL,IAAK,EAAA,QAAA;AAAA,UACL,KAAA,EAAKJ,cAAC,CAAA,CAAA,0FAAA,EACE,IAAW,CAAA,WAAA,CAAA,CAAA;AAAA,UAClB,KAAA,EAAK,CAAG,IAAA,CAAA,UAAA,GAAa,IAAG,CAAA,GAAA,GAAA,IAAA;AAAA,UACzB,WAAU,EAAA,WAAA;AAAA,UACT,YAAY,EAAA,IAAA,CAAA,cAAA;AAAA,UACZ,QAAM,EAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,MAAA,KAAE,IAAO,CAAA,MAAA,CAAA,MAAA,CAAO,OAAO,aAAa,CAAA,CAAA;AAAA,SAAA,EAAA,IAAA,EAAA,EAAA,EAAA,UAAA,CAAA;QAG7CI,kBASE,CAAA,OAAA,EAAA;AAAA,UARA,IAAK,EAAA,KAAA;AAAA,UACL,IAAK,EAAA,QAAA;AAAA,UACL,KAAA,EAAKJ,cAAC,CAAA,CAAA,0FAAA,EACE,IAAW,CAAA,WAAA,CAAA,CAAA;AAAA,UAClB,KAAO,EAAA,IAAA,CAAA,GAAA;AAAA,UACR,WAAU,EAAA,WAAA;AAAA,UACT,YAAY,EAAA,IAAA,CAAA,cAAA;AAAA,UACZ,QAAM,EAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,MAAA,KAAE,IAAO,CAAA,MAAA,CAAA,MAAA,CAAO,OAAO,aAAa,CAAA,CAAA;AAAA,SAAA,EAAA,IAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAKpC,QAAA,CAAA,IAAA,CAAA,SAAA,IAAAF,SAAA,EAAA,EADTC,kBAYS,CAAA,QAAA,EAAA;AAAA,UAAA,GAAA,EAAA,CAAA;UAVP,KAAK,EAAAC,cAAA,CAAA,CAAC,kDACE,IAAY,CAAA,YAAA,CAAA,CAAA;AAAA,UACnB,QAAU,EAAA,IAAA,CAAA,QAAA;AAAA,UACX,WAAU,EAAA,aAAA;AAAA,UACT,SAAK,MAAE,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,GAAA,IAAA,KAAA,IAAA,CAAA,sBAAA,IAAA,IAAA,CAAA,sBAAA,CAAA,GAAA,IAAA,CAAA,CAAA;AAAA,SAAA,EAAA;AAKR,UAAAC,UAAA,CAAmC,kCAAnC,MAAmC;AAAA,YAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAAI,eAAA;AAAR,cAAA,GAAA;AAAA,cAAC,CAAA,CAAA;AAAA;AAAA,aAAA,CAAA;AAAA,WAAA,EAAA,IAAA,CAAA;;QAItB,IADR,CAAA,iBAAA,IAAAP,SAAA,EAAA,EAAAC,kBAAA;AAAA,UAWS,QAAA;AAAA,UAAA;AAAA,YAAA,GAAA,EAAA,CAAA;YATP,KAAK,EAAAC,cAAA,CAAA,CAAC,kDACE,IAAY,CAAA,YAAA,CAAA,CAAA;AAAA,YACpB,WAAU,EAAA,aAAA;AAAA,YACT,SAAK,MAAE,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,GAAA,IAAA,KAAA,IAAA,CAAA,WAAA,IAAA,IAAA,CAAA,WAAA,CAAA,GAAA,IAAA,CAAA,CAAA;AAAA,WAAA;;AAKR,YAAAC,UAAA,CAAoC,kCAApC,MAAoC;AAAA,cAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAAI,eAAA;AAAT,gBAAA,IAAA;AAAA,gBAAE,CAAA,CAAA;AAAA;AAAA,eAAA,CAAA;AAAA,aAAA,EAAA,IAAA,CAAA;;;;;;;;;;;;;;;"}
@@ -71,9 +71,9 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
71
71
  label: withCtx(({ filter: filterBinding }) => [
72
72
  renderSlot(_ctx.$slots, "label", { filter: filterBinding })
73
73
  ]),
74
- _: 2
75
- /* DYNAMIC */
76
- }, 1032, ["children-animation", "filter", "click-events", "children-filters-class", "filter-item-class"])
74
+ _: 3
75
+ /* FORWARDED */
76
+ }, 8, ["children-animation", "filter", "click-events", "children-filters-class", "filter-item-class"])
77
77
  ]),
78
78
  _: 3
79
79
  /* FORWARDED */
@@ -1 +1 @@
1
- {"version":3,"file":"hierarchical-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/hierarchical-filter.vue"],"sourcesContent":["<template>\n <div class=\"x-hierarchical-filter-container\" data-test=\"hierarchical-filter-container\">\n <RenderlessFilter\n v-slot=\"{ filter: filterBinding, clickFilter, cssClasses: cssClassesBinding, isDisabled }\"\n :filter=\"filter\"\n :click-events=\"innerClickEvents\"\n :css-classes=\"innerCssClasses\"\n >\n <!--\n @slot The content to render inside the button.\n @binding {Filter} filter - The filter data.\n @binding {Function} clickFilter - The handler to invoke when clicking the filter.\n @binding {VueCssClasses} cssClasses - The CSS classes.\n @binding {boolean} isDisabled - Flag determining the disabled state.\n -->\n <slot\n v-bind=\"{ filter: filterBinding, clickFilter, cssClasses: cssClassesBinding, isDisabled }\"\n >\n <button\n :aria-checked=\"filterBinding.selected.toString()\"\n :class=\"[cssClassesBinding, filterItemClass]\"\n :disabled=\"isDisabled\"\n data-test=\"filter\"\n role=\"checkbox\"\n @click=\"clickFilter\"\n >\n <!--\n @slot The content to render inside the button.\n @binding {Filter} filter - The filter data.\n -->\n <slot name=\"label\" :filter=\"filterBinding\">{{ filterBinding.label }}</slot>\n </button>\n </slot>\n </RenderlessFilter>\n <FiltersList\n v-slot=\"{ filter: childFilter }\"\n :animation=\"childrenAnimation\"\n :filters=\"renderedChildrenFilters\"\n :parent-id=\"filter.id\"\n class=\"x-hierarchical-filter__children\"\n :class=\"childrenFiltersClass\"\n data-test=\"children-filters\"\n >\n <HierarchicalFilter\n :children-animation=\"childrenAnimation\"\n :filter=\"childFilter\"\n :click-events=\"getChildFilterClickEvents(childFilter)\"\n :children-filters-class=\"childrenFiltersClass\"\n :filter-item-class=\"filterItemClass\"\n >\n <template\n #default=\"{\n filter: filterBinding,\n clickFilter,\n cssClasses: cssClassesBinding,\n isDisabled,\n }\"\n >\n <slot\n v-bind=\"{\n filter: filterBinding,\n clickFilter,\n cssClasses: cssClassesBinding,\n isDisabled,\n }\"\n />\n </template>\n <template #label=\"{ filter: filterBinding }\">\n <slot name=\"label\" :filter=\"filterBinding\" />\n </template>\n </HierarchicalFilter>\n </FiltersList>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport type { Filter, HierarchicalFilter as HierarchicalFilterModel } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { isHierarchicalFilter } from '@empathyco/x-types'\nimport { isObject } from '@empathyco/x-utils'\nimport { computed, defineComponent } from 'vue'\nimport { AnimationProp } from '../../../../types'\nimport { facetsXModule } from '../../x-module'\nimport FiltersList from '../lists/filters-list.vue'\nimport RenderlessFilter from './renderless-filter.vue'\n\n/**\n * Renders a hierarchical filter recursively, emitting the needed events when clicked.\n *\n * @public\n */\nexport default defineComponent({\n name: 'HierarchicalFilter',\n xModule: facetsXModule.name,\n components: { FiltersList, RenderlessFilter },\n props: {\n /** The filter data to render. */\n filter: {\n type: Object as PropType<HierarchicalFilterModel>,\n required: true,\n },\n /** The animation component to use for the children filters. */\n childrenAnimation: AnimationProp,\n /**\n * Additional events, with their payload, to emit when the filter is clicked.\n *\n * @public\n */\n clickEvents: Object as PropType<Partial<XEventsTypes>>,\n /** Inheritance CSS classes. */\n cssClasses: {\n type: Array as PropType<(string | Dictionary<boolean>)[]>,\n default: () => [],\n },\n /** Class inherited by content element. */\n childrenFiltersClass: String,\n /** Class inherited by content element. */\n filterItemClass: String,\n },\n setup(props) {\n /**\n * The {@link XEventsTypes} to emit.\n *\n * @returns The events to emit when clicked.\n * @internal\n */\n const innerClickEvents = computed(() => ({\n UserClickedAHierarchicalFilter: props.filter,\n ...props.clickEvents,\n }))\n\n const isFilterPartiallySelected = (filter: HierarchicalFilterModel) => {\n const selectedChildren = filter.children?.filter(filter => filter.selected)\n const filterChildrenLength = filter.children?.length ?? 0\n return (\n !!selectedChildren &&\n ((selectedChildren.length > 0 && selectedChildren.length < filterChildrenLength) ||\n selectedChildren.some(isFilterPartiallySelected))\n )\n }\n\n /**\n * Returns if the filter is partially selected, which means having more than one child filter\n * selected, but not every of them, or having at least one child filter partially selected.\n *\n * @returns True if the filter is partially selected. False otherwise.\n * @internal\n */\n const isPartiallySelected = computed(() => isFilterPartiallySelected(props.filter))\n\n /**\n * Dynamic CSS classes to apply to the component.\n *\n * @returns The dynamic CSS classes to apply to the component.\n * @internal\n */\n const innerCssClasses = computed(() => [\n 'x-hierarchical-filter',\n { 'x-hierarchical-filter--is-partially-selected': isPartiallySelected.value },\n { 'x-hierarchical-filter--is-selected': props.filter.selected },\n { 'x-facet-filter--is-partially-selected': isPartiallySelected.value },\n ...props.cssClasses,\n ])\n\n /**\n * Gets the child filter click events, converting the payload of the events that have a\n * {@link HierarchicalFilter} as payload to the corresponding child filter.\n *\n * @param childFilter - The child filter.\n * @returns The events to emit when clicking a child.\n * @internal\n */\n const getChildFilterClickEvents = (childFilter: HierarchicalFilterModel) => {\n return Object.entries(innerClickEvents.value).reduce((clickEvents, [event, payload]) => {\n return {\n ...clickEvents,\n [event]:\n isObject(payload) &&\n isHierarchicalFilter(payload as unknown as Filter) &&\n childFilter !== (payload as unknown as HierarchicalFilterModel)\n ? childFilter\n : payload,\n }\n }, {} as Partial<XEventsTypes>)\n }\n\n /**\n * List of filters to render, in case that the children's array\n * is empty it will return an empty array instead of inject the ones from the parent.\n *\n * @returns A list of filters.\n * @internal\n */\n const renderedChildrenFilters = computed(() => props.filter.children ?? [])\n\n return {\n innerClickEvents,\n innerCssClasses,\n renderedChildrenFilters,\n getChildFilterClickEvents,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserClickedAFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n- [`UserClickedAHierarchicalFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n filter.\n\n## See it in action\n\nThis component renders a button, which on clicked emits the `UserClickedAFilter` and\n`UserClickedAHierarchicalFilter` events. By default it renders the filter label as the button text.\nIf the provided filter has children filters, this component will render them recursively. Changing\nthe slot content will change it for all of the children.\n\nThe `filter` prop is required. The `clickEvents` prop is optional and allows configuring the events\nto emit on click.\n\n```vue\n<template>\n <HierarchicalFilter :filter=\"filter\" />\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Playing with props\n\nConfiguring the events to emit when the filter is clicked.\n\n```vue\n<template>\n <HierarchicalFilter :clickEvents=\"{ UserClickedAHierarchicalFilter: filter }\" :filter=\"filter\" />\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the default slot content\n\nIn this example, the child filters will also include the label and checkbox.\n\n```vue\n<template>\n <HierarchicalFilter :filter=\"filter\" v-slot=\"{ filter, clickFilter, slotCSSClasses, isDisabled }\">\n <label :class=\"slotCSSClasses\">\n <input @change=\"clickFilter\" :disabled=\"isDisabled\" />\n {{ filter.label }}\n </label>\n </HierarchicalFilter>\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the label slot content\n\n```vue\n<template>\n <HierarchicalFilter :filter=\"filter\">\n <template #label :filter=\"filter\">\n <span class=\"custom-class\">{{ filter.label }}</span>\n </template>\n </HierarchicalFilter>\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the content with classes\n\nThe `childrenFiltersClass` prop can be used to add classes to the inner filters lists. This is\nuseful to set the indent of the children filters.\n\nThe `filterItemClass` prop can be used to add classes to the filter element itself.\n\n```vue\n<template>\n <HierarchicalFilter\n :filter=\"filter\"\n childrenFiltersClass=\"x-custom-class\"\n filterItemClass=\"x-custom-filter\"\n />\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n</docs>\n"],"names":["_openBlock","_createElementBlock","_createVNode","_withCtx","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_normalizeClass","_createTextVNode","_toDisplayString"],"mappings":";;;;;EACO,KAAM,EAAA,iCAAA;AAAA,EAAkC,WAAU,EAAA,+BAAA;;AADzD,MAAA,UAAA,GAAA,CAAA,cAAA,EAAA,UAAA,EAAA,SAAA,CAAA,CAAA;;;;;AACE,EAAA,OAAAA,SAAA,EAAA,EAAAC,kBAAA,CAuEM,OAvEN,UAuEM,EAAA;AAAA,IAtEJC,WA+BmB,CAAA,2BAAA,EAAA;AAAA,MA7BhB,MAAQ,EAAA,IAAA,CAAA,MAAA;AAAA,MACR,cAAc,EAAA,IAAA,CAAA,gBAAA;AAAA,MACd,aAAa,EAAA,IAAA,CAAA,eAAA;AAAA,KAAA,EAAA;AANpB,MAAA,OAAA,EAAAC,OAAA,CAeM,CAiBO,EA7BW,MAAA,EAAA,aAAA,EAAe,WAAW,EAAA,UAAA,EAAc,mBAAmB,UAAU,EAAA,KAAA;AAAA,QAYvFC,UAAA,CAiBO,wBAhCbC,cAgB0B,CAAAC,kBAAA,CAAA,EAAA,MAAA,EAAA,aAAA,EAAe,aAAW,UAAc,EAAA,iBAAA,EAAmB,UAAU,EAAA,CAAA,CAAA,EADzF,MAiBO;AAAA,UAdLC,kBAaS,CAAA,QAAA,EAAA;AAAA,YAZN,cAAA,EAAc,aAAc,CAAA,QAAA,CAAS,QAAQ,EAAA;AAAA,YAC7C,KAAA,EApBXC,cAoBmB,CAAA,CAAA,iBAAA,EAAmB,IAAe,CAAA,eAAA,CAAA,CAAA;AAAA,YAC1C,QAAU,EAAA,UAAA;AAAA,YACX,WAAU,EAAA,QAAA;AAAA,YACV,IAAK,EAAA,UAAA;AAAA,YACJ,OAAO,EAAA,WAAA;AAAA,WAAA,EAAA;AAMR,YAAAJ,UAAA,CAA2E,IAAvD,CAAA,MAAA,EAAA,OAAA,EAAA,EAAA,MAAA,EAAQ,aAAa,EAAA,EAAzC,MAA2E;AAAA,cA9BrFK,eAAA;AAAA,gBAAAC,eAAA,CA8BwD,cAAc,KAAK,CAAA;AAAA,gBAAA,CAAA;AAAA;AAAA,eAAA;AAAA,aAAA,CAAA;AA9B3E,WAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAAA,SAAA,CAAA;;AAAA,MAAA,CAAA,EAAA,CAAA;AAAA;AAAA,KAAA,EAAA,CAAA,EAAA,CAAA,QAAA,EAAA,cAAA,EAAA,aAAA,CAAA,CAAA;IAkCIR,WAqCc,CAAA,sBAAA,EAAA;AAAA,MAnCX,SAAW,EAAA,IAAA,CAAA,iBAAA;AAAA,MACX,OAAS,EAAA,IAAA,CAAA,uBAAA;AAAA,MACT,aAAW,IAAO,CAAA,MAAA,CAAA,EAAA;AAAA,MACnB,KAAA,EAvCNM,cAuCY,CAAA,CAAA,iCAAA,EACE,IAAoB,CAAA,oBAAA,CAAA,CAAA;AAAA,MAC5B,WAAU,EAAA,kBAAA;AAAA,KAAA,EAAA;MAzChB,OA2CM,EAAAL,OAAA,CAAA,CA2BqB,UAnCH,WAAW,EAAA,KAAA;AAAA,QAQ7BD,WA2BqB,CAAA,6BAAA,EAAA;AAAA,UA1BlB,oBAAoB,EAAA,IAAA,CAAA,iBAAA;AAAA,UACpB,MAAQ,EAAA,WAAA;AAAA,UACR,cAAA,EAAc,+BAA0B,WAAW,CAAA;AAAA,UACnD,wBAAwB,EAAA,IAAA,CAAA,oBAAA;AAAA,UACxB,mBAAmB,EAAA,IAAA,CAAA,eAAA;AAAA,SAAA,EAAA;AAGjB,UAAA,OAAA,EAAOC,QAOR,CAOE;AAAA,YAd8B,MAAA,EAAA,aAAA;AAAA,YAA2B,WAAA;AAAA,YAAqC,UAAA,EAAA,iBAAA;AAAA,YAA+B,UAAA;AAAA,WAAA,KAAA;AAO/H,YAAAC,UAAA,CAOE,IAjEZ,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,cA2D4C,MAAA,EAAA,aAAA;AAAA,cAA6B,WAAA;AAAA,cAAuC,UAAA,EAAA,iBAAA;AAAA,cAAiC,UAAA;AAAA,aAAA,CAAA,CAAA,CAAA;;UAQ9H,KAAK,EAAAH,OAAA,CACd,CAA6C,EAAA,MAAA,EADnB,aAAa,EAAA,KAAA;AAAA,YACvCC,UAAA,CAA6C,IAAzB,CAAA,MAAA,EAAA,OAAA,EAAA,EAAA,MAAA,EAAQ,aAAa,EAAA,CAAA;AAAA,WAAA,CAAA;AApEnD,UAAA,CAAA,EAAA,CAAA;AAAA;AAAA,SAAA,EAAA,IAAA,EAAA,CAAA,oBAAA,EAAA,QAAA,EAAA,cAAA,EAAA,wBAAA,EAAA,mBAAA,CAAA,CAAA;;AAAA,MAAA,CAAA,EAAA,CAAA;AAAA;AAAA,KAAA,EAAA,CAAA,EAAA,CAAA,WAAA,EAAA,SAAA,EAAA,WAAA,EAAA,OAAA,CAAA,CAAA;;;;;;;"}
1
+ {"version":3,"file":"hierarchical-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/hierarchical-filter.vue"],"sourcesContent":["<template>\n <div class=\"x-hierarchical-filter-container\" data-test=\"hierarchical-filter-container\">\n <RenderlessFilter\n v-slot=\"{ filter: filterBinding, clickFilter, cssClasses: cssClassesBinding, isDisabled }\"\n :filter=\"filter\"\n :click-events=\"innerClickEvents\"\n :css-classes=\"innerCssClasses\"\n >\n <!--\n @slot The content to render inside the button.\n @binding {Filter} filter - The filter data.\n @binding {Function} clickFilter - The handler to invoke when clicking the filter.\n @binding {VueCssClasses} cssClasses - The CSS classes.\n @binding {boolean} isDisabled - Flag determining the disabled state.\n -->\n <slot\n v-bind=\"{ filter: filterBinding, clickFilter, cssClasses: cssClassesBinding, isDisabled }\"\n >\n <button\n :aria-checked=\"filterBinding.selected.toString()\"\n :class=\"[cssClassesBinding, filterItemClass]\"\n :disabled=\"isDisabled\"\n data-test=\"filter\"\n role=\"checkbox\"\n @click=\"clickFilter\"\n >\n <!--\n @slot The content to render inside the button.\n @binding {Filter} filter - The filter data.\n -->\n <slot name=\"label\" :filter=\"filterBinding\">{{ filterBinding.label }}</slot>\n </button>\n </slot>\n </RenderlessFilter>\n <FiltersList\n v-slot=\"{ filter: childFilter }\"\n :animation=\"childrenAnimation\"\n :filters=\"renderedChildrenFilters\"\n :parent-id=\"filter.id\"\n class=\"x-hierarchical-filter__children\"\n :class=\"childrenFiltersClass\"\n data-test=\"children-filters\"\n >\n <HierarchicalFilter\n :children-animation=\"childrenAnimation\"\n :filter=\"childFilter\"\n :click-events=\"getChildFilterClickEvents(childFilter)\"\n :children-filters-class=\"childrenFiltersClass\"\n :filter-item-class=\"filterItemClass\"\n >\n <template\n #default=\"{\n filter: filterBinding,\n clickFilter,\n cssClasses: cssClassesBinding,\n isDisabled,\n }\"\n >\n <slot\n v-bind=\"{\n filter: filterBinding,\n clickFilter,\n cssClasses: cssClassesBinding,\n isDisabled,\n }\"\n />\n </template>\n <template #label=\"{ filter: filterBinding }\">\n <slot name=\"label\" :filter=\"filterBinding\" />\n </template>\n </HierarchicalFilter>\n </FiltersList>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport type { Filter, HierarchicalFilter as HierarchicalFilterModel } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { isHierarchicalFilter } from '@empathyco/x-types'\nimport { isObject } from '@empathyco/x-utils'\nimport { computed, defineComponent } from 'vue'\nimport { AnimationProp } from '../../../../types'\nimport { facetsXModule } from '../../x-module'\nimport FiltersList from '../lists/filters-list.vue'\nimport RenderlessFilter from './renderless-filter.vue'\n\n/**\n * Renders a hierarchical filter recursively, emitting the needed events when clicked.\n *\n * @public\n */\nexport default defineComponent({\n name: 'HierarchicalFilter',\n xModule: facetsXModule.name,\n components: { FiltersList, RenderlessFilter },\n props: {\n /** The filter data to render. */\n filter: {\n type: Object as PropType<HierarchicalFilterModel>,\n required: true,\n },\n /** The animation component to use for the children filters. */\n childrenAnimation: AnimationProp,\n /**\n * Additional events, with their payload, to emit when the filter is clicked.\n *\n * @public\n */\n clickEvents: Object as PropType<Partial<XEventsTypes>>,\n /** Inheritance CSS classes. */\n cssClasses: {\n type: Array as PropType<(string | Dictionary<boolean>)[]>,\n default: () => [],\n },\n /** Class inherited by content element. */\n childrenFiltersClass: String,\n /** Class inherited by content element. */\n filterItemClass: String,\n },\n setup(props) {\n /**\n * The {@link XEventsTypes} to emit.\n *\n * @returns The events to emit when clicked.\n * @internal\n */\n const innerClickEvents = computed(() => ({\n UserClickedAHierarchicalFilter: props.filter,\n ...props.clickEvents,\n }))\n\n const isFilterPartiallySelected = (filter: HierarchicalFilterModel) => {\n const selectedChildren = filter.children?.filter(filter => filter.selected)\n const filterChildrenLength = filter.children?.length ?? 0\n return (\n !!selectedChildren &&\n ((selectedChildren.length > 0 && selectedChildren.length < filterChildrenLength) ||\n selectedChildren.some(isFilterPartiallySelected))\n )\n }\n\n /**\n * Returns if the filter is partially selected, which means having more than one child filter\n * selected, but not every of them, or having at least one child filter partially selected.\n *\n * @returns True if the filter is partially selected. False otherwise.\n * @internal\n */\n const isPartiallySelected = computed(() => isFilterPartiallySelected(props.filter))\n\n /**\n * Dynamic CSS classes to apply to the component.\n *\n * @returns The dynamic CSS classes to apply to the component.\n * @internal\n */\n const innerCssClasses = computed(() => [\n 'x-hierarchical-filter',\n { 'x-hierarchical-filter--is-partially-selected': isPartiallySelected.value },\n { 'x-hierarchical-filter--is-selected': props.filter.selected },\n { 'x-facet-filter--is-partially-selected': isPartiallySelected.value },\n ...props.cssClasses,\n ])\n\n /**\n * Gets the child filter click events, converting the payload of the events that have a\n * {@link HierarchicalFilter} as payload to the corresponding child filter.\n *\n * @param childFilter - The child filter.\n * @returns The events to emit when clicking a child.\n * @internal\n */\n const getChildFilterClickEvents = (childFilter: HierarchicalFilterModel) => {\n return Object.entries(innerClickEvents.value).reduce((clickEvents, [event, payload]) => {\n return {\n ...clickEvents,\n [event]:\n isObject(payload) &&\n isHierarchicalFilter(payload as unknown as Filter) &&\n childFilter !== (payload as unknown as HierarchicalFilterModel)\n ? childFilter\n : payload,\n }\n }, {} as Partial<XEventsTypes>)\n }\n\n /**\n * List of filters to render, in case that the children's array\n * is empty it will return an empty array instead of inject the ones from the parent.\n *\n * @returns A list of filters.\n * @internal\n */\n const renderedChildrenFilters = computed(() => props.filter.children ?? [])\n\n return {\n innerClickEvents,\n innerCssClasses,\n renderedChildrenFilters,\n getChildFilterClickEvents,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserClickedAFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n- [`UserClickedAHierarchicalFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n filter.\n\n## See it in action\n\nThis component renders a button, which on clicked emits the `UserClickedAFilter` and\n`UserClickedAHierarchicalFilter` events. By default it renders the filter label as the button text.\nIf the provided filter has children filters, this component will render them recursively. Changing\nthe slot content will change it for all of the children.\n\nThe `filter` prop is required. The `clickEvents` prop is optional and allows configuring the events\nto emit on click.\n\n```vue\n<template>\n <HierarchicalFilter :filter=\"filter\" />\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Playing with props\n\nConfiguring the events to emit when the filter is clicked.\n\n```vue\n<template>\n <HierarchicalFilter :clickEvents=\"{ UserClickedAHierarchicalFilter: filter }\" :filter=\"filter\" />\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the default slot content\n\nIn this example, the child filters will also include the label and checkbox.\n\n```vue\n<template>\n <HierarchicalFilter :filter=\"filter\" v-slot=\"{ filter, clickFilter, slotCSSClasses, isDisabled }\">\n <label :class=\"slotCSSClasses\">\n <input @change=\"clickFilter\" :disabled=\"isDisabled\" />\n {{ filter.label }}\n </label>\n </HierarchicalFilter>\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the label slot content\n\n```vue\n<template>\n <HierarchicalFilter :filter=\"filter\">\n <template #label :filter=\"filter\">\n <span class=\"custom-class\">{{ filter.label }}</span>\n </template>\n </HierarchicalFilter>\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing the content with classes\n\nThe `childrenFiltersClass` prop can be used to add classes to the inner filters lists. This is\nuseful to set the indent of the children filters.\n\nThe `filterItemClass` prop can be used to add classes to the filter element itself.\n\n```vue\n<template>\n <HierarchicalFilter\n :filter=\"filter\"\n childrenFiltersClass=\"x-custom-class\"\n filterItemClass=\"x-custom-filter\"\n />\n</template>\n\n<script>\nimport { HierarchicalFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'HierarchicalFilterTest',\n components: {\n HierarchicalFilter,\n },\n date() {\n return {\n filter: {\n id: `categories:men`,\n modelName: 'HierarchicalFilter',\n label: `men`,\n facetId: 'categories',\n parentId: null,\n totalResults: 10,\n children: [],\n selected: false,\n },\n }\n },\n}\n</script>\n```\n</docs>\n"],"names":["_openBlock","_createElementBlock","_createVNode","_withCtx","_renderSlot","_createElementVNode","_normalizeClass","_createTextVNode","_toDisplayString","_normalizeProps","_guardReactiveProps"],"mappings":";;;;;EACO,KAAM,EAAA,iCAAA;AAAA,EAAkC,WAAU,EAAA,+BAAA;;;;;;;AAAvD,EAAA,OAAAA,SAAA,EAAA,EAAAC,kBAAA,CAuEM,OAvEN,UAuEM,EAAA;AAAA,IAtEJC,WA+BmB,CAAA,2BAAA,EAAA;AAAA,MA7BhB,MAAQ,EAAA,IAAA,CAAA,MAAA;AAAA,MACR,cAAc,EAAA,IAAA,CAAA,gBAAA;AAAA,MACd,aAAa,EAAA,IAAA,CAAA,eAAA;AAAA,KAAA,EAAA;AASd,MAAA,OAAA,EAAAC,OAAA,CAAA,CAiBO,EA7BW,MAAA,EAAA,aAAA,EAAe,WAAW,EAAA,UAAA,EAAc,mBAAmB,UAAU,EAAA,KAAA;AAAA,QAYvFC,UAAA,CAiBO,oEAhBa,aAAe,EAAA,WAAA,EAAW,YAAc,iBAAmB,EAAA,UAAA,MAD/E,MAiBO;AAAA,UAdLC,kBAaS,CAAA,QAAA,EAAA;AAAA,YAZN,cAAA,EAAc,aAAc,CAAA,QAAA,CAAS,QAAQ,EAAA;AAAA,YAC7C,KAAA,EAAKC,cAAG,CAAA,CAAA,iBAAA,EAAmB,IAAe,CAAA,eAAA,CAAA,CAAA;AAAA,YAC1C,QAAU,EAAA,UAAA;AAAA,YACX,WAAU,EAAA,QAAA;AAAA,YACV,IAAK,EAAA,UAAA;AAAA,YACJ,OAAO,EAAA,WAAA;AAAA,WAAA,EAAA;AAMR,YAAAF,UAAA,CAA2E,IAAvD,CAAA,MAAA,EAAA,OAAA,EAAA,EAAA,MAAA,EAAQ,aAAa,EAAA,EAAzC,MAA2E;AAAA,cAAAG,eAAA;AAA7B,gBAAAC,eAAA,CAAA,aAAA,CAAc,KAAK,CAAA;AAAA,gBAAA,CAAA;AAAA;AAAA,eAAA;AAAA,aAAA,CAAA;;;;;;;IAIvEN,WAqCc,CAAA,sBAAA,EAAA;AAAA,MAnCX,SAAW,EAAA,IAAA,CAAA,iBAAA;AAAA,MACX,OAAS,EAAA,IAAA,CAAA,uBAAA;AAAA,MACT,aAAW,IAAO,CAAA,MAAA,CAAA,EAAA;AAAA,MACnB,KAAA,EAAKI,cAAC,CAAA,CAAA,iCAAA,EACE,IAAoB,CAAA,oBAAA,CAAA,CAAA;AAAA,MAC5B,WAAU,EAAA,kBAAA;AAAA,KAAA,EAAA;AAEV,MAAA,OAAA,EAAAH,OAAA,CAAA,CA2BqB,UAnCH,WAAW,EAAA,KAAA;AAAA,QAQ7BD,WA2BqB,CAAA,6BAAA,EAAA;AAAA,UA1BlB,oBAAoB,EAAA,IAAA,CAAA,iBAAA;AAAA,UACpB,MAAQ,EAAA,WAAA;AAAA,UACR,cAAA,EAAc,+BAA0B,WAAW,CAAA;AAAA,UACnD,wBAAwB,EAAA,IAAA,CAAA,oBAAA;AAAA,UACxB,mBAAmB,EAAA,IAAA,CAAA,eAAA;AAAA,SAAA,EAAA;AAGjB,UAAA,OAAA,EAAOC,QAOR,CAOE;AAAA,YAd8B,MAAA,EAAA,aAAA;AAAA,YAA2B,WAAA;AAAA,YAAqC,UAAA,EAAA,iBAAA;AAAA,YAA+B,UAAA;AAAA,WAAA,KAAA;YAO/HC,UAOE,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAAK,cAAA,CAAAC,kBAAA,CAAA;AAAA,cANgC,MAAA,EAAA,aAAA;AAAA,cAA6B,WAAA;AAAA,cAAuC,UAAA,EAAA,iBAAA;AAAA,cAAiC,UAAA;AAAA,aAAA,CAAA,CAAA,CAAA;;UAQ9H,KAAK,EAAAP,OAAA,CACd,CAA6C,EAAA,MAAA,EADnB,aAAa,EAAA,KAAA;AAAA,YACvCC,UAAA,CAA6C,IAAzB,CAAA,MAAA,EAAA,OAAA,EAAA,EAAA,MAAA,EAAQ,aAAa,EAAA,CAAA;AAAA,WAAA,CAAA;;;;;;;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"number-range-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/number-range-filter.vue"],"sourcesContent":["<template>\n <RenderlessFilter\n v-slot=\"{ filter: filterBinding, clickFilter, cssClasses: cssClassesBinding, isDisabled }\"\n :css-classes=\"innerCssClasses\"\n :click-events=\"innerClickEvents\"\n :filter=\"filter\"\n >\n <!--\n @slot The control element to render\n @binding {Filter} filter - The filter data\n @binding {() => void} clickFilter - Method that will invoke the needed actions after the user\n clicks the filter.\n @binding {Object} cssClasses - Object containing CSS classes to add to the button\n @binding {Boolean} isDisabled - True if the filter shouldn't be able to be selected by the\n user\n -->\n <slot\n v-bind=\"{\n filter: filterBinding,\n clickFilter,\n cssClasses: cssClassesBinding,\n isDisabled,\n }\"\n >\n <button\n :aria-checked=\"filterBinding.selected.toString()\"\n :class=\"cssClassesBinding\"\n :disabled=\"isDisabled\"\n data-test=\"filter\"\n role=\"checkbox\"\n v-bind=\"$attrs\"\n @click=\"clickFilter\"\n >\n <!--\n @slot The content to render inside the button\n @binding {Filter} filter - The filter data\n -->\n <slot :filter=\"filter\" name=\"label\">{{ filterBinding.label }}</slot>\n </button>\n </slot>\n </RenderlessFilter>\n</template>\n\n<script lang=\"ts\">\nimport type { NumberRangeFilter as NumberRangeFilterModel } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { computed, defineComponent } from 'vue'\nimport { facetsXModule } from '../../x-module'\nimport RenderlessFilter from './renderless-filter.vue'\n\n/**\n * Renders a number range filter, emitting the needed events when clicked.\n *\n * @public\n */\nexport default defineComponent({\n name: 'NumberRangeFilter',\n xModule: facetsXModule.name,\n components: { RenderlessFilter },\n inheritAttrs: false,\n props: {\n /** The filter data to render. */\n filter: {\n type: Object as PropType<NumberRangeFilterModel>,\n required: true,\n },\n /**\n * Additional events, with their payload, to emit when the filter is clicked.\n *\n * @public\n */\n clickEvents: Object as PropType<Partial<XEventsTypes>>,\n /** Inheritance CSS classes. */\n cssClasses: {\n type: Array as PropType<(string | Dictionary<boolean>)[]>,\n default: () => [],\n },\n },\n setup(props: any) {\n /**\n * The {@link XEventsTypes} to emit.\n *\n * @returns The events to emit when clicked.\n * @internal\n */\n const innerClickEvents = computed(() => ({\n UserClickedANumberRangeFilter: props.filter,\n ...props.clickEvents,\n }))\n\n /**\n * Dynamic CSS classes to apply to the component.\n *\n * @returns The dynamic CSS classes to apply to the component.\n * @internal\n */\n const innerCssClasses = computed(() => [\n 'x-number-range-filter',\n { 'x-number-range-filter--is-selected': props.filter.selected },\n ...props.cssClasses,\n ])\n\n return {\n innerClickEvents,\n innerCssClasses,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nThis component emits the following events:\n\n- [`UserClickedAFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n- [`UserClickedANumberRangeFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n\n## See it in action\n\nThis component renders a button which, on clicked, emits the `UserClickedAFilter` and the\n`UserClickedANumberRangeFilter` events. By default, it renders the filter label as the button text.\n\nThe `filter` prop is required. The `clickEvents` prop is optional and allows configuring the events\nto emit on click.\n\n```vue\n<template>\n <NumberRangeFilter :filter=\"filter\" />\n</template>\n\n<script>\nimport { NumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'NumberRangeFilterTest',\n components: {\n NumberRangeFilter,\n },\n date() {\n return {\n filter: {\n id: `price:1-10`,\n modelName: 'NumberRangeFilter',\n label: `From 1 to 10`,\n facetId: 'price',\n range: {\n min: 1,\n max: 10,\n },\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Playing with props\n\nConfiguring the events to emit when the filter is clicked.\n\n```vue\n<template>\n <NumberRangeFilter :clickEvents=\"{ UserClickedANumberRangeFilter: filter }\" :filter=\"filter\" />\n</template>\n\n<script>\nimport { NumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'NumberRangeFilterTest',\n components: {\n NumberRangeFilter,\n },\n date() {\n return {\n filter: {\n id: `price:1-10`,\n modelName: 'NumberRangeFilter',\n label: `From 1 to 10`,\n facetId: 'price',\n range: {\n min: 1,\n max: 10,\n },\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing its contents\n\n```vue\n<template>\n <NumberRangeFilter :filter=\"filter\" v-slot=\"{ filter }\">\n <img src=\"checkbox.png\" />\n <span>{{ filter.label }}</span>\n </NumberRangeFilter>\n</template>\n\n<script>\nimport { NumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'NumberRangeFilterTest',\n components: {\n NumberRangeFilter,\n },\n date() {\n return {\n filter: {\n id: `price:1-10`,\n modelName: 'NumberRangeFilter',\n label: `From 1 to 10`,\n facetId: 'price',\n range: {\n min: 1,\n max: 10,\n },\n selected: false,\n },\n }\n },\n}\n</script>\n```\n</docs>\n"],"names":["_createBlock","_withCtx","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_mergeProps","_createTextVNode","_toDisplayString"],"mappings":";;;;AAAA,MAAA,UAAA,GAAA,CAAA,cAAA,EAAA,UAAA,EAAA,SAAA,CAAA,CAAA;;;sBACEA,WAuCmB,CAAA,2BAAA,EAAA;AAAA,IArChB,aAAa,EAAA,IAAA,CAAA,eAAA;AAAA,IACb,cAAc,EAAA,IAAA,CAAA,gBAAA;AAAA,IACd,MAAQ,EAAA,IAAA,CAAA,MAAA;AAAA,GAAA,EAAA;AALb,IAAA,OAAA,EAAAC,OAAA,CAgBI,CAuBO,EArCW,MAAA,EAAA,aAAA,EAAe,WAAW,EAAA,UAAA,EAAc,mBAAmB,UAAU,EAAA,KAAA;AAAA,MAcvFC,WAuBO,IAvCX,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,QAiBgC,MAAA,EAAA,aAAA;AAAA,QAAuB,WAAA;AAAA,QAAiC,UAAA,EAAA,iBAAA;AAAA,QAA2B,UAAA;AAAA,OAAA,CAAA,CAAA,EAD/G,MAuBO;AAAA,QAfLC,kBAAA,CAcS,UAdTC,UAcS,CAAA;AAAA,UAbN,cAAA,EAAc,aAAc,CAAA,QAAA,CAAS,QAAQ,EAAA;AAAA,UAC7C,KAAO,EAAA,iBAAA;AAAA,UACP,QAAU,EAAA,UAAA;AAAA,UACX,WAAU,EAAA,QAAA;AAAA,UACV,IAAK,EAAA,UAAA;AAAA,SACG,EAAA,IAAA,CAAA,MAAA,EAAM,EACb,OAAA,EAAO,WAAW,EAAA,CAAA,EAAA;AAAA,UAMnBJ,UAAoE,CAAA,IAAA,CAAA,MAAA,EAAA,OAAA,EAAA,EAA7D,MAAQ,EAAA,IAAA,CAAA,MAAA,IAAf,MAAoE;AAAA,YArC5EK,eAAA;AAAA,cAAAC,eAAA,CAqC+C,cAAc,KAAK,CAAA;AAAA,cAAA,CAAA;AAAA;AAAA,aAAA;AAAA,WAAA,CAAA;AArClE,SAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAAA,OAAA,CAAA;;AAAA,IAAA,CAAA,EAAA,CAAA;AAAA;AAAA,GAAA,EAAA,CAAA,EAAA,CAAA,aAAA,EAAA,cAAA,EAAA,QAAA,CAAA,CAAA,CAAA;;;;;;"}
1
+ {"version":3,"file":"number-range-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/number-range-filter.vue"],"sourcesContent":["<template>\n <RenderlessFilter\n v-slot=\"{ filter: filterBinding, clickFilter, cssClasses: cssClassesBinding, isDisabled }\"\n :css-classes=\"innerCssClasses\"\n :click-events=\"innerClickEvents\"\n :filter=\"filter\"\n >\n <!--\n @slot The control element to render\n @binding {Filter} filter - The filter data\n @binding {() => void} clickFilter - Method that will invoke the needed actions after the user\n clicks the filter.\n @binding {Object} cssClasses - Object containing CSS classes to add to the button\n @binding {Boolean} isDisabled - True if the filter shouldn't be able to be selected by the\n user\n -->\n <slot\n v-bind=\"{\n filter: filterBinding,\n clickFilter,\n cssClasses: cssClassesBinding,\n isDisabled,\n }\"\n >\n <button\n :aria-checked=\"filterBinding.selected.toString()\"\n :class=\"cssClassesBinding\"\n :disabled=\"isDisabled\"\n data-test=\"filter\"\n role=\"checkbox\"\n v-bind=\"$attrs\"\n @click=\"clickFilter\"\n >\n <!--\n @slot The content to render inside the button\n @binding {Filter} filter - The filter data\n -->\n <slot :filter=\"filter\" name=\"label\">{{ filterBinding.label }}</slot>\n </button>\n </slot>\n </RenderlessFilter>\n</template>\n\n<script lang=\"ts\">\nimport type { NumberRangeFilter as NumberRangeFilterModel } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { computed, defineComponent } from 'vue'\nimport { facetsXModule } from '../../x-module'\nimport RenderlessFilter from './renderless-filter.vue'\n\n/**\n * Renders a number range filter, emitting the needed events when clicked.\n *\n * @public\n */\nexport default defineComponent({\n name: 'NumberRangeFilter',\n xModule: facetsXModule.name,\n components: { RenderlessFilter },\n inheritAttrs: false,\n props: {\n /** The filter data to render. */\n filter: {\n type: Object as PropType<NumberRangeFilterModel>,\n required: true,\n },\n /**\n * Additional events, with their payload, to emit when the filter is clicked.\n *\n * @public\n */\n clickEvents: Object as PropType<Partial<XEventsTypes>>,\n /** Inheritance CSS classes. */\n cssClasses: {\n type: Array as PropType<(string | Dictionary<boolean>)[]>,\n default: () => [],\n },\n },\n setup(props: any) {\n /**\n * The {@link XEventsTypes} to emit.\n *\n * @returns The events to emit when clicked.\n * @internal\n */\n const innerClickEvents = computed(() => ({\n UserClickedANumberRangeFilter: props.filter,\n ...props.clickEvents,\n }))\n\n /**\n * Dynamic CSS classes to apply to the component.\n *\n * @returns The dynamic CSS classes to apply to the component.\n * @internal\n */\n const innerCssClasses = computed(() => [\n 'x-number-range-filter',\n { 'x-number-range-filter--is-selected': props.filter.selected },\n ...props.cssClasses,\n ])\n\n return {\n innerClickEvents,\n innerCssClasses,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nThis component emits the following events:\n\n- [`UserClickedAFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n- [`UserClickedANumberRangeFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n\n## See it in action\n\nThis component renders a button which, on clicked, emits the `UserClickedAFilter` and the\n`UserClickedANumberRangeFilter` events. By default, it renders the filter label as the button text.\n\nThe `filter` prop is required. The `clickEvents` prop is optional and allows configuring the events\nto emit on click.\n\n```vue\n<template>\n <NumberRangeFilter :filter=\"filter\" />\n</template>\n\n<script>\nimport { NumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'NumberRangeFilterTest',\n components: {\n NumberRangeFilter,\n },\n date() {\n return {\n filter: {\n id: `price:1-10`,\n modelName: 'NumberRangeFilter',\n label: `From 1 to 10`,\n facetId: 'price',\n range: {\n min: 1,\n max: 10,\n },\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Playing with props\n\nConfiguring the events to emit when the filter is clicked.\n\n```vue\n<template>\n <NumberRangeFilter :clickEvents=\"{ UserClickedANumberRangeFilter: filter }\" :filter=\"filter\" />\n</template>\n\n<script>\nimport { NumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'NumberRangeFilterTest',\n components: {\n NumberRangeFilter,\n },\n date() {\n return {\n filter: {\n id: `price:1-10`,\n modelName: 'NumberRangeFilter',\n label: `From 1 to 10`,\n facetId: 'price',\n range: {\n min: 1,\n max: 10,\n },\n selected: false,\n },\n }\n },\n}\n</script>\n```\n\n### Customizing its contents\n\n```vue\n<template>\n <NumberRangeFilter :filter=\"filter\" v-slot=\"{ filter }\">\n <img src=\"checkbox.png\" />\n <span>{{ filter.label }}</span>\n </NumberRangeFilter>\n</template>\n\n<script>\nimport { NumberRangeFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'NumberRangeFilterTest',\n components: {\n NumberRangeFilter,\n },\n date() {\n return {\n filter: {\n id: `price:1-10`,\n modelName: 'NumberRangeFilter',\n label: `From 1 to 10`,\n facetId: 'price',\n range: {\n min: 1,\n max: 10,\n },\n selected: false,\n },\n }\n },\n}\n</script>\n```\n</docs>\n"],"names":["_createBlock","_withCtx","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_mergeProps","_createTextVNode","_toDisplayString"],"mappings":";;;;;;;sBACEA,WAuCmB,CAAA,2BAAA,EAAA;AAAA,IArChB,aAAa,EAAA,IAAA,CAAA,eAAA;AAAA,IACb,cAAc,EAAA,IAAA,CAAA,gBAAA;AAAA,IACd,MAAQ,EAAA,IAAA,CAAA,MAAA;AAAA,GAAA,EAAA;AAWT,IAAA,OAAA,EAAAC,OAAA,CAAA,CAuBO,EArCW,MAAA,EAAA,aAAA,EAAe,WAAW,EAAA,UAAA,EAAc,mBAAmB,UAAU,EAAA,KAAA;AAAA,MAcvFC,UAuBO,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,QAtBqB,MAAA,EAAA,aAAA;AAAA,QAAuB,WAAA;AAAA,QAAiC,UAAA,EAAA,iBAAA;AAAA,QAA2B,UAAA;AAAA,OAAA,CAAA,CAAA,EAD/G,MAuBO;AAAA,QAfLC,kBAAA,CAcS,UAdTC,UAcS,CAAA;AAAA,UAbN,cAAA,EAAc,aAAc,CAAA,QAAA,CAAS,QAAQ,EAAA;AAAA,UAC7C,KAAO,EAAA,iBAAA;AAAA,UACP,QAAU,EAAA,UAAA;AAAA,UACX,WAAU,EAAA,QAAA;AAAA,UACV,IAAK,EAAA,UAAA;AAAA,SACG,EAAA,IAAA,CAAA,MAAA,EAAM,EACb,OAAA,EAAO,WAAW,EAAA,CAAA,EAAA;AAAA,UAMnBJ,UAAoE,CAAA,IAAA,CAAA,MAAA,EAAA,OAAA,EAAA,EAA7D,MAAQ,EAAA,IAAA,CAAA,MAAA,IAAf,MAAoE;AAAA,YAAAK,eAAA;AAA7B,cAAAC,eAAA,CAAA,aAAA,CAAc,KAAK,CAAA;AAAA,cAAA,CAAA;AAAA;AAAA,aAAA;AAAA,WAAA,CAAA;;;;;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"simple-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/simple-filter.vue"],"sourcesContent":["<template>\n <RenderlessFilter\n v-slot=\"{ filter: filterBinding, clickFilter, isDisabled, cssClasses: cssClassesBinding }\"\n :filter=\"filter\"\n :click-events=\"innerClickEvents\"\n :css-classes=\"innerCssClasses\"\n >\n <!--\n @slot The control element to render\n @binding {Filter} filter - The filter data\n @binding {() => void} clickFilter - Method that will invoke the needed actions after the user\n clicks the filter.\n @binding {Boolean} isDisabled - True if the filter shouldn't be able to be selected by the\n user\n @binding {Object} cssClasses - Object containing CSS classes to add to the button\n -->\n <slot\n v-bind=\"{\n filter: filterBinding,\n clickFilter,\n isDisabled,\n cssClasses: cssClassesBinding,\n }\"\n >\n <button\n :aria-checked=\"filterBinding.selected.toString()\"\n :class=\"cssClassesBinding\"\n :disabled=\"isDisabled\"\n data-test=\"filter\"\n role=\"checkbox\"\n v-bind=\"$attrs\"\n @click=\"clickFilter\"\n >\n <!--\n @slot The content to render inside the button\n @binding {Filter} filter - The filter data\n -->\n <slot :filter=\"filter\" name=\"label\">{{ filterBinding.label }}</slot>\n </button>\n </slot>\n </RenderlessFilter>\n</template>\n\n<script lang=\"ts\">\nimport type { SimpleFilter as SimpleFilterModel } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { computed, defineComponent } from 'vue'\nimport { facetsXModule } from '../../x-module'\nimport RenderlessFilter from './renderless-filter.vue'\n\n/**\n * Renders a simple filter, emitting the needed events when clicked.\n *\n * @public\n */\nexport default defineComponent({\n name: 'SimpleFilter',\n xModule: facetsXModule.name,\n components: { RenderlessFilter },\n inheritAttrs: false,\n props: {\n /** The filter data to render. */\n filter: {\n type: Object as PropType<SimpleFilterModel>,\n required: true,\n },\n /** Additional events, with their payload, to emit when the filter is clicked. */\n clickEvents: Object as PropType<Partial<XEventsTypes>>,\n /** Inheritance CSS classes. */\n cssClasses: {\n type: Array as PropType<(string | Dictionary<boolean>)[]>,\n default: () => [],\n },\n },\n setup(props) {\n /** The {@link XEventsTypes} to emit. */\n const innerClickEvents = computed(() => ({\n UserClickedASimpleFilter: props.filter,\n ...props.clickEvents,\n }))\n\n /** CSS classes to apply to the element. */\n const innerCssClasses = computed(() => [\n 'x-simple-filter',\n { 'x-simple-filter--is-selected': props.filter.selected },\n ...props.cssClasses,\n ])\n\n return {\n innerClickEvents,\n innerCssClasses,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserClickedAFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n- [`UserClickedASimpleFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n\n## See it in action\n\nThis component renders a button, which on clicked emits the `UserClickedAFilter` and the\n`UserClickedASimpleFilter` events. By default, it renders a `button` with the `filter.label`\nproperty as text.\n\nThe `filter` prop is required. The `clickEvents` prop is optional and allows configuring the events\nto emit on click.\n\n```vue\n<template>\n <SimpleFilter :filter=\"filter\" />\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n\n### Playing with props\n\nConfiguring the events to emit when the filter is clicked.\n\n```vue\n<template>\n <SimpleFilter :clickEvents=\"{ UserClickedASimpleFilter: filter }\" :filter=\"filter\" />\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n\n### Rendering an input\n\nYou can change the rendered control using the default slot. Note that because of the current Vue\nlimitations, you must only render one single root node in this slot. There you will receive all the\ndata and methods needed:\n\n```vue\n<template>\n <SimpleFilter v-slot=\"{ filter, clickFilter, isDisabled, cssClasses }\" :filter=\"filter\">\n <label :class=\"cssClasses\">\n <input :checked=\"filter.selected\" type=\"checkbox\" @change=\"clickFilter\" />\n {{ filter.label }}\n </label>\n </SimpleFilter>\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n label: 'Shirts',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n\n### Changing default button content\n\nYou can change the content rendered by the default button using the `label` slot. There you will\nreceive the filter data.\n\n```vue\n<template>\n <SimpleFilter :filter=\"filter\">\n <template #label=\"{ filter }\">\n <img :src=\"`imgs/filters/${filter.id}.png`\" />\n <span>{{ filter.label }}</span>\n </template>\n </SimpleFilter>\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n label: 'Shirts',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n</docs>\n"],"names":["_createBlock","_withCtx","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_mergeProps","_createTextVNode","_toDisplayString"],"mappings":";;;;AAAA,MAAA,UAAA,GAAA,CAAA,cAAA,EAAA,UAAA,EAAA,SAAA,CAAA,CAAA;;;sBACEA,WAuCmB,CAAA,2BAAA,EAAA;AAAA,IArChB,MAAQ,EAAA,IAAA,CAAA,MAAA;AAAA,IACR,cAAc,EAAA,IAAA,CAAA,gBAAA;AAAA,IACd,aAAa,EAAA,IAAA,CAAA,eAAA;AAAA,GAAA,EAAA;AALlB,IAAA,OAAA,EAAAC,OAAA,CAgBI,CAuBO,EArCW,MAAA,EAAA,aAAA,EAAe,WAAa,EAAA,UAAA,EAAU,YAAc,iBAAiB,EAAA,KAAA;AAAA,MAcvFC,WAuBO,IAvCX,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,QAiBgC,MAAA,EAAA,aAAA;AAAA,QAAuB,WAAA;AAAA,QAAqB,UAAA;AAAA,QAAgC,UAAA,EAAA,iBAAA;AAAA,OAAA,CAAA,CAAA,EADxG,MAuBO;AAAA,QAfLC,kBAAA,CAcS,UAdTC,UAcS,CAAA;AAAA,UAbN,cAAA,EAAc,aAAc,CAAA,QAAA,CAAS,QAAQ,EAAA;AAAA,UAC7C,KAAO,EAAA,iBAAA;AAAA,UACP,QAAU,EAAA,UAAA;AAAA,UACX,WAAU,EAAA,QAAA;AAAA,UACV,IAAK,EAAA,UAAA;AAAA,SACG,EAAA,IAAA,CAAA,MAAA,EAAM,EACb,OAAA,EAAO,WAAW,EAAA,CAAA,EAAA;AAAA,UAMnBJ,UAAoE,CAAA,IAAA,CAAA,MAAA,EAAA,OAAA,EAAA,EAA7D,MAAQ,EAAA,IAAA,CAAA,MAAA,IAAf,MAAoE;AAAA,YArC5EK,eAAA;AAAA,cAAAC,eAAA,CAqC+C,cAAc,KAAK,CAAA;AAAA,cAAA,CAAA;AAAA;AAAA,aAAA;AAAA,WAAA,CAAA;AArClE,SAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAAA,OAAA,CAAA;;AAAA,IAAA,CAAA,EAAA,CAAA;AAAA;AAAA,GAAA,EAAA,CAAA,EAAA,CAAA,QAAA,EAAA,cAAA,EAAA,aAAA,CAAA,CAAA,CAAA;;;;;;"}
1
+ {"version":3,"file":"simple-filter.vue.js","sources":["../../../../../../src/x-modules/facets/components/filters/simple-filter.vue"],"sourcesContent":["<template>\n <RenderlessFilter\n v-slot=\"{ filter: filterBinding, clickFilter, isDisabled, cssClasses: cssClassesBinding }\"\n :filter=\"filter\"\n :click-events=\"innerClickEvents\"\n :css-classes=\"innerCssClasses\"\n >\n <!--\n @slot The control element to render\n @binding {Filter} filter - The filter data\n @binding {() => void} clickFilter - Method that will invoke the needed actions after the user\n clicks the filter.\n @binding {Boolean} isDisabled - True if the filter shouldn't be able to be selected by the\n user\n @binding {Object} cssClasses - Object containing CSS classes to add to the button\n -->\n <slot\n v-bind=\"{\n filter: filterBinding,\n clickFilter,\n isDisabled,\n cssClasses: cssClassesBinding,\n }\"\n >\n <button\n :aria-checked=\"filterBinding.selected.toString()\"\n :class=\"cssClassesBinding\"\n :disabled=\"isDisabled\"\n data-test=\"filter\"\n role=\"checkbox\"\n v-bind=\"$attrs\"\n @click=\"clickFilter\"\n >\n <!--\n @slot The content to render inside the button\n @binding {Filter} filter - The filter data\n -->\n <slot :filter=\"filter\" name=\"label\">{{ filterBinding.label }}</slot>\n </button>\n </slot>\n </RenderlessFilter>\n</template>\n\n<script lang=\"ts\">\nimport type { SimpleFilter as SimpleFilterModel } from '@empathyco/x-types'\nimport type { Dictionary } from '@empathyco/x-utils'\nimport type { PropType } from 'vue'\nimport type { XEventsTypes } from '../../../../wiring/events.types'\nimport { computed, defineComponent } from 'vue'\nimport { facetsXModule } from '../../x-module'\nimport RenderlessFilter from './renderless-filter.vue'\n\n/**\n * Renders a simple filter, emitting the needed events when clicked.\n *\n * @public\n */\nexport default defineComponent({\n name: 'SimpleFilter',\n xModule: facetsXModule.name,\n components: { RenderlessFilter },\n inheritAttrs: false,\n props: {\n /** The filter data to render. */\n filter: {\n type: Object as PropType<SimpleFilterModel>,\n required: true,\n },\n /** Additional events, with their payload, to emit when the filter is clicked. */\n clickEvents: Object as PropType<Partial<XEventsTypes>>,\n /** Inheritance CSS classes. */\n cssClasses: {\n type: Array as PropType<(string | Dictionary<boolean>)[]>,\n default: () => [],\n },\n },\n setup(props) {\n /** The {@link XEventsTypes} to emit. */\n const innerClickEvents = computed(() => ({\n UserClickedASimpleFilter: props.filter,\n ...props.clickEvents,\n }))\n\n /** CSS classes to apply to the element. */\n const innerCssClasses = computed(() => [\n 'x-simple-filter',\n { 'x-simple-filter--is-selected': props.filter.selected },\n ...props.cssClasses,\n ])\n\n return {\n innerClickEvents,\n innerCssClasses,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Events\n\nA list of events that the component will emit:\n\n- [`UserClickedAFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n- [`UserClickedASimpleFilter`](https://github.com/empathyco/x/blob/main/packages/x-components/src/wiring/events.types.ts):\n the event is emitted after the user clicks the button, using the `filter` prop as its payload.\n\n## See it in action\n\nThis component renders a button, which on clicked emits the `UserClickedAFilter` and the\n`UserClickedASimpleFilter` events. By default, it renders a `button` with the `filter.label`\nproperty as text.\n\nThe `filter` prop is required. The `clickEvents` prop is optional and allows configuring the events\nto emit on click.\n\n```vue\n<template>\n <SimpleFilter :filter=\"filter\" />\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n\n### Playing with props\n\nConfiguring the events to emit when the filter is clicked.\n\n```vue\n<template>\n <SimpleFilter :clickEvents=\"{ UserClickedASimpleFilter: filter }\" :filter=\"filter\" />\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n\n### Rendering an input\n\nYou can change the rendered control using the default slot. Note that because of the current Vue\nlimitations, you must only render one single root node in this slot. There you will receive all the\ndata and methods needed:\n\n```vue\n<template>\n <SimpleFilter v-slot=\"{ filter, clickFilter, isDisabled, cssClasses }\" :filter=\"filter\">\n <label :class=\"cssClasses\">\n <input :checked=\"filter.selected\" type=\"checkbox\" @change=\"clickFilter\" />\n {{ filter.label }}\n </label>\n </SimpleFilter>\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n label: 'Shirts',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n\n### Changing default button content\n\nYou can change the content rendered by the default button using the `label` slot. There you will\nreceive the filter data.\n\n```vue\n<template>\n <SimpleFilter :filter=\"filter\">\n <template #label=\"{ filter }\">\n <img :src=\"`imgs/filters/${filter.id}.png`\" />\n <span>{{ filter.label }}</span>\n </template>\n </SimpleFilter>\n</template>\n\n<script>\nimport { SimpleFilter } from '@empathyco/x-components/facets'\n\nexport default {\n name: 'SimpleFilterTest',\n components: {\n SimpleFilter,\n },\n data() {\n return {\n filter: {\n modelName: 'SimpleFilter',\n selected: false,\n id: 'category:shirts',\n value: 'category:shirts',\n facetId: 'category',\n label: 'Shirts',\n totalResults: 10,\n },\n }\n },\n}\n</script>\n```\n</docs>\n"],"names":["_createBlock","_withCtx","_renderSlot","_normalizeProps","_guardReactiveProps","_createElementVNode","_mergeProps","_createTextVNode","_toDisplayString"],"mappings":";;;;;;;sBACEA,WAuCmB,CAAA,2BAAA,EAAA;AAAA,IArChB,MAAQ,EAAA,IAAA,CAAA,MAAA;AAAA,IACR,cAAc,EAAA,IAAA,CAAA,gBAAA;AAAA,IACd,aAAa,EAAA,IAAA,CAAA,eAAA;AAAA,GAAA,EAAA;AAWd,IAAA,OAAA,EAAAC,OAAA,CAAA,CAuBO,EArCW,MAAA,EAAA,aAAA,EAAe,WAAa,EAAA,UAAA,EAAU,YAAc,iBAAiB,EAAA,KAAA;AAAA,MAcvFC,UAuBO,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAAC,cAAA,CAAAC,kBAAA,CAAA;AAAA,QAtBqB,MAAA,EAAA,aAAA;AAAA,QAAuB,WAAA;AAAA,QAAqB,UAAA;AAAA,QAAgC,UAAA,EAAA,iBAAA;AAAA,OAAA,CAAA,CAAA,EADxG,MAuBO;AAAA,QAfLC,kBAAA,CAcS,UAdTC,UAcS,CAAA;AAAA,UAbN,cAAA,EAAc,aAAc,CAAA,QAAA,CAAS,QAAQ,EAAA;AAAA,UAC7C,KAAO,EAAA,iBAAA;AAAA,UACP,QAAU,EAAA,UAAA;AAAA,UACX,WAAU,EAAA,QAAA;AAAA,UACV,IAAK,EAAA,UAAA;AAAA,SACG,EAAA,IAAA,CAAA,MAAA,EAAM,EACb,OAAA,EAAO,WAAW,EAAA,CAAA,EAAA;AAAA,UAMnBJ,UAAoE,CAAA,IAAA,CAAA,MAAA,EAAA,OAAA,EAAA,EAA7D,MAAQ,EAAA,IAAA,CAAA,MAAA,IAAf,MAAoE;AAAA,YAAAK,eAAA;AAA7B,cAAAC,eAAA,CAAA,aAAA,CAAc,KAAK,CAAA;AAAA,cAAA,CAAA;AAAA;AAAA,aAAA;AAAA,WAAA,CAAA;;;;;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"filters-list.vue.js","sources":["../../../../../../src/x-modules/facets/components/lists/filters-list.vue"],"sourcesContent":["<template>\n <component\n :is=\"animation\"\n v-if=\"hasFiltersToRender\"\n tag=\"ul\"\n class=\"x-filters\"\n :class=\"cssClasses\"\n data-test=\"base-filters\"\n >\n <li\n v-for=\"filter in renderedFilters\"\n :key=\"filter.id\"\n class=\"x-filters__item\"\n data-test=\"base-filters-item\"\n >\n <!--\n @slot (Required) Filter content\n @binding {Filter} filter - Search-types filter data.\n -->\n <slot :filter=\"filter\" />\n </li>\n </component>\n</template>\n\n<script lang=\"ts\">\nimport type { Filter } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport type { VueCSSClasses } from '../../../../utils/types'\nimport { computed, defineComponent } from 'vue'\nimport { AnimationProp } from '../../../../types/animation-prop'\nimport { useFiltersInjection } from '../../composables/use-filters-injection'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Renders a list with a list item per each\n * {@link @empathyco/x-types#BooleanFilter} in the filters prop array.\n * Each list item has a scoped slot, passing the filter as slot prop.\n *\n * @public\n */\nexport default defineComponent({\n name: 'FiltersList',\n xModule: facetsXModule.name,\n props: {\n /**\n * The list of filters to be rendered as slots.\n *\n * @public\n */\n filters: Array as PropType<Filter[]>,\n\n /**\n * This prop is used in the `HierarchicalFilter` component and only in that case. It is necessary\n * to make the `renderedFilters` to return only the filters of each level of the hierarchy.\n *\n * @public\n */\n parentId: {\n type: String as PropType<Filter['id']>,\n required: false,\n },\n\n /**\n * Animation component that will be used to animate the base filters.\n *\n * @public\n */\n animation: {\n type: AnimationProp,\n default: 'ul',\n },\n },\n setup(props) {\n const renderedFilters = useFiltersInjection(props)\n\n /**\n * It handles if the filters should be rendered.\n *\n * @returns True if there are filters.\n *\n * @public\n */\n const hasFiltersToRender = computed(() => {\n return renderedFilters?.value.length > 0\n })\n\n /**\n * Checks if at least one filter is selected.\n *\n * @returns True if at least one filter is selected. False otherwise.\n * @internal\n */\n const hasSelectedFilters = computed(() => {\n return !!renderedFilters?.value.some(filter => filter.selected)\n })\n\n /**\n * Dynamic CSS classes for the root element of this component.\n *\n * @returns An object containing the dynamic CSS classes and a boolean indicating if they should\n * be added or not.\n */\n const cssClasses = computed((): VueCSSClasses => {\n return {\n 'x-filters--has-selected-filters': hasSelectedFilters.value,\n }\n })\n\n return {\n hasFiltersToRender,\n cssClasses,\n renderedFilters,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-filters {\n list-style-type: none;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Examples\n\nRenders a list with a list item per each filter in the filters prop array. Each list item has a\nscoped slot, passing the filter as slot prop.\n\n### Important\n\nThe component has two ways of receive the filters list, it can be injected by another component or\nbe send it as a prop. If the component doesnt have a parent component that receive and exposed a\nfilters list to their children, it is mandatory to send it as prop.\n\n### Basic usage\n\nUsing default slot:\n\n```vue\n<FiltersList :filters=\"filters\">\n <template #default=\"{ filter }\">\n <p>{{ filter.label }}</p>\n </template>\n</FiltersList>\n```\n\nUsing default slot abbreviated syntax:\n\n```vue\n<FiltersList :filters=\"filters\" v-slot=\"{ filter }\">\n <p>{{ filter.label }}</p>\n</FiltersList>\n```\n\n> **Using injection**: It can receive the filters list by injection. It only works if it has a\n> parent component that receives and exposes the filters list. Using the injection, It is not\n> necessary to send the prop to the child components, it has to be send it in the parent component ,\n> the rest of components will inject this list.\n\n```vue\n<SlicedFilters :filters=\"filters\">\n <FiltersList v-slot=\"{ filter }\">\n <p>{{ filter.label }}</p>\n </FiltersList>\n</SlicedFilters>\n```\n</docs>\n"],"names":["_openBlock","_createBlock","_resolveDynamicComponent","_normalizeClass","_withCtx","_createElementBlock","_Fragment","_renderList","_renderSlot","_createCommentVNode"],"mappings":";;;;;;SAGU,IAFR,CAAA,kBAAA,IAAAA,SAAA,EAAA,EAAAC,WAAA,CAoBYC,wBAnBL,IAAS,CAAA,SAAA,CAAA,EAAA;AAAA,IAFlB,GAAA,EAAA,CAAA;AAAA,IAII,GAAI,EAAA,IAAA;AAAA,IACJ,KAAA,EALJC,cAKU,CAAA,CAAA,WAAA,EACE,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,IAClB,WAAU,EAAA,cAAA;AAAA,GAAA,EAAA;AAPd,IAAA,OAAA,EAAAC,OAAA,CAUM,MAAiC;AAAA,OADnCJ,SAAA,CAAA,IAAA,CAAA,EAAAK,kBAAA;AAAA,QAWKC,QAAA;AAAA,QAAA,IAAA;AAAA,QApBTC,UAAA,CAUuB,IAVvB,CAAA,eAAA,EAAA,CAUa,MAAM,KAAA;8BADfF,kBAWK,CAAA,IAAA,EAAA;AAAA,YATF,KAAK,MAAO,CAAA,EAAA;AAAA,YACb,KAAM,EAAA,iBAAA;AAAA,YACN,WAAU,EAAA,mBAAA;AAAA,WAAA,EAAA;AAMV,YAAAG,UAAA,CAAyB,0BAAlB,MAAc,EAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA;AAAA,WAAA,CAAA,CAAA;;;;;;AAnB3B,IAAA,CAAA,EAAA,CAAA;AAAA;AAAA,GAAA,EAAA,CAAA,EAAA,CAAA,OAAA,CAAA,CAAA,IAAAC,kBAAA,CAAA,MAAA,EAAA,IAAA,CAAA,CAAA;;;;;;"}
1
+ {"version":3,"file":"filters-list.vue.js","sources":["../../../../../../src/x-modules/facets/components/lists/filters-list.vue"],"sourcesContent":["<template>\n <component\n :is=\"animation\"\n v-if=\"hasFiltersToRender\"\n tag=\"ul\"\n class=\"x-filters\"\n :class=\"cssClasses\"\n data-test=\"base-filters\"\n >\n <li\n v-for=\"filter in renderedFilters\"\n :key=\"filter.id\"\n class=\"x-filters__item\"\n data-test=\"base-filters-item\"\n >\n <!--\n @slot (Required) Filter content\n @binding {Filter} filter - Search-types filter data.\n -->\n <slot :filter=\"filter\" />\n </li>\n </component>\n</template>\n\n<script lang=\"ts\">\nimport type { Filter } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport type { VueCSSClasses } from '../../../../utils/types'\nimport { computed, defineComponent } from 'vue'\nimport { AnimationProp } from '../../../../types/animation-prop'\nimport { useFiltersInjection } from '../../composables/use-filters-injection'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Renders a list with a list item per each\n * {@link @empathyco/x-types#BooleanFilter} in the filters prop array.\n * Each list item has a scoped slot, passing the filter as slot prop.\n *\n * @public\n */\nexport default defineComponent({\n name: 'FiltersList',\n xModule: facetsXModule.name,\n props: {\n /**\n * The list of filters to be rendered as slots.\n *\n * @public\n */\n filters: Array as PropType<Filter[]>,\n\n /**\n * This prop is used in the `HierarchicalFilter` component and only in that case. It is necessary\n * to make the `renderedFilters` to return only the filters of each level of the hierarchy.\n *\n * @public\n */\n parentId: {\n type: String as PropType<Filter['id']>,\n required: false,\n },\n\n /**\n * Animation component that will be used to animate the base filters.\n *\n * @public\n */\n animation: {\n type: AnimationProp,\n default: 'ul',\n },\n },\n setup(props) {\n const renderedFilters = useFiltersInjection(props)\n\n /**\n * It handles if the filters should be rendered.\n *\n * @returns True if there are filters.\n *\n * @public\n */\n const hasFiltersToRender = computed(() => {\n return renderedFilters?.value.length > 0\n })\n\n /**\n * Checks if at least one filter is selected.\n *\n * @returns True if at least one filter is selected. False otherwise.\n * @internal\n */\n const hasSelectedFilters = computed(() => {\n return !!renderedFilters?.value.some(filter => filter.selected)\n })\n\n /**\n * Dynamic CSS classes for the root element of this component.\n *\n * @returns An object containing the dynamic CSS classes and a boolean indicating if they should\n * be added or not.\n */\n const cssClasses = computed((): VueCSSClasses => {\n return {\n 'x-filters--has-selected-filters': hasSelectedFilters.value,\n }\n })\n\n return {\n hasFiltersToRender,\n cssClasses,\n renderedFilters,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-filters {\n list-style-type: none;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Examples\n\nRenders a list with a list item per each filter in the filters prop array. Each list item has a\nscoped slot, passing the filter as slot prop.\n\n### Important\n\nThe component has two ways of receive the filters list, it can be injected by another component or\nbe send it as a prop. If the component doesnt have a parent component that receive and exposed a\nfilters list to their children, it is mandatory to send it as prop.\n\n### Basic usage\n\nUsing default slot:\n\n```vue\n<FiltersList :filters=\"filters\">\n <template #default=\"{ filter }\">\n <p>{{ filter.label }}</p>\n </template>\n</FiltersList>\n```\n\nUsing default slot abbreviated syntax:\n\n```vue\n<FiltersList :filters=\"filters\" v-slot=\"{ filter }\">\n <p>{{ filter.label }}</p>\n</FiltersList>\n```\n\n> **Using injection**: It can receive the filters list by injection. It only works if it has a\n> parent component that receives and exposes the filters list. Using the injection, It is not\n> necessary to send the prop to the child components, it has to be send it in the parent component ,\n> the rest of components will inject this list.\n\n```vue\n<SlicedFilters :filters=\"filters\">\n <FiltersList v-slot=\"{ filter }\">\n <p>{{ filter.label }}</p>\n </FiltersList>\n</SlicedFilters>\n```\n</docs>\n"],"names":["_openBlock","_createBlock","_resolveDynamicComponent","_normalizeClass","_createElementBlock","_Fragment","_renderList","_renderSlot"],"mappings":";;;;;;SAGU,IAFR,CAAA,kBAAA,IAAAA,SAAA,EAAA,EAAAC,WAAA,CAoBYC,wBAnBL,IAAS,CAAA,SAAA,CAAA,EAAA;AAAA,IAAA,GAAA,EAAA,CAAA;IAEd,GAAI,EAAA,IAAA;AAAA,IACJ,KAAA,EAAKC,cAAC,CAAA,CAAA,WAAA,EACE,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,IAClB,WAAU,EAAA,cAAA;AAAA,GAAA,EAAA;qBAGR,MAAiC;AAAA,OADnCH,SAAA,CAAA,IAAA,CAAA,EAAAI,kBAAA;AAAA,QAWKC,QAAA;AAAA,QAAA,IAAA;AAAA,QAVcC,UAAA,CAAA,IAAA,CAAA,eAAA,EAAe,CAAzB,MAAM,KAAA;8BADfF,kBAWK,CAAA,IAAA,EAAA;AAAA,YATF,KAAK,MAAO,CAAA,EAAA;AAAA,YACb,KAAM,EAAA,iBAAA;AAAA,YACN,WAAU,EAAA,mBAAA;AAAA,WAAA,EAAA;AAMV,YAAAG,UAAA,CAAyB,0BAAlB,MAAc,EAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA;AAAA,WAAA,CAAA,CAAA;;;;;;;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"filters-search.vue.js","sources":["../../../../../../src/x-modules/facets/components/lists/filters-search.vue"],"sourcesContent":["<template>\n <div class=\"x-filters-search\" :class=\"cssClasses\" data-test=\"filters-search\">\n <!--\n @slot Search content. It is the content which triggers the filters sifting.\n @binding {string} query - The query to search in filters.\n @binding {Function} setQuery - The function to set the query. The query is passed as\n parameter.\n @binding {Function} clearQuery - The function to clear the query.\n -->\n <slot name=\"search\" v-bind=\"{ query, setQuery, clearQuery }\">\n <input\n :value=\"query\"\n type=\"search\"\n class=\"x-filters-search__input x-input\"\n data-test=\"filters-search-input\"\n aria-label=\"search into the filter values\"\n @input=\"setQuery($event.target.value)\"\n />\n </slot>\n <!--\n @slot (Required) Sifted filters content.\n @binding {Filter[]} siftedFilters - Sifted filters data.\n -->\n <slot :sifted-filters=\"siftedFilters\"></slot>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport type { Filter } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport type { DebouncedFunction, VueCSSClasses } from '../../../../utils/types'\nimport { isBooleanFilter } from '@empathyco/x-types'\nimport { computed, defineComponent, provide, ref, watch } from 'vue'\nimport { debounce } from '../../../../utils/debounce'\nimport { normalizeString } from '../../../../utils/normalize'\nimport { useFiltersInjection } from '../../composables/use-filters-injection'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Renders the filters sifted with the input query.\n *\n * @public\n */\nexport default defineComponent({\n name: 'FiltersSearch',\n xModule: facetsXModule.name,\n props: {\n /**\n * The list of filters to be rendered as slots.\n *\n * @public\n */\n filters: Array as PropType<Filter[]>,\n\n /**\n * This prop is used in the `HierarchicalFilter` component and only in that case. It is necessary\n * to make the `renderedFilters` to return only the filters of each level of the hierarchy.\n *\n * @public\n */\n parentId: {\n type: String as PropType<Filter['id']>,\n required: false,\n },\n\n /** The debounce time for applying the filter sifting. */\n debounceInMs: {\n type: Number,\n default: 200,\n },\n },\n setup(props) {\n const renderedFilters = useFiltersInjection(props)\n\n const query = ref('')\n let setQueryDebounced: DebouncedFunction<[string]>\n\n const debounceInMs = computed(() => props.debounceInMs)\n\n /**\n * Set the debounce function for setting the query debounced.\n *\n * @internal\n */\n const updateSetQueryDebounced = () => {\n setQueryDebounced = debounce(queryDebounced => {\n query.value = queryDebounced\n }, props.debounceInMs)\n }\n watch(debounceInMs, updateSetQueryDebounced, { immediate: true })\n\n /**\n * Sift the array of filters which matches with the query.\n *\n * @returns Array of sifted filters.\n * @internal\n */\n const siftedFilters = computed((): Filter[] => {\n const normalizedQuery = normalizeString(query.value)\n return renderedFilters.value.filter(\n filter =>\n isBooleanFilter(filter) && normalizeString(filter.label).includes(normalizedQuery),\n )\n })\n provide('filters', siftedFilters)\n\n /**\n * Adds the dynamic css classes to the component.\n *\n * @returns The class to be added to the component.\n * @internal\n */\n const cssClasses = computed((): VueCSSClasses => {\n return { 'x-filters-search--is-sifted': !!query.value }\n })\n\n /**\n * Set the query through the debounced function.\n *\n * @param query - The query to sift filters.\n * @internal\n */\n const setQuery = (query: string): void => {\n setQueryDebounced(query)\n }\n\n /**\n * Clear the query.\n *\n * @internal\n */\n const clearQuery = (): void => {\n query.value = ''\n }\n\n return {\n clearQuery,\n setQuery,\n cssClasses,\n siftedFilters,\n query,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-filters-search {\n display: flex;\n flex-flow: column nowrap;\n}\n\n.x-filters-search__input::-ms-clear {\n display: none;\n width: 0;\n height: 0;\n}\n\n.x-filters-search__input::-ms-reveal {\n display: none;\n width: 0;\n height: 0;\n}\n\n.x-filters-search__input::-webkit-search-decoration,\n.x-filters-search__input::-webkit-search-cancel-button,\n.x-filters-search__input::-webkit-search-results-button,\n.x-filters-search__input::-webkit-search-results-decoration {\n display: none;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Examples\n\nIt renders an input and a list of filters passed as prop or being injected. The list of filters can\nbe sifted with the query typed in the input. This component has also a debounce prop to set the time\nin milliseconds to apply the filters search. Moreover, it has two scoped slots. The first one for\ncustomize the search triggering with three slot props; the query, a function to set the query by\nsifting and a third one for cleaning the query. The second scoped slot is required and it is for\ndisplaying the list of filters sifted. It has a slot prop with these filters sifted.\n\n### Important\n\nThe component has two ways of receive the filters list, it can be injected by another component or\nbe send it as a prop. If the component doesnt have a parent component that receive and exposed a\nfilters list to their children, it is mandatory to send it as prop.\n\n### Basic usage\n\nUsing default and required slot:\n\n```vue\n<FiltersSearch :filters=\"filters\" v-slot=\"{ siftedFilters }\">\n <ul v-for=\"filter in siftedFilters\">\n <li :key=\"filter.id\">{{ filter.label }}</li>\n </ul>\n</FiltersSearch>\n```\n\nSetting debounce time:\n\n```vue\n<FiltersSearch :filters=\"filters\" :debounceInMs=\"500\" v-slot=\"{ siftedFilters }\">\n <ul v-for=\"filter in siftedFilters\">\n <li :key=\"filter.id\">{{ filter.label }}</li>\n </ul>\n</FiltersSearch>\n```\n\nReplacing search triggering:\n\n```vue\n<FiltersSearch :filters=\"filters\">\n <template #search=\"{ query, setQuery, clearQuery }\">\n <input\n @input=\"setQuery($event.target.value)\"\n :value=\"query\"\n class=\"x-input x-filters-search__input\"\n :aria-label=\"filtersSearchInputMessage\"/>\n <button @click=\"clearQuery\">X</button>\n </template>\n <template #default=\"{ siftedFilters }\">\n <ul v-for=\"filter in siftedFilters\">\n <li :key=\"filter.id\">{{ filter.label }}</li>\n </ul>\n </template>\n</FiltersSearch>\n```\n\n> **Using injection**: It can receive the filters list by injection. It only works if it has a\n> parent component that receives and exposes the filters list. Using the injection, It is not\n> necessary to send the prop to the child components, it has to be send it in the parent component,\n> the rest of components will inject this list.\n\n```vue\n<Facets v-slot=\"{ facet }\">\n <SlicedFilters :filters=\"facet.filters\" :max=\"8\">\n <FiltersSearch >\n <Filters v-slot=\"{ filter }\">\n <SimpleFilter :filter=\"filter\" data-test=\"brand-filter\" />\n </Filters>\n </FiltersSearch>\n </SlicedFilters>\n</Facets>\n```\n</docs>\n"],"names":["_openBlock","_createElementBlock","_normalizeClass","_renderSlot","_normalizeProps","_createElementVNode"],"mappings":";;;;;AAAA,MAAA,UAAA,GAAA,CAAA,OAAA,CAAA,CAAA;;AACE,EAAA,OAAAA,SAAA,EAAA,EAAAC,kBAAA;AAAA,IAuBM,KAAA;AAAA,IAAA;AAAA,MAvBD,KAAA,EADPC,cACa,CAAA,CAAA,kBAAA,EAA2B,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,MAAE,WAAU,EAAA,gBAAA;AAAA,KAAA;;MAQ1DC,UASO,CAAA,IAAA,CAAA,MAAA,EAAA,QAAA,EAlBXC,2CASkC,IAAK,CAAA,KAAA,EAAA,QAAA,EAAE,eAAQ,UAAE,EAAA,IAAA,CAAA,UAAA,MAA/C,MASO;AAAA,QARLC,kBAOE,CAAA,OAAA,EAAA;AAAA,UANC,KAAO,EAAA,IAAA,CAAA,KAAA;AAAA,UACR,IAAK,EAAA,QAAA;AAAA,UACL,KAAM,EAAA,iCAAA;AAAA,UACN,WAAU,EAAA,sBAAA;AAAA,UACV,YAAW,EAAA,+BAAA;AAAA,UACV,OAAK,EAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,MAAA,KAAE,IAAS,CAAA,QAAA,CAAA,MAAA,CAAO,OAAO,KAAK,CAAA,CAAA;AAAA,SAhB5C,EAAA,IAAA,EAAA,EAAA,EAAA,UAAA,CAAA;AAAA,OAAA,EAAA,IAAA,CAAA;MAuBIF,UAA6C,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAA,EAAtC,eAAgB,IAAa,CAAA,aAAA,EAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA;AAAA,KAAA;;;;;;;;;"}
1
+ {"version":3,"file":"filters-search.vue.js","sources":["../../../../../../src/x-modules/facets/components/lists/filters-search.vue"],"sourcesContent":["<template>\n <div class=\"x-filters-search\" :class=\"cssClasses\" data-test=\"filters-search\">\n <!--\n @slot Search content. It is the content which triggers the filters sifting.\n @binding {string} query - The query to search in filters.\n @binding {Function} setQuery - The function to set the query. The query is passed as\n parameter.\n @binding {Function} clearQuery - The function to clear the query.\n -->\n <slot name=\"search\" v-bind=\"{ query, setQuery, clearQuery }\">\n <input\n :value=\"query\"\n type=\"search\"\n class=\"x-filters-search__input x-input\"\n data-test=\"filters-search-input\"\n aria-label=\"search into the filter values\"\n @input=\"setQuery($event.target.value)\"\n />\n </slot>\n <!--\n @slot (Required) Sifted filters content.\n @binding {Filter[]} siftedFilters - Sifted filters data.\n -->\n <slot :sifted-filters=\"siftedFilters\"></slot>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport type { Filter } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport type { DebouncedFunction, VueCSSClasses } from '../../../../utils/types'\nimport { isBooleanFilter } from '@empathyco/x-types'\nimport { computed, defineComponent, provide, ref, watch } from 'vue'\nimport { debounce } from '../../../../utils/debounce'\nimport { normalizeString } from '../../../../utils/normalize'\nimport { useFiltersInjection } from '../../composables/use-filters-injection'\nimport { facetsXModule } from '../../x-module'\n\n/**\n * Renders the filters sifted with the input query.\n *\n * @public\n */\nexport default defineComponent({\n name: 'FiltersSearch',\n xModule: facetsXModule.name,\n props: {\n /**\n * The list of filters to be rendered as slots.\n *\n * @public\n */\n filters: Array as PropType<Filter[]>,\n\n /**\n * This prop is used in the `HierarchicalFilter` component and only in that case. It is necessary\n * to make the `renderedFilters` to return only the filters of each level of the hierarchy.\n *\n * @public\n */\n parentId: {\n type: String as PropType<Filter['id']>,\n required: false,\n },\n\n /** The debounce time for applying the filter sifting. */\n debounceInMs: {\n type: Number,\n default: 200,\n },\n },\n setup(props) {\n const renderedFilters = useFiltersInjection(props)\n\n const query = ref('')\n let setQueryDebounced: DebouncedFunction<[string]>\n\n const debounceInMs = computed(() => props.debounceInMs)\n\n /**\n * Set the debounce function for setting the query debounced.\n *\n * @internal\n */\n const updateSetQueryDebounced = () => {\n setQueryDebounced = debounce(queryDebounced => {\n query.value = queryDebounced\n }, props.debounceInMs)\n }\n watch(debounceInMs, updateSetQueryDebounced, { immediate: true })\n\n /**\n * Sift the array of filters which matches with the query.\n *\n * @returns Array of sifted filters.\n * @internal\n */\n const siftedFilters = computed((): Filter[] => {\n const normalizedQuery = normalizeString(query.value)\n return renderedFilters.value.filter(\n filter =>\n isBooleanFilter(filter) && normalizeString(filter.label).includes(normalizedQuery),\n )\n })\n provide('filters', siftedFilters)\n\n /**\n * Adds the dynamic css classes to the component.\n *\n * @returns The class to be added to the component.\n * @internal\n */\n const cssClasses = computed((): VueCSSClasses => {\n return { 'x-filters-search--is-sifted': !!query.value }\n })\n\n /**\n * Set the query through the debounced function.\n *\n * @param query - The query to sift filters.\n * @internal\n */\n const setQuery = (query: string): void => {\n setQueryDebounced(query)\n }\n\n /**\n * Clear the query.\n *\n * @internal\n */\n const clearQuery = (): void => {\n query.value = ''\n }\n\n return {\n clearQuery,\n setQuery,\n cssClasses,\n siftedFilters,\n query,\n }\n },\n})\n</script>\n\n<style lang=\"css\" scoped>\n.x-filters-search {\n display: flex;\n flex-flow: column nowrap;\n}\n\n.x-filters-search__input::-ms-clear {\n display: none;\n width: 0;\n height: 0;\n}\n\n.x-filters-search__input::-ms-reveal {\n display: none;\n width: 0;\n height: 0;\n}\n\n.x-filters-search__input::-webkit-search-decoration,\n.x-filters-search__input::-webkit-search-cancel-button,\n.x-filters-search__input::-webkit-search-results-button,\n.x-filters-search__input::-webkit-search-results-decoration {\n display: none;\n}\n</style>\n\n<docs lang=\"mdx\">\n## Examples\n\nIt renders an input and a list of filters passed as prop or being injected. The list of filters can\nbe sifted with the query typed in the input. This component has also a debounce prop to set the time\nin milliseconds to apply the filters search. Moreover, it has two scoped slots. The first one for\ncustomize the search triggering with three slot props; the query, a function to set the query by\nsifting and a third one for cleaning the query. The second scoped slot is required and it is for\ndisplaying the list of filters sifted. It has a slot prop with these filters sifted.\n\n### Important\n\nThe component has two ways of receive the filters list, it can be injected by another component or\nbe send it as a prop. If the component doesnt have a parent component that receive and exposed a\nfilters list to their children, it is mandatory to send it as prop.\n\n### Basic usage\n\nUsing default and required slot:\n\n```vue\n<FiltersSearch :filters=\"filters\" v-slot=\"{ siftedFilters }\">\n <ul v-for=\"filter in siftedFilters\">\n <li :key=\"filter.id\">{{ filter.label }}</li>\n </ul>\n</FiltersSearch>\n```\n\nSetting debounce time:\n\n```vue\n<FiltersSearch :filters=\"filters\" :debounceInMs=\"500\" v-slot=\"{ siftedFilters }\">\n <ul v-for=\"filter in siftedFilters\">\n <li :key=\"filter.id\">{{ filter.label }}</li>\n </ul>\n</FiltersSearch>\n```\n\nReplacing search triggering:\n\n```vue\n<FiltersSearch :filters=\"filters\">\n <template #search=\"{ query, setQuery, clearQuery }\">\n <input\n @input=\"setQuery($event.target.value)\"\n :value=\"query\"\n class=\"x-input x-filters-search__input\"\n :aria-label=\"filtersSearchInputMessage\"/>\n <button @click=\"clearQuery\">X</button>\n </template>\n <template #default=\"{ siftedFilters }\">\n <ul v-for=\"filter in siftedFilters\">\n <li :key=\"filter.id\">{{ filter.label }}</li>\n </ul>\n </template>\n</FiltersSearch>\n```\n\n> **Using injection**: It can receive the filters list by injection. It only works if it has a\n> parent component that receives and exposes the filters list. Using the injection, It is not\n> necessary to send the prop to the child components, it has to be send it in the parent component,\n> the rest of components will inject this list.\n\n```vue\n<Facets v-slot=\"{ facet }\">\n <SlicedFilters :filters=\"facet.filters\" :max=\"8\">\n <FiltersSearch >\n <Filters v-slot=\"{ filter }\">\n <SimpleFilter :filter=\"filter\" data-test=\"brand-filter\" />\n </Filters>\n </FiltersSearch>\n </SlicedFilters>\n</Facets>\n```\n</docs>\n"],"names":["_openBlock","_createElementBlock","_normalizeClass","_renderSlot","_createElementVNode"],"mappings":";;;;;;;AACE,EAAA,OAAAA,SAAA,EAAA,EAAAC,kBAAA;AAAA,IAuBM,KAAA;AAAA,IAAA;AAAA,MAvBD,KAAA,EAAKC,cAAC,CAAA,CAAA,kBAAA,EAA2B,IAAU,CAAA,UAAA,CAAA,CAAA;AAAA,MAAE,WAAU,EAAA,gBAAA;AAAA,KAAA;;AAQ1D,MAAAC,UAAA,CASO,kEATuB,IAAK,CAAA,KAAA,EAAA,QAAA,EAAE,eAAQ,UAAE,EAAA,IAAA,CAAA,UAAA,MAA/C,MASO;AAAA,QARLC,kBAOE,CAAA,OAAA,EAAA;AAAA,UANC,KAAO,EAAA,IAAA,CAAA,KAAA;AAAA,UACR,IAAK,EAAA,QAAA;AAAA,UACL,KAAM,EAAA,iCAAA;AAAA,UACN,WAAU,EAAA,sBAAA;AAAA,UACV,YAAW,EAAA,+BAAA;AAAA,UACV,OAAK,EAAA,MAAA,CAAA,CAAA,CAAA,KAAA,MAAA,CAAA,CAAA,CAAA,GAAA,CAAA,MAAA,KAAE,IAAS,CAAA,QAAA,CAAA,MAAA,CAAO,OAAO,KAAK,CAAA,CAAA;AAAA,SAAA,EAAA,IAAA,EAAA,EAAA,EAAA,UAAA,CAAA;;MAOxCD,UAA6C,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAA,EAAtC,eAAgB,IAAa,CAAA,aAAA,EAAA,EAAA,KAAA,CAAA,EAAA,IAAA,CAAA;AAAA,KAAA;;;;;;;;;"}
@@ -1,6 +1,6 @@
1
1
  import injectCss from '../../../../../tools/inject-css.js';
2
2
 
3
- var css = ".x-filters-search[data-v-4979a051]{display:flex;flex-flow:column nowrap}.x-filters-search__input[data-v-4979a051]::-ms-clear,.x-filters-search__input[data-v-4979a051]::-ms-reveal{display:none;height:0;width:0}.x-filters-search__input[data-v-4979a051]::-webkit-search-cancel-button,.x-filters-search__input[data-v-4979a051]::-webkit-search-decoration,.x-filters-search__input[data-v-4979a051]::-webkit-search-results-button,.x-filters-search__input[data-v-4979a051]::-webkit-search-results-decoration{display:none}";
3
+ var css = ".x-filters-search[data-v-4979a051]{display:flex;flex-flow:column nowrap}.x-filters-search__input[data-v-4979a051]::-ms-clear{display:none;height:0;width:0}.x-filters-search__input[data-v-4979a051]::-ms-reveal{display:none;height:0;width:0}.x-filters-search__input[data-v-4979a051]::-webkit-search-cancel-button,.x-filters-search__input[data-v-4979a051]::-webkit-search-decoration,.x-filters-search__input[data-v-4979a051]::-webkit-search-results-button,.x-filters-search__input[data-v-4979a051]::-webkit-search-results-decoration{display:none}";
4
4
  injectCss(css);
5
5
 
6
6
  export { css, css as default };
@@ -1 +1 @@
1
- {"version":3,"file":"selected-filters-list.vue.js","sources":["../../../../../../src/x-modules/facets/components/lists/selected-filters-list.vue"],"sourcesContent":["<template>\n <SelectedFilters :facets-ids=\"facetsIds\" :always-visible=\"alwaysVisible\">\n <component\n :is=\"animation\"\n class=\"x-selected-filters-list\"\n data-test=\"selected-filters-list\"\n tag=\"ul\"\n >\n <li\n v-for=\"{ slotName, selectedFilter } in mapSlot(selectedFilters)\"\n :key=\"selectedFilter.id\"\n class=\"x-selected-filters-list__item\"\n data-test=\"selected-filters-list-item\"\n >\n <!--\n @slot Custom filter rendering. Dynamic slot defined in the template with the filter\n facet id. It renders the filter label by default.\n @binding {Filter} filter - Filter to render.\n -->\n <slot v-if=\"hasSlot(slotName)\" :name=\"slotName\" :filter=\"selectedFilter\">\n <span class=\"x-tag\">{{ selectedFilter.label }}</span>\n </slot>\n\n <!--\n @slot Default filter rendering. It renders the filter label by default.\n @binding {Filter} filter - Filter to render.\n -->\n <slot v-else name=\"default\" :filter=\"selectedFilter\">\n {{ selectedFilter.label }}\n </slot>\n </li>\n </component>\n </SelectedFilters>\n</template>\n\n<script lang=\"ts\">\nimport type { Facet, Filter } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport { isFacetFilter } from '@empathyco/x-types'\nimport { defineComponent } from 'vue'\nimport { AnimationProp } from '../../../../types'\nimport { toKebabCase } from '../../../../utils/string'\nimport { useFacets } from '../../composables/use-facets'\nimport { facetsXModule } from '../../x-module'\nimport SelectedFilters from './selected-filters.vue'\n\n/**\n * Custom interface to provide a slot name to a Filter.\n *\n * @internal\n */\ninterface RenderFilter {\n slotName: string\n selectedFilter: Filter\n}\n\n/**\n * This component renders a list of selected filters from every facet, or from the facet\n * ids passed as property. It uses the SelectedFilters component (state).\n *\n * It provides two slots: a scoped one which name is the filter facet id; and a default one.\n * Both exposes the filter and renders the filter label by default.\n *\n * The property \"alwaysVisible\" handles if the component is rendered if no filters are selected.\n *\n * @public\n */\nexport default defineComponent({\n name: 'SelectedFiltersList',\n xModule: facetsXModule.name,\n components: { SelectedFilters },\n props: {\n /** Array of facets ids used to get the selected filters for those facets. */\n facetsIds: Array as PropType<Array<Facet['id']>>,\n /** Flag to render the component even if there are no filters selected. */\n alwaysVisible: Boolean,\n /** Animation component that will be used to animate the selected filters list. */\n animation: {\n type: AnimationProp,\n default: 'ul',\n },\n },\n setup(props, { slots }) {\n const { selectedFilters } = useFacets(props)\n\n /**\n * Transforms a dictionary of Filters including the slot name.\n *\n * @param selectedFilters - A list of selected filters without slot name.\n *\n * @returns A dictionary of facets with the slot name.\n */\n function mapSlot(selectedFilters: Filter[]): RenderFilter[] {\n return selectedFilters.map(filter => ({\n slotName: isFacetFilter(filter) ? toKebabCase(filter.facetId as string) : 'default',\n selectedFilter: filter,\n }))\n }\n\n /**\n * Whether the slot is present in the template or not.\n *\n * @param name - The slot name.\n *\n * @returns True is the slot is present in the template. False otherwise.\n */\n function hasSlot(name: string): boolean {\n return !!slots[name]\n }\n\n return {\n selectedFilters,\n mapSlot,\n hasSlot,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Example\n\nThis component renders a list of selected filters from every facet, or from the facets which facets\nids are passed as property. It uses the SelectedFilters component (state).\n\nIt provides two slots: a scoped one which name is the filter facet id; and a default one. Both\nexposes the filter and renders the filter label by default.\n\nThe property \"alwaysVisible\" handles if the component is rendered if no filters are selected.\n\n### Default usage\n\n```vue\n<template>\n <SelectedFiltersList />\n</template>\n\n<script>\nimport { SelectedFiltersList } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n SelectedFiltersList,\n },\n}\n</script>\n```\n\n### Customized usage\n\n```vue\n<template>\n <SelectedFiltersList #default=\"{ filter }\">Default: {{ filter.label }}</SelectedFiltersList>\n</template>\n\n<script>\nimport { SelectedFilters } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n SelectedFilters,\n },\n}\n</script>\n```\n\n```vue\n<template>\n <SelectedFiltersList>\n <template #default=\"{ filter }\">Default: {{ filter.label }}</template>\n <template #brand_facet=\"{ filter }\">Brand: {{ filter.label }}</template>\n <template #age_facet=\"{ filter }\">Age: {{ filter.label }}</template>\n <template #price_facet=\"{ filter }\">Price: {{ filter.label }}</template>\n </SelectedFiltersList>\n</template>\n\n<script>\nimport { SelectedFilters } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n SelectedFilters,\n },\n}\n</script>\n```\n\n#### Always visible\n\nIf \"alwaysVisible\" is true, the component is rendered no matter if there are some filter selected.\nIf \"alwaysVisible\" is false (default), the component is rendered if there are some filter selected.\n\n```vue\n<SelectedFiltersList :alwaysVisible=\"true\" />\n```\n\nOutput:\n\n```html\n<div class=\"x-selected-filters\">\n <ul class=\"x-selected-filters-list\" data-test=\"selected-filters-list\"></ul>\n</div>\n```\n\n#### Providing an array of facet ids\n\nIn this example, the selected filters computed are the ones that match the facet ids passed as\nproperties.\n\n```vue\n<SelectedFilters :facetsIds=\"['brand_facet', 'gender_facet']\" />\n```\n</docs>\n"],"names":["_createBlock","_withCtx","_openBlock","_resolveDynamicComponent","_createElementBlock","_Fragment","_renderList","_renderSlot","_createElementVNode","_toDisplayString","_createTextVNode"],"mappings":";;;;AAoBgB,MAAA,UAAA,GAAA,EAAA,KAAA,EAAM,OAAO,EAAA,CAAA;;;sBAnB3BA,WA+BkB,CAAA,0BAAA,EAAA;AAAA,IA/BA,YAAY,EAAA,IAAA,CAAA,SAAA;AAAA,IAAY,gBAAgB,EAAA,IAAA,CAAA,aAAA;AAAA,GAAA,EAAA;AAD5D,IAAA,OAAA,EAAAC,OAAA,CAEI,MA6BY;AAAA,OA7BZC,SAAA,EAAA,EAAAF,WAAA,CA6BYG,wBA5BL,IAAS,CAAA,SAAA,CAAA,EAAA;AAAA,QACd,KAAM,EAAA,yBAAA;AAAA,QACN,WAAU,EAAA,uBAAA;AAAA,QACV,GAAI,EAAA,IAAA;AAAA,OAAA,EAAA;AANV,QAAA,OAAA,EAAAF,OAAA,CASQ,MAAgE;AAAA,WADlEC,SAAA,CAAA,IAAA,CAAA,EAAAE,kBAAA;AAAA,YAsBKC,QAAA;AAAA,YAAA,IAAA;AAAA,YA9BXC,WAS+C,IAAQ,CAAA,OAAA,CAAA,IAAA,CAAA,eAAe,CATtE,EAAA,CAAA,EASiB,UAAU,cAAc,EAAA,KAAA;kCADnCF,kBAsBK,CAAA,IAAA,EAAA;AAAA,gBApBF,KAAK,cAAe,CAAA,EAAA;AAAA,gBACrB,KAAM,EAAA,+BAAA;AAAA,gBACN,WAAU,EAAA,4BAAA;AAAA,eAAA,EAAA;AAOE,gBAAA,IAAA,CAAA,OAAA,CAAQ,QAAQ,CAAA,GAA5BG,UAEO,CAAA,IAAA,CAAA,MAAA,EAF+B,QAAQ,EAAA;AAAA,kBAnBtD,GAAA,EAAA,CAAA;AAAA,kBAmByD,MAAQ,EAAA,cAAA;AAAA,iBAAA,EAAzD,MAEO;AAAA,kBADLC,kBAAA;AAAA,oBAAqD,MAAA;AAAA,oBAArD,UAAA;AAAA,oBAAqDC,eAAA,CAA9B,eAAe,KAAK,CAAA;AAAA,oBAAA,CAAA;AAAA;AAAA,mBAAA;AAAA,iBAAA,CAAA,GAO7CF,UAEO,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAA;AAAA,kBA7Bf,GAAA,EAAA,CAAA;AAAA,kBA2BqC,MAAQ,EAAA,cAAA;AAAA,iBAAA,EAArC,MAEO;AAAA,kBA7BfG,eAAA;AAAA,oBAAAD,eAAA,CA4Ba,eAAe,KAAK,CAAA;AAAA,oBAAA,CAAA;AAAA;AAAA,mBAAA;AAAA,iBAAA,CAAA;;;;;;;AA5BjC,QAAA,CAAA,EAAA,CAAA;AAAA;AAAA,OAAA,CAAA;;AAAA,IAAA,CAAA,EAAA,CAAA;AAAA;AAAA,GAAA,EAAA,CAAA,EAAA,CAAA,YAAA,EAAA,gBAAA,CAAA,CAAA,CAAA;;;;;;"}
1
+ {"version":3,"file":"selected-filters-list.vue.js","sources":["../../../../../../src/x-modules/facets/components/lists/selected-filters-list.vue"],"sourcesContent":["<template>\n <SelectedFilters :facets-ids=\"facetsIds\" :always-visible=\"alwaysVisible\">\n <component\n :is=\"animation\"\n class=\"x-selected-filters-list\"\n data-test=\"selected-filters-list\"\n tag=\"ul\"\n >\n <li\n v-for=\"{ slotName, selectedFilter } in mapSlot(selectedFilters)\"\n :key=\"selectedFilter.id\"\n class=\"x-selected-filters-list__item\"\n data-test=\"selected-filters-list-item\"\n >\n <!--\n @slot Custom filter rendering. Dynamic slot defined in the template with the filter\n facet id. It renders the filter label by default.\n @binding {Filter} filter - Filter to render.\n -->\n <slot v-if=\"hasSlot(slotName)\" :name=\"slotName\" :filter=\"selectedFilter\">\n <span class=\"x-tag\">{{ selectedFilter.label }}</span>\n </slot>\n\n <!--\n @slot Default filter rendering. It renders the filter label by default.\n @binding {Filter} filter - Filter to render.\n -->\n <slot v-else name=\"default\" :filter=\"selectedFilter\">\n {{ selectedFilter.label }}\n </slot>\n </li>\n </component>\n </SelectedFilters>\n</template>\n\n<script lang=\"ts\">\nimport type { Facet, Filter } from '@empathyco/x-types'\nimport type { PropType } from 'vue'\nimport { isFacetFilter } from '@empathyco/x-types'\nimport { defineComponent } from 'vue'\nimport { AnimationProp } from '../../../../types'\nimport { toKebabCase } from '../../../../utils/string'\nimport { useFacets } from '../../composables/use-facets'\nimport { facetsXModule } from '../../x-module'\nimport SelectedFilters from './selected-filters.vue'\n\n/**\n * Custom interface to provide a slot name to a Filter.\n *\n * @internal\n */\ninterface RenderFilter {\n slotName: string\n selectedFilter: Filter\n}\n\n/**\n * This component renders a list of selected filters from every facet, or from the facet\n * ids passed as property. It uses the SelectedFilters component (state).\n *\n * It provides two slots: a scoped one which name is the filter facet id; and a default one.\n * Both exposes the filter and renders the filter label by default.\n *\n * The property \"alwaysVisible\" handles if the component is rendered if no filters are selected.\n *\n * @public\n */\nexport default defineComponent({\n name: 'SelectedFiltersList',\n xModule: facetsXModule.name,\n components: { SelectedFilters },\n props: {\n /** Array of facets ids used to get the selected filters for those facets. */\n facetsIds: Array as PropType<Array<Facet['id']>>,\n /** Flag to render the component even if there are no filters selected. */\n alwaysVisible: Boolean,\n /** Animation component that will be used to animate the selected filters list. */\n animation: {\n type: AnimationProp,\n default: 'ul',\n },\n },\n setup(props, { slots }) {\n const { selectedFilters } = useFacets(props)\n\n /**\n * Transforms a dictionary of Filters including the slot name.\n *\n * @param selectedFilters - A list of selected filters without slot name.\n *\n * @returns A dictionary of facets with the slot name.\n */\n function mapSlot(selectedFilters: Filter[]): RenderFilter[] {\n return selectedFilters.map(filter => ({\n slotName: isFacetFilter(filter) ? toKebabCase(filter.facetId as string) : 'default',\n selectedFilter: filter,\n }))\n }\n\n /**\n * Whether the slot is present in the template or not.\n *\n * @param name - The slot name.\n *\n * @returns True is the slot is present in the template. False otherwise.\n */\n function hasSlot(name: string): boolean {\n return !!slots[name]\n }\n\n return {\n selectedFilters,\n mapSlot,\n hasSlot,\n }\n },\n})\n</script>\n\n<docs lang=\"mdx\">\n## Example\n\nThis component renders a list of selected filters from every facet, or from the facets which facets\nids are passed as property. It uses the SelectedFilters component (state).\n\nIt provides two slots: a scoped one which name is the filter facet id; and a default one. Both\nexposes the filter and renders the filter label by default.\n\nThe property \"alwaysVisible\" handles if the component is rendered if no filters are selected.\n\n### Default usage\n\n```vue\n<template>\n <SelectedFiltersList />\n</template>\n\n<script>\nimport { SelectedFiltersList } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n SelectedFiltersList,\n },\n}\n</script>\n```\n\n### Customized usage\n\n```vue\n<template>\n <SelectedFiltersList #default=\"{ filter }\">Default: {{ filter.label }}</SelectedFiltersList>\n</template>\n\n<script>\nimport { SelectedFilters } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n SelectedFilters,\n },\n}\n</script>\n```\n\n```vue\n<template>\n <SelectedFiltersList>\n <template #default=\"{ filter }\">Default: {{ filter.label }}</template>\n <template #brand_facet=\"{ filter }\">Brand: {{ filter.label }}</template>\n <template #age_facet=\"{ filter }\">Age: {{ filter.label }}</template>\n <template #price_facet=\"{ filter }\">Price: {{ filter.label }}</template>\n </SelectedFiltersList>\n</template>\n\n<script>\nimport { SelectedFilters } from '@empathyco/x-components/facets'\n\nexport default {\n components: {\n SelectedFilters,\n },\n}\n</script>\n```\n\n#### Always visible\n\nIf \"alwaysVisible\" is true, the component is rendered no matter if there are some filter selected.\nIf \"alwaysVisible\" is false (default), the component is rendered if there are some filter selected.\n\n```vue\n<SelectedFiltersList :alwaysVisible=\"true\" />\n```\n\nOutput:\n\n```html\n<div class=\"x-selected-filters\">\n <ul class=\"x-selected-filters-list\" data-test=\"selected-filters-list\"></ul>\n</div>\n```\n\n#### Providing an array of facet ids\n\nIn this example, the selected filters computed are the ones that match the facet ids passed as\nproperties.\n\n```vue\n<SelectedFilters :facetsIds=\"['brand_facet', 'gender_facet']\" />\n```\n</docs>\n"],"names":["_createBlock","_openBlock","_resolveDynamicComponent","_createElementBlock","_Fragment","_renderList","_renderSlot","_createElementVNode","_toDisplayString","_createTextVNode"],"mappings":";;;;AAoBgB,MAAA,UAAA,GAAA,EAAA,KAAA,EAAM,OAAO,EAAA,CAAA;;;sBAnB3BA,WA+BkB,CAAA,0BAAA,EAAA;AAAA,IA/BA,YAAY,EAAA,IAAA,CAAA,SAAA;AAAA,IAAY,gBAAgB,EAAA,IAAA,CAAA,aAAA;AAAA,GAAA,EAAA;qBACxD,MA6BY;AAAA,OA7BZC,SAAA,EAAA,EAAAD,WAAA,CA6BYE,wBA5BL,IAAS,CAAA,SAAA,CAAA,EAAA;AAAA,QACd,KAAM,EAAA,yBAAA;AAAA,QACN,WAAU,EAAA,uBAAA;AAAA,QACV,GAAI,EAAA,IAAA;AAAA,OAAA,EAAA;yBAGF,MAAgE;AAAA,WADlED,SAAA,CAAA,IAAA,CAAA,EAAAE,kBAAA;AAAA,YAsBKC,QAAA;AAAA,YAAA,IAAA;AAAA,YAAAC,UAAA,CArBoC,IAAQ,CAAA,OAAA,CAAA,IAAA,CAAA,eAAe,CAArD,EAAA,CAAA,EAAA,QAAA,EAAU,cAAc,EAAA,KAAA;kCADnCF,kBAsBK,CAAA,IAAA,EAAA;AAAA,gBApBF,KAAK,cAAe,CAAA,EAAA;AAAA,gBACrB,KAAM,EAAA,+BAAA;AAAA,gBACN,WAAU,EAAA,4BAAA;AAAA,eAAA,EAAA;AAOE,gBAAA,IAAA,CAAA,OAAA,CAAQ,QAAQ,CAAA,GAA5BG,UAEO,CAAA,IAAA,CAAA,MAAA,EAF+B,QAAQ,EAAA;AAAA,kBAAA,GAAA,EAAA,CAAA;kBAAG,MAAQ,EAAA,cAAA;AAAA,iBAAA,EAAzD,MAEO;AAAA,kBADLC,kBAAA;AAAA,oBAAqD,MAAA;AAAA,oBAArD,UAAA;AAAA,oBAAqDC,eAAA,CAA9B,eAAe,KAAK,CAAA;AAAA,oBAAA,CAAA;AAAA;AAAA,mBAAA;AAAA,iBAAA,CAAA,GAO7CF,UAEO,CAAA,IAAA,CAAA,MAAA,EAAA,SAAA,EAAA;AAAA,kBAAA,GAAA,EAAA,CAAA;kBAFsB,MAAQ,EAAA,cAAA;AAAA,iBAAA,EAArC,MAEO;AAAA,kBAAAG,eAAA;AADF,oBAAAD,eAAA,CAAA,cAAA,CAAe,KAAK,CAAA;AAAA,oBAAA,CAAA;AAAA;AAAA,mBAAA;AAAA,iBAAA,CAAA;;;;;;;;;;;;;;;;;;;"}