I’m using the ‘shop the look’ section to highlight to customers the core products which make up a product bundle so I don’t have to repeat multiple product content on one page when it already exists on the core product pages.
The ‘shop the look’ section has up to 6 available products which can be linked. I’m populating this dynamically using metafields… but for some of my products there’s only 4 core products I want to link to and so 2 of the cards / section blocks are showing up with placeholder images.
What I would ideally like to happen is when there is nothing populated in the product metafield I’ve created the unused product cards / section blocks are hidden (not just the placeholder images… the entire block/card).
Can anyone help me by sharing a code change that would allow for this to happen? This is what the module currently looks like:
{%- style -%}
#shopify-section-{{ section.id }} {
--section-padding-top: {{ section.settings.padding_top }}px;
--section-padding-bottom: {{ section.settings.padding_bottom }}px;
{%- if section.settings.image != blank %}
--image-ratio-percent: {{ 1 | divided_by: section.settings.image.aspect_ratio | times: 100 }}%;
{% endif -%}
}
{%- endstyle -%}
{{ 'section-image-with-text.css' | asset_url | stylesheet_tag }}
{{ 'section-lookbook.css' | asset_url | stylesheet_tag }}
{{ 'section-shop-the-look.css' | asset_url | stylesheet_tag }}
{%- if settings.quick_view_enabled and section.settings.enable_quick_view -%}
{%- endif -%}
<{{ section.settings.heading_tag }} class="title {{ section.settings.heading_size }}">{{ section.settings.heading | escape }}
{% schema %}
{
"name": "t:sections.shop-the-look.name",
"tag": "section",
"class": "section",
"max_blocks": 6,
"settings": [
{
"type": "image_picker",
"id": "image",
"label": "t:sections.all.image.label"
},
{
"type": "select",
"id": "layout",
"options": [
{
"value": "image_first",
"label": "t:sections.shop-the-look.settings.layout.options__1.label"
},
{
"value": "text_first",
"label": "t:sections.shop-the-look.settings.layout.options__2.label"
}
],
"default": "image_first",
"label": "t:sections.shop-the-look.settings.layout.label",
"info": "t:sections.shop-the-look.settings.layout.info"
},
{
"type": "select",
"id": "text_box_position",
"options": [
{
"value": "top",
"label": "t:sections.shop-the-look.settings.text_box_position.options__1.label"
},
{
"value": "middle",
"label": "t:sections.shop-the-look.settings.text_box_position.options__2.label"
},
{
"value": "bottom",
"label": "t:sections.shop-the-look.settings.text_box_position.options__3.label"
}
],
"default": "top",
"label": "t:sections.shop-the-look.settings.text_box_position.label"
},
{
"type": "select",
"id": "text_alignment",
"options": [
{
"value": "left",
"label": "t:sections.all.text_alignment.options__1.label"
},
{
"value": "center",
"label": "t:sections.all.text_alignment.options__2.label"
},
{
"value": "right",
"label": "t:sections.all.text_alignment.options__3.label"
}
],
"default": "left",
"label": "t:sections.all.text_alignment.label"
},
{
"type": "select",
"id": "mobile_text_alignment",
"options": [
{
"value": "left",
"label": "t:sections.all.mobile_layout.mobile_text_alignment.options__1.label"
},
{
"value": "center",
"label": "t:sections.all.mobile_layout.mobile_text_alignment.options__2.label"
},
{
"value": "right",
"label": "t:sections.all.mobile_layout.mobile_text_alignment.options__3.label"
}
],
"default": "left",
"label": "t:sections.all.mobile_layout.mobile_text_alignment.label"
},
{
"type": "checkbox",
"id": "full_width",
"default": false,
"label": "t:sections.all.full_width.label"
},
{
"type": "checkbox",
"id": "show_divider",
"default": false,
"label": "t:sections.all.show_divider.label"
},
{
"type": "header",
"content": "t:sections.all.heading.label"
},
{
"type": "text",
"id": "heading",
"default": "Shop the Look",
"label": "t:sections.all.heading.label"
},
{
"type": "select",
"id": "heading_size",
"options": [
{
"value": "h2",
"label": "t:sections.all.heading_size.options__1.label"
},
{
"value": "h1",
"label": "t:sections.all.heading_size.options__2.label"
},
{
"value": "h0",
"label": "t:sections.all.heading_size.options__3.label"
}
],
"default": "h1",
"label": "t:sections.all.heading_size.label"
},
{
"type": "select",
"id": "heading_alignment",
"label": "t:sections.all.heading_alignment.label",
"options": [
{
"value": "left",
"label": "t:sections.all.heading_alignment.options__1.label"
},
{
"value": "center",
"label": "t:sections.all.heading_alignment.options__2.label"
},
{
"value": "right",
"label": "t:sections.all.heading_alignment.options__3.label"
}
],
"default": "center"
},
{
"type": "select",
"id": "heading_tag",
"options": [
{
"value": "h1",
"label": "t:sections.all.heading_tag.options__1.label"
},
{
"value": "h2",
"label": "t:sections.all.heading_tag.options__2.label"
},
{
"value": "h3",
"label": "t:sections.all.heading_tag.options__3.label"
},
{
"value": "h4",
"label": "t:sections.all.heading_tag.options__4.label"
},
{
"value": "h5",
"label": "t:sections.all.heading_tag.options__5.label"
},
{
"value": "h6",
"label": "t:sections.all.heading_tag.options__6.label"
},
{
"value": "div",
"label": "t:sections.all.heading_tag.options__7.label"
},
{
"value": "span",
"label": "t:sections.all.heading_tag.options__8.label"
},
{
"value": "p",
"label": "t:sections.all.heading_tag.options__9.label"
}
],
"default": "h2",
"label": "t:sections.all.heading_tag.label",
"info": "t:sections.all.heading_tag.info"
},
{
"type": "header",
"content": "t:sections.all.product_card.header.content"
},
{
"type": "select",
"id": "image_ratio",
"options": [
{
"value": "adapt",
"label": "t:sections.all.card_image_ratio.options__1.label"
},
{
"value": "square",
"label": "t:sections.all.card_image_ratio.options__2.label"
},
{
"value": "portrait",
"label": "t:sections.all.card_image_ratio.options__3.label"
},
{
"value": "landscape",
"label": "t:sections.all.card_image_ratio.options__4.label"
},
{
"value": "wide",
"label": "t:sections.all.card_image_ratio.options__5.label"
}
],
"default": "adapt",
"label": "t:sections.all.card_image_ratio.label"
},
{
"type": "select",
"id": "image_position",
"options": [
{
"value": "20% 0",
"label": "t:sections.all.image_position.options__1.label"
},
{
"value": "top center",
"label": "t:sections.all.image_position.options__2.label"
},
{
"value": "80% 0",
"label": "t:sections.all.image_position.options__3.label"
},
{
"value": "20% 50%",
"label": "t:sections.all.image_position.options__4.label"
},
{
"value": "center center",
"label": "t:sections.all.image_position.options__5.label"
},
{
"value": "80% 50%",
"label": "t:sections.all.image_position.options__6.label"
},
{
"value": "20% 100%",
"label": "t:sections.all.image_position.options__7.label"
},
{
"value": "bottom center",
"label": "t:sections.all.image_position.options__8.label"
},
{
"value": "80% 100%",
"label": "t:sections.all.image_position.options__9.label"
}
],
"default": "center center",
"label": "t:sections.all.image_position.label",
"info": "t:sections.all.image_position.info"
},
{
"type": "checkbox",
"id": "enable_image_fill",
"default": true,
"label": "t:sections.all.product_card.enable_image_fill.label",
"info": "t:sections.all.product_card.enable_image_fill.info"
},
{
"type": "checkbox",
"id": "show_secondary_image",
"default": false,
"label": "t:sections.all.product_card.show_secondary_image.label"
},
{
"type": "checkbox",
"id": "show_vendor",
"default": false,
"label": "t:sections.all.product_card.show_vendor.label"
},
{
"type": "checkbox",
"id": "show_rating",
"default": false,
"label": "t:sections.all.product_card.show_rating.label",
"info": "t:sections.all.product_card.show_rating.info"
},
{
"type": "checkbox",
"id": "show_quick_buy",
"default": true,
"label": "t:sections.all.product_card.show_quick_buy.label"
},
{
"type": "checkbox",
"id": "enable_quick_view",
"default": true,
"label": "t:sections.all.product_card.enable_quick_view.label"
},
{
"type": "checkbox",
"id": "enable_color_swatches",
"default": true,
"label": "t:sections.all.product_card.enable_color_swatches.label"
},
{
"type": "checkbox",
"id": "enable_countdown",
"default": true,
"label": "t:sections.all.product_card.enable_countdown.label"
},
{
"type": "header",
"content": "t:sections.all.padding.header.content"
},
{
"type": "range",
"id": "padding_top",
"min": 0,
"max": 100,
"step": 4,
"unit": "t:sections.all.padding.padding_top.unit",
"label": "t:sections.all.padding.padding_top.label",
"default": 36
},
{
"type": "range",
"id": "padding_bottom",
"min": 0,
"max": 100,
"step": 4,
"unit": "t:sections.all.padding.padding_bottom.unit",
"label": "t:sections.all.padding.padding_bottom.label",
"default": 36
}
],
"blocks": [
{
"type": "product",
"name": "t:sections.shop-the-look.blocks.product.name",
"settings": [
{
"type": "product",
"id": "product",
"label": "t:sections.shop-the-look.blocks.product.settings.product.label"
},
{
"type": "header",
"content": "t:sections.shop-the-look.blocks.product.settings.header.content"
},
{
"type": "color",
"id": "color",
"label": "t:sections.shop-the-look.blocks.product.settings.color.label",
"default": "#000000"
},
{
"type": "range",
"id": "horizontal",
"default": 30,
"min": 5,
"max": 95,
"label": "t:sections.shop-the-look.blocks.product.settings.horizontal.label",
"unit": "t:sections.shop-the-look.blocks.product.settings.horizontal.unit"
},
{
"type": "range",
"id": "vertical",
"default": 40,
"min": 5,
"max": 95,
"label": "t:sections.shop-the-look.blocks.product.settings.vertical.label",
"unit": "t:sections.shop-the-look.blocks.product.settings.vertical.unit"
}
]
}
],
"presets": [
{
"name": "t:sections.shop-the-look.presets.name",
"blocks": [
{
"type": "product",
"settings": {
"horizontal": 30,
"vertical": 40
}
},
{
"type": "product",
"settings": {
"horizontal": 70,
"vertical": 45
}
},
{
"type": "product",
"settings": {
"horizontal": 45,
"vertical": 65
}
}
]
}
],
"templates": ["404", "article", "blog", "cart", "collection", "list-collections", "index", "page", "product", "search"]
}
{% endschema %}