Last active
August 2, 2024 19:26
-
-
Save MaximilianoRicoTabo/ae33f0af7ac63f4325e0531f31f83a4e to your computer and use it in GitHub Desktop.
Format the phone field to look like (###) ###-####
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/** | |
* Format the phone field to look like (###) ###-#### | |
* link: TBD | |
* | |
* You can add this recipe to your site by creating a custom plugin | |
* or using the Code Snippets plugin available for free in the WordPress repository. | |
* Read this companion article for step-by-step directions on either method. | |
* https://www.paidmembershipspro.com/create-a-plugin-for-pmpro-customizations | |
*/ | |
// add script on checkout page | |
function my_pmpro_format_phone() { | |
?> | |
<script> | |
jQuery( document ).ready( function( $ ) { | |
//Change the id below accordingly | |
$( '#phone' ).on( 'input', function() { | |
let input = $( this ).val(); | |
// Remove all non-numeric characters | |
input = input.replace( /\D/g, '' ); | |
// Initialize formatted output | |
let formatted = ''; | |
// Add area code part | |
if ( input.length > 0 ) { | |
formatted += '(' + input.substring( 0, 3 ); | |
} | |
// Add first 3 digits after area code | |
if ( input.length > 3 ) { | |
formatted += ') ' + input.substring( 3, 6 ); | |
} | |
// Add last 4 digits | |
if ( input.length > 6 ) { | |
formatted += '-' + input.substring( 6, 10 ); | |
} | |
// Set the formatted value back to the input field | |
$( this ).val( formatted ); | |
}); | |
}); | |
</script> | |
<?php | |
} | |
add_action( 'pmpro_checkout_after_form', 'my_pmpro_format_phone' ); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment