@salla.sa/twilight-components 2.14.393 → 2.14.395

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (557) hide show
  1. package/dist/cjs/{filepond-D7RVR_w_.js → filepond-DhDK6X-K.js} +1 -1
  2. package/dist/cjs/{filepond-plugin-file-poster-DTuZK2ot.js → filepond-plugin-file-poster-By0OGSbr.js} +2 -2
  3. package/dist/cjs/{filepond-plugin-file-validate-size-DHc6pF_j.js → filepond-plugin-file-validate-size-C5OjLfMZ.js} +1 -1
  4. package/dist/cjs/{filepond-plugin-file-validate-type-DnkcvJVc.js → filepond-plugin-file-validate-type-DAtZkzcc.js} +1 -1
  5. package/dist/cjs/{filepond-plugin-image-edit-vrZ1s7kw.js → filepond-plugin-image-edit-BSqtSAWo.js} +1 -1
  6. package/dist/cjs/{filepond-plugin-image-exif-orientation-Bn5JSzQK.js → filepond-plugin-image-exif-orientation-BLuNiU8R.js} +1 -1
  7. package/dist/cjs/{filepond-plugin-image-preview-8qWUFe9n.js → filepond-plugin-image-preview-DE9EBkNn.js} +1 -1
  8. package/dist/cjs/{index-C5VeFDQ0.js → index-BGJUbcXt.js} +547 -780
  9. package/dist/cjs/{index-CwD81m7i.js → index-BMeldHxT.js} +1 -1
  10. package/dist/cjs/loader.cjs.js +3 -4
  11. package/dist/cjs/salla-accordion-body_2.cjs.entry.js +5 -5
  12. package/dist/cjs/salla-accordion_6.cjs.entry.js +15 -19
  13. package/dist/cjs/salla-add-product-button_4.cjs.entry.js +10 -12
  14. package/dist/cjs/salla-advertisement.cjs.entry.js +3 -3
  15. package/dist/cjs/salla-alert_2.cjs.entry.js +5 -5
  16. package/dist/cjs/salla-app-install-alert.cjs.entry.js +3 -3
  17. package/dist/cjs/salla-apps-icons.cjs.entry.js +3 -3
  18. package/dist/cjs/salla-booking-field_7.cjs.entry.js +23 -25
  19. package/dist/cjs/salla-bullet-delivery.cjs.entry.js +3 -3
  20. package/dist/cjs/salla-cart-coupons.cjs.entry.js +3 -3
  21. package/dist/cjs/salla-cart-item-offers_2.cjs.entry.js +5 -5
  22. package/dist/cjs/salla-comment-form_8.cjs.entry.js +17 -17
  23. package/dist/cjs/salla-conditional-offer.cjs.entry.js +3 -3
  24. package/dist/cjs/salla-contacts.cjs.entry.js +3 -3
  25. package/dist/cjs/salla-cookies-bar.cjs.entry.js +3 -3
  26. package/dist/cjs/salla-count-down.cjs.entry.js +3 -3
  27. package/dist/cjs/salla-custom-fields.cjs.entry.js +3 -3
  28. package/dist/cjs/salla-delivery-promise.cjs.entry.js +1 -1
  29. package/dist/cjs/salla-filters-widget.cjs.entry.js +3 -3
  30. package/dist/cjs/salla-filters.cjs.entry.js +3 -3
  31. package/dist/cjs/salla-fulfillment-methods.cjs.entry.js +1 -1
  32. package/dist/cjs/salla-gifting.cjs.entry.js +17 -14
  33. package/dist/cjs/salla-hook.cjs.entry.js +2 -5
  34. package/dist/cjs/salla-infinite-scroll.cjs.entry.js +3 -3
  35. package/dist/cjs/salla-installment.cjs.entry.js +3 -3
  36. package/dist/cjs/salla-list-tile.cjs.entry.js +3 -3
  37. package/dist/cjs/salla-localization-modal.cjs.entry.js +1 -1
  38. package/dist/cjs/salla-login-modal.cjs.entry.js +3 -3
  39. package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +3 -3
  40. package/dist/cjs/salla-loyalty-program.cjs.entry.js +3 -3
  41. package/dist/cjs/salla-loyalty.cjs.entry.js +3 -3
  42. package/dist/cjs/salla-maintenance-alert.cjs.entry.js +3 -3
  43. package/dist/cjs/salla-map.cjs.entry.js +3 -3
  44. package/dist/cjs/salla-menu.cjs.entry.js +3 -3
  45. package/dist/cjs/salla-metadata.cjs.entry.js +3 -3
  46. package/dist/cjs/salla-multiple-bundle-product-cart_2.cjs.entry.js +5 -5
  47. package/dist/cjs/salla-multiple-bundle-product-options-modal_2.cjs.entry.js +6 -8
  48. package/dist/cjs/salla-multiple-bundle-product.cjs.entry.js +4 -6
  49. package/dist/cjs/salla-notification-item.cjs.entry.js +3 -3
  50. package/dist/cjs/salla-notifications.cjs.entry.js +3 -3
  51. package/dist/cjs/salla-offer-modal.cjs.entry.js +3 -3
  52. package/dist/cjs/salla-offer.cjs.entry.js +3 -3
  53. package/dist/cjs/salla-order-details-multiple-bundle-product.cjs.entry.js +3 -3
  54. package/dist/cjs/salla-order-details-options.cjs.entry.js +3 -3
  55. package/dist/cjs/salla-order-details.cjs.entry.js +4 -6
  56. package/dist/cjs/salla-order-edit-item.cjs.entry.js +3 -3
  57. package/dist/cjs/salla-order-edit.cjs.entry.js +3 -3
  58. package/dist/cjs/salla-order-summary.cjs.entry.js +3 -3
  59. package/dist/cjs/salla-order-totals-card.cjs.entry.js +4 -6
  60. package/dist/cjs/salla-orders.cjs.entry.js +3 -3
  61. package/dist/cjs/salla-payments.cjs.entry.js +3 -3
  62. package/dist/cjs/salla-placeholder.cjs.entry.js +3 -3
  63. package/dist/cjs/salla-price-range.cjs.entry.js +3 -3
  64. package/dist/cjs/salla-product-card.cjs.entry.js +3 -3
  65. package/dist/cjs/salla-product-size-guide.cjs.entry.js +3 -3
  66. package/dist/cjs/salla-products-list.cjs.entry.js +3 -3
  67. package/dist/cjs/salla-products-slider.cjs.entry.js +3 -3
  68. package/dist/cjs/salla-progress-bar.cjs.entry.js +3 -3
  69. package/dist/cjs/salla-quick-order.cjs.entry.js +3 -3
  70. package/dist/cjs/salla-rating-modal.cjs.entry.js +3 -3
  71. package/dist/cjs/salla-scopes.cjs.entry.js +3 -3
  72. package/dist/cjs/salla-search.cjs.entry.js +4 -6
  73. package/dist/cjs/salla-skeleton.cjs.entry.js +3 -3
  74. package/dist/cjs/salla-slider.cjs.entry.js +3 -3
  75. package/dist/cjs/salla-social-share.cjs.entry.js +3 -3
  76. package/dist/cjs/salla-social.cjs.entry.js +3 -3
  77. package/dist/cjs/salla-tab-content_3.cjs.entry.js +7 -7
  78. package/dist/cjs/salla-tiered-offer.cjs.entry.js +3 -3
  79. package/dist/cjs/salla-tooltip.cjs.entry.js +3 -3
  80. package/dist/cjs/salla-trust-badges.cjs.entry.js +3 -3
  81. package/dist/cjs/salla-user-menu.cjs.entry.js +3 -3
  82. package/dist/cjs/salla-user-profile.cjs.entry.js +3 -3
  83. package/dist/cjs/salla-user-settings.cjs.entry.js +3 -3
  84. package/dist/cjs/salla-verify.cjs.entry.js +3 -3
  85. package/dist/cjs/salla-wallet.cjs.entry.js +3 -3
  86. package/dist/cjs/twilight.cjs.js +4 -5
  87. package/dist/cjs/{vanilla-picker-yKERbLpx.js → vanilla-picker-BJmFb-7a.js} +1 -1
  88. package/dist/collection/collection-manifest.json +2 -3
  89. package/dist/collection/components/salla-accordion/salla-accordion-head.js +2 -2
  90. package/dist/collection/components/salla-accordion/salla-accordion.js +4 -4
  91. package/dist/collection/components/salla-add-product-button/salla-add-product-button.js +19 -19
  92. package/dist/collection/components/salla-alert/salla-alert.js +5 -5
  93. package/dist/collection/components/salla-apps-icons/salla-apps-icons.js +6 -6
  94. package/dist/collection/components/salla-booking-field/salla-booking-field.js +4 -4
  95. package/dist/collection/components/salla-bottom-alert/salla-bottom-alert.js +9 -9
  96. package/dist/collection/components/salla-bullet-delivery/salla-bullet-delivery.js +3 -6
  97. package/dist/collection/components/salla-button/salla-button.js +11 -11
  98. package/dist/collection/components/salla-cart-coupons/salla-cart-coupons.js +1 -2
  99. package/dist/collection/components/salla-cart-item-offers/salla-cart-item-offers.js +8 -8
  100. package/dist/collection/components/salla-cart-summary/salla-cart-summary.js +2 -2
  101. package/dist/collection/components/salla-color-picker/salla-color-picker.js +14 -20
  102. package/dist/collection/components/salla-comment-form/salla-comment-form.js +6 -6
  103. package/dist/collection/components/salla-comments/salla-comment-item.js +3 -2
  104. package/dist/collection/components/salla-comments/salla-comments.js +17 -18
  105. package/dist/collection/components/salla-contacts/salla-contacts.js +10 -10
  106. package/dist/collection/components/salla-count-down/salla-count-down.js +34 -34
  107. package/dist/collection/components/salla-custom-fields/salla-custom-fields.js +7 -9
  108. package/dist/collection/components/salla-datetime-picker/salla-datetime-picker.js +65 -69
  109. package/dist/collection/components/salla-drawer/salla-drawer.js +11 -11
  110. package/dist/collection/components/salla-file-upload/salla-file-upload.js +84 -85
  111. package/dist/collection/components/salla-filters/salla-filters.js +2 -2
  112. package/dist/collection/components/salla-filters-widget/salla-filters-widget.js +5 -4
  113. package/dist/collection/components/salla-gifting/salla-gifting.js +45 -23
  114. package/dist/collection/components/salla-hook/salla-hook.js +2 -2
  115. package/dist/collection/components/salla-infinite-scroll/salla-infinite-scroll.js +6 -6
  116. package/dist/collection/components/salla-installment/salla-installment.js +5 -5
  117. package/dist/collection/components/salla-list-tile/salla-list-tile.js +2 -2
  118. package/dist/collection/components/salla-loading/salla-loading.js +4 -4
  119. package/dist/collection/components/salla-localization-modal/salla-localization-modal.js +5 -5
  120. package/dist/collection/components/salla-login-modal/salla-login-modal.js +14 -14
  121. package/dist/collection/components/salla-loyalty/salla-loyalty-prize-item.js +3 -4
  122. package/dist/collection/components/salla-loyalty/salla-loyalty.js +12 -13
  123. package/dist/collection/components/salla-map/salla-map.js +14 -14
  124. package/dist/collection/components/salla-menu/salla-menu.js +9 -10
  125. package/dist/collection/components/salla-metadata/salla-metadata.js +3 -3
  126. package/dist/collection/components/salla-modal/salla-modal.js +11 -11
  127. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-cart.js +2 -2
  128. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-details.js +2 -2
  129. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-options-modal.js +2 -4
  130. package/dist/collection/components/salla-multiple-bundle-product/components/salla-multiple-bundle-product-slider.js +7 -8
  131. package/dist/collection/components/salla-multiple-bundle-product/salla-multiple-bundle-product.js +2 -2
  132. package/dist/collection/components/salla-notifications/salla-notification-item.js +2 -2
  133. package/dist/collection/components/salla-notifications/salla-notifications.js +3 -3
  134. package/dist/collection/components/salla-offer/salla-offer.js +1 -1
  135. package/dist/collection/components/salla-order-details/salla-order-details-multiple-bundle-product.js +5 -5
  136. package/dist/collection/components/salla-order-details/salla-order-details-options.js +5 -6
  137. package/dist/collection/components/salla-order-details/salla-order-details.js +3 -4
  138. package/dist/collection/components/salla-order-edit/salla-order-edit-item.js +4 -4
  139. package/dist/collection/components/salla-order-edit/salla-order-edit.js +4 -4
  140. package/dist/collection/components/salla-order-summary/salla-order-summary.js +2 -2
  141. package/dist/collection/components/salla-order-totals-card/salla-order-totals-card.js +3 -4
  142. package/dist/collection/components/salla-orders/salla-orders.js +4 -4
  143. package/dist/collection/components/salla-payments/salla-payments.js +1 -0
  144. package/dist/collection/components/salla-placeholder/salla-placeholder.js +3 -3
  145. package/dist/collection/components/salla-price-range/salla-price-range.js +8 -8
  146. package/dist/collection/components/salla-product-availability/salla-product-availability.js +6 -6
  147. package/dist/collection/components/salla-product-card/salla-product-card.js +18 -18
  148. package/dist/collection/components/salla-product-options/salla-product-options.js +13 -15
  149. package/dist/collection/components/salla-products-list/salla-products-list.js +21 -20
  150. package/dist/collection/components/salla-products-slider/salla-products-slider.js +23 -22
  151. package/dist/collection/components/salla-progress-bar/salla-progress-bar.js +20 -21
  152. package/dist/collection/components/salla-quantity-input/salla-quantity-input.js +2 -2
  153. package/dist/collection/components/salla-quick-buy/salla-quick-buy.js +17 -16
  154. package/dist/collection/components/salla-quick-order/salla-quick-order.js +11 -11
  155. package/dist/collection/components/salla-rating-modal/salla-rating-modal.js +2 -2
  156. package/dist/collection/components/salla-rating-stars/salla-rating-stars.js +8 -8
  157. package/dist/collection/components/salla-review-card/salla-review-card.js +3 -3
  158. package/dist/collection/components/salla-reviews/salla-reviews.js +13 -16
  159. package/dist/collection/components/salla-reviews-summary/salla-reviews-summary.js +2 -2
  160. package/dist/collection/components/salla-scopes/salla-scopes.js +2 -2
  161. package/dist/collection/components/salla-search/salla-search.js +6 -6
  162. package/dist/collection/components/salla-skeleton/salla-skeleton.js +3 -3
  163. package/dist/collection/components/salla-slider/salla-slider.js +25 -25
  164. package/dist/collection/components/salla-social-share/salla-social-share.js +3 -3
  165. package/dist/collection/components/salla-tabs/salla-tab-content.js +2 -2
  166. package/dist/collection/components/salla-tabs/salla-tab-header.js +5 -5
  167. package/dist/collection/components/salla-tabs/salla-tabs.js +2 -2
  168. package/dist/collection/components/salla-tel-input/salla-tel-input.js +8 -9
  169. package/dist/collection/components/salla-tooltip/salla-tooltip.js +5 -5
  170. package/dist/collection/components/salla-trust-badges/salla-trust-badges.js +1 -1
  171. package/dist/collection/components/salla-user-menu/salla-user-menu.js +5 -5
  172. package/dist/collection/components/salla-user-profile/salla-user-profile.js +1 -1
  173. package/dist/collection/components/salla-verify/salla-verify.js +4 -4
  174. package/dist/components/Helper.js +432 -1
  175. package/dist/components/_commonjsHelpers.js +7 -1
  176. package/dist/components/anime.es.js +1310 -1
  177. package/dist/components/arrow-left.js +8 -1
  178. package/dist/components/axios.js +4240 -2
  179. package/dist/components/bell-ring.js +8 -1
  180. package/dist/components/camera.js +8 -1
  181. package/dist/components/cancel.js +8 -1
  182. package/dist/components/cart.js +8 -1
  183. package/dist/components/check-circle2.js +15 -1
  184. package/dist/components/check.js +8 -1
  185. package/dist/components/facebook.js +10 -1
  186. package/dist/components/filepond-plugin-file-poster.js +662 -2
  187. package/dist/components/filepond-plugin-file-validate-size.js +204 -2
  188. package/dist/components/filepond-plugin-file-validate-type.js +262 -2
  189. package/dist/components/filepond-plugin-image-edit.js +487 -2
  190. package/dist/components/filepond-plugin-image-exif-orientation.js +214 -2
  191. package/dist/components/filepond-plugin-image-preview.js +2237 -2
  192. package/dist/components/filepond.js +11286 -2
  193. package/dist/components/gift.js +8 -1
  194. package/dist/components/image.js +8 -1
  195. package/dist/components/index.d.ts +0 -2
  196. package/dist/components/index.js +8220 -1
  197. package/dist/components/index2.js +1709 -1
  198. package/dist/components/index3.js +2550 -1
  199. package/dist/components/interfaces.js +12 -1
  200. package/dist/components/isObject.js +292 -1
  201. package/dist/components/keyboard_arrow_down.js +8 -1
  202. package/dist/components/keyboard_arrow_right.js +15 -1
  203. package/dist/components/location.js +11 -1
  204. package/dist/components/mail.js +8 -1
  205. package/dist/components/minus.js +15 -1
  206. package/dist/components/salla-accordion-body.js +6 -1
  207. package/dist/components/salla-accordion-body2.js +30 -1
  208. package/dist/components/salla-accordion-head.js +6 -1
  209. package/dist/components/salla-accordion-head2.js +63 -1
  210. package/dist/components/salla-accordion.js +6 -1
  211. package/dist/components/salla-accordion2.js +68 -1
  212. package/dist/components/salla-add-product-button.js +6 -1
  213. package/dist/components/salla-add-product-button2.js +306 -1
  214. package/dist/components/salla-advertisement.js +155 -1
  215. package/dist/components/salla-alert.js +59 -1
  216. package/dist/components/salla-app-install-alert.js +91 -1
  217. package/dist/components/salla-apps-icons.js +63 -1
  218. package/dist/components/salla-booking-field.js +6 -1
  219. package/dist/components/salla-booking-field2.js +221 -1
  220. package/dist/components/salla-bottom-alert.js +214 -1
  221. package/dist/components/salla-breadcrumb.js +226 -1
  222. package/dist/components/salla-bullet-delivery.js +2114 -1
  223. package/dist/components/salla-button.js +6 -1
  224. package/dist/components/salla-button2.js +174 -1
  225. package/dist/components/salla-cart-coupons.js +284 -1
  226. package/dist/components/salla-cart-item-offers.js +143 -1
  227. package/dist/components/salla-cart-summary.js +136 -1
  228. package/dist/components/salla-color-picker.js +6 -1
  229. package/dist/components/salla-color-picker2.js +260 -1
  230. package/dist/components/salla-comment-form.js +6 -1
  231. package/dist/components/salla-comment-form2.js +64 -1
  232. package/dist/components/salla-comment-item.js +6 -1
  233. package/dist/components/salla-comment-item2.js +217 -1
  234. package/dist/components/salla-comments.js +395 -1
  235. package/dist/components/salla-conditional-fields.js +6 -1
  236. package/dist/components/salla-conditional-fields2.js +137 -1
  237. package/dist/components/salla-conditional-offer.js +194 -1
  238. package/dist/components/salla-contacts.js +125 -1
  239. package/dist/components/salla-cookies-bar.js +107 -1
  240. package/dist/components/salla-count-down.js +6 -1
  241. package/dist/components/salla-count-down2.js +271 -1
  242. package/dist/components/salla-custom-fields.js +175 -1
  243. package/dist/components/salla-datetime-picker.js +6 -1
  244. package/dist/components/salla-datetime-picker2.js +342 -1
  245. package/dist/components/salla-delivery-promise.js +263 -1
  246. package/dist/components/salla-drawer.js +6 -1
  247. package/dist/components/salla-drawer2.js +214 -1
  248. package/dist/components/salla-file-upload.js +6 -1
  249. package/dist/components/salla-file-upload2.js +583 -1
  250. package/dist/components/salla-filters-widget.js +6 -1
  251. package/dist/components/salla-filters-widget2.js +245 -1
  252. package/dist/components/salla-filters.js +253 -1
  253. package/dist/components/salla-fulfillment-methods.js +61 -1
  254. package/dist/components/salla-gifting.js +736 -1
  255. package/dist/components/salla-hook.js +47 -1
  256. package/dist/components/salla-infinite-scroll.js +112 -1
  257. package/dist/components/salla-installment.js +306 -1
  258. package/dist/components/salla-list-tile.js +6 -1
  259. package/dist/components/salla-list-tile2.js +47 -1
  260. package/dist/components/salla-loading.js +6 -1
  261. package/dist/components/salla-loading2.js +51 -1
  262. package/dist/components/salla-localization-modal.js +296 -1
  263. package/dist/components/salla-login-modal.js +6 -1
  264. package/dist/components/salla-login-modal2.js +359 -1
  265. package/dist/components/salla-loyalty-prize-item.js +39 -1
  266. package/dist/components/salla-loyalty-program.js +115 -1
  267. package/dist/components/salla-loyalty.js +304 -1
  268. package/dist/components/salla-maintenance-alert.js +57 -1
  269. package/dist/components/salla-map.js +6 -1
  270. package/dist/components/salla-map2.js +766 -1
  271. package/dist/components/salla-menu.js +165 -1
  272. package/dist/components/salla-metadata.js +97 -1
  273. package/dist/components/salla-modal.js +6 -1
  274. package/dist/components/salla-modal2.js +215 -1
  275. package/dist/components/salla-multiple-bundle-product-cart.js +6 -1
  276. package/dist/components/salla-multiple-bundle-product-cart2.js +151 -1
  277. package/dist/components/salla-multiple-bundle-product-details.js +6 -1
  278. package/dist/components/salla-multiple-bundle-product-details2.js +296 -1
  279. package/dist/components/salla-multiple-bundle-product-options-modal.js +6 -1
  280. package/dist/components/salla-multiple-bundle-product-options-modal2.js +598 -1
  281. package/dist/components/salla-multiple-bundle-product-slider.js +6 -1
  282. package/dist/components/salla-multiple-bundle-product-slider2.js +136 -1
  283. package/dist/components/salla-multiple-bundle-product.js +207 -1
  284. package/dist/components/salla-notification-item.js +6 -1
  285. package/dist/components/salla-notification-item2.js +32 -1
  286. package/dist/components/salla-notifications.js +190 -1
  287. package/dist/components/salla-offer-modal.js +328 -1
  288. package/dist/components/salla-offer.js +478 -1
  289. package/dist/components/salla-order-details-multiple-bundle-product.js +6 -1
  290. package/dist/components/salla-order-details-multiple-bundle-product2.js +122 -1
  291. package/dist/components/salla-order-details-options.js +6 -1
  292. package/dist/components/salla-order-details-options2.js +140 -1
  293. package/dist/components/salla-order-details.js +122 -1
  294. package/dist/components/salla-order-edit-item.js +6 -1
  295. package/dist/components/salla-order-edit-item2.js +181 -1
  296. package/dist/components/salla-order-edit.js +288 -1
  297. package/dist/components/salla-order-summary.js +132 -1
  298. package/dist/components/salla-order-totals-card.js +87 -1
  299. package/dist/components/salla-orders.js +271 -1
  300. package/dist/components/salla-payments.js +76 -1
  301. package/dist/components/salla-placeholder.js +6 -1
  302. package/dist/components/salla-placeholder2.js +66 -1
  303. package/dist/components/salla-price-range.js +6 -1
  304. package/dist/components/salla-price-range2.js +204 -1
  305. package/dist/components/salla-product-availability.js +6 -1
  306. package/dist/components/salla-product-availability2.js +206 -1
  307. package/dist/components/salla-product-card.js +6 -1
  308. package/dist/components/salla-product-card2.js +241 -1
  309. package/dist/components/salla-product-options.js +6 -1
  310. package/dist/components/salla-product-options2.js +962 -1
  311. package/dist/components/salla-product-size-guide.js +130 -1
  312. package/dist/components/salla-products-list.js +6 -1
  313. package/dist/components/salla-products-list2.js +812 -1
  314. package/dist/components/salla-products-slider.js +6 -1
  315. package/dist/components/salla-products-slider2.js +215 -1
  316. package/dist/components/salla-progress-bar.js +6 -1
  317. package/dist/components/salla-progress-bar2.js +94 -1
  318. package/dist/components/salla-quantity-input.js +6 -1
  319. package/dist/components/salla-quantity-input2.js +127 -1
  320. package/dist/components/salla-quick-buy.js +6 -1
  321. package/dist/components/salla-quick-buy2.js +1181 -1
  322. package/dist/components/salla-quick-order.js +299 -1
  323. package/dist/components/salla-rating-modal.js +530 -1
  324. package/dist/components/salla-rating-stars.js +6 -1
  325. package/dist/components/salla-rating-stars2.js +162 -1
  326. package/dist/components/salla-review-card.js +6 -1
  327. package/dist/components/salla-review-card2.js +198 -1
  328. package/dist/components/salla-reviews-page.js +726 -1
  329. package/dist/components/salla-reviews-summary.js +6 -1
  330. package/dist/components/salla-reviews-summary2.js +132 -1
  331. package/dist/components/salla-reviews.js +143 -1
  332. package/dist/components/salla-scopes.js +249 -1
  333. package/dist/components/salla-search.js +213 -1
  334. package/dist/components/salla-skeleton.js +6 -1
  335. package/dist/components/salla-skeleton2.js +50 -1
  336. package/dist/components/salla-slider.js +6 -1
  337. package/dist/components/salla-slider2.js +10489 -1
  338. package/dist/components/salla-social-share.js +194 -1
  339. package/dist/components/salla-social.js +89 -1
  340. package/dist/components/salla-tab-content.js +6 -1
  341. package/dist/components/salla-tab-content2.js +55 -1
  342. package/dist/components/salla-tab-header.js +6 -1
  343. package/dist/components/salla-tab-header2.js +85 -1
  344. package/dist/components/salla-tabs.js +6 -1
  345. package/dist/components/salla-tabs2.js +75 -1
  346. package/dist/components/salla-tel-input.js +6 -1
  347. package/dist/components/salla-tel-input2.js +168 -1
  348. package/dist/components/salla-tiered-offer.js +366 -1
  349. package/dist/components/salla-tooltip.js +6 -1
  350. package/dist/components/salla-tooltip2.js +57 -1
  351. package/dist/components/salla-trust-badges.js +90 -1
  352. package/dist/components/salla-user-menu.js +344 -1
  353. package/dist/components/salla-user-profile.js +203 -1
  354. package/dist/components/salla-user-settings.js +139 -1
  355. package/dist/components/salla-verify.js +303 -1
  356. package/dist/components/salla-wallet.js +114 -1
  357. package/dist/components/search.js +8 -1
  358. package/dist/components/shopping-bag.js +8 -1
  359. package/dist/components/special-discount.js +8 -1
  360. package/dist/components/star.js +8 -1
  361. package/dist/components/star2.js +8 -1
  362. package/dist/components/vanilla-picker.js +1034 -2
  363. package/dist/components/whatsapp2.js +8 -1
  364. package/dist/esm/{filepond-DlGaLh8N.js → filepond-B5O4Ep7g.js} +1 -1
  365. package/dist/esm/{filepond-plugin-file-poster-BTVFYcQx.js → filepond-plugin-file-poster-CXl-thGg.js} +2 -2
  366. package/dist/esm/{filepond-plugin-file-validate-size-DGryLmWv.js → filepond-plugin-file-validate-size-9IDBrVOZ.js} +1 -1
  367. package/dist/esm/{filepond-plugin-file-validate-type-DxKfCD0V.js → filepond-plugin-file-validate-type-DcoiRIvo.js} +1 -1
  368. package/dist/esm/{filepond-plugin-image-edit-2W7pu9hn.js → filepond-plugin-image-edit-DDAVgEhK.js} +1 -1
  369. package/dist/esm/{filepond-plugin-image-exif-orientation-OQu-IvPH.js → filepond-plugin-image-exif-orientation-BEr9NdP5.js} +1 -1
  370. package/dist/esm/{filepond-plugin-image-preview-DEW_tSNR.js → filepond-plugin-image-preview-AxYFTZHo.js} +1 -1
  371. package/dist/esm/{index-DYB20YqN.js → index-B08XlOeq.js} +547 -780
  372. package/dist/esm/{index-BDqMkCqE.js → index-CT1GcrKO.js} +1 -1
  373. package/dist/esm/loader.js +3 -4
  374. package/dist/esm/salla-accordion-body_2.entry.js +5 -5
  375. package/dist/esm/salla-accordion_6.entry.js +15 -19
  376. package/dist/esm/salla-add-product-button_4.entry.js +10 -12
  377. package/dist/esm/salla-advertisement.entry.js +3 -3
  378. package/dist/esm/salla-alert_2.entry.js +5 -5
  379. package/dist/esm/salla-app-install-alert.entry.js +3 -3
  380. package/dist/esm/salla-apps-icons.entry.js +3 -3
  381. package/dist/esm/salla-booking-field_7.entry.js +23 -25
  382. package/dist/esm/salla-bullet-delivery.entry.js +3 -3
  383. package/dist/esm/salla-cart-coupons.entry.js +3 -3
  384. package/dist/esm/salla-cart-item-offers_2.entry.js +5 -5
  385. package/dist/esm/salla-comment-form_8.entry.js +17 -17
  386. package/dist/esm/salla-conditional-offer.entry.js +3 -3
  387. package/dist/esm/salla-contacts.entry.js +3 -3
  388. package/dist/esm/salla-cookies-bar.entry.js +3 -3
  389. package/dist/esm/salla-count-down.entry.js +3 -3
  390. package/dist/esm/salla-custom-fields.entry.js +3 -3
  391. package/dist/esm/salla-delivery-promise.entry.js +1 -1
  392. package/dist/esm/salla-filters-widget.entry.js +3 -3
  393. package/dist/esm/salla-filters.entry.js +3 -3
  394. package/dist/esm/salla-fulfillment-methods.entry.js +1 -1
  395. package/dist/esm/salla-gifting.entry.js +17 -14
  396. package/dist/esm/salla-hook.entry.js +2 -5
  397. package/dist/esm/salla-infinite-scroll.entry.js +3 -3
  398. package/dist/esm/salla-installment.entry.js +3 -3
  399. package/dist/esm/salla-list-tile.entry.js +3 -3
  400. package/dist/esm/salla-localization-modal.entry.js +1 -1
  401. package/dist/esm/salla-login-modal.entry.js +3 -3
  402. package/dist/esm/salla-loyalty-prize-item.entry.js +3 -3
  403. package/dist/esm/salla-loyalty-program.entry.js +3 -3
  404. package/dist/esm/salla-loyalty.entry.js +3 -3
  405. package/dist/esm/salla-maintenance-alert.entry.js +3 -3
  406. package/dist/esm/salla-map.entry.js +3 -3
  407. package/dist/esm/salla-menu.entry.js +3 -3
  408. package/dist/esm/salla-metadata.entry.js +3 -3
  409. package/dist/esm/salla-multiple-bundle-product-cart_2.entry.js +5 -5
  410. package/dist/esm/salla-multiple-bundle-product-options-modal_2.entry.js +6 -8
  411. package/dist/esm/salla-multiple-bundle-product.entry.js +4 -6
  412. package/dist/esm/salla-notification-item.entry.js +3 -3
  413. package/dist/esm/salla-notifications.entry.js +3 -3
  414. package/dist/esm/salla-offer-modal.entry.js +3 -3
  415. package/dist/esm/salla-offer.entry.js +3 -3
  416. package/dist/esm/salla-order-details-multiple-bundle-product.entry.js +3 -3
  417. package/dist/esm/salla-order-details-options.entry.js +3 -3
  418. package/dist/esm/salla-order-details.entry.js +4 -6
  419. package/dist/esm/salla-order-edit-item.entry.js +3 -3
  420. package/dist/esm/salla-order-edit.entry.js +3 -3
  421. package/dist/esm/salla-order-summary.entry.js +3 -3
  422. package/dist/esm/salla-order-totals-card.entry.js +4 -6
  423. package/dist/esm/salla-orders.entry.js +3 -3
  424. package/dist/esm/salla-payments.entry.js +3 -3
  425. package/dist/esm/salla-placeholder.entry.js +3 -3
  426. package/dist/esm/salla-price-range.entry.js +3 -3
  427. package/dist/esm/salla-product-card.entry.js +3 -3
  428. package/dist/esm/salla-product-size-guide.entry.js +3 -3
  429. package/dist/esm/salla-products-list.entry.js +3 -3
  430. package/dist/esm/salla-products-slider.entry.js +3 -3
  431. package/dist/esm/salla-progress-bar.entry.js +3 -3
  432. package/dist/esm/salla-quick-order.entry.js +3 -3
  433. package/dist/esm/salla-rating-modal.entry.js +3 -3
  434. package/dist/esm/salla-scopes.entry.js +3 -3
  435. package/dist/esm/salla-search.entry.js +4 -6
  436. package/dist/esm/salla-skeleton.entry.js +3 -3
  437. package/dist/esm/salla-slider.entry.js +3 -3
  438. package/dist/esm/salla-social-share.entry.js +3 -3
  439. package/dist/esm/salla-social.entry.js +3 -3
  440. package/dist/esm/salla-tab-content_3.entry.js +7 -7
  441. package/dist/esm/salla-tiered-offer.entry.js +3 -3
  442. package/dist/esm/salla-tooltip.entry.js +3 -3
  443. package/dist/esm/salla-trust-badges.entry.js +3 -3
  444. package/dist/esm/salla-user-menu.entry.js +3 -3
  445. package/dist/esm/salla-user-profile.entry.js +3 -3
  446. package/dist/esm/salla-user-settings.entry.js +3 -3
  447. package/dist/esm/salla-verify.entry.js +3 -3
  448. package/dist/esm/salla-wallet.entry.js +3 -3
  449. package/dist/esm/twilight.js +4 -5
  450. package/dist/esm/{vanilla-picker-Dt9vZPZF.js → vanilla-picker-BHoeSGTe.js} +1 -1
  451. package/dist/twilight/{p-1875537e.entry.js → p-00ff16e1.entry.js} +1 -1
  452. package/dist/twilight/{p-af3c74f4.entry.js → p-014fb8d0.entry.js} +1 -1
  453. package/dist/twilight/{p-b64f3155.entry.js → p-0253cf3c.entry.js} +1 -1
  454. package/dist/twilight/p-053408d8.entry.js +4 -0
  455. package/dist/twilight/{p-e3b8e0e1.entry.js → p-09d16254.entry.js} +1 -1
  456. package/dist/twilight/{p-c87951a2.entry.js → p-0c90006b.entry.js} +1 -1
  457. package/dist/twilight/{p-296d2dd0.entry.js → p-0d8ec747.entry.js} +1 -1
  458. package/dist/twilight/{p-ad07f67a.entry.js → p-1150cf28.entry.js} +1 -1
  459. package/dist/twilight/p-1303d9d7.entry.js +4 -0
  460. package/dist/twilight/{p-aaa0c743.entry.js → p-14068508.entry.js} +1 -1
  461. package/dist/twilight/{p-ad041ab5.entry.js → p-1cc45c37.entry.js} +1 -1
  462. package/dist/twilight/{p-06fa7327.entry.js → p-1dd74467.entry.js} +1 -1
  463. package/dist/twilight/{p-eac718cd.entry.js → p-1df75ff6.entry.js} +1 -1
  464. package/dist/twilight/p-1dfe9e7e.entry.js +4 -0
  465. package/dist/twilight/{p-09d39785.entry.js → p-211a0d89.entry.js} +1 -1
  466. package/dist/twilight/{p-44fa7521.entry.js → p-2c192362.entry.js} +1 -1
  467. package/dist/twilight/{p-c3ffb88a.entry.js → p-33d101c0.entry.js} +1 -1
  468. package/dist/twilight/{p-b598c0f7.entry.js → p-431a16ce.entry.js} +1 -1
  469. package/dist/twilight/{p-e94f217b.entry.js → p-464bc8d5.entry.js} +1 -1
  470. package/dist/twilight/p-52ac8f65.entry.js +4 -0
  471. package/dist/twilight/{p-33779828.entry.js → p-55fc519c.entry.js} +1 -1
  472. package/dist/twilight/{p-2abaa633.entry.js → p-5ceae537.entry.js} +1 -1
  473. package/dist/twilight/{p-7093a427.entry.js → p-5f23edd8.entry.js} +1 -1
  474. package/dist/twilight/{p-96d03a28.entry.js → p-5f35500e.entry.js} +1 -1
  475. package/dist/twilight/p-61211f13.entry.js +4 -0
  476. package/dist/twilight/{p-1ef2602d.entry.js → p-6456c5b0.entry.js} +1 -1
  477. package/dist/twilight/{p-aa7c5de0.entry.js → p-66240512.entry.js} +1 -1
  478. package/dist/twilight/{p-bff4c7b3.entry.js → p-6f510269.entry.js} +1 -1
  479. package/dist/twilight/{p-748df7e6.entry.js → p-706205de.entry.js} +1 -1
  480. package/dist/twilight/{p-34b670fc.entry.js → p-71752a0e.entry.js} +1 -1
  481. package/dist/twilight/{p-c091e2dc.entry.js → p-736dd3ae.entry.js} +1 -1
  482. package/dist/twilight/p-75c9c0d9.entry.js +4 -0
  483. package/dist/twilight/{p-7abddca8.entry.js → p-77854672.entry.js} +1 -1
  484. package/dist/twilight/{p-d337c399.entry.js → p-7dceb44c.entry.js} +1 -1
  485. package/dist/twilight/{p-96e78428.entry.js → p-822f2337.entry.js} +1 -1
  486. package/dist/twilight/{p-4fa4547a.entry.js → p-82373ce1.entry.js} +1 -1
  487. package/dist/twilight/{p-87c0ca91.entry.js → p-85c67570.entry.js} +1 -1
  488. package/dist/twilight/{p-94dbc1e9.entry.js → p-89a0e4a2.entry.js} +1 -1
  489. package/dist/twilight/{p-105b1dab.entry.js → p-8d3692dd.entry.js} +1 -1
  490. package/dist/twilight/p-8dad41ec.entry.js +4 -0
  491. package/dist/twilight/{p-a01f1992.entry.js → p-8f6fd451.entry.js} +1 -1
  492. package/dist/twilight/{p-f7999a6d.entry.js → p-9131dcc3.entry.js} +1 -1
  493. package/dist/twilight/{p-4932857d.entry.js → p-94846672.entry.js} +1 -1
  494. package/dist/twilight/{p-e28c0773.entry.js → p-95058bbc.entry.js} +1 -1
  495. package/dist/twilight/p-99b45fc0.entry.js +4 -0
  496. package/dist/twilight/{p-ccfe5308.entry.js → p-9b17680f.entry.js} +1 -1
  497. package/dist/twilight/{p-59ae82bd.entry.js → p-9f159167.entry.js} +1 -1
  498. package/dist/twilight/{p-d9f5a8cd.entry.js → p-9f29e169.entry.js} +1 -1
  499. package/dist/twilight/p-B08XlOeq.js +5 -0
  500. package/dist/twilight/{p-Ck4zxCil.js → p-B4GW5rQA.js} +1 -1
  501. package/dist/twilight/p-BJ1KNlpk.js +9 -0
  502. package/dist/twilight/{p-BZnoSB1s.js → p-BaawQYdd.js} +1 -1
  503. package/dist/twilight/{p-BkClxrC4.js → p-CqsSEVeE.js} +1 -1
  504. package/dist/twilight/{p-bNzv71Xl.js → p-D5tTqDmK.js} +1 -1
  505. package/dist/twilight/{p-bScl0xMh.js → p-DH6oNmKl.js} +1 -1
  506. package/dist/twilight/{p-8r0S6BcZ.js → p-DaNAdDbS.js} +1 -1
  507. package/dist/twilight/{p-293c6cf3.entry.js → p-a45b7450.entry.js} +1 -1
  508. package/dist/twilight/{p-f176d41d.entry.js → p-ace93243.entry.js} +1 -1
  509. package/dist/twilight/{p-f5d15e71.entry.js → p-af1efb90.entry.js} +1 -1
  510. package/dist/twilight/{p-b17d055d.entry.js → p-af26e966.entry.js} +1 -1
  511. package/dist/twilight/{p-6f36541a.entry.js → p-b14b4ab3.entry.js} +1 -1
  512. package/dist/twilight/{p-d4a242f8.entry.js → p-b392c814.entry.js} +1 -1
  513. package/dist/twilight/{p-e6bbf50d.entry.js → p-b3a120ea.entry.js} +1 -1
  514. package/dist/twilight/p-b5ccdde0.entry.js +4 -0
  515. package/dist/twilight/{p-96a20515.entry.js → p-b604eb49.entry.js} +1 -1
  516. package/dist/twilight/{p-d371d450.entry.js → p-b7abf14c.entry.js} +1 -1
  517. package/dist/twilight/{p-Cw3UBzjl.js → p-bLx9-3Hz.js} +1 -1
  518. package/dist/twilight/{p-2fe01e44.entry.js → p-bca6dd48.entry.js} +1 -1
  519. package/dist/twilight/{p-817b8ba5.entry.js → p-c2d42f04.entry.js} +1 -1
  520. package/dist/twilight/{p-647b6d76.entry.js → p-c325358a.entry.js} +1 -1
  521. package/dist/twilight/{p-3ccc532d.entry.js → p-ca8718f8.entry.js} +1 -1
  522. package/dist/twilight/{p-542d3277.entry.js → p-cb414a45.entry.js} +1 -1
  523. package/dist/twilight/p-cfe885f4.entry.js +4 -0
  524. package/dist/twilight/{p-df6853b5.entry.js → p-d2c4946f.entry.js} +1 -1
  525. package/dist/twilight/p-d4c3dabd.entry.js +4 -0
  526. package/dist/twilight/{p-ede67a08.entry.js → p-d698ba2c.entry.js} +1 -1
  527. package/dist/twilight/p-d8b1d590.entry.js +4 -0
  528. package/dist/twilight/{p-c1fd45b1.entry.js → p-daa42168.entry.js} +1 -1
  529. package/dist/twilight/{p-41c733c2.entry.js → p-e1a37066.entry.js} +1 -1
  530. package/dist/twilight/{p-18bb0181.entry.js → p-e51efb7b.entry.js} +1 -1
  531. package/dist/twilight/{p-108d8c8b.entry.js → p-e857e666.entry.js} +1 -1
  532. package/dist/twilight/{p-0add06f9.entry.js → p-ea6aa784.entry.js} +1 -1
  533. package/dist/twilight/{p-57ff1f25.entry.js → p-f1401804.entry.js} +1 -1
  534. package/dist/twilight/{p-2881bb33.entry.js → p-f7e41ac3.entry.js} +1 -1
  535. package/dist/twilight/{p-X6Yi3bYP.js → p-m8Xtdgy2.js} +1 -1
  536. package/dist/twilight/twilight.esm.js +1 -1
  537. package/dist/types/components/salla-gifting/salla-gifting.d.ts +6 -1
  538. package/dist/types/components.d.ts +187 -765
  539. package/dist/types/stencil-public-runtime.d.ts +11 -169
  540. package/package.json +5 -5
  541. package/dist/cjs/app-globals-oehrC7QI.js +0 -39
  542. package/dist/esm/app-globals-BFryt7-C.js +0 -37
  543. package/dist/twilight/p-1daeed6e.entry.js +0 -4
  544. package/dist/twilight/p-2ddb3fce.entry.js +0 -4
  545. package/dist/twilight/p-34968e31.entry.js +0 -4
  546. package/dist/twilight/p-665189b4.entry.js +0 -4
  547. package/dist/twilight/p-776c9d33.entry.js +0 -4
  548. package/dist/twilight/p-7b8313ef.entry.js +0 -4
  549. package/dist/twilight/p-7bd0ede5.entry.js +0 -4
  550. package/dist/twilight/p-8e8d9d7d.entry.js +0 -4
  551. package/dist/twilight/p-D1vqXXNX.js +0 -9
  552. package/dist/twilight/p-DYB20YqN.js +0 -5
  553. package/dist/twilight/p-Vl6qpttb.js +0 -4
  554. package/dist/twilight/p-af60e72a.entry.js +0 -4
  555. package/dist/twilight/p-dd2bd5dc.entry.js +0 -4
  556. package/dist/twilight/p-e679884a.entry.js +0 -4
  557. package/dist/twilight/p-efab88c5.entry.js +0 -4
@@ -1,4 +1,266 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
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}
4
+ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
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 };
@@ -1,4 +1,9 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
4
- import{S as a,d as r}from"./salla-drawer2.js";const s=a,o=r;export{s as SallaDrawer,o as defineCustomElement}
4
+ import { S as SallaDrawer$1, d as defineCustomElement$1 } from './salla-drawer2.js';
5
+
6
+ const SallaDrawer = SallaDrawer$1;
7
+ const defineCustomElement = defineCustomElement$1;
8
+
9
+ export { SallaDrawer, defineCustomElement };
@@ -1,4 +1,217 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
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}
4
+ import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
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 };
@@ -1,4 +1,9 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
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}
4
+ import { S as SallaFileUpload$1, d as defineCustomElement$1 } from './salla-file-upload2.js';
5
+
6
+ const SallaFileUpload = SallaFileUpload$1;
7
+ const defineCustomElement = defineCustomElement$1;
8
+
9
+ export { SallaFileUpload, defineCustomElement };