@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.
- package/dist/cjs/app-globals-oehrC7QI.js +39 -0
- package/dist/cjs/{filepond-DFNeUlJZ.js → filepond-D7RVR_w_.js} +10 -5
- package/dist/cjs/{filepond-plugin-file-poster-CdscjCyV.js → filepond-plugin-file-poster-DTuZK2ot.js} +11 -7
- package/dist/cjs/{filepond-plugin-file-validate-size-CeIHus23.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-BEZKgnin.js → filepond-plugin-image-edit-vrZ1s7kw.js} +1 -1
- package/dist/cjs/{filepond-plugin-image-exif-orientation-BsIhjiXV.js → filepond-plugin-image-exif-orientation-Bn5JSzQK.js} +1 -1
- package/dist/cjs/{filepond-plugin-image-preview-CgGyHHMF.js → filepond-plugin-image-preview-8qWUFe9n.js} +1 -1
- package/dist/cjs/{index-RCgJUM7B.js → index-C5VeFDQ0.js} +1966 -1344
- package/dist/cjs/{index-U__MmWip.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 +4 -5
- 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-yWlr4I9a.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 +15 -16
- 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 -360
- 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-dioc1UNj.js → filepond-DlGaLh8N.js} +10 -5
- package/dist/esm/{filepond-plugin-file-poster-BpOMmY57.js → filepond-plugin-file-poster-BTVFYcQx.js} +11 -7
- package/dist/esm/{filepond-plugin-file-validate-size-D3zrIASS.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-vV9cFwQt.js → filepond-plugin-image-edit-2W7pu9hn.js} +1 -1
- package/dist/esm/{filepond-plugin-image-exif-orientation-DQHJunT0.js → filepond-plugin-image-exif-orientation-OQu-IvPH.js} +1 -1
- package/dist/esm/{filepond-plugin-image-preview-CK8pdQ2g.js → filepond-plugin-image-preview-DEW_tSNR.js} +1 -1
- package/dist/esm/{index-B6FFbRiW.js → index-BDqMkCqE.js} +1 -1
- package/dist/esm/{index-BBHnyTVS.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 +4 -5
- 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-DSMkPxn-.js → vanilla-picker-Dt9vZPZF.js} +1 -1
- package/dist/twilight/{p-49260c6c.entry.js → p-06fa7327.entry.js} +1 -1
- package/dist/twilight/{p-0c45b777.entry.js → p-09d39785.entry.js} +1 -1
- package/dist/twilight/{p-98365139.entry.js → p-0add06f9.entry.js} +1 -1
- package/dist/twilight/{p-ccf81e66.entry.js → p-105b1dab.entry.js} +1 -1
- package/dist/twilight/{p-fc6852a0.entry.js → p-108d8c8b.entry.js} +1 -1
- package/dist/twilight/{p-45c1eaa8.entry.js → p-1875537e.entry.js} +1 -1
- package/dist/twilight/{p-06d3f60c.entry.js → p-18bb0181.entry.js} +1 -1
- package/dist/twilight/p-1daeed6e.entry.js +4 -0
- package/dist/twilight/{p-51eeff00.entry.js → p-1ef2602d.entry.js} +1 -1
- package/dist/twilight/{p-e2a6cc78.entry.js → p-2881bb33.entry.js} +1 -1
- package/dist/twilight/{p-143f385c.entry.js → p-293c6cf3.entry.js} +1 -1
- package/dist/twilight/{p-1b50e37e.entry.js → p-296d2dd0.entry.js} +1 -1
- package/dist/twilight/{p-01cb129f.entry.js → p-2abaa633.entry.js} +1 -1
- package/dist/twilight/p-2ddb3fce.entry.js +4 -0
- package/dist/twilight/{p-9623211d.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-1a7e8dc4.entry.js → p-34b670fc.entry.js} +1 -1
- package/dist/twilight/{p-64316672.entry.js → p-3ccc532d.entry.js} +1 -1
- package/dist/twilight/{p-1bacbd68.entry.js → p-41c733c2.entry.js} +1 -1
- package/dist/twilight/{p-abfc0327.entry.js → p-44fa7521.entry.js} +1 -1
- package/dist/twilight/{p-f17b1333.entry.js → p-4932857d.entry.js} +1 -1
- package/dist/twilight/{p-5de17423.entry.js → p-4fa4547a.entry.js} +1 -1
- package/dist/twilight/{p-4f664ee5.entry.js → p-542d3277.entry.js} +1 -1
- package/dist/twilight/{p-db1699d8.entry.js → p-57ff1f25.entry.js} +1 -1
- package/dist/twilight/{p-c800360f.entry.js → p-59ae82bd.entry.js} +1 -1
- package/dist/twilight/{p-495a9262.entry.js → p-647b6d76.entry.js} +1 -1
- package/dist/twilight/p-665189b4.entry.js +4 -0
- package/dist/twilight/{p-a50a28ea.entry.js → p-6f36541a.entry.js} +1 -1
- package/dist/twilight/{p-f8beca67.entry.js → p-7093a427.entry.js} +1 -1
- package/dist/twilight/{p-0a779ecb.entry.js → p-748df7e6.entry.js} +1 -1
- package/dist/twilight/p-776c9d33.entry.js +4 -0
- package/dist/twilight/{p-9a2fa95c.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-2690964e.entry.js → p-87c0ca91.entry.js} +1 -1
- package/dist/twilight/p-8e8d9d7d.entry.js +4 -0
- package/dist/twilight/{p-IulbkBPB.js → p-8r0S6BcZ.js} +1 -1
- package/dist/twilight/{p-d5bea7d7.entry.js → p-94dbc1e9.entry.js} +1 -1
- package/dist/twilight/{p-5e08505f.entry.js → p-96a20515.entry.js} +1 -1
- package/dist/twilight/{p-ce4e06b8.entry.js → p-96d03a28.entry.js} +1 -1
- package/dist/twilight/{p-e8ee7b09.entry.js → p-96e78428.entry.js} +1 -1
- package/dist/twilight/{p-CttEbJoQ.js → p-BZnoSB1s.js} +1 -1
- package/dist/twilight/{p-CWQJdJyB.js → p-BkClxrC4.js} +1 -1
- package/dist/twilight/p-Ck4zxCil.js +9 -0
- package/dist/twilight/{p-BLNd0Q7w.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-03jJUGJM.js → p-X6Yi3bYP.js} +1 -1
- package/dist/twilight/{p-31cff9d6.entry.js → p-a01f1992.entry.js} +1 -1
- package/dist/twilight/{p-dd95dd45.entry.js → p-aa7c5de0.entry.js} +1 -1
- package/dist/twilight/{p-698cda6b.entry.js → p-aaa0c743.entry.js} +1 -1
- package/dist/twilight/{p-2534ee8d.entry.js → p-ad041ab5.entry.js} +1 -1
- package/dist/twilight/{p-78230ff2.entry.js → p-ad07f67a.entry.js} +1 -1
- package/dist/twilight/{p-3570139b.entry.js → p-af3c74f4.entry.js} +1 -1
- package/dist/twilight/p-af60e72a.entry.js +4 -0
- package/dist/twilight/{p-2fd9954e.entry.js → p-b17d055d.entry.js} +1 -1
- package/dist/twilight/{p-0557c403.entry.js → p-b598c0f7.entry.js} +1 -1
- package/dist/twilight/{p-43a3d74b.entry.js → p-b64f3155.entry.js} +1 -1
- package/dist/twilight/p-bNzv71Xl.js +9 -0
- package/dist/twilight/{p-BywTh96y.js → p-bScl0xMh.js} +1 -1
- package/dist/twilight/{p-917e279a.entry.js → p-bff4c7b3.entry.js} +1 -1
- package/dist/twilight/{p-e5faf311.entry.js → p-c091e2dc.entry.js} +1 -1
- package/dist/twilight/{p-5039c032.entry.js → p-c1fd45b1.entry.js} +1 -1
- package/dist/twilight/{p-1646270f.entry.js → p-c3ffb88a.entry.js} +1 -1
- package/dist/twilight/{p-911df985.entry.js → p-c87951a2.entry.js} +1 -1
- package/dist/twilight/{p-cc8c8ee0.entry.js → p-ccfe5308.entry.js} +1 -1
- package/dist/twilight/{p-73fc8bc2.entry.js → p-d337c399.entry.js} +1 -1
- package/dist/twilight/{p-4b78b5b6.entry.js → p-d371d450.entry.js} +1 -1
- package/dist/twilight/{p-099267e9.entry.js → p-d4a242f8.entry.js} +1 -1
- package/dist/twilight/{p-d375a0d6.entry.js → p-d9f5a8cd.entry.js} +1 -1
- package/dist/twilight/{p-72128782.entry.js → p-dd2bd5dc.entry.js} +1 -1
- package/dist/twilight/{p-214c17ba.entry.js → p-df6853b5.entry.js} +1 -1
- package/dist/twilight/{p-db8ea013.entry.js → p-e28c0773.entry.js} +1 -1
- package/dist/twilight/{p-b9a7a8b1.entry.js → p-e3b8e0e1.entry.js} +1 -1
- package/dist/twilight/p-e679884a.entry.js +4 -0
- package/dist/twilight/{p-3094c1a1.entry.js → p-e6bbf50d.entry.js} +1 -1
- package/dist/twilight/{p-6d9ff62d.entry.js → p-e94f217b.entry.js} +1 -1
- package/dist/twilight/{p-f08590d7.entry.js → p-eac718cd.entry.js} +1 -1
- package/dist/twilight/{p-042206f2.entry.js → p-ede67a08.entry.js} +1 -1
- package/dist/twilight/p-efab88c5.entry.js +4 -0
- package/dist/twilight/{p-5abc72fb.entry.js → p-f176d41d.entry.js} +1 -1
- package/dist/twilight/{p-fd540f5b.entry.js → p-f5d15e71.entry.js} +1 -1
- package/dist/twilight/{p-bc9aa300.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-B-xReGXI.js +0 -287
- package/dist/esm/filepond-plugin-file-validate-type-C_O5sg3V.js +0 -285
- package/dist/twilight/p-23c450bb.entry.js +0 -4
- package/dist/twilight/p-2f4352f5.entry.js +0 -4
- package/dist/twilight/p-3a20fbc0.entry.js +0 -4
- package/dist/twilight/p-43fd9024.entry.js +0 -4
- package/dist/twilight/p-736661d1.entry.js +0 -4
- package/dist/twilight/p-7b1e18b9.entry.js +0 -4
- package/dist/twilight/p-8735bed6.entry.js +0 -4
- package/dist/twilight/p-9f09f917.entry.js +0 -4
- package/dist/twilight/p-BBHnyTVS.js +0 -5
- package/dist/twilight/p-BdSnnWWn.js +0 -9
- package/dist/twilight/p-HRFCteJK.js +0 -9
- package/dist/twilight/p-daf6d030.entry.js +0 -4
- package/dist/twilight/p-df66218c.entry.js +0 -4
- package/dist/twilight/p-ec2a876a.entry.js +0 -4
- package/dist/twilight/p-f8b8c0da.entry.js +0 -4
- package/dist/twilight/p-fe417603.entry.js +0 -4
- package/dist/twilight/p-okSe2zH1.js +0 -9
|
@@ -1,266 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
import { d as defineCustomElement$2 } from './salla-skeleton2.js';
|
|
6
|
-
|
|
7
|
-
const SallaDeliveryPromise$1 = /*@__PURE__*/ proxyCustomElement(class SallaDeliveryPromise extends HTMLElement {
|
|
8
|
-
constructor() {
|
|
9
|
-
super();
|
|
10
|
-
this.__registerHost();
|
|
11
|
-
this.cities = [];
|
|
12
|
-
this.filteredCities = [];
|
|
13
|
-
this.selectedCity = null;
|
|
14
|
-
this.deliveryMessage = null;
|
|
15
|
-
this.isLoadingCities = false;
|
|
16
|
-
this.isLoadingPromises = false;
|
|
17
|
-
this.isDropdownOpen = false;
|
|
18
|
-
this.searchQuery = '';
|
|
19
|
-
this.hasError = false;
|
|
20
|
-
this.errorMessage = '';
|
|
21
|
-
/** i18n labels for city selector only; message comes from BE */
|
|
22
|
-
this.labels = {
|
|
23
|
-
deliveryTo: 'توصيل إلى',
|
|
24
|
-
pickupFromBranch: 'الاستلام من فرع',
|
|
25
|
-
searchPlaceholder: 'بحث...',
|
|
26
|
-
noResults: 'لا توجد نتائج',
|
|
27
|
-
selectCity: 'اختر المدينة',
|
|
28
|
-
};
|
|
29
|
-
this.canRender = false;
|
|
30
|
-
this.requiresShipping = false;
|
|
31
|
-
/** Used only for API calls, not rendered — no need for @State */
|
|
32
|
-
this.productId = undefined;
|
|
33
|
-
this.onClickOutside = (e) => {
|
|
34
|
-
if (this.host.contains(e.target)) {
|
|
35
|
-
return; // click inside component (e.g. search input, city list) — don't close
|
|
36
|
-
}
|
|
37
|
-
this.isDropdownOpen = false;
|
|
38
|
-
window.removeEventListener('click', this.onClickOutside);
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
setLabels() {
|
|
42
|
-
this.labels = {
|
|
43
|
-
deliveryTo: salla.lang.getWithDefault('pages.products.promise_deliver_to', 'توصيل إلى'),
|
|
44
|
-
pickupFromBranch: salla.lang.getWithDefault('pages.products.promise_pickup_from_branch', 'الاستلام من فرع'),
|
|
45
|
-
searchPlaceholder: salla.lang.getWithDefault('blocks.header.search_placeholder', 'بحث...'),
|
|
46
|
-
noResults: salla.lang.getWithDefault('common.elements.no_options', 'لا توجد نتائج'),
|
|
47
|
-
selectCity: salla.lang.getWithDefault('common.elements.select_city', 'اختر المدينة'),
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
logger(message, data) {
|
|
51
|
-
if (localStorage.getItem('salla-delivery-promise-debug')) {
|
|
52
|
-
if (data) {
|
|
53
|
-
console.log(message, data);
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
console.log(message);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
async componentDidLoad() {
|
|
61
|
-
await salla.onReady();
|
|
62
|
-
await salla.lang.onLoaded();
|
|
63
|
-
this.setLabels();
|
|
64
|
-
this.requiresShipping = salla.url.is_page('product.single') &&
|
|
65
|
-
salla.config.get('store.features', []).includes('delivery-promises');
|
|
66
|
-
if (this.requiresShipping) {
|
|
67
|
-
this.logger('requiresShipping', this.requiresShipping);
|
|
68
|
-
this.productId = salla.config.get('page.id');
|
|
69
|
-
this.logger('productId', this.productId);
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
this.canRender = false;
|
|
73
|
-
this.logger('not requiresShipping', {
|
|
74
|
-
is_product_single: salla.url.is_page('product.single'),
|
|
75
|
-
includesDeliveryPromises: salla.config.get('store.features', []).includes('delivery-promises')
|
|
76
|
-
});
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
await this.fetchCities();
|
|
80
|
-
}
|
|
81
|
-
async fetchCities() {
|
|
82
|
-
this.logger('start startfetchCities');
|
|
83
|
-
this.isLoadingCities = true;
|
|
84
|
-
this.hasError = false;
|
|
85
|
-
try {
|
|
86
|
-
const response = await salla.api.request(salla.url.api(`products/${this.productId}/delivery-promises/cities`));
|
|
87
|
-
if (response.success && Array.isArray(response.data) && response.data.length > 0) {
|
|
88
|
-
this.logger('fetchCities success', { cities: response.data });
|
|
89
|
-
// Sort cities: explicit cities first (id !== -1), then "Rest of cities" (id === -1)
|
|
90
|
-
this.cities = this.sortCities(response.data);
|
|
91
|
-
this.filteredCities = [...this.cities];
|
|
92
|
-
// First, check if API returns a selected city (is_selected: true)
|
|
93
|
-
let cityToSelect = this.cities.find(c => c.is_selected);
|
|
94
|
-
if (!cityToSelect) {
|
|
95
|
-
this.logger('no selectedCity from API response');
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
this.logger('selectedCity', cityToSelect);
|
|
99
|
-
this.selectedCity = cityToSelect;
|
|
100
|
-
await this.fetchDeliveryMessage(cityToSelect.id);
|
|
101
|
-
}
|
|
102
|
-
this.canRender = true;
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
this.logger('no data returned from fetchCities', { response: response });
|
|
106
|
-
this.canRender = false;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
catch (error) {
|
|
110
|
-
this.logger('fetchCities error', { error: error.message });
|
|
111
|
-
this.hasError = true;
|
|
112
|
-
this.errorMessage = error.message || 'Failed to load cities';
|
|
113
|
-
this.canRender = false;
|
|
114
|
-
}
|
|
115
|
-
finally {
|
|
116
|
-
this.isLoadingCities = false;
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
async fetchDeliveryMessage(cityId) {
|
|
120
|
-
this.logger('start fetchDeliveryMessage', { cityId });
|
|
121
|
-
this.isLoadingPromises = true;
|
|
122
|
-
this.hasError = false;
|
|
123
|
-
this.deliveryMessage = null;
|
|
124
|
-
try {
|
|
125
|
-
const response = await salla.api.withoutNotifier(() => salla.api.request(salla.url.api(`products/${this.productId}/delivery-promises?city_id=${cityId}`)));
|
|
126
|
-
if (response.success && response.data?.message) {
|
|
127
|
-
const message = response.data.message.trim();
|
|
128
|
-
this.logger('fetchDeliveryMessage success', { message });
|
|
129
|
-
this.deliveryMessage = message || null;
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
this.logger('deliveryMessage not valid', { response });
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
catch (error) {
|
|
136
|
-
this.logger('fetchDeliveryMessage error', { error: error.message });
|
|
137
|
-
this.hasError = true;
|
|
138
|
-
this.errorMessage = error.message || 'Failed to load delivery message';
|
|
139
|
-
}
|
|
140
|
-
finally {
|
|
141
|
-
this.isLoadingPromises = false;
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
toggleDropdown(e) {
|
|
145
|
-
e?.stopPropagation();
|
|
146
|
-
this.isDropdownOpen = !this.isDropdownOpen;
|
|
147
|
-
if (this.isDropdownOpen) {
|
|
148
|
-
window.addEventListener('click', this.onClickOutside);
|
|
149
|
-
if (this.searchInputRef) {
|
|
150
|
-
setTimeout(() => this.searchInputRef.focus(), 100);
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
else {
|
|
154
|
-
window.removeEventListener('click', this.onClickOutside);
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
disconnectedCallback() {
|
|
158
|
-
window.removeEventListener('click', this.onClickOutside);
|
|
159
|
-
}
|
|
160
|
-
/**
|
|
161
|
-
* Sort cities: explicit cities first (id !== -1), then "Rest of cities" (id === -1) at the end
|
|
162
|
-
*/
|
|
163
|
-
sortCities(cities) {
|
|
164
|
-
return [...cities].sort((a, b) => {
|
|
165
|
-
// "Rest of cities" (id === -1) should always be at the end
|
|
166
|
-
if (a.id === -1)
|
|
167
|
-
return 1;
|
|
168
|
-
if (b.id === -1)
|
|
169
|
-
return -1;
|
|
170
|
-
return 0;
|
|
171
|
-
});
|
|
172
|
-
}
|
|
173
|
-
handleSearch(event) {
|
|
174
|
-
const query = event.target.value.toLowerCase();
|
|
175
|
-
this.searchQuery = query;
|
|
176
|
-
if (query.length > 0) {
|
|
177
|
-
this.filteredCities = this.cities.filter(city => city.name.toLowerCase()?.includes(query) ||
|
|
178
|
-
(city.name_en || '').toLowerCase()?.includes(query));
|
|
179
|
-
}
|
|
180
|
-
else {
|
|
181
|
-
this.filteredCities = [...this.cities];
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
async selectCity(city) {
|
|
185
|
-
this.logger('selectCity', { city: city });
|
|
186
|
-
this.selectedCity = city;
|
|
187
|
-
this.isDropdownOpen = false;
|
|
188
|
-
window.removeEventListener('click', this.onClickOutside);
|
|
189
|
-
this.searchQuery = '';
|
|
190
|
-
this.filteredCities = [...this.cities];
|
|
191
|
-
await this.fetchDeliveryMessage(city.id);
|
|
192
|
-
}
|
|
193
|
-
renderDropdown() {
|
|
194
|
-
return (h("div", { class: "s-delivery-promise-dropdown" }, h("div", { class: "s-delivery-promise-dropdown-search" }, h("i", { class: "sicon-search" }), h("input", { type: "text", placeholder: this.labels.searchPlaceholder, value: this.searchQuery, onInput: (e) => this.handleSearch(e), ref: el => this.searchInputRef = el })), h("div", { class: "s-delivery-promise-dropdown-list" }, this.filteredCities.length === 0 ? (h("div", { class: "s-delivery-promise-dropdown-empty" }, this.labels.noResults)) : (this.filteredCities.map(city => (h("div", { key: city.id, class: `s-delivery-promise-dropdown-item ${this.selectedCity?.id === city.id ? 'selected' : ''}`, onClick: () => this.selectCity(city) }, h("span", { class: "s-delivery-promise-city-name" }, city.name), this.selectedCity?.id === city.id && (h("i", { class: "sicon-check" })))))))));
|
|
195
|
-
}
|
|
196
|
-
/**
|
|
197
|
-
* Skeleton shown during initial city fetch to avoid blank period and layout shift.
|
|
198
|
-
* Matches the structure/size of the real content (header + message area).
|
|
199
|
-
*/
|
|
200
|
-
renderInitialLoadingSkeleton() {
|
|
201
|
-
return (h(Host, { class: "s-delivery-promise-wrapper s-delivery-promise-skeleton" }, h("div", { class: "s-delivery-promise-container" }, h("div", { class: "s-delivery-promise-header s-delivery-promise-header-skeleton" }, h("div", { class: "s-delivery-promise-location" }, h("salla-skeleton", { height: "14px", width: "180px" })), h("salla-skeleton", { height: "18px", width: "18px" })), h("div", { class: "s-delivery-promise-loading" }, h("salla-skeleton", { height: "20px", width: "80%" })))));
|
|
202
|
-
}
|
|
203
|
-
renderDeliveryMessage() {
|
|
204
|
-
if (this.isLoadingPromises) {
|
|
205
|
-
return (h("div", { class: "s-delivery-promise-loading" }, h("salla-skeleton", { height: "20px", width: "80%" })));
|
|
206
|
-
}
|
|
207
|
-
if (!this.deliveryMessage) {
|
|
208
|
-
return null;
|
|
209
|
-
}
|
|
210
|
-
return (h("div", { class: "s-delivery-promise-message" }, this.deliveryMessage));
|
|
211
|
-
}
|
|
212
|
-
render() {
|
|
213
|
-
// Not on product page or delivery-promises disabled — hide entirely
|
|
214
|
-
if (!this.requiresShipping) {
|
|
215
|
-
return null;
|
|
216
|
-
}
|
|
217
|
-
// Initial city fetch: show skeleton to avoid blank period and layout shift
|
|
218
|
-
if (this.isLoadingCities) {
|
|
219
|
-
return this.renderInitialLoadingSkeleton();
|
|
220
|
-
}
|
|
221
|
-
// Fetch done but no cities / error — hide
|
|
222
|
-
if (!this.canRender || this.cities.length === 0) {
|
|
223
|
-
return null;
|
|
224
|
-
}
|
|
225
|
-
return (h(Host, { class: "s-delivery-promise-wrapper" }, h("div", { class: "s-delivery-promise-container" }, h("div", { class: "s-delivery-promise-header", onClick: (e) => this.toggleDropdown(e) }, h("div", { class: "s-delivery-promise-location" }, h("span", { class: "s-delivery-promise-title" }, this.labels.deliveryTo, " ", this.selectedCity?.name || this.labels.selectCity)), h("i", { class: `sicon-keyboard_arrow_down s-delivery-promise-arrow ${this.isDropdownOpen ? 'open' : ''}` })), this.hasError && (h("div", { class: "s-delivery-promise-error" }, this.errorMessage)), this.isDropdownOpen && this.renderDropdown(), !this.hasError && this.renderDeliveryMessage())));
|
|
226
|
-
}
|
|
227
|
-
get host() { return this; }
|
|
228
|
-
}, [0, "salla-delivery-promise", {
|
|
229
|
-
"cities": [32],
|
|
230
|
-
"filteredCities": [32],
|
|
231
|
-
"selectedCity": [32],
|
|
232
|
-
"deliveryMessage": [32],
|
|
233
|
-
"isLoadingCities": [32],
|
|
234
|
-
"isLoadingPromises": [32],
|
|
235
|
-
"isDropdownOpen": [32],
|
|
236
|
-
"searchQuery": [32],
|
|
237
|
-
"hasError": [32],
|
|
238
|
-
"errorMessage": [32],
|
|
239
|
-
"labels": [32],
|
|
240
|
-
"canRender": [32],
|
|
241
|
-
"requiresShipping": [32]
|
|
242
|
-
}]);
|
|
243
|
-
function defineCustomElement$1() {
|
|
244
|
-
if (typeof customElements === "undefined") {
|
|
245
|
-
return;
|
|
246
|
-
}
|
|
247
|
-
const components = ["salla-delivery-promise", "salla-skeleton"];
|
|
248
|
-
components.forEach(tagName => { switch (tagName) {
|
|
249
|
-
case "salla-delivery-promise":
|
|
250
|
-
if (!customElements.get(tagName)) {
|
|
251
|
-
customElements.define(tagName, SallaDeliveryPromise$1);
|
|
252
|
-
}
|
|
253
|
-
break;
|
|
254
|
-
case "salla-skeleton":
|
|
255
|
-
if (!customElements.get(tagName)) {
|
|
256
|
-
defineCustomElement$2();
|
|
257
|
-
}
|
|
258
|
-
break;
|
|
259
|
-
} });
|
|
260
|
-
}
|
|
261
|
-
defineCustomElement$1();
|
|
262
|
-
|
|
263
|
-
const SallaDeliveryPromise = SallaDeliveryPromise$1;
|
|
264
|
-
const defineCustomElement = defineCustomElement$1;
|
|
265
|
-
|
|
266
|
-
export { SallaDeliveryPromise, defineCustomElement };
|
|
4
|
+
import{transformTag as s,proxyCustomElement as e,HTMLElement as i,h as t,Host as l}from"@stencil/core/internal/client";import{d as r}from"./salla-skeleton2.js";const a=e(class extends i{constructor(s){super(),!1!==s&&this.__registerHost(),this.cities=[],this.filteredCities=[],this.selectedCity=null,this.deliveryMessage=null,this.isLoadingCities=!1,this.isLoadingPromises=!1,this.isDropdownOpen=!1,this.searchQuery="",this.hasError=!1,this.errorMessage="",this.labels={deliveryTo:"توصيل إلى",pickupFromBranch:"الاستلام من فرع",searchPlaceholder:"بحث...",noResults:"لا توجد نتائج",selectCity:"اختر المدينة"},this.canRender=!1,this.requiresShipping=!1,this.productId=void 0,this.onClickOutside=s=>{this.host.contains(s.target)||(this.isDropdownOpen=!1,window.removeEventListener("click",this.onClickOutside))}}setLabels(){this.labels={deliveryTo:salla.lang.getWithDefault("pages.products.promise_deliver_to","توصيل إلى"),pickupFromBranch:salla.lang.getWithDefault("pages.products.promise_pickup_from_branch","الاستلام من فرع"),searchPlaceholder:salla.lang.getWithDefault("blocks.header.search_placeholder","بحث..."),noResults:salla.lang.getWithDefault("common.elements.no_options","لا توجد نتائج"),selectCity:salla.lang.getWithDefault("common.elements.select_city","اختر المدينة")}}logger(s,e){localStorage.getItem("salla-delivery-promise-debug")&&(e?console.log(s,e):console.log(s))}async componentDidLoad(){if(await salla.onReady(),await salla.lang.onLoaded(),this.setLabels(),this.requiresShipping=salla.url.is_page("product.single")&&salla.config.get("store.features",[]).includes("delivery-promises"),!this.requiresShipping)return this.canRender=!1,void this.logger("not requiresShipping",{is_product_single:salla.url.is_page("product.single"),includesDeliveryPromises:salla.config.get("store.features",[]).includes("delivery-promises")});this.logger("requiresShipping",this.requiresShipping),this.productId=salla.config.get("page.id"),this.logger("productId",this.productId),await this.fetchCities()}async fetchCities(){this.logger("start startfetchCities"),this.isLoadingCities=!0,this.hasError=!1;try{const s=await salla.api.request(salla.url.api(`products/${this.productId}/delivery-promises/cities`));if(s.success&&Array.isArray(s.data)&&s.data.length>0){this.logger("fetchCities success",{cities:s.data}),this.cities=this.sortCities(s.data),this.filteredCities=[...this.cities];let e=this.cities.find((s=>s.is_selected));e?(this.logger("selectedCity",e),this.selectedCity=e,await this.fetchDeliveryMessage(e.id)):this.logger("no selectedCity from API response"),this.canRender=!0}else this.logger("no data returned from fetchCities",{response:s}),this.canRender=!1}catch(s){this.logger("fetchCities error",{error:s.message}),this.hasError=!0,this.errorMessage=s.message||"Failed to load cities",this.canRender=!1}finally{this.isLoadingCities=!1}}async fetchDeliveryMessage(s){this.logger("start fetchDeliveryMessage",{cityId:s}),this.isLoadingPromises=!0,this.hasError=!1,this.deliveryMessage=null;try{const e=await salla.api.withoutNotifier((()=>salla.api.request(salla.url.api(`products/${this.productId}/delivery-promises?city_id=${s}`))));if(e.success&&e.data?.message){const s=e.data.message.trim();this.logger("fetchDeliveryMessage success",{message:s}),this.deliveryMessage=s||null}else this.logger("deliveryMessage not valid",{response:e})}catch(s){this.logger("fetchDeliveryMessage error",{error:s.message}),this.hasError=!0,this.errorMessage=s.message||"Failed to load delivery message"}finally{this.isLoadingPromises=!1}}toggleDropdown(s){s?.stopPropagation(),this.isDropdownOpen=!this.isDropdownOpen,this.isDropdownOpen?(window.addEventListener("click",this.onClickOutside),this.searchInputRef&&setTimeout((()=>this.searchInputRef.focus()),100)):window.removeEventListener("click",this.onClickOutside)}disconnectedCallback(){window.removeEventListener("click",this.onClickOutside)}sortCities(s){return[...s].sort(((s,e)=>-1===s.id?1:-1===e.id?-1:0))}handleSearch(s){const e=s.target.value.toLowerCase();this.searchQuery=e,this.filteredCities=e.length>0?this.cities.filter((s=>s.name.toLowerCase()?.includes(e)||(s.name_en||"").toLowerCase()?.includes(e))):[...this.cities]}async selectCity(s){this.logger("selectCity",{city:s}),this.selectedCity=s,this.isDropdownOpen=!1,window.removeEventListener("click",this.onClickOutside),this.searchQuery="",this.filteredCities=[...this.cities],await this.fetchDeliveryMessage(s.id)}renderDropdown(){return t("div",{class:"s-delivery-promise-dropdown"},t("div",{class:"s-delivery-promise-dropdown-search"},t("i",{class:"sicon-search"}),t("input",{type:"text",placeholder:this.labels.searchPlaceholder,value:this.searchQuery,onInput:s=>this.handleSearch(s),ref:s=>this.searchInputRef=s})),t("div",{class:"s-delivery-promise-dropdown-list"},0===this.filteredCities.length?t("div",{class:"s-delivery-promise-dropdown-empty"},this.labels.noResults):this.filteredCities.map((s=>t("div",{key:s.id,class:"s-delivery-promise-dropdown-item "+(this.selectedCity?.id===s.id?"selected":""),onClick:()=>this.selectCity(s)},t("span",{class:"s-delivery-promise-city-name"},s.name),this.selectedCity?.id===s.id&&t("i",{class:"sicon-check"}))))))}renderInitialLoadingSkeleton(){return t(l,{class:"s-delivery-promise-wrapper s-delivery-promise-skeleton"},t("div",{class:"s-delivery-promise-container"},t("div",{class:"s-delivery-promise-header s-delivery-promise-header-skeleton"},t("div",{class:"s-delivery-promise-location"},t("salla-skeleton",{height:"14px",width:"180px"})),t("salla-skeleton",{height:"18px",width:"18px"})),t("div",{class:"s-delivery-promise-loading"},t("salla-skeleton",{height:"20px",width:"80%"}))))}renderDeliveryMessage(){return this.isLoadingPromises?t("div",{class:"s-delivery-promise-loading"},t("salla-skeleton",{height:"20px",width:"80%"})):this.deliveryMessage?t("div",{class:"s-delivery-promise-message"},this.deliveryMessage):null}render(){return this.requiresShipping?this.isLoadingCities?this.renderInitialLoadingSkeleton():this.canRender&&0!==this.cities.length?t(l,{class:"s-delivery-promise-wrapper"},t("div",{class:"s-delivery-promise-container"},t("div",{class:"s-delivery-promise-header",onClick:s=>this.toggleDropdown(s)},t("div",{class:"s-delivery-promise-location"},t("span",{class:"s-delivery-promise-title"},this.labels.deliveryTo," ",this.selectedCity?.name||this.labels.selectCity)),t("i",{class:"sicon-keyboard_arrow_down s-delivery-promise-arrow "+(this.isDropdownOpen?"open":"")})),this.hasError&&t("div",{class:"s-delivery-promise-error"},this.errorMessage),this.isDropdownOpen&&this.renderDropdown(),!this.hasError&&this.renderDeliveryMessage())):null:null}get host(){return this}},[0,"salla-delivery-promise",{cities:[32],filteredCities:[32],selectedCity:[32],deliveryMessage:[32],isLoadingCities:[32],isLoadingPromises:[32],isDropdownOpen:[32],searchQuery:[32],hasError:[32],errorMessage:[32],labels:[32],canRender:[32],requiresShipping:[32]}]);function o(){"undefined"!=typeof customElements&&["salla-delivery-promise","salla-skeleton"].forEach((e=>{switch(e){case"salla-delivery-promise":customElements.get(s(e))||customElements.define(s(e),a);break;case"salla-skeleton":customElements.get(s(e))||r()}}))}o();const h=a,c=o;export{h as SallaDeliveryPromise,c as defineCustomElement}
|
|
@@ -1,9 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
const SallaDrawer = SallaDrawer$1;
|
|
7
|
-
const defineCustomElement = defineCustomElement$1;
|
|
8
|
-
|
|
9
|
-
export { SallaDrawer, defineCustomElement };
|
|
4
|
+
import{S as a,d as r}from"./salla-drawer2.js";const s=a,o=r;export{s as SallaDrawer,o as defineCustomElement}
|
|
@@ -1,217 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
import { C as Cancel } from './cancel.js';
|
|
6
|
-
import { A as AlertEngineIcon, C as CheckCircle2 } from './check-circle2.js';
|
|
7
|
-
import { H as Helper } from './Helper.js';
|
|
8
|
-
import { d as defineCustomElement$1 } from './salla-loading2.js';
|
|
9
|
-
|
|
10
|
-
const sallaDrawerCss = "";
|
|
11
|
-
|
|
12
|
-
const SallaDrawer = /*@__PURE__*/ proxyCustomElement(class SallaDrawer extends HTMLElement {
|
|
13
|
-
constructor() {
|
|
14
|
-
super();
|
|
15
|
-
this.__registerHost();
|
|
16
|
-
this.drawerVisibilityChanged = createEvent(this, "drawerVisibilityChanged", 7);
|
|
17
|
-
/**
|
|
18
|
-
* Sets the drawer to be closable. Defaults to `true`
|
|
19
|
-
*/
|
|
20
|
-
this.isClosable = true;
|
|
21
|
-
/**
|
|
22
|
-
* The width of the drawer
|
|
23
|
-
*/
|
|
24
|
-
this.width = 'md';
|
|
25
|
-
/**
|
|
26
|
-
* The position of the drawer (left or right)
|
|
27
|
-
*/
|
|
28
|
-
this.position = 'right';
|
|
29
|
-
/**
|
|
30
|
-
* open the drawer on rendering
|
|
31
|
-
*/
|
|
32
|
-
this.visible = false;
|
|
33
|
-
/**
|
|
34
|
-
* open the drawer on rendering
|
|
35
|
-
*/
|
|
36
|
-
this.hasSkeleton = false;
|
|
37
|
-
/**
|
|
38
|
-
* Show loading in the middle
|
|
39
|
-
*/
|
|
40
|
-
this.isLoading = false;
|
|
41
|
-
/**
|
|
42
|
-
* Show subtitle before the title or not, defaults to `false` (after the title)
|
|
43
|
-
*/
|
|
44
|
-
this.subTitleFirst = false;
|
|
45
|
-
/**
|
|
46
|
-
* Avoid padding in the drawer body or not, defaults to `false`
|
|
47
|
-
*/
|
|
48
|
-
this.noPadding = false;
|
|
49
|
-
/**
|
|
50
|
-
* Set drawer sub title.
|
|
51
|
-
*/
|
|
52
|
-
this.subTitle = '';
|
|
53
|
-
/**
|
|
54
|
-
* Align drawer content to center, defaults to `false`
|
|
55
|
-
*/
|
|
56
|
-
this.centered = false;
|
|
57
|
-
/**
|
|
58
|
-
* Set the style of the header icon.
|
|
59
|
-
*/
|
|
60
|
-
this.iconStyle = undefined;
|
|
61
|
-
salla.event.on('drawer::open', target => target == this.host.id && this.open());
|
|
62
|
-
salla.event.on('drawer::close', target => target == this.host.id && this.close());
|
|
63
|
-
this.drawerTitle = this.host.getAttribute('drawer-title');
|
|
64
|
-
}
|
|
65
|
-
handleVisible(newValue) {
|
|
66
|
-
if (!newValue) {
|
|
67
|
-
this.drawerVisibilityChanged.emit(false);
|
|
68
|
-
this.toggleDrawer(false);
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
this.drawerVisibilityChanged.emit(true);
|
|
72
|
-
this.host.classList.remove('s-hidden');
|
|
73
|
-
setTimeout(() => this.toggleDrawer(true)); //small amont of time to running toggle After adding hidden
|
|
74
|
-
}
|
|
75
|
-
handleKeyUp(ev) {
|
|
76
|
-
if (ev.key === "Escape") {
|
|
77
|
-
this.closeDrawer();
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Open the drawer
|
|
82
|
-
*/
|
|
83
|
-
async open() {
|
|
84
|
-
this.host.setAttribute('visible', '');
|
|
85
|
-
this.handleAutoFocus();
|
|
86
|
-
return this.host;
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* close the drawer
|
|
90
|
-
*/
|
|
91
|
-
async close() {
|
|
92
|
-
this.host.removeAttribute('visible');
|
|
93
|
-
return this.host;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Change the Drawer Title
|
|
97
|
-
* @param {string} drawerTitle
|
|
98
|
-
*/
|
|
99
|
-
async setTitle(drawerTitle) {
|
|
100
|
-
this.drawerTitle = drawerTitle;
|
|
101
|
-
return this.host;
|
|
102
|
-
}
|
|
103
|
-
/**
|
|
104
|
-
* Start loading
|
|
105
|
-
*/
|
|
106
|
-
async loading() {
|
|
107
|
-
this.isLoading = true;
|
|
108
|
-
return this.host;
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Stop the loading
|
|
112
|
-
*/
|
|
113
|
-
async stopLoading() {
|
|
114
|
-
this.isLoading = false;
|
|
115
|
-
return this.host;
|
|
116
|
-
}
|
|
117
|
-
handleAutoFocus() {
|
|
118
|
-
const firstFocusableElement = this.host.querySelector('input, textarea, select');
|
|
119
|
-
if (!firstFocusableElement) {
|
|
120
|
-
return;
|
|
121
|
-
}
|
|
122
|
-
setTimeout(() => {
|
|
123
|
-
firstFocusableElement.focus();
|
|
124
|
-
}, 100);
|
|
125
|
-
}
|
|
126
|
-
toggleDrawer(isOpen) {
|
|
127
|
-
const body = this.host.querySelector('.s-drawer-body');
|
|
128
|
-
Helper.toggleElementClassIf(body, 's-drawer-entering', 's-drawer-leaving', () => isOpen)
|
|
129
|
-
.toggleElementClassIf(this.overlay, 's-drawer-entering', 's-drawer-overlay-leaving', () => isOpen)
|
|
130
|
-
.toggleElementClassIf(document.body, 'drawer-is-open', 'drawer-is-closed', () => isOpen);
|
|
131
|
-
if (!isOpen) {
|
|
132
|
-
setTimeout(() => this.host.classList.add('s-hidden'), 350);
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
closeDrawer(reason) {
|
|
136
|
-
if (!this.isClosable) {
|
|
137
|
-
return;
|
|
138
|
-
}
|
|
139
|
-
salla.event.dispatch('drawer::close', { reason });
|
|
140
|
-
this.host.removeAttribute('visible');
|
|
141
|
-
}
|
|
142
|
-
iconBlockClasses() {
|
|
143
|
-
return {
|
|
144
|
-
's-drawer-icon': true,
|
|
145
|
-
's-drawer-bg-error': this.iconStyle == 'error',
|
|
146
|
-
's-drawer-bg-success': this.iconStyle == 'success',
|
|
147
|
-
's-drawer-bg-normal': !this.iconStyle,
|
|
148
|
-
's-drawer-bg-primary': this.iconStyle == 'primary'
|
|
149
|
-
};
|
|
150
|
-
}
|
|
151
|
-
getWidth() {
|
|
152
|
-
return this.isLoading ? (this.hasSkeleton ? 'md' : 'xs') : this.width;
|
|
153
|
-
}
|
|
154
|
-
render() {
|
|
155
|
-
this.host.id = this.host.id || 'salla-drawer';
|
|
156
|
-
if (this.isLoading) {
|
|
157
|
-
return (h(Host, { class: 'salla-drawer s-drawer s-drawer-container s-hidden', "aria-modal": "true", role: "dialog", onKeyUp: e => this.handleKeyUp(e) }, h("div", { class: "s-drawer-overlay s-drawer-overlay-leaving", ref: el => this.overlay = el, onClick: () => this.closeDrawer("backdropClick") }), h("div", { class: "s-drawer-wrapper s-drawer-wrapper-" + this.position }, h("div", { class: 's-drawer-body flex justify-center s-drawer-leaving s-drawer-' + this.position + ' s-drawer-' + this.getWidth() + (this.noPadding ? ' s-drawer-nopadding' : ' s-drawer-padding') }, h("slot", { name: "loading" }, h("salla-loading", null)), h("div", { class: "s-hidden" }, h("slot", null))))));
|
|
158
|
-
}
|
|
159
|
-
return (h(Host, { class: 'salla-drawer s-drawer s-drawer-container s-hidden', "aria-modal": "true", role: "dialog" }, h("div", { class: "s-drawer-overlay s-drawer-overlay-leaving", ref: el => this.overlay = el, onClick: () => this.closeDrawer("backdropClick") }), h("div", { class: "s-drawer-wrapper s-drawer-wrapper-" + this.position }, h("div", { class: 's-drawer-body s-drawer-leaving s-drawer-' + this.position + ' s-drawer-' + this.getWidth() + (this.noPadding ? ' s-drawer-nopadding' : ' s-drawer-padding') }, h("div", { class: { 's-drawer-header': true, 's-drawer-is-center': this.centered } }, this.isClosable ?
|
|
160
|
-
h("button", { class: "s-drawer-close", onClick: () => this.closeDrawer("closeButtonClick"), type: "button" }, h("span", { innerHTML: Cancel }))
|
|
161
|
-
: '', this.drawerTitle || this.subTitle ?
|
|
162
|
-
h("div", { class: "s-drawer-header-inner" }, h("slot", { name: 'icon' }, !!this.iconStyle ?
|
|
163
|
-
h("div", { class: this.iconBlockClasses(), innerHTML: this.iconStyle == 'error' ? AlertEngineIcon : CheckCircle2 })
|
|
164
|
-
: ''), h("div", { class: "s-drawer-header-content" }, this.drawerTitle ? h("div", { class: { 's-drawer-title': true, 's-drawer-title-below': this.subTitleFirst }, innerHTML: this.drawerTitle }) : '', this.subTitle ? h("p", { class: { 's-drawer-sub-title': true }, innerHTML: this.subTitle }) : ''))
|
|
165
|
-
: ''), h("slot", null), h("slot", { name: "footer" })))));
|
|
166
|
-
}
|
|
167
|
-
//move the drawer as root dom, because we need the drawer to be outside the forms
|
|
168
|
-
componentDidLoad() {
|
|
169
|
-
document.body.append(this.host);
|
|
170
|
-
}
|
|
171
|
-
get host() { return this; }
|
|
172
|
-
static get watchers() { return {
|
|
173
|
-
"visible": ["handleVisible"]
|
|
174
|
-
}; }
|
|
175
|
-
static get style() { return sallaDrawerCss; }
|
|
176
|
-
}, [4, "salla-drawer", {
|
|
177
|
-
"isClosable": [1028, "is-closable"],
|
|
178
|
-
"width": [513],
|
|
179
|
-
"position": [513],
|
|
180
|
-
"visible": [516],
|
|
181
|
-
"hasSkeleton": [516, "has-skeleton"],
|
|
182
|
-
"isLoading": [1540, "is-loading"],
|
|
183
|
-
"subTitleFirst": [4, "sub-title-first"],
|
|
184
|
-
"noPadding": [4, "no-padding"],
|
|
185
|
-
"subTitle": [1, "sub-title"],
|
|
186
|
-
"centered": [4],
|
|
187
|
-
"iconStyle": [1, "icon-style"],
|
|
188
|
-
"drawerTitle": [32],
|
|
189
|
-
"open": [64],
|
|
190
|
-
"close": [64],
|
|
191
|
-
"setTitle": [64],
|
|
192
|
-
"loading": [64],
|
|
193
|
-
"stopLoading": [64]
|
|
194
|
-
}, [[0, "keyup", "handleKeyUp"]], {
|
|
195
|
-
"visible": ["handleVisible"]
|
|
196
|
-
}]);
|
|
197
|
-
function defineCustomElement() {
|
|
198
|
-
if (typeof customElements === "undefined") {
|
|
199
|
-
return;
|
|
200
|
-
}
|
|
201
|
-
const components = ["salla-drawer", "salla-loading"];
|
|
202
|
-
components.forEach(tagName => { switch (tagName) {
|
|
203
|
-
case "salla-drawer":
|
|
204
|
-
if (!customElements.get(tagName)) {
|
|
205
|
-
customElements.define(tagName, SallaDrawer);
|
|
206
|
-
}
|
|
207
|
-
break;
|
|
208
|
-
case "salla-loading":
|
|
209
|
-
if (!customElements.get(tagName)) {
|
|
210
|
-
defineCustomElement$1();
|
|
211
|
-
}
|
|
212
|
-
break;
|
|
213
|
-
} });
|
|
214
|
-
}
|
|
215
|
-
defineCustomElement();
|
|
216
|
-
|
|
217
|
-
export { SallaDrawer as S, defineCustomElement as d };
|
|
4
|
+
import{transformTag as s,proxyCustomElement as e,HTMLElement as r,createEvent as i,h as t,Host as a}from"@stencil/core/internal/client";import{C as l}from"./cancel.js";import{A as d,C as n}from"./check-circle2.js";import{H as o}from"./Helper.js";import{d as h}from"./salla-loading2.js";const c=e(class extends r{constructor(s){super(),!1!==s&&this.__registerHost(),this.drawerVisibilityChanged=i(this,"drawerVisibilityChanged",7),this.isClosable=!0,this.width="md",this.position="right",this.visible=!1,this.hasSkeleton=!1,this.isLoading=!1,this.subTitleFirst=!1,this.noPadding=!1,this.subTitle="",this.centered=!1,this.iconStyle=void 0,salla.event.on("drawer::open",(s=>s==this.host.id&&this.open())),salla.event.on("drawer::close",(s=>s==this.host.id&&this.close())),this.drawerTitle=this.host.getAttribute("drawer-title")}handleVisible(s){if(!s)return this.drawerVisibilityChanged.emit(!1),void this.toggleDrawer(!1);this.drawerVisibilityChanged.emit(!0),this.host.classList.remove("s-hidden"),setTimeout((()=>this.toggleDrawer(!0)))}handleKeyUp(s){"Escape"===s.key&&this.closeDrawer()}async open(){return this.host.setAttribute("visible",""),this.handleAutoFocus(),this.host}async close(){return this.host.removeAttribute("visible"),this.host}async setTitle(s){return this.drawerTitle=s,this.host}async loading(){return this.isLoading=!0,this.host}async stopLoading(){return this.isLoading=!1,this.host}handleAutoFocus(){const s=this.host.querySelector("input, textarea, select");s&&setTimeout((()=>{s.focus()}),100)}toggleDrawer(s){const e=this.host.querySelector(".s-drawer-body");o.toggleElementClassIf(e,"s-drawer-entering","s-drawer-leaving",(()=>s)).toggleElementClassIf(this.overlay,"s-drawer-entering","s-drawer-overlay-leaving",(()=>s)).toggleElementClassIf(document.body,"drawer-is-open","drawer-is-closed",(()=>s)),s||setTimeout((()=>this.host.classList.add("s-hidden")),350)}closeDrawer(s){this.isClosable&&(salla.event.dispatch("drawer::close",{reason:s}),this.host.removeAttribute("visible"))}iconBlockClasses(){return{"s-drawer-icon":!0,"s-drawer-bg-error":"error"==this.iconStyle,"s-drawer-bg-success":"success"==this.iconStyle,"s-drawer-bg-normal":!this.iconStyle,"s-drawer-bg-primary":"primary"==this.iconStyle}}getWidth(){return this.isLoading?this.hasSkeleton?"md":"xs":this.width}render(){return this.host.id=this.host.id||"salla-drawer",this.isLoading?t(a,{class:"salla-drawer s-drawer s-drawer-container s-hidden","aria-modal":"true",role:"dialog",onKeyUp:s=>this.handleKeyUp(s)},t("div",{class:"s-drawer-overlay s-drawer-overlay-leaving",ref:s=>this.overlay=s,onClick:()=>this.closeDrawer("backdropClick")}),t("div",{class:"s-drawer-wrapper s-drawer-wrapper-"+this.position},t("div",{class:"s-drawer-body flex justify-center s-drawer-leaving s-drawer-"+this.position+" s-drawer-"+this.getWidth()+(this.noPadding?" s-drawer-nopadding":" s-drawer-padding")},t("slot",{name:"loading"},t("salla-loading",null)),t("div",{class:"s-hidden"},t("slot",null))))):t(a,{class:"salla-drawer s-drawer s-drawer-container s-hidden","aria-modal":"true",role:"dialog"},t("div",{class:"s-drawer-overlay s-drawer-overlay-leaving",ref:s=>this.overlay=s,onClick:()=>this.closeDrawer("backdropClick")}),t("div",{class:"s-drawer-wrapper s-drawer-wrapper-"+this.position},t("div",{class:"s-drawer-body s-drawer-leaving s-drawer-"+this.position+" s-drawer-"+this.getWidth()+(this.noPadding?" s-drawer-nopadding":" s-drawer-padding")},t("div",{class:{"s-drawer-header":!0,"s-drawer-is-center":this.centered}},this.isClosable?t("button",{class:"s-drawer-close",onClick:()=>this.closeDrawer("closeButtonClick"),type:"button"},t("span",{innerHTML:l})):"",this.drawerTitle||this.subTitle?t("div",{class:"s-drawer-header-inner"},t("slot",{name:"icon"},this.iconStyle?t("div",{class:this.iconBlockClasses(),innerHTML:"error"==this.iconStyle?d:n}):""),t("div",{class:"s-drawer-header-content"},this.drawerTitle?t("div",{class:{"s-drawer-title":!0,"s-drawer-title-below":this.subTitleFirst},innerHTML:this.drawerTitle}):"",this.subTitle?t("p",{class:{"s-drawer-sub-title":!0},innerHTML:this.subTitle}):"")):""),t("slot",null),t("slot",{name:"footer"}))))}componentDidLoad(){document.body.append(this.host)}get host(){return this}static get watchers(){return{visible:[{handleVisible:0}]}}static get style(){return""}},[260,"salla-drawer",{isClosable:[1028,"is-closable"],width:[513],position:[513],visible:[516],hasSkeleton:[516,"has-skeleton"],isLoading:[1540,"is-loading"],subTitleFirst:[4,"sub-title-first"],noPadding:[4,"no-padding"],subTitle:[1,"sub-title"],centered:[4],iconStyle:[1,"icon-style"],drawerTitle:[32],open:[64],close:[64],setTitle:[64],loading:[64],stopLoading:[64]},[[0,"keyup","handleKeyUp"]],{visible:[{handleVisible:0}]}]);function w(){"undefined"!=typeof customElements&&["salla-drawer","salla-loading"].forEach((e=>{switch(e){case"salla-drawer":customElements.get(s(e))||customElements.define(s(e),c);break;case"salla-loading":customElements.get(s(e))||h()}}))}w();export{c as S,w as d}
|
|
@@ -1,9 +1,4 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Crafted with ❤ by Salla
|
|
3
3
|
*/
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
const SallaFileUpload = SallaFileUpload$1;
|
|
7
|
-
const defineCustomElement = defineCustomElement$1;
|
|
8
|
-
|
|
9
|
-
export { SallaFileUpload, defineCustomElement };
|
|
4
|
+
import{S as a,d as o}from"./salla-file-upload2.js";const s=a,l=o;export{s as SallaFileUpload,l as defineCustomElement}
|