Current File : /home/escuelai/public_html/wp-content/plugins/wpforms-lite/assets/js/frontend/fields/address.js |
/* global wpforms_settings */
/**
* @param wpforms_settings.address_field.list_countries_without_states
*/
( function( window, $ ) {
const app = {
/**
* List of countries without states.
*
* @see WPForms\Forms\Fields\Address\Frontend::strings for PHP filter.
*
* @since 1.9.5
*/
noStateCountries: [],
/**
* Init Address field.
*
* @since 1.9.5
*/
init() {
$( window ).on( 'load', app.onLoad );
$( document )
.on( 'wpformsRepeaterFieldCloneCreated', app.setChangeHandlers );
},
/**
* On load event.
*
* @since 1.9.5
*/
onLoad() {
app.noStateCountries = wpforms_settings?.address_field?.list_countries_without_states || [];
if ( ! app.noStateCountries.length ) {
return;
}
app.setChangeHandlers();
},
/**
* Set change handlers.
*
* @since 1.9.5
*/
setChangeHandlers() {
$( '.wpforms-field-address' ).each( function() {
const $countrySelect = $( this ).find( 'select.wpforms-field-address-country' );
if ( ! $countrySelect.length ) {
return;
}
app.handleCountryChange( $countrySelect );
$countrySelect
.off( 'change' )
.on( 'change', function() {
app.handleCountryChange( this );
} );
} );
},
/**
* Handle country change.
*
* @since 1.9.5
*
* @param {HTMLElement} field Country select field.
*/
handleCountryChange( field ) {
const $this = $( field ),
$stateInput = $this.closest( '.wpforms-field' ).find( '.wpforms-field-address-state' ),
$rowWithState = $stateInput.closest( '.wpforms-field-row' );
if ( ! $rowWithState.length ) {
return;
}
const value = $this.val();
app.handleStateInput( $stateInput, $rowWithState, value );
},
/**
* Handle state input.
*
* @since 1.9.5
*
* @param {jQuery} $stateInput State input.
* @param {jQuery} $rowWithState Row with state.
* @param {string} countryValue Country value.
*/
handleStateInput( $stateInput, $rowWithState, countryValue ) {
if ( app.noStateCountries.includes( countryValue ) ) {
$stateInput
.val( '' )
.prop( 'disabled', true )
.prop( 'required', false )
.on( 'change', function() {
$( this ).val( '' );
} );
$rowWithState.addClass( 'wpforms-without-state' );
return;
}
$stateInput
.prop( 'disabled', false )
.prop( 'required', $rowWithState.find( '.wpforms-first input' ).prop( 'required' ) ) // Set required same as first input.
.off( 'change' );
$rowWithState.removeClass( 'wpforms-without-state' );
},
};
app.init();
return app;
}( window, jQuery ) );