Edible Flower Seed Bank 2026 – 32 Non-GMO Varieties

$69.99 $94.99 Save $25.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 = "9293baf5-c9b4-44e7-ac5d-b51297c4f91a"; // 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 == '854d2e2e-a0aa-4163-97d7-f60c2687b26a' && 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: "854d2e2e-a0aa-4163-97d7-f60c2687b26a", 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
Share the love
Free worldwide shipping
Free returns
Sustainably made
Secure payments
Description

🌸 Garden-to-Table Edible Blooms for Drinks, Desserts, Botanical Sugar, Candied Flowers & More

Transform your garden into a vibrant edible landscape with the newly upgraded Premium Edible Flower Seed Bank. Designed for garden-to-table living and creative home culinary projects, this collection is perfect for home bakers, tea and cocktail lovers, food crafters, herbal drink makers, and gardening enthusiasts who want to grow beautiful blooms they can actually enjoy in the kitchen.

From iced floral drinks and herbal teas to violet sugar, candied flowers, salad garnishes, syrups, honey infusions, jellies and jams, every seed variety in this collection brings beauty, flavor, aroma, and nourishment to your table.

Design to Pair with the Edible Flower Almanac 2026 by USDA Zones

To deepen your garden-to-table journey, you can pair with the Edible Flower Almanac 2026, which offers:

  • USDA Zone-based sowing and harvesting guidance
  • Flavor profiles and culinary safety notes
  • Seasonal recipes for teas, cocktails, syrups, jellies, candied flowers and botanical sugars
  • Preservation guidance including drying, freezing, candying and pressing
    Together, they create a complete edible flower growing and culinary crafting system.

Why You’ll Love It

🌱 Culinary-Safe, Organic & Non-GMO

Unlike florist flower seeds that may contain weed seeds, pesticides, and preservatives, these blooms are safe for culinary use, non-GMO, and tested for high germination rate over 90%. Enjoy nature’s flavor and color with peace of mind.

🌼 Garden-to-Table Edible Blooms

     Grow your own edible flowers for:

✔️iced botanical drinks & cocktail garnish
✔️herbal teas & wellness infusions
✔️candied flowers & pressed cake decor
✔️salad seasoning & colorful plate garnish
✔️floral syrups, vinegars, jellies & jams
✔️violet sugar, rose sugar, herb sugars & salts

     A perfect seed kit for kitchen creatives and healthy, self-sufficient homesteads.

🐝 Supports Pollinators & Biodiversity

Many of the included blooms also support bees, butterflies, and beneficial pollinators, helping you cultivate a thriving, ecologically balanced garden.

✨ Exquisite Box Design – Transparent Lid + Illustrated Acrylic Containers

Just like our beloved Cut Flower Seed Bank, this edition features a transparent lid, now enhanced with edible-flower botanical illustrations. Inside, 32 reusable acrylic seed containers are printed with the seed name and edible flower illustration for instant recognition. No guessing, no mixing, no label peeling. 

🎁 Gift-Ready Heirloom Seed Bank

A meaningful garden-to-table gift for nature lovers, kitchen creatives, homesteaders, tea and cocktail lovers, wellness seekers, and anyone who finds joy in edible beauty. It's also a stunning, reusable, eco-conscious wooden organizer perfect for: Mother’s Day, birthdays, weddings, gardeners, bakers, tea lovers, botanical drink makers.

What’s Included

  • 1 Premium Wooden Storage Box
  • 32 Reusable Labeled Acrylic Containers
  • 32 Organic Edible Flower Seed Varieties, categorized by botanical flavor profile:

🌸Floral and Mild:
Rose Mallow, Viola Philippica, Sweet Violet, Pot Marigold, Cornflower Blue, Snow Chrysanthemum, Signet Marigold, Cow Cockle, English Lavender, Garland Daisy, Echinacea Purpurea, Clover Blossoms

🌿Herbal and Savory:
Borage, Sage Flowers, Thyme Blossoms, Oregano Flowers, Chive Blossoms, Fennel Flowers, Cilantro Flowers, Dill Blossoms

🌶 Spicy and Peppery:
Nasturtium, Mustard Flowers, Radish Flowers, Arugula Blossoms, Sunflower,Kale Blossoms

🍋Citrus and Bright:
Lemon Balm, African Marigold, French Marigold, Tickseed. Roselle Hibiscus, Yarrow