How to Swap or Hide the Add to Cart Button on a Shopify site

August 29, 2024

Author: Joe

Shopify Expert, store owner for 7 years, former eCommerce marketer and consultant

This guide shows you how to modify the add to cart button on a Shopify site to do things like:

  • Show a different button, link, or text for certain products or situations

  • Hide the button for certain visitors or certain locations

Includes: example code snippet + how to integrate into a Shopify theme.

Contents

First step: Backup your theme

Always backup your live theme, then work off the new duplicated theme, so you can edit freely without worry of breaking the live site. After you're satisfied with the changes in the new theme, you can publish it.

Editing the code in your Shopify theme

Here's the code snippet we'll be working with (there will be copy/pastable code later):

Edit add to cart button in Shopify

That code controls the 2 buttons here:

add to cart dawn v1

To open this file go to your theme editor and click the Snippets folder, then select the buy-buttons.liquid file to see this code. Yours should look similar, I just added html comments to clarify the blocks.

This example is from the Dawn theme but Shopify themes usually follow a similar structure.

If your theme doesn't have that file, search other files in the Snippets folder that look like they're for the product form or add to cart button, and search in the code for text like "add_to_cart" or "add" to find the button code.

To make things easier moving forward, I'll refer to that whole code block in the screenshot to the Add to cart button code.

Example 1: Show a different button for a certain product

Let's say you have a product in your store that you prefer the customer to buy from a different marketplace.

I've seen this example for stores that have a mix of their own products + affiliate products.

You can do something like this:

{% if product.title == "Rave Gorilla Logo Tee" %} <style> /* Adding CSS for an optional style change to the new button */ #new-button { background-color: #ffc200; border: 1px #ffa400 solid; --border-opacity: none; color: #000; } </style> <a href="https://amazon.com/link-to-the-product" id="new-button" class="button button--full-width"> Buy on Amazon </a> {% else %} <!-- Put your regular add to cart button code here --> {% endif %}

Now for the product with title Rave Gorilla Logo Tee it shows a new button + custom link, like this:

add to cart dawn v2

The CSS style block is just to show a quick example of changing the color. You may not want to do that. If you do want to change it, you'd probably want to add the CSS class to your custom CSS file, instead of inside the liquid code here.

Example 2: Show a new button for visitors from a certain location

Let's say your store is based in the USA but you also have inventory in European Amazon Seller Central accounts and want to allow customers to purchase "locally" from there.

For this example we're going to check if the visitor is from the UK or Germany, and if yes then route them to our Amazon store in those countrys.

This is a fairly common setup, here's a guide on connecting multiple Amazon stores for shipping Shopify orders: How to Automate Shopify Order Fulfillment with Amazon MCF / FBA

For this example, you want to first add the CSS + HTML for the button and set to display: none, so it doesn't show until the location is detected.

Add this above or below your add to cart button code:

<style> /* Adding a CSS class for optional style change + setting display to none so it doesn't unless called for */ #new-button { background-color: #ffc200; border: 1px #ffa400 solid; --border-opacity: none; color: #000; display: none; margin: 10px 0; } </style> <a href="" id="new-button" class="button button--full-width"></a>

Then below your add to cart button code add this:

<script> fetch("https://ipinfo.io/json") .then(response => response.text()) .then(data => { const country = JSON.parse(data).country; const button = document.getElementById("new-button"); // Show the button if visitor is from UK or Germany if (country == "GB" || country == "DE") { button.style.display = "flex"; } // Change the link based on country if (country == "GB") { button.href = "https://www.amazon.co.uk/your-store"; button.innerText = "Shop our Amazon UK store"; } else if (country == "DE") { button.href = "https://www.amazon.de/your-store"; button.innerText = "Shop our Amazon store"; } }) </script>

For details on how that location snippet works or more ideas to integrate that in your store see How to Get Visitor Location on a Shopify Site.

Now when a visitor is from UK (GB) or Germany (DE), that custom button will show to them, with the new link you set.

Here's what that looks like for a visitor from the UK:

add to cart dawn v3

Example 3: Show a new button on certain product pages for visitors from a certain location

This one is like Example 2 but adds the extra option to show a specific link based on the product the visitor is looking at.

First add the CSS + HTML for the button and set to display: none, so it doesn't show until the location is detected.

Add this above or below your add to cart button code:

<style> /* Adding a CSS class for optional style change + setting display to none so it doesn't unless called for */ #new-button { background-color: #ffc200; border: 1px #ffa400 solid; --border-opacity: none; color: #000; display: none; margin: 10px 0; } </style> <a href="" id="new-button" class="button button--full-width"></a>

Then below your add to cart button code add this:

<script> fetch("https://ipinfo.io/json") .then(response => response.text()) .then(data => { const country = JSON.parse(data).country; const button = document.getElementById("new-button"); // Show the button if visitor is from UK or Germany if (country == "GB" || country == "DE") { button.style.display = "flex"; } // Change the link based on country + product title if (country == "GB") { {% if product.title == "Rave Gorilla Logo Tee" %} button.href = "https://www.amazon.co.uk/the-amazon-url-for-this-product"; button.innerText = "Buy this on our Amazon UK store"; {% else %} button.href = "https://www.amazon.co.uk/your-store"; button.innerText = "Shop our Amazon UK store"; {% endif %} } else if (country == "DE") { {% if product.title == "Rave Gorilla Logo Tee" %} button.href = "https://www.amazon.de/the-amazon-url-for-this-product"; button.innerText = "Buy this on our Amazon DE store"; {% else %} button.href = "https://www.amazon.de/your-store"; button.innerText = "Shop our Amazon DE store"; {% endif %} } }) </script>

Now we see the new button text, plus the link will take them directly to the product in that other store:

add to cart dawn v4

Example 4: Hide add to cart button for visitors from certain countries

You might have a reason to prevent visitors from certain countries buying certain products, I've seen this asked a few times.

Below your add to cart button code add this:

<script> fetch("https://ipinfo.io/json") .then(response => response.text()) .then(data => { const country = JSON.parse(data).country; const button = document.querySelector('[id*="ProductSubmitButton"]'); // Hide the add to cart button if visitor is from Thailand if (country == "TH") { button.style.display = "none"; } }) </script>

For this example, we hide the add to cart button if the visitor is from Thailand.

This idea popped in my head because I know people that have US based businesses and manufacture products in Thailand. In that case, you could use a combination of Example 4 to hide the add to cart button, and then add an element like in Example 3 where you could change some text, maybe just have some text say Contact us to buy locally in Thailand.

When hiding an item, you may see the item visibly show when page loads, then disappear as the code executes. One way to solve this is to set the add to cart button to display: none in the CSS, and then set the display to flex (or block, inline-block, etc) like we did in Example 3.

Example 5: Show different buttons or text based on inventory levels

Here's a couple scenarios: Show how many inventory units are left based on the country the user is browsing from. Or if you're out of stock in a certain country, offer the customer to either ship internationally or enter their email in a field to know when it's locally available.

You aren't able to get product inventory levels at different locations using just Liquid code in your theme. For this you'll either need to create a custom app to access the Shopify API, or rely on an existing app.

Our app Product Automator can do this. Send a message at productautomator.com/contact to explore that functionality.

Summary + notes

You can use these conditional showing / hiding / displaying information to give a more personalized experience for your visitors.

Try 1 of the examples above and think about where you can implement this type of feature anywhere in your theme or notifications to provide a better shopping experience for your customers.

You probably don't need a developer to integrate these, but if you have 1 on your team just share this guide with them.

If you're having trouble integrating the code examples, shoot us a message here.

Notes

  1. I used the example to purchase certain items from Amazon marketplaces worldwide because I've seen that done before, and also used to use this workflow myself. Works great! People get excited when the shipping arrives fast and there are no extra taxes.

Bonus tip: Sign up for the Amazon Affiliate program and use affiliate links when sending visitors to your Amazon site for a little extra revenue stream. Check Amazon Affiliate terms first to make sure you comply (you should add a disclaimer to the page, for example).

  1. I just showed 5 examples but there are plenty of other ways to use this tactic. You can also use the same code snippet to conditionally show / hide elements anywhere on your site.

  2. For a list of country codes see the IBAN country codes here.

Have fun!

🧙‍♂️ If this post was useful and you'd like to help us out, please check out our apps Order Automator and Product Automator. Our apps help Shopify stores and staff save time and money. 😃

About the Author: Joe

Joe's a 10+ years Shopify partner, certified Shopify Expert, 7 year Shopify store owner, former Shopify optimization agency owner, creator of Order Automator and co-creator of Product Automator. Outside of tech he's into nature adventures, travel, trees, music, books, and art. 🏕🌎🌞

Some of our guides and blog posts contain affiliate links, meaning Automator Apps could receive a commission if you sign up for an app or service using those links. We only recommend things we believe in, and there is no additional cost to you, we're just recommending trusted partners.

Recent Posts


About Us

We make Shopify apps, custom plugins, and automated solutions.

We also have experience creating and managing eCommerce brands.

Our goal is to help Shopify stores be more efficient and more successful with smart solutions.

Contact us if you need a technological solution for your business.


Automation Apps for Shopify Stores

Use Order Automator to automate routine Shopify tasks, connect your store to 3rd party marketplaces (Amazon, TikTok, etc), and save you time and money.

It's customizable too, so you can request specific functionality for your store.


Product Automator has a suite of features to help organize your products and collections, increase your conversion rate, and get operational notifications.

It's a newer app so we're adding new functionality every week. Try it now and contact us to make a request or custom tailor a feature to your store.


Automated Fulfillment Solutions for Shopify Stores

ShipBob is a 3rd party fulfillment service that connects easily with Shopify, ships worldwide, and has no minimum requirements.

Connect ShipBob to your Shopify store, send inventory, then your orders will get automatically fulfilled.

Available in the US, UK, Canada, Europe, and Australia


Use Amazon FBA to automatically fulfill your Shopify store orders domestically and internationally.

See How to Automate Shopify Order Fulfillment with Amazon MCF / FBA to learn how to set it up.

Using the Order Automator app connected to your Amazon Seller Central account, you can do things like:

  • Automatically sync inventory between Amazon and Shopify
  • Automatically fulfill Shopify orders using Amazon FBA inventory
  • Route Shopify orders to Amazon marketplaces around the world, handling international fulfillment

Fulfilling off-Amazon orders with your Amazon inventory is called MCF. Learn more about Amazon MCF here.


All Guides and Posts