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

|

Boost Your Site and Save 20% this Weekend

Join 50,000 users and build a better site with 20% off all Divi Booster plugins.

Discount applied at checkout. Offer ends Monday!

Day(s)

:

Hour(s)

:

Minute(s)

:

Second(s)

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>

This post may contain referral links which may earn a commission for this site

Divi Booster

Hundreds of new features for Divi
in one easy-to-use plugin

2 Comments

  1. 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

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