2016-08-12 09:39:21 +00:00
|
|
|
/*global wc_add_to_cart_variation_params */
|
2013-02-07 10:12:08 +00:00
|
|
|
/*!
|
|
|
|
* Variations Plugin
|
|
|
|
*/
|
|
|
|
;(function ( $, window, document, undefined ) {
|
2012-07-17 14:09:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
$.fn.wc_variation_form = function() {
|
2015-10-28 14:27:02 +00:00
|
|
|
var $form = this,
|
|
|
|
$single_variation = $form.find( '.single_variation' ),
|
2015-10-28 18:52:31 +00:00
|
|
|
$product = $form.closest( '.product' ),
|
2015-10-28 14:27:02 +00:00
|
|
|
$product_id = parseInt( $form.data( 'product_id' ), 10 ),
|
|
|
|
$product_variations = $form.data( 'product_variations' ),
|
|
|
|
$use_ajax = $product_variations === false,
|
|
|
|
$xhr = false,
|
|
|
|
$reset_variations = $form.find( '.reset_variations' ),
|
|
|
|
template = wp.template( 'variation-template' ),
|
|
|
|
unavailable_template = wp.template( 'unavailable-variation-template' ),
|
2015-10-28 14:59:40 +00:00
|
|
|
$single_variation_wrap = $form.find( '.single_variation_wrap' );
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-12-04 13:45:47 +00:00
|
|
|
// Always visible since 2.5.0
|
|
|
|
$single_variation_wrap.show();
|
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Unbind any existing events
|
|
|
|
$form.unbind( 'check_variations update_variation_values found_variation' );
|
|
|
|
$form.find( '.reset_variations' ).unbind( 'click' );
|
|
|
|
$form.find( '.variations select' ).unbind( 'change focusin' );
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Bind new events to form
|
|
|
|
$form
|
2012-12-10 13:11:05 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// On clicking the reset variation button
|
2016-02-01 12:16:17 +00:00
|
|
|
.on( 'click', '.reset_variations', function( event ) {
|
|
|
|
event.preventDefault();
|
2015-07-09 14:56:20 +00:00
|
|
|
$form.find( '.variations select' ).val( '' ).change();
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'reset_data' );
|
2015-07-09 14:56:20 +00:00
|
|
|
} )
|
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// When the variation is hidden
|
2016-02-01 12:16:17 +00:00
|
|
|
.on( 'hide_variation', function( event ) {
|
|
|
|
event.preventDefault();
|
2016-02-08 16:21:02 +00:00
|
|
|
$form.find( '.single_add_to_cart_button' ).removeClass( 'wc-variation-is-unavailable' ).addClass( 'disabled wc-variation-selection-needed' );
|
2016-05-19 10:17:34 +00:00
|
|
|
$form.find( '.woocommerce-variation-add-to-cart' ).removeClass( 'woocommerce-variation-add-to-cart-enabled' ).addClass( 'woocommerce-variation-add-to-cart-disabled' );
|
2015-10-28 13:04:28 +00:00
|
|
|
} )
|
|
|
|
|
|
|
|
// When the variation is revealed
|
|
|
|
.on( 'show_variation', function( event, variation, purchasable ) {
|
2016-02-01 12:16:17 +00:00
|
|
|
event.preventDefault();
|
2015-10-28 13:04:28 +00:00
|
|
|
if ( purchasable ) {
|
2016-02-08 16:21:02 +00:00
|
|
|
$form.find( '.single_add_to_cart_button' ).removeClass( 'disabled wc-variation-selection-needed wc-variation-is-unavailable' );
|
2016-05-19 10:17:34 +00:00
|
|
|
$form.find( '.woocommerce-variation-add-to-cart' ).removeClass( 'woocommerce-variation-add-to-cart-disabled' ).addClass( 'woocommerce-variation-add-to-cart-enabled' );
|
2015-10-28 13:04:28 +00:00
|
|
|
} else {
|
2016-02-08 16:21:02 +00:00
|
|
|
$form.find( '.single_add_to_cart_button' ).removeClass( 'wc-variation-selection-needed' ).addClass( 'disabled wc-variation-is-unavailable' );
|
2016-05-19 10:17:34 +00:00
|
|
|
$form.find( '.woocommerce-variation-add-to-cart' ).removeClass( 'woocommerce-variation-add-to-cart-enabled' ).addClass( 'woocommerce-variation-add-to-cart-disabled' );
|
2016-02-08 16:21:02 +00:00
|
|
|
}
|
|
|
|
} )
|
|
|
|
|
|
|
|
.on( 'click', '.single_add_to_cart_button', function( event ) {
|
|
|
|
var $this = $( this );
|
|
|
|
|
|
|
|
if ( $this.is('.disabled') ) {
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
if ( $this.is('.wc-variation-is-unavailable') ) {
|
|
|
|
window.alert( wc_add_to_cart_variation_params.i18n_unavailable_text );
|
|
|
|
} else if ( $this.is('.wc-variation-selection-needed') ) {
|
|
|
|
window.alert( wc_add_to_cart_variation_params.i18n_make_a_selection_text );
|
|
|
|
}
|
2015-10-28 13:04:28 +00:00
|
|
|
}
|
|
|
|
} )
|
|
|
|
|
2015-07-28 12:34:04 +00:00
|
|
|
// Reload product variations data
|
|
|
|
.on( 'reload_product_variations', function() {
|
|
|
|
$product_variations = $form.data( 'product_variations' );
|
|
|
|
$use_ajax = $product_variations === false;
|
|
|
|
} )
|
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Reset product data
|
2015-07-10 10:37:05 +00:00
|
|
|
.on( 'reset_data', function() {
|
2016-05-11 17:25:56 +00:00
|
|
|
$product.find( '.product_meta' ).find( '.sku' ).wc_reset_content();
|
2015-10-28 13:04:28 +00:00
|
|
|
$('.product_weight').wc_reset_content();
|
|
|
|
$('.product_dimensions').wc_reset_content();
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'reset_image' );
|
2015-10-28 13:53:51 +00:00
|
|
|
$single_variation.slideUp( 200 ).trigger( 'hide_variation' );
|
2015-07-09 14:56:20 +00:00
|
|
|
} )
|
|
|
|
|
|
|
|
// Reset product image
|
2015-07-10 10:37:05 +00:00
|
|
|
.on( 'reset_image', function() {
|
2015-10-28 13:53:51 +00:00
|
|
|
$form.wc_variations_image_update( false );
|
2015-07-09 14:56:20 +00:00
|
|
|
} )
|
2015-05-14 17:56:26 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// On changing an attribute
|
2015-07-10 10:37:05 +00:00
|
|
|
.on( 'change', '.variations select', function() {
|
2015-07-09 14:56:20 +00:00
|
|
|
$form.find( 'input[name="variation_id"], input.variation_id' ).val( '' ).change();
|
|
|
|
$form.find( '.wc-no-matching-variations' ).remove();
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( $use_ajax ) {
|
|
|
|
if ( $xhr ) {
|
|
|
|
$xhr.abort();
|
2015-07-10 05:13:30 +00:00
|
|
|
}
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
var all_attributes_chosen = true;
|
|
|
|
var some_attributes_chosen = false;
|
|
|
|
var data = {};
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
$form.find( '.variations select' ).each( function() {
|
|
|
|
var attribute_name = $( this ).data( 'attribute_name' ) || $( this ).attr( 'name' );
|
2016-07-22 11:42:21 +00:00
|
|
|
var value = $( this ).val() || '';
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2016-07-22 11:42:21 +00:00
|
|
|
if ( value.length === 0 ) {
|
2015-07-09 14:56:20 +00:00
|
|
|
all_attributes_chosen = false;
|
|
|
|
} else {
|
|
|
|
some_attributes_chosen = true;
|
|
|
|
}
|
2014-10-20 08:59:01 +00:00
|
|
|
|
2016-07-22 11:42:21 +00:00
|
|
|
data[ attribute_name ] = value;
|
2015-07-09 14:56:20 +00:00
|
|
|
});
|
2015-07-10 05:13:30 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( all_attributes_chosen ) {
|
|
|
|
// Get a matchihng variation via ajax
|
2016-07-07 08:16:46 +00:00
|
|
|
data.product_id = $product_id;
|
|
|
|
data.custom_data = $form.data( 'custom_data' );
|
2015-07-09 14:56:20 +00:00
|
|
|
|
2016-07-07 08:07:20 +00:00
|
|
|
$form.block( {
|
2016-06-06 13:37:49 +00:00
|
|
|
message: null,
|
|
|
|
overlayCSS: {
|
|
|
|
background: '#fff',
|
|
|
|
opacity: 0.6
|
|
|
|
}
|
2016-07-07 08:07:20 +00:00
|
|
|
} );
|
2016-06-06 13:37:49 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
$xhr = $.ajax( {
|
2016-08-11 00:17:43 +00:00
|
|
|
url: wc_add_to_cart_variation_params.wc_ajax_url.toString().replace( '%%endpoint%%', 'get_variation' ),
|
2015-07-09 14:56:20 +00:00
|
|
|
type: 'POST',
|
|
|
|
data: data,
|
|
|
|
success: function( variation ) {
|
|
|
|
if ( variation ) {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'found_variation', [ variation ] );
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'reset_data' );
|
2015-10-28 13:53:51 +00:00
|
|
|
$form.find( '.single_variation' ).after( '<p class="wc-no-matching-variations woocommerce-info">' + wc_add_to_cart_variation_params.i18n_no_matching_variations_text + '</p>' );
|
2015-07-09 14:56:20 +00:00
|
|
|
$form.find( '.wc-no-matching-variations' ).slideDown( 200 );
|
|
|
|
}
|
2016-06-06 13:37:49 +00:00
|
|
|
},
|
|
|
|
complete: function() {
|
2016-07-07 08:07:20 +00:00
|
|
|
$form.unblock();
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
|
|
|
} );
|
|
|
|
} else {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'reset_data' );
|
2015-05-14 17:56:26 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( some_attributes_chosen ) {
|
|
|
|
if ( $reset_variations.css( 'visibility' ) === 'hidden' ) {
|
|
|
|
$reset_variations.css( 'visibility', 'visible' ).hide().fadeIn();
|
|
|
|
}
|
2015-05-14 17:56:26 +00:00
|
|
|
} else {
|
2015-07-09 14:56:20 +00:00
|
|
|
$reset_variations.css( 'visibility', 'hidden' );
|
2015-05-14 17:56:26 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'woocommerce_variation_select_change' );
|
|
|
|
$form.trigger( 'check_variations', [ '', false ] );
|
2014-03-17 05:19:58 +00:00
|
|
|
$( this ).blur();
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-10-02 01:45:11 +00:00
|
|
|
// added to get around variation image flicker issue
|
2015-10-02 08:26:53 +00:00
|
|
|
$( '.product.has-default-attributes > .images' ).fadeTo( 200, 1 );
|
2015-10-27 19:24:32 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Custom event for when variation selection has been changed
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'woocommerce_variation_has_changed' );
|
2015-07-09 14:56:20 +00:00
|
|
|
} )
|
2014-12-10 21:43:26 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Upon gaining focus
|
2015-07-10 10:37:05 +00:00
|
|
|
.on( 'focusin touchstart', '.variations select', function() {
|
2015-10-27 19:59:26 +00:00
|
|
|
$( this ).find( 'option:selected' ).attr( 'selected', 'selected' );
|
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( ! $use_ajax ) {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'woocommerce_variation_select_focusin' );
|
|
|
|
$form.trigger( 'check_variations', [ $( this ).data( 'attribute_name' ) || $( this ).attr( 'name' ), true ] );
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
|
|
|
} )
|
|
|
|
|
|
|
|
// Show single variation details (price, stock, image)
|
|
|
|
.on( 'found_variation', function( event, variation ) {
|
2015-10-28 14:59:40 +00:00
|
|
|
var $sku = $product.find( '.product_meta' ).find( '.sku' ),
|
|
|
|
$weight = $product.find( '.product_weight' ),
|
|
|
|
$dimensions = $product.find( '.product_dimensions' ),
|
|
|
|
$qty = $single_variation_wrap.find( '.quantity' ),
|
|
|
|
purchasable = true;
|
2015-10-28 13:04:28 +00:00
|
|
|
|
|
|
|
// Display SKU
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( variation.sku ) {
|
2015-10-28 13:04:28 +00:00
|
|
|
$sku.wc_set_content( variation.sku );
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2015-10-28 13:04:28 +00:00
|
|
|
$sku.wc_reset_content();
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-12-10 13:11:05 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// Display weight
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( variation.weight ) {
|
2015-10-28 13:04:28 +00:00
|
|
|
$weight.wc_set_content( variation.weight );
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2015-10-28 13:04:28 +00:00
|
|
|
$weight.wc_reset_content();
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-12-10 13:11:05 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// Display dimensions
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( variation.dimensions ) {
|
2015-10-28 13:04:28 +00:00
|
|
|
$dimensions.wc_set_content( variation.dimensions );
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2015-10-28 13:04:28 +00:00
|
|
|
$dimensions.wc_reset_content();
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// Show images
|
|
|
|
$form.wc_variations_image_update( variation );
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-10-28 14:59:40 +00:00
|
|
|
// Output correct templates
|
2016-01-25 20:14:45 +00:00
|
|
|
var $template_html = '';
|
2016-02-01 12:16:17 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( ! variation.variation_is_visible ) {
|
2016-02-17 15:50:38 +00:00
|
|
|
$template_html = unavailable_template();
|
2016-01-25 20:14:45 +00:00
|
|
|
// w3 total cache inline minification adds CDATA tags around our HTML (sigh)
|
|
|
|
$template_html = $template_html.replace( '/*<![CDATA[*/', '' );
|
|
|
|
$template_html = $template_html.replace( '/*]]>*/', '' );
|
|
|
|
$single_variation.html( $template_html );
|
2015-10-28 14:59:40 +00:00
|
|
|
$form.find( 'input[name="variation_id"], input.variation_id' ).val( '' ).change();
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2016-01-25 20:14:45 +00:00
|
|
|
$template_html = template( {
|
2015-12-04 13:31:36 +00:00
|
|
|
variation: variation
|
2016-01-25 20:14:45 +00:00
|
|
|
} );
|
|
|
|
// w3 total cache inline minification adds CDATA tags around our HTML (sigh)
|
|
|
|
$template_html = $template_html.replace( '/*<![CDATA[*/', '' );
|
|
|
|
$template_html = $template_html.replace( '/*]]>*/', '' );
|
|
|
|
$single_variation.html( $template_html );
|
2015-10-28 14:59:40 +00:00
|
|
|
$form.find( 'input[name="variation_id"], input.variation_id' ).val( variation.variation_id ).change();
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// Hide or show qty input
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( variation.is_sold_individually === 'yes' ) {
|
2015-10-28 14:59:40 +00:00
|
|
|
$qty.find( 'input.qty' ).val( '1' ).attr( 'min', '1' ).attr( 'max', '' );
|
|
|
|
$qty.hide();
|
2015-07-31 11:04:55 +00:00
|
|
|
} else {
|
2015-10-28 14:59:40 +00:00
|
|
|
$qty.find( 'input.qty' ).attr( 'min', variation.min_qty ).attr( 'max', variation.max_qty );
|
|
|
|
$qty.show();
|
2015-07-31 11:04:55 +00:00
|
|
|
}
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// Enable or disable the add to cart button
|
|
|
|
if ( ! variation.is_purchasable || ! variation.is_in_stock || ! variation.variation_is_visible ) {
|
|
|
|
purchasable = false;
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
// Reveal
|
2015-10-28 15:43:06 +00:00
|
|
|
if ( $.trim( $single_variation.text() ) ) {
|
|
|
|
$single_variation.slideDown( 200 ).trigger( 'show_variation', [ variation, purchasable ] );
|
|
|
|
} else {
|
|
|
|
$single_variation.show().trigger( 'show_variation', [ variation, purchasable ] );
|
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
})
|
2014-10-20 08:59:01 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Check variations
|
|
|
|
.on( 'check_variations', function( event, exclude, focus ) {
|
|
|
|
if ( $use_ajax ) {
|
|
|
|
return;
|
|
|
|
}
|
2014-10-20 08:59:01 +00:00
|
|
|
|
2015-10-28 13:53:51 +00:00
|
|
|
var all_attributes_chosen = true,
|
2015-07-09 14:56:20 +00:00
|
|
|
some_attributes_chosen = false,
|
2015-10-28 13:53:51 +00:00
|
|
|
current_settings = {},
|
|
|
|
$form = $( this ),
|
|
|
|
$reset_variations = $form.find( '.reset_variations' );
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
$form.find( '.variations select' ).each( function() {
|
|
|
|
var attribute_name = $( this ).data( 'attribute_name' ) || $( this ).attr( 'name' );
|
2016-07-22 11:42:21 +00:00
|
|
|
var value = $( this ).val() || '';
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2016-07-22 11:42:21 +00:00
|
|
|
if ( value.length === 0 ) {
|
2015-07-09 14:56:20 +00:00
|
|
|
all_attributes_chosen = false;
|
2014-03-17 05:19:58 +00:00
|
|
|
} else {
|
2015-07-09 14:56:20 +00:00
|
|
|
some_attributes_chosen = true;
|
|
|
|
}
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( exclude && attribute_name === exclude ) {
|
|
|
|
all_attributes_chosen = false;
|
|
|
|
current_settings[ attribute_name ] = '';
|
|
|
|
} else {
|
|
|
|
// Add to settings array
|
2016-07-22 11:42:21 +00:00
|
|
|
current_settings[ attribute_name ] = value;
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
});
|
2012-08-22 06:51:19 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
var matching_variations = wc_variation_form_matcher.find_matching_variations( $product_variations, current_settings );
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( all_attributes_chosen ) {
|
2012-07-17 14:09:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
var variation = matching_variations.shift();
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( variation ) {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'found_variation', [ variation ] );
|
2014-03-17 05:19:58 +00:00
|
|
|
} else {
|
2015-07-09 14:56:20 +00:00
|
|
|
// Nothing found - reset fields
|
|
|
|
$form.find( '.variations select' ).val( '' );
|
2012-07-17 14:09:18 +00:00
|
|
|
|
2015-07-10 05:13:30 +00:00
|
|
|
if ( ! focus ) {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'reset_data' );
|
2015-07-10 05:13:30 +00:00
|
|
|
}
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-10 10:37:05 +00:00
|
|
|
window.alert( wc_add_to_cart_variation_params.i18n_no_matching_variations_text );
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'update_variation_values', [ matching_variations ] );
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( ! focus ) {
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'reset_data' );
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2014-02-22 04:08:08 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( ! exclude ) {
|
2015-10-28 13:53:51 +00:00
|
|
|
$single_variation.slideUp( 200 ).trigger( 'hide_variation' );
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
|
|
|
if ( some_attributes_chosen ) {
|
|
|
|
if ( $reset_variations.css( 'visibility' ) === 'hidden' ) {
|
|
|
|
$reset_variations.css( 'visibility', 'visible' ).hide().fadeIn();
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
|
|
|
$reset_variations.css( 'visibility', 'hidden' );
|
|
|
|
}
|
|
|
|
} )
|
2012-07-17 14:09:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Disable option fields that are unavaiable for current set of attributes
|
|
|
|
.on( 'update_variation_values', function( event, variations ) {
|
|
|
|
if ( $use_ajax ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Loop through selects and disable/enable options based on selections
|
|
|
|
$form.find( '.variations select' ).each( function( index, el ) {
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2016-10-11 17:26:08 +00:00
|
|
|
var current_attr_name, current_attr_select = $( el ),
|
|
|
|
show_option_none = $( el ).data( 'show_option_none' ),
|
|
|
|
option_gt_filter = 'no' === show_option_none ? '' : ':gt(0)';
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Reset options
|
|
|
|
if ( ! current_attr_select.data( 'attribute_options' ) ) {
|
2016-10-11 17:26:08 +00:00
|
|
|
current_attr_select.data( 'attribute_options', current_attr_select.find( 'option' + option_gt_filter ).get() );
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2016-10-11 17:26:08 +00:00
|
|
|
current_attr_select.find( 'option' + option_gt_filter ).remove();
|
2015-07-09 14:56:20 +00:00
|
|
|
current_attr_select.append( current_attr_select.data( 'attribute_options' ) );
|
2016-10-11 17:26:08 +00:00
|
|
|
current_attr_select.find( 'option' + option_gt_filter ).removeClass( 'attached' );
|
|
|
|
current_attr_select.find( 'option' + option_gt_filter ).removeClass( 'enabled' );
|
|
|
|
current_attr_select.find( 'option' + option_gt_filter ).removeAttr( 'disabled' );
|
2014-09-26 16:22:43 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Get name from data-attribute_name, or from input name if it doesn't exist
|
2015-07-10 10:37:05 +00:00
|
|
|
if ( typeof( current_attr_select.data( 'attribute_name' ) ) !== 'undefined' ) {
|
2015-07-09 14:56:20 +00:00
|
|
|
current_attr_name = current_attr_select.data( 'attribute_name' );
|
|
|
|
} else {
|
|
|
|
current_attr_name = current_attr_select.attr( 'name' );
|
|
|
|
}
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Loop through variations
|
|
|
|
for ( var num in variations ) {
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-10 10:37:05 +00:00
|
|
|
if ( typeof( variations[ num ] ) !== 'undefined' ) {
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
var attributes = variations[ num ].attributes;
|
2012-07-17 14:09:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
for ( var attr_name in attributes ) {
|
|
|
|
if ( attributes.hasOwnProperty( attr_name ) ) {
|
|
|
|
var attr_val = attributes[ attr_name ];
|
2013-02-01 11:49:29 +00:00
|
|
|
|
2015-07-10 10:37:05 +00:00
|
|
|
if ( attr_name === current_attr_name ) {
|
2013-02-01 11:49:29 +00:00
|
|
|
|
2015-07-10 10:37:05 +00:00
|
|
|
var variation_active = '';
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-10 10:37:05 +00:00
|
|
|
if ( variations[ num ].variation_is_active ) {
|
2015-07-09 14:56:20 +00:00
|
|
|
variation_active = 'enabled';
|
2015-07-10 10:37:05 +00:00
|
|
|
}
|
2014-09-26 16:22:43 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( attr_val ) {
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Decode entities
|
|
|
|
attr_val = $( '<div/>' ).html( attr_val ).text();
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Add slashes
|
2015-07-10 10:37:05 +00:00
|
|
|
attr_val = attr_val.replace( /'/g, '\\\'' );
|
|
|
|
attr_val = attr_val.replace( /"/g, '\\\"' );
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Compare the meerkat
|
|
|
|
current_attr_select.find( 'option[value="' + attr_val + '"]' ).addClass( 'attached ' + variation_active );
|
2013-02-01 11:49:29 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
} else {
|
2012-08-08 10:53:36 +00:00
|
|
|
|
2016-10-11 17:26:08 +00:00
|
|
|
current_attr_select.find( 'option' + option_gt_filter ).addClass( 'attached ' + variation_active );
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2014-02-22 04:08:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2014-02-22 04:08:08 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Detach unattached
|
2016-10-11 17:26:08 +00:00
|
|
|
current_attr_select.find( 'option' + option_gt_filter + ':not(.attached)' ).remove();
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Grey out disabled
|
2016-10-11 17:26:08 +00:00
|
|
|
current_attr_select.find( 'option' + option_gt_filter + ':not(.enabled)' ).attr( 'disabled', 'disabled' );
|
2012-08-21 15:41:18 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
});
|
2013-10-10 15:34:44 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
// Custom event for when variations have been updated
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'woocommerce_update_variation_values' );
|
2015-07-09 14:56:20 +00:00
|
|
|
});
|
2013-02-07 10:12:08 +00:00
|
|
|
|
2015-07-14 09:28:49 +00:00
|
|
|
$form.trigger( 'wc_variation_form' );
|
2013-02-07 10:12:08 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
return $form;
|
|
|
|
};
|
2013-02-07 10:12:08 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
/**
|
|
|
|
* Matches inline variation objects to chosen attributes
|
|
|
|
* @type {Object}
|
|
|
|
*/
|
|
|
|
var wc_variation_form_matcher = {
|
|
|
|
find_matching_variations: function( product_variations, settings ) {
|
|
|
|
var matching = [];
|
|
|
|
for ( var i = 0; i < product_variations.length; i++ ) {
|
|
|
|
var variation = product_variations[i];
|
2013-02-07 10:12:08 +00:00
|
|
|
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( wc_variation_form_matcher.variations_match( variation.attributes, settings ) ) {
|
|
|
|
matching.push( variation );
|
2015-07-10 05:13:30 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
|
|
|
return matching;
|
|
|
|
},
|
|
|
|
variations_match: function( attrs1, attrs2 ) {
|
|
|
|
var match = true;
|
|
|
|
for ( var attr_name in attrs1 ) {
|
|
|
|
if ( attrs1.hasOwnProperty( attr_name ) ) {
|
|
|
|
var val1 = attrs1[ attr_name ];
|
|
|
|
var val2 = attrs2[ attr_name ];
|
|
|
|
if ( val1 !== undefined && val2 !== undefined && val1.length !== 0 && val2.length !== 0 && val1 !== val2 ) {
|
|
|
|
match = false;
|
|
|
|
}
|
2014-03-17 05:19:58 +00:00
|
|
|
}
|
2015-07-09 14:56:20 +00:00
|
|
|
}
|
|
|
|
return match;
|
|
|
|
}
|
2014-02-22 04:08:08 +00:00
|
|
|
};
|
2013-02-07 10:12:08 +00:00
|
|
|
|
2015-10-28 13:04:28 +00:00
|
|
|
/**
|
|
|
|
* Stores the default text for an element so it can be reset later
|
|
|
|
*/
|
|
|
|
$.fn.wc_set_content = function( content ) {
|
|
|
|
if ( undefined === this.attr( 'data-o_content' ) ) {
|
|
|
|
this.attr( 'data-o_content', this.text() );
|
|
|
|
}
|
|
|
|
this.text( content );
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stores the default text for an element so it can be reset later
|
|
|
|
*/
|
|
|
|
$.fn.wc_reset_content = function() {
|
|
|
|
if ( undefined !== this.attr( 'data-o_content' ) ) {
|
|
|
|
this.text( this.attr( 'data-o_content' ) );
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stores a default attribute for an element so it can be reset later
|
|
|
|
*/
|
|
|
|
$.fn.wc_set_variation_attr = function( attr, value ) {
|
|
|
|
if ( undefined === this.attr( 'data-o_' + attr ) ) {
|
|
|
|
this.attr( 'data-o_' + attr, ( ! this.attr( attr ) ) ? '' : this.attr( attr ) );
|
|
|
|
}
|
|
|
|
this.attr( attr, value );
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset a default attribute for an element so it can be reset later
|
|
|
|
*/
|
|
|
|
$.fn.wc_reset_variation_attr = function( attr ) {
|
|
|
|
if ( undefined !== this.attr( 'data-o_' + attr ) ) {
|
|
|
|
this.attr( attr, this.attr( 'data-o_' + attr ) );
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets product images for the chosen variation
|
|
|
|
*/
|
|
|
|
$.fn.wc_variations_image_update = function( variation ) {
|
|
|
|
var $form = this,
|
|
|
|
$product = $form.closest('.product'),
|
|
|
|
$product_img = $product.find( 'div.images img:eq(0)' ),
|
|
|
|
$product_link = $product.find( 'div.images a.zoom:eq(0)' );
|
|
|
|
|
2015-10-28 13:53:51 +00:00
|
|
|
if ( variation && variation.image_src && variation.image_src.length > 1 ) {
|
2015-10-28 13:04:28 +00:00
|
|
|
$product_img.wc_set_variation_attr( 'src', variation.image_src );
|
|
|
|
$product_img.wc_set_variation_attr( 'title', variation.image_title );
|
2016-02-11 12:40:56 +00:00
|
|
|
$product_img.wc_set_variation_attr( 'alt', variation.image_alt );
|
2015-11-23 16:35:11 +00:00
|
|
|
$product_img.wc_set_variation_attr( 'srcset', variation.image_srcset );
|
|
|
|
$product_img.wc_set_variation_attr( 'sizes', variation.image_sizes );
|
2015-10-28 13:04:28 +00:00
|
|
|
$product_link.wc_set_variation_attr( 'href', variation.image_link );
|
|
|
|
$product_link.wc_set_variation_attr( 'title', variation.image_caption );
|
|
|
|
} else {
|
|
|
|
$product_img.wc_reset_variation_attr( 'src' );
|
|
|
|
$product_img.wc_reset_variation_attr( 'title' );
|
|
|
|
$product_img.wc_reset_variation_attr( 'alt' );
|
2015-11-23 16:35:11 +00:00
|
|
|
$product_img.wc_reset_variation_attr( 'srcset' );
|
|
|
|
$product_img.wc_reset_variation_attr( 'sizes' );
|
2015-10-28 13:04:28 +00:00
|
|
|
$product_link.wc_reset_variation_attr( 'href' );
|
|
|
|
$product_link.wc_reset_variation_attr( 'title' );
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-02-22 04:08:08 +00:00
|
|
|
$( function() {
|
2015-07-09 14:56:20 +00:00
|
|
|
if ( typeof wc_add_to_cart_variation_params !== 'undefined' ) {
|
2015-07-09 15:21:17 +00:00
|
|
|
$( '.variations_form' ).each( function() {
|
|
|
|
$( this ).wc_variation_form().find('.variations select:eq(0)').change();
|
|
|
|
});
|
2015-07-10 05:13:30 +00:00
|
|
|
}
|
2014-02-22 04:08:08 +00:00
|
|
|
});
|
2013-02-07 10:12:08 +00:00
|
|
|
|
2015-07-14 09:28:49 +00:00
|
|
|
})( jQuery, window, document );
|