2015-07-10 04:32:30 +00:00
|
|
|
/*global wc_setup_params */
|
2017-10-26 12:39:54 +00:00
|
|
|
/*global wc_setup_currencies */
|
2018-03-27 18:32:04 +00:00
|
|
|
/*global wc_base_state */
|
2016-04-01 10:19:55 +00:00
|
|
|
jQuery( function( $ ) {
|
2017-09-10 22:48:38 +00:00
|
|
|
function blockWizardUI() {
|
|
|
|
$('.wc-setup-content').block({
|
|
|
|
message: null,
|
|
|
|
overlayCSS: {
|
|
|
|
background: '#fff',
|
|
|
|
opacity: 0.6
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-03-31 16:17:11 +00:00
|
|
|
$( '.button-next' ).on( 'click', function() {
|
2017-09-09 01:45:57 +00:00
|
|
|
var form = $( this ).parents( 'form' ).get( 0 );
|
|
|
|
|
2017-09-10 22:33:04 +00:00
|
|
|
if ( ( 'function' !== typeof form.checkValidity ) || form.checkValidity() ) {
|
2017-09-10 22:48:38 +00:00
|
|
|
blockWizardUI();
|
2017-09-09 01:45:57 +00:00
|
|
|
}
|
|
|
|
|
2015-08-21 18:12:36 +00:00
|
|
|
return true;
|
2016-04-01 10:19:55 +00:00
|
|
|
} );
|
2015-08-21 18:12:36 +00:00
|
|
|
|
2018-03-27 18:32:04 +00:00
|
|
|
$( '#store_country' ).on( 'change', function() {
|
|
|
|
// Prevent if we don't have the metabox data
|
|
|
|
if ( wc_setup_params.states === null ){
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var $this = $( this ),
|
|
|
|
country = $this.val(),
|
|
|
|
$state_select = $( '#store_state' );
|
|
|
|
|
|
|
|
if ( ! $.isEmptyObject( wc_setup_params.states[ country ] ) ) {
|
|
|
|
var states = wc_setup_params.states[ country ];
|
|
|
|
|
|
|
|
$state_select.empty();
|
|
|
|
|
|
|
|
$.each( states, function( index ) {
|
|
|
|
$state_select.append( $( '<option value="' + index + '">' + states[ index ] + '</option>' ) );
|
|
|
|
} );
|
|
|
|
|
|
|
|
$( '.store-state-container' ).show();
|
|
|
|
$state_select.selectWoo().val( wc_base_state ).change().prop( 'required', true );
|
|
|
|
} else {
|
|
|
|
$( '.store-state-container' ).hide();
|
|
|
|
$state_select.empty().val( '' ).change().prop( 'required', false );
|
|
|
|
}
|
|
|
|
} );
|
|
|
|
|
|
|
|
$( '#store_country' ).change();
|
|
|
|
|
2017-09-07 23:03:16 +00:00
|
|
|
$( '.wc-wizard-services' ).on( 'change', '.wc-wizard-service-enable input', function() {
|
2016-04-01 16:30:04 +00:00
|
|
|
if ( $( this ).is( ':checked' ) ) {
|
2017-09-07 23:03:16 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-toggle' ).removeClass( 'disabled' );
|
2017-09-17 00:57:17 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-item' ).addClass( 'checked' );
|
2017-10-04 19:37:59 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-item' )
|
|
|
|
.find( '.wc-wizard-service-settings' ).removeClass( 'hide' );
|
2016-04-01 16:30:04 +00:00
|
|
|
} else {
|
2017-09-07 23:03:16 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-toggle' ).addClass( 'disabled' );
|
2017-09-17 00:57:17 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-item' ).removeClass( 'checked' );
|
2017-10-04 19:37:59 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-item' )
|
|
|
|
.find( '.wc-wizard-service-settings' ).addClass( 'hide' );
|
2016-04-01 16:30:04 +00:00
|
|
|
}
|
|
|
|
} );
|
|
|
|
|
2017-09-09 02:11:28 +00:00
|
|
|
$( '.wc-wizard-services' ).on( 'click', '.wc-wizard-service-enable', function( e ) {
|
2017-11-15 14:34:35 +00:00
|
|
|
var eventTarget = $( e.target );
|
|
|
|
|
|
|
|
if ( eventTarget.is( 'input' ) ) {
|
|
|
|
e.stopPropagation();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var $checkbox = $( this ).find( 'input[type="checkbox"]' );
|
2017-09-09 02:11:28 +00:00
|
|
|
|
|
|
|
$checkbox.prop( 'checked', ! $checkbox.prop( 'checked' ) ).change();
|
2016-04-01 16:30:04 +00:00
|
|
|
} );
|
2017-09-07 23:24:49 +00:00
|
|
|
|
2018-02-20 01:03:32 +00:00
|
|
|
$( '.wc-wizard-services-list-toggle' ).on( 'click', function() {
|
2017-11-15 14:34:35 +00:00
|
|
|
$( this ).closest( '.wc-wizard-services-list-toggle' ).toggleClass( 'closed' );
|
|
|
|
$( this ).closest( '.wc-wizard-services' ).find( '.wc-wizard-service-item' )
|
|
|
|
.slideToggle()
|
|
|
|
.css( 'display', 'flex' );
|
2017-09-07 23:24:49 +00:00
|
|
|
} );
|
2017-09-09 03:53:34 +00:00
|
|
|
|
2017-09-10 16:39:38 +00:00
|
|
|
$( '.wc-wizard-services' ).on( 'change', '.wc-wizard-shipping-method-select .method', function( e ) {
|
2017-09-21 17:17:55 +00:00
|
|
|
var zone = $( this ).closest( '.wc-wizard-service-description' );
|
2017-09-11 20:56:29 +00:00
|
|
|
var selectedMethod = e.target.value;
|
2017-09-09 03:53:34 +00:00
|
|
|
|
2017-09-21 17:17:55 +00:00
|
|
|
var description = zone.find( '.shipping-method-descriptions' );
|
|
|
|
description.find( '.shipping-method-description' ).addClass( 'hide' );
|
|
|
|
description.find( '.' + selectedMethod ).removeClass( 'hide' );
|
2017-09-09 03:53:34 +00:00
|
|
|
|
2017-09-21 17:17:55 +00:00
|
|
|
var settings = zone.find( '.shipping-method-settings' );
|
2017-10-10 15:59:08 +00:00
|
|
|
settings
|
|
|
|
.find( '.shipping-method-setting' )
|
|
|
|
.addClass( 'hide' )
|
|
|
|
.find( '.shipping-method-required-field' )
|
|
|
|
.prop( 'required', false );
|
|
|
|
settings
|
|
|
|
.find( '.' + selectedMethod )
|
|
|
|
.removeClass( 'hide' )
|
|
|
|
.find( '.shipping-method-required-field' )
|
|
|
|
.prop( 'required', true );
|
2018-01-25 04:52:59 +00:00
|
|
|
} ).find( '.wc-wizard-shipping-method-select .method' ).change();
|
2017-10-10 15:59:08 +00:00
|
|
|
|
2017-10-11 09:50:39 +00:00
|
|
|
$( '.wc-wizard-services' ).on( 'change', '.wc-wizard-shipping-method-enable', function() {
|
2017-10-10 15:59:08 +00:00
|
|
|
var checked = $( this ).is( ':checked' );
|
|
|
|
|
|
|
|
$( this )
|
|
|
|
.closest( '.wc-wizard-service-item' )
|
|
|
|
.find( '.shipping-method-required-field' )
|
|
|
|
.prop( 'required', checked );
|
2017-09-09 03:53:34 +00:00
|
|
|
} );
|
2017-09-10 22:48:38 +00:00
|
|
|
|
|
|
|
function submitActivateForm() {
|
|
|
|
$( 'form.activate-jetpack' ).submit();
|
|
|
|
}
|
|
|
|
|
|
|
|
function waitForJetpackInstall() {
|
|
|
|
wp.ajax.post( 'setup_wizard_check_jetpack' )
|
|
|
|
.then( function( result ) {
|
|
|
|
// If we receive success, or an unexpected result
|
|
|
|
// let the form submit.
|
|
|
|
if (
|
|
|
|
! result ||
|
|
|
|
! result.is_active ||
|
|
|
|
'yes' === result.is_active
|
|
|
|
) {
|
|
|
|
return submitActivateForm();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Wait until checking the status again
|
|
|
|
setTimeout( waitForJetpackInstall, 3000 );
|
|
|
|
} )
|
|
|
|
.fail( function() {
|
|
|
|
// Submit the form as normal if the request fails
|
|
|
|
submitActivateForm();
|
|
|
|
} );
|
|
|
|
}
|
|
|
|
|
|
|
|
// Wait for a pending Jetpack install to finish before triggering a "save"
|
|
|
|
// on the activate step, which launches the Jetpack connection flow.
|
2017-09-25 15:24:16 +00:00
|
|
|
$( '.activate-jetpack' ).on( 'click', '.button-primary', function( e ) {
|
2017-09-10 22:48:38 +00:00
|
|
|
blockWizardUI();
|
|
|
|
|
|
|
|
if ( 'no' === wc_setup_params.pending_jetpack_install ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
e.preventDefault();
|
|
|
|
waitForJetpackInstall();
|
|
|
|
} );
|
2017-10-04 19:37:59 +00:00
|
|
|
|
2017-12-05 19:58:50 +00:00
|
|
|
$( '.wc-wizard-services' ).on( 'change', 'input#stripe_create_account, input#ppec_paypal_reroute_requests', function() {
|
2017-10-04 19:37:59 +00:00
|
|
|
if ( $( this ).is( ':checked' ) ) {
|
|
|
|
$( this ).closest( '.wc-wizard-service-settings' )
|
|
|
|
.find( 'input.payment-email-input' )
|
|
|
|
.prop( 'required', true );
|
2017-10-10 14:40:03 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-settings' )
|
2017-12-22 19:57:50 +00:00
|
|
|
.find( '.wc-wizard-service-setting-stripe_email, .wc-wizard-service-setting-ppec_paypal_email' )
|
2017-10-10 14:40:03 +00:00
|
|
|
.show();
|
2017-10-04 19:37:59 +00:00
|
|
|
} else {
|
|
|
|
$( this ).closest( '.wc-wizard-service-settings' )
|
|
|
|
.find( 'input.payment-email-input' )
|
|
|
|
.prop( 'required', false );
|
2017-10-10 14:40:03 +00:00
|
|
|
$( this ).closest( '.wc-wizard-service-settings' )
|
2017-12-22 19:57:50 +00:00
|
|
|
.find( '.wc-wizard-service-setting-stripe_email, .wc-wizard-service-setting-ppec_paypal_email' )
|
2017-10-10 14:40:03 +00:00
|
|
|
.hide();
|
2017-10-04 19:37:59 +00:00
|
|
|
}
|
2017-12-05 19:58:50 +00:00
|
|
|
} ).find( 'input#stripe_create_account, input#ppec_paypal_reroute_requests' ).change();
|
2017-10-26 12:39:54 +00:00
|
|
|
|
2018-03-27 18:32:04 +00:00
|
|
|
$( 'select#store_country' ).on( 'change', function() {
|
|
|
|
var countryCode = $( this ).val();
|
2017-10-26 12:39:54 +00:00
|
|
|
$( 'select#currency_code' ).val( wc_setup_currencies[ countryCode ] ).change();
|
|
|
|
} );
|
2016-04-01 10:19:55 +00:00
|
|
|
} );
|