@salla.sa/twilight-components 2.14.220 → 2.14.222

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 (349) hide show
  1. package/dist/cjs/{app-globals-2vTvVXxF.js → app-globals-DPedpk8u.js} +3 -3
  2. package/dist/cjs/{app-globals-2vTvVXxF.js.map → app-globals-DPedpk8u.js.map} +1 -1
  3. package/dist/cjs/{index-B04Y8RyW.js → index-BDn6fH9S.js} +8 -4
  4. package/dist/cjs/index-BDn6fH9S.js.map +1 -0
  5. package/dist/cjs/loader.cjs.js +3 -3
  6. package/dist/cjs/salla-accordion-body.cjs.entry.js +1 -1
  7. package/dist/cjs/salla-accordion-head.cjs.entry.js +1 -1
  8. package/dist/cjs/salla-accordion.cjs.entry.js +1 -1
  9. package/dist/cjs/salla-add-product-button_51.cjs.entry.js +1 -1
  10. package/dist/cjs/salla-advertisement.cjs.entry.js +1 -1
  11. package/dist/cjs/salla-app-install-alert.cjs.entry.js +1 -1
  12. package/dist/cjs/salla-apps-icons.cjs.entry.js +1 -1
  13. package/dist/cjs/salla-booking-field_2.cjs.entry.js +1 -1
  14. package/dist/cjs/salla-cart-item-offers.cjs.entry.js +1 -1
  15. package/dist/cjs/salla-conditional-offer.cjs.entry.js +16 -5
  16. package/dist/cjs/salla-conditional-offer.cjs.entry.js.map +1 -1
  17. package/dist/cjs/salla-conditional-offer.entry.cjs.js.map +1 -1
  18. package/dist/cjs/salla-contacts.cjs.entry.js +1 -1
  19. package/dist/cjs/salla-filters-widget.cjs.entry.js +1 -1
  20. package/dist/cjs/salla-filters.cjs.entry.js +1 -1
  21. package/dist/cjs/salla-installment.cjs.entry.js +1 -1
  22. package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +1 -1
  23. package/dist/cjs/salla-loyalty-program.cjs.entry.js +1 -1
  24. package/dist/cjs/salla-metadata.cjs.entry.js +1 -1
  25. package/dist/cjs/salla-notification-item.cjs.entry.js +1 -1
  26. package/dist/cjs/salla-notifications.cjs.entry.js +1 -1
  27. package/dist/cjs/salla-offer.cjs.entry.js +1 -1
  28. package/dist/cjs/salla-order-summary.cjs.entry.js +1 -1
  29. package/dist/cjs/salla-orders.cjs.entry.js +1 -1
  30. package/dist/cjs/salla-payments.cjs.entry.js +1 -1
  31. package/dist/cjs/salla-price-range.cjs.entry.js +1 -1
  32. package/dist/cjs/salla-product-options.cjs.entry.js +1 -1
  33. package/dist/cjs/salla-review-card.cjs.entry.js +1 -1
  34. package/dist/cjs/salla-reviews-page.cjs.entry.js +1 -1
  35. package/dist/cjs/salla-reviews.cjs.entry.js +1 -1
  36. package/dist/cjs/salla-social.cjs.entry.js +1 -1
  37. package/dist/cjs/salla-tiered-offer.cjs.entry.js +338 -0
  38. package/dist/cjs/salla-tiered-offer.cjs.entry.js.map +1 -0
  39. package/dist/cjs/salla-tiered-offer.entry.cjs.js.map +1 -0
  40. package/dist/cjs/salla-tooltip.cjs.entry.js +1 -1
  41. package/dist/cjs/salla-verify.cjs.entry.js +1 -1
  42. package/dist/cjs/salla-wallet.cjs.entry.js +1 -1
  43. package/dist/cjs/twilight.cjs.js +3 -3
  44. package/dist/collection/assets/svg/diamond-02.svg +4 -0
  45. package/dist/collection/assets/svg/gold.svg +6 -0
  46. package/dist/collection/assets/svg/star-rounded.svg +3 -0
  47. package/dist/collection/assets/svg/stars.svg +5 -0
  48. package/dist/collection/collection-manifest.json +1 -0
  49. package/dist/collection/components/salla-conditional-offer/salla-conditional-offer.js +15 -4
  50. package/dist/collection/components/salla-conditional-offer/salla-conditional-offer.js.map +1 -1
  51. package/dist/collection/components/salla-tiered-offer/constants.js +12 -0
  52. package/dist/collection/components/salla-tiered-offer/constants.js.map +1 -0
  53. package/dist/collection/components/salla-tiered-offer/interfaces.js +9 -0
  54. package/dist/collection/components/salla-tiered-offer/interfaces.js.map +1 -0
  55. package/dist/collection/components/salla-tiered-offer/salla-tiered-offer.css +26 -0
  56. package/dist/collection/components/salla-tiered-offer/salla-tiered-offer.js +288 -0
  57. package/dist/collection/components/salla-tiered-offer/salla-tiered-offer.js.map +1 -0
  58. package/dist/collection/components/salla-tiered-offer/utils.js +38 -0
  59. package/dist/collection/components/salla-tiered-offer/utils.js.map +1 -0
  60. package/dist/components/index.js +2 -2
  61. package/dist/components/index.js.map +1 -1
  62. package/dist/components/salla-conditional-offer.js +15 -4
  63. package/dist/components/salla-conditional-offer.js.map +1 -1
  64. package/dist/components/salla-tiered-offer.d.ts +11 -0
  65. package/dist/components/salla-tiered-offer.js +371 -0
  66. package/dist/components/salla-tiered-offer.js.map +1 -0
  67. package/dist/esm/{app-globals-DRz9_J1y.js → app-globals-wLakfxcp.js} +3 -3
  68. package/dist/esm/{app-globals-DRz9_J1y.js.map → app-globals-wLakfxcp.js.map} +1 -1
  69. package/dist/esm/{index-L1Wml9tS.js → index-Dj2SrCy0.js} +8 -4
  70. package/dist/esm/index-Dj2SrCy0.js.map +1 -0
  71. package/dist/esm/loader.js +4 -4
  72. package/dist/esm/salla-accordion-body.entry.js +1 -1
  73. package/dist/esm/salla-accordion-head.entry.js +1 -1
  74. package/dist/esm/salla-accordion.entry.js +1 -1
  75. package/dist/esm/salla-add-product-button_51.entry.js +1 -1
  76. package/dist/esm/salla-advertisement.entry.js +1 -1
  77. package/dist/esm/salla-app-install-alert.entry.js +1 -1
  78. package/dist/esm/salla-apps-icons.entry.js +1 -1
  79. package/dist/esm/salla-booking-field_2.entry.js +1 -1
  80. package/dist/esm/salla-cart-item-offers.entry.js +1 -1
  81. package/dist/esm/salla-conditional-offer.entry.js +16 -5
  82. package/dist/esm/salla-conditional-offer.entry.js.map +1 -1
  83. package/dist/esm/salla-contacts.entry.js +1 -1
  84. package/dist/esm/salla-filters-widget.entry.js +1 -1
  85. package/dist/esm/salla-filters.entry.js +1 -1
  86. package/dist/esm/salla-installment.entry.js +1 -1
  87. package/dist/esm/salla-loyalty-prize-item.entry.js +1 -1
  88. package/dist/esm/salla-loyalty-program.entry.js +1 -1
  89. package/dist/esm/salla-metadata.entry.js +1 -1
  90. package/dist/esm/salla-notification-item.entry.js +1 -1
  91. package/dist/esm/salla-notifications.entry.js +1 -1
  92. package/dist/esm/salla-offer.entry.js +1 -1
  93. package/dist/esm/salla-order-summary.entry.js +1 -1
  94. package/dist/esm/salla-orders.entry.js +1 -1
  95. package/dist/esm/salla-payments.entry.js +1 -1
  96. package/dist/esm/salla-price-range.entry.js +1 -1
  97. package/dist/esm/salla-product-options.entry.js +1 -1
  98. package/dist/esm/salla-review-card.entry.js +1 -1
  99. package/dist/esm/salla-reviews-page.entry.js +1 -1
  100. package/dist/esm/salla-reviews.entry.js +1 -1
  101. package/dist/esm/salla-social.entry.js +1 -1
  102. package/dist/esm/salla-tiered-offer.entry.js +336 -0
  103. package/dist/esm/salla-tiered-offer.entry.js.map +1 -0
  104. package/dist/esm/salla-tooltip.entry.js +1 -1
  105. package/dist/esm/salla-verify.entry.js +1 -1
  106. package/dist/esm/salla-wallet.entry.js +1 -1
  107. package/dist/esm/twilight.js +4 -4
  108. package/dist/esm-es5/{app-globals-DRz9_J1y.js → app-globals-wLakfxcp.js} +2 -2
  109. package/dist/esm-es5/{app-globals-DRz9_J1y.js.map → app-globals-wLakfxcp.js.map} +1 -1
  110. package/dist/esm-es5/{index-L1Wml9tS.js → index-Dj2SrCy0.js} +3 -3
  111. package/dist/esm-es5/index-Dj2SrCy0.js.map +1 -0
  112. package/dist/esm-es5/loader.js +1 -1
  113. package/dist/esm-es5/salla-accordion-body.entry.js +1 -1
  114. package/dist/esm-es5/salla-accordion-head.entry.js +1 -1
  115. package/dist/esm-es5/salla-accordion.entry.js +1 -1
  116. package/dist/esm-es5/salla-add-product-button_51.entry.js +1 -1
  117. package/dist/esm-es5/salla-advertisement.entry.js +1 -1
  118. package/dist/esm-es5/salla-app-install-alert.entry.js +1 -1
  119. package/dist/esm-es5/salla-apps-icons.entry.js +1 -1
  120. package/dist/esm-es5/salla-booking-field_2.entry.js +1 -1
  121. package/dist/esm-es5/salla-cart-item-offers.entry.js +1 -1
  122. package/dist/esm-es5/salla-conditional-offer.entry.js +1 -1
  123. package/dist/esm-es5/salla-conditional-offer.entry.js.map +1 -1
  124. package/dist/esm-es5/salla-contacts.entry.js +1 -1
  125. package/dist/esm-es5/salla-filters-widget.entry.js +2 -2
  126. package/dist/esm-es5/salla-filters.entry.js +1 -1
  127. package/dist/esm-es5/salla-installment.entry.js +1 -1
  128. package/dist/esm-es5/salla-loyalty-prize-item.entry.js +1 -1
  129. package/dist/esm-es5/salla-loyalty-program.entry.js +1 -1
  130. package/dist/esm-es5/salla-metadata.entry.js +2 -2
  131. package/dist/esm-es5/salla-notification-item.entry.js +1 -1
  132. package/dist/esm-es5/salla-notifications.entry.js +2 -2
  133. package/dist/esm-es5/salla-offer.entry.js +1 -1
  134. package/dist/esm-es5/salla-order-summary.entry.js +2 -2
  135. package/dist/esm-es5/salla-orders.entry.js +2 -2
  136. package/dist/esm-es5/salla-payments.entry.js +1 -1
  137. package/dist/esm-es5/salla-price-range.entry.js +1 -1
  138. package/dist/esm-es5/salla-product-options.entry.js +1 -1
  139. package/dist/esm-es5/salla-review-card.entry.js +1 -1
  140. package/dist/esm-es5/salla-reviews-page.entry.js +1 -1
  141. package/dist/esm-es5/salla-reviews.entry.js +1 -1
  142. package/dist/esm-es5/salla-social.entry.js +1 -1
  143. package/dist/esm-es5/salla-tiered-offer.entry.js +5 -0
  144. package/dist/esm-es5/salla-tiered-offer.entry.js.map +1 -0
  145. package/dist/esm-es5/salla-tooltip.entry.js +1 -1
  146. package/dist/esm-es5/salla-verify.entry.js +1 -1
  147. package/dist/esm-es5/salla-wallet.entry.js +1 -1
  148. package/dist/esm-es5/twilight.js +1 -1
  149. package/dist/twilight/{p-2ac20d02.entry.js → p-00ce3e65.entry.js} +2 -2
  150. package/dist/twilight/{p-e00746e9.system.entry.js → p-02cc2225.system.entry.js} +2 -2
  151. package/dist/twilight/{p-0a469ba7.system.entry.js → p-0b16f452.system.entry.js} +3 -3
  152. package/dist/twilight/{p-3bdebf0d.entry.js → p-109136fc.entry.js} +2 -2
  153. package/dist/twilight/{p-fe959c9a.system.entry.js → p-12adb702.system.entry.js} +2 -2
  154. package/dist/twilight/{p-12a13525.entry.js → p-16dfee33.entry.js} +2 -2
  155. package/dist/twilight/{p-1ccd8b8e.entry.js → p-18537486.entry.js} +2 -2
  156. package/dist/twilight/{p-2cd40336.system.entry.js → p-1cbc4329.system.entry.js} +2 -2
  157. package/dist/twilight/{p-fbaa093c.entry.js → p-1cf1344e.entry.js} +2 -2
  158. package/dist/twilight/{p-a477ee76.system.entry.js → p-1d6100c4.system.entry.js} +2 -2
  159. package/dist/twilight/{p-75ec194e.system.entry.js → p-29567106.system.entry.js} +2 -2
  160. package/dist/twilight/{p-962cd525.entry.js → p-315c5fd3.entry.js} +2 -2
  161. package/dist/twilight/{p-184f98b1.entry.js → p-337fca82.entry.js} +2 -2
  162. package/dist/twilight/{p-5b8bf0e6.system.entry.js → p-3b02f780.system.entry.js} +2 -2
  163. package/dist/twilight/{p-Burnn1Qt.js → p-4drPVtGP.js} +2 -2
  164. package/dist/twilight/{p-Burnn1Qt.js.map → p-4drPVtGP.js.map} +1 -1
  165. package/dist/twilight/{p-7b7618d5.entry.js → p-5394cdeb.entry.js} +2 -2
  166. package/dist/twilight/{p-38526ba5.system.entry.js → p-55306475.system.entry.js} +2 -2
  167. package/dist/twilight/{p-b1ad7c75.entry.js → p-59763129.entry.js} +2 -2
  168. package/dist/twilight/{p-52156f6d.system.entry.js → p-5cd7ff6d.system.entry.js} +2 -2
  169. package/dist/twilight/{p-5c918974.entry.js → p-5e1f0ddf.entry.js} +2 -2
  170. package/dist/twilight/p-618eb3f2.system.entry.js +5 -0
  171. package/dist/twilight/p-618eb3f2.system.entry.js.map +1 -0
  172. package/dist/twilight/{p-f6c410c6.entry.js → p-67b54ac4.entry.js} +2 -2
  173. package/dist/twilight/p-67ebf87e.system.entry.js +5 -0
  174. package/dist/twilight/{p-76137ff1.entry.js → p-688dd765.entry.js} +2 -2
  175. package/dist/twilight/{p-284dae41.system.entry.js → p-6ec767ac.system.entry.js} +2 -2
  176. package/dist/twilight/{p-1af18eb4.entry.js → p-70e74f3c.entry.js} +2 -2
  177. package/dist/twilight/{p-d9c2f2b0.system.entry.js → p-7236a037.system.entry.js} +2 -2
  178. package/dist/twilight/{p-30c8b458.system.entry.js → p-7436f972.system.entry.js} +2 -2
  179. package/dist/twilight/{p-8d9a5dc0.entry.js → p-74647582.entry.js} +2 -2
  180. package/dist/twilight/{p-Cl_CHxGj.system.js.map → p-78vq_YNh.system.js.map} +1 -1
  181. package/dist/twilight/{p-c781f7a7.entry.js → p-8162a820.entry.js} +2 -2
  182. package/dist/twilight/p-864f1430.system.entry.js +5 -0
  183. package/dist/twilight/{p-47b6e06b.system.entry.js → p-865fc401.system.entry.js} +2 -2
  184. package/dist/twilight/{p-bfb9457b.system.entry.js → p-87206bd7.system.entry.js} +2 -2
  185. package/dist/twilight/p-8c08dafb.entry.js +5 -0
  186. package/dist/twilight/{p-0e4f26bb.system.entry.js → p-8ce2a142.system.entry.js} +2 -2
  187. package/dist/twilight/{p-60e6d7e6.system.entry.js → p-8d28bf6e.system.entry.js} +2 -2
  188. package/dist/twilight/{p-d07e552b.system.entry.js → p-97337c52.system.entry.js} +2 -2
  189. package/dist/twilight/{p-08258532.entry.js → p-9e54e404.entry.js} +2 -2
  190. package/dist/twilight/{p-C9IwdXDn.system.js.map → p-B-EmhPha.system.js.map} +1 -1
  191. package/dist/twilight/{p-B0ThVjj_.system.js.map → p-B6apPCKk.system.js.map} +1 -1
  192. package/dist/twilight/{p-D_Of4cjl.system.js.map → p-BC5TR2o4.system.js.map} +1 -1
  193. package/dist/twilight/{p-Bvg9GRmu.system.js.map → p-BFLzwSRe.system.js.map} +1 -1
  194. package/dist/twilight/{p-DFlc0grl.system.js.map → p-BIlNLy1w.system.js.map} +1 -1
  195. package/dist/twilight/{p-j7nJelMY.system.js.map → p-B_H7JnAQ.system.js.map} +1 -1
  196. package/dist/twilight/{p-BWD1Mdmj.system.js.map → p-BfizdcIv.system.js.map} +1 -1
  197. package/dist/twilight/{p-BfxbBmpF.system.js.map → p-BgVK0PPB.system.js.map} +1 -1
  198. package/dist/twilight/{p-BUNm7oxn.system.js → p-BtfcvLWi.system.js} +2 -2
  199. package/dist/twilight/{p-BUNm7oxn.system.js.map → p-BtfcvLWi.system.js.map} +1 -1
  200. package/dist/twilight/{p-BP344v_q.system.js.map → p-BxPxFmIf.system.js.map} +1 -1
  201. package/dist/twilight/{p-9jT7Wo1H.system.js.map → p-C6Mc-nga.system.js.map} +1 -1
  202. package/dist/twilight/{p-nuRa4ECK.system.js.map → p-CAhB5SXO.system.js.map} +1 -1
  203. package/dist/twilight/{p-cWZujtjd.system.js.map → p-CD5EBKFr.system.js.map} +1 -1
  204. package/dist/twilight/{p-egmUBeji.system.js.map → p-CDPN9ikP.system.js.map} +1 -1
  205. package/dist/twilight/{p-YvHIMjOJ.system.js.map → p-CE_xhQMS.system.js.map} +1 -1
  206. package/dist/twilight/{p-Cee0DssD.system.js.map → p-CIzZIur3.system.js.map} +1 -1
  207. package/dist/twilight/p-CaVNqQXu.system.js +5 -0
  208. package/dist/twilight/{p-ByGP8fWO.system.js.map → p-CaVNqQXu.system.js.map} +1 -1
  209. package/dist/twilight/{p-DPreD4Hr.system.js.map → p-CfNLozg0.system.js.map} +1 -1
  210. package/dist/twilight/p-ClaSC-3N.system.js.map +1 -0
  211. package/dist/twilight/{p-CIghWdV5.system.js.map → p-Cm8GjH45.system.js.map} +1 -1
  212. package/dist/twilight/{p-BftU992I.system.js.map → p-CpJOChwF.system.js.map} +1 -1
  213. package/dist/twilight/{p-BWnEoSJY.system.js.map → p-CsweHiBJ.system.js.map} +1 -1
  214. package/dist/twilight/{p-CpzD5fce.system.js.map → p-CtiUKful.system.js.map} +1 -1
  215. package/dist/twilight/{p-nvgYekhd.system.js.map → p-D0vXKNzE.system.js.map} +1 -1
  216. package/dist/twilight/{p-BCvHzhOW.system.js.map → p-D6fGvShW.system.js.map} +1 -1
  217. package/dist/twilight/{p-BlpV9vce.system.js.map → p-DInbMpRZ.system.js.map} +1 -1
  218. package/dist/twilight/{p-DVqtOGyR.system.js.map → p-DRUO4ntA.system.js.map} +1 -1
  219. package/dist/twilight/{p-L1Wml9tS.js → p-Dj2SrCy0.js} +3 -3
  220. package/dist/twilight/p-Dj2SrCy0.js.map +1 -0
  221. package/dist/twilight/{p-DuTXkmaO.system.js → p-DvJ_tnSw.system.js} +6 -6
  222. package/dist/twilight/p-DvJ_tnSw.system.js.map +1 -0
  223. package/dist/twilight/{p-DUDOY-ZS.system.js.map → p-DvQIv_6Y.system.js.map} +1 -1
  224. package/dist/twilight/{p-DwLeLHva.system.js.map → p-Dx2JzDoP.system.js.map} +1 -1
  225. package/dist/twilight/{p-DmQdqVWv.system.js.map → p-Dzal8dOY.system.js.map} +1 -1
  226. package/dist/twilight/p-FGWU4ai_.system.js.map +1 -0
  227. package/dist/twilight/{p-DvZ3uG1Y.system.js.map → p-LondrlGD.system.js.map} +1 -1
  228. package/dist/twilight/{p-tI_9cOVN.system.js.map → p-Q2yReOd3.system.js.map} +1 -1
  229. package/dist/twilight/{p-ByVXW9BA.system.js.map → p-WlDhq-4G.system.js.map} +1 -1
  230. package/dist/twilight/{p-cbadf894.system.entry.js → p-a20b6984.system.entry.js} +2 -2
  231. package/dist/twilight/{p-b4b5a600.system.entry.js → p-a439d5c1.system.entry.js} +2 -2
  232. package/dist/twilight/{p-62ba5382.entry.js → p-a531e0e4.entry.js} +2 -2
  233. package/dist/twilight/{p-342e13e4.system.entry.js → p-acaa2f80.system.entry.js} +2 -2
  234. package/dist/twilight/{p-154d97db.system.entry.js → p-ae7962ba.system.entry.js} +2 -2
  235. package/dist/twilight/{p-039b45e6.system.entry.js → p-b167e712.system.entry.js} +2 -2
  236. package/dist/twilight/{p-9a3f6331.entry.js → p-b42c8720.entry.js} +2 -2
  237. package/dist/twilight/{p-4291c03c.system.entry.js → p-b477f55b.system.entry.js} +2 -2
  238. package/dist/twilight/{p-50f789e5.entry.js → p-bc918d89.entry.js} +2 -2
  239. package/dist/twilight/{p-96d501d2.entry.js → p-c3adc5d9.entry.js} +2 -2
  240. package/dist/twilight/{p-5a577bf3.system.entry.js → p-c842f73f.system.entry.js} +2 -2
  241. package/dist/twilight/{p-f72dd4b6.system.entry.js → p-c8cea269.system.entry.js} +2 -2
  242. package/dist/twilight/{p-90fc2489.entry.js → p-d37bad6f.entry.js} +2 -2
  243. package/dist/twilight/{p-af1f9cd6.entry.js → p-d85581c6.entry.js} +2 -2
  244. package/dist/twilight/{p-666189da.system.entry.js → p-d8d9cdcd.system.entry.js} +2 -2
  245. package/dist/twilight/{p-be1034af.system.entry.js → p-de891990.system.entry.js} +2 -2
  246. package/dist/twilight/{p-6c83517d.entry.js → p-def552bd.entry.js} +2 -2
  247. package/dist/twilight/{p-228d58df.system.entry.js → p-e4f73083.system.entry.js} +2 -2
  248. package/dist/twilight/{p-a3ab451d.entry.js → p-e5872e75.entry.js} +2 -2
  249. package/dist/twilight/{p-d0a760cc.entry.js → p-ed4c7158.entry.js} +2 -2
  250. package/dist/twilight/p-ee443b00.entry.js +5 -0
  251. package/dist/twilight/p-ee443b00.entry.js.map +1 -0
  252. package/dist/twilight/{p-789f0166.system.entry.js → p-f1f3d74e.system.entry.js} +2 -2
  253. package/dist/twilight/{p-ca88566e.entry.js → p-f3b8551c.entry.js} +2 -2
  254. package/dist/twilight/{p-c63ddf33.entry.js → p-f41e7eed.entry.js} +2 -2
  255. package/dist/twilight/{p-6fcc8ed3.entry.js → p-f4918259.entry.js} +2 -2
  256. package/dist/twilight/p-f594b721.entry.js +5 -0
  257. package/dist/twilight/p-f594b721.entry.js.map +1 -0
  258. package/dist/twilight/{p-5b4f648e.entry.js → p-f9d8f20d.entry.js} +2 -2
  259. package/dist/twilight/p-fb59e3b5.entry.js +5 -0
  260. package/dist/twilight/p-ffb9ab7b.system.entry.js +5 -0
  261. package/dist/twilight/p-ffb9ab7b.system.entry.js.map +1 -0
  262. package/dist/twilight/{p-DKke2twA.system.js.map → p-jlCh1xBh.system.js.map} +1 -1
  263. package/dist/twilight/salla-conditional-offer.entry.esm.js.map +1 -1
  264. package/dist/twilight/salla-tiered-offer.entry.esm.js.map +1 -0
  265. package/dist/twilight/twilight.esm.js +1 -1
  266. package/dist/twilight/twilight.js +1 -1
  267. package/dist/types/components/salla-tiered-offer/constants.d.ts +2 -0
  268. package/dist/types/components/salla-tiered-offer/interfaces.d.ts +44 -0
  269. package/dist/types/components/salla-tiered-offer/salla-tiered-offer.d.ts +39 -0
  270. package/dist/types/components/salla-tiered-offer/utils.d.ts +19 -0
  271. package/dist/types/components.d.ts +13 -0
  272. package/package.json +5 -5
  273. package/dist/cjs/index-B04Y8RyW.js.map +0 -1
  274. package/dist/esm/index-L1Wml9tS.js.map +0 -1
  275. package/dist/esm-es5/index-L1Wml9tS.js.map +0 -1
  276. package/dist/twilight/p-0225792d.system.entry.js +0 -5
  277. package/dist/twilight/p-0225792d.system.entry.js.map +0 -1
  278. package/dist/twilight/p-2c11821b.entry.js +0 -5
  279. package/dist/twilight/p-4fd3a01d.entry.js +0 -5
  280. package/dist/twilight/p-4fd3a01d.entry.js.map +0 -1
  281. package/dist/twilight/p-57bbd96b.system.entry.js +0 -5
  282. package/dist/twilight/p-BIOQiBj0.system.js.map +0 -1
  283. package/dist/twilight/p-ByGP8fWO.system.js +0 -5
  284. package/dist/twilight/p-DuTXkmaO.system.js.map +0 -1
  285. package/dist/twilight/p-L1Wml9tS.js.map +0 -1
  286. package/dist/twilight/p-a198f405.entry.js +0 -5
  287. package/dist/twilight/p-e58e21db.system.entry.js +0 -5
  288. /package/dist/twilight/{p-2ac20d02.entry.js.map → p-00ce3e65.entry.js.map} +0 -0
  289. /package/dist/twilight/{p-e00746e9.system.entry.js.map → p-02cc2225.system.entry.js.map} +0 -0
  290. /package/dist/twilight/{p-0a469ba7.system.entry.js.map → p-0b16f452.system.entry.js.map} +0 -0
  291. /package/dist/twilight/{p-3bdebf0d.entry.js.map → p-109136fc.entry.js.map} +0 -0
  292. /package/dist/twilight/{p-fe959c9a.system.entry.js.map → p-12adb702.system.entry.js.map} +0 -0
  293. /package/dist/twilight/{p-12a13525.entry.js.map → p-16dfee33.entry.js.map} +0 -0
  294. /package/dist/twilight/{p-1ccd8b8e.entry.js.map → p-18537486.entry.js.map} +0 -0
  295. /package/dist/twilight/{p-2cd40336.system.entry.js.map → p-1cbc4329.system.entry.js.map} +0 -0
  296. /package/dist/twilight/{p-fbaa093c.entry.js.map → p-1cf1344e.entry.js.map} +0 -0
  297. /package/dist/twilight/{p-a477ee76.system.entry.js.map → p-1d6100c4.system.entry.js.map} +0 -0
  298. /package/dist/twilight/{p-75ec194e.system.entry.js.map → p-29567106.system.entry.js.map} +0 -0
  299. /package/dist/twilight/{p-962cd525.entry.js.map → p-315c5fd3.entry.js.map} +0 -0
  300. /package/dist/twilight/{p-184f98b1.entry.js.map → p-337fca82.entry.js.map} +0 -0
  301. /package/dist/twilight/{p-5b8bf0e6.system.entry.js.map → p-3b02f780.system.entry.js.map} +0 -0
  302. /package/dist/twilight/{p-7b7618d5.entry.js.map → p-5394cdeb.entry.js.map} +0 -0
  303. /package/dist/twilight/{p-38526ba5.system.entry.js.map → p-55306475.system.entry.js.map} +0 -0
  304. /package/dist/twilight/{p-b1ad7c75.entry.js.map → p-59763129.entry.js.map} +0 -0
  305. /package/dist/twilight/{p-52156f6d.system.entry.js.map → p-5cd7ff6d.system.entry.js.map} +0 -0
  306. /package/dist/twilight/{p-5c918974.entry.js.map → p-5e1f0ddf.entry.js.map} +0 -0
  307. /package/dist/twilight/{p-f6c410c6.entry.js.map → p-67b54ac4.entry.js.map} +0 -0
  308. /package/dist/twilight/{p-57bbd96b.system.entry.js.map → p-67ebf87e.system.entry.js.map} +0 -0
  309. /package/dist/twilight/{p-76137ff1.entry.js.map → p-688dd765.entry.js.map} +0 -0
  310. /package/dist/twilight/{p-284dae41.system.entry.js.map → p-6ec767ac.system.entry.js.map} +0 -0
  311. /package/dist/twilight/{p-1af18eb4.entry.js.map → p-70e74f3c.entry.js.map} +0 -0
  312. /package/dist/twilight/{p-d9c2f2b0.system.entry.js.map → p-7236a037.system.entry.js.map} +0 -0
  313. /package/dist/twilight/{p-30c8b458.system.entry.js.map → p-7436f972.system.entry.js.map} +0 -0
  314. /package/dist/twilight/{p-8d9a5dc0.entry.js.map → p-74647582.entry.js.map} +0 -0
  315. /package/dist/twilight/{p-c781f7a7.entry.js.map → p-8162a820.entry.js.map} +0 -0
  316. /package/dist/twilight/{p-e58e21db.system.entry.js.map → p-864f1430.system.entry.js.map} +0 -0
  317. /package/dist/twilight/{p-47b6e06b.system.entry.js.map → p-865fc401.system.entry.js.map} +0 -0
  318. /package/dist/twilight/{p-bfb9457b.system.entry.js.map → p-87206bd7.system.entry.js.map} +0 -0
  319. /package/dist/twilight/{p-a198f405.entry.js.map → p-8c08dafb.entry.js.map} +0 -0
  320. /package/dist/twilight/{p-0e4f26bb.system.entry.js.map → p-8ce2a142.system.entry.js.map} +0 -0
  321. /package/dist/twilight/{p-60e6d7e6.system.entry.js.map → p-8d28bf6e.system.entry.js.map} +0 -0
  322. /package/dist/twilight/{p-d07e552b.system.entry.js.map → p-97337c52.system.entry.js.map} +0 -0
  323. /package/dist/twilight/{p-08258532.entry.js.map → p-9e54e404.entry.js.map} +0 -0
  324. /package/dist/twilight/{p-cbadf894.system.entry.js.map → p-a20b6984.system.entry.js.map} +0 -0
  325. /package/dist/twilight/{p-b4b5a600.system.entry.js.map → p-a439d5c1.system.entry.js.map} +0 -0
  326. /package/dist/twilight/{p-62ba5382.entry.js.map → p-a531e0e4.entry.js.map} +0 -0
  327. /package/dist/twilight/{p-342e13e4.system.entry.js.map → p-acaa2f80.system.entry.js.map} +0 -0
  328. /package/dist/twilight/{p-154d97db.system.entry.js.map → p-ae7962ba.system.entry.js.map} +0 -0
  329. /package/dist/twilight/{p-039b45e6.system.entry.js.map → p-b167e712.system.entry.js.map} +0 -0
  330. /package/dist/twilight/{p-9a3f6331.entry.js.map → p-b42c8720.entry.js.map} +0 -0
  331. /package/dist/twilight/{p-4291c03c.system.entry.js.map → p-b477f55b.system.entry.js.map} +0 -0
  332. /package/dist/twilight/{p-50f789e5.entry.js.map → p-bc918d89.entry.js.map} +0 -0
  333. /package/dist/twilight/{p-96d501d2.entry.js.map → p-c3adc5d9.entry.js.map} +0 -0
  334. /package/dist/twilight/{p-5a577bf3.system.entry.js.map → p-c842f73f.system.entry.js.map} +0 -0
  335. /package/dist/twilight/{p-f72dd4b6.system.entry.js.map → p-c8cea269.system.entry.js.map} +0 -0
  336. /package/dist/twilight/{p-90fc2489.entry.js.map → p-d37bad6f.entry.js.map} +0 -0
  337. /package/dist/twilight/{p-af1f9cd6.entry.js.map → p-d85581c6.entry.js.map} +0 -0
  338. /package/dist/twilight/{p-666189da.system.entry.js.map → p-d8d9cdcd.system.entry.js.map} +0 -0
  339. /package/dist/twilight/{p-be1034af.system.entry.js.map → p-de891990.system.entry.js.map} +0 -0
  340. /package/dist/twilight/{p-6c83517d.entry.js.map → p-def552bd.entry.js.map} +0 -0
  341. /package/dist/twilight/{p-228d58df.system.entry.js.map → p-e4f73083.system.entry.js.map} +0 -0
  342. /package/dist/twilight/{p-a3ab451d.entry.js.map → p-e5872e75.entry.js.map} +0 -0
  343. /package/dist/twilight/{p-d0a760cc.entry.js.map → p-ed4c7158.entry.js.map} +0 -0
  344. /package/dist/twilight/{p-789f0166.system.entry.js.map → p-f1f3d74e.system.entry.js.map} +0 -0
  345. /package/dist/twilight/{p-ca88566e.entry.js.map → p-f3b8551c.entry.js.map} +0 -0
  346. /package/dist/twilight/{p-c63ddf33.entry.js.map → p-f41e7eed.entry.js.map} +0 -0
  347. /package/dist/twilight/{p-6fcc8ed3.entry.js.map → p-f4918259.entry.js.map} +0 -0
  348. /package/dist/twilight/{p-5b4f648e.entry.js.map → p-f9d8f20d.entry.js.map} +0 -0
  349. /package/dist/twilight/{p-2c11821b.entry.js.map → p-fb59e3b5.entry.js.map} +0 -0
@@ -0,0 +1,288 @@
1
+ /*!
2
+ * Crafted with ❤ by Salla
3
+ */
4
+ import { Host, h } from "@stencil/core";
5
+ import { DiscountType } from "./interfaces";
6
+ import { TIERED_OFFER_CONFIG } from "./constants";
7
+ import { TierUtils } from "./utils";
8
+ export class SallaTieredOffer {
9
+ constructor() {
10
+ this.currentTierIndex = 0;
11
+ this.canRender = false;
12
+ this.isLoading = false;
13
+ this.handleTabClick = (tierName) => {
14
+ this.activeTabTier = tierName;
15
+ };
16
+ salla.lang.onLoaded(() => {
17
+ this.loyaltyProgramText = salla.lang.get('blocks.tiered_offer.program_title');
18
+ this.currentTierText = salla.lang.get('blocks.tiered_offer.current_tier');
19
+ this.discountText = salla.lang.get('blocks.tiered_offer.discount');
20
+ this.benefitText = salla.lang.get('blocks.tiered_offer.tier_description');
21
+ });
22
+ }
23
+ async componentWillLoad() {
24
+ try {
25
+ await salla.onReady();
26
+ if (!this.checkFeatureEnabled()) {
27
+ return;
28
+ }
29
+ if (!this.checkCartExists()) {
30
+ return;
31
+ }
32
+ this.isLoading = true;
33
+ const offerData = await this.fetchTieredOfferData();
34
+ if (!offerData) {
35
+ return;
36
+ }
37
+ this.initializeComponent(offerData);
38
+ }
39
+ catch (error) {
40
+ this.canRender = false;
41
+ salla.logger.warn('salla-tiered-offer:: ', error);
42
+ }
43
+ finally {
44
+ this.isLoading = false;
45
+ }
46
+ }
47
+ checkFeatureEnabled() {
48
+ var _a;
49
+ return (_a = salla.config.get('store.features')) === null || _a === void 0 ? void 0 : _a.includes('tiered-offer');
50
+ }
51
+ checkCartExists() {
52
+ var _a, _b;
53
+ return !!((_b = (_a = salla.storage.get("cart")) === null || _a === void 0 ? void 0 : _a.summary) === null || _b === void 0 ? void 0 : _b.count);
54
+ }
55
+ validateCouponCompatibility(offerData, cartCoupon) {
56
+ var _a;
57
+ // If coupon is applied but offer doesn't support coupons, widget should be hidden
58
+ return !(cartCoupon && !((_a = offerData.details) === null || _a === void 0 ? void 0 : _a.applied_with_coupon));
59
+ }
60
+ async fetchTieredOfferData() {
61
+ var _a;
62
+ try {
63
+ const { data } = await salla.api.cart.offers();
64
+ const tieredOffer = data.find(offer => offer.type === "tiered_offer");
65
+ if (!tieredOffer) {
66
+ return null;
67
+ }
68
+ // Hide widget if coupon is applied and offer doesn't support coupons
69
+ if (!this.validateCouponCompatibility(tieredOffer, (_a = salla.storage.get("cart")) === null || _a === void 0 ? void 0 : _a.coupon)) {
70
+ this.canRender = false;
71
+ return null;
72
+ }
73
+ return tieredOffer;
74
+ }
75
+ catch (error) {
76
+ throw error;
77
+ }
78
+ }
79
+ initializeComponent(apiOfferData) {
80
+ var _a;
81
+ this.apiOfferData = apiOfferData;
82
+ // Map tiered details data to component format
83
+ this.tieredOfferData = this.mapApiDataToTiers(this.apiOfferData);
84
+ this.loyaltyProgramText = this.apiOfferData.title || this.loyaltyProgramText;
85
+ // Find current tier index based on current_value from API
86
+ const currentValue = ((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.current_value) || 0;
87
+ const currentTierIndex = this.findCurrentTierIndex(currentValue);
88
+ // Only render if user has reached at least the first tier
89
+ if (currentTierIndex === 0) {
90
+ this.canRender = false;
91
+ return;
92
+ }
93
+ this.currentTierIndex = currentTierIndex;
94
+ this.currentTier = TierUtils.getTierNameByIndex(this.tieredOfferData.tiers, currentTierIndex);
95
+ this.activeTabTier = this.currentTier;
96
+ this.canRender = true;
97
+ }
98
+ componentDidLoad() {
99
+ salla.event.on("cart::updated", (updatedCart) => {
100
+ this.updateOfferValues(updatedCart);
101
+ });
102
+ }
103
+ mapApiDataToTiers(apiData) {
104
+ // Sort discounts by min_spend to create proper tier order
105
+ const sortedDiscounts = [...apiData.details.discounts].sort((a, b) => a.min_spend - b.min_spend);
106
+ const tiers = sortedDiscounts.map((discount, index) => ({
107
+ name: discount.name,
108
+ tier_name: discount.name,
109
+ discount: discount.type === DiscountType.PERCENTAGE ? `${salla.helpers.number(discount.value)}%` : salla.money(discount.value),
110
+ icon: TIERED_OFFER_CONFIG.staticIcons[index] || TIERED_OFFER_CONFIG.staticIcons[0],
111
+ threshold: discount.min_spend,
112
+ text_color: TIERED_OFFER_CONFIG.staticColors[index],
113
+ index: index + 1
114
+ }));
115
+ return {
116
+ current_tier: TierUtils.getTierNameByIndex(tiers, this.findCurrentTierIndex(apiData.details.current_value, tiers)),
117
+ tiers
118
+ };
119
+ }
120
+ findCurrentTierIndex(currentValue, tiers) {
121
+ var _a;
122
+ if (tiers === void 0) {
123
+ tiers = (_a = this.tieredOfferData) === null || _a === void 0 ? void 0 : _a.tiers;
124
+ }
125
+ return TierUtils.findCurrentTierIndex(currentValue, tiers || []);
126
+ }
127
+ updateOfferValues(updatedCart) {
128
+ var _a;
129
+ if (!this.apiOfferData || !this.tieredOfferData) {
130
+ return;
131
+ }
132
+ // Check coupon compatibility
133
+ if (!this.validateCouponCompatibility(this.apiOfferData, updatedCart.coupon)) {
134
+ this.canRender = false;
135
+ return;
136
+ }
137
+ // If no coupon conflict, show widget
138
+ this.canRender = true;
139
+ // Check if this offer should update with cart changes
140
+ if (((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.with_current_cart) === false) {
141
+ return;
142
+ }
143
+ // Update current_value in API offer data
144
+ const currentValue = updatedCart.sub_total;
145
+ this.apiOfferData = Object.assign(Object.assign({}, this.apiOfferData), { details: Object.assign(Object.assign({}, this.apiOfferData.details), { current_value: currentValue }) });
146
+ // Update current tier based on new value
147
+ const newTierIndex = this.findCurrentTierIndex(currentValue);
148
+ // Check if user qualifies for any tier
149
+ if (newTierIndex === 0) {
150
+ this.canRender = false;
151
+ return;
152
+ }
153
+ // user qualifies show widget
154
+ this.canRender = true;
155
+ this.currentTierIndex = newTierIndex;
156
+ this.currentTier = TierUtils.getTierNameByIndex(this.tieredOfferData.tiers, newTierIndex);
157
+ // Update active tab if needed
158
+ if (this.activeTabTier !== this.currentTier) {
159
+ this.activeTabTier = this.currentTier;
160
+ }
161
+ }
162
+ getLoadingSkeletonView() {
163
+ return h(Host, null, h("div", { class: "s-tiered-offer-container" }, h("div", { class: "s-tiered-offer-skeleton-wrapper" }, h("div", { class: "s-tiered-offer-skeleton-title" }, h("salla-skeleton", { height: "16px", width: "40%" })), h("div", { class: "s-tiered-offer-skeleton-subtitle" }, h("salla-skeleton", { height: "20px", width: "60%" })), h("div", { class: "s-tiered-offer-skeleton-progress" }, h("salla-skeleton", { height: "16px", width: "100%" })), h("div", { class: "s-tiered-offer-skeleton-tabs" }, h("salla-skeleton", { height: "50px", width: "100%" })))));
164
+ }
165
+ getCurrentTierData() {
166
+ return TierUtils.findTierByIndex(this.tieredOfferData.tiers, this.currentTierIndex) || this.tieredOfferData.tiers[0];
167
+ }
168
+ getProgressWidth() {
169
+ var _a;
170
+ const currentValue = ((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.current_value) || 0;
171
+ const totalTiers = this.tieredOfferData.tiers.length;
172
+ // Use existing method to find current tier index (which already handles the logic)
173
+ const currentTierIndex = this.findCurrentTierIndex(currentValue);
174
+ // Convert to 0-based index for progress calculation
175
+ const completedTiers = currentTierIndex;
176
+ return (completedTiers / totalTiers) * 100;
177
+ }
178
+ calculateMilestonePosition(index, totalTiers) {
179
+ if (totalTiers === 1) {
180
+ return 'calc(100% - 18px)';
181
+ }
182
+ const milestonePercent = ((index + 1) / totalTiers) * 100;
183
+ const offsetPercent = 8 / totalTiers;
184
+ return `${Math.max(2, Math.min(95, milestonePercent - offsetPercent))}%`;
185
+ }
186
+ getMilestoneStyles(tier, index, totalTiers) {
187
+ const isRtl = document.documentElement.dir === 'rtl';
188
+ const adjustedPercent = this.calculateMilestonePosition(index, totalTiers);
189
+ const alignItems = tier.name.length > 6 ? 'flex-end' : 'center';
190
+ return {
191
+ [isRtl ? 'right' : 'left']: adjustedPercent,
192
+ alignItems,
193
+ position: 'absolute',
194
+ transform: isRtl ? 'translateX(50%)' : 'translateX(-50%)'
195
+ };
196
+ }
197
+ getMilestoneIconStyles(tier, isCurrent, isReached) {
198
+ if (isCurrent) {
199
+ return { color: tier.text_color };
200
+ }
201
+ if (isReached) {
202
+ return { color: 'var(--color-primary)' };
203
+ }
204
+ return {};
205
+ }
206
+ renderProgressBarBackground(progressWidth) {
207
+ return [
208
+ h("div", { class: "s-tiered-offer-progress-bg" }),
209
+ h("div", { class: "s-tiered-offer-progress-fill", style: { width: `${progressWidth}%` } })
210
+ ];
211
+ }
212
+ renderMilestoneIcon(tier, isCurrent, isReached) {
213
+ const iconClasses = [
214
+ 's-tiered-offer-milestone-icon',
215
+ isCurrent ? 's-tiered-offer-milestone-active' : '',
216
+ isReached ? 's-tiered-offer-milestone-completed' : ''
217
+ ].filter(Boolean).join(' ');
218
+ return (h("div", { class: iconClasses, style: this.getMilestoneIconStyles(tier, isCurrent, isReached) }, h("span", { innerHTML: tier.icon })));
219
+ }
220
+ renderMilestoneName(tier, isCurrent) {
221
+ return (h("div", { class: "s-tiered-offer-milestone-name" }, isCurrent && (h("span", { style: { color: tier.text_color } }, tier.name))));
222
+ }
223
+ renderMilestones(currentValue, totalTiers) {
224
+ const containerClass = totalTiers === 1
225
+ ? 's-tiered-offer-single-milestone-justify-end'
226
+ : 's-tiered-offer-milestones';
227
+ return (h("div", { class: "s-tiered-offer-milestones-wrapper" }, h("div", { class: containerClass }, this.tieredOfferData.tiers.map((tier, index) => {
228
+ const isReached = currentValue >= tier.threshold;
229
+ const isCurrent = tier.tier_name === this.currentTier;
230
+ return (h("div", { class: "s-tiered-offer-milestone", style: this.getMilestoneStyles(tier, index, totalTiers) }, this.renderMilestoneIcon(tier, isCurrent, isReached), this.renderMilestoneName(tier, isCurrent)));
231
+ }))));
232
+ }
233
+ renderProgressBar() {
234
+ var _a;
235
+ const progressWidth = this.getProgressWidth();
236
+ const totalTiers = this.tieredOfferData.tiers.length;
237
+ const currentValue = ((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.current_value) || 0;
238
+ return (h("div", { class: "s-tiered-offer-progress-container" }, h("div", { class: "s-tiered-offer-progress-wrapper" }, this.renderProgressBarBackground(progressWidth), this.renderMilestones(currentValue, totalTiers))));
239
+ }
240
+ renderTabs() {
241
+ return (h("div", { class: "s-tiered-offer-tabs-container" }, h("div", { class: "s-tiered-offer-tab-headers" }, this.tieredOfferData.tiers.map(tier => {
242
+ const isActive = tier.tier_name === this.activeTabTier;
243
+ return (h("button", { class: `s-tiered-offer-tab-header ${isActive ? 's-tiered-offer-tab-active' : ''}`, onClick: () => this.handleTabClick(tier.tier_name) }, h("span", null, tier.name)));
244
+ })), h("div", { class: "s-tiered-offer-tab-content-wrapper" }, (() => {
245
+ const activeTier = TierUtils.findTierByName(this.tieredOfferData.tiers, this.activeTabTier);
246
+ if (!activeTier)
247
+ return null;
248
+ return (h("div", { class: "s-tiered-offer-tab-content" }, h("div", { class: "s-tiered-offer-tab-content-inner" }, h("div", { class: "s-tiered-offer-discount-section" }, h("p", { class: "s-tiered-offer-discount-title" }, this.discountText, " ", h("span", { innerHTML: activeTier.discount })), h("p", { class: "s-tiered-offer-benefit-description" }, this.benefitText, " ", activeTier.name)))));
249
+ })())));
250
+ }
251
+ render() {
252
+ if (this.isLoading) {
253
+ return this.getLoadingSkeletonView();
254
+ }
255
+ if (!this.canRender || !this.tieredOfferData) {
256
+ return null;
257
+ }
258
+ const currentTierData = this.getCurrentTierData();
259
+ return (h(Host, null, h("div", { class: "s-tiered-offer-container" }, h("div", { class: "s-tiered-offer-header" }, h("div", { class: "s-tiered-offer-header-content" }, h("p", { class: "s-tiered-offer-program-title" }, this.loyaltyProgramText), h("div", { class: "s-tiered-offer-current-tier-name-wrapper" }, h("h2", { class: "s-tiered-offer-current-tier" }, this.currentTierText, " ", h("span", { class: "s-tiered-offer-tier-name" }, currentTierData.name)), h("span", { innerHTML: currentTierData.icon })))), this.renderProgressBar(), this.renderTabs())));
260
+ }
261
+ static get is() { return "salla-tiered-offer"; }
262
+ static get originalStyleUrls() {
263
+ return {
264
+ "$": ["salla-tiered-offer.scss"]
265
+ };
266
+ }
267
+ static get styleUrls() {
268
+ return {
269
+ "$": ["salla-tiered-offer.css"]
270
+ };
271
+ }
272
+ static get states() {
273
+ return {
274
+ "tieredOfferData": {},
275
+ "apiOfferData": {},
276
+ "currentTierIndex": {},
277
+ "currentTier": {},
278
+ "activeTabTier": {},
279
+ "canRender": {},
280
+ "isLoading": {},
281
+ "loyaltyProgramText": {},
282
+ "currentTierText": {},
283
+ "discountText": {},
284
+ "benefitText": {}
285
+ };
286
+ }
287
+ }
288
+ //# sourceMappingURL=salla-tiered-offer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"salla-tiered-offer.js","sourceRoot":"","sources":["../../../src/components/salla-tiered-offer/salla-tiered-offer.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, h, State } from '@stencil/core';\nimport { Offer, TieredOfferTier, TieredOfferData, DiscountType } from './interfaces';\nimport { TIERED_OFFER_CONFIG } from './constants';\nimport { TierUtils } from './utils';\n\n@Component({\n tag: 'salla-tiered-offer',\n styleUrl: 'salla-tiered-offer.scss',\n})\nexport class SallaTieredOffer {\n\n constructor() {\n salla.lang.onLoaded(() => {\n this.loyaltyProgramText = salla.lang.get('blocks.tiered_offer.program_title');\n this.currentTierText = salla.lang.get('blocks.tiered_offer.current_tier');\n this.discountText = salla.lang.get('blocks.tiered_offer.discount');\n this.benefitText = salla.lang.get('blocks.tiered_offer.tier_description');\n });\n }\n\n\n @State() tieredOfferData: TieredOfferData;\n @State() apiOfferData: Offer;\n @State() currentTierIndex: number = 0;\n @State() currentTier: string;\n @State() activeTabTier: string;\n\n @State() canRender: boolean = false;\n @State() isLoading: boolean = false;\n\n // Language strings\n @State() loyaltyProgramText: string;\n @State() currentTierText: string;\n @State() discountText: string;\n @State() benefitText: string;\n\n async componentWillLoad() {\n try {\n await salla.onReady();\n \n if (!this.checkFeatureEnabled()) {\n return;\n }\n \n if (!this.checkCartExists()) {\n return;\n }\n \n this.isLoading = true;\n \n const offerData = await this.fetchTieredOfferData();\n if (!offerData) {\n return;\n }\n \n this.initializeComponent(offerData);\n \n } catch (error) {\n this.canRender = false;\n salla.logger.warn('salla-tiered-offer:: ', error);\n } finally {\n this.isLoading = false;\n }\n }\n \n private checkFeatureEnabled(): boolean {\n return salla.config.get('store.features')?.includes('tiered-offer');\n }\n \n private checkCartExists(): boolean {\n return !!salla.storage.get(\"cart\")?.summary?.count;\n }\n \n private validateCouponCompatibility(offerData: Offer, cartCoupon?: any): boolean {\n // If coupon is applied but offer doesn't support coupons, widget should be hidden\n return !(cartCoupon && !offerData.details?.applied_with_coupon);\n }\n \n private async fetchTieredOfferData(): Promise<Offer | null> {\n try {\n const { data }: { data: Offer[] } = await salla.api.cart.offers();\n const tieredOffer = data.find(offer => offer.type === \"tiered_offer\");\n \n if (!tieredOffer) {\n return null;\n }\n \n // Hide widget if coupon is applied and offer doesn't support coupons\n if (!this.validateCouponCompatibility(tieredOffer, salla.storage.get(\"cart\")?.coupon)) {\n this.canRender = false;\n return null;\n }\n \n return tieredOffer;\n } catch (error) {\n throw error;\n }\n }\n \n private initializeComponent(apiOfferData: Offer): void {\n this.apiOfferData = apiOfferData;\n \n // Map tiered details data to component format\n this.tieredOfferData = this.mapApiDataToTiers(this.apiOfferData);\n this.loyaltyProgramText = this.apiOfferData.title || this.loyaltyProgramText;\n \n // Find current tier index based on current_value from API\n const currentValue = this.apiOfferData.details?.current_value || 0;\n const currentTierIndex = this.findCurrentTierIndex(currentValue);\n \n // Only render if user has reached at least the first tier\n if (currentTierIndex === 0) {\n this.canRender = false;\n return;\n }\n \n this.currentTierIndex = currentTierIndex;\n this.currentTier = TierUtils.getTierNameByIndex(this.tieredOfferData.tiers, currentTierIndex);\n this.activeTabTier = this.currentTier;\n this.canRender = true;\n }\n\n componentDidLoad() {\n salla.event.on(\"cart::updated\", (updatedCart) => {\n this.updateOfferValues(updatedCart);\n });\n }\n\n private mapApiDataToTiers(apiData: Offer): TieredOfferData {\n // Sort discounts by min_spend to create proper tier order\n const sortedDiscounts = [...apiData.details.discounts].sort((a, b) => a.min_spend - b.min_spend);\n\n const tiers: TieredOfferTier[] = sortedDiscounts.map((discount, index) => ({\n name: discount.name, \n tier_name: discount.name, \n discount: discount.type === DiscountType.PERCENTAGE ? `${salla.helpers.number(discount.value)}%` : salla.money(discount.value),\n icon: TIERED_OFFER_CONFIG.staticIcons[index] || TIERED_OFFER_CONFIG.staticIcons[0], \n threshold: discount.min_spend,\n text_color: TIERED_OFFER_CONFIG.staticColors[index], \n index: index + 1\n }));\n\n return {\n current_tier: TierUtils.getTierNameByIndex(tiers, this.findCurrentTierIndex(apiData.details.current_value, tiers)),\n tiers\n };\n }\n\n private findCurrentTierIndex(currentValue: number, tiers = this.tieredOfferData?.tiers): number {\n return TierUtils.findCurrentTierIndex(currentValue, tiers || []);\n }\n\n private updateOfferValues(updatedCart: { items: any[], sub_total: number, coupon?: any }) {\n if (!this.apiOfferData || !this.tieredOfferData) {\n return;\n }\n\n // Check coupon compatibility\n if (!this.validateCouponCompatibility(this.apiOfferData, updatedCart.coupon)) {\n this.canRender = false;\n return;\n }\n\n // If no coupon conflict, show widget\n this.canRender = true;\n\n // Check if this offer should update with cart changes\n if (this.apiOfferData.details?.with_current_cart === false) {\n return;\n }\n\n // Update current_value in API offer data\n const currentValue = updatedCart.sub_total;\n this.apiOfferData = {\n ...this.apiOfferData,\n details: {\n ...this.apiOfferData.details,\n current_value: currentValue\n }\n };\n\n // Update current tier based on new value\n const newTierIndex = this.findCurrentTierIndex(currentValue);\n \n // Check if user qualifies for any tier\n if (newTierIndex === 0) {\n this.canRender = false;\n return;\n }\n\n // user qualifies show widget\n this.canRender = true;\n this.currentTierIndex = newTierIndex;\n this.currentTier = TierUtils.getTierNameByIndex(this.tieredOfferData.tiers, newTierIndex);\n \n // Update active tab if needed\n if (this.activeTabTier !== this.currentTier) {\n this.activeTabTier = this.currentTier;\n }\n }\n\n private getLoadingSkeletonView() {\n return <Host>\n <div class=\"s-tiered-offer-container\">\n <div class=\"s-tiered-offer-skeleton-wrapper\">\n <div class=\"s-tiered-offer-skeleton-title\">\n <salla-skeleton height=\"16px\" width=\"40%\" />\n </div>\n <div class=\"s-tiered-offer-skeleton-subtitle\">\n <salla-skeleton height=\"20px\" width=\"60%\" />\n </div>\n <div class=\"s-tiered-offer-skeleton-progress\">\n <salla-skeleton height=\"16px\" width=\"100%\" />\n </div>\n <div class=\"s-tiered-offer-skeleton-tabs\">\n <salla-skeleton height=\"50px\" width=\"100%\" />\n </div>\n </div>\n </div>\n </Host>\n }\n\n private getCurrentTierData(): TieredOfferTier {\n return TierUtils.findTierByIndex(this.tieredOfferData.tiers, this.currentTierIndex) || this.tieredOfferData.tiers[0];\n }\n\n private getProgressWidth(): number {\n const currentValue = this.apiOfferData.details?.current_value || 0;\n const totalTiers = this.tieredOfferData.tiers.length;\n \n // Use existing method to find current tier index (which already handles the logic)\n const currentTierIndex = this.findCurrentTierIndex(currentValue);\n \n // Convert to 0-based index for progress calculation\n const completedTiers = currentTierIndex;\n return (completedTiers / totalTiers) * 100;\n }\n\n private handleTabClick = (tierName: string) => {\n this.activeTabTier = tierName;\n }\n \n private calculateMilestonePosition(index: number, totalTiers: number): string {\n if (totalTiers === 1) {\n return 'calc(100% - 18px)';\n }\n const milestonePercent = ((index + 1) / totalTiers) * 100;\n const offsetPercent = 8 / totalTiers;\n return `${Math.max(2, Math.min(95, milestonePercent - offsetPercent))}%`;\n }\n \n private getMilestoneStyles(tier: TieredOfferTier, index: number, totalTiers: number) {\n const isRtl = document.documentElement.dir === 'rtl';\n const adjustedPercent = this.calculateMilestonePosition(index, totalTiers);\n const alignItems = tier.name.length > 6 ? 'flex-end' : 'center';\n \n return {\n [isRtl ? 'right' : 'left']: adjustedPercent,\n alignItems,\n position: 'absolute' as const,\n transform: isRtl ? 'translateX(50%)' : 'translateX(-50%)'\n };\n }\n \n private getMilestoneIconStyles(tier: TieredOfferTier, isCurrent: boolean, isReached: boolean) {\n if (isCurrent) {\n return { color: tier.text_color };\n }\n if (isReached) {\n return { color: 'var(--color-primary)' };\n }\n return {};\n }\n \n private renderProgressBarBackground(progressWidth: number) {\n return [\n <div class=\"s-tiered-offer-progress-bg\"></div>,\n <div \n class=\"s-tiered-offer-progress-fill\"\n style={{ width: `${progressWidth}%` }}>\n </div>\n ];\n }\n \n private renderMilestoneIcon(tier: TieredOfferTier, isCurrent: boolean, isReached: boolean) {\n const iconClasses = [\n 's-tiered-offer-milestone-icon',\n isCurrent ? 's-tiered-offer-milestone-active' : '',\n isReached ? 's-tiered-offer-milestone-completed' : ''\n ].filter(Boolean).join(' ');\n \n return (\n <div \n class={iconClasses}\n style={this.getMilestoneIconStyles(tier, isCurrent, isReached)}>\n <span innerHTML={tier.icon}></span>\n </div>\n );\n }\n \n private renderMilestoneName(tier: TieredOfferTier, isCurrent: boolean) {\n return (\n <div class=\"s-tiered-offer-milestone-name\">\n {isCurrent && (\n <span style={{ color: tier.text_color }}>\n {tier.name}\n </span>\n )}\n </div>\n );\n }\n \n private renderMilestones(currentValue: number, totalTiers: number) {\n const containerClass = totalTiers === 1 \n ? 's-tiered-offer-single-milestone-justify-end' \n : 's-tiered-offer-milestones';\n \n return (\n <div class=\"s-tiered-offer-milestones-wrapper\">\n <div class={containerClass}>\n {this.tieredOfferData.tiers.map((tier, index) => {\n const isReached = currentValue >= tier.threshold;\n const isCurrent = tier.tier_name === this.currentTier;\n \n return (\n <div \n class=\"s-tiered-offer-milestone\"\n style={this.getMilestoneStyles(tier, index, totalTiers)}>\n {this.renderMilestoneIcon(tier, isCurrent, isReached)}\n {this.renderMilestoneName(tier, isCurrent)}\n </div>\n );\n })}\n </div>\n </div>\n );\n }\n\n private renderProgressBar() {\n const progressWidth = this.getProgressWidth();\n const totalTiers = this.tieredOfferData.tiers.length;\n const currentValue = this.apiOfferData.details?.current_value || 0;\n\n return (\n <div class=\"s-tiered-offer-progress-container\">\n <div class=\"s-tiered-offer-progress-wrapper\">\n {this.renderProgressBarBackground(progressWidth)}\n {this.renderMilestones(currentValue, totalTiers)}\n </div>\n </div>\n );\n }\n\n private renderTabs() {\n return (\n <div class=\"s-tiered-offer-tabs-container\">\n {/* Tab Headers */}\n <div class=\"s-tiered-offer-tab-headers\">\n {this.tieredOfferData.tiers.map(tier => {\n const isActive = tier.tier_name === this.activeTabTier;\n return (\n <button \n class={`s-tiered-offer-tab-header ${isActive ? 's-tiered-offer-tab-active' : ''}`}\n onClick={() => this.handleTabClick(tier.tier_name)}>\n <span>{tier.name}</span>\n </button>\n );\n })}\n </div>\n\n {/* Tab Content */}\n <div class=\"s-tiered-offer-tab-content-wrapper\">\n {(() => {\n const activeTier = TierUtils.findTierByName(this.tieredOfferData.tiers, this.activeTabTier);\n if (!activeTier) return null;\n \n return (\n <div class=\"s-tiered-offer-tab-content\">\n <div class=\"s-tiered-offer-tab-content-inner\">\n <div class=\"s-tiered-offer-discount-section\">\n <p class=\"s-tiered-offer-discount-title\">\n {this.discountText} <span innerHTML={activeTier.discount}></span>\n </p>\n <p class=\"s-tiered-offer-benefit-description\">\n {this.benefitText} {activeTier.name}\n </p>\n </div>\n </div>\n </div>\n );\n })()}\n </div>\n </div>\n );\n }\n\n render() {\n \n if (this.isLoading) {\n return this.getLoadingSkeletonView();\n }\n\n if (!this.canRender || !this.tieredOfferData) {\n return null;\n }\n \n\n const currentTierData = this.getCurrentTierData();\n\n return (\n <Host>\n <div class=\"s-tiered-offer-container\">\n {/* Header Section */}\n <div class=\"s-tiered-offer-header\">\n <div class=\"s-tiered-offer-header-content\">\n <p class=\"s-tiered-offer-program-title\">{this.loyaltyProgramText}</p>\n <div class=\"s-tiered-offer-current-tier-name-wrapper\">\n <h2 class=\"s-tiered-offer-current-tier\">\n {this.currentTierText} <span class=\"s-tiered-offer-tier-name\">{currentTierData.name}</span>\n </h2>\n <span innerHTML={currentTierData.icon}></span>\n </div>\n </div>\n </div>\n\n {/* Progress Bar */}\n {this.renderProgressBar()}\n\n {/* Tabs */}\n {this.renderTabs()}\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -0,0 +1,38 @@
1
+ /*!
2
+ * Crafted with ❤ by Salla
3
+ */
4
+ export class TierUtils {
5
+ /**
6
+ * Find tier by index
7
+ */
8
+ static findTierByIndex(tiers, index) {
9
+ return tiers.find(tier => tier.index === index) || null;
10
+ }
11
+ /**
12
+ * Find tier by tier name
13
+ */
14
+ static findTierByName(tiers, tierName) {
15
+ return tiers.find(tier => tier.tier_name === tierName) || null;
16
+ }
17
+ /**
18
+ * Get tier name by index
19
+ */
20
+ static getTierNameByIndex(tiers, index) {
21
+ var _a;
22
+ return (_a = this.findTierByIndex(tiers, index)) === null || _a === void 0 ? void 0 : _a.tier_name;
23
+ }
24
+ /**
25
+ * Find current tier index based on current value
26
+ */
27
+ static findCurrentTierIndex(currentValue, tiers) {
28
+ if (!tiers)
29
+ return 0;
30
+ for (let i = tiers.length - 1; i >= 0; i--) {
31
+ if (currentValue >= tiers[i].threshold) {
32
+ return tiers[i].index;
33
+ }
34
+ }
35
+ return 0;
36
+ }
37
+ }
38
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/components/salla-tiered-offer/utils.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,SAAS;IACpB;;OAEG;IACH,MAAM,CAAC,eAAe,CAAC,KAAwB,EAAE,KAAa;QAC5D,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC;IAC1D,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,cAAc,CAAC,KAAwB,EAAE,QAAgB;QAC9D,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAC,IAAI,IAAI,CAAC;IACjE,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,kBAAkB,CAAC,KAAwB,EAAE,KAAa;;QAC/D,OAAO,MAAA,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,0CAAE,SAAS,CAAC;IACvD,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,oBAAoB,CAAC,YAAoB,EAAE,KAAwB;QACxE,IAAI,CAAC,KAAK;YAAE,OAAO,CAAC,CAAC;QAErB,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3C,IAAI,YAAY,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;gBACvC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACxB,CAAC;QACH,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;CACF","sourcesContent":["import { TieredOfferTier } from './interfaces';\n\nexport class TierUtils {\n /**\n * Find tier by index\n */\n static findTierByIndex(tiers: TieredOfferTier[], index: number): TieredOfferTier | null {\n return tiers.find(tier => tier.index === index) || null;\n }\n\n /**\n * Find tier by tier name\n */\n static findTierByName(tiers: TieredOfferTier[], tierName: string): TieredOfferTier | null {\n return tiers.find(tier => tier.tier_name === tierName) || null;\n }\n\n /**\n * Get tier name by index\n */\n static getTierNameByIndex(tiers: TieredOfferTier[], index: number): string | undefined {\n return this.findTierByIndex(tiers, index)?.tier_name;\n }\n\n /**\n * Find current tier index based on current value\n */\n static findCurrentTierIndex(currentValue: number, tiers: TieredOfferTier[]): number {\n if (!tiers) return 0;\n \n for (let i = tiers.length - 1; i >= 0; i--) {\n if (currentValue >= tiers[i].threshold) {\n return tiers[i].index;\n }\n }\n return 0;\n }\n}"]}