@salla.sa/twilight-components 2.14.418 → 2.14.420

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 (383) hide show
  1. package/dist/cjs/{filepond-C1_8U7ht.js → filepond-CTL5dLDP.js} +1 -1
  2. package/dist/cjs/{filepond-plugin-file-poster-C2QZkcu0.js → filepond-plugin-file-poster-B-C_VVcX.js} +1 -1
  3. package/dist/cjs/{filepond-plugin-file-validate-size-CbVRd24w.js → filepond-plugin-file-validate-size-CzKg3e_q.js} +1 -1
  4. package/dist/cjs/{filepond-plugin-file-validate-type-63RP4vcL.js → filepond-plugin-file-validate-type-vnM88Tws.js} +1 -1
  5. package/dist/cjs/{filepond-plugin-image-edit-CjWMhhkZ.js → filepond-plugin-image-edit-DI2Woa_n.js} +1 -1
  6. package/dist/cjs/{filepond-plugin-image-exif-orientation-CJxStqYG.js → filepond-plugin-image-exif-orientation-DfOieqsR.js} +1 -1
  7. package/dist/cjs/{filepond-plugin-image-preview--RTa59Q8.js → filepond-plugin-image-preview-BnoA6sXp.js} +1 -1
  8. package/dist/cjs/{functions-T48FHZw8.js → functions-DlISHrKx.js} +1 -1
  9. package/dist/cjs/helpers-BJ2rnhxz.js +197 -0
  10. package/dist/cjs/{index-CQ4zjhzH.js → index-tOrYNNsf.js} +1 -1
  11. package/dist/cjs/{index-DO_QXaSt.js → index-vstkdqRz.js} +10 -6
  12. package/dist/cjs/interfaces-Bh7W0bEU.js +33 -0
  13. package/dist/cjs/loader.cjs.js +2 -2
  14. package/dist/cjs/salla-accordion-body_2.cjs.entry.js +1 -1
  15. package/dist/cjs/salla-accordion_6.cjs.entry.js +1 -1
  16. package/dist/cjs/salla-add-product-button_5.cjs.entry.js +36 -58
  17. package/dist/cjs/salla-advertisement.cjs.entry.js +1 -1
  18. package/dist/cjs/salla-alert_2.cjs.entry.js +1 -1
  19. package/dist/cjs/salla-app-install-alert.cjs.entry.js +1 -1
  20. package/dist/cjs/salla-apps-icons.cjs.entry.js +1 -1
  21. package/dist/cjs/salla-badge.cjs.entry.js +1 -1
  22. package/dist/cjs/salla-booking-field_7.cjs.entry.js +12 -12
  23. package/dist/cjs/salla-bullet-delivery.cjs.entry.js +1 -1
  24. package/dist/cjs/salla-cart-coupons.cjs.entry.js +1 -1
  25. package/dist/cjs/salla-cart-item-offers_2.cjs.entry.js +1 -1
  26. package/dist/cjs/salla-comment-form_8.cjs.entry.js +4 -4
  27. package/dist/cjs/salla-conditional-offer.cjs.entry.js +1 -1
  28. package/dist/cjs/salla-contacts.cjs.entry.js +1 -1
  29. package/dist/cjs/salla-cookies-bar.cjs.entry.js +1 -1
  30. package/dist/cjs/salla-count-down.cjs.entry.js +1 -1
  31. package/dist/cjs/salla-custom-fields.cjs.entry.js +1 -1
  32. package/dist/cjs/salla-delivery-promise.cjs.entry.js +1 -1
  33. package/dist/cjs/salla-edit-order-button.cjs.entry.js +1 -1
  34. package/dist/cjs/salla-filters-widget.cjs.entry.js +1 -1
  35. package/dist/cjs/salla-filters.cjs.entry.js +1 -1
  36. package/dist/cjs/salla-fulfillment-methods.cjs.entry.js +1 -1
  37. package/dist/cjs/salla-gifting.cjs.entry.js +1 -1
  38. package/dist/cjs/salla-hook.cjs.entry.js +1 -1
  39. package/dist/cjs/salla-infinite-scroll.cjs.entry.js +1 -1
  40. package/dist/cjs/salla-installment.cjs.entry.js +1 -1
  41. package/dist/cjs/salla-list-tile.cjs.entry.js +1 -1
  42. package/dist/cjs/salla-localization-modal.cjs.entry.js +1 -1
  43. package/dist/cjs/salla-login-modal.cjs.entry.js +1 -1
  44. package/dist/cjs/salla-loyalty-banner.cjs.entry.js +2 -2
  45. package/dist/cjs/salla-loyalty-hero_2.cjs.entry.js +2 -2
  46. package/dist/cjs/salla-loyalty-panel.cjs.entry.js +8 -6
  47. package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +1 -1
  48. package/dist/cjs/salla-loyalty-program.cjs.entry.js +3 -3
  49. package/dist/cjs/salla-loyalty-reward.cjs.entry.js +2 -2
  50. package/dist/cjs/salla-loyalty.cjs.entry.js +14 -3
  51. package/dist/cjs/salla-maintenance-alert.cjs.entry.js +1 -1
  52. package/dist/cjs/salla-map.cjs.entry.js +1 -1
  53. package/dist/cjs/salla-menu.cjs.entry.js +1 -1
  54. package/dist/cjs/salla-metadata.cjs.entry.js +1 -1
  55. package/dist/cjs/salla-multiple-bundle-product-cart_2.cjs.entry.js +1 -1
  56. package/dist/cjs/salla-multiple-bundle-product-options-modal_2.cjs.entry.js +1 -1
  57. package/dist/cjs/salla-multiple-bundle-product.cjs.entry.js +1 -1
  58. package/dist/cjs/salla-notification-item.cjs.entry.js +1 -1
  59. package/dist/cjs/salla-notifications.cjs.entry.js +1 -1
  60. package/dist/cjs/salla-offer-modal.cjs.entry.js +1 -1
  61. package/dist/cjs/salla-offer.cjs.entry.js +1 -1
  62. package/dist/cjs/salla-order-details-multiple-bundle-product.cjs.entry.js +1 -1
  63. package/dist/cjs/salla-order-details-options.cjs.entry.js +1 -1
  64. package/dist/cjs/salla-order-details.cjs.entry.js +1 -1
  65. package/dist/cjs/salla-order-edit-item.cjs.entry.js +28 -29
  66. package/dist/cjs/salla-order-edit-product-card.cjs.entry.js +41 -0
  67. package/dist/cjs/salla-order-edit.cjs.entry.js +339 -40
  68. package/dist/cjs/salla-order-summary.cjs.entry.js +2 -2
  69. package/dist/cjs/salla-order-totals-card.cjs.entry.js +1 -1
  70. package/dist/cjs/salla-orders.cjs.entry.js +1 -1
  71. package/dist/cjs/salla-payments.cjs.entry.js +3 -3
  72. package/dist/cjs/salla-placeholder.cjs.entry.js +2 -2
  73. package/dist/cjs/salla-price-range.cjs.entry.js +3 -3
  74. package/dist/cjs/salla-product-card_2.cjs.entry.js +6 -6
  75. package/dist/cjs/salla-product-size-guide.cjs.entry.js +3 -3
  76. package/dist/cjs/salla-products-list.cjs.entry.js +38 -15
  77. package/dist/cjs/salla-progress-bar.cjs.entry.js +1 -1
  78. package/dist/cjs/salla-quick-order.cjs.entry.js +1 -1
  79. package/dist/cjs/salla-rating-modal.cjs.entry.js +1 -1
  80. package/dist/cjs/salla-reward-action_4.cjs.entry.js +15 -8
  81. package/dist/cjs/salla-scopes.cjs.entry.js +2 -2
  82. package/dist/cjs/salla-search.cjs.entry.js +6 -6
  83. package/dist/cjs/salla-skeleton.cjs.entry.js +2 -2
  84. package/dist/cjs/salla-slider.cjs.entry.js +1 -1
  85. package/dist/cjs/salla-social-share.cjs.entry.js +2 -2
  86. package/dist/cjs/salla-social.cjs.entry.js +2 -2
  87. package/dist/cjs/salla-tab-content_3.cjs.entry.js +4 -4
  88. package/dist/cjs/salla-tiered-offer.cjs.entry.js +1 -1
  89. package/dist/cjs/salla-tooltip.cjs.entry.js +2 -2
  90. package/dist/cjs/salla-trust-badges.cjs.entry.js +1 -1
  91. package/dist/cjs/salla-user-menu.cjs.entry.js +1 -1
  92. package/dist/cjs/salla-user-profile.cjs.entry.js +1 -1
  93. package/dist/cjs/salla-user-settings.cjs.entry.js +2 -2
  94. package/dist/cjs/salla-verify.cjs.entry.js +1 -1
  95. package/dist/cjs/salla-wallet.cjs.entry.js +1 -1
  96. package/dist/cjs/{tracked-promise-BnNAgCN_.js → tracked-promise-BJe1J-1V.js} +1 -1
  97. package/dist/cjs/twilight.cjs.js +2 -2
  98. package/dist/cjs/{vanilla-picker-wbE79zwn.js → vanilla-picker-nnRs4Y1U.js} +1 -1
  99. package/dist/collection/collection-manifest.json +1 -0
  100. package/dist/collection/components/salla-loyalty/salla-loyalty.js +24 -2
  101. package/dist/collection/components/salla-loyalty-program/salla-loyalty-panel.js +5 -3
  102. package/dist/collection/components/salla-loyalty-program/salla-reward-details.js +12 -5
  103. package/dist/collection/components/salla-order-edit/helpers.js +181 -0
  104. package/dist/collection/components/salla-order-edit/salla-order-edit-item.css +3 -0
  105. package/dist/collection/components/salla-order-edit/salla-order-edit-item.js +42 -30
  106. package/dist/collection/components/salla-order-edit/salla-order-edit-product-card.css +4 -0
  107. package/dist/collection/components/salla-order-edit/salla-order-edit-product-card.js +93 -0
  108. package/dist/collection/components/salla-order-edit/salla-order-edit.css +3 -0
  109. package/dist/collection/components/salla-order-edit/salla-order-edit.js +353 -39
  110. package/dist/collection/components/salla-order-summary/salla-order-summary.js +1 -1
  111. package/dist/collection/components/salla-payments/salla-payments.js +2 -2
  112. package/dist/collection/components/salla-placeholder/salla-placeholder.js +1 -1
  113. package/dist/collection/components/salla-price-range/salla-price-range.js +2 -2
  114. package/dist/collection/components/salla-product-availability/salla-product-availability.js +1 -1
  115. package/dist/collection/components/salla-product-card/salla-product-card.js +5 -5
  116. package/dist/collection/components/salla-product-options/salla-product-options.js +28 -0
  117. package/dist/collection/components/salla-product-size-guide/salla-product-size-guide.js +2 -2
  118. package/dist/collection/components/salla-products-list/salla-products-list.js +54 -14
  119. package/dist/collection/components/salla-quantity-input/salla-quantity-input.js +1 -1
  120. package/dist/collection/components/salla-quick-buy/salla-quick-buy.js +1 -1
  121. package/dist/collection/components/salla-review-card/salla-review-card.js +1 -1
  122. package/dist/collection/components/salla-reviews/salla-reviews.js +1 -1
  123. package/dist/collection/components/salla-reviews-page/salla-reviews-page.js +1 -1
  124. package/dist/collection/components/salla-scopes/salla-scopes.js +1 -1
  125. package/dist/collection/components/salla-search/salla-search.js +5 -5
  126. package/dist/collection/components/salla-skeleton/salla-skeleton.js +1 -1
  127. package/dist/collection/components/salla-social/salla-social.js +1 -1
  128. package/dist/collection/components/salla-social-share/salla-social-share.js +1 -1
  129. package/dist/collection/components/salla-tabs/salla-tab-content.js +1 -1
  130. package/dist/collection/components/salla-tabs/salla-tab-header.js +1 -1
  131. package/dist/collection/components/salla-tabs/salla-tabs.js +1 -1
  132. package/dist/collection/components/salla-tel-input/salla-tel-input.js +1 -1
  133. package/dist/collection/components/salla-tooltip/salla-tooltip.js +1 -1
  134. package/dist/collection/components/salla-user-settings/salla-user-settings.js +1 -1
  135. package/dist/components/index.js +2 -2
  136. package/dist/components/salla-loyalty-panel.js +5 -3
  137. package/dist/components/salla-loyalty.js +16 -3
  138. package/dist/components/salla-order-edit-item2.js +207 -30
  139. package/dist/components/salla-order-edit-product-card.d.ts +11 -0
  140. package/dist/components/salla-order-edit-product-card.js +59 -0
  141. package/dist/components/salla-order-edit.js +378 -65
  142. package/dist/components/salla-order-summary.js +1 -1
  143. package/dist/components/salla-payments.js +2 -2
  144. package/dist/components/salla-placeholder2.js +1 -1
  145. package/dist/components/salla-price-range2.js +2 -2
  146. package/dist/components/salla-product-availability2.js +1 -1
  147. package/dist/components/salla-product-card2.js +5 -5
  148. package/dist/components/salla-product-options2.js +8 -1
  149. package/dist/components/salla-product-size-guide.js +2 -2
  150. package/dist/components/salla-products-list2.js +39 -15
  151. package/dist/components/salla-quantity-input2.js +1 -1
  152. package/dist/components/salla-quick-buy2.js +1 -1
  153. package/dist/components/salla-review-card2.js +1 -1
  154. package/dist/components/salla-reviews-page.js +1 -1
  155. package/dist/components/salla-reviews.js +1 -1
  156. package/dist/components/salla-reward-details2.js +12 -5
  157. package/dist/components/salla-scopes.js +1 -1
  158. package/dist/components/salla-search.js +5 -5
  159. package/dist/components/salla-skeleton2.js +1 -1
  160. package/dist/components/salla-social-share.js +1 -1
  161. package/dist/components/salla-social.js +1 -1
  162. package/dist/components/salla-tab-content2.js +1 -1
  163. package/dist/components/salla-tab-header2.js +1 -1
  164. package/dist/components/salla-tabs2.js +1 -1
  165. package/dist/components/salla-tel-input2.js +1 -1
  166. package/dist/components/salla-tooltip2.js +1 -1
  167. package/dist/components/salla-user-settings.js +1 -1
  168. package/dist/esm/{filepond-BaqNYv3C.js → filepond-DcrhDD5e.js} +1 -1
  169. package/dist/esm/{filepond-plugin-file-poster-nENZqIRv.js → filepond-plugin-file-poster-meDD1pU1.js} +1 -1
  170. package/dist/esm/{filepond-plugin-file-validate-size-DGOq4RG8.js → filepond-plugin-file-validate-size-Ta6h96xm.js} +1 -1
  171. package/dist/esm/{filepond-plugin-file-validate-type-DwM-3UO7.js → filepond-plugin-file-validate-type-PVDX_x_z.js} +1 -1
  172. package/dist/esm/{filepond-plugin-image-edit-BCqDiFWK.js → filepond-plugin-image-edit-BR1HO3-K.js} +1 -1
  173. package/dist/esm/{filepond-plugin-image-exif-orientation-DiuxhjrQ.js → filepond-plugin-image-exif-orientation-CEWqrOc9.js} +1 -1
  174. package/dist/esm/{filepond-plugin-image-preview-DbFvPPQQ.js → filepond-plugin-image-preview-6ACW1Nfe.js} +1 -1
  175. package/dist/esm/{functions-JPNAXx4d.js → functions-DqpTrGHa.js} +1 -1
  176. package/dist/esm/helpers-DR_vlSvU.js +184 -0
  177. package/dist/esm/{index-DElBWCVR.js → index-COvJOSNr.js} +1 -1
  178. package/dist/esm/{index-BwsreBbG.js → index-Cb4NFvMH.js} +10 -6
  179. package/dist/esm/interfaces-CoQJOPRz.js +33 -0
  180. package/dist/esm/loader.js +3 -3
  181. package/dist/esm/salla-accordion-body_2.entry.js +1 -1
  182. package/dist/esm/salla-accordion_6.entry.js +1 -1
  183. package/dist/esm/salla-add-product-button_5.entry.js +10 -32
  184. package/dist/esm/salla-advertisement.entry.js +1 -1
  185. package/dist/esm/salla-alert_2.entry.js +1 -1
  186. package/dist/esm/salla-app-install-alert.entry.js +1 -1
  187. package/dist/esm/salla-apps-icons.entry.js +1 -1
  188. package/dist/esm/salla-badge.entry.js +1 -1
  189. package/dist/esm/salla-booking-field_7.entry.js +12 -12
  190. package/dist/esm/salla-bullet-delivery.entry.js +1 -1
  191. package/dist/esm/salla-cart-coupons.entry.js +1 -1
  192. package/dist/esm/salla-cart-item-offers_2.entry.js +1 -1
  193. package/dist/esm/salla-comment-form_8.entry.js +4 -4
  194. package/dist/esm/salla-conditional-offer.entry.js +1 -1
  195. package/dist/esm/salla-contacts.entry.js +1 -1
  196. package/dist/esm/salla-cookies-bar.entry.js +1 -1
  197. package/dist/esm/salla-count-down.entry.js +1 -1
  198. package/dist/esm/salla-custom-fields.entry.js +1 -1
  199. package/dist/esm/salla-delivery-promise.entry.js +1 -1
  200. package/dist/esm/salla-edit-order-button.entry.js +1 -1
  201. package/dist/esm/salla-filters-widget.entry.js +1 -1
  202. package/dist/esm/salla-filters.entry.js +1 -1
  203. package/dist/esm/salla-fulfillment-methods.entry.js +1 -1
  204. package/dist/esm/salla-gifting.entry.js +1 -1
  205. package/dist/esm/salla-hook.entry.js +1 -1
  206. package/dist/esm/salla-infinite-scroll.entry.js +1 -1
  207. package/dist/esm/salla-installment.entry.js +1 -1
  208. package/dist/esm/salla-list-tile.entry.js +1 -1
  209. package/dist/esm/salla-localization-modal.entry.js +1 -1
  210. package/dist/esm/salla-login-modal.entry.js +1 -1
  211. package/dist/esm/salla-loyalty-banner.entry.js +2 -2
  212. package/dist/esm/salla-loyalty-hero_2.entry.js +2 -2
  213. package/dist/esm/salla-loyalty-panel.entry.js +8 -6
  214. package/dist/esm/salla-loyalty-prize-item.entry.js +1 -1
  215. package/dist/esm/salla-loyalty-program.entry.js +3 -3
  216. package/dist/esm/salla-loyalty-reward.entry.js +2 -2
  217. package/dist/esm/salla-loyalty.entry.js +14 -3
  218. package/dist/esm/salla-maintenance-alert.entry.js +1 -1
  219. package/dist/esm/salla-map.entry.js +1 -1
  220. package/dist/esm/salla-menu.entry.js +1 -1
  221. package/dist/esm/salla-metadata.entry.js +1 -1
  222. package/dist/esm/salla-multiple-bundle-product-cart_2.entry.js +1 -1
  223. package/dist/esm/salla-multiple-bundle-product-options-modal_2.entry.js +1 -1
  224. package/dist/esm/salla-multiple-bundle-product.entry.js +1 -1
  225. package/dist/esm/salla-notification-item.entry.js +1 -1
  226. package/dist/esm/salla-notifications.entry.js +1 -1
  227. package/dist/esm/salla-offer-modal.entry.js +1 -1
  228. package/dist/esm/salla-offer.entry.js +1 -1
  229. package/dist/esm/salla-order-details-multiple-bundle-product.entry.js +1 -1
  230. package/dist/esm/salla-order-details-options.entry.js +1 -1
  231. package/dist/esm/salla-order-details.entry.js +1 -1
  232. package/dist/esm/salla-order-edit-item.entry.js +28 -29
  233. package/dist/esm/salla-order-edit-product-card.entry.js +39 -0
  234. package/dist/esm/salla-order-edit.entry.js +339 -40
  235. package/dist/esm/salla-order-summary.entry.js +2 -2
  236. package/dist/esm/salla-order-totals-card.entry.js +1 -1
  237. package/dist/esm/salla-orders.entry.js +1 -1
  238. package/dist/esm/salla-payments.entry.js +3 -3
  239. package/dist/esm/salla-placeholder.entry.js +2 -2
  240. package/dist/esm/salla-price-range.entry.js +3 -3
  241. package/dist/esm/salla-product-card_2.entry.js +6 -6
  242. package/dist/esm/salla-product-size-guide.entry.js +3 -3
  243. package/dist/esm/salla-products-list.entry.js +38 -15
  244. package/dist/esm/salla-progress-bar.entry.js +1 -1
  245. package/dist/esm/salla-quick-order.entry.js +1 -1
  246. package/dist/esm/salla-rating-modal.entry.js +1 -1
  247. package/dist/esm/salla-reward-action_4.entry.js +15 -8
  248. package/dist/esm/salla-scopes.entry.js +2 -2
  249. package/dist/esm/salla-search.entry.js +6 -6
  250. package/dist/esm/salla-skeleton.entry.js +2 -2
  251. package/dist/esm/salla-slider.entry.js +1 -1
  252. package/dist/esm/salla-social-share.entry.js +2 -2
  253. package/dist/esm/salla-social.entry.js +2 -2
  254. package/dist/esm/salla-tab-content_3.entry.js +4 -4
  255. package/dist/esm/salla-tiered-offer.entry.js +1 -1
  256. package/dist/esm/salla-tooltip.entry.js +2 -2
  257. package/dist/esm/salla-trust-badges.entry.js +1 -1
  258. package/dist/esm/salla-user-menu.entry.js +1 -1
  259. package/dist/esm/salla-user-profile.entry.js +1 -1
  260. package/dist/esm/salla-user-settings.entry.js +2 -2
  261. package/dist/esm/salla-verify.entry.js +1 -1
  262. package/dist/esm/salla-wallet.entry.js +1 -1
  263. package/dist/esm/{tracked-promise-BD-FZk2P.js → tracked-promise-Dl5Y2VO1.js} +1 -1
  264. package/dist/esm/twilight.js +3 -3
  265. package/dist/esm/{vanilla-picker-CqoFxJJE.js → vanilla-picker-CuBrX87l.js} +1 -1
  266. package/dist/twilight/p-03c91b77.entry.js +4 -0
  267. package/dist/twilight/{p-af84c7b8.entry.js → p-0bb36191.entry.js} +1 -1
  268. package/dist/twilight/{p-a3a0bafa.entry.js → p-0c0df6f7.entry.js} +1 -1
  269. package/dist/twilight/p-142ed3d7.entry.js +4 -0
  270. package/dist/twilight/{p-CbukOCNI.js → p-14uV0Dqq.js} +1 -1
  271. package/dist/twilight/{p-46088f51.entry.js → p-15c3ec6b.entry.js} +1 -1
  272. package/dist/twilight/{p-7d3722ad.entry.js → p-15f015b1.entry.js} +1 -1
  273. package/dist/twilight/{p-ce588635.entry.js → p-213cee5f.entry.js} +1 -1
  274. package/dist/twilight/{p-c5e18341.entry.js → p-2726ea01.entry.js} +1 -1
  275. package/dist/twilight/{p-57451f00.entry.js → p-28208f79.entry.js} +1 -1
  276. package/dist/twilight/{p-b6dce61a.entry.js → p-293fa7ae.entry.js} +1 -1
  277. package/dist/twilight/{p-993bdcbe.entry.js → p-29f8baaa.entry.js} +1 -1
  278. package/dist/twilight/{p-60878c2e.entry.js → p-324dc99a.entry.js} +1 -1
  279. package/dist/twilight/p-3383da76.entry.js +4 -0
  280. package/dist/twilight/{p-d9c4d2ed.entry.js → p-38ae0da1.entry.js} +1 -1
  281. package/dist/twilight/{p-0a786447.entry.js → p-3bd864fe.entry.js} +1 -1
  282. package/dist/twilight/p-3e6f7773.entry.js +4 -0
  283. package/dist/twilight/p-408ed55f.entry.js +4 -0
  284. package/dist/twilight/{p-695e3211.entry.js → p-40a41577.entry.js} +1 -1
  285. package/dist/twilight/{p-aaff5603.entry.js → p-4105a9cd.entry.js} +1 -1
  286. package/dist/twilight/{p-91d74168.entry.js → p-45f138dd.entry.js} +1 -1
  287. package/dist/twilight/{p-0654ccca.entry.js → p-4a788634.entry.js} +1 -1
  288. package/dist/twilight/{p-ad762138.entry.js → p-4c3d17a1.entry.js} +1 -1
  289. package/dist/twilight/{p-4c57de7b.entry.js → p-52f5ccfe.entry.js} +1 -1
  290. package/dist/twilight/p-59a083e4.entry.js +4 -0
  291. package/dist/twilight/{p-1c1ac203.entry.js → p-5b7970ef.entry.js} +1 -1
  292. package/dist/twilight/{p-ab5e0aef.entry.js → p-5e62a40f.entry.js} +1 -1
  293. package/dist/twilight/{p-b9c9c487.entry.js → p-5fbf4640.entry.js} +1 -1
  294. package/dist/twilight/{p-9c73e42a.entry.js → p-6135ad16.entry.js} +1 -1
  295. package/dist/twilight/{p-2f833767.entry.js → p-628a8e24.entry.js} +1 -1
  296. package/dist/twilight/{p-167f5262.entry.js → p-65c18d39.entry.js} +1 -1
  297. package/dist/twilight/{p-ff90dbf0.entry.js → p-686eecd6.entry.js} +1 -1
  298. package/dist/twilight/{p-fec6b08b.entry.js → p-68f21f26.entry.js} +1 -1
  299. package/dist/twilight/{p-3f50a52d.entry.js → p-691c3a17.entry.js} +1 -1
  300. package/dist/twilight/{p-9134d94d.entry.js → p-6cb4a60b.entry.js} +1 -1
  301. package/dist/twilight/{p-44db7163.entry.js → p-6f2edfae.entry.js} +1 -1
  302. package/dist/twilight/{p-edaba475.entry.js → p-6fb7d4f8.entry.js} +1 -1
  303. package/dist/twilight/{p-dcc65eb2.entry.js → p-72e169bd.entry.js} +1 -1
  304. package/dist/twilight/{p-681953ef.entry.js → p-73ba81cc.entry.js} +1 -1
  305. package/dist/twilight/{p-f88806d7.entry.js → p-7444a1ed.entry.js} +1 -1
  306. package/dist/twilight/{p-10884e6e.entry.js → p-752f162a.entry.js} +1 -1
  307. package/dist/twilight/{p-b737dbcb.entry.js → p-772b766c.entry.js} +1 -1
  308. package/dist/twilight/{p-03c39b2d.entry.js → p-774461b2.entry.js} +1 -1
  309. package/dist/twilight/p-7cba634a.entry.js +4 -0
  310. package/dist/twilight/p-7d37007a.entry.js +4 -0
  311. package/dist/twilight/{p-2bd83486.entry.js → p-7e47c403.entry.js} +1 -1
  312. package/dist/twilight/{p-ac008da7.entry.js → p-7ec0ac91.entry.js} +1 -1
  313. package/dist/twilight/{p-57e0b11b.entry.js → p-825cc1f7.entry.js} +1 -1
  314. package/dist/twilight/{p-f73c7b43.entry.js → p-85a15cc1.entry.js} +1 -1
  315. package/dist/twilight/p-8e96221d.entry.js +4 -0
  316. package/dist/twilight/{p-5ac81ffe.entry.js → p-95f3620c.entry.js} +1 -1
  317. package/dist/twilight/{p-29fc145b.entry.js → p-95ff1eb1.entry.js} +1 -1
  318. package/dist/twilight/{p-cd6fc43c.entry.js → p-96343e93.entry.js} +1 -1
  319. package/dist/twilight/{p-a00015ec.entry.js → p-96b64fd6.entry.js} +1 -1
  320. package/dist/twilight/{p-580441f5.entry.js → p-9a6dfcde.entry.js} +1 -1
  321. package/dist/twilight/{p-f653f2bb.entry.js → p-9b865b2c.entry.js} +1 -1
  322. package/dist/twilight/{p-5b371b1f.entry.js → p-9ba89557.entry.js} +1 -1
  323. package/dist/twilight/{p-Dw7mGaHj.js → p-B9znPMU0.js} +1 -1
  324. package/dist/twilight/{p-Cw0Ky-u0.js → p-BCTUg3S2.js} +1 -1
  325. package/dist/twilight/{p-LWKLIOwS.js → p-BII4XUuF.js} +1 -1
  326. package/dist/twilight/{p-GgHo6Cr_.js → p-BIai7zYt.js} +1 -1
  327. package/dist/twilight/p-C8xwacGT.js +4 -0
  328. package/dist/twilight/{p-DPgASjJ8.js → p-CBJQc5Lg.js} +1 -1
  329. package/dist/twilight/{p-BwsreBbG.js → p-Cb4NFvMH.js} +1 -1
  330. package/dist/twilight/{p-BuNOvMeU.js → p-Ch9nMk63.js} +1 -1
  331. package/dist/twilight/p-CoQJOPRz.js +4 -0
  332. package/dist/twilight/{p-CEuTw3-D.js → p-DQjeyM6u.js} +1 -1
  333. package/dist/twilight/{p-DlGhggDp.js → p-DXTkDRjS.js} +1 -1
  334. package/dist/twilight/{p-f-qXMnue.js → p-DvkL8Ozv.js} +1 -1
  335. package/dist/twilight/{p-4807586a.entry.js → p-acf5c683.entry.js} +1 -1
  336. package/dist/twilight/{p-9d8e4e7c.entry.js → p-aec7b53d.entry.js} +1 -1
  337. package/dist/twilight/{p-e5325563.entry.js → p-b495fd3a.entry.js} +1 -1
  338. package/dist/twilight/{p-d739ae41.entry.js → p-b5b0d57a.entry.js} +1 -1
  339. package/dist/twilight/{p-d0cf9b68.entry.js → p-b8d87ece.entry.js} +1 -1
  340. package/dist/twilight/{p-af1474dd.entry.js → p-bc8070a0.entry.js} +1 -1
  341. package/dist/twilight/{p-19e82de2.entry.js → p-befbbd96.entry.js} +1 -1
  342. package/dist/twilight/{p-b9062150.entry.js → p-c4c7efc7.entry.js} +1 -1
  343. package/dist/twilight/{p-7d492d3c.entry.js → p-c4f7d697.entry.js} +1 -1
  344. package/dist/twilight/{p-b6ac7a22.entry.js → p-cb70fe7f.entry.js} +1 -1
  345. package/dist/twilight/{p-0bf11f89.entry.js → p-d4b7ef45.entry.js} +1 -1
  346. package/dist/twilight/{p-fbe07d2d.entry.js → p-d4d61e9d.entry.js} +1 -1
  347. package/dist/twilight/{p-59657a19.entry.js → p-d6cfb7cf.entry.js} +1 -1
  348. package/dist/twilight/p-dfad4e49.entry.js +4 -0
  349. package/dist/twilight/{p-4edf67be.entry.js → p-e30f5be9.entry.js} +1 -1
  350. package/dist/twilight/{p-d469525b.entry.js → p-e64af075.entry.js} +1 -1
  351. package/dist/twilight/{p-c1d4db6f.entry.js → p-e7fd1dab.entry.js} +1 -1
  352. package/dist/twilight/{p-ceb9458e.entry.js → p-e85f1f4a.entry.js} +1 -1
  353. package/dist/twilight/{p-201926a3.entry.js → p-e9251839.entry.js} +1 -1
  354. package/dist/twilight/{p-1c3e0dbc.entry.js → p-e94f7e62.entry.js} +1 -1
  355. package/dist/twilight/p-ebc19788.entry.js +4 -0
  356. package/dist/twilight/{p-b4fd50ef.entry.js → p-f6bc9645.entry.js} +1 -1
  357. package/dist/twilight/p-f6da3fad.entry.js +4 -0
  358. package/dist/twilight/{p-a96ec635.entry.js → p-fbfa12cf.entry.js} +1 -1
  359. package/dist/twilight/{p-069485ec.entry.js → p-fca860eb.entry.js} +1 -1
  360. package/dist/twilight/{p-61215f22.entry.js → p-fd4eec62.entry.js} +1 -1
  361. package/dist/twilight/{p-CTyl0UJE.js → p-pyjmoRFm.js} +1 -1
  362. package/dist/twilight/twilight.esm.js +1 -1
  363. package/dist/types/components/salla-loyalty/salla-loyalty.d.ts +3 -0
  364. package/dist/types/components/salla-order-edit/helpers.d.ts +25 -0
  365. package/dist/types/components/salla-order-edit/interfaces.d.ts +22 -25
  366. package/dist/types/components/salla-order-edit/salla-order-edit-item.d.ts +7 -5
  367. package/dist/types/components/salla-order-edit/salla-order-edit-product-card.d.ts +11 -0
  368. package/dist/types/components/salla-order-edit/salla-order-edit.d.ts +56 -4
  369. package/dist/types/components/salla-product-options/salla-product-options.d.ts +4 -0
  370. package/dist/types/components/salla-products-list/salla-products-list.d.ts +5 -0
  371. package/dist/types/components.d.ts +51 -4
  372. package/package.json +5 -5
  373. package/dist/twilight/p-25104b13.entry.js +0 -4
  374. package/dist/twilight/p-36048354.entry.js +0 -4
  375. package/dist/twilight/p-4110e600.entry.js +0 -4
  376. package/dist/twilight/p-60d875cc.entry.js +0 -4
  377. package/dist/twilight/p-7a33e83b.entry.js +0 -4
  378. package/dist/twilight/p-86cfa253.entry.js +0 -4
  379. package/dist/twilight/p-c0b690b2.entry.js +0 -4
  380. package/dist/twilight/p-c968dab0.entry.js +0 -4
  381. package/dist/twilight/p-e07f938a.entry.js +0 -4
  382. package/dist/twilight/p-f2815da9.entry.js +0 -4
  383. package/dist/twilight/p-f7b21078.entry.js +0 -4
@@ -84,17 +84,19 @@ const SallaLoyaltyPanel$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyaltyP
84
84
  render() {
85
85
  const prizesGroups = this.program.data.prizes;
86
86
  const prizesCount = this.program.data.prizes_count;
87
- const isLoadingPoints = this.points.status === 'pending' && this.points.data === null && !this.customerPoints;
88
- const customerPoints = isLoadingPoints ? '---' : (this.points.data ?? this.customerPoints ?? 0);
87
+ const customerPoints = (this.points.data ?? this.customerPoints ?? 0);
89
88
  if (this.prizeTitle && this.prizePoints) {
90
89
  return (h("div", { class: "s-loyalty-program-panel-exchange-wrapper" }, h("salla-list-tile", { class: "s-loyalty-program-after-exchange" }, h("div", { slot: "title", class: "s-loyalty-program-after-exchange-title" }, this.prizeTitle, " \u00A0 - \u00A0 ", this.prizePoints, " ", salla.lang.get('pages.loyalty_program.point')), h("div", { slot: "action", class: "s-loyalty-program-after-exchange-action" }, h("salla-button", { class: "s-loyalty-program-after-exchange-reset", shape: "icon", fill: 'outline', color: "danger", size: "small", onClick: () => salla.loyalty.reset() }, h("span", { innerHTML: Cancel }))))));
91
90
  }
91
+ if (!customerPoints || customerPoints === 0) {
92
+ return null;
93
+ }
92
94
  return (h("div", { class: "" }, h("div", { class: "s-loyalty-program-panel-exchange-wrapper" }, h("salla-list-tile", { class: 's-loyalty-program-panel-widget' }, h("div", { slot: "icon", class: "s-loyalty-program-panel-widget-icon", innerHTML: Rate }), h("div", { slot: "subtitle" }, salla.lang.get('pages.loyalty_program.cart_total_point_summary', { "balance": customerPoints }), h("salla-button", { shape: "link", color: "primary", onClick: () => {
93
95
  if (['error', 'idle'].includes(this.program.status)) {
94
96
  this.program();
95
97
  }
96
98
  this.rewardsModal.open();
97
- } }, customerPoints !== '---' && customerPoints ? salla.lang.get('pages.loyalty_program.cart_point_exchange_now') : salla.lang.get('blocks.header.login'))))), h("salla-modal", { id: "loyalty-rewards-modal", isLoading: this.program.status === 'pending', ref: modal => this.rewardsModal = modal, class: "s-loyalty-program-rewards-cart s-loyalty-program-modal", width: "lg", noPadding: true }, h("div", { slot: "loading" }, h("salla-loading", null)), this.program.status === 'success' ? h("div", { class: "s-loyalty-program-rewards-container-cart" }, h("div", { class: "s-loyalty-program-rewards-cart-header" }, h("div", { innerHTML: PrizeImage }), h("div", { class: "s-loyalty-program-panel-content" }, h("h1", null, this.program.data.prize_promotion_title), h("p", null, this.program.data.prize_promotion_description))), h("div", { class: {
99
+ } }, salla.lang.get('pages.loyalty_program.cart_point_exchange_now'))))), h("salla-modal", { id: "loyalty-rewards-modal", isLoading: this.program.status === 'pending', ref: modal => this.rewardsModal = modal, class: "s-loyalty-program-rewards-cart s-loyalty-program-modal", width: "lg", noPadding: true }, h("div", { slot: "loading" }, h("salla-loading", null)), this.program.status === 'success' ? h("div", { class: "s-loyalty-program-rewards-container-cart" }, h("div", { class: "s-loyalty-program-rewards-cart-header" }, h("div", { innerHTML: PrizeImage }), h("div", { class: "s-loyalty-program-panel-content" }, h("h1", null, this.program.data.prize_promotion_title), h("p", null, this.program.data.prize_promotion_description))), h("div", { class: {
98
100
  's-loyalty-program-slider-arrows': true,
99
101
  's-loyalty-program-tabs-hider': prizesGroups.length < 2 || prizesCount < 2,
100
102
  } }, h("salla-tabs", null, prizesGroups.map((group) => (h("salla-tab-header", { slot: "header", name: group.type }, sicons[group.type], h("span", null, group.title)))), prizesGroups.map((group) => (h("salla-tab-content", { slot: "content", name: group.type }, h("salla-slider", { id: group.type, type: "default", "slider-config": '{"loop":false,"slidesPerView":"auto","freeMode":true,"spaceBetween":12,"breakpoints":{"768":{"slidesPerView":3,"spaceBetween":24,"freeMode":false,"speed":300}}}' }, h("div", { slot: "items" }, group.items.map((prize) => h("salla-reward-card", { prize: prize, onAreaClick: () => {
@@ -73,6 +73,8 @@ const SallaLoyalty$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyalty exten
73
73
  constructor() {
74
74
  super();
75
75
  this.__registerHost();
76
+ this.activeTabType = '';
77
+ this.tabsKey = 0;
76
78
  this.selectedItem = undefined;
77
79
  /**
78
80
  * Does the merchant allow to login using email
@@ -103,6 +105,11 @@ const SallaLoyalty$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyalty exten
103
105
  this.customerPoints = cart.loyalty.customer_points || this.customerPoints;
104
106
  });
105
107
  }
108
+ onTabSelected(event) {
109
+ const prize = this.loyaltyProgram?.prizes.find(p => p.title === event.detail?.name);
110
+ if (prize)
111
+ this.activeTabType = prize.type;
112
+ }
106
113
  setSelectedPrizeItem(item) {
107
114
  if (!this.selectedItem || this.selectedItem?.id != item.id) {
108
115
  this.selectedItem = item;
@@ -143,6 +150,8 @@ const SallaLoyalty$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyalty exten
143
150
  return await salla.loyalty.getProgram()
144
151
  .then(response => {
145
152
  this.loyaltyProgram = response.data;
153
+ this.activeTabType = this.loyaltyProgram.prizes[0]?.type || '';
154
+ this.tabsKey++;
146
155
  })
147
156
  .catch(e => {
148
157
  this.hasError = true;
@@ -208,8 +217,10 @@ const SallaLoyalty$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyalty exten
208
217
  h("salla-modal", { isLoading: true, "has-skeleton": true, width: "md", ref: modal => this.modal = modal }, h("div", { slot: "loading" }, h("div", { class: "s-loyalty-skeleton" }, h("salla-list-tile", { class: "s-loyalty-header" }, h("div", { slot: "icon", class: "s-loyalty-header-icon" }, h("salla-skeleton", { type: "circle", height: '6rem', width: '6rem' })), h("div", { slot: "title", class: "s-loyalty-header-title mb-5" }, h("salla-skeleton", { height: '15px', width: '50%' })), h("div", { slot: "subtitle", class: "s-loyalty-header-subtitle" }, h("salla-skeleton", { height: '10px' }), h("salla-skeleton", { height: '10px', width: '75%' }))), h("div", { class: "s-loyalty-skeleton-cards" }, [...Array(3)].map(() => h("div", { class: "s-loyalty-prize-item swiper-slide" }, h("salla-skeleton", { height: '9rem' }), h("div", { class: "s-loyalty-prize-item-title" }, h("salla-skeleton", { height: '15px', width: '75%' })), h("div", { class: "s-loyalty-prize-item-subtitle" }, h("salla-skeleton", { height: '10px', width: '50%' }), h("salla-skeleton", { height: '10px', width: '25%' })), h("div", { class: "s-loyalty-prize-item-points" }, h("salla-skeleton", { height: '15px', width: '100px' }), h("div", { class: "s-loyalty-prize-item-check" }, h("salla-skeleton", { height: '1rem', width: '1rem', type: 'circle' })))))))), !this.hasError && !!this.loyaltyProgram ?
209
218
  [
210
219
  h("salla-list-tile", { id: 's-loyalty-header', class: "s-loyalty-header" }, h("div", { slot: "icon", class: "s-loyalty-header-icon", innerHTML: GiftImg }), h("div", { slot: "title", class: "s-loyalty-header-title" }, this.loyaltyProgram.prize_promotion_title), h("div", { slot: "subtitle", class: "s-loyalty-header-subtitle" }, this.loyaltyProgram.prize_promotion_description)),
211
- h("salla-tabs", null, this.loyaltyProgram.prizes.map((prize) => h("salla-tab-header", { slot: "header", name: prize.title }, h("span", null, prize.title))), this.loyaltyProgram.prizes.map((prize, index) => h("salla-tab-content", { slot: "content", name: prize.title }, h("salla-slider", { class: "s-loyalty-slider", loop: false, "controls-outer": true, id: 'loyalty-popup-slider-' + index, type: "carousel" }, h("div", { slot: 'items' }, prize.items.map((item) => this.prizeItem(item))))))),
212
- h("salla-button", { disabled: !this.selectedItem, width: "wide", class: "s-loyalty-program-redeem-btn", onClick: () => this.openConfirmation() }, salla.lang.get('pages.loyalty_program.exchange_points')),
220
+ h("salla-tabs", { key: this.tabsKey }, this.loyaltyProgram.prizes.map((prize) => h("salla-tab-header", { slot: "header", name: prize.title }, h("span", null, prize.title))), this.loyaltyProgram.prizes.map((prize, index) => h("salla-tab-content", { slot: "content", name: prize.title }, h("salla-slider", { class: "s-loyalty-slider", loop: false, "controls-outer": true, id: 'loyalty-popup-slider-' + index, type: "carousel" }, h("div", { slot: 'items' }, prize.items.map((item) => this.prizeItem(item))))))),
221
+ this.activeTabType?.toUpperCase() === 'FREE_PRODUCT'
222
+ ? h("a", { href: salla.url.get(''), class: "s-loyalty-program-redeem-btn s-button-element s-button-btn s-button-solid s-button-wide s-button-primary s-button-wrap" }, salla.lang.get('pages.loyalty_program.shop_now'))
223
+ : h("salla-button", { disabled: !this.selectedItem, width: "wide", class: "s-loyalty-program-redeem-btn", onClick: () => this.openConfirmation() }, salla.lang.get('pages.loyalty_program.exchange_points')),
213
224
  ]
214
225
  : h("salla-placeholder", { class: "s-loyalty-placeholder", alignment: "center" }, !!this.errorMessage ? h("span", { slot: "description" }, this.errorMessage) : '')),
215
226
  ];
@@ -224,6 +235,8 @@ const SallaLoyalty$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyalty exten
224
235
  "requireEmail": [4, "require-email"],
225
236
  "guestMessage": [1025, "guest-message"],
226
237
  "loyaltyProgram": [32],
238
+ "activeTabType": [32],
239
+ "tabsKey": [32],
227
240
  "buttonLoading": [32],
228
241
  "selectedItem": [32],
229
242
  "askConfirmation": [32],
@@ -235,7 +248,7 @@ const SallaLoyalty$1 = /*@__PURE__*/ proxyCustomElement(class SallaLoyalty exten
235
248
  "close": [64],
236
249
  "resetExchange": [64],
237
250
  "exchangeLoyaltyPoint": [64]
238
- }]);
251
+ }, [[0, "tabSelected", "onTabSelected"]]]);
239
252
  function defineCustomElement$1() {
240
253
  if (typeof customElements === "undefined") {
241
254
  return;
@@ -2,6 +2,7 @@
2
2
  * Crafted with ❤ by Salla
3
3
  */
4
4
  import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
5
+ import { D as DisplayType, d as defineCustomElement$3 } from './salla-product-options2.js';
5
6
  import { d as defineCustomElement$c } from './salla-booking-field2.js';
6
7
  import { d as defineCustomElement$b } from './salla-button2.js';
7
8
  import { d as defineCustomElement$a } from './salla-color-picker2.js';
@@ -11,11 +12,188 @@ import { d as defineCustomElement$7 } from './salla-file-upload2.js';
11
12
  import { d as defineCustomElement$6 } from './salla-loading2.js';
12
13
  import { d as defineCustomElement$5 } from './salla-map2.js';
13
14
  import { d as defineCustomElement$4 } from './salla-modal2.js';
14
- import { d as defineCustomElement$3 } from './salla-product-options2.js';
15
15
  import { d as defineCustomElement$2 } from './salla-progress-bar2.js';
16
16
  import { d as defineCustomElement$1 } from './salla-quantity-input2.js';
17
17
 
18
- const sallaOrderEditItemCss = "";
18
+ let addedOrderItemCounter = 0;
19
+ function generateAddedOrderItemId(productId) {
20
+ const cryptoRef = (typeof globalThis !== 'undefined' ? globalThis.crypto : undefined);
21
+ if (cryptoRef && typeof cryptoRef.randomUUID === 'function') {
22
+ return `new-${productId}-${cryptoRef.randomUUID()}`;
23
+ }
24
+ addedOrderItemCounter += 1;
25
+ return `new-${productId}-${Date.now()}-${addedOrderItemCounter}`;
26
+ }
27
+ function cloneOrderEditProduct(product) {
28
+ if (product == null) {
29
+ return product;
30
+ }
31
+ return typeof structuredClone === 'function'
32
+ ? structuredClone(product)
33
+ : JSON.parse(JSON.stringify(product));
34
+ }
35
+ function buildSavePayload(payload) {
36
+ return {
37
+ items: {
38
+ update: payload.items.update,
39
+ remove: payload.items.remove,
40
+ add: payload.items.add.map(({ itemId, ...addItem }) => addItem),
41
+ },
42
+ };
43
+ }
44
+ function createAddedOrderItem(product, quantity, optionDefinitions, selectedOptions = {}) {
45
+ const productData = cloneOrderEditProduct(product);
46
+ return {
47
+ id: generateAddedOrderItemId(product.id),
48
+ quantity,
49
+ isNew: true,
50
+ selectedOptions,
51
+ product: {
52
+ ...productData,
53
+ options: cloneOrderEditProduct(optionDefinitions),
54
+ },
55
+ };
56
+ }
57
+ function normalizeOrderEditOptionValue(value) {
58
+ if (typeof File !== 'undefined' && value instanceof File) {
59
+ return value.name;
60
+ }
61
+ return String(value);
62
+ }
63
+ function normalizeSelectedOptions(selectedOptions = {}) {
64
+ return JSON.stringify(Object.entries(selectedOptions)
65
+ .filter(([, value]) => value != null && normalizeOrderEditOptionValue(value).length > 0)
66
+ .map(([optionId, value]) => [String(optionId), normalizeOrderEditOptionValue(value)])
67
+ .sort(([leftId], [rightId]) => leftId.localeCompare(rightId)));
68
+ }
69
+ function hasSelectedOptions(selectedOptions) {
70
+ return Boolean(selectedOptions &&
71
+ Object.values(selectedOptions).some(value => value != null && normalizeOrderEditOptionValue(value).length > 0));
72
+ }
73
+ const detailIdOptionTypes = new Set([
74
+ DisplayType.COLOR,
75
+ DisplayType.COUNTRY,
76
+ DisplayType.DIGITAL_CARD_VALUE,
77
+ DisplayType.MULTIPLE_OPTIONS,
78
+ DisplayType.RADIO,
79
+ DisplayType.SINGLE_OPTION,
80
+ DisplayType.THUMBNAIL,
81
+ ]);
82
+ function getProductOptionSelectedOptions(options = []) {
83
+ return options.reduce((acc, option) => {
84
+ if (option?.id == null) {
85
+ return acc;
86
+ }
87
+ const selectedDetails = option.details?.filter(detail => detail?.is_selected) || [];
88
+ const selectedDetail = selectedDetails[selectedDetails.length - 1];
89
+ const value = selectedDetail?.id ?? option.value;
90
+ if (value == null || String(value).length === 0) {
91
+ return acc;
92
+ }
93
+ acc[String(option.id)] = String(value);
94
+ return acc;
95
+ }, {});
96
+ }
97
+ function getOrderDetailSelectedOptionValue(item, optionId, value) {
98
+ const productOption = item?.product?.options?.find(option => String(option.id) === String(optionId));
99
+ const normalizedValue = String(value);
100
+ if (!productOption?.details?.length || !detailIdOptionTypes.has(productOption.type)) {
101
+ return normalizedValue;
102
+ }
103
+ const selectedDetail = productOption.details.find(detail => [
104
+ detail.id,
105
+ detail.name,
106
+ detail.option_value,
107
+ detail.color,
108
+ detail.image,
109
+ detail.code,
110
+ detail.display_value,
111
+ ].some(detailValue => detailValue != null && String(detailValue) === normalizedValue));
112
+ return selectedDetail ? String(selectedDetail.id) : normalizedValue;
113
+ }
114
+ function getOrderDetailsSelectedOptions(item) {
115
+ return (item?.options || []).reduce((acc, option) => {
116
+ if (option?.id == null) {
117
+ return acc;
118
+ }
119
+ const value = option.value ?? option.display_value;
120
+ if (value == null || String(value).length === 0) {
121
+ return acc;
122
+ }
123
+ acc[String(option.id)] = getOrderDetailSelectedOptionValue(item, option.id, value);
124
+ return acc;
125
+ }, {});
126
+ }
127
+ function getOrderItemSelectedOptions(item) {
128
+ if (hasSelectedOptions(item?.selectedOptions)) {
129
+ return item.selectedOptions;
130
+ }
131
+ const productSelectedOptions = getProductOptionSelectedOptions(item?.product?.options);
132
+ if (hasSelectedOptions(productSelectedOptions)) {
133
+ return productSelectedOptions;
134
+ }
135
+ return getOrderDetailsSelectedOptions(item);
136
+ }
137
+ function findMergeableItem(items = [], productId, selectedOptions = {}) {
138
+ const targetSelectedOptions = normalizeSelectedOptions(selectedOptions);
139
+ return items.find(item => String(item.product?.id) === String(productId) &&
140
+ normalizeSelectedOptions(getOrderItemSelectedOptions(item)) === targetSelectedOptions);
141
+ }
142
+ function getOrderEditProductMaxQuantity(product) {
143
+ const rawQuantity = product?.max_quantity ?? product?.max_quantity_per_order;
144
+ const parsedQuantity = Number(rawQuantity);
145
+ return Number.isFinite(parsedQuantity) && parsedQuantity > 0 ? parsedQuantity : undefined;
146
+ }
147
+ function clampOrderEditQuantity(quantity, maxQuantity) {
148
+ if (!Number.isFinite(quantity) || quantity < 1) {
149
+ return 1;
150
+ }
151
+ if (maxQuantity && quantity > maxQuantity) {
152
+ return maxQuantity;
153
+ }
154
+ return quantity;
155
+ }
156
+ function patchOrderItem(item, quantity, optionDefinitions, selectedOptions) {
157
+ return {
158
+ ...item,
159
+ quantity,
160
+ selectedOptions: selectedOptions ?? getOrderItemSelectedOptions(item),
161
+ product: item.product
162
+ ? {
163
+ ...item.product,
164
+ options: optionDefinitions ?? item.product.options,
165
+ }
166
+ : item.product,
167
+ };
168
+ }
169
+ function updateOrderItems(items = [], itemId, quantity, optionDefinitions, selectedOptions) {
170
+ return items.map(item => item.id === itemId ? patchOrderItem(item, quantity, optionDefinitions, selectedOptions) : item);
171
+ }
172
+ function removeOrderItems(items = [], itemId) {
173
+ return items.filter(item => item.id !== itemId);
174
+ }
175
+ function mergePayloadItems(items, patch) {
176
+ return {
177
+ ...items,
178
+ ...patch,
179
+ };
180
+ }
181
+ function upsertPayloadUpdateList(updateList = [], itemId, quantity, options = {}) {
182
+ const nextUpdateList = updateList.filter(item => item.id !== itemId);
183
+ nextUpdateList.push({ id: itemId, quantity, options });
184
+ return nextUpdateList;
185
+ }
186
+ function updateAddedPayloadList(addList = [], itemId, quantity, options) {
187
+ return addList.map(item => item.itemId === itemId
188
+ ? {
189
+ ...item,
190
+ quantity,
191
+ options: options ?? item.options,
192
+ }
193
+ : item);
194
+ }
195
+
196
+ const sallaOrderEditItemCss = ":host{display:block}";
19
197
 
20
198
  const SallaOrderEditItem = /*@__PURE__*/ proxyCustomElement(class SallaOrderEditItem extends HTMLElement {
21
199
  constructor() {
@@ -23,6 +201,8 @@ const SallaOrderEditItem = /*@__PURE__*/ proxyCustomElement(class SallaOrderEdit
23
201
  this.__registerHost();
24
202
  this.orderItemUpdated = createEvent(this, "orderItemUpdated", 7);
25
203
  this.orderItemRemoved = createEvent(this, "orderItemRemoved", 7);
204
+ this.quantityInput = null;
205
+ this.productOptions = null;
26
206
  this.handleQuantityChange = (event) => {
27
207
  const detail = event.detail;
28
208
  const newQuantity = detail?.quantity ?? parseInt(event.target.value, 10);
@@ -40,38 +220,30 @@ const SallaOrderEditItem = /*@__PURE__*/ proxyCustomElement(class SallaOrderEdit
40
220
  componentWillLoad() {
41
221
  this.quantity = this.item?.quantity || 1;
42
222
  }
43
- componentDidLoad() {
44
- const quantityEl = this.host.querySelector('salla-quantity-input');
45
- if (quantityEl) {
46
- quantityEl.addEventListener('change', this.handleQuantityChange);
47
- }
48
- const optionsEl = this.host.querySelector('salla-product-options');
49
- if (optionsEl) {
50
- optionsEl.addEventListener('change', this.handleOptionsChange);
51
- }
52
- }
53
- disconnectedCallback() {
54
- const quantityEl = this.host.querySelector('salla-quantity-input');
55
- if (quantityEl) {
56
- quantityEl.removeEventListener('change', this.handleQuantityChange);
57
- }
58
- const optionsEl = this.host.querySelector('salla-product-options');
59
- if (optionsEl) {
60
- optionsEl.removeEventListener('change', this.handleOptionsChange);
61
- }
223
+ handleItemChange(newItem) {
224
+ const newQuantity = newItem?.quantity || 1;
225
+ if (newQuantity === this.quantity)
226
+ return;
227
+ this.quantity = newQuantity;
228
+ this.quantityInput?.setValue?.(newQuantity, false);
62
229
  }
63
230
  get hasOptions() {
64
- const options = this.item.product?.options;
65
- return options && options.length > 0;
231
+ return (this.item.product?.options?.length || 0) > 0;
66
232
  }
67
233
  async getSelectedOptions() {
68
- const optionsEl = this.host.querySelector(`salla-product-options[product-id="${this.item.product?.id}"]`);
69
- return (await optionsEl?.getSelectedOptionsData()) || {};
234
+ return (await this.productOptions?.getSelectedOptionsData?.()) || {};
235
+ }
236
+ async getOptionsData() {
237
+ return (await this.productOptions?.getOptionsData?.()) || this.item.product?.options || [];
70
238
  }
71
239
  async emitUpdate(quantity) {
72
- const detail = { itemId: this.item?.id, quantity };
240
+ const itemId = this.item?.id;
241
+ if (itemId == null)
242
+ return;
243
+ const detail = { itemId, quantity };
73
244
  if (this.hasOptions) {
74
245
  detail.options = await this.getSelectedOptions();
246
+ detail.optionDefinitions = await this.getOptionsData();
75
247
  }
76
248
  this.orderItemUpdated.emit(detail);
77
249
  }
@@ -90,21 +262,26 @@ const SallaOrderEditItem = /*@__PURE__*/ proxyCustomElement(class SallaOrderEdit
90
262
  const imageAlt = product?.image?.alt || productName;
91
263
  const productUrl = product?.url || '#';
92
264
  const price = product?.price;
93
- const maxQuantity = product?.max_quantity;
265
+ const maxQuantity = getOrderEditProductMaxQuantity(product);
94
266
  const weightLabel = product?.weight_label;
95
267
  const options = this.item.product?.options;
268
+ const optionsInstanceKey = `order-edit-item-${this.item.id}-${product?.id}`;
96
269
  const quantityAttrs = { value: this.quantity };
97
270
  if (maxQuantity) {
98
271
  quantityAttrs.max = maxQuantity;
99
272
  }
100
- return (h(Host, null, h("div", null, h("div", { class: "s-order-edit-item-header" }, h("div", { class: "s-order-edit-item-media" }, imageUrl && (h("a", { href: productUrl }, h("img", { src: imageUrl, alt: imageAlt, class: "s-order-edit-item-image" }))), h("div", { class: "s-order-edit-item-details" }, h("h2", { class: "s-order-edit-item-name" }, h("a", { href: productUrl, class: "s-order-edit-item-link" }, productName)), price != null && (h("span", { class: "s-order-edit-item-price", innerHTML: salla.money(price) })), weightLabel && (h("p", { class: "s-order-edit-item-weight" }, salla.lang.getWithDefault('pages.products.weight', 'الوزن'), " ", weightLabel)))), h("salla-button", { type: "button", shape: "icon", size: "small", color: "danger", "aria-label": salla.lang.getWithDefault('common.elements.delete', 'حذف'), onClick: () => this.removeItem() }, h("i", { class: "sicon-cancel" }))), h("div", { class: "s-order-edit-item-quantity" }, h("h3", { class: "s-order-edit-item-quantity-label" }, salla.lang.getWithDefault('common.elements.quantity', 'الكمية')), h("div", { class: "s-order-edit-item-quantity-input" }, h("salla-quantity-input", { ...quantityAttrs }))), this.hasOptions && (h("form", { onSubmit: e => e.preventDefault() }, h("salla-product-options", { "product-id": product.id, options: JSON.stringify(options), key: `${product.id}-order-edit-item-options` }))))));
273
+ return (h(Host, null, h("div", null, h("div", { class: "s-order-edit-item-header" }, h("div", { class: "s-order-edit-item-media" }, imageUrl && (h("a", { href: productUrl }, h("img", { src: imageUrl, alt: imageAlt, class: "s-order-edit-item-image" }))), h("div", { class: "s-order-edit-item-details" }, h("h2", { class: "s-order-edit-item-name" }, h("a", { href: productUrl, class: "s-order-edit-item-link" }, productName)), price != null && (h("span", { class: "s-order-edit-item-price", innerHTML: salla.money(price) })), weightLabel && (h("p", { class: "s-order-edit-item-weight" }, salla.lang.getWithDefault('pages.products.weight', 'الوزن'), " ", weightLabel)))), h("salla-button", { type: "button", shape: "icon", size: "small", color: "danger", "aria-label": salla.lang.getWithDefault('common.elements.delete', 'حذف'), onClick: () => this.removeItem() }, h("i", { class: "sicon-cancel" }))), h("div", { class: "s-order-edit-item-quantity" }, h("h3", { class: "s-order-edit-item-quantity-label" }, salla.lang.getWithDefault('common.elements.quantity', 'الكمية')), h("div", { class: "s-order-edit-item-quantity-input" }, h("salla-quantity-input", { ref: el => (this.quantityInput = el), ...quantityAttrs, onChange: this.handleQuantityChange }))), this.hasOptions && (h("form", { class: "s-order-edit-item-options", onSubmit: e => e.preventDefault() }, h("salla-product-options", { ref: el => (this.productOptions = el), onChange: this.handleOptionsChange, "product-id": product.id, "unique-key": optionsInstanceKey, options: JSON.stringify(options), key: `${optionsInstanceKey}-options` }))))));
101
274
  }
102
- get host() { return this; }
275
+ static get watchers() { return {
276
+ "item": ["handleItemChange"]
277
+ }; }
103
278
  static get style() { return sallaOrderEditItemCss; }
104
279
  }, [0, "salla-order-edit-item", {
105
280
  "item": [16],
106
281
  "orderId": [8, "order-id"],
107
282
  "quantity": [32]
283
+ }, undefined, {
284
+ "item": ["handleItemChange"]
108
285
  }]);
109
286
  function defineCustomElement() {
110
287
  if (typeof customElements === "undefined") {
@@ -181,4 +358,4 @@ function defineCustomElement() {
181
358
  }
182
359
  defineCustomElement();
183
360
 
184
- export { SallaOrderEditItem as S, defineCustomElement as d };
361
+ export { SallaOrderEditItem as S, getOrderEditProductMaxQuantity as a, cloneOrderEditProduct as b, clampOrderEditQuantity as c, defineCustomElement as d, updateAddedPayloadList as e, findMergeableItem as f, getOrderItemSelectedOptions as g, upsertPayloadUpdateList as h, createAddedOrderItem as i, buildSavePayload as j, mergePayloadItems as m, removeOrderItems as r, updateOrderItems as u };
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface SallaOrderEditProductCard extends Components.SallaOrderEditProductCard, HTMLElement {}
4
+ export const SallaOrderEditProductCard: {
5
+ prototype: SallaOrderEditProductCard;
6
+ new (): SallaOrderEditProductCard;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,59 @@
1
+ /*!
2
+ * Crafted with ❤ by Salla
3
+ */
4
+ import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
5
+
6
+ const sallaOrderEditProductCardCss = ":host{display:block;min-width:0}";
7
+
8
+ const SallaOrderEditProductCard$1 = /*@__PURE__*/ proxyCustomElement(class SallaOrderEditProductCard extends HTMLElement {
9
+ constructor() {
10
+ super();
11
+ this.__registerHost();
12
+ this.orderEditProductSelected = createEvent(this, "orderEditProductSelected", 7);
13
+ }
14
+ get productData() {
15
+ if (!this.product) {
16
+ return {};
17
+ }
18
+ if (typeof this.product === 'object') {
19
+ return this.product;
20
+ }
21
+ try {
22
+ return JSON.parse(this.product);
23
+ }
24
+ catch (_error) {
25
+ return {};
26
+ }
27
+ }
28
+ handleSelectProduct() {
29
+ this.orderEditProductSelected.emit({ product: this.productData });
30
+ }
31
+ render() {
32
+ const product = this.productData;
33
+ const productName = product?.name || salla.lang.getWithDefault('common.elements.product', 'منتج');
34
+ const price = product?.price;
35
+ return (h(Host, { key: 'e5837d7ec53f2566fe981f02a95b52c7c817821c' }, h("button", { key: '415861262349f83c3c7d1dc72d9f8f01f855317e', type: "button", class: "s-order-edit-product-card", onClick: () => this.handleSelectProduct() }, h("div", { key: '072d3af840d5044636380f5620703cc446877162', class: "s-order-edit-product-card-media" }, product?.image?.url ? (h("img", { src: product.image.url, alt: product.image.alt || productName, class: "s-order-edit-product-card-image" })) : (h("div", { class: "s-order-edit-product-card-placeholder" }, h("i", { class: "sicon-shopping-bag" })))), h("div", { key: 'ac51822bbcf1f2213b11204fa968a40e7de164a3', class: "s-order-edit-product-card-content" }, h("h3", { key: 'e817582bf88db2ed6ac47a37a5d2b4e4ac953770', class: "s-order-edit-product-card-title" }, productName), price != null && (h("p", { key: 'efbf1b16d7c6d73de76bab1e8715a474f812fde4', class: "s-order-edit-product-card-price", innerHTML: salla.money(price) }))))));
36
+ }
37
+ static get style() { return sallaOrderEditProductCardCss; }
38
+ }, [0, "salla-order-edit-product-card", {
39
+ "product": [1]
40
+ }]);
41
+ function defineCustomElement$1() {
42
+ if (typeof customElements === "undefined") {
43
+ return;
44
+ }
45
+ const components = ["salla-order-edit-product-card"];
46
+ components.forEach(tagName => { switch (tagName) {
47
+ case "salla-order-edit-product-card":
48
+ if (!customElements.get(tagName)) {
49
+ customElements.define(tagName, SallaOrderEditProductCard$1);
50
+ }
51
+ break;
52
+ } });
53
+ }
54
+ defineCustomElement$1();
55
+
56
+ const SallaOrderEditProductCard = SallaOrderEditProductCard$1;
57
+ const defineCustomElement = defineCustomElement$1;
58
+
59
+ export { SallaOrderEditProductCard, defineCustomElement };