Giant Bayberry: Ping-Pong Ball Size, ⭐Strawberry-Cherry Fusion Flavor

$19.99 $26.99 Save $7.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 = "31eb1ef2-2ae8-4205-ac4e-a24db66f1537"; // 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 == 'ac631035-c94c-49bc-bdd6-ca5e73259caf' && 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: "ac631035-c94c-49bc-bdd6-ca5e73259caf", 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:  🔥100 Seeds🔥
Variety:  Red
Quantity
Share the love
Free worldwide shipping
Free returns
Sustainably made
Secure payments
Description

Description

Himalayan Bayberry (Kaphal) Quick Facts

Name:Himalayan Bayberry (Kaphal)
OriginHimalayas of Nepal, in southern China east to Guangdong province, in Burma, Indo-China, Thailand and hilly regions of northern India
ColorsInitially green and turn reddish-purple or black when ripe
ShapesSmall, round to ovoid succulent berry, usually around 1-1.5 cm in diameter
Major nutrients• Vitamins
• Minerals
• Dietary Fibers
• Antioxidants
• Natural Acids
• Phytonutrients
• Carbohydrates
• Calories
Health benefitsDigestive Health, Blood Sugar, Cholesterol Management, Immune System, Skin Health, Liver Health, Heart Health, Gastrointestinal Health, Weight Management, Respiratory Health, Dental Health, Wound Healing, Eye Health

🌿Plant Your Own Bayberry Tree and Harvest Nature's Sweet Bounty! 🌿

Why Choose Bayberry Trees? Experience the joy of a thriving garden with our Bayberry tree seeds. In no time, you'll be surrounded by bountiful fruits resembling table tennis balls – sweet, crisp, tender, and bursting with juicy goodness.

Nutrient-Rich Goodness: The red flesh of Bayberries is not just delicious; it's a nutritional powerhouse. Packed with essential nutrients, every bite is a treat for your taste buds and your well-being.

Simple Planting, Abundant Rewards: Planting a bayberry tree has never been easier! Just bury the seeds in the soil, give them a thorough watering, and watch your own bayberry grove flourish. The simplicity of the process ensures a rewarding harvest.

Enjoy Freshness Every Year: Once planted, your bayberry tree will provide you with a yearly supply of fresh, delectable bayberries. Say goodbye to store-bought fruits and hello to homegrown goodness!

Nutritious and Healthy Delight: Not only are bayberries a delicious addition to your diet, but they also contribute to your overall health. Indulge guilt-free in these nutritious and healthy treats straight from your garden.

🌱 Plant Your Bayberry Tree Today and Reap the Rewards Tomorrow! 🌱

Now is the perfect season for planting seedlings. Don't miss the opportunity to embark on your journey to homegrown, fresh bayberries. Click the link above to get your Bayberry tree seeds and start your gardening adventure now!

🌿Bayberry Seeds Planting Guide

Germination Time: Bayberry seeds typically take 4 to 6 weeks to germinate. Patience is key during this period, and maintaining consistent moisture is crucial for successful sprouting.

Planting Method:

  1. Prepare the Seeds: Before planting, soak the bayberry seeds in water for 24 hours to enhance germination.

  2. Sowing Depth: Plant the seeds approximately 1/4 inch deep in well-draining soil. Ensure the seeds are covered with a thin layer of soil.

  3. Container Planting (Optional): If starting indoors, use seed trays or pots with good drainage. Transplant seedlings outdoors when they have reached a suitable size.

  4. Sunlight Exposure: Bayberries thrive in full sunlight. Ensure your planting location receives ample sunlight for at least 6-8 hours a day.

  5. Watering Routine: Keep the soil consistently moist but not waterlogged. Regular, moderate watering is essential for successful germination and early growth.

Soil Conditions:

  1. Well-Draining Soil: Bayberries prefer well-draining soil to prevent waterlogged conditions, which can be detrimental to the plant's health.

  2. Soil pH: Aim for slightly acidic to neutral soil with a pH range between 5.5 and 7.0.

  3. Organic Matter: Enrich the soil with organic matter, such as compost, to provide essential nutrients for seedling development.

  4. Aeration: Ensure proper aeration of the soil to promote root health and prevent diseases.

Remember, successful bayberry cultivation requires a balance of proper germination conditions, suitable planting methods, and well-maintained soil. Follow these guidelines, and you'll soon enjoy the rewards of a flourishing bayberry tree in your garden!

🌍 Supporting Nature, One Order at a Time! 🌿

🤝We donate $1 to the World Conservation Organization (WCO) with every purchase. ✨

This limited-time offer is your ticket to a guilt-free shopping spree. Don't miss out! Treat yourself and your loved ones while enjoying incredible discounts. Your perfect shopping experience is just a click away. 🎊

At LivelySeed, we believe in the extraordinary power of small actions. With our "Seeds of Hope" campaign, your shopping experience takes on a whole new meaning.

Embark on a shopping experience with purpose! For each purchase, $1 will be donated to UNICEF — an initiative that plants seeds of hope in the lives of children worldwide. Join us in cultivating positive change while enjoying quality products.

Your purchase not only brings you exceptional products but also contributes to essential programs that support children's health, education, and well-being. Together, we are sowing the seeds of a better future.

Make your shopping matter. Choose quality, choose compassion.

Thank you for being a part of our Seeds of Hope Campaign!