@salla.sa/twilight-components 2.14.391 → 2.14.393

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 (566) hide show
  1. package/dist/cjs/app-globals-oehrC7QI.js +39 -0
  2. package/dist/cjs/{filepond-DFNeUlJZ.js → filepond-D7RVR_w_.js} +10 -5
  3. package/dist/cjs/{filepond-plugin-file-poster-CdscjCyV.js → filepond-plugin-file-poster-DTuZK2ot.js} +11 -7
  4. package/dist/cjs/{filepond-plugin-file-validate-size-CeIHus23.js → filepond-plugin-file-validate-size-DHc6pF_j.js} +1 -1
  5. package/dist/cjs/filepond-plugin-file-validate-type-DnkcvJVc.js +271 -0
  6. package/dist/cjs/{filepond-plugin-image-edit-BEZKgnin.js → filepond-plugin-image-edit-vrZ1s7kw.js} +1 -1
  7. package/dist/cjs/{filepond-plugin-image-exif-orientation-BsIhjiXV.js → filepond-plugin-image-exif-orientation-Bn5JSzQK.js} +1 -1
  8. package/dist/cjs/{filepond-plugin-image-preview-CgGyHHMF.js → filepond-plugin-image-preview-8qWUFe9n.js} +1 -1
  9. package/dist/cjs/{index-RCgJUM7B.js → index-C5VeFDQ0.js} +1966 -1344
  10. package/dist/cjs/{index-U__MmWip.js → index-CwD81m7i.js} +1 -1
  11. package/dist/cjs/loader.cjs.js +4 -3
  12. package/dist/cjs/salla-accordion-body_2.cjs.entry.js +5 -5
  13. package/dist/cjs/salla-accordion_6.cjs.entry.js +19 -15
  14. package/dist/cjs/salla-add-product-button_4.cjs.entry.js +12 -10
  15. package/dist/cjs/salla-advertisement.cjs.entry.js +3 -3
  16. package/dist/cjs/salla-alert_2.cjs.entry.js +5 -5
  17. package/dist/cjs/salla-app-install-alert.cjs.entry.js +3 -3
  18. package/dist/cjs/salla-apps-icons.cjs.entry.js +3 -3
  19. package/dist/cjs/salla-booking-field_7.cjs.entry.js +25 -23
  20. package/dist/cjs/salla-bullet-delivery.cjs.entry.js +3 -3
  21. package/dist/cjs/salla-cart-coupons.cjs.entry.js +3 -3
  22. package/dist/cjs/salla-cart-item-offers_2.cjs.entry.js +5 -5
  23. package/dist/cjs/salla-comment-form_8.cjs.entry.js +17 -17
  24. package/dist/cjs/salla-conditional-offer.cjs.entry.js +3 -3
  25. package/dist/cjs/salla-contacts.cjs.entry.js +3 -3
  26. package/dist/cjs/salla-cookies-bar.cjs.entry.js +3 -3
  27. package/dist/cjs/salla-count-down.cjs.entry.js +35 -11
  28. package/dist/cjs/salla-custom-fields.cjs.entry.js +3 -3
  29. package/dist/cjs/salla-delivery-promise.cjs.entry.js +1 -1
  30. package/dist/cjs/salla-filters-widget.cjs.entry.js +3 -3
  31. package/dist/cjs/salla-filters.cjs.entry.js +3 -3
  32. package/dist/cjs/salla-fulfillment-methods.cjs.entry.js +1 -1
  33. package/dist/cjs/salla-gifting.cjs.entry.js +3 -3
  34. package/dist/cjs/salla-hook.cjs.entry.js +5 -2
  35. package/dist/cjs/salla-infinite-scroll.cjs.entry.js +3 -3
  36. package/dist/cjs/salla-installment.cjs.entry.js +3 -3
  37. package/dist/cjs/salla-list-tile.cjs.entry.js +3 -3
  38. package/dist/cjs/salla-localization-modal.cjs.entry.js +1 -1
  39. package/dist/cjs/salla-login-modal.cjs.entry.js +4 -5
  40. package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +3 -3
  41. package/dist/cjs/salla-loyalty-program.cjs.entry.js +3 -3
  42. package/dist/cjs/salla-loyalty.cjs.entry.js +3 -3
  43. package/dist/cjs/salla-maintenance-alert.cjs.entry.js +3 -3
  44. package/dist/cjs/salla-map.cjs.entry.js +3 -3
  45. package/dist/cjs/salla-menu.cjs.entry.js +3 -3
  46. package/dist/cjs/salla-metadata.cjs.entry.js +3 -3
  47. package/dist/cjs/salla-multiple-bundle-product-cart_2.cjs.entry.js +5 -5
  48. package/dist/cjs/salla-multiple-bundle-product-options-modal_2.cjs.entry.js +8 -6
  49. package/dist/cjs/salla-multiple-bundle-product.cjs.entry.js +6 -4
  50. package/dist/cjs/salla-notification-item.cjs.entry.js +3 -3
  51. package/dist/cjs/salla-notifications.cjs.entry.js +50 -5
  52. package/dist/cjs/salla-offer-modal.cjs.entry.js +3 -3
  53. package/dist/cjs/salla-offer.cjs.entry.js +3 -3
  54. package/dist/cjs/salla-order-details-multiple-bundle-product.cjs.entry.js +3 -3
  55. package/dist/cjs/salla-order-details-options.cjs.entry.js +3 -3
  56. package/dist/cjs/salla-order-details.cjs.entry.js +6 -4
  57. package/dist/cjs/salla-order-edit-item.cjs.entry.js +3 -3
  58. package/dist/cjs/salla-order-edit.cjs.entry.js +3 -3
  59. package/dist/cjs/salla-order-summary.cjs.entry.js +3 -3
  60. package/dist/cjs/salla-order-totals-card.cjs.entry.js +6 -4
  61. package/dist/cjs/salla-orders.cjs.entry.js +3 -3
  62. package/dist/cjs/salla-payments.cjs.entry.js +3 -3
  63. package/dist/cjs/salla-placeholder.cjs.entry.js +3 -3
  64. package/dist/cjs/salla-price-range.cjs.entry.js +3 -3
  65. package/dist/cjs/salla-product-card.cjs.entry.js +3 -3
  66. package/dist/cjs/salla-product-size-guide.cjs.entry.js +3 -3
  67. package/dist/cjs/salla-products-list.cjs.entry.js +3 -3
  68. package/dist/cjs/salla-products-slider.cjs.entry.js +3 -3
  69. package/dist/cjs/salla-progress-bar.cjs.entry.js +3 -3
  70. package/dist/cjs/salla-quick-order.cjs.entry.js +3 -3
  71. package/dist/cjs/salla-rating-modal.cjs.entry.js +3 -3
  72. package/dist/cjs/salla-scopes.cjs.entry.js +3 -3
  73. package/dist/cjs/salla-search.cjs.entry.js +6 -4
  74. package/dist/cjs/salla-skeleton.cjs.entry.js +3 -3
  75. package/dist/cjs/salla-slider.cjs.entry.js +20 -14
  76. package/dist/cjs/salla-social-share.cjs.entry.js +3 -3
  77. package/dist/cjs/salla-social.cjs.entry.js +3 -3
  78. package/dist/cjs/salla-tab-content_3.cjs.entry.js +7 -7
  79. package/dist/cjs/salla-tiered-offer.cjs.entry.js +3 -3
  80. package/dist/cjs/salla-tooltip.cjs.entry.js +3 -3
  81. package/dist/cjs/salla-trust-badges.cjs.entry.js +3 -3
  82. package/dist/cjs/salla-user-menu.cjs.entry.js +3 -3
  83. package/dist/cjs/salla-user-profile.cjs.entry.js +3 -3
  84. package/dist/cjs/salla-user-settings.cjs.entry.js +3 -3
  85. package/dist/cjs/salla-verify.cjs.entry.js +3 -3
  86. package/dist/cjs/salla-wallet.cjs.entry.js +3 -3
  87. package/dist/cjs/twilight.cjs.js +5 -4
  88. package/dist/cjs/{vanilla-picker-yWlr4I9a.js → vanilla-picker-yKERbLpx.js} +1 -1
  89. package/dist/collection/collection-manifest.json +3 -2
  90. package/dist/collection/components/salla-accordion/salla-accordion-head.js +2 -2
  91. package/dist/collection/components/salla-accordion/salla-accordion.js +4 -4
  92. package/dist/collection/components/salla-add-product-button/salla-add-product-button.js +19 -19
  93. package/dist/collection/components/salla-alert/salla-alert.js +5 -5
  94. package/dist/collection/components/salla-apps-icons/salla-apps-icons.js +6 -6
  95. package/dist/collection/components/salla-booking-field/salla-booking-field.js +4 -4
  96. package/dist/collection/components/salla-bottom-alert/salla-bottom-alert.js +9 -9
  97. package/dist/collection/components/salla-bullet-delivery/salla-bullet-delivery.js +6 -3
  98. package/dist/collection/components/salla-button/salla-button.js +11 -11
  99. package/dist/collection/components/salla-cart-coupons/salla-cart-coupons.js +2 -1
  100. package/dist/collection/components/salla-cart-item-offers/salla-cart-item-offers.js +8 -8
  101. package/dist/collection/components/salla-cart-summary/salla-cart-summary.js +2 -2
  102. package/dist/collection/components/salla-color-picker/salla-color-picker.js +20 -14
  103. package/dist/collection/components/salla-comment-form/salla-comment-form.js +6 -6
  104. package/dist/collection/components/salla-comments/salla-comment-item.js +2 -3
  105. package/dist/collection/components/salla-comments/salla-comments.js +18 -17
  106. package/dist/collection/components/salla-contacts/salla-contacts.js +10 -10
  107. package/dist/collection/components/salla-count-down/salla-count-down.js +66 -42
  108. package/dist/collection/components/salla-custom-fields/salla-custom-fields.js +9 -7
  109. package/dist/collection/components/salla-datetime-picker/salla-datetime-picker.js +69 -65
  110. package/dist/collection/components/salla-drawer/salla-drawer.js +11 -11
  111. package/dist/collection/components/salla-file-upload/salla-file-upload.css +1 -1
  112. package/dist/collection/components/salla-file-upload/salla-file-upload.js +85 -84
  113. package/dist/collection/components/salla-filters/salla-filters.js +2 -2
  114. package/dist/collection/components/salla-filters-widget/salla-filters-widget.js +4 -5
  115. package/dist/collection/components/salla-gifting/salla-gifting.js +11 -11
  116. package/dist/collection/components/salla-hook/salla-hook.js +2 -2
  117. package/dist/collection/components/salla-infinite-scroll/salla-infinite-scroll.js +6 -6
  118. package/dist/collection/components/salla-installment/salla-installment.js +5 -5
  119. package/dist/collection/components/salla-list-tile/salla-list-tile.js +2 -2
  120. package/dist/collection/components/salla-loading/salla-loading.js +4 -4
  121. package/dist/collection/components/salla-localization-modal/salla-localization-modal.js +5 -5
  122. package/dist/collection/components/salla-login-modal/salla-login-modal.js +15 -16
  123. package/dist/collection/components/salla-loyalty/salla-loyalty-prize-item.js +4 -3
  124. package/dist/collection/components/salla-loyalty/salla-loyalty.js +13 -12
  125. package/dist/collection/components/salla-map/salla-map.js +14 -14
  126. package/dist/collection/components/salla-menu/salla-menu.js +10 -9
  127. package/dist/collection/components/salla-metadata/salla-metadata.js +3 -3
  128. package/dist/collection/components/salla-modal/salla-modal.js +11 -11
  129. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-cart.js +2 -2
  130. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-details.js +2 -2
  131. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-options-modal.js +4 -2
  132. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-slider.js +8 -7
  133. package/dist/collection/components/salla-multiple-bundle-product/salla-multiple-bundle-product.js +2 -2
  134. package/dist/collection/components/salla-notifications/salla-notification-item.js +2 -2
  135. package/dist/collection/components/salla-notifications/salla-notifications.js +50 -5
  136. package/dist/collection/components/salla-offer/salla-offer.js +1 -1
  137. package/dist/collection/components/salla-order-details/salla-order-details-multiple-bundle-product.js +5 -5
  138. package/dist/collection/components/salla-order-details/salla-order-details-options.js +6 -5
  139. package/dist/collection/components/salla-order-details/salla-order-details.js +4 -3
  140. package/dist/collection/components/salla-order-edit/salla-order-edit-item.js +4 -4
  141. package/dist/collection/components/salla-order-edit/salla-order-edit.js +4 -4
  142. package/dist/collection/components/salla-order-summary/salla-order-summary.js +2 -2
  143. package/dist/collection/components/salla-order-totals-card/salla-order-totals-card.js +4 -3
  144. package/dist/collection/components/salla-orders/salla-orders.js +4 -4
  145. package/dist/collection/components/salla-payments/salla-payments.js +0 -1
  146. package/dist/collection/components/salla-placeholder/salla-placeholder.js +3 -3
  147. package/dist/collection/components/salla-price-range/salla-price-range.js +8 -8
  148. package/dist/collection/components/salla-product-availability/salla-product-availability.js +6 -6
  149. package/dist/collection/components/salla-product-card/salla-product-card.js +18 -18
  150. package/dist/collection/components/salla-product-options/salla-product-options.js +15 -13
  151. package/dist/collection/components/salla-products-list/salla-products-list.js +20 -21
  152. package/dist/collection/components/salla-products-slider/salla-products-slider.js +22 -23
  153. package/dist/collection/components/salla-progress-bar/salla-progress-bar.js +21 -20
  154. package/dist/collection/components/salla-quantity-input/salla-quantity-input.js +2 -2
  155. package/dist/collection/components/salla-quick-buy/salla-quick-buy.js +16 -17
  156. package/dist/collection/components/salla-quick-order/salla-quick-order.js +11 -11
  157. package/dist/collection/components/salla-rating-modal/salla-rating-modal.js +2 -2
  158. package/dist/collection/components/salla-rating-stars/salla-rating-stars.js +8 -8
  159. package/dist/collection/components/salla-review-card/salla-review-card.js +3 -3
  160. package/dist/collection/components/salla-reviews/salla-reviews.js +16 -13
  161. package/dist/collection/components/salla-reviews-summary/salla-reviews-summary.js +2 -2
  162. package/dist/collection/components/salla-scopes/salla-scopes.js +2 -2
  163. package/dist/collection/components/salla-search/salla-search.js +6 -6
  164. package/dist/collection/components/salla-skeleton/salla-skeleton.js +3 -3
  165. package/dist/collection/components/salla-slider/salla-slider.css +9 -2
  166. package/dist/collection/components/salla-slider/salla-slider.js +25 -25
  167. package/dist/collection/components/salla-social-share/salla-social-share.js +3 -3
  168. package/dist/collection/components/salla-tabs/salla-tab-content.js +2 -2
  169. package/dist/collection/components/salla-tabs/salla-tab-header.js +5 -5
  170. package/dist/collection/components/salla-tabs/salla-tabs.js +2 -2
  171. package/dist/collection/components/salla-tel-input/salla-tel-input.js +9 -8
  172. package/dist/collection/components/salla-tooltip/salla-tooltip.js +5 -5
  173. package/dist/collection/components/salla-trust-badges/salla-trust-badges.js +1 -1
  174. package/dist/collection/components/salla-user-menu/salla-user-menu.js +5 -5
  175. package/dist/collection/components/salla-user-profile/salla-user-profile.js +1 -1
  176. package/dist/collection/components/salla-verify/salla-verify.js +4 -4
  177. package/dist/components/Helper.js +1 -432
  178. package/dist/components/_commonjsHelpers.js +1 -7
  179. package/dist/components/anime.es.js +1 -1310
  180. package/dist/components/arrow-left.js +1 -8
  181. package/dist/components/axios.js +2 -3908
  182. package/dist/components/bell-ring.js +1 -8
  183. package/dist/components/camera.js +1 -8
  184. package/dist/components/cancel.js +1 -8
  185. package/dist/components/cart.js +1 -8
  186. package/dist/components/check-circle2.js +1 -15
  187. package/dist/components/check.js +1 -8
  188. package/dist/components/facebook.js +1 -10
  189. package/dist/components/filepond-plugin-file-poster.js +3 -659
  190. package/dist/components/filepond-plugin-file-validate-size.js +2 -204
  191. package/dist/components/filepond-plugin-file-validate-type.js +3 -279
  192. package/dist/components/filepond-plugin-image-edit.js +2 -487
  193. package/dist/components/filepond-plugin-image-exif-orientation.js +2 -214
  194. package/dist/components/filepond-plugin-image-preview.js +2 -2237
  195. package/dist/components/filepond.js +3 -11282
  196. package/dist/components/gift.js +1 -8
  197. package/dist/components/image.js +1 -8
  198. package/dist/components/index.d.ts +2 -0
  199. package/dist/components/index.js +1 -8163
  200. package/dist/components/index2.js +1 -1709
  201. package/dist/components/index3.js +1 -2550
  202. package/dist/components/interfaces.js +1 -12
  203. package/dist/components/isObject.js +1 -292
  204. package/dist/components/keyboard_arrow_down.js +1 -8
  205. package/dist/components/keyboard_arrow_right.js +1 -15
  206. package/dist/components/location.js +1 -11
  207. package/dist/components/mail.js +1 -8
  208. package/dist/components/minus.js +1 -15
  209. package/dist/components/salla-accordion-body.js +1 -6
  210. package/dist/components/salla-accordion-body2.js +1 -30
  211. package/dist/components/salla-accordion-head.js +1 -6
  212. package/dist/components/salla-accordion-head2.js +1 -63
  213. package/dist/components/salla-accordion.js +1 -6
  214. package/dist/components/salla-accordion2.js +1 -68
  215. package/dist/components/salla-add-product-button.js +1 -6
  216. package/dist/components/salla-add-product-button2.js +1 -306
  217. package/dist/components/salla-advertisement.js +1 -155
  218. package/dist/components/salla-alert.js +1 -59
  219. package/dist/components/salla-app-install-alert.js +1 -91
  220. package/dist/components/salla-apps-icons.js +1 -63
  221. package/dist/components/salla-booking-field.js +1 -6
  222. package/dist/components/salla-booking-field2.js +1 -221
  223. package/dist/components/salla-bottom-alert.js +1 -214
  224. package/dist/components/salla-breadcrumb.js +1 -226
  225. package/dist/components/salla-bullet-delivery.js +1 -2114
  226. package/dist/components/salla-button.js +1 -6
  227. package/dist/components/salla-button2.js +1 -174
  228. package/dist/components/salla-cart-coupons.js +1 -284
  229. package/dist/components/salla-cart-item-offers.js +1 -143
  230. package/dist/components/salla-cart-summary.js +1 -136
  231. package/dist/components/salla-color-picker.js +1 -6
  232. package/dist/components/salla-color-picker2.js +1 -260
  233. package/dist/components/salla-comment-form.js +1 -6
  234. package/dist/components/salla-comment-form2.js +1 -64
  235. package/dist/components/salla-comment-item.js +1 -6
  236. package/dist/components/salla-comment-item2.js +1 -217
  237. package/dist/components/salla-comments.js +1 -395
  238. package/dist/components/salla-conditional-fields.js +1 -6
  239. package/dist/components/salla-conditional-fields2.js +1 -137
  240. package/dist/components/salla-conditional-offer.js +1 -194
  241. package/dist/components/salla-contacts.js +1 -125
  242. package/dist/components/salla-cookies-bar.js +1 -107
  243. package/dist/components/salla-count-down.js +1 -6
  244. package/dist/components/salla-count-down2.js +1 -247
  245. package/dist/components/salla-custom-fields.js +1 -175
  246. package/dist/components/salla-datetime-picker.js +1 -6
  247. package/dist/components/salla-datetime-picker2.js +1 -342
  248. package/dist/components/salla-delivery-promise.js +1 -263
  249. package/dist/components/salla-drawer.js +1 -6
  250. package/dist/components/salla-drawer2.js +1 -214
  251. package/dist/components/salla-file-upload.js +1 -6
  252. package/dist/components/salla-file-upload2.js +1 -583
  253. package/dist/components/salla-filters-widget.js +1 -6
  254. package/dist/components/salla-filters-widget2.js +1 -245
  255. package/dist/components/salla-filters.js +1 -253
  256. package/dist/components/salla-fulfillment-methods.js +1 -61
  257. package/dist/components/salla-gifting.js +1 -732
  258. package/dist/components/salla-hook.js +1 -47
  259. package/dist/components/salla-infinite-scroll.js +1 -112
  260. package/dist/components/salla-installment.js +1 -306
  261. package/dist/components/salla-list-tile.js +1 -6
  262. package/dist/components/salla-list-tile2.js +1 -47
  263. package/dist/components/salla-loading.js +1 -6
  264. package/dist/components/salla-loading2.js +1 -51
  265. package/dist/components/salla-localization-modal.js +1 -296
  266. package/dist/components/salla-login-modal.js +1 -6
  267. package/dist/components/salla-login-modal2.js +1 -360
  268. package/dist/components/salla-loyalty-prize-item.js +1 -39
  269. package/dist/components/salla-loyalty-program.js +1 -115
  270. package/dist/components/salla-loyalty.js +1 -304
  271. package/dist/components/salla-maintenance-alert.js +1 -57
  272. package/dist/components/salla-map.js +1 -6
  273. package/dist/components/salla-map2.js +1 -766
  274. package/dist/components/salla-menu.js +1 -165
  275. package/dist/components/salla-metadata.js +1 -97
  276. package/dist/components/salla-modal.js +1 -6
  277. package/dist/components/salla-modal2.js +1 -215
  278. package/dist/components/salla-multiple-bundle-product-cart.js +1 -6
  279. package/dist/components/salla-multiple-bundle-product-cart2.js +1 -151
  280. package/dist/components/salla-multiple-bundle-product-details.js +1 -6
  281. package/dist/components/salla-multiple-bundle-product-details2.js +1 -296
  282. package/dist/components/salla-multiple-bundle-product-options-modal.js +1 -6
  283. package/dist/components/salla-multiple-bundle-product-options-modal2.js +1 -598
  284. package/dist/components/salla-multiple-bundle-product-slider.js +1 -6
  285. package/dist/components/salla-multiple-bundle-product-slider2.js +1 -136
  286. package/dist/components/salla-multiple-bundle-product.js +1 -207
  287. package/dist/components/salla-notification-item.js +1 -6
  288. package/dist/components/salla-notification-item2.js +1 -32
  289. package/dist/components/salla-notifications.js +1 -145
  290. package/dist/components/salla-offer-modal.js +1 -328
  291. package/dist/components/salla-offer.js +1 -478
  292. package/dist/components/salla-order-details-multiple-bundle-product.js +1 -6
  293. package/dist/components/salla-order-details-multiple-bundle-product2.js +1 -122
  294. package/dist/components/salla-order-details-options.js +1 -6
  295. package/dist/components/salla-order-details-options2.js +1 -140
  296. package/dist/components/salla-order-details.js +1 -122
  297. package/dist/components/salla-order-edit-item.js +1 -6
  298. package/dist/components/salla-order-edit-item2.js +1 -181
  299. package/dist/components/salla-order-edit.js +1 -288
  300. package/dist/components/salla-order-summary.js +1 -132
  301. package/dist/components/salla-order-totals-card.js +1 -87
  302. package/dist/components/salla-orders.js +1 -271
  303. package/dist/components/salla-payments.js +1 -76
  304. package/dist/components/salla-placeholder.js +1 -6
  305. package/dist/components/salla-placeholder2.js +1 -66
  306. package/dist/components/salla-price-range.js +1 -6
  307. package/dist/components/salla-price-range2.js +1 -204
  308. package/dist/components/salla-product-availability.js +1 -6
  309. package/dist/components/salla-product-availability2.js +1 -206
  310. package/dist/components/salla-product-card.js +1 -6
  311. package/dist/components/salla-product-card2.js +1 -241
  312. package/dist/components/salla-product-options.js +1 -6
  313. package/dist/components/salla-product-options2.js +1 -962
  314. package/dist/components/salla-product-size-guide.js +1 -130
  315. package/dist/components/salla-products-list.js +1 -6
  316. package/dist/components/salla-products-list2.js +1 -812
  317. package/dist/components/salla-products-slider.js +1 -6
  318. package/dist/components/salla-products-slider2.js +1 -215
  319. package/dist/components/salla-progress-bar.js +1 -6
  320. package/dist/components/salla-progress-bar2.js +1 -94
  321. package/dist/components/salla-quantity-input.js +1 -6
  322. package/dist/components/salla-quantity-input2.js +1 -127
  323. package/dist/components/salla-quick-buy.js +1 -6
  324. package/dist/components/salla-quick-buy2.js +1 -1181
  325. package/dist/components/salla-quick-order.js +1 -299
  326. package/dist/components/salla-rating-modal.js +1 -530
  327. package/dist/components/salla-rating-stars.js +1 -6
  328. package/dist/components/salla-rating-stars2.js +1 -162
  329. package/dist/components/salla-review-card.js +1 -6
  330. package/dist/components/salla-review-card2.js +1 -198
  331. package/dist/components/salla-reviews-page.js +1 -726
  332. package/dist/components/salla-reviews-summary.js +1 -6
  333. package/dist/components/salla-reviews-summary2.js +1 -132
  334. package/dist/components/salla-reviews.js +1 -143
  335. package/dist/components/salla-scopes.js +1 -249
  336. package/dist/components/salla-search.js +1 -213
  337. package/dist/components/salla-skeleton.js +1 -6
  338. package/dist/components/salla-skeleton2.js +1 -50
  339. package/dist/components/salla-slider.js +1 -6
  340. package/dist/components/salla-slider2.js +1 -10483
  341. package/dist/components/salla-social-share.js +1 -194
  342. package/dist/components/salla-social.js +1 -89
  343. package/dist/components/salla-tab-content.js +1 -6
  344. package/dist/components/salla-tab-content2.js +1 -55
  345. package/dist/components/salla-tab-header.js +1 -6
  346. package/dist/components/salla-tab-header2.js +1 -85
  347. package/dist/components/salla-tabs.js +1 -6
  348. package/dist/components/salla-tabs2.js +1 -75
  349. package/dist/components/salla-tel-input.js +1 -6
  350. package/dist/components/salla-tel-input2.js +1 -168
  351. package/dist/components/salla-tiered-offer.js +1 -366
  352. package/dist/components/salla-tooltip.js +1 -6
  353. package/dist/components/salla-tooltip2.js +1 -57
  354. package/dist/components/salla-trust-badges.js +1 -90
  355. package/dist/components/salla-user-menu.js +1 -344
  356. package/dist/components/salla-user-profile.js +1 -203
  357. package/dist/components/salla-user-settings.js +1 -139
  358. package/dist/components/salla-verify.js +1 -303
  359. package/dist/components/salla-wallet.js +1 -114
  360. package/dist/components/search.js +1 -8
  361. package/dist/components/shopping-bag.js +1 -8
  362. package/dist/components/special-discount.js +1 -8
  363. package/dist/components/star.js +1 -8
  364. package/dist/components/star2.js +1 -8
  365. package/dist/components/vanilla-picker.js +2 -1034
  366. package/dist/components/whatsapp2.js +1 -8
  367. package/dist/esm/app-globals-BFryt7-C.js +37 -0
  368. package/dist/esm/{filepond-dioc1UNj.js → filepond-DlGaLh8N.js} +10 -5
  369. package/dist/esm/{filepond-plugin-file-poster-BpOMmY57.js → filepond-plugin-file-poster-BTVFYcQx.js} +11 -7
  370. package/dist/esm/{filepond-plugin-file-validate-size-D3zrIASS.js → filepond-plugin-file-validate-size-DGryLmWv.js} +1 -1
  371. package/dist/esm/filepond-plugin-file-validate-type-DxKfCD0V.js +269 -0
  372. package/dist/esm/{filepond-plugin-image-edit-vV9cFwQt.js → filepond-plugin-image-edit-2W7pu9hn.js} +1 -1
  373. package/dist/esm/{filepond-plugin-image-exif-orientation-DQHJunT0.js → filepond-plugin-image-exif-orientation-OQu-IvPH.js} +1 -1
  374. package/dist/esm/{filepond-plugin-image-preview-CK8pdQ2g.js → filepond-plugin-image-preview-DEW_tSNR.js} +1 -1
  375. package/dist/esm/{index-B6FFbRiW.js → index-BDqMkCqE.js} +1 -1
  376. package/dist/esm/{index-BBHnyTVS.js → index-DYB20YqN.js} +1966 -1344
  377. package/dist/esm/loader.js +4 -3
  378. package/dist/esm/salla-accordion-body_2.entry.js +5 -5
  379. package/dist/esm/salla-accordion_6.entry.js +19 -15
  380. package/dist/esm/salla-add-product-button_4.entry.js +12 -10
  381. package/dist/esm/salla-advertisement.entry.js +3 -3
  382. package/dist/esm/salla-alert_2.entry.js +5 -5
  383. package/dist/esm/salla-app-install-alert.entry.js +3 -3
  384. package/dist/esm/salla-apps-icons.entry.js +3 -3
  385. package/dist/esm/salla-booking-field_7.entry.js +25 -23
  386. package/dist/esm/salla-bullet-delivery.entry.js +3 -3
  387. package/dist/esm/salla-cart-coupons.entry.js +3 -3
  388. package/dist/esm/salla-cart-item-offers_2.entry.js +5 -5
  389. package/dist/esm/salla-comment-form_8.entry.js +17 -17
  390. package/dist/esm/salla-conditional-offer.entry.js +3 -3
  391. package/dist/esm/salla-contacts.entry.js +3 -3
  392. package/dist/esm/salla-cookies-bar.entry.js +3 -3
  393. package/dist/esm/salla-count-down.entry.js +35 -11
  394. package/dist/esm/salla-custom-fields.entry.js +3 -3
  395. package/dist/esm/salla-delivery-promise.entry.js +1 -1
  396. package/dist/esm/salla-filters-widget.entry.js +3 -3
  397. package/dist/esm/salla-filters.entry.js +3 -3
  398. package/dist/esm/salla-fulfillment-methods.entry.js +1 -1
  399. package/dist/esm/salla-gifting.entry.js +3 -3
  400. package/dist/esm/salla-hook.entry.js +5 -2
  401. package/dist/esm/salla-infinite-scroll.entry.js +3 -3
  402. package/dist/esm/salla-installment.entry.js +3 -3
  403. package/dist/esm/salla-list-tile.entry.js +3 -3
  404. package/dist/esm/salla-localization-modal.entry.js +1 -1
  405. package/dist/esm/salla-login-modal.entry.js +4 -5
  406. package/dist/esm/salla-loyalty-prize-item.entry.js +3 -3
  407. package/dist/esm/salla-loyalty-program.entry.js +3 -3
  408. package/dist/esm/salla-loyalty.entry.js +3 -3
  409. package/dist/esm/salla-maintenance-alert.entry.js +3 -3
  410. package/dist/esm/salla-map.entry.js +3 -3
  411. package/dist/esm/salla-menu.entry.js +3 -3
  412. package/dist/esm/salla-metadata.entry.js +3 -3
  413. package/dist/esm/salla-multiple-bundle-product-cart_2.entry.js +5 -5
  414. package/dist/esm/salla-multiple-bundle-product-options-modal_2.entry.js +8 -6
  415. package/dist/esm/salla-multiple-bundle-product.entry.js +6 -4
  416. package/dist/esm/salla-notification-item.entry.js +3 -3
  417. package/dist/esm/salla-notifications.entry.js +50 -5
  418. package/dist/esm/salla-offer-modal.entry.js +3 -3
  419. package/dist/esm/salla-offer.entry.js +3 -3
  420. package/dist/esm/salla-order-details-multiple-bundle-product.entry.js +3 -3
  421. package/dist/esm/salla-order-details-options.entry.js +3 -3
  422. package/dist/esm/salla-order-details.entry.js +6 -4
  423. package/dist/esm/salla-order-edit-item.entry.js +3 -3
  424. package/dist/esm/salla-order-edit.entry.js +3 -3
  425. package/dist/esm/salla-order-summary.entry.js +3 -3
  426. package/dist/esm/salla-order-totals-card.entry.js +6 -4
  427. package/dist/esm/salla-orders.entry.js +3 -3
  428. package/dist/esm/salla-payments.entry.js +3 -3
  429. package/dist/esm/salla-placeholder.entry.js +3 -3
  430. package/dist/esm/salla-price-range.entry.js +3 -3
  431. package/dist/esm/salla-product-card.entry.js +3 -3
  432. package/dist/esm/salla-product-size-guide.entry.js +3 -3
  433. package/dist/esm/salla-products-list.entry.js +3 -3
  434. package/dist/esm/salla-products-slider.entry.js +3 -3
  435. package/dist/esm/salla-progress-bar.entry.js +3 -3
  436. package/dist/esm/salla-quick-order.entry.js +3 -3
  437. package/dist/esm/salla-rating-modal.entry.js +3 -3
  438. package/dist/esm/salla-scopes.entry.js +3 -3
  439. package/dist/esm/salla-search.entry.js +6 -4
  440. package/dist/esm/salla-skeleton.entry.js +3 -3
  441. package/dist/esm/salla-slider.entry.js +20 -14
  442. package/dist/esm/salla-social-share.entry.js +3 -3
  443. package/dist/esm/salla-social.entry.js +3 -3
  444. package/dist/esm/salla-tab-content_3.entry.js +7 -7
  445. package/dist/esm/salla-tiered-offer.entry.js +3 -3
  446. package/dist/esm/salla-tooltip.entry.js +3 -3
  447. package/dist/esm/salla-trust-badges.entry.js +3 -3
  448. package/dist/esm/salla-user-menu.entry.js +3 -3
  449. package/dist/esm/salla-user-profile.entry.js +3 -3
  450. package/dist/esm/salla-user-settings.entry.js +3 -3
  451. package/dist/esm/salla-verify.entry.js +3 -3
  452. package/dist/esm/salla-wallet.entry.js +3 -3
  453. package/dist/esm/twilight.js +5 -4
  454. package/dist/esm/{vanilla-picker-DSMkPxn-.js → vanilla-picker-Dt9vZPZF.js} +1 -1
  455. package/dist/twilight/{p-49260c6c.entry.js → p-06fa7327.entry.js} +1 -1
  456. package/dist/twilight/{p-0c45b777.entry.js → p-09d39785.entry.js} +1 -1
  457. package/dist/twilight/{p-98365139.entry.js → p-0add06f9.entry.js} +1 -1
  458. package/dist/twilight/{p-ccf81e66.entry.js → p-105b1dab.entry.js} +1 -1
  459. package/dist/twilight/{p-fc6852a0.entry.js → p-108d8c8b.entry.js} +1 -1
  460. package/dist/twilight/{p-45c1eaa8.entry.js → p-1875537e.entry.js} +1 -1
  461. package/dist/twilight/{p-06d3f60c.entry.js → p-18bb0181.entry.js} +1 -1
  462. package/dist/twilight/p-1daeed6e.entry.js +4 -0
  463. package/dist/twilight/{p-51eeff00.entry.js → p-1ef2602d.entry.js} +1 -1
  464. package/dist/twilight/{p-e2a6cc78.entry.js → p-2881bb33.entry.js} +1 -1
  465. package/dist/twilight/{p-143f385c.entry.js → p-293c6cf3.entry.js} +1 -1
  466. package/dist/twilight/{p-1b50e37e.entry.js → p-296d2dd0.entry.js} +1 -1
  467. package/dist/twilight/{p-01cb129f.entry.js → p-2abaa633.entry.js} +1 -1
  468. package/dist/twilight/p-2ddb3fce.entry.js +4 -0
  469. package/dist/twilight/{p-9623211d.entry.js → p-2fe01e44.entry.js} +1 -1
  470. package/dist/twilight/p-33779828.entry.js +4 -0
  471. package/dist/twilight/p-34968e31.entry.js +4 -0
  472. package/dist/twilight/{p-1a7e8dc4.entry.js → p-34b670fc.entry.js} +1 -1
  473. package/dist/twilight/{p-64316672.entry.js → p-3ccc532d.entry.js} +1 -1
  474. package/dist/twilight/{p-1bacbd68.entry.js → p-41c733c2.entry.js} +1 -1
  475. package/dist/twilight/{p-abfc0327.entry.js → p-44fa7521.entry.js} +1 -1
  476. package/dist/twilight/{p-f17b1333.entry.js → p-4932857d.entry.js} +1 -1
  477. package/dist/twilight/{p-5de17423.entry.js → p-4fa4547a.entry.js} +1 -1
  478. package/dist/twilight/{p-4f664ee5.entry.js → p-542d3277.entry.js} +1 -1
  479. package/dist/twilight/{p-db1699d8.entry.js → p-57ff1f25.entry.js} +1 -1
  480. package/dist/twilight/{p-c800360f.entry.js → p-59ae82bd.entry.js} +1 -1
  481. package/dist/twilight/{p-495a9262.entry.js → p-647b6d76.entry.js} +1 -1
  482. package/dist/twilight/p-665189b4.entry.js +4 -0
  483. package/dist/twilight/{p-a50a28ea.entry.js → p-6f36541a.entry.js} +1 -1
  484. package/dist/twilight/{p-f8beca67.entry.js → p-7093a427.entry.js} +1 -1
  485. package/dist/twilight/{p-0a779ecb.entry.js → p-748df7e6.entry.js} +1 -1
  486. package/dist/twilight/p-776c9d33.entry.js +4 -0
  487. package/dist/twilight/{p-9a2fa95c.entry.js → p-7abddca8.entry.js} +1 -1
  488. package/dist/twilight/p-7b8313ef.entry.js +4 -0
  489. package/dist/twilight/p-7bd0ede5.entry.js +4 -0
  490. package/dist/twilight/p-817b8ba5.entry.js +4 -0
  491. package/dist/twilight/{p-2690964e.entry.js → p-87c0ca91.entry.js} +1 -1
  492. package/dist/twilight/p-8e8d9d7d.entry.js +4 -0
  493. package/dist/twilight/{p-IulbkBPB.js → p-8r0S6BcZ.js} +1 -1
  494. package/dist/twilight/{p-d5bea7d7.entry.js → p-94dbc1e9.entry.js} +1 -1
  495. package/dist/twilight/{p-5e08505f.entry.js → p-96a20515.entry.js} +1 -1
  496. package/dist/twilight/{p-ce4e06b8.entry.js → p-96d03a28.entry.js} +1 -1
  497. package/dist/twilight/{p-e8ee7b09.entry.js → p-96e78428.entry.js} +1 -1
  498. package/dist/twilight/{p-CttEbJoQ.js → p-BZnoSB1s.js} +1 -1
  499. package/dist/twilight/{p-CWQJdJyB.js → p-BkClxrC4.js} +1 -1
  500. package/dist/twilight/p-Ck4zxCil.js +9 -0
  501. package/dist/twilight/{p-BLNd0Q7w.js → p-Cw3UBzjl.js} +1 -1
  502. package/dist/twilight/p-D1vqXXNX.js +9 -0
  503. package/dist/twilight/p-DYB20YqN.js +5 -0
  504. package/dist/twilight/p-Vl6qpttb.js +4 -0
  505. package/dist/twilight/{p-03jJUGJM.js → p-X6Yi3bYP.js} +1 -1
  506. package/dist/twilight/{p-31cff9d6.entry.js → p-a01f1992.entry.js} +1 -1
  507. package/dist/twilight/{p-dd95dd45.entry.js → p-aa7c5de0.entry.js} +1 -1
  508. package/dist/twilight/{p-698cda6b.entry.js → p-aaa0c743.entry.js} +1 -1
  509. package/dist/twilight/{p-2534ee8d.entry.js → p-ad041ab5.entry.js} +1 -1
  510. package/dist/twilight/{p-78230ff2.entry.js → p-ad07f67a.entry.js} +1 -1
  511. package/dist/twilight/{p-3570139b.entry.js → p-af3c74f4.entry.js} +1 -1
  512. package/dist/twilight/p-af60e72a.entry.js +4 -0
  513. package/dist/twilight/{p-2fd9954e.entry.js → p-b17d055d.entry.js} +1 -1
  514. package/dist/twilight/{p-0557c403.entry.js → p-b598c0f7.entry.js} +1 -1
  515. package/dist/twilight/{p-43a3d74b.entry.js → p-b64f3155.entry.js} +1 -1
  516. package/dist/twilight/p-bNzv71Xl.js +9 -0
  517. package/dist/twilight/{p-BywTh96y.js → p-bScl0xMh.js} +1 -1
  518. package/dist/twilight/{p-917e279a.entry.js → p-bff4c7b3.entry.js} +1 -1
  519. package/dist/twilight/{p-e5faf311.entry.js → p-c091e2dc.entry.js} +1 -1
  520. package/dist/twilight/{p-5039c032.entry.js → p-c1fd45b1.entry.js} +1 -1
  521. package/dist/twilight/{p-1646270f.entry.js → p-c3ffb88a.entry.js} +1 -1
  522. package/dist/twilight/{p-911df985.entry.js → p-c87951a2.entry.js} +1 -1
  523. package/dist/twilight/{p-cc8c8ee0.entry.js → p-ccfe5308.entry.js} +1 -1
  524. package/dist/twilight/{p-73fc8bc2.entry.js → p-d337c399.entry.js} +1 -1
  525. package/dist/twilight/{p-4b78b5b6.entry.js → p-d371d450.entry.js} +1 -1
  526. package/dist/twilight/{p-099267e9.entry.js → p-d4a242f8.entry.js} +1 -1
  527. package/dist/twilight/{p-d375a0d6.entry.js → p-d9f5a8cd.entry.js} +1 -1
  528. package/dist/twilight/{p-72128782.entry.js → p-dd2bd5dc.entry.js} +1 -1
  529. package/dist/twilight/{p-214c17ba.entry.js → p-df6853b5.entry.js} +1 -1
  530. package/dist/twilight/{p-db8ea013.entry.js → p-e28c0773.entry.js} +1 -1
  531. package/dist/twilight/{p-b9a7a8b1.entry.js → p-e3b8e0e1.entry.js} +1 -1
  532. package/dist/twilight/p-e679884a.entry.js +4 -0
  533. package/dist/twilight/{p-3094c1a1.entry.js → p-e6bbf50d.entry.js} +1 -1
  534. package/dist/twilight/{p-6d9ff62d.entry.js → p-e94f217b.entry.js} +1 -1
  535. package/dist/twilight/{p-f08590d7.entry.js → p-eac718cd.entry.js} +1 -1
  536. package/dist/twilight/{p-042206f2.entry.js → p-ede67a08.entry.js} +1 -1
  537. package/dist/twilight/p-efab88c5.entry.js +4 -0
  538. package/dist/twilight/{p-5abc72fb.entry.js → p-f176d41d.entry.js} +1 -1
  539. package/dist/twilight/{p-fd540f5b.entry.js → p-f5d15e71.entry.js} +1 -1
  540. package/dist/twilight/{p-bc9aa300.entry.js → p-f7999a6d.entry.js} +1 -1
  541. package/dist/twilight/twilight.esm.js +1 -1
  542. package/dist/types/components/salla-count-down/salla-count-down.d.ts +6 -0
  543. package/dist/types/components/salla-notifications/interfaces.d.ts +20 -0
  544. package/dist/types/components/salla-notifications/salla-notifications.d.ts +17 -0
  545. package/dist/types/components.d.ts +763 -177
  546. package/dist/types/stencil-public-runtime.d.ts +169 -11
  547. package/package.json +5 -5
  548. package/dist/cjs/filepond-plugin-file-validate-type-B-xReGXI.js +0 -287
  549. package/dist/esm/filepond-plugin-file-validate-type-C_O5sg3V.js +0 -285
  550. package/dist/twilight/p-23c450bb.entry.js +0 -4
  551. package/dist/twilight/p-2f4352f5.entry.js +0 -4
  552. package/dist/twilight/p-3a20fbc0.entry.js +0 -4
  553. package/dist/twilight/p-43fd9024.entry.js +0 -4
  554. package/dist/twilight/p-736661d1.entry.js +0 -4
  555. package/dist/twilight/p-7b1e18b9.entry.js +0 -4
  556. package/dist/twilight/p-8735bed6.entry.js +0 -4
  557. package/dist/twilight/p-9f09f917.entry.js +0 -4
  558. package/dist/twilight/p-BBHnyTVS.js +0 -5
  559. package/dist/twilight/p-BdSnnWWn.js +0 -9
  560. package/dist/twilight/p-HRFCteJK.js +0 -9
  561. package/dist/twilight/p-daf6d030.entry.js +0 -4
  562. package/dist/twilight/p-df66218c.entry.js +0 -4
  563. package/dist/twilight/p-ec2a876a.entry.js +0 -4
  564. package/dist/twilight/p-f8b8c0da.entry.js +0 -4
  565. package/dist/twilight/p-fe417603.entry.js +0 -4
  566. package/dist/twilight/p-okSe2zH1.js +0 -9
@@ -1,815 +1,4 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
4
- import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
5
- import { a as anime } from './anime.es.js';
6
- import { S as ShoppingBag } from './shopping-bag.js';
7
- import { H as Helper } from './Helper.js';
8
-
9
- const sallaProductsListCss = "";
10
-
11
- const SallaProductsList = /*@__PURE__*/ proxyCustomElement(class SallaProductsList extends HTMLElement {
12
- constructor() {
13
- super();
14
- this.__registerHost();
15
- this.productsFetched = createEvent(this, "productsFetched", 7);
16
- /**
17
- * Autoload next page when scroll
18
- */
19
- this.autoload = false;
20
- /**
21
- * Custom Card Component for the Salla Products List.
22
- *
23
- * This component allows you to customize the appearance of individual product cards within a Salla Products List.
24
- *
25
- * @example
26
- * <salla-products-list product-card-component="my-custom-card-style1" ...
27
- * <salla-products-list product-card-component="my-custom-card-style2" ...
28
- */
29
- this.productCardComponent = 'custom-salla-product-card';
30
- // State
31
- this.page = 1;
32
- this.placeholderText = salla.lang.get('pages.categories.no_products');
33
- this.endOfText = salla.lang.get('common.elements.end_of_content');
34
- this.failedLoadMore = salla.lang.get('common.elements.failed_to_load_more');
35
- this.currentPage = salla.config.get('page');
36
- this.filtersSnapshot = [];
37
- this.lastViewedProductKey = "lastViewedProductId";
38
- this.filtersKey = "filters";
39
- this.infiniteScrollStateKey = "infiniteScrollState";
40
- this.prevCategoryIdKey = "prevCategoryId";
41
- this.isProcessing = false; // Tracks if we are processing data
42
- this.scrollTimeout = null;
43
- this.boundScrollToLastViewedProduct = () => this.scrollToLastViewedProduct();
44
- this.boundHandleScroll = () => this.handleScroll();
45
- this.specialPagesWithoutIds = {
46
- 'product.index.latest': 'latest',
47
- 'product.index.offers': 'offers',
48
- 'product.index.search': 'search',
49
- 'product.index.sales': 'sales'
50
- };
51
- //TODO:: check why `this.includes` not working!!
52
- this.includes = Helper.parseJson(this.includes || this.host.getAttribute('includes'));
53
- if (!Array.isArray(this.includes)) {
54
- this.includes = null;
55
- }
56
- Helper.setIncludes(this.includes);
57
- salla.lang.onLoaded(() => {
58
- this.placeholderText = salla.lang.get('pages.categories.no_products');
59
- this.endOfText = salla.lang.get('common.elements.end_of_content');
60
- this.failedLoadMore = salla.lang.get('common.elements.failed_to_load_more');
61
- this.currentPage = salla.config.get('page');
62
- });
63
- }
64
- connectedCallback() {
65
- //Override browser scroll restoration default behaviour
66
- if ("scrollRestoration" in history)
67
- history.scrollRestoration = "manual";
68
- // required for scroll restoration case when the component loads before DOM content is completed (slow internet bandwidth /low device specs)
69
- window.addEventListener('DOMContentLoaded', this.boundScrollToLastViewedProduct);
70
- salla.event.on('salla-filters::changed', filters => this.setFilters(filters));
71
- }
72
- disconnectedCallback() {
73
- window.removeEventListener('DOMContentLoaded', this.boundScrollToLastViewedProduct);
74
- window.removeEventListener('scroll', this.boundHandleScroll);
75
- }
76
- /**
77
- * Set parsed filters data from URI
78
- * @param filters
79
- */
80
- async setFilters(filters) {
81
- if (!filters || JSON.stringify(filters) === JSON.stringify(this.parsedFilters)) {
82
- return;
83
- }
84
- window.scrollTo({ top: 0, behavior: 'smooth' });
85
- // Create a deep copy of the filters object to avoid mutating the original object
86
- this.parsedFilters = JSON.parse(JSON.stringify(filters));
87
- this.filtersSnapshot = this.parsedFilters;
88
- if (this.currentPage?.slug == "product.index" && this.parsedFilters && this.parsedFilters.category_id) {
89
- this.currentCategoryIdFilter = [this.parsedFilters.category_id];
90
- }
91
- return this.reload();
92
- }
93
- /**
94
- * Reload the list of products (entire content of the component).
95
- */
96
- async reload() {
97
- !this.autoload && this.loadMoreWrapper && (this.loadMoreWrapper.style.display = 'none');
98
- this.hasInfiniteScroll && salla.infiniteScroll.destroy(this.infiniteScroll);
99
- this.buildNextPageUrl();
100
- // TODO: this is problematic in testing, for the time being it's been resolved like this
101
- this.wrapper.innerHTML = '';
102
- if (this.hasInfiniteScroll) {
103
- this.init();
104
- }
105
- else {
106
- this.getInitialData();
107
- }
108
- // Special case for the placeholder loader
109
- if (this.showPlaceholder) {
110
- this.showPlaceholder = false;
111
- this.placeholderLoader = document.createElement('div');
112
- this.placeholderLoader.classList.add('s-products-list-loading-wrapper');
113
- this.placeholderLoader.style.display = 'inherit';
114
- this.placeholderLoader.innerHTML = `<span class="s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"></span>`;
115
- this.host.insertAdjacentElement('afterend', this.placeholderLoader);
116
- }
117
- }
118
- isFilterable() {
119
- return salla.config.get('store.settings.product.filters') && this.filtersResults;
120
- }
121
- isSourceWithoutValue() {
122
- return ['offers', 'latest', 'sales', 'wishlist', 'top-rated', 'reorder'].includes(this.getSource());
123
- }
124
- animateItems() {
125
- anime({
126
- targets: 'salla-products-list salla-product-card',
127
- opacity: [0, 1],
128
- duration: 1200,
129
- translateY: [20, 0],
130
- delay: function (_el, i) {
131
- return i * 100;
132
- },
133
- });
134
- }
135
- initBaseNextPageUrl(source) {
136
- this.nextPage = salla.url.api(`products?source=${source}`);
137
- if (this.includes?.length) {
138
- this.nextPage += `&includes[]=${this.includes.join('&includes[]=')}`;
139
- }
140
- if (this.limit) {
141
- this.nextPage += `&per_page=${this.limit > 32 ? 32 : this.limit}`;
142
- }
143
- if (this.sortBy) {
144
- this.nextPage += `&sort=${this.sortBy}`;
145
- }
146
- if (salla.config.get('theme.mode') === 'preview') {
147
- this.nextPage += `&use_username_url=1`;
148
- }
149
- this.nextPage += '&filterable=1';
150
- for (const [key, value] of Object.entries(this.parsedFilters || {})) {
151
- if (["string", "number"].includes(typeof value)) {
152
- // @ts-ignore
153
- this.nextPage += `&filters[${encodeURIComponent(key)}]=${encodeURIComponent(value)}`;
154
- }
155
- else if (Array.isArray(value)) {
156
- value.forEach(item => this.nextPage += `&filters[${encodeURIComponent(key)}][]=${encodeURIComponent(item)}`);
157
- }
158
- else if (typeof value === 'object') {
159
- for (const [k, v] of Object.entries(value)) {
160
- this.nextPage += `&filters[${encodeURIComponent(key)}][${encodeURIComponent(k)}]=${encodeURIComponent(v)}`;
161
- }
162
- }
163
- }
164
- }
165
- buildNextPageUrl() {
166
- let source = this.getSource();
167
- if (source === 'json') {
168
- return;
169
- }
170
- const snapshot = sessionStorage.getItem(this.infiniteScrollStateKey);
171
- if (snapshot) {
172
- const { nextPage } = JSON.parse(snapshot);
173
- if (!nextPage) {
174
- return;
175
- }
176
- }
177
- this.initBaseNextPageUrl(source);
178
- if (this.isSourceWithoutValue()) {
179
- return;
180
- }
181
- if (['search', 'related', 'landing-page'].includes(source)) {
182
- this.nextPage += `&source_value=${this.getSourceValue()}`;
183
- return;
184
- }
185
- try {
186
- this.nextPage += `&source_value[]=${this.getSourceValue().join('&source_value[]=')}`;
187
- }
188
- catch (e) {
189
- salla.logger.warn(`source-value prop should be array of ids ex source-value="[1,2,3]" for the source [${source}]`);
190
- this.sourceValueIsValid = false;
191
- }
192
- }
193
- loading(isLoading = true, isBtn = false) {
194
- if (!isLoading) {
195
- if (!this.autoload) {
196
- this.btnLoader && (this.btnLoader.style.display = 'none');
197
- }
198
- this.loader && (this.loader.style.display = 'none');
199
- }
200
- else {
201
- let currentLoader = isBtn && !this.autoload ? this.btnLoader : this.loader;
202
- currentLoader && (currentLoader.style.display = 'inherit');
203
- }
204
- }
205
- getItemHTML(product) {
206
- //as a request they don't want to let the user to open the product details
207
- //todo:: find a better way to handle this request
208
- this.getSource() === 'landing-page' && (product.url = '');
209
- const customComponentTag = this.hasCustomComponent ? this.productCardComponent : 'salla-product-card';
210
- const productCard = document.createElement(customComponentTag);
211
- productCard.product = product;
212
- // Apply compact layout if requested - set both property and attribute for compatibility
213
- if (this.compactCards) {
214
- productCard.compact = true;
215
- productCard.toggleAttribute('compact', true);
216
- }
217
- this.applyLandingPageStyles(productCard);
218
- this.applyHorizontalCardStyles(productCard);
219
- // Attach click event listener to save the current products snapshot
220
- productCard.addEventListener('click', (event) => {
221
- const target = event.target;
222
- // Check if the clicked element is an anchor or inside an anchor
223
- const anchor = target.closest('a');
224
- if (anchor) {
225
- Helper.saveProductSource(this.getSource());
226
- if (this.hasInfiniteScroll) {
227
- this.takeStateSnapshot();
228
- sessionStorage.setItem(this.lastViewedProductKey, product.id);
229
- }
230
- }
231
- });
232
- return productCard;
233
- }
234
- applyLandingPageStyles(productCard) {
235
- if (this.getSource() === 'landing-page' && !this.hasCustomComponent) {
236
- productCard.toggleAttribute('hide-add-btn', true);
237
- productCard.classList.add('s-product-card-fit-height');
238
- }
239
- }
240
- applyHorizontalCardStyles(productCard) {
241
- if (!this.horizontalCards) {
242
- return;
243
- }
244
- productCard.toggleAttribute('horizontal', true);
245
- if (!this.hasCustomComponent) {
246
- productCard.toggleAttribute('shadow-on-hover', true);
247
- }
248
- }
249
- waitForResizing(element) {
250
- let timeout = null;
251
- return new Promise((resolve) => {
252
- const resizeObserver = new ResizeObserver(() => {
253
- clearTimeout(timeout);
254
- timeout = setTimeout(() => {
255
- resizeObserver.disconnect();
256
- resolve(null);
257
- }, 160); // Adjust delay as needed for your layout
258
- });
259
- resizeObserver.observe(element); // Watch the body or a specific container
260
- });
261
- }
262
- waitForLayoutStable(element) {
263
- let timeout = null;
264
- return new Promise((resolve) => {
265
- const observer = new MutationObserver(() => {
266
- clearTimeout(timeout);
267
- timeout = setTimeout(() => {
268
- observer.disconnect();
269
- resolve(null);
270
- }, 160); // Adjust delay as needed for your layout
271
- });
272
- // Observe changes to the entire body, including child nodes and attributes.
273
- observer.observe(element, {
274
- childList: true,
275
- subtree: true,
276
- attributes: true,
277
- });
278
- });
279
- }
280
- async waitForStableLayout(element) {
281
- // Wait for DOM mutations and layout shifts to stabilize
282
- return await Promise.allSettled([
283
- this.waitForResizing(element),
284
- this.waitForLayoutStable(element)
285
- ]);
286
- }
287
- scrollToLastViewedProduct() {
288
- const lastViewedProductId = sessionStorage.getItem(this.lastViewedProductKey);
289
- if (!lastViewedProductId || salla.url.is_page('product.single'))
290
- return;
291
- this.isElementLoaded(`[id*="${lastViewedProductId}"]`)
292
- .then(() => {
293
- const productCard = this.wrapper?.querySelector(`[id*="${lastViewedProductId}"]`);
294
- if (!productCard)
295
- return;
296
- const scrollToPosition = () => {
297
- const scrollToProductCard = () => {
298
- // calculations is located here for last second changes in the ui (ie. sticky header height)
299
- productCard.scrollIntoView({ block: 'start', behavior: 'instant' });
300
- const headerSelector = matchMedia('(max-width: 1024px)').matches ? "header .inner" : "ul.main-menu";
301
- const headerHeight = window?.header_is_sticky ? (document.querySelector(headerSelector)?.getBoundingClientRect()?.height ?? 56) : 0;
302
- const cardsListRowGap = parseInt(getComputedStyle(this.wrapper).rowGap) ?? 16;
303
- const productCardOffset = headerHeight + cardsListRowGap;
304
- scrollBy({ top: productCardOffset * -1, behavior: 'instant' });
305
- };
306
- //start scrolling to the product card position
307
- requestAnimationFrame(scrollToProductCard);
308
- const productImages = productCard.querySelectorAll('img.lazy');
309
- productImages.forEach((image) => {
310
- const productImage = image;
311
- const handleImageEvent = () => {
312
- requestAnimationFrame(scrollToProductCard);
313
- productImage.onload = productImage.onerror = null;
314
- };
315
- productImage.onload = handleImageEvent;
316
- productImage.onerror = handleImageEvent;
317
- });
318
- // remove snapshot of product cards items in session storage after scroll restoration completiion
319
- this.removeScrollRestorationSession();
320
- return void 0;
321
- };
322
- this.waitForStableLayout(this.host).then(() => requestAnimationFrame(scrollToPosition));
323
- });
324
- }
325
- isElementLoaded(selector) {
326
- return new Promise((resolve => {
327
- const interval = setInterval(() => {
328
- if (document.querySelector(selector)) {
329
- clearInterval(interval);
330
- return resolve(document.querySelector(selector));
331
- }
332
- }, 50);
333
- }));
334
- }
335
- ;
336
- takeStateSnapshot() {
337
- const currentPageData = [];
338
- // Classic for-loop for performance
339
- for (let i = 0; i < this.wrapper.children.length; i++) {
340
- const child = this.wrapper.children?.[i];
341
- currentPageData.push(child.product);
342
- }
343
- const scrollState = {
344
- pageIndex: Math.max((this.infiniteScroll?.pageIndex ?? 1) - 1, 1),
345
- nextPage: this.nextPage,
346
- currentPageData
347
- };
348
- if (this.isFilterable()) {
349
- const existingFilters = sessionStorage.getItem(this.filtersKey);
350
- sessionStorage.setItem(this.filtersKey, existingFilters || JSON.stringify(this.filtersSnapshot));
351
- }
352
- sessionStorage.setItem(this.infiniteScrollStateKey, JSON.stringify(scrollState));
353
- // Determine and store the correct prevCategoryId
354
- let prevCategoryId = salla.config.get('page.id'); // Number or null
355
- const currentPage = Object.keys(this.specialPagesWithoutIds).find(page => salla.url.is_page(page));
356
- if (currentPage) {
357
- prevCategoryId = this.specialPagesWithoutIds[currentPage];
358
- }
359
- else if (prevCategoryId !== null) {
360
- prevCategoryId = String(prevCategoryId); // Ensure it's stored as a string
361
- }
362
- sessionStorage.setItem(this.prevCategoryIdKey, prevCategoryId);
363
- }
364
- removeScrollRestorationSession() {
365
- if (!this.isFilterable()) {
366
- sessionStorage.removeItem(this.filtersKey);
367
- }
368
- sessionStorage.removeItem(this.infiniteScrollStateKey);
369
- sessionStorage.removeItem(this.lastViewedProductKey);
370
- sessionStorage.removeItem(this.prevCategoryIdKey);
371
- }
372
- loadStoredScrollState() {
373
- const storedState = sessionStorage.getItem(this.infiniteScrollStateKey);
374
- const filetrsState = sessionStorage.getItem(this.filtersKey);
375
- /*
376
- * Remove the scroll restoration session under the following conditions:
377
- * 1. The user has navigated to a different category page:
378
- * - If the previously stored category ID is different from the current one.
379
- * - This includes "latest", "offers", "sales" and "search" pages.
380
- *
381
- * 2. The user is on the homepage, but infinite scroll is disabled.
382
- *
383
- * 3. The user is on a product page.
384
- */
385
- const prevCategory = sessionStorage.getItem(this.prevCategoryIdKey); // Get previously stored category
386
- const currentPageSlug = this.specialPagesWithoutIds[salla.config.get('page.slug')] || null;
387
- const currentPageId = salla.config.get('page.id'); // Number or null
388
- const isHomepage = salla.url.is_page('index');
389
- const isProductPage = salla.url.is_page('product.single');
390
- const isDifferentCategory = currentPageSlug
391
- ? prevCategory !== currentPageSlug // Compare slugs for special pages
392
- : prevCategory !== String(currentPageId); // Compare IDs otherwise
393
- if ((prevCategory && isDifferentCategory && !isHomepage && !isProductPage)
394
- ||
395
- (isHomepage && !this.hasInfiniteScroll)) {
396
- this.removeScrollRestorationSession();
397
- this.switchToNormalBehavior = true;
398
- return false;
399
- }
400
- // Keep the snapshot in product page that contains salla-products-list but without scroll restoration
401
- if (isProductPage) {
402
- this.switchToNormalBehavior = true;
403
- return false;
404
- }
405
- if (storedState) {
406
- try {
407
- const { pageIndex, nextPage, currentPageData } = JSON.parse(storedState);
408
- if (filetrsState !== 'undefined') {
409
- const filters = JSON.parse(filetrsState);
410
- salla.event.emit('filters::fetched', { filters });
411
- }
412
- this.page = pageIndex;
413
- this.nextPage = nextPage;
414
- // more performant on larger set of data
415
- for (let i = 0; i < currentPageData.length; i++) {
416
- this.wrapper.append(this.getItemHTML(currentPageData?.[i]));
417
- }
418
- return true;
419
- }
420
- catch (error) {
421
- console.error('Failed to load stored scroll state:', error);
422
- this.removeScrollRestorationSession();
423
- }
424
- }
425
- return false;
426
- }
427
- getSource() {
428
- return Helper.getProductsSource(this.source);
429
- }
430
- getSourceValue() {
431
- return this.currentCategoryIdFilter ? this.currentCategoryIdFilter : Helper.getProductsSourceValue(this.source, this.sourceValue);
432
- }
433
- appendDataLayer(data) {
434
- if (typeof dataLayer !== 'object' || !Array.isArray(dataLayer)) {
435
- //todo:: check if we should define it here
436
- return;
437
- }
438
- dataLayer.push({
439
- "event": "impressions",
440
- "ecommerce": {
441
- "currencyCode": salla.config.currency().code,
442
- // "event_id":"", // todo
443
- "impressions": data.map((product, index) => {
444
- return {
445
- "id": product.id,
446
- "name": product.name,
447
- "price": product.price,
448
- "brand": product.brand?.name || '',
449
- "quantity": product.quantity,
450
- // "variant": "",
451
- "categories": [
452
- {
453
- "name": product.category?.name || salla.config.get('page.title'),
454
- "id": salla.config.get('page.id')
455
- }
456
- ],
457
- "category": product.category?.name || salla.config.get('page.title'),
458
- 'position': index + 1
459
- };
460
- })
461
- }
462
- });
463
- }
464
- initiateInfiniteScroll() {
465
- if (!this.hasInfiniteScroll) {
466
- return;
467
- }
468
- const shouldApplyManualLoad = this.autoload && this.includes && this.includes.length > 0;
469
- this.infiniteScroll = salla.infiniteScroll.initiate(this.wrapper, this.wrapper, {
470
- path: () => this.nextPage,
471
- history: false,
472
- nextPage: this.nextPage,
473
- scrollThreshold: shouldApplyManualLoad ? false : this.autoload ? 100 : false,
474
- loadOnScroll: shouldApplyManualLoad ? false : this.autoload
475
- }, true);
476
- this.infiniteScroll.pageIndex = this.page;
477
- this.infiniteScroll?.on('request', () => {
478
- this.loading(true, this.autoload ? false : true);
479
- });
480
- // Manual scroll listener
481
- shouldApplyManualLoad && window.addEventListener('scroll', this.boundHandleScroll);
482
- this.infiniteScroll?.on('load', async (response) => {
483
- if (this.isProcessing)
484
- return;
485
- this.isProcessing = true;
486
- try {
487
- if (!response.data?.length && this.infiniteScroll.pageIndex === 2) {
488
- this.showPlaceholder = true;
489
- salla.infiniteScroll.destroy(this.infiniteScroll);
490
- this.loading(false);
491
- this.placeholderLoader && this.placeholderLoader.remove();
492
- return;
493
- }
494
- if (this.includes) {
495
- await this.injectAndProcessData(response);
496
- }
497
- const items = this.handleResponse(response);
498
- this.infiniteScroll.appendItems(items);
499
- if (this.infiniteScroll.pageIndex === 2) {
500
- if (!this.autoload && this.nextPage) {
501
- this.loadMoreWrapper.style.display = 'block';
502
- }
503
- this.animateItems();
504
- }
505
- }
506
- catch (error) {
507
- console.error('Error during load:', error);
508
- }
509
- finally {
510
- this.isProcessing = false;
511
- }
512
- });
513
- this.infiniteScroll?.on('error', () => {
514
- console.log('Error occurred during request');
515
- this.status.querySelector('.s-infinite-scroll-error').classList.remove('s-hidden');
516
- this.placeholderLoader && this.placeholderLoader.remove();
517
- this.loading(false);
518
- this.isProcessing = false;
519
- });
520
- salla.onReady(() => {
521
- const snapshot = sessionStorage.getItem(this.infiniteScrollStateKey);
522
- if (!snapshot) {
523
- this.manualLoadNextPage();
524
- }
525
- });
526
- }
527
- handleScroll() {
528
- if (this.isProcessing)
529
- return;
530
- if (this.scrollTimeout)
531
- return;
532
- this.scrollTimeout = setTimeout(() => {
533
- this.scrollTimeout = null;
534
- // Defer layout reads to next frame to avoid forced reflow (Lighthouse/PageSpeed)
535
- requestAnimationFrame(() => {
536
- const wrapperRect = this.wrapper.getBoundingClientRect();
537
- const windowHeight = window.innerHeight;
538
- const distanceToBottom = wrapperRect.bottom - windowHeight;
539
- // Trigger only when the wrapper bottom is within 200px of the viewport bottom
540
- if (distanceToBottom <= 200 && !this.isProcessing && this.nextPage) {
541
- // Reached near the bottom of the wrapper, loading next page...
542
- this.manualLoadNextPage();
543
- }
544
- });
545
- }, 200);
546
- }
547
- manualLoadNextPage() {
548
- if (this.nextPage) {
549
- this.infiniteScroll.loadNextPage();
550
- }
551
- }
552
- async injectAndProcessData(response) {
553
- try {
554
- await Helper.injectExtraFieldsToResponse(response);
555
- }
556
- catch (error) {
557
- console.error('Error injecting data:', error);
558
- }
559
- }
560
- getInitialData() {
561
- this.loading();
562
- return salla.api.withoutNotifier(() => salla.product.api.fetch({
563
- source: Helper.getApiSource(this.getSource()),
564
- source_value: this.getSourceValue(),
565
- limit: this.limit
566
- }).then(async (response) => {
567
- if (!response.data.length) {
568
- this.showPlaceholder = true;
569
- this.placeholderLoader && this.placeholderLoader.remove();
570
- this.loading(false);
571
- return;
572
- }
573
- await Helper.injectExtraFieldsToResponse(response);
574
- //this.firstPageResponse will be null only in the first page, after that it will be assinged,
575
- //for the first page we need to inject the dom after the load, see @method componentDidLoad
576
- if (!this.firstPageResponse) {
577
- this.firstPageResponse = response;
578
- this.nextPage = response.cursor ? response.cursor.next : this.nextPage;
579
- return;
580
- }
581
- this.handleResponse(response).forEach(card => this.wrapper.append(card));
582
- }));
583
- }
584
- async loadMore() {
585
- this.infiniteScroll?.loadNextPage();
586
- }
587
- componentWillLoad() {
588
- return salla.onReady()
589
- .then(() => {
590
- this.hasCustomComponent = !!customElements.get(this.productCardComponent);
591
- this.sourceValueIsValid = !!(this.getSourceValue() || this.isSourceWithoutValue());
592
- this.hasInfiniteScroll = !['json', 'selected', 'related', 'landing-page', 'recently'].includes(this.getSource()) && !this.limit;
593
- let searchParams = new URLSearchParams(window.location.search);
594
- try {
595
- this.sortBy = this.sortBy || searchParams.get('sort') || searchParams.get('by');
596
- this.parsedFilters = Helper.extractFiltersFromUrl(searchParams);
597
- if (this.parsedFilters && this.parsedFilters.category_id) {
598
- this.currentCategoryIdFilter = [this.parsedFilters.category_id];
599
- }
600
- }
601
- catch (e) {
602
- salla.logger.warn('failed to get filters from url', e.message);
603
- }
604
- this.buildNextPageUrl();
605
- this.isReady = true;
606
- const snapshot = sessionStorage.getItem(this.infiniteScrollStateKey);
607
- if (!!snapshot) {
608
- return;
609
- }
610
- if (!this.sourceValueIsValid) {
611
- salla.logger.warn(`source-value prop is required for source [${this.getSource()}]`);
612
- return;
613
- }
614
- if (this.hasInfiniteScroll) {
615
- return;
616
- }
617
- // Handle json source
618
- if (this.getSource() === 'json') {
619
- if (!this.getSourceValue().length) {
620
- this.showPlaceholder = true;
621
- return;
622
- }
623
- //todo:: avoid using timeout, just assigne the data to the this.firstPageResponse and it should work fine, because it will be rendered in componentDidLoad
624
- setTimeout(() => {
625
- let productsList = this.getSourceValue();
626
- productsList.map(product => this.wrapper.append(this.getItemHTML(product)));
627
- });
628
- return;
629
- }
630
- // Handle selected source
631
- if (this.getSource() === 'selected' && !this.getSourceValue().length) {
632
- this.showPlaceholder = true;
633
- return;
634
- }
635
- return this.getInitialData();
636
- });
637
- }
638
- async componentDidLoad() {
639
- this.hasInfiniteScroll && this.init();
640
- await Salla.hooks.registerComponent('salla-products-list', this);
641
- if (this.loadStoredScrollState()) {
642
- if (this.autoload) {
643
- !this.nextPage && this.loading(false);
644
- }
645
- else if (!this.nextPage) {
646
- this.loadMoreWrapper && (this.loadMoreWrapper.style.display = 'none');
647
- this.status.querySelector('.s-infinite-scroll-last').classList.remove('s-hidden');
648
- }
649
- else {
650
- this.loadMoreWrapper && (this.loadMoreWrapper.style.display = 'block');
651
- }
652
- this.scrollToLastViewedProduct();
653
- }
654
- else if (!this.firstPageResponse && this.switchToNormalBehavior) {
655
- this.getInitialData()
656
- .then(() => {
657
- if (this.firstPageResponse) {
658
- this.handleResponse(this.firstPageResponse, false).forEach(card => {
659
- this.wrapper.append(card);
660
- });
661
- setTimeout(() => {
662
- if (!this.autoload && this.nextPage && this.infiniteScroll.pageIndex == 1) {
663
- const loadMoreWrapper = this.host.querySelector('.s-infinite-scroll-wrapper');
664
- loadMoreWrapper && (loadMoreWrapper.style.display = 'block');
665
- }
666
- });
667
- }
668
- else {
669
- console.error("No response received after getInitialData.");
670
- }
671
- })
672
- .catch(error => {
673
- console.error("Error during initial data fetch:", error);
674
- });
675
- }
676
- else {
677
- this.firstPageResponse && this.handleResponse(this.firstPageResponse, false).forEach(card => this.wrapper.append(card));
678
- }
679
- }
680
- canRender() {
681
- return this.sourceValueIsValid && this.isReady;
682
- }
683
- render() {
684
- if (!this.canRender()) {
685
- return '';
686
- }
687
- if (this.showPlaceholder) {
688
- return h("div", { class: "s-products-list-placeholder" }, h("span", { innerHTML: ShoppingBag }), h("p", null, this.placeholderText));
689
- }
690
- return (h(Host, { class: "s-products-list" }, h("div", { class: {
691
- "s-products-list-wrapper": true,
692
- 's-products-list-horizontal-cards': this.horizontalCards && !this.filtersResults,
693
- 's-products-list-vertical-cards': !this.horizontalCards && !this.rowCards && !this.filtersResults,
694
- 's-products-list-row-cards': this.rowCards,
695
- 's-products-list-compact-cards': this.compactCards,
696
- 's-products-list-filters-results': this.filtersResults,
697
- }, ref: wrapper => this.wrapper = wrapper }), h("div", { class: "s-infinite-scroll-status", ref: status => this.status = status }, h("p", { class: "s-infinite-scroll-last infinite-scroll-last s-hidden" }, this.endOfText), h("p", { class: "s-infinite-scroll-error infinite-scroll-error s-hidden" }, this.failedLoadMore)), this.autoload && h("div", { class: "s-products-list-loading-wrapper", style: { "display": "none" }, ref: loader => this.loader = loader }, h("span", { class: "s-button-loader s-button-loader-center s-infinite-scroll-btn-loader" })), this.hasInfiniteScroll && this.nextPage && !this.autoload ? (h("div", { class: "s-infinite-scroll-wrapper", style: { "display": "none" }, ref: loadMoreWrapper => this.loadMoreWrapper = loadMoreWrapper }, h("button", { onClick: () => this.loadMore(), class: "s-infinite-scroll-btn s-button-btn s-button-primary" }, h("span", { class: "s-button-text s-infinite-scroll-btn-text" }, this.loadMoreText ? this.loadMoreText : salla.lang.get('common.elements.load_more')), h("span", { class: "s-button-loader s-button-loader-center s-infinite-scroll-btn-loader", ref: btnLoader => this.btnLoader = btnLoader, style: { "display": "none" } })))) : ""));
698
- }
699
- init() {
700
- this.initiateInfiniteScroll();
701
- this.loading();
702
- }
703
- handleResponse(response, shouldBuildNextPage = true) {
704
- //todo:: check why it reach here undfined one time🤔
705
- if (!response) {
706
- return [];
707
- }
708
- let source = this.getSource();
709
- let title = '';
710
- //help the developer to know the current page title
711
- if (response.cursor?.current === 1) {
712
- title = Helper.getPageTitleForSource(source);
713
- try {
714
- if (this.getSource() === 'search') {
715
- title = salla.lang.get('common.elements.search_about', { 'word': this.getSourceValue() });
716
- }
717
- else if (!title) {
718
- let catId = this.parsedFilters.category_id || this.getSourceValue()[0];
719
- // get the first filter that its key is category_id, then get the value when filter.value.*.key==catId
720
- title = response.filters?.find(filter => filter.key === 'category_id')?.values?.find(cat => cat.key === catId)?.value ?? '';
721
- this.filtersSnapshot = response.filters;
722
- }
723
- title += (title ? ' - ' : '') + salla.lang.choice('blocks.header.products_count', response.data?.length);
724
- if (response.data.length === 15) {
725
- title = title.replace(response.data.length, salla.lang.get('common.elements.more_than') + ' ' + response.data.length);
726
- }
727
- response.title = title;
728
- }
729
- catch (e) {
730
- salla.logger.error('Error::falid to handle response', e);
731
- }
732
- //inject the SEO schema
733
- //handleResponse works only on the infinite-scroll and infinite scroll works only on the categories pages and main latest-page ..etc, so no need to add condition
734
- Helper.generateProductSchema(response.data);
735
- }
736
- this.appendDataLayer(response.data);
737
- response.nextPage = this.nextPage;
738
- response.source = this.getSource();
739
- response.sourceValue = this.getSourceValue();
740
- salla.event.emit('salla-products-list::products.fetched', response);
741
- this.productsFetched.emit(response);
742
- //💡 when source is related, cursor will not be existed
743
- if (response.filters && this.isFilterable()) {
744
- this.filtersResults = true;
745
- this.filtersSnapshot = JSON.parse(JSON.stringify(response.filters));
746
- salla.event.emit('filters::fetched', { filters: response.filters });
747
- }
748
- else if (this.isFilterable()) {
749
- salla.event.emit('filters::hidden');
750
- }
751
- //because: this.nextPage is state we don't need to touch it after the build, to avoid the re-rendering
752
- if (shouldBuildNextPage) {
753
- this.nextPage = response.cursor ? response.cursor.next : this.nextPage;
754
- }
755
- this.loading(false);
756
- this.placeholderLoader && this.placeholderLoader.remove();
757
- if (this.hasInfiniteScroll && !this.nextPage) {
758
- this.infiniteScroll.option({ scrollThreshold: false, loadOnScroll: false });
759
- this.status.querySelector('.s-infinite-scroll-last').classList.remove('s-hidden');
760
- }
761
- const productCardsView = [];
762
- for (let i = 0; i < response.data.length; i++) {
763
- productCardsView.push(this.getItemHTML(response.data?.[i]));
764
- }
765
- return productCardsView;
766
- }
767
- get host() { return this; }
768
- static get style() { return sallaProductsListCss; }
769
- }, [0, "salla-products-list", {
770
- "source": [1537],
771
- "sourceValue": [1032, "source-value"],
772
- "limit": [1026],
773
- "sortBy": [1025, "sort-by"],
774
- "filtersResults": [1540, "filters-results"],
775
- "horizontalCards": [516, "horizontal-cards"],
776
- "rowCards": [516, "row-cards"],
777
- "compactCards": [516, "compact-cards"],
778
- "autoload": [1028],
779
- "loadMoreText": [1, "load-more-text"],
780
- "productCardComponent": [1, "product-card-component"],
781
- "includes": [1040],
782
- "page": [32],
783
- "nextPage": [32],
784
- "hasInfiniteScroll": [32],
785
- "hasCustomComponent": [32],
786
- "sourceValueIsValid": [32],
787
- "placeholderText": [32],
788
- "endOfText": [32],
789
- "failedLoadMore": [32],
790
- "currentPage": [32],
791
- "currentCategoryIdFilter": [32],
792
- "isReady": [32],
793
- "showPlaceholder": [32],
794
- "switchToNormalBehavior": [32],
795
- "parsedFilters": [32],
796
- "filtersSnapshot": [32],
797
- "setFilters": [64],
798
- "reload": [64]
799
- }]);
800
- function defineCustomElement() {
801
- if (typeof customElements === "undefined") {
802
- return;
803
- }
804
- const components = ["salla-products-list"];
805
- components.forEach(tagName => { switch (tagName) {
806
- case "salla-products-list":
807
- if (!customElements.get(tagName)) {
808
- customElements.define(tagName, SallaProductsList);
809
- }
810
- break;
811
- } });
812
- }
813
- defineCustomElement();
814
-
815
- export { SallaProductsList as S, defineCustomElement as d };
4
+ import{transformTag as t,proxyCustomElement as s,HTMLElement as i,createEvent as e,h as o,Host as a}from"@stencil/core/internal/client";import{a as r}from"./anime.es.js";import{S as l}from"./shopping-bag.js";import{H as h}from"./Helper.js";const n=s(class extends i{constructor(t){super(),!1!==t&&this.__registerHost(),this.productsFetched=e(this,"productsFetched",7),this.autoload=!1,this.productCardComponent="custom-salla-product-card",this.page=1,this.placeholderText=salla.lang.get("pages.categories.no_products"),this.endOfText=salla.lang.get("common.elements.end_of_content"),this.failedLoadMore=salla.lang.get("common.elements.failed_to_load_more"),this.currentPage=salla.config.get("page"),this.filtersSnapshot=[],this.lastViewedProductKey="lastViewedProductId",this.filtersKey="filters",this.infiniteScrollStateKey="infiniteScrollState",this.prevCategoryIdKey="prevCategoryId",this.isProcessing=!1,this.scrollTimeout=null,this.boundScrollToLastViewedProduct=()=>this.scrollToLastViewedProduct(),this.boundHandleScroll=()=>this.handleScroll(),this.specialPagesWithoutIds={"product.index.latest":"latest","product.index.offers":"offers","product.index.search":"search","product.index.sales":"sales"},this.includes=h.parseJson(this.includes||this.host.getAttribute("includes")),Array.isArray(this.includes)||(this.includes=null),h.setIncludes(this.includes),salla.lang.onLoaded((()=>{this.placeholderText=salla.lang.get("pages.categories.no_products"),this.endOfText=salla.lang.get("common.elements.end_of_content"),this.failedLoadMore=salla.lang.get("common.elements.failed_to_load_more"),this.currentPage=salla.config.get("page")}))}connectedCallback(){"scrollRestoration"in history&&(history.scrollRestoration="manual"),window.addEventListener("DOMContentLoaded",this.boundScrollToLastViewedProduct),salla.event.on("salla-filters::changed",(t=>this.setFilters(t)))}disconnectedCallback(){window.removeEventListener("DOMContentLoaded",this.boundScrollToLastViewedProduct),window.removeEventListener("scroll",this.boundHandleScroll)}async setFilters(t){if(t&&JSON.stringify(t)!==JSON.stringify(this.parsedFilters))return window.scrollTo({top:0,behavior:"smooth"}),this.parsedFilters=JSON.parse(JSON.stringify(t)),this.filtersSnapshot=this.parsedFilters,"product.index"==this.currentPage?.slug&&this.parsedFilters&&this.parsedFilters.category_id&&(this.currentCategoryIdFilter=[this.parsedFilters.category_id]),this.reload()}async reload(){!this.autoload&&this.loadMoreWrapper&&(this.loadMoreWrapper.style.display="none"),this.hasInfiniteScroll&&salla.infiniteScroll.destroy(this.infiniteScroll),this.buildNextPageUrl(),this.wrapper.innerHTML="",this.hasInfiniteScroll?this.init():this.getInitialData(),this.showPlaceholder&&(this.showPlaceholder=!1,this.placeholderLoader=document.createElement("div"),this.placeholderLoader.classList.add("s-products-list-loading-wrapper"),this.placeholderLoader.style.display="inherit",this.placeholderLoader.innerHTML='<span class="s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"></span>',this.host.insertAdjacentElement("afterend",this.placeholderLoader))}isFilterable(){return salla.config.get("store.settings.product.filters")&&this.filtersResults}isSourceWithoutValue(){return["offers","latest","sales","wishlist","top-rated","reorder"].includes(this.getSource())}animateItems(){r({targets:"salla-products-list salla-product-card",opacity:[0,1],duration:1200,translateY:[20,0],delay:function(t,s){return 100*s}})}initBaseNextPageUrl(t){this.nextPage=salla.url.api(`products?source=${t}`),this.includes?.length&&(this.nextPage+=`&includes[]=${this.includes.join("&includes[]=")}`),this.limit&&(this.nextPage+=`&per_page=${this.limit>32?32:this.limit}`),this.sortBy&&(this.nextPage+=`&sort=${this.sortBy}`),"preview"===salla.config.get("theme.mode")&&(this.nextPage+="&use_username_url=1"),this.nextPage+="&filterable=1";for(const[t,s]of Object.entries(this.parsedFilters||{}))if(["string","number"].includes(typeof s))this.nextPage+=`&filters[${encodeURIComponent(t)}]=${encodeURIComponent(s)}`;else if(Array.isArray(s))s.forEach((s=>this.nextPage+=`&filters[${encodeURIComponent(t)}][]=${encodeURIComponent(s)}`));else if("object"==typeof s)for(const[i,e]of Object.entries(s))this.nextPage+=`&filters[${encodeURIComponent(t)}][${encodeURIComponent(i)}]=${encodeURIComponent(e)}`}buildNextPageUrl(){let t=this.getSource();if("json"===t)return;const s=sessionStorage.getItem(this.infiniteScrollStateKey);if(s){const{nextPage:t}=JSON.parse(s);if(!t)return}if(this.initBaseNextPageUrl(t),!this.isSourceWithoutValue())if(["search","related","landing-page"].includes(t))this.nextPage+=`&source_value=${this.getSourceValue()}`;else try{this.nextPage+=`&source_value[]=${this.getSourceValue().join("&source_value[]=")}`}catch(s){salla.logger.warn(`source-value prop should be array of ids ex source-value="[1,2,3]" for the source [${t}]`),this.sourceValueIsValid=!1}}loading(t=!0,s=!1){if(t){let t=s&&!this.autoload?this.btnLoader:this.loader;t&&(t.style.display="inherit")}else this.autoload||this.btnLoader&&(this.btnLoader.style.display="none"),this.loader&&(this.loader.style.display="none")}getItemHTML(t){"landing-page"===this.getSource()&&(t.url="");const s=document.createElement(this.hasCustomComponent?this.productCardComponent:"salla-product-card");return s.product=t,this.compactCards&&(s.compact=!0,s.toggleAttribute("compact",!0)),this.applyLandingPageStyles(s),this.applyHorizontalCardStyles(s),s.addEventListener("click",(s=>{s.target.closest("a")&&(h.saveProductSource(this.getSource()),this.hasInfiniteScroll&&(this.takeStateSnapshot(),sessionStorage.setItem(this.lastViewedProductKey,t.id)))})),s}applyLandingPageStyles(t){"landing-page"!==this.getSource()||this.hasCustomComponent||(t.toggleAttribute("hide-add-btn",!0),t.classList.add("s-product-card-fit-height"))}applyHorizontalCardStyles(t){this.horizontalCards&&(t.toggleAttribute("horizontal",!0),this.hasCustomComponent||t.toggleAttribute("shadow-on-hover",!0))}waitForResizing(t){let s=null;return new Promise((i=>{const e=new ResizeObserver((()=>{clearTimeout(s),s=setTimeout((()=>{e.disconnect(),i(null)}),160)}));e.observe(t)}))}waitForLayoutStable(t){let s=null;return new Promise((i=>{const e=new MutationObserver((()=>{clearTimeout(s),s=setTimeout((()=>{e.disconnect(),i(null)}),160)}));e.observe(t,{childList:!0,subtree:!0,attributes:!0})}))}async waitForStableLayout(t){return await Promise.allSettled([this.waitForResizing(t),this.waitForLayoutStable(t)])}scrollToLastViewedProduct(){const t=sessionStorage.getItem(this.lastViewedProductKey);t&&!salla.url.is_page("product.single")&&this.isElementLoaded(`[id*="${t}"]`).then((()=>{const s=this.wrapper?.querySelector(`[id*="${t}"]`);if(!s)return;const i=()=>{const t=()=>{s.scrollIntoView({block:"start",behavior:"instant"});const t=matchMedia("(max-width: 1024px)").matches?"header .inner":"ul.main-menu",i=window?.header_is_sticky?document.querySelector(t)?.getBoundingClientRect()?.height??56:0,e=parseInt(getComputedStyle(this.wrapper).rowGap)??16;scrollBy({top:-1*(i+e),behavior:"instant"})};requestAnimationFrame(t),s.querySelectorAll("img.lazy").forEach((s=>{const i=s,e=()=>{requestAnimationFrame(t),i.onload=i.onerror=null};i.onload=e,i.onerror=e})),this.removeScrollRestorationSession()};this.waitForStableLayout(this.host).then((()=>requestAnimationFrame(i)))}))}isElementLoaded(t){return new Promise((s=>{const i=setInterval((()=>{if(document.querySelector(t))return clearInterval(i),s(document.querySelector(t))}),50)}))}takeStateSnapshot(){const t=[];for(let s=0;s<this.wrapper.children.length;s++){const i=this.wrapper.children?.[s];t.push(i.product)}const s={pageIndex:Math.max((this.infiniteScroll?.pageIndex??1)-1,1),nextPage:this.nextPage,currentPageData:t};if(this.isFilterable()){const t=sessionStorage.getItem(this.filtersKey);sessionStorage.setItem(this.filtersKey,t||JSON.stringify(this.filtersSnapshot))}sessionStorage.setItem(this.infiniteScrollStateKey,JSON.stringify(s));let i=salla.config.get("page.id");const e=Object.keys(this.specialPagesWithoutIds).find((t=>salla.url.is_page(t)));e?i=this.specialPagesWithoutIds[e]:null!==i&&(i=String(i)),sessionStorage.setItem(this.prevCategoryIdKey,i)}removeScrollRestorationSession(){this.isFilterable()||sessionStorage.removeItem(this.filtersKey),sessionStorage.removeItem(this.infiniteScrollStateKey),sessionStorage.removeItem(this.lastViewedProductKey),sessionStorage.removeItem(this.prevCategoryIdKey)}loadStoredScrollState(){const t=sessionStorage.getItem(this.infiniteScrollStateKey),s=sessionStorage.getItem(this.filtersKey),i=sessionStorage.getItem(this.prevCategoryIdKey),e=this.specialPagesWithoutIds[salla.config.get("page.slug")]||null,o=salla.config.get("page.id"),a=salla.url.is_page("index"),r=salla.url.is_page("product.single"),l=e?i!==e:i!==String(o);if(i&&l&&!a&&!r||a&&!this.hasInfiniteScroll)return this.removeScrollRestorationSession(),this.switchToNormalBehavior=!0,!1;if(r)return this.switchToNormalBehavior=!0,!1;if(t)try{const{pageIndex:i,nextPage:e,currentPageData:o}=JSON.parse(t);if("undefined"!==s){const t=JSON.parse(s);salla.event.emit("filters::fetched",{filters:t})}this.page=i,this.nextPage=e;for(let t=0;t<o.length;t++)this.wrapper.append(this.getItemHTML(o?.[t]));return!0}catch(t){console.error("Failed to load stored scroll state:",t),this.removeScrollRestorationSession()}return!1}getSource(){return h.getProductsSource(this.source)}getSourceValue(){return this.currentCategoryIdFilter?this.currentCategoryIdFilter:h.getProductsSourceValue(this.source,this.sourceValue)}appendDataLayer(t){"object"==typeof dataLayer&&Array.isArray(dataLayer)&&dataLayer.push({event:"impressions",ecommerce:{currencyCode:salla.config.currency().code,impressions:t.map(((t,s)=>({id:t.id,name:t.name,price:t.price,brand:t.brand?.name||"",quantity:t.quantity,categories:[{name:t.category?.name||salla.config.get("page.title"),id:salla.config.get("page.id")}],category:t.category?.name||salla.config.get("page.title"),position:s+1})))}})}initiateInfiniteScroll(){if(!this.hasInfiniteScroll)return;const t=this.autoload&&this.includes&&this.includes.length>0;this.infiniteScroll=salla.infiniteScroll.initiate(this.wrapper,this.wrapper,{path:()=>this.nextPage,history:!1,nextPage:this.nextPage,scrollThreshold:!t&&!!this.autoload&&100,loadOnScroll:!t&&this.autoload},!0),this.infiniteScroll.pageIndex=this.page,this.infiniteScroll?.on("request",(()=>{this.loading(!0,!this.autoload)})),t&&window.addEventListener("scroll",this.boundHandleScroll),this.infiniteScroll?.on("load",(async t=>{if(!this.isProcessing){this.isProcessing=!0;try{if(!t.data?.length&&2===this.infiniteScroll.pageIndex)return this.showPlaceholder=!0,salla.infiniteScroll.destroy(this.infiniteScroll),this.loading(!1),void(this.placeholderLoader&&this.placeholderLoader.remove());this.includes&&await this.injectAndProcessData(t);const s=this.handleResponse(t);this.infiniteScroll.appendItems(s),2===this.infiniteScroll.pageIndex&&(!this.autoload&&this.nextPage&&(this.loadMoreWrapper.style.display="block"),this.animateItems())}catch(t){console.error("Error during load:",t)}finally{this.isProcessing=!1}}})),this.infiniteScroll?.on("error",(()=>{console.log("Error occurred during request"),this.status.querySelector(".s-infinite-scroll-error").classList.remove("s-hidden"),this.placeholderLoader&&this.placeholderLoader.remove(),this.loading(!1),this.isProcessing=!1})),salla.onReady((()=>{sessionStorage.getItem(this.infiniteScrollStateKey)||this.manualLoadNextPage()}))}handleScroll(){this.isProcessing||this.scrollTimeout||(this.scrollTimeout=setTimeout((()=>{this.scrollTimeout=null,requestAnimationFrame((()=>{const t=this.wrapper.getBoundingClientRect(),s=window.innerHeight;t.bottom-s<=200&&!this.isProcessing&&this.nextPage&&this.manualLoadNextPage()}))}),200))}manualLoadNextPage(){this.nextPage&&this.infiniteScroll.loadNextPage()}async injectAndProcessData(t){try{await h.injectExtraFieldsToResponse(t)}catch(t){console.error("Error injecting data:",t)}}getInitialData(){return this.loading(),salla.api.withoutNotifier((()=>salla.product.api.fetch({source:h.getApiSource(this.getSource()),source_value:this.getSourceValue(),limit:this.limit}).then((async t=>t.data.length?(await h.injectExtraFieldsToResponse(t),this.firstPageResponse?void this.handleResponse(t).forEach((t=>this.wrapper.append(t))):(this.firstPageResponse=t,void(this.nextPage=t.cursor?t.cursor.next:this.nextPage))):(this.showPlaceholder=!0,this.placeholderLoader&&this.placeholderLoader.remove(),void this.loading(!1))))))}async loadMore(){this.infiniteScroll?.loadNextPage()}componentWillLoad(){return salla.onReady().then((()=>{this.hasCustomComponent=!!customElements.get(this.productCardComponent),this.sourceValueIsValid=!(!this.getSourceValue()&&!this.isSourceWithoutValue()),this.hasInfiniteScroll=!["json","selected","related","landing-page","recently"].includes(this.getSource())&&!this.limit;let t=new URLSearchParams(window.location.search);try{this.sortBy=this.sortBy||t.get("sort")||t.get("by"),this.parsedFilters=h.extractFiltersFromUrl(t),this.parsedFilters&&this.parsedFilters.category_id&&(this.currentCategoryIdFilter=[this.parsedFilters.category_id])}catch(t){salla.logger.warn("failed to get filters from url",t.message)}if(this.buildNextPageUrl(),this.isReady=!0,!sessionStorage.getItem(this.infiniteScrollStateKey))if(this.sourceValueIsValid){if(!this.hasInfiniteScroll){if("json"===this.getSource())return this.getSourceValue().length?void setTimeout((()=>{this.getSourceValue().map((t=>this.wrapper.append(this.getItemHTML(t))))})):void(this.showPlaceholder=!0);if("selected"!==this.getSource()||this.getSourceValue().length)return this.getInitialData();this.showPlaceholder=!0}}else salla.logger.warn(`source-value prop is required for source [${this.getSource()}]`)}))}async componentDidLoad(){this.hasInfiniteScroll&&this.init(),await Salla.hooks.registerComponent("salla-products-list",this),this.loadStoredScrollState()?(this.autoload?!this.nextPage&&this.loading(!1):this.nextPage?this.loadMoreWrapper&&(this.loadMoreWrapper.style.display="block"):(this.loadMoreWrapper&&(this.loadMoreWrapper.style.display="none"),this.status.querySelector(".s-infinite-scroll-last").classList.remove("s-hidden")),this.scrollToLastViewedProduct()):!this.firstPageResponse&&this.switchToNormalBehavior?this.getInitialData().then((()=>{this.firstPageResponse?(this.handleResponse(this.firstPageResponse,!1).forEach((t=>{this.wrapper.append(t)})),setTimeout((()=>{if(!this.autoload&&this.nextPage&&1==this.infiniteScroll.pageIndex){const t=this.host.querySelector(".s-infinite-scroll-wrapper");t&&(t.style.display="block")}}))):console.error("No response received after getInitialData.")})).catch((t=>{console.error("Error during initial data fetch:",t)})):this.firstPageResponse&&this.handleResponse(this.firstPageResponse,!1).forEach((t=>this.wrapper.append(t)))}canRender(){return this.sourceValueIsValid&&this.isReady}render(){return this.canRender()?this.showPlaceholder?o("div",{class:"s-products-list-placeholder"},o("span",{innerHTML:l}),o("p",null,this.placeholderText)):o(a,{class:"s-products-list"},o("div",{class:{"s-products-list-wrapper":!0,"s-products-list-horizontal-cards":this.horizontalCards&&!this.filtersResults,"s-products-list-vertical-cards":!this.horizontalCards&&!this.rowCards&&!this.filtersResults,"s-products-list-row-cards":this.rowCards,"s-products-list-compact-cards":this.compactCards,"s-products-list-filters-results":this.filtersResults},ref:t=>this.wrapper=t}),o("div",{class:"s-infinite-scroll-status",ref:t=>this.status=t},o("p",{class:"s-infinite-scroll-last infinite-scroll-last s-hidden"},this.endOfText),o("p",{class:"s-infinite-scroll-error infinite-scroll-error s-hidden"},this.failedLoadMore)),this.autoload&&o("div",{class:"s-products-list-loading-wrapper",style:{display:"none"},ref:t=>this.loader=t},o("span",{class:"s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"})),this.hasInfiniteScroll&&this.nextPage&&!this.autoload?o("div",{class:"s-infinite-scroll-wrapper",style:{display:"none"},ref:t=>this.loadMoreWrapper=t},o("button",{onClick:()=>this.loadMore(),class:"s-infinite-scroll-btn s-button-btn s-button-primary"},o("span",{class:"s-button-text s-infinite-scroll-btn-text"},this.loadMoreText?this.loadMoreText:salla.lang.get("common.elements.load_more")),o("span",{class:"s-button-loader s-button-loader-center s-infinite-scroll-btn-loader",ref:t=>this.btnLoader=t,style:{display:"none"}}))):""):""}init(){this.initiateInfiniteScroll(),this.loading()}handleResponse(t,s=!0){if(!t)return[];let i=this.getSource(),e="";if(1===t.cursor?.current){e=h.getPageTitleForSource(i);try{if("search"===this.getSource())e=salla.lang.get("common.elements.search_about",{word:this.getSourceValue()});else if(!e){let s=this.parsedFilters.category_id||this.getSourceValue()[0];e=t.filters?.find((t=>"category_id"===t.key))?.values?.find((t=>t.key===s))?.value??"",this.filtersSnapshot=t.filters}e+=(e?" - ":"")+salla.lang.choice("blocks.header.products_count",t.data?.length),15===t.data.length&&(e=e.replace(t.data.length,salla.lang.get("common.elements.more_than")+" "+t.data.length)),t.title=e}catch(t){salla.logger.error("Error::falid to handle response",t)}h.generateProductSchema(t.data)}this.appendDataLayer(t.data),t.nextPage=this.nextPage,t.source=this.getSource(),t.sourceValue=this.getSourceValue(),salla.event.emit("salla-products-list::products.fetched",t),this.productsFetched.emit(t),t.filters&&this.isFilterable()?(this.filtersResults=!0,this.filtersSnapshot=JSON.parse(JSON.stringify(t.filters)),salla.event.emit("filters::fetched",{filters:t.filters})):this.isFilterable()&&salla.event.emit("filters::hidden"),s&&(this.nextPage=t.cursor?t.cursor.next:this.nextPage),this.loading(!1),this.placeholderLoader&&this.placeholderLoader.remove(),this.hasInfiniteScroll&&!this.nextPage&&(this.infiniteScroll.option({scrollThreshold:!1,loadOnScroll:!1}),this.status.querySelector(".s-infinite-scroll-last").classList.remove("s-hidden"));const o=[];for(let s=0;s<t.data.length;s++)o.push(this.getItemHTML(t.data?.[s]));return o}get host(){return this}static get style(){return""}},[0,"salla-products-list",{source:[1537],sourceValue:[1032,"source-value"],limit:[1026],sortBy:[1025,"sort-by"],filtersResults:[1540,"filters-results"],horizontalCards:[516,"horizontal-cards"],rowCards:[516,"row-cards"],compactCards:[516,"compact-cards"],autoload:[1028],loadMoreText:[1,"load-more-text"],productCardComponent:[1,"product-card-component"],includes:[1040],page:[32],nextPage:[32],hasInfiniteScroll:[32],hasCustomComponent:[32],sourceValueIsValid:[32],placeholderText:[32],endOfText:[32],failedLoadMore:[32],currentPage:[32],currentCategoryIdFilter:[32],isReady:[32],showPlaceholder:[32],switchToNormalBehavior:[32],parsedFilters:[32],filtersSnapshot:[32],setFilters:[64],reload:[64]}]);function c(){"undefined"!=typeof customElements&&["salla-products-list"].forEach((s=>{"salla-products-list"===s&&(customElements.get(t(s))||customElements.define(t(s),n))}))}c();export{n as S,c as d}