Re: Variant Metafield Dynamically Changing

How to dynamically change variant metafield on product page?

chels_grove
Shopify Partner
74 0 20

On the product page, I would like to show the Variant Metafield, I was able to do figure out how to get it in there using this:

{% for variant in product.variants %}
{% if product.selected_or_first_available_variant.id == variant.id %}
<strong>Only {{ variant.metafields.my_fields.quantity_by_color }} PCS are available in {{variant.title}}!</strong>
{% endif %}
{% endfor %}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script type="text/javascript">
jQuery(document).ready(function($){
$(".no-js-hidden").on("click", function(){
var refreshint = setInterval(function(){
location.reload();
}, 1000);    });   });
</script>

In this example, the person used it to update specific quantities of each variant (in case that is important). I changed it to my metafield and put this in a Custom Liquid block:

 

{% for variant in product.variants %}
{% if product.selected_or_first_available_variant.id == variant.id %}
<strong>{{variant.title}}:</strong> <strong style="color:#CC2229;">{{ variant.metafields.my_fields.shipping_status }} </strong>
{% endif %}
{% endfor %}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script type="text/javascript">
jQuery(document).ready(function($){
$(".no-js-hidden").on("click", function(){
var refreshint = setInterval(function(){
location.reload();
}, 1000); }); });
</script> 

 

It works great but the only way to show it when you click on a different variant is to refresh the page which isn't intuitive - I would like it to change depending on what variant you click.

 

Thanks!

 

store is: https://detroit-bikes.myshopify.com/

Replies 7 (7)

guilhermealbino
Shopify Partner
22 1 6

Did you manage to resolve this?
I'm having a similar situation, but I don't mind if it is refreshing the page when variant is switched. My problem is that when I change the product quantity, it refreshes the page and sets the quantity's value to 1 again.

 

If you solved it, could you share your solution? Thanks.

Metirof
Visitor
2 0 0

Exact same issue can someone help please 🙂

guilhermealbino
Shopify Partner
22 1 6

In the global.js file you will find the functions that deal with updating parts of the page with eventListener.
In the example I'll show, let's pay attention to updating the SKU information, which I put to be shown just below the price on the product page.

Example:

 

  renderProductInfo() {
    fetch(
      `${this.dataset.url}?variant=${this.currentVariant.id}&section_id=${
        this.dataset.originalSection
          ? this.dataset.originalSection
          : this.dataset.section
      }`
    )
      .then((response) => response.text())
      .then((responseText) => {
        const html = new DOMParser().parseFromString(responseText, "text/html");
        const destination = document.getElementById(
          `price-${this.dataset.section}`
        );
        const source = html.getElementById(
          `price-${
            this.dataset.originalSection
              ? this.dataset.originalSection
              : this.dataset.section
          }`
        );
        if (source && destination) destination.innerHTML = source.innerHTML;

        const price = document.getElementById(`price-${this.dataset.section}`);

        if (price) price.classList.remove("visibility-hidden");

        const sku = document.getElementById(`sku-${this.dataset.section}`);
        if (sku)
          sku.classList.remove("visibility-hidden"), this.updateSku(html);

        this.toggleAddButton(
          !this.currentVariant.available,
          window.variantStrings.soldOut
        );
      });
  }

 

The function above, calls updateSku() to update its sku dynamically:

 

  updateSku(html) {
    const id = `sku-${this.dataset.section}`;
    const destination = document.getElementById(id);
    const source = html.getElementById(id);

    if (source && destination) destination.innerHTML = source.innerHTML;
  }

 

Following that logic you'll can do that kind of update without refreshing the entire page.

DesignerJoe55
Explorer
45 0 22

Same problem here. Would love a solution to this. What is the point of having variant metafields if they don't update when the variant is chosen?

FredericVervill
Tourist
7 0 1

Did someone found a solution for this?

Frederic Verville - Floèm

mpaule1004
Visitor
3 0 0

Anyone has update on this? I'm using Expanse theme and have the same problem

I manage to show the variant, but the problem the page need to refresh

{% for variant in product.variants %}
<div class="variant__description" data-variant-id="{{variant.id}}" {% if product.selected_or_first_available_variant.id == variant.id %} style="display: block;" {% endif %}>
{% if variant.metafields.custom.variant_size %}
<p><span class="font-body-bold">Dimension:</span>{{ variant.metafields.custom.variant_size }}</p>
{% endif %}
{% if variant.metafields.custom.variant_cubage %}
<p><span class="font-body-bold">Cubage:</span>{{ variant.metafields.custom.variant_cubage }}</p>
{% endif %}
</div>
{%- endfor -%}

adupont
Visitor
2 0 1

I found a great tutorial for how to do this by first placing a record of the variants in the product page (invisibly):

 

https://ecommercepot.com/shopify-qa/variant-metafield/