List of variants of product X, shown on productpage of product Z

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 %}

This tile is available in these sizes:

{% for variant in product.variants %} {% if variant.available %}

{{ variant.title | append: ‘
’}}

{% endif %}
{% endfor %}


{% endunless %}
{% endif %}

Thanks for your help in advance!

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 %}
      
        {% for linked_variant in available_variants %}
          {{ linked_variant.title }}

        {% endfor %}
      
    {% endif %}
  {% endunless %}
{% endif %}

https://shopify.dev/docs/api/liquid/objects/metafield

Thank you, Tim! This is indeed exactly what I was looking for!