UNPKG

@salla.sa/twilight-components

Version:
253 lines (243 loc) 19.6 kB
/*! * Crafted with ❤ by Salla */ import { r as registerInstance, c as createEvent, h, H as Host } from './index-BHYtfMwX.js'; import { c as closeModals, b as brand_path, f as formattedPointsJsx } from './functions-BwIeBNND.js'; import { S as SIGift } from './gift-CXRKXFgT.js'; import { S as SITag } from './tag-cgSL_BIo.js'; import { S as SICheck } from './check-BZp0rKEO.js'; import { S as SICancel } from './cancel-8Tsmrwno.js'; import { T as TrackedPromise } from './tracked-promise-p8K_AJAQ.js'; const sallaLoyaltyProgramCss$3 = ""; const SallaRewardAction = class { constructor(hostRef) { registerInstance(this, hostRef); this.actionClick = createEvent(this, "actionClick"); this.isShopNow = (prize) => { if (!(salla.config.get('store.features') || []).includes('loyalty-system-v2')) { return false; } return prize.key?.toLowerCase() === 'free_product'; }; this.handleClick = (e) => { if (salla.config.isGuest()) { closeModals(() => salla.event.dispatch('login::open')); return; } this.actionClick.emit(e); }; } render() { return (h("div", { key: '95d6e753d49c7cb69e6f5e25ef6ccf3f916f4022', class: "s-loyalty-program-rewards-modal-action" }, this.isShopNow(this.prize) ? (h("a", { href: this.prize.prize_url || salla.url.get(''), class: { 's-loyalty-program-rewards-action-base': true, 's-loyalty-program-rewards-action-on': true, } }, salla.lang.get('pages.loyalty_program.shop_now'))) : (h("button", { onClick: this.handleClick, class: { 's-loyalty-program-rewards-action-base': true, 's-loyalty-program-rewards-action-on': true, } }, salla.lang.get('pages.loyalty_program.redeem_reward'))))); } }; SallaRewardAction.style = sallaLoyaltyProgramCss$3; const sallaLoyaltyProgramCss$2 = ""; const SallaRewardCard = class { constructor(hostRef) { registerInstance(this, hostRef); this.areaClick = createEvent(this, "areaClick"); this.actionClick = createEvent(this, "actionClick"); } render() { return (h(Host, { key: '900a20618e1b3ce82778aa99715baf61689f3eee', class: "s-loyalty-program-reward-host" }, h("div", { key: '95b326008c2799ee7d38b48bc57e0860a9386184', class: "s-loyalty-program-reward-container" }, h("div", { key: 'd846dc36fa4494ed9ac6152a982f18598936969f', onClick: (e) => this.areaClick.emit(e), role: "button" }, h("div", { key: 'b8d23796827e4b07f6c271c50fa0e4aeb59f82fc', class: "s-loyalty-program-reward-img" }, h("img", { key: '04a52401941d8a731e8d310397b1ad735bfe44db', alt: "", src: this.prize.image || salla.url.cdn('images/s-empty.png'), class: "s-loyalty-program-rewards-img" })), h("div", { key: '64fa967c98d615d7b16859c9d14b60e0c53fc5aa', class: "s-loyalty-program-reward-content" }, h("div", { key: 'bb8c34ce8f3bcec9599c87b56bea6abd793187df', class: "s-loyalty-program-reward-points" }, h("salla-badge", { key: 'f7d0a396cf754d1e8f9e8fddee53a7d545311148', size: "xs" }, h("span", { key: '36f4e1ed873f1a231e2d5e51a2a8cc36bdcedfee', innerHTML: SIGift }), h("span", { key: '638b3ecefbfcb424869987ab33478e67d9b5d9b8', class: "s-loyalty-program-rewards-points" }, this.prize.cost_points, " ", salla.lang.get('pages.loyalty_program.points')))), h("div", { key: '6f8386fccf201836d76a86e7fe5e6d3461bb5540', class: "s-loyalty-program-reward-title" }, h("span", { key: '6d6692c44d6bac35da40108514471a3c56884d81' }, this.prize.group_title)), h("div", { key: '6ad9ad90728ac7f882ff8db9cfadb5a6e12f3e25', class: "s-loyalty-program-reward-name" }, h("div", { key: 'ef4344c7cb67785a4cd66d36e303e40a610a5375', class: "s-loyalty-program-rewards-name", id: `prize-${this.prize.id}` }, this.prize.name, this.prize.description ? `: ${this.prize.description}` : '')))), h("div", { key: '5eee5a4f8b10cd790ce41e4a99d94f86bd26dd3b', class: "p-4" }, h("slot", { key: '359d50033cdd3cce41901401bf0b75ba9c5aea1f', name: "action" }, h("button", { key: 'ea7aa1c5cd50937a27cef7580e508a1e3f8f852d', onClick: (e) => this.actionClick.emit(e.detail), class: "s-loyalty-program-rewards-action-base s-loyalty-program-rewards-action-on" }, salla.lang.get('pages.loyalty_program.show_reward'))))))); } }; SallaRewardCard.style = sallaLoyaltyProgramCss$2; const sallaLoyaltyProgramCss$1 = ""; var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; const c = (...args) => args.map(i => 's-loyalty-program-' + i).join(' '); const SallaRewardDetails = class { constructor(hostRef) { registerInstance(this, hostRef); this.actionClick = createEvent(this, "actionClick"); this.refreshKey = Date.now(); } handlePrizeChange() { this.refreshKey = Date.now(); } componentWillLoad() { if (this.category.status === 'idle') { this.category(); } if (this.brand.status === 'idle') { this.brand(); } } getTermsAndConditions() { const minimumAmount = Number((this.prize.order_minimum_amount || '0').split('.')[0]) || 0; const maximumAmount = Number((this.prize.coupon_maximum_amount || '0').split('.')[0]) || 0; const termsAndConditions = []; if (minimumAmount) { termsAndConditions.push([ salla.lang.get('pages.loyalty_program.order_minimum_amount'), `${minimumAmount} ${salla.lang.get(`currency.${(salla.config.get('user.currency_code') || '').toLowerCase()}`)}`, ]); } if (maximumAmount) { termsAndConditions.push([ salla.lang.get('pages.loyalty_program.coupon_maximum_amount'), `${maximumAmount} ${salla.lang.get(`currency.${(salla.config.get('user.currency_code') || '').toLowerCase()}`)}`, ]); } return termsAndConditions; } findItems(ids) { if (!ids?.length) return []; const brands = this.brand.data; const categories = this.category.data; // id_ is the numeric ID from the API (e.g. 740744759); id is a string hash (e.g. "zEVZGx"). included_category_ids/included_brand_ids are number[], so id_ is correct here. return brands.concat(categories).filter(i => ids.includes(i.id_)); } getIncludedItems(items, ids) { if (items?.length) { return items; } if (ids?.length) { return this.findItems(ids); } return []; } getProductIds(ids) { return ids || []; } getItemsMarkers(key) { if (key === 'both') { return this.getItemsMarkers('included') + this.getItemsMarkers('excluded'); } return [ this.prize[`${key}_product_ids`]?.length || 0, this.prize[`${key}_brand_ids`]?.length || 0, this.prize[`${key}_category_ids`]?.length || 0, ].map(Boolean).map(Number).join(''); } getItemsMarkersText() { // Check if prize type is free_shipping if (this.prize.key === 'FREE_SHIPPING') { return salla.lang.get('pages.loyalty_program.redeem_for_free_shipping'); } switch (this.getItemsMarkers('included')) { case '001': return salla.lang.get('pages.loyalty_program.redeem_on_specific_products'); case '010': return salla.lang.get('pages.loyalty_program.redeem_on_specific_brands'); case '100': return salla.lang.get('pages.loyalty_program.redeem_on_specific_categories'); case '000': return salla.lang.get('pages.loyalty_program.redeem_on_all_products'); default: return salla.lang.get('pages.loyalty_program.redeem_on_specific_products'); } } getCategoriesJsx(items, title) { return !items.length ? '' : h("div", { class: c('reward-details-categories-wrapper') }, h("div", { class: c('reward-details-categories') }, h("h2", { class: c('reward-details-categories-heading') }, title), h("ul", { class: c('reward-details-categories-list') }, items.map((category) => { return (h("li", null, h("a", { href: category.urls?.customer || category.url || category.lingual_urls?.[0], class: c('reward-details-categories-item') }, h("span", { innerHTML: SITag }), h("span", { class: c('reward-details-categories-item-content') }, category.name)))); })))); } getBrandsJsx(items, title) { return !items.length ? '' : h("div", { class: c('reward-details-items-brands', 'slider-arrows-edges') }, h("div", null, h("h2", null, title), h("salla-slider", { id: `brands-${items.map(({ id }) => id).join('-')}`, "slider-config": '{"loop":false,"slidesPerView":"auto","spaceBetween":10}' }, h("div", { slot: "items" }, items.map((brand) => (h("a", { href: salla.url.get(brand_path(brand)), class: c('reward-brand-item') }, h("img", { src: brand.logo || salla.url.cdn('images/s-empty.png'), alt: "" })))))))); } getProductsJsx(items, title) { return !items?.length ? '' : h("div", { class: "s-loyalty-program-reward-details-items-products s-loyalty-program-slider-arrows-edges" }, h("h2", null, title), h("salla-products-slider", { source: "selected", sourceValue: JSON.stringify(items), "slider-config": '{"loop":false,"slidesPerView":"auto","freeMode":true,"spaceBetween":0,"breakpoints":{"768":{"slidesPerView":3,"freeMode":false,"speed":300}}}' })); } render() { const termsAndConditions = this.getTermsAndConditions(); return (h("div", { key: '280d646eff094c16596ca31ee57f4bd104958f8c', class: "s-loyalty-program-reward-modal" }, h("div", { key: 'a39d376f170684f754c4357dc64d02b5ffbb1ed2', class: "s-loyalty-program-points-modal-header" }, h("h1", { key: '654e061c8852461a5248248ed2d95ef02a8a4711', class: "s-loyalty-program-points-modal-info" }, !salla.url.is_page('cart') ? '' : h("button", { class: "s-loyalty-program-back-btn", onClick: () => closeModals(() => salla.event.dispatch('modal::open', 'loyalty-rewards-modal')) }, h("span", { class: { 'sicon-arrow-right': document.documentElement.getAttribute('dir') === 'rtl', 'sicon-arrow-left': document.documentElement.getAttribute('dir') === 'ltr', } })), this.prize.name)), h("div", { key: '8dce07ce81b0d6879efc0cba88523b6d3daf42bb', class: "s-loyalty-program-modal-scrollable-content" }, h("div", { key: 'f288d7483911af0bbc17a824ee4397ad0b3ef367', class: "s-loyalty-program-reward-details-header" }, h("div", { key: '87686174a3a8c17558d0a97180cb4756a1edbefe', class: "s-loyalty-program-aspect-container" }, h("img", { key: '31461e1503c50715f160e75cf7ffad59939fb93c', src: this.prize.image, alt: this.prize.name })), h("salla-badge", { key: 'ed1fc08260885fa865279a9d2fc6af35c01e2bdc', size: "sm", bg: "light" }, h("span", { key: '26eec953f9c5f3fa5aa118828faec50a4477e013', innerHTML: SIGift }), h("span", { key: 'db3bf908be0f28534e121da9e692d801d2ee6cf9', class: "s-loyalty-program-points-badge-points" }, formattedPointsJsx(this.prize.cost_points)))), !termsAndConditions.length ? '' : h("div", { class: "s-loyalty-program-terms-and-conditions" }, h("h1", { class: "s-loyalty-program-terms-and-conditions-heading" }, salla.lang.get('pages.loyalty_program.terms_and_conditions')), h("ul", { class: "s-loyalty-program-terms-and-conditions-list" }, termsAndConditions.map(([title, points]) => (h("li", { class: "s-loyalty-program-terms-and-conditions-item" }, h("span", { class: "s-loyalty-program-terms-and-conditions-content" }, title), h("span", { class: "s-loyalty-program-terms-and-conditions-content" }, points)))))), h("div", { key: 'bfdc4d22117ae86f3bb2140546b4b5a8ecd35f8e', class: "s-loyalty-program-reward-info-message" }, h("h1", { key: 'f03b30c0372fd83e4fa7815bbd76d307c6fbe3c1', class: "s-loyalty-program-reward-info-message-heading" }, salla.lang.get('pages.loyalty_program.how_to_benefit_from_this_reward')), h("p", { key: '245acd0b8438230ff5d503e5819abb581f0ba14a', class: "s-loyalty-program-reward-info-message-content" }, this.getItemsMarkersText())), (this.prize.key === 'FREE_SHIPPING' || this.getItemsMarkers('both') === '000000') ? '' : h("div", { class: "s-loyalty-program-reward-details" }, h("salla-tabs", { key: this.refreshKey }, this.getItemsMarkers('included') === '000' ? '' : [ h("salla-tab-header", { slot: "header", name: "included", style: { display: this.getItemsMarkers('excluded') === '000' ? 'none' : 'block', } }, h("span", { class: "s-loyalty-program-reward-details-tab-icon", innerHTML: SICheck }), h("span", null, salla.lang.get(`pages.loyalty_program.included`))), h("salla-tab-content", { slot: "content", name: "included" }, h("div", { class: "s-loyalty-program-reward-details-items-wrapper" }, this.getCategoriesJsx(this.getIncludedItems(this.prize.categories, this.prize.included_category_ids), salla.lang.get('pages.loyalty_program.included_categories')), this.getBrandsJsx(this.getIncludedItems(this.prize.brands, this.prize.included_brand_ids), salla.lang.get('pages.loyalty_program.included_brands')), this.getProductsJsx(this.getProductIds(this.prize.included_product_ids), salla.lang.get('pages.loyalty_program.included_products')))), ], this.getItemsMarkers('excluded') === '000' ? '' : [ h("salla-tab-header", { slot: "header", name: "excluded", style: { display: this.getItemsMarkers('included') === '000' ? 'none' : 'block', } }, h("span", { class: "s-loyalty-program-reward-details-tab-icon", innerHTML: SICancel }), h("span", null, salla.lang.get(`pages.loyalty_program.excluded`))), h("salla-tab-content", { slot: "content", name: "excluded" }, h("div", { class: "s-loyalty-program-reward-details-items-wrapper" }, this.getCategoriesJsx(this.getIncludedItems(this.prize.excludedCategories, this.prize.excluded_category_ids), salla.lang.get('pages.loyalty_program.excluded_categories')), this.getBrandsJsx(this.getIncludedItems(this.prize.excludedBrands, this.prize.excluded_brand_ids), salla.lang.get('pages.loyalty_program.excluded_brands')), this.getProductsJsx(this.getProductIds(this.prize.excluded_product_ids), salla.lang.get('pages.loyalty_program.excluded_products')))), ]))), h("salla-reward-action", { key: 'e129546afde7da7fe66e250ce4de67d4523727be', onActionClick: e => this.actionClick.emit(e.detail), prize: this.prize }))); } static get watchers() { return { "prize": ["handlePrizeChange"] }; } }; __decorate$1([ TrackedPromise(async () => { return (await salla.product.api.categories()).data; }, { initialData: [] }) ], SallaRewardDetails.prototype, "category", void 0); __decorate$1([ TrackedPromise(async () => { return (await salla.api.request('/brands')).data; }, { initialData: [] }) ], SallaRewardDetails.prototype, "brand", void 0); SallaRewardDetails.style = sallaLoyaltyProgramCss$1; const sallaLoyaltyProgramCss = ""; var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; const SallaRewardExchange = class { constructor(hostRef) { registerInstance(this, hostRef); this.productId = null; } reset(timeout = 0) { setTimeout(() => { closeModals(); }, timeout); } getApiErrorMessage(error) { return error?.response?.data?.error?.message || error?.response?.data?.message || (typeof error === 'string' ? error : null) || salla.lang.get('common.errors.error_occurred'); } async handleConfirm() { try { await this.exchange(this.prize.id, null, this.productId); this.reset(300); } catch (error) { salla.notify.error(this.getApiErrorMessage(error)); } } handleCancel() { this.reset(0); } render() { return (h(Host, { key: 'ceecba37884a11443b52b76dad69bd164b52b788' }, h("div", { key: '598f185363b917969b9de0fb6a536884d6578c95', class: "s-loyalty-program-exchange-heading" }, h("div", { key: 'a2aa6b15d97533a973f7f2fb6a2cf517c147367d', class: "s-loyalty-program-circle-base s-loyalty-program-circle-size-xl s-loyalty-program-circle-variant-fill" }, h("span", { key: '9745001d514643add62fe9a64df7fc2c0a694513', innerHTML: SIGift })), h("h2", { key: '4819327aacc1307c0f75014d9faef50f55115289' }, salla.lang.get('pages.loyalty_program.redeem_reward')), h("p", { key: 'b39c99abcefb0f3baf609cd21049b083a115cdef' }, salla.lang.get('pages.loyalty_program.redeem_confirmation'), " ", h("span", { key: '50852d87c9686f66beddc7b0a0a3062f0ced1a61' }, "(", this.prize.cost_points, " ", salla.lang.get('pages.loyalty_program.point'), ")"), " ", salla.lang.get('pages.loyalty_program.for'), " ", h("span", { key: '5a4baa0f02859ced6fdcf7ce77c31bf9b27c45e6' }, "(", this.prize.name, ")"))), h("div", { key: 'b1f1067bd0f3a84231ac017f4b66a71277a5d209', class: "s-loyalty-program-exchange-btns" }, h("button", { key: '7d4ce6c08fcac58290b364a0df55f8acb715d362', class: "s-loyalty-program-rewards-action-base s-loyalty-program-rewards-action-confirm", onClick: () => this.handleConfirm() }, h("span", { key: 'ef1deb96c4bbb2843ae088b539848c15aacdb244', style: { opacity: this.exchange.status !== 'pending' ? '1' : '0', } }, salla.lang.get('common.elements.confirm')), h("span", { key: '0f949386c85d7544f7098e2bdc8c7ce4390c4383', class: "s-loyalty-program-exchange-loading", style: { opacity: this.exchange.status === 'pending' ? '1' : '0', } }, h("salla-loading", { key: '9cdfbfdc7ebfb2e1874f1956560dc464e4aa2a9f', color: "primary", size: 24 }))), h("button", { key: '79a2e8b44be5eb4b3ec5f1a285a8f4eba5324814', class: "s-loyalty-program-rewards-action-base s-loyalty-program-rewards-action-cancel", onClick: () => this.handleCancel() }, salla.lang.get('common.elements.cancel'))))); } }; __decorate([ TrackedPromise(async (...args) => await salla.loyalty.exchange(...args)) ], SallaRewardExchange.prototype, "exchange", void 0); SallaRewardExchange.style = sallaLoyaltyProgramCss; export { SallaRewardAction as salla_reward_action, SallaRewardCard as salla_reward_card, SallaRewardDetails as salla_reward_details, SallaRewardExchange as salla_reward_exchange };