Skip to content

Instantly share code, notes, and snippets.

@ashokmhrj
Last active January 17, 2024 16:04
Show Gist options
  • Save ashokmhrj/fda5a23f7bdfc55749bd2bd53c64a8ca to your computer and use it in GitHub Desktop.
Save ashokmhrj/fda5a23f7bdfc55749bd2bd53c64a8ca to your computer and use it in GitHub Desktop.
WooCommerce mnicart qty update
<?php
add_action('woocommerce_widget_shopping_cart_before_buttons','ask_woo_mini_cart_before_buttons' );
function ask_woo_mini_cart_before_buttons(){
wp_nonce_field( 'woocommerce-cart' );
?>
<div class="submit-button">
<input type="submit" class="button" name="update_cart" value="<?php esc_attr_e('Uppdatera varukorg', 'tidymerch'); ?>"/>
</div>
<?php
}
<?php
/**
* Mini-cart
*
* Contains the markup for the mini-cart, used by the cart widget.
*
* This template can be overridden by copying it to yourtheme/woocommerce/cart/mini-cart.php.
*
* HOWEVER, on occasion WooCommerce will need to update template files and you
* (the theme developer) will need to copy the new files to your theme to
* maintain compatibility. We try to do this as little as possible, but it does
* happen. When this occurs the version of the template file will be bumped and
* the readme will list any important changes.
*
* @see https://docs.woocommerce.com/document/template-structure/
* @author WooThemes
* @package WooCommerce/Templates
* @version 3.3.0
*/
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
do_action( 'woocommerce_before_mini_cart' ); ?>
<div class="shop_table cart">
<?php if ( ! WC()->cart->is_empty() ) : ?>
<form action="<?php echo esc_url(wc_get_cart_url()); ?>" method="post">
<ul class="woocommerce-mini-cart cart_list product_list_widget <?php echo esc_attr( $args['list_class'] ); ?>">
<?php
do_action( 'woocommerce_before_mini_cart_contents' );
foreach ( WC()->cart->get_cart() as $cart_item_key => $cart_item ) {
$_product = apply_filters( 'woocommerce_cart_item_product', $cart_item['data'], $cart_item, $cart_item_key );
$product_id = apply_filters( 'woocommerce_cart_item_product_id', $cart_item['product_id'], $cart_item, $cart_item_key );
if ( $_product && $_product->exists() && $cart_item['quantity'] > 0 && apply_filters( 'woocommerce_widget_cart_item_visible', true, $cart_item, $cart_item_key ) ) {
$product_name = apply_filters( 'woocommerce_cart_item_name', $_product->get_name(), $cart_item, $cart_item_key );
$thumbnail = apply_filters( 'woocommerce_cart_item_thumbnail', $_product->get_image(), $cart_item, $cart_item_key );
$product_price = apply_filters( 'woocommerce_cart_item_price', WC()->cart->get_product_price( $_product ), $cart_item, $cart_item_key );
$product_permalink = apply_filters( 'woocommerce_cart_item_permalink', $_product->is_visible() ? $_product->get_permalink( $cart_item ) : '', $cart_item, $cart_item_key );
?>
<li class="woocommerce-mini-cart-item <?php echo esc_attr( apply_filters( 'woocommerce_mini_cart_item_class', 'mini_cart_item', $cart_item, $cart_item_key ) ); ?>">
<?php
echo apply_filters( 'woocommerce_cart_item_remove_link', sprintf(
'<a href="%s" class="remove remove_from_cart_button" aria-label="%s" data-product_id="%s" data-cart_item_key="%s" data-product_sku="%s">&times;</a>',
esc_url( wc_get_cart_remove_url( $cart_item_key ) ),
__( 'Remove this item', 'woocommerce' ),
esc_attr( $product_id ),
esc_attr( $cart_item_key ),
esc_attr( $_product->get_sku() )
), $cart_item_key );
?>
<?php if ( ! $_product->is_visible() ) : ?>
<?php echo str_replace( array( 'http:', 'https:' ), '', $thumbnail ) . $product_name . '&nbsp;'; ?>
<?php else : ?>
<a href="<?php echo esc_url( $product_permalink ); ?>">
<?php echo str_replace( array( 'http:', 'https:' ), '', $thumbnail ) . $product_name . '&nbsp;'; ?>
</a>
<?php endif; ?>
<?php echo wc_get_formatted_cart_item_data( $cart_item ); ?>
<?php
if ($_product->is_sold_individually()) {
$product_quantity = sprintf('<input type="hidden" name="cart[%s][qty]" value="1" />', $cart_item_key);
} else {
$input_args = array(
'input_name' => "cart[{$cart_item_key}][qty]",
'input_value' => $cart_item['quantity'],
'max_value' => $_product->backorders_allowed() ? '' : $_product->get_stock_quantity(),
'min_value' => '0'
);
$product_quantity = woocommerce_quantity_input($input_args, $_product, false);
}
echo apply_filters('woocommerce_cart_item_quantity', $product_quantity, $cart_item_key, $cart_item);
?>
<div class="tidy-minicart-price"><?php echo $product_price;?></div>
</li>
<?php
}
}
do_action( 'woocommerce_mini_cart_contents' );
?>
</ul>
<p class="woocommerce-mini-cart__total total"><strong><?php _e( 'Subtotal', 'woocommerce' ); ?>:</strong> <?php echo WC()->cart->get_cart_subtotal(); ?></p>
<?php do_action( 'woocommerce_widget_shopping_cart_before_buttons' ); ?>
</form>
<p class="woocommerce-mini-cart__buttons buttons"><?php do_action( 'woocommerce_widget_shopping_cart_buttons' ); ?></p>
<?php else : ?>
<p class="woocommerce-mini-cart__empty-message"><?php _e( 'No products in the cart.', 'woocommerce' ); ?></p>
<?php endif; ?>
</div>
<?php do_action( 'woocommerce_after_mini_cart' ); ?>
jQuery(document).on('submit', '.shop_table.cart form', function() {
updateMiniCartQuantity();
return false;
});
function updateMiniCartQuantity() {
var cartForm = jQuery('.shop_table.cart form');
jQuery('<input />').attr('type', 'hidden')
.attr('name', 'update_cart')
.attr('value', 'Update Cart')
.appendTo(cartForm);
var formData = cartForm.serialize();
jQuery.ajax({
type: cartForm.attr('method'),
url: cartForm.attr('action'),
data: formData,
dataType: 'html',
success: function(response) {
console.log(response);
let wc_cart_fragment_url = (wc_cart_fragments_params.wc_ajax_url).replace("%%endpoint%%", "get_refreshed_fragments");
jQuery.ajax({
type: 'post',
url: wc_cart_fragment_url,
success: function(response) {
console.log(response);
var mini_cart_wrapper = jQuery('.widget_shopping_cart_content');
var parent = mini_cart_wrapper.parent();
mini_cart_wrapper.remove();
parent.append(response.fragments['div.widget_shopping_cart_content']);
},
complete: function() {
cartForm = jQuery('.shop_table.cart form');
}
});
}
});
}
@dan-zakirov
Copy link

Nice

@Snadex
Copy link

Snadex commented Dec 15, 2021

On the latest wp + woo I had to make the following changes to make this work:

  1. Change the WP Nonce and manually add _wp_http_referer
    this will remove the auto added input "_wp_http_referer" with the last "false" parameter.
add_action('woocommerce_before_mini_cart_contents','mini_cart_nonce' );
function mini_cart_nonce(){
    wp_nonce_field( 'woocommerce-cart', 'woocommerce-cart-nonce', false );
}

VERY IMPORTANT, add
<input type="hidden" name="_wp_http_referer" value="<?php echo wc_get_cart_url(); ?>">
inside the mini-cart form.

  1. For refreshing the cart, just trigger
    jQuery( document.body ).trigger( 'wc_fragment_refresh' );
jQuery.ajax({
    type: cartForm.attr('method'),
    url: cartForm.attr('action'),
    data: formData,
    dataType: 'html',
    success: function(response) {

        jQuery( document.body ).trigger( 'wc_fragment_refresh' );

    }
});

(make sure the mini-cart is coming with the fragments)

@Ali-Javaid09
Copy link

this code i snot working in basel theme. Quantity not update ist goin on loading

@daniloclabs
Copy link

Stopped working in Hello Elementor as well

@tomcei
Copy link

tomcei commented Jan 17, 2024

Hi, thank You . Mini-cart is refreshing properly by using your code on a local environment. But what about verifying nonce you created ? Is it not needed ?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment