Purple Watermelon Seeds🍉✨

$25.99 $35.99 Save $10.00
/** * 优惠码组件模型类 * 处理优惠码的显示和交互逻辑 */ class SpzCustomDiscountCodeModel extends SPZ.BaseElement { constructor(element) { super(element); // 复制按钮和内容的类名 this.copyBtnClass = "discount_code_btn" this.copyClass = "discount_code_value" } isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } buildCallback() { // 初始化服务 this.action_ = SPZServices.actionServiceForDoc(this.element); this.templates_ = SPZServices.templatesForDoc(this.element); this.xhr_ = SPZServices.xhrFor(this.win); } /** * 渲染优惠码组件 * @param {Object} data - 渲染数据 */ doRender_(data) { return this.templates_ .findAndRenderTemplate(this.element, Object.assign(this.getDefaultData(), data) ) .then((el) => { this.clearDom(); this.element.appendChild(el); // 绑定复制代码功能 this.copyCode(el, data); }); } /** * 获取渲染模板 * @param {Object} data - 渲染数据 */ getRenderTemplate(data) { const renderData = Object.assign(this.getDefaultData(), data); return this.templates_ .findAndRenderTemplate(this.element, renderData) .then((el) => { this.clearDom(); return el; }); } /** * 清除DOM内容 */ clearDom() { const children = this.element.querySelector('*:not(template)'); children && SPZCore.Dom.removeElement(children); } /** * 获取默认数据 * @returns {Object} 默认数据对象 */ getDefaultData() { return { isMobile: appDiscountUtils.judgeMobile(), isRTL: appDiscountUtils.judgeRTL(), image_domain: this.win.SHOPLAZZA.image_domain, copyBtnClass: this.copyBtnClass, copyClass: this.copyClass } } /** * 复制优惠码功能 * @param {Element} el - 当前元素 */ copyCode(el) { const copyBtnList = el.querySelectorAll(`.${this.copyBtnClass}`); if (copyBtnList.length > 0) { copyBtnList.forEach(item => { item.onclick = async () => { // 确保获取正确的元素和内容 const codeElement = item.querySelector(`.${this.copyClass}`); if (!codeElement) return; // 获取纯文本内容 const textToCopy = codeElement.innerText.trim(); // 尝试使用现代API,如果失败则使用备用方案 try { if (navigator.clipboard && navigator.clipboard.writeText) { await navigator.clipboard.writeText(textToCopy); } else { throw new Error('Clipboard API not available'); } // 显示复制成功提示 this.showCopySuccessToast(textToCopy, el); } catch (err) { console.error('Modern clipboard API failed, trying fallback...', err); // 使用备用复制方案 this.fallbackCopy(textToCopy, el); } const discountId = item.dataset["discountId"]; // 跳转决策: is_redirection + link(可选覆盖) const setting = { is_redirection: item.dataset["redirection"] === "true", link: item.dataset["link"], }; const landingUrl = `/promotions/discount-default/${discountId}`; const finalUrl = appDiscountUtils.resolveDiscountHref(setting, landingUrl); if (finalUrl && appDiscountUtils.inProductBody(this.element)) { this.win.open(finalUrl, '_blank', 'noopener'); } } }) } } /** * 使用 execCommand 的复制方案 * @param {string} codeText - 要复制的文本 * @param {Element} el - 当前元素 */ fallbackCopy(codeText, el) { const textarea = this.win.document.createElement('textarea'); textarea.value = codeText; // 设置样式使文本框不可见 textarea.style.position = 'fixed'; textarea.style.left = '-9999px'; textarea.style.top = '0'; // 添加 readonly 属性防止移动端虚拟键盘弹出 textarea.setAttribute('readonly', 'readonly'); this.win.document.body.appendChild(textarea); textarea.focus(); textarea.select(); try { this.win.document.execCommand('copy'); // 显示复制成功提示 this.showCopySuccessToast(codeText, el); } catch (err) { console.error('Copy failed:', err); } this.win.document.body.removeChild(textarea); } /** * 创建 Toast 元素 * @returns {Element} 创建的 Toast 元素 */ createToastEl_() { const toast = document.createElement('ljs-toast'); toast.setAttribute('layout', 'nodisplay'); toast.setAttribute('hidden', ''); toast.setAttribute('id', 'discount-code-toast'); toast.style.zIndex = '1051'; return toast; } /** * 挂载 Toast 元素到 body * @returns {Element} 挂载的 Toast 元素 */ mountToastToBody_() { const existingToast = this.win.document.getElementById('discount-code-toast'); if (existingToast) { return existingToast; } const toast = this.createToastEl_(); this.win.document.body.appendChild(toast); return toast; } /** * 复制成功的提醒 * @param {string} codeText - 要复制的文本 * @param {Element} el - 当前元素 */ showCopySuccessToast(codeText, el) { const $toast = this.mountToastToBody_(); SPZ.whenApiDefined($toast).then(toast => { toast.showToast("Discount code copied !"); this.codeCopyInSessionStorage(codeText); }); } /** * 复制优惠码成功后要存一份到本地存储中,购物车使用 * @param {string} codeText - 要复制的文本 */ codeCopyInSessionStorage(codeText) { try { sessionStorage.setItem('other-copied-coupon', codeText); } catch (error) { console.error(error) } } } // 注册自定义元素 SPZ.defineElement('spz-custom-discount-code-model', SpzCustomDiscountCodeModel);
/** * Custom discount code component that handles displaying and managing discount codes * @extends {SPZ.BaseElement} */ class SpzCustomDiscountCode extends SPZ.BaseElement { constructor(element) { super(element); // API endpoint for fetching discount codes this.getDiscountCodeApi = "\/api\/storefront\/promotion\/code\/list"; // Debounce timer for resize events this.timer = null; // Current variant ID this.variantId = "f893a39f-b51a-4ce0-b3a5-552215d199cb"; // Store discount code data this.discountCodeData = {} } /** * Check if layout is supported * @param {string} layout - Layout type * @return {boolean} */ isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } /** * Initialize component after build */ buildCallback() { this.templates_ = SPZServices.templatesForDoc(); this.viewport_ = this.getViewport(); // Bind methods to maintain context this.render = this.render.bind(this); this.resize = this.resize.bind(this); this.switchVariant = this.switchVariant.bind(this); } /** * Setup component when mounted */ mountCallback() { this.getData(); // Add event listeners this.viewport_.onResize(this.resize); this.win.document.addEventListener('dj.variantChange', this.switchVariant); } /** * Cleanup when component is unmounted */ unmountCallback() { this.viewport_.removeResize(this.resize); this.win.document.removeEventListener('dj.variantChange', this.switchVariant); // 清除定时器 if (this.timer) { clearTimeout(this.timer); this.timer = null; } } /** * Handle resize events with debouncing */ resize() { if (this.timer) { clearTimeout(this.timer) this.timer = null; } this.timer = setTimeout(() => { if (appDiscountUtils.inProductBody(this.element)) { this.render(); } else { this.renderSkeleton(); } }, 200); } /** * Handle variant changes * @param {Event} event - Variant change event */ switchVariant(event) { const variant = event.detail.selected; if (variant.product_id == '2fdb3398-fd9e-4b22-a8ed-8cf2b23902e1' && variant.id != this.variantId) { this.variantId = variant.id; this.getData(); } } /** * Fetch discount code data from API */ getData() { if (appDiscountUtils.inProductBody(this.element)) { const reqBody = { product_id: "2fdb3398-fd9e-4b22-a8ed-8cf2b23902e1", variant_id: this.variantId, product_type: "default", } if (!reqBody.product_id || !reqBody.variant_id) return; this.discountCodeData = {}; this.win.fetch(this.getDiscountCodeApi, { method: "POST", body: JSON.stringify(reqBody), headers: { "Content-Type": "application/json" } }).then(async (response) => { if (response.ok) { let data = await response.json(); if (data.list && data.list.length > 0) { data.list[0].product_setting.template_config = JSON.parse(data.list[0].product_setting.template_config); // Format timestamps to local timezone const zone = this.win.SHOPLAZZA.shop.time_zone; data.list = data.list.map(item => { if(+item.ends_at !== -1) { item.ends_at = appDiscountUtils.convertTimestampToFormat(+item.ends_at, zone); } item.starts_at = appDiscountUtils.convertTimestampToFormat(+item.starts_at, zone); return item; }); } this.discountCodeData = data; this.render(); } else { this.clearDom(); } }).catch(err => { console.error("discount_code", err) this.clearDom(); }); } else { this.renderSkeleton(); } } /** * Clear component DOM except template */ clearDom() { const children = this.element.querySelector('*:not(template)'); children && SPZCore.Dom.removeElement(children); } /** * Render discount codes with formatted dates */ render() { // Render using discount code model SPZ.whenApiDefined(document.querySelector('#spz_custom_discount_code_model')).then(renderApi => { renderApi.doRender_({ discountCodeData: this.discountCodeData }) }).catch(err => { this.clearDom(); }) } renderSkeleton() { // Render template for non-product pages this.templates_ .findAndRenderTemplate(this.element, { isMobile: appDiscountUtils.judgeMobile() }) .then((el) => { this.clearDom(); this.element.appendChild(el); }) .catch(err => { this.clearDom(); }); } } // Register custom element SPZ.defineElement('spz-custom-discount-code', SpzCustomDiscountCode);
Quantity:  200 Seeds ✨70% OFF
Quantity
Share the love
Free worldwide shipping
Free returns
Sustainably made
Secure payments
Description

Description

🪴We are committed to providing our customers with quality, affordable seeds. 🌱

💵 Payments Via PayPal® and CreditCard 
😍 99.3% of customers buy 2 items(10% Off) or more to share with family or friends
✨Priority is given to delivery after payment
✈ Worldwide Express Shipping Available

Introducing the Alluring Purple Watermelon 🍉✨

Unveil the marvel of nature—the Purple Watermelon. Known for its dazzling purple rind and unique cinnamon-kissed sweetness, this extraordinary fruit is a true delight for the senses and a conversation piece for any occasion. 🍇🌟

1. A Flavor Sensation: Juicy, sweet, and slightly spiced with cinnamon, each bite of Purple Watermelon is an unforgettable experience. Whether enjoyed fresh, blended into a refreshing juice, or featured in gourmet recipes, this fruit redefines deliciousness. 🍏🍷

2. Health Benefits Galore: Packed with antioxidants, anthocyanins, and essential nutrients, the Purple Watermelon promotes heart health, boosts immunity, and energizes your day. Nourish your body while indulging in its vibrant charm. 🌿💜

3. Sustainable & Rewarding: Growing Purple Watermelons supports eco-friendly practices and offers the joy of cultivating a stunning, rare fruit right in your own garden.

Grow Your Own Masterpiece 🌈🍉

Transform your garden with the vivid beauty of Purple Watermelon. Its rich color, delectable taste, and myriad benefits make it a treasure to grow and share.

Planting Tips for Success 🌱

  1. Choose the Right Location: Purple Watermelon thrives in warm, sunny spots with well-drained soil. Ensure your garden bed receives at least 6-8 hours of sunlight daily. ☀️

  2. Prepare the Soil: Use nutrient-rich, loamy soil with a pH between 6.0 and 6.8. Add compost or organic matter to improve fertility and drainage. 🌾

  3. Start with Seeds: Soak the seeds in water for 12-24 hours before planting to promote faster germination. Plant seeds 1 inch deep and space them 3 feet apart in rows that are 5-6 feet apart. 🌿

  4. Water Wisely: Keep the soil consistently moist but not waterlogged. Water deeply once or twice a week, adjusting based on rainfall and temperature. 🌧️

  5. Fertilize Regularly: Use a balanced fertilizer with equal parts nitrogen, phosphorus, and potassium during early growth. As vines develop, switch to a fertilizer higher in phosphorus and potassium to encourage flowering and fruiting. 🌱

  6. Provide Support: Allow the vines ample space to spread, or use trellises for vertical gardening. This helps prevent diseases and makes harvesting easier. 🍉

  7. Monitor for Pests: Watch for common pests like aphids and cucumber beetles. Use natural repellents or introduce beneficial insects like ladybugs to protect your plants. 🐞

  8. Harvest at the Right Time: Your Purple Watermelon is ready to harvest when the tendril nearest to the fruit turns brown, and the underside develops a creamy yellow spot. Knock lightly on the rind—a hollow sound indicates ripeness! 🍈

💐OUR GUARANTEE

📦 Insured shipping: Every order includes real-time tracking information and insurance coverage in the unlikely event that a package is lost or stolen in transit.

💰Money-back guarantee: If your items arrive damaged within 14 days of normal use, we will gladly provide you with a replacement item or your money back.

✉️Kundensupport 24/7: We have a team of live representatives available to assist you and answer all your questions within 24 hours, 7 days a week.

🔒Secure payments: We use state-of-the-art SSL encryption to keep your personal and financial information 100% secure.

🌎 WORLDWIDE SHIPPING ✈
Please note that shipping is insured worldwide. Tracking numbers are ALWAYS sent so you can track them every step of the way! It's worth waiting for cool things! 😉

💳 Shop with ease and choose your favorite payment method:

🌐 Choose a payment method: During checkout, you can connect your PayPal account, credit card, debit card, or bank account. We support multiple payment methods, ensuring you have flexible payment options.

🔐 Secure Login: If you choose PayPal, you can securely log into your PayPal account. If using a credit card, you can choose Credit Card Express for quick payment. Enter your payment information, making sure it is accurate.

🛍 Submit order: After completing product selection, click Submit order. Next, you will be directed to PayPal to complete the transaction. If you choose to pay by credit card, you will see the option to "Pay with credit or debit card."

🏠 Confirm Address: Confirm or enter your address information on PayPal to ensure your order will be shipped to your desired address. Click "Submit" to continue.

💸 Payment Processing: Your payment will be processed securely. After successful payment, the system will send a detailed payment invoice to your email to confirm your purchase.

If you'd like to check out by credit card, click on PayPal and select "Pay with debit or credit card" for express checkout.

✨ Simple, safe and convenient, start your happy shopping trip! 🛒🌐