@salla.sa/twilight-components 2.14.219 → 2.14.221
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/{app-globals-DwcsRV1q.js → app-globals-CURclN4K.js} +3 -3
- package/dist/cjs/{app-globals-DwcsRV1q.js.map → app-globals-CURclN4K.js.map} +1 -1
- package/dist/cjs/{index-CcKYmcmm.js → index-1TYwVkJb.js} +8 -4
- package/dist/cjs/index-1TYwVkJb.js.map +1 -0
- package/dist/cjs/loader.cjs.js +3 -3
- package/dist/cjs/salla-accordion-body.cjs.entry.js +1 -1
- package/dist/cjs/salla-accordion-head.cjs.entry.js +1 -1
- package/dist/cjs/salla-accordion.cjs.entry.js +1 -1
- package/dist/cjs/salla-add-product-button_51.cjs.entry.js +1 -1
- package/dist/cjs/salla-advertisement.cjs.entry.js +1 -1
- package/dist/cjs/salla-app-install-alert.cjs.entry.js +1 -1
- package/dist/cjs/salla-apps-icons.cjs.entry.js +1 -1
- package/dist/cjs/salla-booking-field_2.cjs.entry.js +1 -1
- package/dist/cjs/salla-cart-item-offers.cjs.entry.js +1 -1
- package/dist/cjs/salla-conditional-offer.cjs.entry.js +1 -1
- package/dist/cjs/salla-contacts.cjs.entry.js +1 -1
- package/dist/cjs/salla-filters-widget.cjs.entry.js +1 -1
- package/dist/cjs/salla-filters.cjs.entry.js +1 -1
- package/dist/cjs/salla-installment.cjs.entry.js +1 -1
- package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +1 -1
- package/dist/cjs/salla-loyalty-program.cjs.entry.js +1 -1
- package/dist/cjs/salla-metadata.cjs.entry.js +1 -1
- package/dist/cjs/salla-notification-item.cjs.entry.js +1 -1
- package/dist/cjs/salla-notifications.cjs.entry.js +1 -1
- package/dist/cjs/salla-offer.cjs.entry.js +1 -1
- package/dist/cjs/salla-order-summary.cjs.entry.js +1 -1
- package/dist/cjs/salla-orders.cjs.entry.js +1 -1
- package/dist/cjs/salla-payments.cjs.entry.js +1 -1
- package/dist/cjs/salla-price-range.cjs.entry.js +1 -1
- package/dist/cjs/salla-product-options.cjs.entry.js +1 -1
- package/dist/cjs/salla-review-card.cjs.entry.js +1 -1
- package/dist/cjs/salla-reviews-page.cjs.entry.js +1 -1
- package/dist/cjs/salla-reviews.cjs.entry.js +1 -1
- package/dist/cjs/salla-social.cjs.entry.js +1 -1
- package/dist/cjs/salla-tiered-offer.cjs.entry.js +338 -0
- package/dist/cjs/salla-tiered-offer.cjs.entry.js.map +1 -0
- package/dist/cjs/salla-tiered-offer.entry.cjs.js.map +1 -0
- package/dist/cjs/salla-tooltip.cjs.entry.js +1 -1
- package/dist/cjs/salla-verify.cjs.entry.js +1 -1
- package/dist/cjs/salla-wallet.cjs.entry.js +1 -1
- package/dist/cjs/twilight.cjs.js +3 -3
- package/dist/collection/assets/svg/diamond-02.svg +4 -0
- package/dist/collection/assets/svg/gold.svg +6 -0
- package/dist/collection/assets/svg/star-rounded.svg +3 -0
- package/dist/collection/assets/svg/stars.svg +5 -0
- package/dist/collection/collection-manifest.json +1 -0
- package/dist/collection/components/salla-tiered-offer/constants.js +12 -0
- package/dist/collection/components/salla-tiered-offer/constants.js.map +1 -0
- package/dist/collection/components/salla-tiered-offer/interfaces.js +9 -0
- package/dist/collection/components/salla-tiered-offer/interfaces.js.map +1 -0
- package/dist/collection/components/salla-tiered-offer/salla-tiered-offer.css +26 -0
- package/dist/collection/components/salla-tiered-offer/salla-tiered-offer.js +288 -0
- package/dist/collection/components/salla-tiered-offer/salla-tiered-offer.js.map +1 -0
- package/dist/collection/components/salla-tiered-offer/utils.js +38 -0
- package/dist/collection/components/salla-tiered-offer/utils.js.map +1 -0
- package/dist/components/index.js +2 -2
- package/dist/components/index.js.map +1 -1
- package/dist/components/salla-tiered-offer.d.ts +11 -0
- package/dist/components/salla-tiered-offer.js +371 -0
- package/dist/components/salla-tiered-offer.js.map +1 -0
- package/dist/esm/{app-globals-C4AMOceU.js → app-globals-CIvCwBrC.js} +3 -3
- package/dist/esm/{app-globals-C4AMOceU.js.map → app-globals-CIvCwBrC.js.map} +1 -1
- package/dist/esm/{index-5Ng8LPjI.js → index-DJeJWTdD.js} +8 -4
- package/dist/esm/index-DJeJWTdD.js.map +1 -0
- package/dist/esm/loader.js +4 -4
- package/dist/esm/salla-accordion-body.entry.js +1 -1
- package/dist/esm/salla-accordion-head.entry.js +1 -1
- package/dist/esm/salla-accordion.entry.js +1 -1
- package/dist/esm/salla-add-product-button_51.entry.js +1 -1
- package/dist/esm/salla-advertisement.entry.js +1 -1
- package/dist/esm/salla-app-install-alert.entry.js +1 -1
- package/dist/esm/salla-apps-icons.entry.js +1 -1
- package/dist/esm/salla-booking-field_2.entry.js +1 -1
- package/dist/esm/salla-cart-item-offers.entry.js +1 -1
- package/dist/esm/salla-conditional-offer.entry.js +1 -1
- package/dist/esm/salla-contacts.entry.js +1 -1
- package/dist/esm/salla-filters-widget.entry.js +1 -1
- package/dist/esm/salla-filters.entry.js +1 -1
- package/dist/esm/salla-installment.entry.js +1 -1
- package/dist/esm/salla-loyalty-prize-item.entry.js +1 -1
- package/dist/esm/salla-loyalty-program.entry.js +1 -1
- package/dist/esm/salla-metadata.entry.js +1 -1
- package/dist/esm/salla-notification-item.entry.js +1 -1
- package/dist/esm/salla-notifications.entry.js +1 -1
- package/dist/esm/salla-offer.entry.js +1 -1
- package/dist/esm/salla-order-summary.entry.js +1 -1
- package/dist/esm/salla-orders.entry.js +1 -1
- package/dist/esm/salla-payments.entry.js +1 -1
- package/dist/esm/salla-price-range.entry.js +1 -1
- package/dist/esm/salla-product-options.entry.js +1 -1
- package/dist/esm/salla-review-card.entry.js +1 -1
- package/dist/esm/salla-reviews-page.entry.js +1 -1
- package/dist/esm/salla-reviews.entry.js +1 -1
- package/dist/esm/salla-social.entry.js +1 -1
- package/dist/esm/salla-tiered-offer.entry.js +336 -0
- package/dist/esm/salla-tiered-offer.entry.js.map +1 -0
- package/dist/esm/salla-tooltip.entry.js +1 -1
- package/dist/esm/salla-verify.entry.js +1 -1
- package/dist/esm/salla-wallet.entry.js +1 -1
- package/dist/esm/twilight.js +4 -4
- package/dist/esm-es5/{app-globals-C4AMOceU.js → app-globals-CIvCwBrC.js} +2 -2
- package/dist/esm-es5/{app-globals-C4AMOceU.js.map → app-globals-CIvCwBrC.js.map} +1 -1
- package/dist/esm-es5/{index-5Ng8LPjI.js → index-DJeJWTdD.js} +3 -3
- package/dist/esm-es5/index-DJeJWTdD.js.map +1 -0
- package/dist/esm-es5/loader.js +1 -1
- package/dist/esm-es5/salla-accordion-body.entry.js +1 -1
- package/dist/esm-es5/salla-accordion-head.entry.js +1 -1
- package/dist/esm-es5/salla-accordion.entry.js +1 -1
- package/dist/esm-es5/salla-add-product-button_51.entry.js +4 -4
- package/dist/esm-es5/salla-advertisement.entry.js +1 -1
- package/dist/esm-es5/salla-app-install-alert.entry.js +1 -1
- package/dist/esm-es5/salla-apps-icons.entry.js +1 -1
- package/dist/esm-es5/salla-booking-field_2.entry.js +1 -1
- package/dist/esm-es5/salla-cart-item-offers.entry.js +1 -1
- package/dist/esm-es5/salla-conditional-offer.entry.js +1 -1
- package/dist/esm-es5/salla-contacts.entry.js +1 -1
- package/dist/esm-es5/salla-filters-widget.entry.js +1 -1
- package/dist/esm-es5/salla-filters.entry.js +1 -1
- package/dist/esm-es5/salla-installment.entry.js +1 -1
- package/dist/esm-es5/salla-loyalty-prize-item.entry.js +1 -1
- package/dist/esm-es5/salla-loyalty-program.entry.js +2 -2
- package/dist/esm-es5/salla-metadata.entry.js +1 -1
- package/dist/esm-es5/salla-notification-item.entry.js +1 -1
- package/dist/esm-es5/salla-notifications.entry.js +1 -1
- package/dist/esm-es5/salla-offer.entry.js +1 -1
- package/dist/esm-es5/salla-order-summary.entry.js +1 -1
- package/dist/esm-es5/salla-orders.entry.js +1 -1
- package/dist/esm-es5/salla-payments.entry.js +1 -1
- package/dist/esm-es5/salla-price-range.entry.js +1 -1
- package/dist/esm-es5/salla-product-options.entry.js +1 -1
- package/dist/esm-es5/salla-review-card.entry.js +1 -1
- package/dist/esm-es5/salla-reviews-page.entry.js +1 -1
- package/dist/esm-es5/salla-reviews.entry.js +1 -1
- package/dist/esm-es5/salla-social.entry.js +1 -1
- package/dist/esm-es5/salla-tiered-offer.entry.js +5 -0
- package/dist/esm-es5/salla-tiered-offer.entry.js.map +1 -0
- package/dist/esm-es5/salla-tooltip.entry.js +1 -1
- package/dist/esm-es5/salla-verify.entry.js +1 -1
- package/dist/esm-es5/salla-wallet.entry.js +1 -1
- package/dist/esm-es5/twilight.js +1 -1
- package/dist/twilight/{p-7f275c07.entry.js → p-018db6d5.entry.js} +2 -2
- package/dist/twilight/{p-592ab962.system.entry.js → p-01ab98b8.system.entry.js} +2 -2
- package/dist/twilight/{p-0997acd6.system.entry.js → p-0213d2ff.system.entry.js} +2 -2
- package/dist/twilight/{p-27b836fc.entry.js → p-0530fecd.entry.js} +2 -2
- package/dist/twilight/{p-a3867f03.system.entry.js → p-0a564fe6.system.entry.js} +2 -2
- package/dist/twilight/{p-3f87edc6.entry.js → p-0bd54dae.entry.js} +2 -2
- package/dist/twilight/{p-87ed46f2.entry.js → p-11542446.entry.js} +2 -2
- package/dist/twilight/{p-817c183a.entry.js → p-1196a23a.entry.js} +2 -2
- package/dist/twilight/{p-5bcba29f.system.entry.js → p-125e8e09.system.entry.js} +2 -2
- package/dist/twilight/{p-bb0a64fb.system.entry.js → p-137b9ced.system.entry.js} +2 -2
- package/dist/twilight/{p-4aec7d12.system.entry.js → p-14bce2e7.system.entry.js} +2 -2
- package/dist/twilight/{p-63f7bf97.system.entry.js → p-1bc7d70c.system.entry.js} +2 -2
- package/dist/twilight/{p-026b2234.system.entry.js → p-1c1baf96.system.entry.js} +2 -2
- package/dist/twilight/{p-7e2380cb.entry.js → p-1e32544e.entry.js} +2 -2
- package/dist/twilight/{p-CW47XnO5.system.js → p-1xnr2J3b.system.js} +6 -6
- package/dist/twilight/p-1xnr2J3b.system.js.map +1 -0
- package/dist/twilight/{p-b56edfc7.system.entry.js → p-2411b6cb.system.entry.js} +2 -2
- package/dist/twilight/{p-cd1a5066.system.entry.js → p-2943fae2.system.entry.js} +2 -2
- package/dist/twilight/{p-fe03bd17.entry.js → p-2e1838fc.entry.js} +2 -2
- package/dist/twilight/{p-606c8dfc.entry.js → p-2ecd9c73.entry.js} +2 -2
- package/dist/twilight/{p-917f2e0d.entry.js → p-345e7510.entry.js} +2 -2
- package/dist/twilight/{p-uTVeOuzK.system.js.map → p-3_GHqNLe.system.js.map} +1 -1
- package/dist/twilight/{p-B5V-3iwA.system.js.map → p-3iOHI_bZ.system.js.map} +1 -1
- package/dist/twilight/{p-50348764.entry.js → p-4719adfd.entry.js} +2 -2
- package/dist/twilight/{p-27fa775d.system.entry.js → p-512dbfd8.system.entry.js} +2 -2
- package/dist/twilight/{p-5092bc1b.system.entry.js → p-5222370a.system.entry.js} +2 -2
- package/dist/twilight/p-56329c93.system.entry.js +5 -0
- package/dist/twilight/{p-4defb732.entry.js → p-594c82e8.entry.js} +2 -2
- package/dist/twilight/{p-4260bfbf.entry.js → p-5a3e638f.entry.js} +2 -2
- package/dist/twilight/{p-89b36aa5.entry.js → p-5f22ded8.entry.js} +2 -2
- package/dist/twilight/{p-d39080ee.system.entry.js → p-60550d95.system.entry.js} +2 -2
- package/dist/twilight/{p-e7267b4b.system.entry.js → p-611a0591.system.entry.js} +2 -2
- package/dist/twilight/{p-6ccab36e.entry.js → p-62372bb6.entry.js} +2 -2
- package/dist/twilight/{p-2378fcc3.system.entry.js → p-64346d4f.system.entry.js} +2 -2
- package/dist/twilight/{p-725de283.system.entry.js → p-65f8266c.system.entry.js} +2 -2
- package/dist/twilight/{p-0c73100c.entry.js → p-7dc53e3e.entry.js} +2 -2
- package/dist/twilight/{p-e182183b.entry.js → p-84aaa78d.entry.js} +2 -2
- package/dist/twilight/{p-b66d9649.system.entry.js → p-8b0b63d3.system.entry.js} +2 -2
- package/dist/twilight/p-8b9cdaa8.system.entry.js +5 -0
- package/dist/twilight/p-8b9cdaa8.system.entry.js.map +1 -0
- package/dist/twilight/{p-74922500.entry.js → p-8d171391.entry.js} +2 -2
- package/dist/twilight/{p-568ca254.system.entry.js → p-8d241400.system.entry.js} +2 -2
- package/dist/twilight/{p-b0b3047d.entry.js → p-8f504c22.entry.js} +2 -2
- package/dist/twilight/{p-059307d0.system.entry.js → p-96c0dbe6.system.entry.js} +2 -2
- package/dist/twilight/{p-6831d2b2.entry.js → p-9c6d592b.entry.js} +2 -2
- package/dist/twilight/{p-jJ43wXLr.system.js.map → p-B0iUa0dk.system.js.map} +1 -1
- package/dist/twilight/{p-C435-Ngu.system.js.map → p-B78CJAeo.system.js.map} +1 -1
- package/dist/twilight/{p-7SiswGu5.system.js.map → p-BEAZDb3Z.system.js.map} +1 -1
- package/dist/twilight/{p-D0yWDY14.system.js.map → p-BQW3a64v.system.js.map} +1 -1
- package/dist/twilight/p-BYmyEppC.system.js.map +1 -0
- package/dist/twilight/{p-BKj6IZd9.system.js.map → p-BbGRMLwX.system.js.map} +1 -1
- package/dist/twilight/{p-F2JLu9jF.system.js.map → p-BiWj3BdY.system.js.map} +1 -1
- package/dist/twilight/{p-Qk6u-mnz.system.js.map → p-BmpTR30a.system.js.map} +1 -1
- package/dist/twilight/{p-Q3cnmL-k.system.js.map → p-BwBcvX6V.system.js.map} +1 -1
- package/dist/twilight/{p-DO1cm8rG.system.js.map → p-C1YpO4ps.system.js.map} +1 -1
- package/dist/twilight/{p-nXvqfF6q.system.js.map → p-CS3lHUTW.system.js.map} +1 -1
- package/dist/twilight/{p-gVMnKsEU.system.js.map → p-CW5Y_Ilm.system.js.map} +1 -1
- package/dist/twilight/{p-TbCQaUz_.system.js.map → p-CW_Wih48.system.js.map} +1 -1
- package/dist/twilight/{p-DkgAOYre.system.js.map → p-Cny8cSf0.system.js.map} +1 -1
- package/dist/twilight/{p-DUpLpWDY.system.js.map → p-Cv-fXCMq.system.js.map} +1 -1
- package/dist/twilight/{p-DvQyp25Z.js → p-D4Rc_kre.js} +2 -2
- package/dist/twilight/{p-DvQyp25Z.js.map → p-D4Rc_kre.js.map} +1 -1
- package/dist/twilight/{p-C1RajKkq.system.js.map → p-D8gfPwyY.system.js.map} +1 -1
- package/dist/twilight/{p-Uyr4Flns.system.js.map → p-DDxbK6va.system.js.map} +1 -1
- package/dist/twilight/{p-BC9d2sk2.system.js.map → p-DF0wZDI-.system.js.map} +1 -1
- package/dist/twilight/{p-0n3Z0RlT.system.js.map → p-DJO9K4n7.system.js.map} +1 -1
- package/dist/twilight/{p-5Ng8LPjI.js → p-DJeJWTdD.js} +3 -3
- package/dist/twilight/p-DJeJWTdD.js.map +1 -0
- package/dist/twilight/{p-SmO-pF11.system.js.map → p-DYXzVtwh.system.js.map} +1 -1
- package/dist/twilight/{p-W-D1NGNr.system.js.map → p-D_GDndNn.system.js.map} +1 -1
- package/dist/twilight/{p-B_XWr5W4.system.js.map → p-DanADfyI.system.js.map} +1 -1
- package/dist/twilight/{p-DrkjWDOn.system.js.map → p-DlFxCb4V.system.js.map} +1 -1
- package/dist/twilight/{p-DyTthv6s.system.js → p-Dtkyz9uf.system.js} +2 -2
- package/dist/twilight/{p-DyTthv6s.system.js.map → p-Dtkyz9uf.system.js.map} +1 -1
- package/dist/twilight/{p-DAcwScl7.system.js.map → p-DuXM8liP.system.js.map} +1 -1
- package/dist/twilight/{p-D5qlTBkb.system.js.map → p-DvaxAP4E.system.js.map} +1 -1
- package/dist/twilight/{p-D66T0o_K.system.js.map → p-DygvAhI4.system.js.map} +1 -1
- package/dist/twilight/{p-BRVKF1oX.system.js.map → p-V-F3jS9L.system.js.map} +1 -1
- package/dist/twilight/{p-CVCIt2lC.system.js.map → p-Vh3TFQnV.system.js.map} +1 -1
- package/dist/twilight/{p-38dbabf3.system.entry.js → p-a4376ad7.system.entry.js} +2 -2
- package/dist/twilight/{p-7425415e.entry.js → p-a52f5483.entry.js} +2 -2
- package/dist/twilight/{p-2bbb1442.system.entry.js → p-a8541cb2.system.entry.js} +2 -2
- package/dist/twilight/{p-b932035d.entry.js → p-aae55c3c.entry.js} +2 -2
- package/dist/twilight/{p-83ec57bf.system.entry.js → p-ab9a81e5.system.entry.js} +2 -2
- package/dist/twilight/{p-9a610905.entry.js → p-b311d422.entry.js} +2 -2
- package/dist/twilight/{p-8fee4078.entry.js → p-b734e69f.entry.js} +2 -2
- package/dist/twilight/{p-5cdc0973.entry.js → p-bdef02e0.entry.js} +2 -2
- package/dist/twilight/{p-ab25e4b2.system.entry.js → p-bec1f4a2.system.entry.js} +2 -2
- package/dist/twilight/{p-52d9262a.system.entry.js → p-c62d7968.system.entry.js} +2 -2
- package/dist/twilight/{p-2406c822.entry.js → p-cba454b7.entry.js} +2 -2
- package/dist/twilight/{p-3fcf491f.entry.js → p-d0db93be.entry.js} +2 -2
- package/dist/twilight/{p-30635b42.system.entry.js → p-d78f9304.system.entry.js} +2 -2
- package/dist/twilight/{p-DA5WTaBt.system.js.map → p-dKVQW-4Z.system.js.map} +1 -1
- package/dist/twilight/{p-fa63f709.entry.js → p-ddfc02db.entry.js} +2 -2
- package/dist/twilight/p-df86fa35.entry.js +5 -0
- package/dist/twilight/p-df86fa35.entry.js.map +1 -0
- package/dist/twilight/{p-727b5970.system.entry.js → p-e09dbe92.system.entry.js} +2 -2
- package/dist/twilight/{p-8aebf618.system.entry.js → p-e45781c5.system.entry.js} +2 -2
- package/dist/twilight/{p-1d9751af.system.entry.js → p-e490de2f.system.entry.js} +2 -2
- package/dist/twilight/{p-e38dcdec.entry.js → p-e9e4a641.entry.js} +7 -7
- package/dist/twilight/{p-c8833f02.system.entry.js → p-eb847afb.system.entry.js} +2 -2
- package/dist/twilight/{p-DAzL0lXn.system.js.map → p-eyvPNcBM.system.js.map} +1 -1
- package/dist/twilight/{p-1fec50ba.entry.js → p-f26aa117.entry.js} +2 -2
- package/dist/twilight/{p-e0039759.entry.js → p-f5364a4e.entry.js} +2 -2
- package/dist/twilight/{p-0f6f5c5a.system.entry.js → p-f6e14858.system.entry.js} +2 -2
- package/dist/twilight/{p-f0eacf55.entry.js → p-f8f0dd3d.entry.js} +2 -2
- package/dist/twilight/{p-f0443b95.entry.js → p-fd20f996.entry.js} +2 -2
- package/dist/twilight/{p-b0218d53.system.entry.js → p-fe4d5abb.system.entry.js} +2 -2
- package/dist/twilight/{p-BwQkR44B.system.js.map → p-rHIfLORZ.system.js.map} +1 -1
- package/dist/twilight/p-t_BLXxaT.system.js +5 -0
- package/dist/twilight/{p-DF9ZFyzo.system.js.map → p-t_BLXxaT.system.js.map} +1 -1
- package/dist/twilight/{p-DEap41uW.system.js.map → p-urL630v4.system.js.map} +1 -1
- package/dist/twilight/salla-tiered-offer.entry.esm.js.map +1 -0
- package/dist/twilight/twilight.esm.js +1 -1
- package/dist/twilight/twilight.js +1 -1
- package/dist/types/components/salla-tiered-offer/constants.d.ts +2 -0
- package/dist/types/components/salla-tiered-offer/interfaces.d.ts +44 -0
- package/dist/types/components/salla-tiered-offer/salla-tiered-offer.d.ts +39 -0
- package/dist/types/components/salla-tiered-offer/utils.d.ts +19 -0
- package/dist/types/components.d.ts +13 -0
- package/package.json +5 -5
- package/dist/cjs/index-CcKYmcmm.js.map +0 -1
- package/dist/esm/index-5Ng8LPjI.js.map +0 -1
- package/dist/esm-es5/index-5Ng8LPjI.js.map +0 -1
- package/dist/twilight/p-5Ng8LPjI.js.map +0 -1
- package/dist/twilight/p-CW47XnO5.system.js.map +0 -1
- package/dist/twilight/p-DF9ZFyzo.system.js +0 -5
- package/dist/twilight/p-bed89c3a.system.entry.js +0 -5
- /package/dist/twilight/{p-7f275c07.entry.js.map → p-018db6d5.entry.js.map} +0 -0
- /package/dist/twilight/{p-592ab962.system.entry.js.map → p-01ab98b8.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-0997acd6.system.entry.js.map → p-0213d2ff.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-27b836fc.entry.js.map → p-0530fecd.entry.js.map} +0 -0
- /package/dist/twilight/{p-a3867f03.system.entry.js.map → p-0a564fe6.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-3f87edc6.entry.js.map → p-0bd54dae.entry.js.map} +0 -0
- /package/dist/twilight/{p-87ed46f2.entry.js.map → p-11542446.entry.js.map} +0 -0
- /package/dist/twilight/{p-817c183a.entry.js.map → p-1196a23a.entry.js.map} +0 -0
- /package/dist/twilight/{p-5bcba29f.system.entry.js.map → p-125e8e09.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-bb0a64fb.system.entry.js.map → p-137b9ced.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-4aec7d12.system.entry.js.map → p-14bce2e7.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-63f7bf97.system.entry.js.map → p-1bc7d70c.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-026b2234.system.entry.js.map → p-1c1baf96.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-7e2380cb.entry.js.map → p-1e32544e.entry.js.map} +0 -0
- /package/dist/twilight/{p-b56edfc7.system.entry.js.map → p-2411b6cb.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-cd1a5066.system.entry.js.map → p-2943fae2.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-fe03bd17.entry.js.map → p-2e1838fc.entry.js.map} +0 -0
- /package/dist/twilight/{p-606c8dfc.entry.js.map → p-2ecd9c73.entry.js.map} +0 -0
- /package/dist/twilight/{p-917f2e0d.entry.js.map → p-345e7510.entry.js.map} +0 -0
- /package/dist/twilight/{p-50348764.entry.js.map → p-4719adfd.entry.js.map} +0 -0
- /package/dist/twilight/{p-27fa775d.system.entry.js.map → p-512dbfd8.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-5092bc1b.system.entry.js.map → p-5222370a.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-bed89c3a.system.entry.js.map → p-56329c93.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-4defb732.entry.js.map → p-594c82e8.entry.js.map} +0 -0
- /package/dist/twilight/{p-4260bfbf.entry.js.map → p-5a3e638f.entry.js.map} +0 -0
- /package/dist/twilight/{p-89b36aa5.entry.js.map → p-5f22ded8.entry.js.map} +0 -0
- /package/dist/twilight/{p-d39080ee.system.entry.js.map → p-60550d95.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-e7267b4b.system.entry.js.map → p-611a0591.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-6ccab36e.entry.js.map → p-62372bb6.entry.js.map} +0 -0
- /package/dist/twilight/{p-2378fcc3.system.entry.js.map → p-64346d4f.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-725de283.system.entry.js.map → p-65f8266c.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-0c73100c.entry.js.map → p-7dc53e3e.entry.js.map} +0 -0
- /package/dist/twilight/{p-e182183b.entry.js.map → p-84aaa78d.entry.js.map} +0 -0
- /package/dist/twilight/{p-b66d9649.system.entry.js.map → p-8b0b63d3.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-74922500.entry.js.map → p-8d171391.entry.js.map} +0 -0
- /package/dist/twilight/{p-568ca254.system.entry.js.map → p-8d241400.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-b0b3047d.entry.js.map → p-8f504c22.entry.js.map} +0 -0
- /package/dist/twilight/{p-059307d0.system.entry.js.map → p-96c0dbe6.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-6831d2b2.entry.js.map → p-9c6d592b.entry.js.map} +0 -0
- /package/dist/twilight/{p-38dbabf3.system.entry.js.map → p-a4376ad7.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-7425415e.entry.js.map → p-a52f5483.entry.js.map} +0 -0
- /package/dist/twilight/{p-2bbb1442.system.entry.js.map → p-a8541cb2.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-b932035d.entry.js.map → p-aae55c3c.entry.js.map} +0 -0
- /package/dist/twilight/{p-83ec57bf.system.entry.js.map → p-ab9a81e5.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-9a610905.entry.js.map → p-b311d422.entry.js.map} +0 -0
- /package/dist/twilight/{p-8fee4078.entry.js.map → p-b734e69f.entry.js.map} +0 -0
- /package/dist/twilight/{p-5cdc0973.entry.js.map → p-bdef02e0.entry.js.map} +0 -0
- /package/dist/twilight/{p-ab25e4b2.system.entry.js.map → p-bec1f4a2.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-52d9262a.system.entry.js.map → p-c62d7968.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-2406c822.entry.js.map → p-cba454b7.entry.js.map} +0 -0
- /package/dist/twilight/{p-3fcf491f.entry.js.map → p-d0db93be.entry.js.map} +0 -0
- /package/dist/twilight/{p-30635b42.system.entry.js.map → p-d78f9304.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-fa63f709.entry.js.map → p-ddfc02db.entry.js.map} +0 -0
- /package/dist/twilight/{p-727b5970.system.entry.js.map → p-e09dbe92.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-8aebf618.system.entry.js.map → p-e45781c5.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-1d9751af.system.entry.js.map → p-e490de2f.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-e38dcdec.entry.js.map → p-e9e4a641.entry.js.map} +0 -0
- /package/dist/twilight/{p-c8833f02.system.entry.js.map → p-eb847afb.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-1fec50ba.entry.js.map → p-f26aa117.entry.js.map} +0 -0
- /package/dist/twilight/{p-e0039759.entry.js.map → p-f5364a4e.entry.js.map} +0 -0
- /package/dist/twilight/{p-0f6f5c5a.system.entry.js.map → p-f6e14858.system.entry.js.map} +0 -0
- /package/dist/twilight/{p-f0eacf55.entry.js.map → p-f8f0dd3d.entry.js.map} +0 -0
- /package/dist/twilight/{p-f0443b95.entry.js.map → p-fd20f996.entry.js.map} +0 -0
- /package/dist/twilight/{p-b0218d53.system.entry.js.map → p-fe4d5abb.system.entry.js.map} +0 -0
|
@@ -0,0 +1,338 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Crafted with ❤ by Salla
|
|
3
|
+
*/
|
|
4
|
+
'use strict';
|
|
5
|
+
|
|
6
|
+
var index = require('./index-1TYwVkJb.js');
|
|
7
|
+
|
|
8
|
+
var DiscountType;
|
|
9
|
+
(function (DiscountType) {
|
|
10
|
+
DiscountType["PERCENTAGE"] = "percentage";
|
|
11
|
+
DiscountType["FIXED"] = "fixed";
|
|
12
|
+
})(DiscountType || (DiscountType = {}));
|
|
13
|
+
|
|
14
|
+
var StarIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="40" height="40" color="#000000" fill="none">
|
|
15
|
+
<path d="M13.7276 3.44418L15.4874 6.99288C15.7274 7.48687 16.3673 7.9607 16.9073 8.05143L20.0969 8.58575C22.1367 8.92853 22.6167 10.4206 21.1468 11.8925L18.6671 14.3927C18.2471 14.8161 18.0172 15.6327 18.1471 16.2175L18.8571 19.3125C19.417 21.7623 18.1271 22.71 15.9774 21.4296L12.9877 19.6452C12.4478 19.3226 11.5579 19.3226 11.0079 19.6452L8.01827 21.4296C5.8785 22.71 4.57865 21.7522 5.13859 19.3125L5.84851 16.2175C5.97849 15.6327 5.74852 14.8161 5.32856 14.3927L2.84884 11.8925C1.389 10.4206 1.85895 8.92853 3.89872 8.58575L7.08837 8.05143C7.61831 7.9607 8.25824 7.48687 8.49821 6.99288L10.258 3.44418C11.2179 1.51861 12.7777 1.51861 13.7276 3.44418Z" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"></path>
|
|
16
|
+
</svg>`;
|
|
17
|
+
|
|
18
|
+
var StarsIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24" color="#000000" fill="none">
|
|
19
|
+
<path d="M3 12C7.5 12 12 7.5 12 3C12 7.5 16.5 12 21 12C16.5 12 12 16.5 12 21C12 16.5 7.5 12 3 12Z" stroke="currentColor" stroke-width="1.5" stroke-linejoin="round"></path>
|
|
20
|
+
<path d="M2 19.5C2.83333 19.5 4.5 17.8333 4.5 17C4.5 17.8333 6.16667 19.5 7 19.5C6.16667 19.5 4.5 21.1667 4.5 22C4.5 21.1667 2.83333 19.5 2 19.5Z" stroke="currentColor" stroke-width="1.5" stroke-linejoin="round"></path>
|
|
21
|
+
<path d="M16 5C17 5 19 3 19 2C19 3 21 5 22 5C21 5 19 7 19 8C19 7 17 5 16 5Z" stroke="currentColor" stroke-width="1.5" stroke-linejoin="round"></path>
|
|
22
|
+
</svg>`;
|
|
23
|
+
|
|
24
|
+
var GoldIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="40" height="40" color="#000000" fill="none">
|
|
25
|
+
<path d="M14.2644 18.3717C14.5806 17.407 14.7387 16.9247 15.0616 16.593C15.215 16.4354 15.3932 16.3048 15.5887 16.2066C16.0003 16 16.5003 16 17.5002 16C18.5001 16 19.0001 16 19.4116 16.2066C19.6072 16.3048 19.7853 16.4354 19.9388 16.593C20.2617 16.9247 20.4198 17.407 20.736 18.3717L21.0624 19.3675C21.4561 20.5688 21.653 21.1694 21.3587 21.5847C21.0643 22 20.4418 22 19.1966 22H15.8038C14.5586 22 13.936 22 13.6417 21.5847C13.3473 21.1694 13.5442 20.5688 13.938 19.3675L14.2644 18.3717Z" stroke="currentColor" stroke-width="1.5"></path>
|
|
26
|
+
<path d="M8.76421 10.3717C9.08041 9.40705 9.23851 8.92471 9.56143 8.59298C9.71485 8.43537 9.89299 8.3048 10.0885 8.20663C10.5001 8 11.0001 8 12 8C12.9999 8 13.4999 8 13.9115 8.20663C14.107 8.3048 14.2851 8.43537 14.4386 8.59298C14.7615 8.92471 14.9196 9.40705 15.2358 10.3717L15.5622 11.3675C15.956 12.5688 16.1528 13.1694 15.8585 13.5847C15.5642 14 14.9416 14 13.6964 14H10.3036C9.05842 14 8.43585 14 8.1415 13.5847C7.84716 13.1694 8.04404 12.5688 8.43779 11.3675L8.76421 10.3717Z" stroke="currentColor" stroke-width="1.5"></path>
|
|
27
|
+
<path d="M3.26439 18.3717C3.58059 17.407 3.73869 16.9247 4.06162 16.593C4.21504 16.4354 4.39317 16.3048 4.58872 16.2066C5.00031 16 5.50027 16 6.50018 16C7.5001 16 8.00006 16 8.41165 16.2066C8.6072 16.3048 8.78533 16.4354 8.93875 16.593C9.26167 16.9247 9.41977 17.407 9.73597 18.3717L10.0624 19.3675C10.4561 20.5688 10.653 21.1694 10.3587 21.5847C10.0643 22 9.44176 22 8.19661 22H4.80375C3.5586 22 2.93603 22 2.64169 21.5847C2.34735 21.1694 2.54422 20.5688 2.93797 19.3675L3.26439 18.3717Z" stroke="currentColor" stroke-width="1.5"></path>
|
|
28
|
+
<path d="M12 2V4M7.5 3.5L9 5M16.5 3.5L15 5" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path>
|
|
29
|
+
</svg>`;
|
|
30
|
+
|
|
31
|
+
var DiamondIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24" color="#000000" fill="none">
|
|
32
|
+
<path d="M5.78223 4.18192C6.43007 3.68319 6.754 3.43383 7.12788 3.27323C7.29741 3.20041 7.47367 3.14158 7.65459 3.09741C8.0536 3 8.4767 3 9.32289 3H14.6771C15.5233 3 15.9464 3 16.3454 3.09741C16.5263 3.14158 16.7026 3.20041 16.8721 3.27323C17.246 3.43383 17.5699 3.68319 18.2178 4.18192C20.3644 5.83448 21.4378 6.66077 21.8057 7.73078C21.9694 8.20673 22.0305 8.70728 21.9858 9.20461C21.8852 10.3227 21.0379 11.346 19.3433 13.3925L15.3498 18.2153C13.8126 20.0718 13.044 21 12 21C10.956 21 10.1874 20.0718 8.65018 18.2153L4.65671 13.3925C2.96208 11.346 2.11476 10.3227 2.0142 9.20461C1.96947 8.70728 2.03064 8.20673 2.1943 7.73078C2.56224 6.66077 3.63557 5.83448 5.78223 4.18192Z" stroke="currentColor" stroke-width="1.5"></path>
|
|
33
|
+
<path d="M10 8.5H14" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"></path>
|
|
34
|
+
</svg>`;
|
|
35
|
+
|
|
36
|
+
const TIERED_OFFER_CONFIG = {
|
|
37
|
+
staticIcons: [StarIcon, StarsIcon, GoldIcon, DiamondIcon],
|
|
38
|
+
staticColors: ['#993018', '#444444', '#D18F36', '#315F9C']
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
class TierUtils {
|
|
42
|
+
/**
|
|
43
|
+
* Find tier by index
|
|
44
|
+
*/
|
|
45
|
+
static findTierByIndex(tiers, index) {
|
|
46
|
+
return tiers.find(tier => tier.index === index) || null;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Find tier by tier name
|
|
50
|
+
*/
|
|
51
|
+
static findTierByName(tiers, tierName) {
|
|
52
|
+
return tiers.find(tier => tier.tier_name === tierName) || null;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Get tier name by index
|
|
56
|
+
*/
|
|
57
|
+
static getTierNameByIndex(tiers, index) {
|
|
58
|
+
var _a;
|
|
59
|
+
return (_a = this.findTierByIndex(tiers, index)) === null || _a === void 0 ? void 0 : _a.tier_name;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Find current tier index based on current value
|
|
63
|
+
*/
|
|
64
|
+
static findCurrentTierIndex(currentValue, tiers) {
|
|
65
|
+
if (!tiers)
|
|
66
|
+
return 0;
|
|
67
|
+
for (let i = tiers.length - 1; i >= 0; i--) {
|
|
68
|
+
if (currentValue >= tiers[i].threshold) {
|
|
69
|
+
return tiers[i].index;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return 0;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const sallaTieredOfferCss = ".s-tiered-offer-milestone-icon svg{color:currentColor}.s-tiered-offer-milestone-icon svg path{stroke:currentColor;fill:none}.s-tiered-offer-milestone-icon.s-tiered-offer-milestone-active svg path,.s-tiered-offer-milestone-icon.s-tiered-offer-milestone-completed svg path{fill:currentColor;stroke:none}.s-tiered-offer-milestone-icon.s-tiered-offer-milestone-active svg[fill=none] path,.s-tiered-offer-milestone-icon.s-tiered-offer-milestone-completed svg[fill=none] path{fill:none;stroke:currentColor}[dir=rtl] .s-tiered-offer-progress-wrapper .s-tiered-offer-progress-bg{-webkit-transform:scaleX(-1);transform:scaleX(-1)}[dir=rtl] .s-tiered-offer-progress-wrapper .s-tiered-offer-progress-fill{-webkit-transform:scaleX(-1);transform:scaleX(-1);left:auto}[dir=rtl] .flip-x{-webkit-transform:scaleX(-1);transform:scaleX(-1)}";
|
|
77
|
+
|
|
78
|
+
const SallaTieredOffer = class {
|
|
79
|
+
constructor(hostRef) {
|
|
80
|
+
index.registerInstance(this, hostRef);
|
|
81
|
+
this.currentTierIndex = 0;
|
|
82
|
+
this.canRender = false;
|
|
83
|
+
this.isLoading = false;
|
|
84
|
+
this.handleTabClick = (tierName) => {
|
|
85
|
+
this.activeTabTier = tierName;
|
|
86
|
+
};
|
|
87
|
+
salla.lang.onLoaded(() => {
|
|
88
|
+
this.loyaltyProgramText = salla.lang.get('blocks.tiered_offer.program_title');
|
|
89
|
+
this.currentTierText = salla.lang.get('blocks.tiered_offer.current_tier');
|
|
90
|
+
this.discountText = salla.lang.get('blocks.tiered_offer.discount');
|
|
91
|
+
this.benefitText = salla.lang.get('blocks.tiered_offer.tier_description');
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
async componentWillLoad() {
|
|
95
|
+
try {
|
|
96
|
+
await salla.onReady();
|
|
97
|
+
if (!this.checkFeatureEnabled()) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
if (!this.checkCartExists()) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
this.isLoading = true;
|
|
104
|
+
const offerData = await this.fetchTieredOfferData();
|
|
105
|
+
if (!offerData) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
this.initializeComponent(offerData);
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
this.canRender = false;
|
|
112
|
+
salla.logger.warn('salla-tiered-offer:: ', error);
|
|
113
|
+
}
|
|
114
|
+
finally {
|
|
115
|
+
this.isLoading = false;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
checkFeatureEnabled() {
|
|
119
|
+
var _a;
|
|
120
|
+
return (_a = salla.config.get('store.features')) === null || _a === void 0 ? void 0 : _a.includes('tiered-offer');
|
|
121
|
+
}
|
|
122
|
+
checkCartExists() {
|
|
123
|
+
var _a, _b;
|
|
124
|
+
return !!((_b = (_a = salla.storage.get("cart")) === null || _a === void 0 ? void 0 : _a.summary) === null || _b === void 0 ? void 0 : _b.count);
|
|
125
|
+
}
|
|
126
|
+
validateCouponCompatibility(offerData, cartCoupon) {
|
|
127
|
+
var _a;
|
|
128
|
+
// If coupon is applied but offer doesn't support coupons, widget should be hidden
|
|
129
|
+
return !(cartCoupon && !((_a = offerData.details) === null || _a === void 0 ? void 0 : _a.applied_with_coupon));
|
|
130
|
+
}
|
|
131
|
+
async fetchTieredOfferData() {
|
|
132
|
+
var _a;
|
|
133
|
+
try {
|
|
134
|
+
const { data } = await salla.api.cart.offers();
|
|
135
|
+
const tieredOffer = data.find(offer => offer.type === "tiered_offer");
|
|
136
|
+
if (!tieredOffer) {
|
|
137
|
+
return null;
|
|
138
|
+
}
|
|
139
|
+
// Hide widget if coupon is applied and offer doesn't support coupons
|
|
140
|
+
if (!this.validateCouponCompatibility(tieredOffer, (_a = salla.storage.get("cart")) === null || _a === void 0 ? void 0 : _a.coupon)) {
|
|
141
|
+
this.canRender = false;
|
|
142
|
+
return null;
|
|
143
|
+
}
|
|
144
|
+
return tieredOffer;
|
|
145
|
+
}
|
|
146
|
+
catch (error) {
|
|
147
|
+
throw error;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
initializeComponent(apiOfferData) {
|
|
151
|
+
var _a;
|
|
152
|
+
this.apiOfferData = apiOfferData;
|
|
153
|
+
// Map tiered details data to component format
|
|
154
|
+
this.tieredOfferData = this.mapApiDataToTiers(this.apiOfferData);
|
|
155
|
+
this.loyaltyProgramText = this.apiOfferData.title || this.loyaltyProgramText;
|
|
156
|
+
// Find current tier index based on current_value from API
|
|
157
|
+
const currentValue = ((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.current_value) || 0;
|
|
158
|
+
const currentTierIndex = this.findCurrentTierIndex(currentValue);
|
|
159
|
+
// Only render if user has reached at least the first tier
|
|
160
|
+
if (currentTierIndex === 0) {
|
|
161
|
+
this.canRender = false;
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
this.currentTierIndex = currentTierIndex;
|
|
165
|
+
this.currentTier = TierUtils.getTierNameByIndex(this.tieredOfferData.tiers, currentTierIndex);
|
|
166
|
+
this.activeTabTier = this.currentTier;
|
|
167
|
+
this.canRender = true;
|
|
168
|
+
}
|
|
169
|
+
componentDidLoad() {
|
|
170
|
+
salla.event.on("cart::updated", (updatedCart) => {
|
|
171
|
+
this.updateOfferValues(updatedCart);
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
mapApiDataToTiers(apiData) {
|
|
175
|
+
// Sort discounts by min_spend to create proper tier order
|
|
176
|
+
const sortedDiscounts = [...apiData.details.discounts].sort((a, b) => a.min_spend - b.min_spend);
|
|
177
|
+
const tiers = sortedDiscounts.map((discount, index) => ({
|
|
178
|
+
name: discount.name,
|
|
179
|
+
tier_name: discount.name,
|
|
180
|
+
discount: discount.type === DiscountType.PERCENTAGE ? `${salla.helpers.number(discount.value)}%` : salla.money(discount.value),
|
|
181
|
+
icon: TIERED_OFFER_CONFIG.staticIcons[index] || TIERED_OFFER_CONFIG.staticIcons[0],
|
|
182
|
+
threshold: discount.min_spend,
|
|
183
|
+
text_color: TIERED_OFFER_CONFIG.staticColors[index],
|
|
184
|
+
index: index + 1
|
|
185
|
+
}));
|
|
186
|
+
return {
|
|
187
|
+
current_tier: TierUtils.getTierNameByIndex(tiers, this.findCurrentTierIndex(apiData.details.current_value, tiers)),
|
|
188
|
+
tiers
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
findCurrentTierIndex(currentValue, tiers) {
|
|
192
|
+
var _a;
|
|
193
|
+
if (tiers === void 0) {
|
|
194
|
+
tiers = (_a = this.tieredOfferData) === null || _a === void 0 ? void 0 : _a.tiers;
|
|
195
|
+
}
|
|
196
|
+
return TierUtils.findCurrentTierIndex(currentValue, tiers || []);
|
|
197
|
+
}
|
|
198
|
+
updateOfferValues(updatedCart) {
|
|
199
|
+
var _a;
|
|
200
|
+
if (!this.apiOfferData || !this.tieredOfferData) {
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
// Check coupon compatibility
|
|
204
|
+
if (!this.validateCouponCompatibility(this.apiOfferData, updatedCart.coupon)) {
|
|
205
|
+
this.canRender = false;
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
// If no coupon conflict, show widget
|
|
209
|
+
this.canRender = true;
|
|
210
|
+
// Check if this offer should update with cart changes
|
|
211
|
+
if (((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.with_current_cart) === false) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
// Update current_value in API offer data
|
|
215
|
+
const currentValue = updatedCart.sub_total;
|
|
216
|
+
this.apiOfferData = Object.assign(Object.assign({}, this.apiOfferData), { details: Object.assign(Object.assign({}, this.apiOfferData.details), { current_value: currentValue }) });
|
|
217
|
+
// Update current tier based on new value
|
|
218
|
+
const newTierIndex = this.findCurrentTierIndex(currentValue);
|
|
219
|
+
// Check if user qualifies for any tier
|
|
220
|
+
if (newTierIndex === 0) {
|
|
221
|
+
this.canRender = false;
|
|
222
|
+
return;
|
|
223
|
+
}
|
|
224
|
+
// user qualifies show widget
|
|
225
|
+
this.canRender = true;
|
|
226
|
+
this.currentTierIndex = newTierIndex;
|
|
227
|
+
this.currentTier = TierUtils.getTierNameByIndex(this.tieredOfferData.tiers, newTierIndex);
|
|
228
|
+
// Update active tab if needed
|
|
229
|
+
if (this.activeTabTier !== this.currentTier) {
|
|
230
|
+
this.activeTabTier = this.currentTier;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
getLoadingSkeletonView() {
|
|
234
|
+
return index.h(index.Host, null, index.h("div", { class: "s-tiered-offer-container" }, index.h("div", { class: "s-tiered-offer-skeleton-wrapper" }, index.h("div", { class: "s-tiered-offer-skeleton-title" }, index.h("salla-skeleton", { height: "16px", width: "40%" })), index.h("div", { class: "s-tiered-offer-skeleton-subtitle" }, index.h("salla-skeleton", { height: "20px", width: "60%" })), index.h("div", { class: "s-tiered-offer-skeleton-progress" }, index.h("salla-skeleton", { height: "16px", width: "100%" })), index.h("div", { class: "s-tiered-offer-skeleton-tabs" }, index.h("salla-skeleton", { height: "50px", width: "100%" })))));
|
|
235
|
+
}
|
|
236
|
+
getCurrentTierData() {
|
|
237
|
+
return TierUtils.findTierByIndex(this.tieredOfferData.tiers, this.currentTierIndex) || this.tieredOfferData.tiers[0];
|
|
238
|
+
}
|
|
239
|
+
getProgressWidth() {
|
|
240
|
+
var _a;
|
|
241
|
+
const currentValue = ((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.current_value) || 0;
|
|
242
|
+
const totalTiers = this.tieredOfferData.tiers.length;
|
|
243
|
+
// Use existing method to find current tier index (which already handles the logic)
|
|
244
|
+
const currentTierIndex = this.findCurrentTierIndex(currentValue);
|
|
245
|
+
// Convert to 0-based index for progress calculation
|
|
246
|
+
const completedTiers = currentTierIndex;
|
|
247
|
+
return (completedTiers / totalTiers) * 100;
|
|
248
|
+
}
|
|
249
|
+
calculateMilestonePosition(index, totalTiers) {
|
|
250
|
+
if (totalTiers === 1) {
|
|
251
|
+
return 'calc(100% - 18px)';
|
|
252
|
+
}
|
|
253
|
+
const milestonePercent = ((index + 1) / totalTiers) * 100;
|
|
254
|
+
const offsetPercent = 8 / totalTiers;
|
|
255
|
+
return `${Math.max(2, Math.min(95, milestonePercent - offsetPercent))}%`;
|
|
256
|
+
}
|
|
257
|
+
getMilestoneStyles(tier, index, totalTiers) {
|
|
258
|
+
const isRtl = document.documentElement.dir === 'rtl';
|
|
259
|
+
const adjustedPercent = this.calculateMilestonePosition(index, totalTiers);
|
|
260
|
+
const alignItems = tier.name.length > 6 ? 'flex-end' : 'center';
|
|
261
|
+
return {
|
|
262
|
+
[isRtl ? 'right' : 'left']: adjustedPercent,
|
|
263
|
+
alignItems,
|
|
264
|
+
position: 'absolute',
|
|
265
|
+
transform: isRtl ? 'translateX(50%)' : 'translateX(-50%)'
|
|
266
|
+
};
|
|
267
|
+
}
|
|
268
|
+
getMilestoneIconStyles(tier, isCurrent, isReached) {
|
|
269
|
+
if (isCurrent) {
|
|
270
|
+
return { color: tier.text_color };
|
|
271
|
+
}
|
|
272
|
+
if (isReached) {
|
|
273
|
+
return { color: 'var(--color-primary)' };
|
|
274
|
+
}
|
|
275
|
+
return {};
|
|
276
|
+
}
|
|
277
|
+
renderProgressBarBackground(progressWidth) {
|
|
278
|
+
return [
|
|
279
|
+
index.h("div", { class: "s-tiered-offer-progress-bg" }),
|
|
280
|
+
index.h("div", { class: "s-tiered-offer-progress-fill", style: { width: `${progressWidth}%` } })
|
|
281
|
+
];
|
|
282
|
+
}
|
|
283
|
+
renderMilestoneIcon(tier, isCurrent, isReached) {
|
|
284
|
+
const iconClasses = [
|
|
285
|
+
's-tiered-offer-milestone-icon',
|
|
286
|
+
isCurrent ? 's-tiered-offer-milestone-active' : '',
|
|
287
|
+
isReached ? 's-tiered-offer-milestone-completed' : ''
|
|
288
|
+
].filter(Boolean).join(' ');
|
|
289
|
+
return (index.h("div", { class: iconClasses, style: this.getMilestoneIconStyles(tier, isCurrent, isReached) }, index.h("span", { innerHTML: tier.icon })));
|
|
290
|
+
}
|
|
291
|
+
renderMilestoneName(tier, isCurrent) {
|
|
292
|
+
return (index.h("div", { class: "s-tiered-offer-milestone-name" }, isCurrent && (index.h("span", { style: { color: tier.text_color } }, tier.name))));
|
|
293
|
+
}
|
|
294
|
+
renderMilestones(currentValue, totalTiers) {
|
|
295
|
+
const containerClass = totalTiers === 1
|
|
296
|
+
? 's-tiered-offer-single-milestone-justify-end'
|
|
297
|
+
: 's-tiered-offer-milestones';
|
|
298
|
+
return (index.h("div", { class: "s-tiered-offer-milestones-wrapper" }, index.h("div", { class: containerClass }, this.tieredOfferData.tiers.map((tier, index$1) => {
|
|
299
|
+
const isReached = currentValue >= tier.threshold;
|
|
300
|
+
const isCurrent = tier.tier_name === this.currentTier;
|
|
301
|
+
return (index.h("div", { class: "s-tiered-offer-milestone", style: this.getMilestoneStyles(tier, index$1, totalTiers) }, this.renderMilestoneIcon(tier, isCurrent, isReached), this.renderMilestoneName(tier, isCurrent)));
|
|
302
|
+
}))));
|
|
303
|
+
}
|
|
304
|
+
renderProgressBar() {
|
|
305
|
+
var _a;
|
|
306
|
+
const progressWidth = this.getProgressWidth();
|
|
307
|
+
const totalTiers = this.tieredOfferData.tiers.length;
|
|
308
|
+
const currentValue = ((_a = this.apiOfferData.details) === null || _a === void 0 ? void 0 : _a.current_value) || 0;
|
|
309
|
+
return (index.h("div", { class: "s-tiered-offer-progress-container" }, index.h("div", { class: "s-tiered-offer-progress-wrapper" }, this.renderProgressBarBackground(progressWidth), this.renderMilestones(currentValue, totalTiers))));
|
|
310
|
+
}
|
|
311
|
+
renderTabs() {
|
|
312
|
+
return (index.h("div", { class: "s-tiered-offer-tabs-container" }, index.h("div", { class: "s-tiered-offer-tab-headers" }, this.tieredOfferData.tiers.map(tier => {
|
|
313
|
+
const isActive = tier.tier_name === this.activeTabTier;
|
|
314
|
+
return (index.h("button", { class: `s-tiered-offer-tab-header ${isActive ? 's-tiered-offer-tab-active' : ''}`, onClick: () => this.handleTabClick(tier.tier_name) }, index.h("span", null, tier.name)));
|
|
315
|
+
})), index.h("div", { class: "s-tiered-offer-tab-content-wrapper" }, (() => {
|
|
316
|
+
const activeTier = TierUtils.findTierByName(this.tieredOfferData.tiers, this.activeTabTier);
|
|
317
|
+
if (!activeTier)
|
|
318
|
+
return null;
|
|
319
|
+
return (index.h("div", { class: "s-tiered-offer-tab-content" }, index.h("div", { class: "s-tiered-offer-tab-content-inner" }, index.h("div", { class: "s-tiered-offer-discount-section" }, index.h("p", { class: "s-tiered-offer-discount-title" }, this.discountText, " ", index.h("span", { innerHTML: activeTier.discount })), index.h("p", { class: "s-tiered-offer-benefit-description" }, this.benefitText, " ", activeTier.name)))));
|
|
320
|
+
})())));
|
|
321
|
+
}
|
|
322
|
+
render() {
|
|
323
|
+
if (this.isLoading) {
|
|
324
|
+
return this.getLoadingSkeletonView();
|
|
325
|
+
}
|
|
326
|
+
if (!this.canRender || !this.tieredOfferData) {
|
|
327
|
+
return null;
|
|
328
|
+
}
|
|
329
|
+
const currentTierData = this.getCurrentTierData();
|
|
330
|
+
return (index.h(index.Host, null, index.h("div", { class: "s-tiered-offer-container" }, index.h("div", { class: "s-tiered-offer-header" }, index.h("div", { class: "s-tiered-offer-header-content" }, index.h("p", { class: "s-tiered-offer-program-title" }, this.loyaltyProgramText), index.h("div", { class: "s-tiered-offer-current-tier-name-wrapper" }, index.h("h2", { class: "s-tiered-offer-current-tier" }, this.currentTierText, " ", index.h("span", { class: "s-tiered-offer-tier-name" }, currentTierData.name)), index.h("span", { innerHTML: currentTierData.icon })))), this.renderProgressBar(), this.renderTabs())));
|
|
331
|
+
}
|
|
332
|
+
};
|
|
333
|
+
SallaTieredOffer.style = sallaTieredOfferCss;
|
|
334
|
+
|
|
335
|
+
exports.salla_tiered_offer = SallaTieredOffer;
|
|
336
|
+
//# sourceMappingURL=salla-tiered-offer.entry.cjs.js.map
|
|
337
|
+
|
|
338
|
+
//# sourceMappingURL=salla-tiered-offer.cjs.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"salla-tiered-offer.entry.cjs.js","mappings":"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","names":["h","Host","index"],"sources":["src/components/salla-tiered-offer/interfaces.ts","src/components/salla-tiered-offer/constants.ts","src/components/salla-tiered-offer/utils.ts","src/components/salla-tiered-offer/salla-tiered-offer.scss?tag=salla-tiered-offer","src/components/salla-tiered-offer/salla-tiered-offer.tsx"],"sourcesContent":["export enum DiscountType {\n PERCENTAGE = \"percentage\",\n FIXED = \"fixed\",\n}\n\n\nexport interface Discount {\n name?: string;\n type?: DiscountType;\n value?: number;\n min_spend?: number;\n}\n\nexport interface TieredOfferDetails {\n based_on?: string;\n ends_at?: number;\n start_value?: number;\n end_value?: number;\n current_value?: number;\n discounts?: Discount[];\n with_current_cart?: boolean;\n applied_with_coupon?: boolean;\n}\n\nexport interface Offer {\n id?: number;\n type?: string;\n title?: string;\n description?: string;\n details?: TieredOfferDetails | null;\n}\n\nexport interface TieredOfferTier {\n name: string;\n tier_name: string;\n discount: string;\n icon: string;\n threshold: number;\n text_color?: string;\n index: number;\n}\n\nexport interface TieredOfferData {\n current_tier: string;\n tiers: TieredOfferTier[];\n}\n\nexport interface TieredOfferConfig {\n staticIcons: string[];\n staticColors: string[];\n}\n","import { TieredOfferConfig } from './interfaces';\nimport StarIcon from '../../assets/svg/star-rounded.svg';\nimport StarsIcon from '../../assets/svg/stars.svg';\nimport GoldIcon from '../../assets/svg/gold.svg';\nimport DiamondIcon from '../../assets/svg/diamond-02.svg';\n\nexport const TIERED_OFFER_CONFIG: TieredOfferConfig = {\n staticIcons: [StarIcon, StarsIcon, GoldIcon, DiamondIcon],\n staticColors: ['#993018', '#444444', '#D18F36', '#315F9C']\n};","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}","\n// SVG styling for milestone icons \n.s-tiered-offer-milestone-icon {\n svg {\n color: currentColor;\n \n path {\n stroke: currentColor;\n fill: none;\n }\n }\n \n // Active and completed states - fill the star icon, keep others as stroke\n &.s-tiered-offer-milestone-active,\n &.s-tiered-offer-milestone-completed {\n svg {\n path {\n fill: currentColor;\n stroke: none;\n }\n \n // For stroke-based icons (crown, stars, diamond) \n &[fill=\"none\"] path {\n fill: none;\n stroke: currentColor;\n }\n }\n }\n}\n\n// RTL Support \n[dir=\"rtl\"] {\n .s-tiered-offer-progress-wrapper {\n .s-tiered-offer-progress-bg {\n transform: scaleX(-1);\n }\n \n .s-tiered-offer-progress-fill {\n transform: scaleX(-1);\n left: auto;\n }\n }\n\n .flip-x {\n transform: scaleX(-1);\n }\n}\n","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"],"version":3}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"salla-tiered-offer.entry.cjs.js","sources":["src/components/salla-tiered-offer/interfaces.ts","src/components/salla-tiered-offer/constants.ts","src/components/salla-tiered-offer/utils.ts","src/components/salla-tiered-offer/salla-tiered-offer.scss?tag=salla-tiered-offer","src/components/salla-tiered-offer/salla-tiered-offer.tsx"],"sourcesContent":["export enum DiscountType {\n PERCENTAGE = \"percentage\",\n FIXED = \"fixed\",\n}\n\n\nexport interface Discount {\n name?: string;\n type?: DiscountType;\n value?: number;\n min_spend?: number;\n}\n\nexport interface TieredOfferDetails {\n based_on?: string;\n ends_at?: number;\n start_value?: number;\n end_value?: number;\n current_value?: number;\n discounts?: Discount[];\n with_current_cart?: boolean;\n applied_with_coupon?: boolean;\n}\n\nexport interface Offer {\n id?: number;\n type?: string;\n title?: string;\n description?: string;\n details?: TieredOfferDetails | null;\n}\n\nexport interface TieredOfferTier {\n name: string;\n tier_name: string;\n discount: string;\n icon: string;\n threshold: number;\n text_color?: string;\n index: number;\n}\n\nexport interface TieredOfferData {\n current_tier: string;\n tiers: TieredOfferTier[];\n}\n\nexport interface TieredOfferConfig {\n staticIcons: string[];\n staticColors: string[];\n}\n","import { TieredOfferConfig } from './interfaces';\nimport StarIcon from '../../assets/svg/star-rounded.svg';\nimport StarsIcon from '../../assets/svg/stars.svg';\nimport GoldIcon from '../../assets/svg/gold.svg';\nimport DiamondIcon from '../../assets/svg/diamond-02.svg';\n\nexport const TIERED_OFFER_CONFIG: TieredOfferConfig = {\n staticIcons: [StarIcon, StarsIcon, GoldIcon, DiamondIcon],\n staticColors: ['#993018', '#444444', '#D18F36', '#315F9C']\n};","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}","\n// SVG styling for milestone icons \n.s-tiered-offer-milestone-icon {\n svg {\n color: currentColor;\n \n path {\n stroke: currentColor;\n fill: none;\n }\n }\n \n // Active and completed states - fill the star icon, keep others as stroke\n &.s-tiered-offer-milestone-active,\n &.s-tiered-offer-milestone-completed {\n svg {\n path {\n fill: currentColor;\n stroke: none;\n }\n \n // For stroke-based icons (crown, stars, diamond) \n &[fill=\"none\"] path {\n fill: none;\n stroke: currentColor;\n }\n }\n }\n}\n\n// RTL Support \n[dir=\"rtl\"] {\n .s-tiered-offer-progress-wrapper {\n .s-tiered-offer-progress-bg {\n transform: scaleX(-1);\n }\n \n .s-tiered-offer-progress-fill {\n transform: scaleX(-1);\n left: auto;\n }\n }\n\n .flip-x {\n transform: scaleX(-1);\n }\n}\n","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"],"names":["h","Host","index"],"mappings":";;;;;;;AAAA,IAAY,YAGX;AAHD,CAAA,UAAY,YAAY,EAAA;AACtB,IAAA,YAAA,CAAA,YAAA,CAAA,GAAA,YAAyB;AACzB,IAAA,YAAA,CAAA,OAAA,CAAA,GAAA,OAAe;AACjB,CAAC,EAHW,YAAY,KAAZ,YAAY,GAGvB,EAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;ACGM,MAAM,mBAAmB,GAAsB;IACpD,WAAW,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,CAAC;IACzD,YAAY,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;CAC1D;;MCPY,SAAS,CAAA;AACpB;;AAEG;AACH,IAAA,OAAO,eAAe,CAAC,KAAwB,EAAE,KAAa,EAAA;AAC5D,QAAA,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,IAAI;;AAGzD;;AAEG;AACH,IAAA,OAAO,cAAc,CAAC,KAAwB,EAAE,QAAgB,EAAA;AAC9D,QAAA,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAC,IAAI,IAAI;;AAGhE;;AAEG;AACH,IAAA,OAAO,kBAAkB,CAAC,KAAwB,EAAE,KAAa,EAAA;;QAC/D,OAAO,CAAA,EAAA,GAAA,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,SAAS;;AAGtD;;AAEG;AACH,IAAA,OAAO,oBAAoB,CAAC,YAAoB,EAAE,KAAwB,EAAA;AACxE,QAAA,IAAI,CAAC,KAAK;AAAE,YAAA,OAAO,CAAC;AAEpB,QAAA,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1C,IAAI,YAAY,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE;AACtC,gBAAA,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK;;;AAGzB,QAAA,OAAO,CAAC;;AAEX;;ACrCD,MAAM,mBAAmB,GAAG,wzBAAwzB;;MCSv0B,gBAAgB,GAAA,MAAA;AAE3B,IAAA,WAAA,CAAA,OAAA,EAAA;;AAYS,QAAA,IAAgB,CAAA,gBAAA,GAAW,CAAC;AAI5B,QAAA,IAAS,CAAA,SAAA,GAAY,KAAK;AAC1B,QAAA,IAAS,CAAA,SAAA,GAAY,KAAK;AAkN3B,QAAA,IAAA,CAAA,cAAc,GAAG,CAAC,QAAgB,KAAI;AAC5C,YAAA,IAAI,CAAC,aAAa,GAAG,QAAQ;AAC/B,SAAC;AApOC,QAAA,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAK;YACvB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,mCAAmC,CAAC;YAC7E,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,kCAAkC,CAAC;YACzE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,8BAA8B,CAAC;YAClE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,sCAAsC,CAAC;AAC3E,SAAC,CAAC;AACH;AAkBD,IAAA,MAAM,iBAAiB,GAAA;AACrB,QAAA,IAAI;AACF,YAAA,MAAM,KAAK,CAAC,OAAO,EAAE;AAErB,YAAA,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE;gBAC/B;;AAGF,YAAA,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE;gBAC3B;;AAGF,YAAA,IAAI,CAAC,SAAS,GAAG,IAAI;AAErB,YAAA,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,oBAAoB,EAAE;YACnD,IAAI,CAAC,SAAS,EAAE;gBACd;;AAGF,YAAA,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC;;QAEnC,OAAO,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,SAAS,GAAG,KAAK;YACtB,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE,KAAK,CAAC;;gBACzC;AACR,YAAA,IAAI,CAAC,SAAS,GAAG,KAAK;;;IAIlB,mBAAmB,GAAA;;AACzB,QAAA,OAAO,CAAA,EAAA,GAAA,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,QAAQ,CAAC,cAAc,CAAC;;IAG7D,eAAe,GAAA;;QACrB,OAAO,CAAC,EAAC,MAAA,CAAA,EAAA,GAAA,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,OAAO,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,KAAK,CAAA;;IAG5C,2BAA2B,CAAC,SAAgB,EAAE,UAAgB,EAAA;;;AAEpE,QAAA,OAAO,EAAE,UAAU,IAAI,EAAC,CAAA,EAAA,GAAA,SAAS,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,mBAAmB,CAAA,CAAC;;AAGzD,IAAA,MAAM,oBAAoB,GAAA;;AAChC,QAAA,IAAI;AACF,YAAA,MAAM,EAAE,IAAI,EAAE,GAAsB,MAAM,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE;AACjE,YAAA,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,KAAK,cAAc,CAAC;YAErE,IAAI,CAAC,WAAW,EAAE;AAChB,gBAAA,OAAO,IAAI;;;AAIb,YAAA,IAAI,CAAC,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,MAAA,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,0CAAE,MAAM,CAAC,EAAE;AACrF,gBAAA,IAAI,CAAC,SAAS,GAAG,KAAK;AACtB,gBAAA,OAAO,IAAI;;AAGb,YAAA,OAAO,WAAW;;QAClB,OAAO,KAAK,EAAE;AACd,YAAA,MAAM,KAAK;;;AAIP,IAAA,mBAAmB,CAAC,YAAmB,EAAA;;AAC7C,QAAA,IAAI,CAAC,YAAY,GAAG,YAAY;;QAGhC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC;AAChE,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,IAAI,CAAC,kBAAkB;;AAG5E,QAAA,MAAM,YAAY,GAAG,CAAA,CAAA,EAAA,GAAA,IAAI,CAAC,YAAY,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,aAAa,KAAI,CAAC;QAClE,MAAM,gBAAgB,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC;;AAGhE,QAAA,IAAI,gBAAgB,KAAK,CAAC,EAAE;AAC1B,YAAA,IAAI,CAAC,SAAS,GAAG,KAAK;YACtB;;AAGF,QAAA,IAAI,CAAC,gBAAgB,GAAG,gBAAgB;AACxC,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,gBAAgB,CAAC;AAC7F,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW;AACrC,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI;;IAGvB,gBAAgB,GAAA;QACd,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,WAAW,KAAI;AAC9C,YAAA,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC;AACrC,SAAC,CAAC;;AAGI,IAAA,iBAAiB,CAAC,OAAc,EAAA;;AAEtC,QAAA,MAAM,eAAe,GAAG,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,SAAS,CAAC;AAEhG,QAAA,MAAM,KAAK,GAAsB,eAAe,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,MAAM;YACzE,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,SAAS,EAAE,QAAQ,CAAC,IAAI;AACxB,YAAA,QAAQ,EAAE,QAAQ,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,GAAG,CAAG,EAAA,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC;AAC9H,YAAA,IAAI,EAAE,mBAAmB,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC;YAClF,SAAS,EAAE,QAAQ,CAAC,SAAS;AAC7B,YAAA,UAAU,EAAE,mBAAmB,CAAC,YAAY,CAAC,KAAK,CAAC;YACnD,KAAK,EAAE,KAAK,GAAG;AAChB,SAAA,CAAC,CAAC;QAEH,OAAO;AACL,YAAA,YAAY,EAAE,SAAS,CAAC,kBAAkB,CAAC,KAAK,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YAClH;SACD;;IAGK,oBAAoB,CAAC,YAAoB,EAAE,KAAmC,EAAA;;AAAnC,QAAA,IAAA,KAAA,KAAA,MAAA,EAAA;YAAA,KAAQ,GAAA,CAAA,EAAA,GAAA,IAAI,CAAC,eAAe,0CAAE,KAAK;;QACpF,OAAO,SAAS,CAAC,oBAAoB,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE,CAAC;;AAG1D,IAAA,iBAAiB,CAAC,WAA8D,EAAA;;QACtF,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YAC/C;;;AAIF,QAAA,IAAI,CAAC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,MAAM,CAAC,EAAE;AAC5E,YAAA,IAAI,CAAC,SAAS,GAAG,KAAK;YACtB;;;AAIF,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI;;AAGrB,QAAA,IAAI,CAAA,CAAA,EAAA,GAAA,IAAI,CAAC,YAAY,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,iBAAiB,MAAK,KAAK,EAAE;YAC1D;;;AAIF,QAAA,MAAM,YAAY,GAAG,WAAW,CAAC,SAAS;QAC1C,IAAI,CAAC,YAAY,GAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACZ,IAAI,CAAC,YAAY,KACpB,OAAO,EAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACF,IAAI,CAAC,YAAY,CAAC,OAAO,CAAA,EAAA,EAC5B,aAAa,EAAE,YAAY,MAE9B;;QAGD,MAAM,YAAY,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC;;AAG5D,QAAA,IAAI,YAAY,KAAK,CAAC,EAAE;AACtB,YAAA,IAAI,CAAC,SAAS,GAAG,KAAK;YACtB;;;AAIF,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI;AACrB,QAAA,IAAI,CAAC,gBAAgB,GAAG,YAAY;AACpC,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,YAAY,CAAC;;QAGzF,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,CAAC,WAAW,EAAE;AAC3C,YAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW;;;IAIjC,sBAAsB,GAAA;AAC5B,QAAA,OAAOA,QAACC,UAAI,EAAA,IAAA,EACVD,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,0BAA0B,EAAA,EACnCA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,iCAAiC,EAAA,EAC1CA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,+BAA+B,EAAA,EACxCA,OAAgB,CAAA,gBAAA,EAAA,EAAA,MAAM,EAAC,MAAM,EAAC,KAAK,EAAC,KAAK,GAAG,CACxC,EACNA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,kCAAkC,EAAA,EAC3CA,OAAgB,CAAA,gBAAA,EAAA,EAAA,MAAM,EAAC,MAAM,EAAC,KAAK,EAAC,KAAK,GAAG,CACxC,EACNA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,kCAAkC,EAAA,EAC3CA,OAAgB,CAAA,gBAAA,EAAA,EAAA,MAAM,EAAC,MAAM,EAAC,KAAK,EAAC,MAAM,GAAG,CACzC,EACNA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,8BAA8B,EAAA,EACvCA,OAAA,CAAA,gBAAA,EAAA,EAAgB,MAAM,EAAC,MAAM,EAAC,KAAK,EAAC,MAAM,EAAA,CAAG,CACzC,CACF,CACF,CACD;;IAGD,kBAAkB,GAAA;QACxB,OAAO,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;;IAG9G,gBAAgB,GAAA;;AACtB,QAAA,MAAM,YAAY,GAAG,CAAA,CAAA,EAAA,GAAA,IAAI,CAAC,YAAY,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,aAAa,KAAI,CAAC;QAClE,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM;;QAGpD,MAAM,gBAAgB,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC;;QAGhE,MAAM,cAAc,GAAG,gBAAgB;AACvC,QAAA,OAAO,CAAC,cAAc,GAAG,UAAU,IAAI,GAAG;;IAOpC,0BAA0B,CAAC,KAAa,EAAE,UAAkB,EAAA;AAClE,QAAA,IAAI,UAAU,KAAK,CAAC,EAAE;AACpB,YAAA,OAAO,mBAAmB;;AAE5B,QAAA,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,IAAI,UAAU,IAAI,GAAG;AACzD,QAAA,MAAM,aAAa,GAAG,CAAC,GAAG,UAAU;AACpC,QAAA,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,gBAAgB,GAAG,aAAa,CAAC,CAAC,GAAG;;AAGlE,IAAA,kBAAkB,CAAC,IAAqB,EAAE,KAAa,EAAE,UAAkB,EAAA;QACjF,MAAM,KAAK,GAAG,QAAQ,CAAC,eAAe,CAAC,GAAG,KAAK,KAAK;QACpD,MAAM,eAAe,GAAG,IAAI,CAAC,0BAA0B,CAAC,KAAK,EAAE,UAAU,CAAC;AAC1E,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,UAAU,GAAG,QAAQ;QAE/D,OAAO;YACL,CAAC,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,eAAe;YAC3C,UAAU;AACV,YAAA,QAAQ,EAAE,UAAmB;YAC7B,SAAS,EAAE,KAAK,GAAG,iBAAiB,GAAG;SACxC;;AAGK,IAAA,sBAAsB,CAAC,IAAqB,EAAE,SAAkB,EAAE,SAAkB,EAAA;QAC1F,IAAI,SAAS,EAAE;AACb,YAAA,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE;;QAEnC,IAAI,SAAS,EAAE;AACb,YAAA,OAAO,EAAE,KAAK,EAAE,sBAAsB,EAAE;;AAE1C,QAAA,OAAO,EAAE;;AAGH,IAAA,2BAA2B,CAAC,aAAqB,EAAA;QACvD,OAAO;YACLA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,4BAA4B,EAAO,CAAA;AAC9C,YAAAA,OAAA,CAAA,KAAA,EAAA,EACE,KAAK,EAAC,8BAA8B,EACpC,KAAK,EAAE,EAAE,KAAK,EAAE,CAAA,EAAG,aAAa,CAAG,CAAA,CAAA,EAAE,EACjC;SACP;;AAGK,IAAA,mBAAmB,CAAC,IAAqB,EAAE,SAAkB,EAAE,SAAkB,EAAA;AACvF,QAAA,MAAM,WAAW,GAAG;YAClB,+BAA+B;AAC/B,YAAA,SAAS,GAAG,iCAAiC,GAAG,EAAE;AAClD,YAAA,SAAS,GAAG,oCAAoC,GAAG;SACpD,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;AAE3B,QAAA,QACEA,OACE,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,SAAS,EAAE,SAAS,CAAC,EAAA,EAC9DA,OAAM,CAAA,MAAA,EAAA,EAAA,SAAS,EAAE,IAAI,CAAC,IAAI,EAAS,CAAA,CAC/B;;IAIF,mBAAmB,CAAC,IAAqB,EAAE,SAAkB,EAAA;AACnE,QAAA,QACEA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,+BAA+B,EACvC,EAAA,SAAS,KACRA,OAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,EACpC,EAAA,IAAI,CAAC,IAAI,CACL,CACR,CACG;;IAIF,gBAAgB,CAAC,YAAoB,EAAE,UAAkB,EAAA;AAC/D,QAAA,MAAM,cAAc,GAAG,UAAU,KAAK;AACpC,cAAE;cACA,2BAA2B;AAE/B,QAAA,QACEA,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,mCAAmC,EAAA,EAC5CA,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAE,cAAc,EACvB,EAAA,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAEE,OAAK,KAAI;AAC9C,YAAA,MAAM,SAAS,GAAG,YAAY,IAAI,IAAI,CAAC,SAAS;YAChD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,WAAW;YAErD,QACEF,OACE,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,0BAA0B,EAChC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAEE,OAAK,EAAE,UAAU,CAAC,EAAA,EACtD,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,SAAS,EAAE,SAAS,CAAC,EACpD,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,SAAS,CAAC,CACtC;AAEV,SAAC,CAAC,CACE,CACF;;IAIF,iBAAiB,GAAA;;AACvB,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE;QAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM;AACpD,QAAA,MAAM,YAAY,GAAG,CAAA,CAAA,EAAA,GAAA,IAAI,CAAC,YAAY,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,aAAa,KAAI,CAAC;AAElE,QAAA,QACEF,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,mCAAmC,EAAA,EAC5CA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,iCAAiC,EAAA,EACzC,IAAI,CAAC,2BAA2B,CAAC,aAAa,CAAC,EAC/C,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,UAAU,CAAC,CAC5C,CACF;;IAIF,UAAU,GAAA;AAChB,QAAA,QACEA,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,+BAA+B,EAAA,EAExCA,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,4BAA4B,EAAA,EACpC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,IAAG;YACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,aAAa;YACtD,QACEA,OAAA,CAAA,QAAA,EAAA,EACE,KAAK,EAAE,CAA6B,0BAAA,EAAA,QAAQ,GAAG,2BAA2B,GAAG,EAAE,CAAA,CAAE,EACjF,OAAO,EAAE,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,EAAA,EAClDA,OAAA,CAAA,MAAA,EAAA,IAAA,EAAO,IAAI,CAAC,IAAI,CAAQ,CACjB;AAEb,SAAC,CAAC,CACE,EAGNA,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,oCAAoC,EAC5C,EAAA,CAAC,MAAK;AACL,YAAA,MAAM,UAAU,GAAG,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC;AAC3F,YAAA,IAAI,CAAC,UAAU;AAAE,gBAAA,OAAO,IAAI;AAE5B,YAAA,QACEA,OAAA,CAAA,KAAA,EAAA,EAAK,KAAK,EAAC,4BAA4B,EAAA,EACrCA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,kCAAkC,EAAA,EAC3CA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,iCAAiC,EAAA,EAC1CA,OAAG,CAAA,GAAA,EAAA,EAAA,KAAK,EAAC,+BAA+B,EAAA,EACrC,IAAI,CAAC,YAAY,OAAEA,OAAA,CAAA,MAAA,EAAA,EAAM,SAAS,EAAE,UAAU,CAAC,QAAQ,GAAS,CAC/D,EACJA,OAAG,CAAA,GAAA,EAAA,EAAA,KAAK,EAAC,oCAAoC,EAAA,EAC1C,IAAI,CAAC,WAAW,OAAG,UAAU,CAAC,IAAI,CACjC,CACA,CACF,CACF;AAEV,SAAC,GAAG,CACA,CACF;;IAIV,MAAM,GAAA;AAEJ,QAAA,IAAI,IAAI,CAAC,SAAS,EAAE;AAClB,YAAA,OAAO,IAAI,CAAC,sBAAsB,EAAE;;QAGtC,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;AAC5C,YAAA,OAAO,IAAI;;AAIb,QAAA,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE;QAEjD,QACEA,QAACC,UAAI,EAAA,IAAA,EACHD,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,0BAA0B,EAAA,EAEnCA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,uBAAuB,EAAA,EAChCA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,+BAA+B,EAAA,EACxCA,OAAA,CAAA,GAAA,EAAA,EAAG,KAAK,EAAC,8BAA8B,IAAE,IAAI,CAAC,kBAAkB,CAAK,EACrEA,OAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,0CAA0C,EAAA,EACnDA,OAAI,CAAA,IAAA,EAAA,EAAA,KAAK,EAAC,6BAA6B,EAAA,EACpC,IAAI,CAAC,eAAe,OAAEA,OAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,0BAA0B,EAAA,EAAE,eAAe,CAAC,IAAI,CAAQ,CACxF,EACLA,OAAM,CAAA,MAAA,EAAA,EAAA,SAAS,EAAE,eAAe,CAAC,IAAI,EAAS,CAAA,CAC1C,CACF,CACF,EAGL,IAAI,CAAC,iBAAiB,EAAE,EAGxB,IAAI,CAAC,UAAU,EAAE,CACd,CACD;;;;;;;"}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
-
var index = require('./index-
|
|
6
|
+
var index = require('./index-1TYwVkJb.js');
|
|
7
7
|
|
|
8
8
|
const sallaTooltipCss = ".s-tooltip-container{position:relative;display:inline-block}.s-tooltip-item{position:absolute;-webkit-transform:translateX(-39%);transform:translateX(-39%);background-color:#baf3e6;color:#004d5a;bottom:100%;left:50%;text-align:center;border-radius:5px;z-index:1;white-space:nowrap;opacity:0;-webkit-transition:opacity 0.3s;transition:opacity 0.3s;pointer-events:none;margin:0 0 16px 8px;padding:12px;max-width:150px;width:190px;white-space:normal;opacity:1}.s-tooltip-item::after{content:\"\";position:absolute;bottom:-10px;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#baf3e6 transparent transparent transparent}.s-tooltip-item:dir(ltr){-webkit-transform:translateX(-72%);transform:translateX(-72%)}";
|
|
9
9
|
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
-
var index = require('./index-
|
|
6
|
+
var index = require('./index-1TYwVkJb.js');
|
|
7
7
|
|
|
8
8
|
const sallaWalletCss = ".s-wallet-table{min-width:100%}.s-wallet-table-balance-container{display:-ms-flexbox !important;display:flex !important;-ms-flex-align:center !important;align-items:center !important;-ms-flex-pack:start !important;justify-content:flex-start !important;gap:1rem}.s-wallet-table-balance-icon{border-radius:50%;width:52px;height:52px;font-size:25px;padding:16px 13px;background:var(--color-primary-reverse);color:var(--color-primary)}.s-wallet-table-empty-state{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-align:center;align-items:center}.s-wallet-table-empty-state i{font-size:80px;margin:4rem 0 2rem;color:var(--infinte-color)}.s-wallet-table-transaction-status{padding:6px 19px !important;border-radius:20px;width:-webkit-max-content;width:-moz-max-content;width:max-content;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.s-wallet-table-transaction-status-default{background:#fff6eb;color:#a46f29}.s-wallet-table-transaction-status-cashback{background:#effbf6;color:#00af6c}.s-wallet-table-transaction-status-refund{background:#ecf3fe;color:#5196f3}.s-wallet-table-transaction-status-purchase{background:#feecec;color:#f55157}.s-wallet-table-transaction-status-icons-success{color:#00af6c}";
|
|
9
9
|
|