Add an "Add to Cart" Button to the Woo Products Module

Written by Dan Mossop

Divi includes a WooCommerce Products module (formally called the Shop module), which can display a grid of products from your WooCommerce store. Here's how to add an "Add to Cart" button to the products in the products module, and some tips for configuring these buttons.

Enabling "Add to Cart" Buttons in the WooCommerce Products Module

While there isn't currently a built-in option to enable "Add to Cart" buttons in the WooCommerce Products module, there are various tutorials on the web (such as this one) all offering variations of the following PHP code snippet:

add_action('woocommerce_after_shop_loop_item_title', 'woocommerce_template_loop_add_to_cart', 10);
Simply add this PHP code to your site and an ajax enabled "Add to Cart" button will be added below each product.

Disable the "Add to Cart" buttons after they are clicked

If the product can only be added once, you may want to disable the button once it has been used. You can do so by adding the following jQuery to your site:

<script>
jQuery(function() { 
	jQuery(document).on(
		'click', 
		'.et_pb_shop .ajax_add_to_cart', 
		function() {
			jQuery(this).css('pointer-events', 'none');
		}
	);
});
</script>

Change the "Add to Cart" button text when clicked

To change the text displayed on the add to cart button, e.g. to "Added to Cart", add the following jQuery to your site:

<script>
jQuery(function() { 
	jQuery(document).on(
		'click', 
		'.et_pb_shop .ajax_add_to_cart', 
		function() {
			jQuery(this).text('Added to Cart');
		}
	);
});
</script>

Hide the "Add to Cart" button on out-of-stock products

Normally, when a product is out of stock, the "Add to Cart" button will change to a "Read More" button that just links to the product page. If you'd like to hide the button entirely when a product is out of stock, you can add the following CSS to your site:

<style>
.et_pb_shop .outofstock .button {
	display:none !important; 
}
</style>

We may earn a commission when you visit links on our website.

Run PHP Code Directly in your Divi Layouts

Unlock endless customization, automation, and dynamic functionality by seamlessly adding PHP code to your Divi pages and posts with the Divi PHP Code Module. Style, preview, and debug your PHP creations directly in the visual builder with robust error handling and enhanced security.

Latest Posts

Customize Lightbox Title Styling in the Divi Gallery Module

Adjust the appearance of the lightbox title that appears when visitors open images from a Divi Gallery to align with your brand and improve readability. Refining the title’s color, size, and weight enhances visual hierarchy, accessibility, and overall polish. In this...

Center the Lightbox Image Count in the Divi Gallery Module

Centering the image count in a gallery lightbox creates a cleaner, more balanced presentation and makes it easier for visitors to see where they are in the image set. This simple visual tweak can enhance readability, especially with larger images and longer captions,...

Style the Divi Gallery Module Lightbox Image Count

Tailor the appearance of the image counter in the Divi Gallery module lightbox to match your brand and improve readability. By customizing the counter’s color and typography, you ensure it displays clearly and suits your design. In this guide we show you how to style...

Customize the Lightbox Image Background Color in the Divi Gallery

Control the color that appears behind your images when users open in the gallery lightbox, including support for semi-transparent hues. This helps improve contrast for transparent images, align the experience with your brand palette, and create a more polished viewing...

About Dan Mossop

Dan is a Scottish-born web developer, now living in Brisbane with his wife and son. He has been sharing tips and helping users with Divi since 2014. He created Divi Booster, the first Divi plugin, and continues to develop it along with 20+ other Divi plugins. Dan has a PhD in Computer Science, a background in web security and likes a lot of stuff, 

4 Comments

  1. Hi! I added the "add to cart" button in the products module, but when "add to cart" is clicked, 2 woo notices are displayed. This is only when the "add to cart" button for the woo products module is clicked. Am I missing something? Thank you!

    Reply
    • Hey Raissa, I'm not seeing a double notice on my test site, I'm afraid. Is there any chance you're able to share a link to a page showing the issue so that I can take a look at it for you? Thanks!

      Reply
  2. Hi,

    I add to stop it, while it was showing "unavalaible" for products with wariables…

    Reply
    • Hey Antonin, thanks for the comment. I'm not sure your comment fully came through, sorry… I can't see what you added?

      But if you want to hide the "Add to Cart" button on any "Variable – unavailable" products, then I guess you'd be using some CSS similar to this, right?

      .et_pb_shop .product-type-variable.outofstock .button {
      	display:none !important; 
      }
      

      (Note that when the product is out of stock the button will normally say "Read More" rather than "Add to Cart").

      Anyway, thanks again for the comment and sorry if I haven't understood it correctly. Hopefully you've got things working the way you want, but if you do need any help with it, perhaps you can explain in a bit more detail what you need?

      Reply

Submit a Comment

Comments are manually moderated and approved at the time they are answered. A preview is shown while pending but may disappear if your are cookies cleared - don't worry though, the comment is still in the queue.

Your email address will not be published. Required fields are marked *.