@salla.sa/twilight-components 2.14.392 → 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.
- package/dist/cjs/app-globals-oehrC7QI.js +39 -0
- package/dist/cjs/{filepond-D-ur1GA-.js → filepond-D7RVR_w_.js} +10 -5
- package/dist/cjs/{filepond-plugin-file-poster-DigEeKId.js → filepond-plugin-file-poster-DTuZK2ot.js} +11 -7
- package/dist/cjs/{filepond-plugin-file-validate-size-R9el3Yro.js → filepond-plugin-file-validate-size-DHc6pF_j.js} +1 -1
- package/dist/cjs/filepond-plugin-file-validate-type-DnkcvJVc.js +271 -0
- package/dist/cjs/{filepond-plugin-image-edit-bhI8kqN_.js → filepond-plugin-image-edit-vrZ1s7kw.js} +1 -1
- package/dist/cjs/{filepond-plugin-image-exif-orientation-COXZUVRV.js → filepond-plugin-image-exif-orientation-Bn5JSzQK.js} +1 -1
- package/dist/cjs/{filepond-plugin-image-preview-COP8QJBf.js → filepond-plugin-image-preview-8qWUFe9n.js} +1 -1
- package/dist/cjs/{index-CGnPURjZ.js → index-C5VeFDQ0.js} +1966 -1344
- package/dist/cjs/{index-BILBEE9f.js → index-CwD81m7i.js} +1 -1
- package/dist/cjs/loader.cjs.js +4 -3
- package/dist/cjs/salla-accordion-body_2.cjs.entry.js +5 -5
- package/dist/cjs/salla-accordion_6.cjs.entry.js +19 -15
- package/dist/cjs/salla-add-product-button_4.cjs.entry.js +12 -10
- package/dist/cjs/salla-advertisement.cjs.entry.js +3 -3
- package/dist/cjs/salla-alert_2.cjs.entry.js +5 -5
- package/dist/cjs/salla-app-install-alert.cjs.entry.js +3 -3
- package/dist/cjs/salla-apps-icons.cjs.entry.js +3 -3
- package/dist/cjs/salla-booking-field_7.cjs.entry.js +25 -23
- package/dist/cjs/salla-bullet-delivery.cjs.entry.js +3 -3
- package/dist/cjs/salla-cart-coupons.cjs.entry.js +3 -3
- package/dist/cjs/salla-cart-item-offers_2.cjs.entry.js +5 -5
- package/dist/cjs/salla-comment-form_8.cjs.entry.js +17 -17
- package/dist/cjs/salla-conditional-offer.cjs.entry.js +3 -3
- package/dist/cjs/salla-contacts.cjs.entry.js +3 -3
- package/dist/cjs/salla-cookies-bar.cjs.entry.js +3 -3
- package/dist/cjs/salla-count-down.cjs.entry.js +35 -11
- package/dist/cjs/salla-custom-fields.cjs.entry.js +3 -3
- package/dist/cjs/salla-delivery-promise.cjs.entry.js +1 -1
- package/dist/cjs/salla-filters-widget.cjs.entry.js +3 -3
- package/dist/cjs/salla-filters.cjs.entry.js +3 -3
- package/dist/cjs/salla-fulfillment-methods.cjs.entry.js +1 -1
- package/dist/cjs/salla-gifting.cjs.entry.js +3 -3
- package/dist/cjs/salla-hook.cjs.entry.js +5 -2
- package/dist/cjs/salla-infinite-scroll.cjs.entry.js +3 -3
- package/dist/cjs/salla-installment.cjs.entry.js +3 -3
- package/dist/cjs/salla-list-tile.cjs.entry.js +3 -3
- package/dist/cjs/salla-localization-modal.cjs.entry.js +1 -1
- package/dist/cjs/salla-login-modal.cjs.entry.js +3 -3
- package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +3 -3
- package/dist/cjs/salla-loyalty-program.cjs.entry.js +3 -3
- package/dist/cjs/salla-loyalty.cjs.entry.js +3 -3
- package/dist/cjs/salla-maintenance-alert.cjs.entry.js +3 -3
- package/dist/cjs/salla-map.cjs.entry.js +3 -3
- package/dist/cjs/salla-menu.cjs.entry.js +3 -3
- package/dist/cjs/salla-metadata.cjs.entry.js +3 -3
- package/dist/cjs/salla-multiple-bundle-product-cart_2.cjs.entry.js +5 -5
- package/dist/cjs/salla-multiple-bundle-product-options-modal_2.cjs.entry.js +8 -6
- package/dist/cjs/salla-multiple-bundle-product.cjs.entry.js +6 -4
- package/dist/cjs/salla-notification-item.cjs.entry.js +3 -3
- package/dist/cjs/salla-notifications.cjs.entry.js +50 -5
- package/dist/cjs/salla-offer-modal.cjs.entry.js +3 -3
- package/dist/cjs/salla-offer.cjs.entry.js +3 -3
- package/dist/cjs/salla-order-details-multiple-bundle-product.cjs.entry.js +3 -3
- package/dist/cjs/salla-order-details-options.cjs.entry.js +3 -3
- package/dist/cjs/salla-order-details.cjs.entry.js +6 -4
- package/dist/cjs/salla-order-edit-item.cjs.entry.js +3 -3
- package/dist/cjs/salla-order-edit.cjs.entry.js +3 -3
- package/dist/cjs/salla-order-summary.cjs.entry.js +3 -3
- package/dist/cjs/salla-order-totals-card.cjs.entry.js +6 -4
- package/dist/cjs/salla-orders.cjs.entry.js +3 -3
- package/dist/cjs/salla-payments.cjs.entry.js +3 -3
- package/dist/cjs/salla-placeholder.cjs.entry.js +3 -3
- package/dist/cjs/salla-price-range.cjs.entry.js +3 -3
- package/dist/cjs/salla-product-card.cjs.entry.js +3 -3
- package/dist/cjs/salla-product-size-guide.cjs.entry.js +3 -3
- package/dist/cjs/salla-products-list.cjs.entry.js +3 -3
- package/dist/cjs/salla-products-slider.cjs.entry.js +3 -3
- package/dist/cjs/salla-progress-bar.cjs.entry.js +3 -3
- package/dist/cjs/salla-quick-order.cjs.entry.js +3 -3
- package/dist/cjs/salla-rating-modal.cjs.entry.js +3 -3
- package/dist/cjs/salla-scopes.cjs.entry.js +3 -3
- package/dist/cjs/salla-search.cjs.entry.js +6 -4
- package/dist/cjs/salla-skeleton.cjs.entry.js +3 -3
- package/dist/cjs/salla-slider.cjs.entry.js +20 -14
- package/dist/cjs/salla-social-share.cjs.entry.js +3 -3
- package/dist/cjs/salla-social.cjs.entry.js +3 -3
- package/dist/cjs/salla-tab-content_3.cjs.entry.js +7 -7
- package/dist/cjs/salla-tiered-offer.cjs.entry.js +3 -3
- package/dist/cjs/salla-tooltip.cjs.entry.js +3 -3
- package/dist/cjs/salla-trust-badges.cjs.entry.js +3 -3
- package/dist/cjs/salla-user-menu.cjs.entry.js +3 -3
- package/dist/cjs/salla-user-profile.cjs.entry.js +3 -3
- package/dist/cjs/salla-user-settings.cjs.entry.js +3 -3
- package/dist/cjs/salla-verify.cjs.entry.js +3 -3
- package/dist/cjs/salla-wallet.cjs.entry.js +3 -3
- package/dist/cjs/twilight.cjs.js +5 -4
- package/dist/cjs/{vanilla-picker-DI3TImGd.js → vanilla-picker-yKERbLpx.js} +1 -1
- package/dist/collection/collection-manifest.json +3 -2
- package/dist/collection/components/salla-accordion/salla-accordion-head.js +2 -2
- package/dist/collection/components/salla-accordion/salla-accordion.js +4 -4
- package/dist/collection/components/salla-add-product-button/salla-add-product-button.js +19 -19
- package/dist/collection/components/salla-alert/salla-alert.js +5 -5
- package/dist/collection/components/salla-apps-icons/salla-apps-icons.js +6 -6
- package/dist/collection/components/salla-booking-field/salla-booking-field.js +4 -4
- package/dist/collection/components/salla-bottom-alert/salla-bottom-alert.js +9 -9
- package/dist/collection/components/salla-bullet-delivery/salla-bullet-delivery.js +6 -3
- package/dist/collection/components/salla-button/salla-button.js +11 -11
- package/dist/collection/components/salla-cart-coupons/salla-cart-coupons.js +2 -1
- package/dist/collection/components/salla-cart-item-offers/salla-cart-item-offers.js +8 -8
- package/dist/collection/components/salla-cart-summary/salla-cart-summary.js +2 -2
- package/dist/collection/components/salla-color-picker/salla-color-picker.js +20 -14
- package/dist/collection/components/salla-comment-form/salla-comment-form.js +6 -6
- package/dist/collection/components/salla-comments/salla-comment-item.js +2 -3
- package/dist/collection/components/salla-comments/salla-comments.js +18 -17
- package/dist/collection/components/salla-contacts/salla-contacts.js +10 -10
- package/dist/collection/components/salla-count-down/salla-count-down.js +66 -42
- package/dist/collection/components/salla-custom-fields/salla-custom-fields.js +9 -7
- package/dist/collection/components/salla-datetime-picker/salla-datetime-picker.js +69 -65
- package/dist/collection/components/salla-drawer/salla-drawer.js +11 -11
- package/dist/collection/components/salla-file-upload/salla-file-upload.css +1 -1
- package/dist/collection/components/salla-file-upload/salla-file-upload.js +85 -84
- package/dist/collection/components/salla-filters/salla-filters.js +2 -2
- package/dist/collection/components/salla-filters-widget/salla-filters-widget.js +4 -5
- package/dist/collection/components/salla-gifting/salla-gifting.js +11 -11
- package/dist/collection/components/salla-hook/salla-hook.js +2 -2
- package/dist/collection/components/salla-infinite-scroll/salla-infinite-scroll.js +6 -6
- package/dist/collection/components/salla-installment/salla-installment.js +5 -5
- package/dist/collection/components/salla-list-tile/salla-list-tile.js +2 -2
- package/dist/collection/components/salla-loading/salla-loading.js +4 -4
- package/dist/collection/components/salla-localization-modal/salla-localization-modal.js +5 -5
- package/dist/collection/components/salla-login-modal/salla-login-modal.js +14 -14
- package/dist/collection/components/salla-loyalty/salla-loyalty-prize-item.js +4 -3
- package/dist/collection/components/salla-loyalty/salla-loyalty.js +13 -12
- package/dist/collection/components/salla-map/salla-map.js +14 -14
- package/dist/collection/components/salla-menu/salla-menu.js +10 -9
- package/dist/collection/components/salla-metadata/salla-metadata.js +3 -3
- package/dist/collection/components/salla-modal/salla-modal.js +11 -11
- package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-cart.js +2 -2
- package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-details.js +2 -2
- package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-options-modal.js +4 -2
- package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-slider.js +8 -7
- package/dist/collection/components/salla-multiple-bundle-product/salla-multiple-bundle-product.js +2 -2
- package/dist/collection/components/salla-notifications/salla-notification-item.js +2 -2
- package/dist/collection/components/salla-notifications/salla-notifications.js +50 -5
- package/dist/collection/components/salla-offer/salla-offer.js +1 -1
- package/dist/collection/components/salla-order-details/salla-order-details-multiple-bundle-product.js +5 -5
- package/dist/collection/components/salla-order-details/salla-order-details-options.js +6 -5
- package/dist/collection/components/salla-order-details/salla-order-details.js +4 -3
- package/dist/collection/components/salla-order-edit/salla-order-edit-item.js +4 -4
- package/dist/collection/components/salla-order-edit/salla-order-edit.js +4 -4
- package/dist/collection/components/salla-order-summary/salla-order-summary.js +2 -2
- package/dist/collection/components/salla-order-totals-card/salla-order-totals-card.js +4 -3
- package/dist/collection/components/salla-orders/salla-orders.js +4 -4
- package/dist/collection/components/salla-payments/salla-payments.js +0 -1
- package/dist/collection/components/salla-placeholder/salla-placeholder.js +3 -3
- package/dist/collection/components/salla-price-range/salla-price-range.js +8 -8
- package/dist/collection/components/salla-product-availability/salla-product-availability.js +6 -6
- package/dist/collection/components/salla-product-card/salla-product-card.js +18 -18
- package/dist/collection/components/salla-product-options/salla-product-options.js +15 -13
- package/dist/collection/components/salla-products-list/salla-products-list.js +20 -21
- package/dist/collection/components/salla-products-slider/salla-products-slider.js +22 -23
- package/dist/collection/components/salla-progress-bar/salla-progress-bar.js +21 -20
- package/dist/collection/components/salla-quantity-input/salla-quantity-input.js +2 -2
- package/dist/collection/components/salla-quick-buy/salla-quick-buy.js +16 -17
- package/dist/collection/components/salla-quick-order/salla-quick-order.js +11 -11
- package/dist/collection/components/salla-rating-modal/salla-rating-modal.js +2 -2
- package/dist/collection/components/salla-rating-stars/salla-rating-stars.js +8 -8
- package/dist/collection/components/salla-review-card/salla-review-card.js +3 -3
- package/dist/collection/components/salla-reviews/salla-reviews.js +16 -13
- package/dist/collection/components/salla-reviews-summary/salla-reviews-summary.js +2 -2
- package/dist/collection/components/salla-scopes/salla-scopes.js +2 -2
- package/dist/collection/components/salla-search/salla-search.js +6 -6
- package/dist/collection/components/salla-skeleton/salla-skeleton.js +3 -3
- package/dist/collection/components/salla-slider/salla-slider.css +9 -2
- package/dist/collection/components/salla-slider/salla-slider.js +25 -25
- package/dist/collection/components/salla-social-share/salla-social-share.js +3 -3
- package/dist/collection/components/salla-tabs/salla-tab-content.js +2 -2
- package/dist/collection/components/salla-tabs/salla-tab-header.js +5 -5
- package/dist/collection/components/salla-tabs/salla-tabs.js +2 -2
- package/dist/collection/components/salla-tel-input/salla-tel-input.js +9 -8
- package/dist/collection/components/salla-tooltip/salla-tooltip.js +5 -5
- package/dist/collection/components/salla-trust-badges/salla-trust-badges.js +1 -1
- package/dist/collection/components/salla-user-menu/salla-user-menu.js +5 -5
- package/dist/collection/components/salla-user-profile/salla-user-profile.js +1 -1
- package/dist/collection/components/salla-verify/salla-verify.js +4 -4
- package/dist/components/Helper.js +1 -432
- package/dist/components/_commonjsHelpers.js +1 -7
- package/dist/components/anime.es.js +1 -1310
- package/dist/components/arrow-left.js +1 -8
- package/dist/components/axios.js +2 -3908
- package/dist/components/bell-ring.js +1 -8
- package/dist/components/camera.js +1 -8
- package/dist/components/cancel.js +1 -8
- package/dist/components/cart.js +1 -8
- package/dist/components/check-circle2.js +1 -15
- package/dist/components/check.js +1 -8
- package/dist/components/facebook.js +1 -10
- package/dist/components/filepond-plugin-file-poster.js +3 -659
- package/dist/components/filepond-plugin-file-validate-size.js +2 -204
- package/dist/components/filepond-plugin-file-validate-type.js +3 -279
- package/dist/components/filepond-plugin-image-edit.js +2 -487
- package/dist/components/filepond-plugin-image-exif-orientation.js +2 -214
- package/dist/components/filepond-plugin-image-preview.js +2 -2237
- package/dist/components/filepond.js +3 -11282
- package/dist/components/gift.js +1 -8
- package/dist/components/image.js +1 -8
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.js +1 -8163
- package/dist/components/index2.js +1 -1709
- package/dist/components/index3.js +1 -2550
- package/dist/components/interfaces.js +1 -12
- package/dist/components/isObject.js +1 -292
- package/dist/components/keyboard_arrow_down.js +1 -8
- package/dist/components/keyboard_arrow_right.js +1 -15
- package/dist/components/location.js +1 -11
- package/dist/components/mail.js +1 -8
- package/dist/components/minus.js +1 -15
- package/dist/components/salla-accordion-body.js +1 -6
- package/dist/components/salla-accordion-body2.js +1 -30
- package/dist/components/salla-accordion-head.js +1 -6
- package/dist/components/salla-accordion-head2.js +1 -63
- package/dist/components/salla-accordion.js +1 -6
- package/dist/components/salla-accordion2.js +1 -68
- package/dist/components/salla-add-product-button.js +1 -6
- package/dist/components/salla-add-product-button2.js +1 -306
- package/dist/components/salla-advertisement.js +1 -155
- package/dist/components/salla-alert.js +1 -59
- package/dist/components/salla-app-install-alert.js +1 -91
- package/dist/components/salla-apps-icons.js +1 -63
- package/dist/components/salla-booking-field.js +1 -6
- package/dist/components/salla-booking-field2.js +1 -221
- package/dist/components/salla-bottom-alert.js +1 -214
- package/dist/components/salla-breadcrumb.js +1 -226
- package/dist/components/salla-bullet-delivery.js +1 -2114
- package/dist/components/salla-button.js +1 -6
- package/dist/components/salla-button2.js +1 -174
- package/dist/components/salla-cart-coupons.js +1 -284
- package/dist/components/salla-cart-item-offers.js +1 -143
- package/dist/components/salla-cart-summary.js +1 -136
- package/dist/components/salla-color-picker.js +1 -6
- package/dist/components/salla-color-picker2.js +1 -260
- package/dist/components/salla-comment-form.js +1 -6
- package/dist/components/salla-comment-form2.js +1 -64
- package/dist/components/salla-comment-item.js +1 -6
- package/dist/components/salla-comment-item2.js +1 -217
- package/dist/components/salla-comments.js +1 -395
- package/dist/components/salla-conditional-fields.js +1 -6
- package/dist/components/salla-conditional-fields2.js +1 -137
- package/dist/components/salla-conditional-offer.js +1 -194
- package/dist/components/salla-contacts.js +1 -125
- package/dist/components/salla-cookies-bar.js +1 -107
- package/dist/components/salla-count-down.js +1 -6
- package/dist/components/salla-count-down2.js +1 -247
- package/dist/components/salla-custom-fields.js +1 -175
- package/dist/components/salla-datetime-picker.js +1 -6
- package/dist/components/salla-datetime-picker2.js +1 -342
- package/dist/components/salla-delivery-promise.js +1 -263
- package/dist/components/salla-drawer.js +1 -6
- package/dist/components/salla-drawer2.js +1 -214
- package/dist/components/salla-file-upload.js +1 -6
- package/dist/components/salla-file-upload2.js +1 -583
- package/dist/components/salla-filters-widget.js +1 -6
- package/dist/components/salla-filters-widget2.js +1 -245
- package/dist/components/salla-filters.js +1 -253
- package/dist/components/salla-fulfillment-methods.js +1 -61
- package/dist/components/salla-gifting.js +1 -732
- package/dist/components/salla-hook.js +1 -47
- package/dist/components/salla-infinite-scroll.js +1 -112
- package/dist/components/salla-installment.js +1 -306
- package/dist/components/salla-list-tile.js +1 -6
- package/dist/components/salla-list-tile2.js +1 -47
- package/dist/components/salla-loading.js +1 -6
- package/dist/components/salla-loading2.js +1 -51
- package/dist/components/salla-localization-modal.js +1 -296
- package/dist/components/salla-login-modal.js +1 -6
- package/dist/components/salla-login-modal2.js +1 -359
- package/dist/components/salla-loyalty-prize-item.js +1 -39
- package/dist/components/salla-loyalty-program.js +1 -115
- package/dist/components/salla-loyalty.js +1 -304
- package/dist/components/salla-maintenance-alert.js +1 -57
- package/dist/components/salla-map.js +1 -6
- package/dist/components/salla-map2.js +1 -766
- package/dist/components/salla-menu.js +1 -165
- package/dist/components/salla-metadata.js +1 -97
- package/dist/components/salla-modal.js +1 -6
- package/dist/components/salla-modal2.js +1 -215
- package/dist/components/salla-multiple-bundle-product-cart.js +1 -6
- package/dist/components/salla-multiple-bundle-product-cart2.js +1 -151
- package/dist/components/salla-multiple-bundle-product-details.js +1 -6
- package/dist/components/salla-multiple-bundle-product-details2.js +1 -296
- package/dist/components/salla-multiple-bundle-product-options-modal.js +1 -6
- package/dist/components/salla-multiple-bundle-product-options-modal2.js +1 -598
- package/dist/components/salla-multiple-bundle-product-slider.js +1 -6
- package/dist/components/salla-multiple-bundle-product-slider2.js +1 -136
- package/dist/components/salla-multiple-bundle-product.js +1 -207
- package/dist/components/salla-notification-item.js +1 -6
- package/dist/components/salla-notification-item2.js +1 -32
- package/dist/components/salla-notifications.js +1 -145
- package/dist/components/salla-offer-modal.js +1 -328
- package/dist/components/salla-offer.js +1 -478
- package/dist/components/salla-order-details-multiple-bundle-product.js +1 -6
- package/dist/components/salla-order-details-multiple-bundle-product2.js +1 -122
- package/dist/components/salla-order-details-options.js +1 -6
- package/dist/components/salla-order-details-options2.js +1 -140
- package/dist/components/salla-order-details.js +1 -122
- package/dist/components/salla-order-edit-item.js +1 -6
- package/dist/components/salla-order-edit-item2.js +1 -181
- package/dist/components/salla-order-edit.js +1 -288
- package/dist/components/salla-order-summary.js +1 -132
- package/dist/components/salla-order-totals-card.js +1 -87
- package/dist/components/salla-orders.js +1 -271
- package/dist/components/salla-payments.js +1 -76
- package/dist/components/salla-placeholder.js +1 -6
- package/dist/components/salla-placeholder2.js +1 -66
- package/dist/components/salla-price-range.js +1 -6
- package/dist/components/salla-price-range2.js +1 -204
- package/dist/components/salla-product-availability.js +1 -6
- package/dist/components/salla-product-availability2.js +1 -206
- package/dist/components/salla-product-card.js +1 -6
- package/dist/components/salla-product-card2.js +1 -241
- package/dist/components/salla-product-options.js +1 -6
- package/dist/components/salla-product-options2.js +1 -962
- package/dist/components/salla-product-size-guide.js +1 -130
- package/dist/components/salla-products-list.js +1 -6
- package/dist/components/salla-products-list2.js +1 -812
- package/dist/components/salla-products-slider.js +1 -6
- package/dist/components/salla-products-slider2.js +1 -215
- package/dist/components/salla-progress-bar.js +1 -6
- package/dist/components/salla-progress-bar2.js +1 -94
- package/dist/components/salla-quantity-input.js +1 -6
- package/dist/components/salla-quantity-input2.js +1 -127
- package/dist/components/salla-quick-buy.js +1 -6
- package/dist/components/salla-quick-buy2.js +1 -1181
- package/dist/components/salla-quick-order.js +1 -299
- package/dist/components/salla-rating-modal.js +1 -530
- package/dist/components/salla-rating-stars.js +1 -6
- package/dist/components/salla-rating-stars2.js +1 -162
- package/dist/components/salla-review-card.js +1 -6
- package/dist/components/salla-review-card2.js +1 -198
- package/dist/components/salla-reviews-page.js +1 -726
- package/dist/components/salla-reviews-summary.js +1 -6
- package/dist/components/salla-reviews-summary2.js +1 -132
- package/dist/components/salla-reviews.js +1 -143
- package/dist/components/salla-scopes.js +1 -249
- package/dist/components/salla-search.js +1 -213
- package/dist/components/salla-skeleton.js +1 -6
- package/dist/components/salla-skeleton2.js +1 -50
- package/dist/components/salla-slider.js +1 -6
- package/dist/components/salla-slider2.js +1 -10483
- package/dist/components/salla-social-share.js +1 -194
- package/dist/components/salla-social.js +1 -89
- package/dist/components/salla-tab-content.js +1 -6
- package/dist/components/salla-tab-content2.js +1 -55
- package/dist/components/salla-tab-header.js +1 -6
- package/dist/components/salla-tab-header2.js +1 -85
- package/dist/components/salla-tabs.js +1 -6
- package/dist/components/salla-tabs2.js +1 -75
- package/dist/components/salla-tel-input.js +1 -6
- package/dist/components/salla-tel-input2.js +1 -168
- package/dist/components/salla-tiered-offer.js +1 -366
- package/dist/components/salla-tooltip.js +1 -6
- package/dist/components/salla-tooltip2.js +1 -57
- package/dist/components/salla-trust-badges.js +1 -90
- package/dist/components/salla-user-menu.js +1 -344
- package/dist/components/salla-user-profile.js +1 -203
- package/dist/components/salla-user-settings.js +1 -139
- package/dist/components/salla-verify.js +1 -303
- package/dist/components/salla-wallet.js +1 -114
- package/dist/components/search.js +1 -8
- package/dist/components/shopping-bag.js +1 -8
- package/dist/components/special-discount.js +1 -8
- package/dist/components/star.js +1 -8
- package/dist/components/star2.js +1 -8
- package/dist/components/vanilla-picker.js +2 -1034
- package/dist/components/whatsapp2.js +1 -8
- package/dist/esm/app-globals-BFryt7-C.js +37 -0
- package/dist/esm/{filepond-kTbl0kuh.js → filepond-DlGaLh8N.js} +10 -5
- package/dist/esm/{filepond-plugin-file-poster-CyywnjKv.js → filepond-plugin-file-poster-BTVFYcQx.js} +11 -7
- package/dist/esm/{filepond-plugin-file-validate-size-DgteZhje.js → filepond-plugin-file-validate-size-DGryLmWv.js} +1 -1
- package/dist/esm/filepond-plugin-file-validate-type-DxKfCD0V.js +269 -0
- package/dist/esm/{filepond-plugin-image-edit-pZ_mETE7.js → filepond-plugin-image-edit-2W7pu9hn.js} +1 -1
- package/dist/esm/{filepond-plugin-image-exif-orientation-CjKYl7HL.js → filepond-plugin-image-exif-orientation-OQu-IvPH.js} +1 -1
- package/dist/esm/{filepond-plugin-image-preview-BzJTl_2A.js → filepond-plugin-image-preview-DEW_tSNR.js} +1 -1
- package/dist/esm/{index-3Kis_Ivk.js → index-BDqMkCqE.js} +1 -1
- package/dist/esm/{index-C23tPnnH.js → index-DYB20YqN.js} +1966 -1344
- package/dist/esm/loader.js +4 -3
- package/dist/esm/salla-accordion-body_2.entry.js +5 -5
- package/dist/esm/salla-accordion_6.entry.js +19 -15
- package/dist/esm/salla-add-product-button_4.entry.js +12 -10
- package/dist/esm/salla-advertisement.entry.js +3 -3
- package/dist/esm/salla-alert_2.entry.js +5 -5
- package/dist/esm/salla-app-install-alert.entry.js +3 -3
- package/dist/esm/salla-apps-icons.entry.js +3 -3
- package/dist/esm/salla-booking-field_7.entry.js +25 -23
- package/dist/esm/salla-bullet-delivery.entry.js +3 -3
- package/dist/esm/salla-cart-coupons.entry.js +3 -3
- package/dist/esm/salla-cart-item-offers_2.entry.js +5 -5
- package/dist/esm/salla-comment-form_8.entry.js +17 -17
- package/dist/esm/salla-conditional-offer.entry.js +3 -3
- package/dist/esm/salla-contacts.entry.js +3 -3
- package/dist/esm/salla-cookies-bar.entry.js +3 -3
- package/dist/esm/salla-count-down.entry.js +35 -11
- package/dist/esm/salla-custom-fields.entry.js +3 -3
- package/dist/esm/salla-delivery-promise.entry.js +1 -1
- package/dist/esm/salla-filters-widget.entry.js +3 -3
- package/dist/esm/salla-filters.entry.js +3 -3
- package/dist/esm/salla-fulfillment-methods.entry.js +1 -1
- package/dist/esm/salla-gifting.entry.js +3 -3
- package/dist/esm/salla-hook.entry.js +5 -2
- package/dist/esm/salla-infinite-scroll.entry.js +3 -3
- package/dist/esm/salla-installment.entry.js +3 -3
- package/dist/esm/salla-list-tile.entry.js +3 -3
- package/dist/esm/salla-localization-modal.entry.js +1 -1
- package/dist/esm/salla-login-modal.entry.js +3 -3
- package/dist/esm/salla-loyalty-prize-item.entry.js +3 -3
- package/dist/esm/salla-loyalty-program.entry.js +3 -3
- package/dist/esm/salla-loyalty.entry.js +3 -3
- package/dist/esm/salla-maintenance-alert.entry.js +3 -3
- package/dist/esm/salla-map.entry.js +3 -3
- package/dist/esm/salla-menu.entry.js +3 -3
- package/dist/esm/salla-metadata.entry.js +3 -3
- package/dist/esm/salla-multiple-bundle-product-cart_2.entry.js +5 -5
- package/dist/esm/salla-multiple-bundle-product-options-modal_2.entry.js +8 -6
- package/dist/esm/salla-multiple-bundle-product.entry.js +6 -4
- package/dist/esm/salla-notification-item.entry.js +3 -3
- package/dist/esm/salla-notifications.entry.js +50 -5
- package/dist/esm/salla-offer-modal.entry.js +3 -3
- package/dist/esm/salla-offer.entry.js +3 -3
- package/dist/esm/salla-order-details-multiple-bundle-product.entry.js +3 -3
- package/dist/esm/salla-order-details-options.entry.js +3 -3
- package/dist/esm/salla-order-details.entry.js +6 -4
- package/dist/esm/salla-order-edit-item.entry.js +3 -3
- package/dist/esm/salla-order-edit.entry.js +3 -3
- package/dist/esm/salla-order-summary.entry.js +3 -3
- package/dist/esm/salla-order-totals-card.entry.js +6 -4
- package/dist/esm/salla-orders.entry.js +3 -3
- package/dist/esm/salla-payments.entry.js +3 -3
- package/dist/esm/salla-placeholder.entry.js +3 -3
- package/dist/esm/salla-price-range.entry.js +3 -3
- package/dist/esm/salla-product-card.entry.js +3 -3
- package/dist/esm/salla-product-size-guide.entry.js +3 -3
- package/dist/esm/salla-products-list.entry.js +3 -3
- package/dist/esm/salla-products-slider.entry.js +3 -3
- package/dist/esm/salla-progress-bar.entry.js +3 -3
- package/dist/esm/salla-quick-order.entry.js +3 -3
- package/dist/esm/salla-rating-modal.entry.js +3 -3
- package/dist/esm/salla-scopes.entry.js +3 -3
- package/dist/esm/salla-search.entry.js +6 -4
- package/dist/esm/salla-skeleton.entry.js +3 -3
- package/dist/esm/salla-slider.entry.js +20 -14
- package/dist/esm/salla-social-share.entry.js +3 -3
- package/dist/esm/salla-social.entry.js +3 -3
- package/dist/esm/salla-tab-content_3.entry.js +7 -7
- package/dist/esm/salla-tiered-offer.entry.js +3 -3
- package/dist/esm/salla-tooltip.entry.js +3 -3
- package/dist/esm/salla-trust-badges.entry.js +3 -3
- package/dist/esm/salla-user-menu.entry.js +3 -3
- package/dist/esm/salla-user-profile.entry.js +3 -3
- package/dist/esm/salla-user-settings.entry.js +3 -3
- package/dist/esm/salla-verify.entry.js +3 -3
- package/dist/esm/salla-wallet.entry.js +3 -3
- package/dist/esm/twilight.js +5 -4
- package/dist/esm/{vanilla-picker-CEy5x8Cf.js → vanilla-picker-Dt9vZPZF.js} +1 -1
- package/dist/twilight/{p-651fe6e4.entry.js → p-06fa7327.entry.js} +1 -1
- package/dist/twilight/{p-a50f7f70.entry.js → p-09d39785.entry.js} +1 -1
- package/dist/twilight/{p-744d6394.entry.js → p-0add06f9.entry.js} +1 -1
- package/dist/twilight/{p-f251e744.entry.js → p-105b1dab.entry.js} +1 -1
- package/dist/twilight/{p-407828e4.entry.js → p-108d8c8b.entry.js} +1 -1
- package/dist/twilight/{p-2a1871c2.entry.js → p-1875537e.entry.js} +1 -1
- package/dist/twilight/{p-ff6f769c.entry.js → p-18bb0181.entry.js} +1 -1
- package/dist/twilight/p-1daeed6e.entry.js +4 -0
- package/dist/twilight/{p-2aa48902.entry.js → p-1ef2602d.entry.js} +1 -1
- package/dist/twilight/{p-27f34c85.entry.js → p-2881bb33.entry.js} +1 -1
- package/dist/twilight/{p-c3d0c062.entry.js → p-293c6cf3.entry.js} +1 -1
- package/dist/twilight/{p-866b297b.entry.js → p-296d2dd0.entry.js} +1 -1
- package/dist/twilight/{p-3a5aaa20.entry.js → p-2abaa633.entry.js} +1 -1
- package/dist/twilight/p-2ddb3fce.entry.js +4 -0
- package/dist/twilight/{p-81f648a2.entry.js → p-2fe01e44.entry.js} +1 -1
- package/dist/twilight/p-33779828.entry.js +4 -0
- package/dist/twilight/p-34968e31.entry.js +4 -0
- package/dist/twilight/{p-3745a7d0.entry.js → p-34b670fc.entry.js} +1 -1
- package/dist/twilight/{p-9f23dd30.entry.js → p-3ccc532d.entry.js} +1 -1
- package/dist/twilight/{p-f2ee9ceb.entry.js → p-41c733c2.entry.js} +1 -1
- package/dist/twilight/{p-67fe5680.entry.js → p-44fa7521.entry.js} +1 -1
- package/dist/twilight/{p-b4f07395.entry.js → p-4932857d.entry.js} +1 -1
- package/dist/twilight/{p-81f6638f.entry.js → p-4fa4547a.entry.js} +1 -1
- package/dist/twilight/{p-ba4b672c.entry.js → p-542d3277.entry.js} +1 -1
- package/dist/twilight/{p-a00e249b.entry.js → p-57ff1f25.entry.js} +1 -1
- package/dist/twilight/{p-827edf95.entry.js → p-59ae82bd.entry.js} +1 -1
- package/dist/twilight/{p-82e3c734.entry.js → p-647b6d76.entry.js} +1 -1
- package/dist/twilight/p-665189b4.entry.js +4 -0
- package/dist/twilight/{p-b55da21d.entry.js → p-6f36541a.entry.js} +1 -1
- package/dist/twilight/{p-c8aa5377.entry.js → p-7093a427.entry.js} +1 -1
- package/dist/twilight/{p-f201122a.entry.js → p-748df7e6.entry.js} +1 -1
- package/dist/twilight/p-776c9d33.entry.js +4 -0
- package/dist/twilight/{p-ce9fee6d.entry.js → p-7abddca8.entry.js} +1 -1
- package/dist/twilight/p-7b8313ef.entry.js +4 -0
- package/dist/twilight/p-7bd0ede5.entry.js +4 -0
- package/dist/twilight/p-817b8ba5.entry.js +4 -0
- package/dist/twilight/{p-5ef1b170.entry.js → p-87c0ca91.entry.js} +1 -1
- package/dist/twilight/p-8e8d9d7d.entry.js +4 -0
- package/dist/twilight/{p-BHjlzmYy.js → p-8r0S6BcZ.js} +1 -1
- package/dist/twilight/{p-face0448.entry.js → p-94dbc1e9.entry.js} +1 -1
- package/dist/twilight/{p-4e00f827.entry.js → p-96a20515.entry.js} +1 -1
- package/dist/twilight/{p-81f76d49.entry.js → p-96d03a28.entry.js} +1 -1
- package/dist/twilight/{p-97df32eb.entry.js → p-96e78428.entry.js} +1 -1
- package/dist/twilight/{p-CU-HtXWh.js → p-BZnoSB1s.js} +1 -1
- package/dist/twilight/p-BkClxrC4.js +9 -0
- package/dist/twilight/p-Ck4zxCil.js +9 -0
- package/dist/twilight/{p-IoI86ovS.js → p-Cw3UBzjl.js} +1 -1
- package/dist/twilight/p-D1vqXXNX.js +9 -0
- package/dist/twilight/p-DYB20YqN.js +5 -0
- package/dist/twilight/p-Vl6qpttb.js +4 -0
- package/dist/twilight/{p-BgG5eq1x.js → p-X6Yi3bYP.js} +1 -1
- package/dist/twilight/{p-d022b6ec.entry.js → p-a01f1992.entry.js} +1 -1
- package/dist/twilight/{p-5d37cc33.entry.js → p-aa7c5de0.entry.js} +1 -1
- package/dist/twilight/{p-b6ded196.entry.js → p-aaa0c743.entry.js} +1 -1
- package/dist/twilight/{p-713590e2.entry.js → p-ad041ab5.entry.js} +1 -1
- package/dist/twilight/{p-d1dd1db6.entry.js → p-ad07f67a.entry.js} +1 -1
- package/dist/twilight/{p-f1f74b41.entry.js → p-af3c74f4.entry.js} +1 -1
- package/dist/twilight/p-af60e72a.entry.js +4 -0
- package/dist/twilight/{p-bdcf3926.entry.js → p-b17d055d.entry.js} +1 -1
- package/dist/twilight/{p-c68f3054.entry.js → p-b598c0f7.entry.js} +1 -1
- package/dist/twilight/{p-8c6db6d7.entry.js → p-b64f3155.entry.js} +1 -1
- package/dist/twilight/p-bNzv71Xl.js +9 -0
- package/dist/twilight/{p-BqCmPfAo.js → p-bScl0xMh.js} +2 -2
- package/dist/twilight/{p-344c1910.entry.js → p-bff4c7b3.entry.js} +1 -1
- package/dist/twilight/{p-1b1f9f71.entry.js → p-c091e2dc.entry.js} +1 -1
- package/dist/twilight/{p-775b42ec.entry.js → p-c1fd45b1.entry.js} +1 -1
- package/dist/twilight/{p-1c215c8c.entry.js → p-c3ffb88a.entry.js} +1 -1
- package/dist/twilight/{p-9deae4f4.entry.js → p-c87951a2.entry.js} +1 -1
- package/dist/twilight/{p-1899f283.entry.js → p-ccfe5308.entry.js} +1 -1
- package/dist/twilight/{p-98eb495e.entry.js → p-d337c399.entry.js} +1 -1
- package/dist/twilight/{p-7b717899.entry.js → p-d371d450.entry.js} +1 -1
- package/dist/twilight/{p-f8b6967f.entry.js → p-d4a242f8.entry.js} +1 -1
- package/dist/twilight/{p-194d87c6.entry.js → p-d9f5a8cd.entry.js} +1 -1
- package/dist/twilight/{p-ff9b33bb.entry.js → p-dd2bd5dc.entry.js} +1 -1
- package/dist/twilight/{p-e89812d8.entry.js → p-df6853b5.entry.js} +1 -1
- package/dist/twilight/{p-05663bb1.entry.js → p-e28c0773.entry.js} +1 -1
- package/dist/twilight/{p-a76b3dba.entry.js → p-e3b8e0e1.entry.js} +1 -1
- package/dist/twilight/p-e679884a.entry.js +4 -0
- package/dist/twilight/{p-11767786.entry.js → p-e6bbf50d.entry.js} +1 -1
- package/dist/twilight/{p-1ca75c99.entry.js → p-e94f217b.entry.js} +1 -1
- package/dist/twilight/{p-d81ad2c3.entry.js → p-eac718cd.entry.js} +1 -1
- package/dist/twilight/{p-85ceef78.entry.js → p-ede67a08.entry.js} +1 -1
- package/dist/twilight/p-efab88c5.entry.js +4 -0
- package/dist/twilight/{p-1dbaefb8.entry.js → p-f176d41d.entry.js} +1 -1
- package/dist/twilight/p-f5d15e71.entry.js +4 -0
- package/dist/twilight/{p-50621375.entry.js → p-f7999a6d.entry.js} +1 -1
- package/dist/twilight/twilight.esm.js +1 -1
- package/dist/types/components/salla-count-down/salla-count-down.d.ts +6 -0
- package/dist/types/components/salla-notifications/interfaces.d.ts +20 -0
- package/dist/types/components/salla-notifications/salla-notifications.d.ts +17 -0
- package/dist/types/components.d.ts +763 -177
- package/dist/types/stencil-public-runtime.d.ts +169 -11
- package/package.json +5 -5
- package/dist/cjs/filepond-plugin-file-validate-type-Dfy66STE.js +0 -287
- package/dist/esm/filepond-plugin-file-validate-type-BYs_scJr.js +0 -285
- package/dist/twilight/p-0652987b.entry.js +0 -4
- package/dist/twilight/p-14529fd6.entry.js +0 -4
- package/dist/twilight/p-1c8394db.entry.js +0 -4
- package/dist/twilight/p-346b55d6.entry.js +0 -4
- package/dist/twilight/p-3962c34c.entry.js +0 -4
- package/dist/twilight/p-4e9e3ab1.entry.js +0 -4
- package/dist/twilight/p-549f59ed.entry.js +0 -4
- package/dist/twilight/p-54f65187.entry.js +0 -4
- package/dist/twilight/p-726513f8.entry.js +0 -4
- package/dist/twilight/p-753464fd.entry.js +0 -4
- package/dist/twilight/p-AfW2b46_.js +0 -9
- package/dist/twilight/p-C23tPnnH.js +0 -5
- package/dist/twilight/p-CrYUKEsF.js +0 -9
- package/dist/twilight/p-HWjjIZ9_.js +0 -9
- package/dist/twilight/p-Ig1Tafsp.js +0 -9
- package/dist/twilight/p-c9001d7f.entry.js +0 -4
- package/dist/twilight/p-cf9573fd.entry.js +0 -4
- package/dist/twilight/p-e6124fab.entry.js +0 -4
- package/dist/twilight/p-eb5a8329.entry.js +0 -4
|
@@ -1,9 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
const SallaFiltersWidget = SallaFiltersWidget$1;
|
|
7
|
-
const defineCustomElement = defineCustomElement$1;
|
|
8
|
-
|
|
9
|
-
export { SallaFiltersWidget, defineCustomElement };
|
|
4
|
+
import{S as s,d as t}from"./salla-filters-widget2.js";const a=s,o=t;export{a as SallaFiltersWidget,o as defineCustomElement}
|
|
@@ -1,248 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
import { H as Helper } from './Helper.js';
|
|
6
|
-
import { d as defineCustomElement$3 } from './salla-button2.js';
|
|
7
|
-
import { d as defineCustomElement$2 } from './salla-price-range2.js';
|
|
8
|
-
import { d as defineCustomElement$1 } from './salla-rating-stars2.js';
|
|
9
|
-
|
|
10
|
-
var FilterOptionTypes;
|
|
11
|
-
(function (FilterOptionTypes) {
|
|
12
|
-
// CATEGORIES = "categories",
|
|
13
|
-
// BRANDs = "brands",
|
|
14
|
-
// RATING = "rating",
|
|
15
|
-
// PRICE = "price",
|
|
16
|
-
// RADIO = "radio",
|
|
17
|
-
FilterOptionTypes["VALUES"] = "values";
|
|
18
|
-
FilterOptionTypes["VARIANTS"] = "variants";
|
|
19
|
-
FilterOptionTypes["MINIMUM"] = "minimum";
|
|
20
|
-
FilterOptionTypes["RANGE"] = "range";
|
|
21
|
-
})(FilterOptionTypes || (FilterOptionTypes = {}));
|
|
22
|
-
var FilterOptionInputType;
|
|
23
|
-
(function (FilterOptionInputType) {
|
|
24
|
-
FilterOptionInputType["VALUES"] = "values";
|
|
25
|
-
FilterOptionInputType["VARIANT"] = "variants";
|
|
26
|
-
FilterOptionInputType["RANGE"] = "range";
|
|
27
|
-
})(FilterOptionInputType || (FilterOptionInputType = {}));
|
|
28
|
-
|
|
29
|
-
const sallaFiltersWidgetCss = ":host{display:block}";
|
|
30
|
-
|
|
31
|
-
const SallaFiltersWidget = /*@__PURE__*/ proxyCustomElement(class SallaFiltersWidget extends HTMLElement {
|
|
32
|
-
constructor() {
|
|
33
|
-
super();
|
|
34
|
-
this.__registerHost();
|
|
35
|
-
this.changed = createEvent(this, "changed", 7);
|
|
36
|
-
this.initialItemCount = 10; // Show 10 items initially
|
|
37
|
-
this.expandedItemCount = 15; // Show 15 items when expanded
|
|
38
|
-
this.calculatedInitialHeight = 0; // Calculated based on actual content
|
|
39
|
-
this.calculatedExpandedHeight = 0; // Calculated based on actual content
|
|
40
|
-
this.isOpen = true;
|
|
41
|
-
this.isShowMore = false;
|
|
42
|
-
this.showMoreLabel = "عرض المزيد";
|
|
43
|
-
this.showLessLabel = "عرض أقل";
|
|
44
|
-
this.page = salla.config.get('page');
|
|
45
|
-
this.searchQuery = '';
|
|
46
|
-
this.filteredCount = 0; // Track filtered results count
|
|
47
|
-
}
|
|
48
|
-
connectedCallback() {
|
|
49
|
-
// Show "Show More" button if there are more than 10 items
|
|
50
|
-
this.withLoadMore = this.option.key != 'price' && Array.isArray(this.option.values) && this.option.values.length > this.initialItemCount;
|
|
51
|
-
salla.onReady(() => {
|
|
52
|
-
this.page = salla.config.get('page');
|
|
53
|
-
});
|
|
54
|
-
salla.lang.onLoaded(() => {
|
|
55
|
-
this.showMoreLabel = salla.lang.getWithDefault('common.titles.more', this.showMoreLabel);
|
|
56
|
-
this.showLessLabel = salla.lang.getWithDefault('common.elements.show_less', this.showLessLabel);
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
componentDidLoad() {
|
|
60
|
-
// Use fixed height per item for predictable calculations
|
|
61
|
-
// Each item is approximately 20px, so we calculate based on item count
|
|
62
|
-
const itemHeight = 20; // Fixed height per item
|
|
63
|
-
const paddingPerItem = 15; // Additional padding per item for margins/spacing
|
|
64
|
-
const allItems = this.widgetValues.querySelectorAll('.s-filters-label');
|
|
65
|
-
if (allItems.length > 0) {
|
|
66
|
-
const itemsToMeasure = Math.min(this.initialItemCount, allItems.length);
|
|
67
|
-
// Calculate initial height: (items × height) + (items × padding)
|
|
68
|
-
this.calculatedInitialHeight = this.initialItemCount * (itemHeight + paddingPerItem);
|
|
69
|
-
// Calculate expanded height based on first 15 items
|
|
70
|
-
if (allItems.length > this.initialItemCount) {
|
|
71
|
-
this.calculatedExpandedHeight = this.expandedItemCount * (itemHeight + paddingPerItem);
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
this.calculatedExpandedHeight = itemsToMeasure * (itemHeight + paddingPerItem);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
this.widgetValues.scrollHeight < this.calculatedInitialHeight && (this.withLoadMore = false);
|
|
78
|
-
(this.withLoadMore && this.widgetValues) && (this.widgetValues.style.maxHeight = `${this.calculatedInitialHeight}px`);
|
|
79
|
-
this.widgetContent.style.height = `${this.widgetContent.scrollHeight}px`;
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* Asynchronously sets the height of a widget element to its current height, allowing for smooth transitions.
|
|
83
|
-
* This function is often used in scenarios where the widget's content changes dynamically, and animating
|
|
84
|
-
* the height adjustment is desired for a smoother user experience.
|
|
85
|
-
*
|
|
86
|
-
* @param {number} [delay=250] - Optional. The delay (in milliseconds) before updating the widget height.
|
|
87
|
-
* Defaults to 250 milliseconds.
|
|
88
|
-
*
|
|
89
|
-
* @returns {Promise<void>} - A Promise that resolves once the widget height is set after the specified delay.
|
|
90
|
-
*
|
|
91
|
-
* @example
|
|
92
|
-
* // Set widget height with the default delay (250 milliseconds)
|
|
93
|
-
* await setWidgetHeight();
|
|
94
|
-
*
|
|
95
|
-
* // Set widget height with a custom delay (e.g., 500 milliseconds)
|
|
96
|
-
* await setWidgetHeight(500);
|
|
97
|
-
*/
|
|
98
|
-
async setWidgetHeight(delay = 250) {
|
|
99
|
-
this.widgetContent.removeAttribute('style');
|
|
100
|
-
setTimeout(() => {
|
|
101
|
-
let currentWidgetHeight = this.widgetContent.scrollHeight;
|
|
102
|
-
this.widgetContent.style.height = currentWidgetHeight + 'px';
|
|
103
|
-
}, delay);
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Reset selected filter options.
|
|
107
|
-
*/
|
|
108
|
-
async reset() {
|
|
109
|
-
if (this.option.type === FilterOptionTypes.RANGE) {
|
|
110
|
-
this.priceRange.reset();
|
|
111
|
-
}
|
|
112
|
-
Array.from(this.host.querySelectorAll('input')).forEach(input => input.checked = false);
|
|
113
|
-
}
|
|
114
|
-
/**
|
|
115
|
-
* Action to show more or less filter options.
|
|
116
|
-
*/
|
|
117
|
-
async showMore() {
|
|
118
|
-
this.isShowMore = !this.isShowMore;
|
|
119
|
-
this.widgetContent.style.height = 'auto';
|
|
120
|
-
// Reset scroll position to top when collapsing to prevent content cutting
|
|
121
|
-
if (!this.isShowMore) {
|
|
122
|
-
this.widgetValues.scrollTop = 0;
|
|
123
|
-
}
|
|
124
|
-
// Use calculated heights based on actual content
|
|
125
|
-
const maxHeight = this.isShowMore ? this.calculatedExpandedHeight : this.calculatedInitialHeight;
|
|
126
|
-
// Calculate actual item count
|
|
127
|
-
const actualCount = this.searchQuery ? this.filteredCount : (Array.isArray(this.option.values) ? this.option.values.length : 0);
|
|
128
|
-
// When showing more: expand to 15 items height with scrollbar for items beyond 15
|
|
129
|
-
// When showing less: collapse to 10 items height
|
|
130
|
-
this.widgetValues.style.maxHeight = `${maxHeight}px`;
|
|
131
|
-
this.widgetValues.style.overflowY = this.isShowMore && actualCount > this.expandedItemCount ? 'auto' : 'hidden';
|
|
132
|
-
setTimeout(() => {
|
|
133
|
-
this.widgetContent.style.height = `${this.widgetContent.scrollHeight}px`;
|
|
134
|
-
}, 400); // get height after time of collapse animation (duration-300)
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* Action to toggle widget open or closed (expand/ collapse).
|
|
138
|
-
*/
|
|
139
|
-
async toggleWidget() {
|
|
140
|
-
this.isOpen = !this.isOpen;
|
|
141
|
-
Helper.toggleElementClassIf(this.widgetContent, 's-filters-widget-opened', 's-filters-widget-closed', () => this.isOpen);
|
|
142
|
-
}
|
|
143
|
-
renderFilterOption(option) {
|
|
144
|
-
if (![FilterOptionTypes.VALUES, FilterOptionTypes.MINIMUM, FilterOptionTypes.VARIANTS].includes(option.type)) {
|
|
145
|
-
return '';
|
|
146
|
-
}
|
|
147
|
-
//@ts-ignore
|
|
148
|
-
const filteredValues = option.values.filter((filterOption) => {
|
|
149
|
-
if (!this.searchQuery)
|
|
150
|
-
return true;
|
|
151
|
-
const label = typeof filterOption === 'number'
|
|
152
|
-
? String(filterOption)
|
|
153
|
-
: (filterOption?.value || filterOption?.key || '');
|
|
154
|
-
return String(label).toLowerCase().includes(this.searchQuery.toLowerCase());
|
|
155
|
-
});
|
|
156
|
-
// Update filtered count for show more button logic
|
|
157
|
-
this.filteredCount = filteredValues.length;
|
|
158
|
-
// Show empty state if no results
|
|
159
|
-
if (filteredValues.length === 0) {
|
|
160
|
-
return (h("div", { class: "s-filters-widget-empty-state" }, salla.lang.get('common.elements.no_options') || 'لا توجد نتائج'));
|
|
161
|
-
}
|
|
162
|
-
//@ts-ignore
|
|
163
|
-
return filteredValues.map((filterOption, index) => {
|
|
164
|
-
let value = typeof filterOption == 'number' ? filterOption : (filterOption.key || filterOption.value);
|
|
165
|
-
return h("label", { class: "s-filters-label", htmlFor: `${option.key}-option-${value}`, key: `${option.key}-option-${value}` }, h("input", { id: `${option.key}-option-${value}`, name: option.key, type: "radio", checked: this.isSelectedOption(option, value), class: `s-filters-radio`, onChange: event => this.changed.emit({ event, option, value }) }), this.getOptionLabel(option, filterOption));
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
isSelectedOption(option, value) {
|
|
169
|
-
if (option.type === FilterOptionTypes.MINIMUM) {
|
|
170
|
-
return this.filtersData[option.key] == value;
|
|
171
|
-
}
|
|
172
|
-
if (option.type === FilterOptionTypes.VARIANTS) {
|
|
173
|
-
return this.filtersData[option.type] && this.filtersData[option.type][Object.keys(this.filtersData[option.type])[0]] == value;
|
|
174
|
-
}
|
|
175
|
-
if (option.type === FilterOptionTypes.RANGE) {
|
|
176
|
-
return this.filtersData[option.key] && this.filtersData[option.key].min == value.min && this.filtersData[option.key].max == value.max;
|
|
177
|
-
}
|
|
178
|
-
if (option.type === FilterOptionTypes.VALUES) {
|
|
179
|
-
return this.filtersData[option.key] && Number(this.filtersData[option.key]) == Number(value);
|
|
180
|
-
}
|
|
181
|
-
return false;
|
|
182
|
-
}
|
|
183
|
-
getOptionLabel(option, filterOption) {
|
|
184
|
-
if (option.key == 'rating') {
|
|
185
|
-
//in amazon has stars & up, should we add it, to avoid those people who will come to say I selected 4 why I see 5 sars products
|
|
186
|
-
return h("salla-rating-stars", { size: "small", value: filterOption });
|
|
187
|
-
}
|
|
188
|
-
let label = filterOption.value || 'null';
|
|
189
|
-
//label+=filterOption.count ? ` (${salla.helpers.number(filterOption.count)})` : '';
|
|
190
|
-
return h("span", { class: "s-filters-option-name" }, label);
|
|
191
|
-
}
|
|
192
|
-
render() {
|
|
193
|
-
return (h(Host, { key: 'e93cfb9f1f6daeb8a2121ccb36a3cf135a55e902', class: "s-filters-widget-container" }, h("h3", { key: 'd5ef45d78e0119e2ac997ded417e310c0a797c34', class: "s-filters-widget-title", onClick: () => this.toggleWidget() }, h("span", { key: 'fe4df56fad0d290395d78588456fb7d00a20ed43' }, this.option.label), h("span", { key: 'c961f86b5e06437dfdd145e164da5fe326500032', class: `s-filters-widget-plusminus ${this.isOpen ? 's-filters-widget-plusminus-active' : ''}` })), h("div", { key: '7cf1ed1b562bf16acc481f682965567d8bc1813c', class: "s-filters-widget-content", ref: (el) => this.widgetContent = el }, Array.isArray(this.option.values) && this.option.values.length > 5 && (h("div", { key: '275427371f48fdfc8ef8b80b9d3e11fa247f7d7a', class: "s-filters-widget-search-wrapper", style: { padding: '8px 0', marginBottom: '8px' } }, h("input", { key: '473c082ed9f7415beba445d36a121027eaadbbe1', type: "text", class: "s-filters-widget-search-input", placeholder: salla.lang.get('blocks.header.search_placeholder') || 'بحث...', value: this.searchQuery, onInput: (e) => this.searchQuery = e.target.value }))), h("div", { key: 'e45654731cdd801345acc5b3311d9ddab3020035', class: "s-filters-widget-values", ref: (el) => this.widgetValues = el }, h("slot", { key: '5ae673157a4b579a000901b04db8e375a52565e7' }), this.option.type !== FilterOptionTypes.RANGE
|
|
194
|
-
? this.renderFilterOption(this.option)
|
|
195
|
-
: h("salla-price-range", { onChanged: (event) => {
|
|
196
|
-
this.changed.emit(event.detail);
|
|
197
|
-
}, ref: price => this.priceRange = price, filtersData: this.filtersData, option: this.option })), this.withLoadMore && (!this.searchQuery || this.filteredCount > this.initialItemCount) &&
|
|
198
|
-
h("a", { key: '8ec08429d8fb31b338e6f9f9cf455b5ba2155cb8', class: "s-filters-widget-more", onClick: () => this.showMore() }, !this.isShowMore ? this.showMoreLabel : this.showLessLabel))));
|
|
199
|
-
}
|
|
200
|
-
get host() { return this; }
|
|
201
|
-
static get style() { return sallaFiltersWidgetCss; }
|
|
202
|
-
}, [4, "salla-filters-widget", {
|
|
203
|
-
"withLoadMore": [1028, "with-load-more"],
|
|
204
|
-
"filtersData": [16, "filters-data"],
|
|
205
|
-
"option": [16],
|
|
206
|
-
"isOpen": [32],
|
|
207
|
-
"isShowMore": [32],
|
|
208
|
-
"showMoreLabel": [32],
|
|
209
|
-
"showLessLabel": [32],
|
|
210
|
-
"page": [32],
|
|
211
|
-
"searchQuery": [32],
|
|
212
|
-
"filteredCount": [32],
|
|
213
|
-
"setWidgetHeight": [64],
|
|
214
|
-
"reset": [64],
|
|
215
|
-
"showMore": [64],
|
|
216
|
-
"toggleWidget": [64]
|
|
217
|
-
}]);
|
|
218
|
-
function defineCustomElement() {
|
|
219
|
-
if (typeof customElements === "undefined") {
|
|
220
|
-
return;
|
|
221
|
-
}
|
|
222
|
-
const components = ["salla-filters-widget", "salla-button", "salla-price-range", "salla-rating-stars"];
|
|
223
|
-
components.forEach(tagName => { switch (tagName) {
|
|
224
|
-
case "salla-filters-widget":
|
|
225
|
-
if (!customElements.get(tagName)) {
|
|
226
|
-
customElements.define(tagName, SallaFiltersWidget);
|
|
227
|
-
}
|
|
228
|
-
break;
|
|
229
|
-
case "salla-button":
|
|
230
|
-
if (!customElements.get(tagName)) {
|
|
231
|
-
defineCustomElement$3();
|
|
232
|
-
}
|
|
233
|
-
break;
|
|
234
|
-
case "salla-price-range":
|
|
235
|
-
if (!customElements.get(tagName)) {
|
|
236
|
-
defineCustomElement$2();
|
|
237
|
-
}
|
|
238
|
-
break;
|
|
239
|
-
case "salla-rating-stars":
|
|
240
|
-
if (!customElements.get(tagName)) {
|
|
241
|
-
defineCustomElement$1();
|
|
242
|
-
}
|
|
243
|
-
break;
|
|
244
|
-
} });
|
|
245
|
-
}
|
|
246
|
-
defineCustomElement();
|
|
247
|
-
|
|
248
|
-
export { FilterOptionTypes as F, SallaFiltersWidget as S, defineCustomElement as d };
|
|
4
|
+
import{transformTag as s,proxyCustomElement as t,HTMLElement as e,createEvent as i,h as a,Host as l}from"@stencil/core/internal/client";import{H as h}from"./Helper.js";import{d as r}from"./salla-button2.js";import{d as n}from"./salla-price-range2.js";import{d as o}from"./salla-rating-stars2.js";var c,d;!function(s){s.VALUES="values",s.VARIANTS="variants",s.MINIMUM="minimum",s.RANGE="range"}(c||(c={})),function(s){s.VALUES="values",s.VARIANT="variants",s.RANGE="range"}(d||(d={}));const f=t(class extends e{constructor(s){super(),!1!==s&&this.__registerHost(),this.changed=i(this,"changed",7),this.initialItemCount=10,this.expandedItemCount=15,this.calculatedInitialHeight=0,this.calculatedExpandedHeight=0,this.isOpen=!0,this.isShowMore=!1,this.showMoreLabel="عرض المزيد",this.showLessLabel="عرض أقل",this.page=salla.config.get("page"),this.searchQuery="",this.filteredCount=0}connectedCallback(){this.withLoadMore="price"!=this.option.key&&Array.isArray(this.option.values)&&this.option.values.length>this.initialItemCount,salla.onReady((()=>{this.page=salla.config.get("page")})),salla.lang.onLoaded((()=>{this.showMoreLabel=salla.lang.getWithDefault("common.titles.more",this.showMoreLabel),this.showLessLabel=salla.lang.getWithDefault("common.elements.show_less",this.showLessLabel)}))}componentDidLoad(){const s=this.widgetValues.querySelectorAll(".s-filters-label");if(s.length>0){const t=Math.min(this.initialItemCount,s.length);this.calculatedInitialHeight=35*this.initialItemCount,this.calculatedExpandedHeight=s.length>this.initialItemCount?35*this.expandedItemCount:35*t}this.widgetValues.scrollHeight<this.calculatedInitialHeight&&(this.withLoadMore=!1),this.withLoadMore&&this.widgetValues&&(this.widgetValues.style.maxHeight=`${this.calculatedInitialHeight}px`),this.widgetContent.style.height=`${this.widgetContent.scrollHeight}px`}async setWidgetHeight(s=250){this.widgetContent.removeAttribute("style"),setTimeout((()=>{this.widgetContent.style.height=this.widgetContent.scrollHeight+"px"}),s)}async reset(){this.option.type===c.RANGE&&this.priceRange.reset(),Array.from(this.host.querySelectorAll("input")).forEach((s=>s.checked=!1))}async showMore(){this.isShowMore=!this.isShowMore,this.widgetContent.style.height="auto",this.isShowMore||(this.widgetValues.scrollTop=0);const s=this.isShowMore?this.calculatedExpandedHeight:this.calculatedInitialHeight,t=this.searchQuery?this.filteredCount:Array.isArray(this.option.values)?this.option.values.length:0;this.widgetValues.style.maxHeight=`${s}px`,this.widgetValues.style.overflowY=this.isShowMore&&t>this.expandedItemCount?"auto":"hidden",setTimeout((()=>{this.widgetContent.style.height=`${this.widgetContent.scrollHeight}px`}),400)}async toggleWidget(){this.isOpen=!this.isOpen,h.toggleElementClassIf(this.widgetContent,"s-filters-widget-opened","s-filters-widget-closed",(()=>this.isOpen))}renderFilterOption(s){if(![c.VALUES,c.MINIMUM,c.VARIANTS].includes(s.type))return"";const t=s.values.filter((s=>{if(!this.searchQuery)return!0;const t="number"==typeof s?String(s):s?.value||s?.key||"";return String(t).toLowerCase().includes(this.searchQuery.toLowerCase())}));return this.filteredCount=t.length,0===t.length?a("div",{class:"s-filters-widget-empty-state"},salla.lang.get("common.elements.no_options")||"لا توجد نتائج"):t.map((t=>{let e="number"==typeof t?t:t.key||t.value;return a("label",{class:"s-filters-label",htmlFor:`${s.key}-option-${e}`,key:`${s.key}-option-${e}`},a("input",{id:`${s.key}-option-${e}`,name:s.key,type:"radio",checked:this.isSelectedOption(s,e),class:"s-filters-radio",onChange:t=>this.changed.emit({event:t,option:s,value:e})}),this.getOptionLabel(s,t))}))}isSelectedOption(s,t){return s.type===c.MINIMUM?this.filtersData[s.key]==t:s.type===c.VARIANTS?this.filtersData[s.type]&&this.filtersData[s.type][Object.keys(this.filtersData[s.type])[0]]==t:s.type===c.RANGE?this.filtersData[s.key]&&this.filtersData[s.key].min==t.min&&this.filtersData[s.key].max==t.max:s.type===c.VALUES&&this.filtersData[s.key]&&Number(this.filtersData[s.key])==Number(t)}getOptionLabel(s,t){return"rating"==s.key?a("salla-rating-stars",{size:"small",value:t}):a("span",{class:"s-filters-option-name"},t.value||"null")}render(){return a(l,{key:"e93cfb9f1f6daeb8a2121ccb36a3cf135a55e902",class:"s-filters-widget-container"},a("h3",{key:"d5ef45d78e0119e2ac997ded417e310c0a797c34",class:"s-filters-widget-title",onClick:()=>this.toggleWidget()},a("span",{key:"fe4df56fad0d290395d78588456fb7d00a20ed43"},this.option.label),a("span",{key:"c961f86b5e06437dfdd145e164da5fe326500032",class:"s-filters-widget-plusminus "+(this.isOpen?"s-filters-widget-plusminus-active":"")})),a("div",{key:"7cf1ed1b562bf16acc481f682965567d8bc1813c",class:"s-filters-widget-content",ref:s=>this.widgetContent=s},Array.isArray(this.option.values)&&this.option.values.length>5&&a("div",{key:"275427371f48fdfc8ef8b80b9d3e11fa247f7d7a",class:"s-filters-widget-search-wrapper",style:{padding:"8px 0",marginBottom:"8px"}},a("input",{key:"473c082ed9f7415beba445d36a121027eaadbbe1",type:"text",class:"s-filters-widget-search-input",placeholder:salla.lang.get("blocks.header.search_placeholder")||"بحث...",value:this.searchQuery,onInput:s=>this.searchQuery=s.target.value})),a("div",{key:"e45654731cdd801345acc5b3311d9ddab3020035",class:"s-filters-widget-values",ref:s=>this.widgetValues=s},a("slot",{key:"5ae673157a4b579a000901b04db8e375a52565e7"}),this.option.type!==c.RANGE?this.renderFilterOption(this.option):a("salla-price-range",{onChanged:s=>{this.changed.emit(s.detail)},ref:s=>this.priceRange=s,filtersData:this.filtersData,option:this.option})),this.withLoadMore&&(!this.searchQuery||this.filteredCount>this.initialItemCount)&&a("a",{key:"8ec08429d8fb31b338e6f9f9cf455b5ba2155cb8",class:"s-filters-widget-more",onClick:()=>this.showMore()},this.isShowMore?this.showLessLabel:this.showMoreLabel)))}get host(){return this}static get style(){return":host{display:block}"}},[260,"salla-filters-widget",{withLoadMore:[1028,"with-load-more"],filtersData:[16],option:[16],isOpen:[32],isShowMore:[32],showMoreLabel:[32],showLessLabel:[32],page:[32],searchQuery:[32],filteredCount:[32],setWidgetHeight:[64],reset:[64],showMore:[64],toggleWidget:[64]}]);function p(){"undefined"!=typeof customElements&&["salla-filters-widget","salla-button","salla-price-range","salla-rating-stars"].forEach((t=>{switch(t){case"salla-filters-widget":customElements.get(s(t))||customElements.define(s(t),f);break;case"salla-button":customElements.get(s(t))||r();break;case"salla-price-range":customElements.get(s(t))||n();break;case"salla-rating-stars":customElements.get(s(t))||o()}}))}p();export{c as F,f as S,p as d}
|
|
@@ -1,256 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
import { d as defineCustomElement$4, F as FilterOptionTypes } from './salla-filters-widget2.js';
|
|
6
|
-
import { H as Helper } from './Helper.js';
|
|
7
|
-
import { d as defineCustomElement$5 } from './salla-button2.js';
|
|
8
|
-
import { d as defineCustomElement$3 } from './salla-price-range2.js';
|
|
9
|
-
import { d as defineCustomElement$2 } from './salla-rating-stars2.js';
|
|
10
|
-
|
|
11
|
-
const sallaFiltersCss = ":host{display:block}.s-rating-stars-small{line-height:12px}.s-filters-radio{background-image:none !important}";
|
|
12
|
-
|
|
13
|
-
const SallaFilters$1 = /*@__PURE__*/ proxyCustomElement(class SallaFilters extends HTMLElement {
|
|
14
|
-
constructor() {
|
|
15
|
-
super();
|
|
16
|
-
this.__registerHost();
|
|
17
|
-
this.changed = createEvent(this, "changed", 7);
|
|
18
|
-
this.isReady = false; //to avoid triggering the changed event
|
|
19
|
-
this.filtersData = {};
|
|
20
|
-
salla.event.on('filters::hidden', () => this.host.style.display = 'none');
|
|
21
|
-
salla.lang.onLoaded(() => {
|
|
22
|
-
this.apply = salla.lang.get('pages.checkout.apply');
|
|
23
|
-
this.reset = salla.lang.get('pages.categories.filters_reset');
|
|
24
|
-
});
|
|
25
|
-
salla.event.on('filters::fetched', ({ filters }) => {
|
|
26
|
-
this.host.style.display = '';
|
|
27
|
-
let freshFilterData = {};
|
|
28
|
-
this.filters = filters
|
|
29
|
-
.map((filter) => {
|
|
30
|
-
filter.label = {
|
|
31
|
-
category_id: salla.lang.get('common.titles.categories'),
|
|
32
|
-
brand_id: salla.lang.get('common.titles.brands'),
|
|
33
|
-
rating: salla.lang.get('pages.categories.filter_rating'),
|
|
34
|
-
price: salla.lang.get('pages.categories.filter_price'),
|
|
35
|
-
}[filter.key] || filter.label;
|
|
36
|
-
// filter.type = FilterOptionTypes.VALUES;
|
|
37
|
-
if (filter.key == 'rating') {
|
|
38
|
-
filter.type = FilterOptionTypes.VALUES;
|
|
39
|
-
//@ts-ignore
|
|
40
|
-
let { max, min } = filter.values;
|
|
41
|
-
//@ts-ignore
|
|
42
|
-
filter.values = [5, 4, 3, 2, 1].filter(stars => stars >= min || stars <= max);
|
|
43
|
-
}
|
|
44
|
-
if (this.filtersData.variants && filter.type == FilterOptionTypes.VARIANTS) {
|
|
45
|
-
freshFilterData.variants = this.filtersData.variants;
|
|
46
|
-
}
|
|
47
|
-
if (this.filtersData[filter.key] && filter.type !== FilterOptionTypes.VARIANTS) {
|
|
48
|
-
freshFilterData[filter.key] = this.filtersData[filter.key];
|
|
49
|
-
}
|
|
50
|
-
let searchParams = new URLSearchParams(window.location.search);
|
|
51
|
-
let hasFilters = false;
|
|
52
|
-
for (let key of searchParams.keys()) {
|
|
53
|
-
if (key.includes('filters')) {
|
|
54
|
-
hasFilters = true;
|
|
55
|
-
break; // No need to continue checking once a match is found
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
if (salla.config.get('page.slug') == "product.index" && Object.keys(freshFilterData).length == 0 && !hasFilters) {
|
|
59
|
-
// Append the current category to the url if there are no pre-selected filters
|
|
60
|
-
let currentUrl = window.location.href;
|
|
61
|
-
let filterValue = salla.config.get('page.id');
|
|
62
|
-
let separator = currentUrl.indexOf('?') !== -1 ? '&' : '?';
|
|
63
|
-
let newUrl = currentUrl + separator + 'filters[category_id]=' + filterValue;
|
|
64
|
-
freshFilterData.category_id = filterValue;
|
|
65
|
-
window.history.pushState({ path: newUrl }, '', newUrl);
|
|
66
|
-
}
|
|
67
|
-
return filter;
|
|
68
|
-
});
|
|
69
|
-
this.filtersData = freshFilterData;
|
|
70
|
-
this.host.childNodes.forEach(async (widget) => widget.setWidgetHeight && await widget.setWidgetHeight());
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
async componentWillLoad() {
|
|
74
|
-
try {
|
|
75
|
-
const searchParams = new URLSearchParams(window.location.search);
|
|
76
|
-
this.filtersData = await Helper.extractFiltersFromUrl(searchParams);
|
|
77
|
-
}
|
|
78
|
-
catch (e) {
|
|
79
|
-
console.warn('failed to get filters from URL', e.message);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Method to get filter data.
|
|
84
|
-
*/
|
|
85
|
-
async getFilters() {
|
|
86
|
-
return this.filtersData;
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Apply filter action.
|
|
90
|
-
*/
|
|
91
|
-
async applyFilters() {
|
|
92
|
-
if (!this.isReady) {
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
let hasFilters = Object.keys(this.filtersData).length > 0;
|
|
96
|
-
setTimeout(() => {
|
|
97
|
-
if (hasFilters) {
|
|
98
|
-
let url = new URL(window.location.href);
|
|
99
|
-
for (const [key] of url.searchParams.entries()) {
|
|
100
|
-
if (key.startsWith("filters")) {
|
|
101
|
-
url.searchParams.delete(key);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
let encodedFilterValues = this.encodeFilters(this.filtersData);
|
|
105
|
-
let sanitizedFilterValues = url.search.split("&").filter(item => !item.includes('filters')).join("&");
|
|
106
|
-
if (sanitizedFilterValues) {
|
|
107
|
-
url.search = url.search.split("&filters")[0] + "&" + encodedFilterValues;
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
url.search = `?${encodedFilterValues}`;
|
|
111
|
-
}
|
|
112
|
-
window.history.pushState({}, '', url.href);
|
|
113
|
-
}
|
|
114
|
-
else {
|
|
115
|
-
let url = new URL(window.location.href);
|
|
116
|
-
url.searchParams?.delete('filters');
|
|
117
|
-
window.history.pushState({}, '', url.toString());
|
|
118
|
-
}
|
|
119
|
-
salla.event.emit('salla-filters::changed', this.filtersData);
|
|
120
|
-
this.changed.emit(this.filtersData);
|
|
121
|
-
}, 300);
|
|
122
|
-
}
|
|
123
|
-
encodeFilters(filters, parentKey = 'filters') {
|
|
124
|
-
const encodedFilters = [];
|
|
125
|
-
for (const key in filters) {
|
|
126
|
-
if (Object.prototype.hasOwnProperty.call(filters, key)) {
|
|
127
|
-
const value = filters[key];
|
|
128
|
-
const fullKey = parentKey ? `${parentKey}[${key}]` : key;
|
|
129
|
-
if (Array.isArray(value)) {
|
|
130
|
-
for (let i = 0; i < value.length; i++) {
|
|
131
|
-
encodedFilters.push(`${fullKey}[${i}]=${value[i]}`);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
else if (typeof value === 'object' && value !== null) {
|
|
135
|
-
encodedFilters.push(this.encodeFilters(value, fullKey));
|
|
136
|
-
}
|
|
137
|
-
else {
|
|
138
|
-
// const encodedKey = encodeURIComponent(fullKey);
|
|
139
|
-
// const encodedValue = encodeURIComponent(value);
|
|
140
|
-
let result = `${fullKey}=${value}`;
|
|
141
|
-
encodedFilters.push(result);
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
return encodedFilters.join('&');
|
|
146
|
-
}
|
|
147
|
-
;
|
|
148
|
-
/**
|
|
149
|
-
* Reset selected filters.
|
|
150
|
-
*/
|
|
151
|
-
async resetFilters() {
|
|
152
|
-
this.removeFiltersQueryParams();
|
|
153
|
-
this.filtersData = {};
|
|
154
|
-
this.host.childNodes.forEach((widget) => widget.reset && widget.reset());
|
|
155
|
-
salla.event.emit('salla-filters::reset');
|
|
156
|
-
return this.applyFilters();
|
|
157
|
-
}
|
|
158
|
-
removeFiltersQueryParams() {
|
|
159
|
-
const searchParams = new URLSearchParams(window.location.search);
|
|
160
|
-
const newUrl = Array.from(searchParams.keys())
|
|
161
|
-
.filter(key => !key.startsWith('filters['))
|
|
162
|
-
.map(key => `${encodeURIComponent(key)}=${encodeURIComponent(searchParams.get(key))}`)
|
|
163
|
-
.join('&');
|
|
164
|
-
const finalUrl = newUrl ? `${window.location.pathname}?${newUrl}` : window.location.pathname;
|
|
165
|
-
window.history.pushState({}, '', finalUrl);
|
|
166
|
-
}
|
|
167
|
-
/**
|
|
168
|
-
* @param {{target:HTMLInputElement}} event
|
|
169
|
-
* @param option
|
|
170
|
-
* @param value
|
|
171
|
-
* @private
|
|
172
|
-
*/
|
|
173
|
-
handleOptionChange(event, option, value) {
|
|
174
|
-
if (option.type === FilterOptionTypes.RANGE) {
|
|
175
|
-
this.filtersData[option.key] = value;
|
|
176
|
-
}
|
|
177
|
-
let isChecked = event.target.checked;
|
|
178
|
-
if (option.type === FilterOptionTypes.VARIANTS) {
|
|
179
|
-
this.filtersData.variants = this.filtersData.variants || {};
|
|
180
|
-
isChecked && (this.filtersData.variants[option.key] = value);
|
|
181
|
-
isChecked || (delete this.filtersData.variants[option.key]);
|
|
182
|
-
}
|
|
183
|
-
else if (event.target.type == "radio") {
|
|
184
|
-
isChecked && (this.filtersData[option.key] = value);
|
|
185
|
-
isChecked || (delete this.filtersData[option.key]);
|
|
186
|
-
}
|
|
187
|
-
//it's checkbox
|
|
188
|
-
// add if condition to avoid error when the filter is not existed in the filtersData
|
|
189
|
-
else if (event.target.type == "checkbox") {
|
|
190
|
-
this.filtersData[option.key] = this.filtersData[option.key] || [];
|
|
191
|
-
if (isChecked) {
|
|
192
|
-
this.filtersData[option.key].push(value);
|
|
193
|
-
}
|
|
194
|
-
this.filtersData[option.key] = this.filtersData[option.key].filter(val => val != value);
|
|
195
|
-
}
|
|
196
|
-
this.applyFilters();
|
|
197
|
-
}
|
|
198
|
-
render() {
|
|
199
|
-
return h(Host, { key: 'f3c454fc20472dca6fe646c9121028a2c045808f' }, this.filters?.map(option => h("salla-filters-widget", { option: option, filtersData: this.filtersData, onChanged: ({ detail: { event, option, value } }) => {
|
|
200
|
-
this.handleOptionChange(event, option, value);
|
|
201
|
-
} })), this.filters?.length ? h("div", { class: "s-filters-footer" }, h("salla-button", { color: 'gray', fill: 'outline', onClick: () => this.resetFilters() }, this.reset)) : '');
|
|
202
|
-
}
|
|
203
|
-
componentDidLoad() {
|
|
204
|
-
this.isReady = true;
|
|
205
|
-
}
|
|
206
|
-
get host() { return this; }
|
|
207
|
-
static get style() { return sallaFiltersCss; }
|
|
208
|
-
}, [0, "salla-filters", {
|
|
209
|
-
"filters": [1040],
|
|
210
|
-
"isSidebarOpen": [32],
|
|
211
|
-
"filtersData": [32],
|
|
212
|
-
"apply": [32],
|
|
213
|
-
"reset": [32],
|
|
214
|
-
"getFilters": [64],
|
|
215
|
-
"applyFilters": [64],
|
|
216
|
-
"resetFilters": [64]
|
|
217
|
-
}]);
|
|
218
|
-
function defineCustomElement$1() {
|
|
219
|
-
if (typeof customElements === "undefined") {
|
|
220
|
-
return;
|
|
221
|
-
}
|
|
222
|
-
const components = ["salla-filters", "salla-button", "salla-filters-widget", "salla-price-range", "salla-rating-stars"];
|
|
223
|
-
components.forEach(tagName => { switch (tagName) {
|
|
224
|
-
case "salla-filters":
|
|
225
|
-
if (!customElements.get(tagName)) {
|
|
226
|
-
customElements.define(tagName, SallaFilters$1);
|
|
227
|
-
}
|
|
228
|
-
break;
|
|
229
|
-
case "salla-button":
|
|
230
|
-
if (!customElements.get(tagName)) {
|
|
231
|
-
defineCustomElement$5();
|
|
232
|
-
}
|
|
233
|
-
break;
|
|
234
|
-
case "salla-filters-widget":
|
|
235
|
-
if (!customElements.get(tagName)) {
|
|
236
|
-
defineCustomElement$4();
|
|
237
|
-
}
|
|
238
|
-
break;
|
|
239
|
-
case "salla-price-range":
|
|
240
|
-
if (!customElements.get(tagName)) {
|
|
241
|
-
defineCustomElement$3();
|
|
242
|
-
}
|
|
243
|
-
break;
|
|
244
|
-
case "salla-rating-stars":
|
|
245
|
-
if (!customElements.get(tagName)) {
|
|
246
|
-
defineCustomElement$2();
|
|
247
|
-
}
|
|
248
|
-
break;
|
|
249
|
-
} });
|
|
250
|
-
}
|
|
251
|
-
defineCustomElement$1();
|
|
252
|
-
|
|
253
|
-
const SallaFilters = SallaFilters$1;
|
|
254
|
-
const defineCustomElement = defineCustomElement$1;
|
|
255
|
-
|
|
256
|
-
export { SallaFilters, defineCustomElement };
|
|
4
|
+
import{transformTag as t,proxyCustomElement as s,HTMLElement as e,createEvent as i,h as a,Host as l}from"@stencil/core/internal/client";import{d as r,F as n}from"./salla-filters-widget2.js";import{H as o}from"./Helper.js";import{d as c}from"./salla-button2.js";import{d as h}from"./salla-price-range2.js";import{d as f}from"./salla-rating-stars2.js";const d=s(class extends e{constructor(t){super(),!1!==t&&this.__registerHost(),this.changed=i(this,"changed",7),this.isReady=!1,this.filtersData={},salla.event.on("filters::hidden",(()=>this.host.style.display="none")),salla.lang.onLoaded((()=>{this.apply=salla.lang.get("pages.checkout.apply"),this.reset=salla.lang.get("pages.categories.filters_reset")})),salla.event.on("filters::fetched",(({filters:t})=>{this.host.style.display="";let s={};this.filters=t.map((t=>{if(t.label={category_id:salla.lang.get("common.titles.categories"),brand_id:salla.lang.get("common.titles.brands"),rating:salla.lang.get("pages.categories.filter_rating"),price:salla.lang.get("pages.categories.filter_price")}[t.key]||t.label,"rating"==t.key){t.type=n.VALUES;let{max:s,min:e}=t.values;t.values=[5,4,3,2,1].filter((t=>t>=e||t<=s))}this.filtersData.variants&&t.type==n.VARIANTS&&(s.variants=this.filtersData.variants),this.filtersData[t.key]&&t.type!==n.VARIANTS&&(s[t.key]=this.filtersData[t.key]);let e=new URLSearchParams(window.location.search),i=!1;for(let t of e.keys())if(t.includes("filters")){i=!0;break}if("product.index"==salla.config.get("page.slug")&&0==Object.keys(s).length&&!i){let t=window.location.href,e=salla.config.get("page.id"),i=-1!==t.indexOf("?")?"&":"?",a=t+i+"filters[category_id]="+e;s.category_id=e,window.history.pushState({path:a},"",a)}return t})),this.filtersData=s,this.host.childNodes.forEach((async t=>t.setWidgetHeight&&await t.setWidgetHeight()))}))}async componentWillLoad(){try{const t=new URLSearchParams(window.location.search);this.filtersData=await o.extractFiltersFromUrl(t)}catch(t){console.warn("failed to get filters from URL",t.message)}}async getFilters(){return this.filtersData}async applyFilters(){if(!this.isReady)return;let t=Object.keys(this.filtersData).length>0;setTimeout((()=>{if(t){let t=new URL(window.location.href);for(const[s]of t.searchParams.entries())s.startsWith("filters")&&t.searchParams.delete(s);let s=this.encodeFilters(this.filtersData),e=t.search.split("&").filter((t=>!t.includes("filters"))).join("&");t.search=e?t.search.split("&filters")[0]+"&"+s:"?"+s,window.history.pushState({},"",t.href)}else{let t=new URL(window.location.href);t.searchParams?.delete("filters"),window.history.pushState({},"",""+t)}salla.event.emit("salla-filters::changed",this.filtersData),this.changed.emit(this.filtersData)}),300)}encodeFilters(t,s="filters"){const e=[];for(const i in t)if(Object.prototype.hasOwnProperty.call(t,i)){const a=t[i],l=s?`${s}[${i}]`:i;if(Array.isArray(a))for(let t=0;t<a.length;t++)e.push(`${l}[${t}]=${a[t]}`);else e.push("object"==typeof a&&null!==a?this.encodeFilters(a,l):`${l}=${a}`)}return e.join("&")}async resetFilters(){return this.removeFiltersQueryParams(),this.filtersData={},this.host.childNodes.forEach((t=>t.reset&&t.reset())),salla.event.emit("salla-filters::reset"),this.applyFilters()}removeFiltersQueryParams(){const t=new URLSearchParams(window.location.search),s=Array.from(t.keys()).filter((t=>!t.startsWith("filters["))).map((s=>`${encodeURIComponent(s)}=${encodeURIComponent(t.get(s))}`)).join("&"),e=s?`${window.location.pathname}?${s}`:window.location.pathname;window.history.pushState({},"",e)}handleOptionChange(t,s,e){s.type===n.RANGE&&(this.filtersData[s.key]=e);let i=t.target.checked;s.type===n.VARIANTS?(this.filtersData.variants=this.filtersData.variants||{},i&&(this.filtersData.variants[s.key]=e),i||delete this.filtersData.variants[s.key]):"radio"==t.target.type?(i&&(this.filtersData[s.key]=e),i||delete this.filtersData[s.key]):"checkbox"==t.target.type&&(this.filtersData[s.key]=this.filtersData[s.key]||[],i&&this.filtersData[s.key].push(e),this.filtersData[s.key]=this.filtersData[s.key].filter((t=>t!=e))),this.applyFilters()}render(){return a(l,{key:"f3c454fc20472dca6fe646c9121028a2c045808f"},this.filters?.map((t=>a("salla-filters-widget",{option:t,filtersData:this.filtersData,onChanged:({detail:{event:t,option:s,value:e}})=>{this.handleOptionChange(t,s,e)}}))),this.filters?.length?a("div",{class:"s-filters-footer"},a("salla-button",{color:"gray",fill:"outline",onClick:()=>this.resetFilters()},this.reset)):"")}componentDidLoad(){this.isReady=!0}get host(){return this}static get style(){return":host{display:block}.s-rating-stars-small{line-height:12px}.s-filters-radio{background-image:none !important}"}},[0,"salla-filters",{filters:[1040],isSidebarOpen:[32],filtersData:[32],apply:[32],reset:[32],getFilters:[64],applyFilters:[64],resetFilters:[64]}]);function m(){"undefined"!=typeof customElements&&["salla-filters","salla-button","salla-filters-widget","salla-price-range","salla-rating-stars"].forEach((s=>{switch(s){case"salla-filters":customElements.get(t(s))||customElements.define(t(s),d);break;case"salla-button":customElements.get(t(s))||c();break;case"salla-filters-widget":customElements.get(t(s))||r();break;case"salla-price-range":customElements.get(t(s))||h();break;case"salla-rating-stars":customElements.get(t(s))||f()}}))}m();const p=d,g=m;export{p as SallaFilters,g as defineCustomElement}
|
|
@@ -1,64 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
const SallaFulfillmentMethods$1 = /*@__PURE__*/ proxyCustomElement(class SallaFulfillmentMethods extends HTMLElement {
|
|
7
|
-
constructor() {
|
|
8
|
-
super();
|
|
9
|
-
this.__registerHost();
|
|
10
|
-
this.methods = [];
|
|
11
|
-
this.shouldRender = false;
|
|
12
|
-
}
|
|
13
|
-
async componentDidLoad() {
|
|
14
|
-
await Salla.onReady();
|
|
15
|
-
await Salla.lang.onLoaded();
|
|
16
|
-
if (!Salla.config.get('store.support_pickup'))
|
|
17
|
-
return;
|
|
18
|
-
this.shouldRender = true;
|
|
19
|
-
this.setLabels();
|
|
20
|
-
}
|
|
21
|
-
setLabels() {
|
|
22
|
-
this.methods = [
|
|
23
|
-
{
|
|
24
|
-
id: 'delivery',
|
|
25
|
-
title: Salla.lang.getWithDefault('pages.products.promise_delivery_title', 'متاح للتوصيل'),
|
|
26
|
-
subtitle: Salla.lang.getWithDefault('pages.products.promise_delivery_subtitle', 'طلبك يوصلك لباب البيت بسهولة.'),
|
|
27
|
-
iconClass: 'sicon-location',
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
id: 'pickup',
|
|
31
|
-
title: Salla.lang.getWithDefault('pages.products.promise_pickup_title', 'متاح للاستلام'),
|
|
32
|
-
subtitle: Salla.lang.getWithDefault('pages.products.promise_pickup_subtitle', 'استلام فوري من أقرب فرع.'),
|
|
33
|
-
iconClass: 'sicon-store',
|
|
34
|
-
},
|
|
35
|
-
];
|
|
36
|
-
}
|
|
37
|
-
render() {
|
|
38
|
-
if (!this.shouldRender)
|
|
39
|
-
return null;
|
|
40
|
-
return (h(Host, { class: "s-fulfillment-methods" }, h("div", { class: "s-fulfillment-methods-list" }, this.methods.map((method) => (h("div", { key: method.id, class: "s-fulfillment-methods-card" }, h("div", { class: "s-fulfillment-methods-content" }, h("div", { class: "s-fulfillment-methods-icon-wrap" }, h("i", { class: `${method.iconClass} s-fulfillment-methods-icon` })), h("div", { class: "s-fulfillment-methods-text" }, h("span", { class: "s-fulfillment-methods-title" }, method.title), h("span", { class: "s-fulfillment-methods-subtitle" }, method.subtitle)))))))));
|
|
41
|
-
}
|
|
42
|
-
}, [0, "salla-fulfillment-methods", {
|
|
43
|
-
"methods": [32],
|
|
44
|
-
"shouldRender": [32]
|
|
45
|
-
}]);
|
|
46
|
-
function defineCustomElement$1() {
|
|
47
|
-
if (typeof customElements === "undefined") {
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
const components = ["salla-fulfillment-methods"];
|
|
51
|
-
components.forEach(tagName => { switch (tagName) {
|
|
52
|
-
case "salla-fulfillment-methods":
|
|
53
|
-
if (!customElements.get(tagName)) {
|
|
54
|
-
customElements.define(tagName, SallaFulfillmentMethods$1);
|
|
55
|
-
}
|
|
56
|
-
break;
|
|
57
|
-
} });
|
|
58
|
-
}
|
|
59
|
-
defineCustomElement$1();
|
|
60
|
-
|
|
61
|
-
const SallaFulfillmentMethods = SallaFulfillmentMethods$1;
|
|
62
|
-
const defineCustomElement = defineCustomElement$1;
|
|
63
|
-
|
|
64
|
-
export { SallaFulfillmentMethods, defineCustomElement };
|
|
4
|
+
import{transformTag as s,proxyCustomElement as l,HTMLElement as t,h as e,Host as i}from"@stencil/core/internal/client";const o=l(class extends t{constructor(s){super(),!1!==s&&this.__registerHost(),this.methods=[],this.shouldRender=!1}async componentDidLoad(){await Salla.onReady(),await Salla.lang.onLoaded(),Salla.config.get("store.support_pickup")&&(this.shouldRender=!0,this.setLabels())}setLabels(){this.methods=[{id:"delivery",title:Salla.lang.getWithDefault("pages.products.promise_delivery_title","متاح للتوصيل"),subtitle:Salla.lang.getWithDefault("pages.products.promise_delivery_subtitle","طلبك يوصلك لباب البيت بسهولة."),iconClass:"sicon-location"},{id:"pickup",title:Salla.lang.getWithDefault("pages.products.promise_pickup_title","متاح للاستلام"),subtitle:Salla.lang.getWithDefault("pages.products.promise_pickup_subtitle","استلام فوري من أقرب فرع."),iconClass:"sicon-store"}]}render(){return this.shouldRender?e(i,{class:"s-fulfillment-methods"},e("div",{class:"s-fulfillment-methods-list"},this.methods.map((s=>e("div",{key:s.id,class:"s-fulfillment-methods-card"},e("div",{class:"s-fulfillment-methods-content"},e("div",{class:"s-fulfillment-methods-icon-wrap"},e("i",{class:s.iconClass+" s-fulfillment-methods-icon"})),e("div",{class:"s-fulfillment-methods-text"},e("span",{class:"s-fulfillment-methods-title"},s.title),e("span",{class:"s-fulfillment-methods-subtitle"},s.subtitle)))))))):null}},[0,"salla-fulfillment-methods",{methods:[32],shouldRender:[32]}]);function a(){"undefined"!=typeof customElements&&["salla-fulfillment-methods"].forEach((l=>{"salla-fulfillment-methods"===l&&(customElements.get(s(l))||customElements.define(s(l),o))}))}a();const n=o,c=a;export{n as SallaFulfillmentMethods,c as defineCustomElement}
|