This is easily done, but the javascript functions that trigger the minicart show/hide will "break", since you are reloading content into the DOM, which was instantiated at page load or document ready.
I'll show you how to achieve the result first, then we'll tackle the javascript issue.
Answering The Question
The block you want is called minicart_head
, so your layout code in the controller addAction
should be as follows:
if (!$this->_getSession()->getNoCartRedirect(true)) {
if (!$cart->getQuote()->getHasError()){
$message = $this->__('%s was added to your shopping cart.', Mage::helper('core')->htmlEscape($product->getName()));
$response['status'] = 'SUCCESS';
$response['message'] = $message;
$this->loadLayout();
$minicart = $this->getLayout()->getBlock('minicart_head')->toHtml(); // <-- here's the block
$response['minicart'] = $minicart;
}
}
You can use the minicart
data to replace the DOM object from your javascript function.
try {
jQuery.ajax({
url: url,
dataType: 'json',
type : 'post',
data: data,
success: function(data){
var json = eval(data);
jQuery('#ajax_loader').hide();
if (jQuery('.header-minicart')) {
jQuery('.header-minicart').html( json.minicart );
}
}
});
} catch (e) {
}
If you observe the DOM, using Web Inspector, for example, you will see that the content updates now via AJAX, but your show/hide feature will no longer work, since the javascript that acts on the #header-cart
link has not been triggered for the new content.
Javascript Issue
By using jQuery's .on()
, the theme developers at magento are on the right track (although they use a convoluted procedure to update the cart via AJAX).
In order for the show/hide feature to work, you need to use .on()
delegation, or bubbling. In app.js
, find the following:
File: app/skin/frontend/rwd/default/js/app.js
var skipContents = $j('.skip-content');
var skipLinks = $j('.skip-link');
skipLinks.on('click', function (e) {
...
}
And replace it as follows:
var skipContents = $j('.skip-content');
var skipLinks = $j('.skip-link');
$j('.skip-links').on('click', '.skip-link', function (e) {
...
}
And there you have it. Now your content reloads via AJAX, and the links still work after the cart changes.
Open your root directory and open minicart.phtml
.
The file path is:
app/design/frontend/{Vendor}/{themename}/Magento_Checkout/templates/cart/minicart.phtml
You have to just replace span with below code,
<span class="counter qty empty"
data-bind="css: { empty: cart().summary_count == 0 }, blockLoader: isLoading">
<!-- ko if: cart().summary_count -->
<span class="counter-number"><!-- ko text: cart().summary_count --><!-- /ko --></span>
<!-- /ko -->
<!-- ko ifnot: cart().summary_count -->
<span class="counter-number">0</span>
<!-- /ko -->
<span class="counter-label">
<!-- ko if: cart().summary_count -->
<!-- ko text: cart().summary_count --><!-- /ko -->
<!-- ko i18n: 'items' --><!-- /ko -->
<!-- /ko -->
</span>
</span>
Run command, php bin/magento setup:static-content:deploy
remove var folder and check again.
Best Answer
Add to cart Ajax call is given in below js file:
/vendor/magento/module-catalog/view/frontend/web/js/catalog-add-to-cart.js
So we need to override it in your theme like following:
Following is default ajax call where we need to add some code:
Add below code in beforeSend() function:
Add below code in success() function:
Like below:
I have used setTimeout() function to stop loader after mini-cart count increament.