Skip to content

Commit

Permalink
Merge pull request woocommerce#19951 from woocommerce/update/19745
Browse files Browse the repository at this point in the history
Eircode validation and formatting
  • Loading branch information
claudiulodro authored May 31, 2018
2 parents a4b9346 + cc3fb97 commit 07bad69
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 2 deletions.
12 changes: 10 additions & 2 deletions includes/class-wc-checkout.php
Original file line number Diff line number Diff line change
Expand Up @@ -673,8 +673,16 @@ protected function validate_posted_data( &$data, &$errors ) {
$data[ $key ] = wc_format_postcode( $data[ $key ], $country );

if ( '' !== $data[ $key ] && ! WC_Validation::is_postcode( $data[ $key ], $country ) ) {
/* translators: %s: field name */
$errors->add( 'validation', sprintf( __( '%s is not a valid postcode / ZIP.', 'woocommerce' ), '<strong>' . esc_html( $field_label ) . '</strong>' ) );
switch ( $country ) {
case 'IE':
/* translators: %1$s: field name, %2$s finder.eircode.ie URL */
$postcode_validation_notice = sprintf( __( '%1$s is not a valid. You can look up the correct Eircode <a target="_blank" href="%2$s">here</a>.', 'woocommerce' ), '<strong>' . esc_html( $field_label ) . '</strong>', 'https://finder.eircode.ie' );
break;
default:
/* translators: %s: field name */
$postcode_validation_notice = sprintf( __( '%s is not a valid postcode / ZIP.', 'woocommerce' ), '<strong>' . esc_html( $field_label ) . '</strong>' );
}
$errors->add( 'validation', apply_filters( 'woocommerce_checkout_postcode_validation_notice', $postcode_validation_notice, $country, $data[ $key ] ) );
}
}

Expand Down
3 changes: 3 additions & 0 deletions includes/class-wc-validation.php
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,9 @@ public static function is_postcode( $postcode, $country ) {
case 'GB':
$valid = self::is_gb_postcode( $postcode );
break;
case 'IE':
$valid = (bool) preg_match( '/([AC-FHKNPRTV-Y]\d{2}|D6W)[0-9AC-FHKNPRTV-Y]{4}/', wc_normalize_postcode( $postcode ) );
break;
case 'JP':
$valid = (bool) preg_match( '/^([0-9]{3})([-])([0-9]{4})$/', $postcode );
break;
Expand Down
3 changes: 3 additions & 0 deletions includes/wc-formatting-functions.php
Original file line number Diff line number Diff line change
Expand Up @@ -900,6 +900,9 @@ function wc_format_postcode( $postcode, $country ) {
case 'GB':
$postcode = trim( substr_replace( $postcode, ' ', -3, 0 ) );
break;
case 'IE':
$postcode = trim( substr_replace( $postcode, ' ', 3, 0 ) );
break;
case 'BR':
case 'PL':
$postcode = substr_replace( $postcode, '-', -3, 0 );
Expand Down

0 comments on commit 07bad69

Please sign in to comment.