Shopify themes, liquid, logos, and UX
Hey everyone,
I'm trying to display a list of available variants on my product page via Liquid Code. I've already found a code to do this for the current product. The catch is that I'm trying to do this for a product that I've linked via variant.metafields.
Let me explain:
I've linked product X to product Z via a variant.metafield.
On the productpage of product Z, I would like to show a list of available variants for product X.
This is the code that I've found to do this for the current product. Does anyone know what needs to be changed in order to do this for the linked-product?
{% if product.variants.size > 0 and product.available %} {% unless product.has_only_default_variant %}
<span class="sizes-available">
This tile is available in these sizes:
</br>
{% for variant in product.variants %} {% if variant.available %}
{{ variant.title | append: '</br>'}}
{% endif %}
{% endfor %}
</span>
{% endunless %}
{% endif %}
Thanks for your help in advance!
Solved! Go to the solution
This is an accepted solution.
Some details are missing in your post, so let's assume that for your products you've defined a "product reference"/single type metafield with namespace "custom" and key "linked".
Then the code may look like:
{% assign metafield = product.metafields.custom.linked %}
{% if metafield != blank %}
{% assign linked_product = metafield.value %}
{% unless linked_product.has_only_default_variant %}
{% assign available_variants = linked_product.variants | where: 'available' %}
{% if available_variants.size > 0 %}
<span class="sizes-available">
{% for linked_variant in available_variants %}
{{ linked_variant.title }}<br />
{% endfor %}
</span>
{% endif %}
{% endunless %}
{% endif %}
https://shopify.dev/docs/api/liquid/objects/metafield
This is an accepted solution.
Some details are missing in your post, so let's assume that for your products you've defined a "product reference"/single type metafield with namespace "custom" and key "linked".
Then the code may look like:
{% assign metafield = product.metafields.custom.linked %}
{% if metafield != blank %}
{% assign linked_product = metafield.value %}
{% unless linked_product.has_only_default_variant %}
{% assign available_variants = linked_product.variants | where: 'available' %}
{% if available_variants.size > 0 %}
<span class="sizes-available">
{% for linked_variant in available_variants %}
{{ linked_variant.title }}<br />
{% endfor %}
</span>
{% endif %}
{% endunless %}
{% endif %}
https://shopify.dev/docs/api/liquid/objects/metafield
Thank you, Tim! This is indeed exactly what I was looking for!
Discover how to increase customer engagement on your store with articles from Shopify A...
By Jacqui Apr 23, 2025Hey Community 👋 Did you know that March 15th is National Everything You Think Is W...
By JasonH Apr 1, 2025Discover how to increase the efficiency of commerce operations with Shopify Academy's l...
By Jacqui Mar 26, 2025