Ask your WordPress questions! Pay money and get answers fast! (more info)

Modification of Woocommerce 'Product Add-ons' data WordPress

  • SOLVED

Hi,

I am using the Product Add-ons plugin (http://www.woothemes.com/products/product-add-ons/) for adding input fields to products.

The plugin displays total order amount in two section
1. Options total and
2. Grand total(base price+option price).

Is there any way to display the Options total and Grand total amount permanently without select options? i mean to say like always show option total and Grand total regardless of options.

please help me in this regard.

I'm posting the addon.js code file which I believe is used for calculation and displaying the amounts by the product addon plugin.

(Screenshot attached that how i want)



jQuery(document).ready(function($) {

function init_addon_totals() {

$('.cart').on( 'keyup change', '.product-addon input, .product-addon textarea', function() {

if ( $(this).attr('maxlength') > 0 ) {

var value = $(this).val();
var remaining = $(this).attr('maxlength') - value.length;

$(this).next('.chars_remaining').find('span').text( remaining );

}

} );

$('.cart').find('.addon-custom, .addon-custom-textarea').each(function(){

if ( $(this).attr('maxlength') > 0 ) {

$(this).after('<small class="chars_remaining"><span>' + $(this).attr('maxlength') + '</span> ' + woocommerce_addons_params.i18n_remaining + '</small>' );

}

} );

$('.cart').on( 'change', '.product-addon input, .product-addon textarea, .product-addon select, input.qty', function() {
var $cart = $(this).closest('.cart');
$cart.trigger('woocommerce-product-addons-update');
} );

$('body').on('found_variation', '.variations_form', function( event, variation ) {
var $variation_form = $(this);
var $totals = $variation_form.find('#product-addons-total');

if ( $( variation.price_html ).find('.amount:last').size() ) {
product_price = $( variation.price_html ).find('.amount:last').text();
product_price = product_price.replace( woocommerce_addons_params.currency_format_thousand_sep, '' );
product_price = product_price.replace( woocommerce_addons_params.currency_format_decimal_sep, '.' );
product_price = product_price.replace(/[^0-9\.]/g, '');
product_price = parseFloat( product_price );

$totals.data( 'price', product_price );
}
$variation_form.trigger('woocommerce-product-addons-update');
});

$('.cart').bind( 'woocommerce-product-addons-update', function() {
var total = 0;
var $cart = $(this);
var $totals = $cart.find('#product-addons-total');
var product_price = $totals.data( 'price' );
var product_type = $totals.data( 'type' );

// Move totals
if ( product_type == 'variable' || product_type == 'variable-subscription' ) {
$cart.find('.single_variation').after( $totals );
}

$cart.find('.addon').each(function() {
var addon_cost = 0;

if ( $(this).is('.addon-custom-price') ) {
addon_cost = $(this).val();
} else if ( $(this).is('.addon-input_multiplier') ) {
if( isNaN( $(this).val() ) || $(this).val() == "" ) { // Number inputs return blank when invalid
$(this).val('');
$(this).closest('p').find('.addon-alert').show();
} else {
if( $(this).val() != "" ){
$(this).val( Math.ceil( $(this).val() ) );
}
$(this).closest('p').find('.addon-alert').hide();
}
addon_cost = $(this).data('price') * $(this).val();
} else if ( $(this).is('.addon-checkbox, .addon-radio') ) {
if ( $(this).is(':checked') )
addon_cost = $(this).data('price');
} else if ( $(this).is('.addon-select') ) {
if ( $(this).val() )
addon_cost = $(this).find('option:selected').data('price');
} else {
if ( $(this).val() )
addon_cost = $(this).data('price');
}

if ( ! addon_cost )
addon_cost = 0;

total = parseFloat( total ) + parseFloat( addon_cost );
} );

var qty = parseFloat( $cart.find('input.qty').val() );

if ( total > 0 && qty > 0 ) {

total = parseFloat( total * qty );

var formatted_addon_total = accounting.formatMoney( total, {
symbol : woocommerce_addons_params.currency_format_symbol,
decimal : woocommerce_addons_params.currency_format_decimal_sep,
thousand : woocommerce_addons_params.currency_format_thousand_sep,
precision : woocommerce_addons_params.currency_format_num_decimals,
format : woocommerce_addons_params.currency_format
} );

if ( product_price ) {

product_total_price = parseFloat( product_price * qty );

var formatted_grand_total = accounting.formatMoney( product_total_price + total, {
symbol : woocommerce_addons_params.currency_format_symbol,
decimal : woocommerce_addons_params.currency_format_decimal_sep,
thousand : woocommerce_addons_params.currency_format_thousand_sep,
precision : woocommerce_addons_params.currency_format_num_decimals,
format : woocommerce_addons_params.currency_format
} );

}

if ( $('.single_variation_wrap .subscription-details').length ) {
var subscription_details = $('.single_variation_wrap .subscription-details').clone().wrap('<p>').parent().html();
formatted_addon_total += subscription_details;
if ( formatted_grand_total ){
formatted_grand_total += subscription_details;
}
}

html = '<dl class="product-addon-totals"><dt>' + woocommerce_addons_params.i18n_addon_total + '</dt><dd><strong><span class="amount">' + formatted_addon_total + '</span></strong></dd>';

if ( formatted_grand_total ) {
html = html + '<dt>' + woocommerce_addons_params.i18n_grand_total + '</dt><dd><strong><span class="amount">' + formatted_grand_total + '</span></strong></dd>';
}

html = html + '</dl>';

$totals.html( html );

} else {
$totals.empty();
}

$('body').trigger('updated_addons');

} );

$('.cart').find('.addon-custom, .addon-custom-textarea, .product-addon input, .product-addon textarea, .product-addon select, input.qty').change();
}

init_addon_totals();

$( '.variations_form .product-addon' ).closest( '.cart' ).find( '.variations select' ).change();

// Quick view
$('body').on('quick-view-displayed', function() {
init_addon_totals();
});
});



Answers (3)

2014-12-08

timDesain Nanang answers:

you can try to hardcode /plugins/woocommerce-product-addons/assets/js/addons.js

change line 96:
if ( total > 0 && qty > 0 ) {
with
if ( qty > 0 ) {

<strong>PS.</strong> addons.js will be replaced after updated


simonshah comments:

You rocks Man Thanks timDesain Nanang

but grand total is still showing amount that should be zero. please advise.

Thanks


timDesain Nanang comments:

Options total: $0.00
Grand total: $144.25

I think grand total should be (25 x $5.77) = $144.25
If the product prize is zero (free), then grand total should be zero (0 x $x) = 0

This is a free product:
http://codecanyon.net/item/woocommerce-extra-product-options/full_screen_preview/7908619
Product Level Option -> Woo Single #2


timDesain Nanang comments:

Options total: $0.00
Grand total: $144.25

I think grand total should be (25 x $5.77) = $144.25
If the product prize is zero (free), then grand total should be zero (0 x $x) = 0

This is a free product:
http://codecanyon.net/item/woocommerce-extra-product-options/full_screen_preview/7908619
Product Level Option -> Woo Single #2


simonshah comments:

Got it Thanks you are amazing timDesain Nanang.


simonshah comments:

timDesain Nanang i am new to this system can you please let me know how i can assign the work amount to you.

Thanks


timDesain Nanang comments:

Hi Sir, you can give a vote here:
[[LINK href="http://wpquestions.com/question/pickAWinner/id/10241"]]http://wpquestions.com/question/pickAWinner/id/10241[[/LINK]]

Thank you


simonshah comments:

what is highest 1 or 10 please let me know.

Thanks


simonshah comments:

Sorry Odd question my meant to ask was highest vote value is 1 or 10. i got answer.

Thanks


simonshah comments:

Hey one more task if you can solve this let me know and i will create new question and we can continue there.

We need to be able to add flat / single charge costs per product. However, the plugins we see don’t allow us to do this on the product page.

We added two custom fields cost_1_name and cost_1_value. These are in the product posts. We would like the name and the value to appear on the product page, and the cost_1_value to be added into the total cost. This should also carry over to the cart /check out.

The cost_1_value is a single charge per line, not a per item charge.

screenshot attached how it should look like.