Skip to content

Commit

Permalink
Merge branch 'master' into customer-exceptions
Browse files Browse the repository at this point in the history
  • Loading branch information
mikejolley committed Aug 31, 2016
2 parents d9a0d09 + 335a5e2 commit 19f051c
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 25 deletions.
57 changes: 33 additions & 24 deletions includes/class-wc-coupon.php
Original file line number Diff line number Diff line change
Expand Up @@ -800,32 +800,41 @@ private function update_post_meta( $coupon_id ) {
* @param array $coupon Array of coupon properties
*/
public function read_manual_coupon( $code, $coupon ) {
// product_ids and exclude_product_ids could be passed in as an empty string '', or comma separated values, when it should be an empty array for the new format.
$convert_fields_to_array = array( 'product_ids', 'exclude_product_ids' );
foreach ( $convert_fields_to_array as $field ) {
if ( ! is_array( $coupon[ $field ] ) ) {
_doing_it_wrong( $field, $field . ' should be an array instead of a string.', '2.7' );
$coupon[ $field ] = array_filter( explode( ',', $coupon[ $field ] ) );
}
}

// flip yes|no to true|false
$yes_no_fields = array( 'individual_use', 'free_shipping', 'exclude_sale_items' );
foreach ( $yes_no_fields as $field ) {
if ( 'yes' === $coupon[ $field ] || 'no' === $coupon[ $field ] ) {
_doing_it_wrong( $field, $field . ' should be true or false instead of yes or no.', '2.7' );
$coupon[ $field ] = 'yes' === $coupon[ $field ];
foreach ( $coupon as $key => $value ) {
switch ( $key ) {
case 'excluded_product_ids' :
case 'exclude_product_ids' :
if ( ! is_array( $coupon[ $key ] ) ) {
_doing_it_wrong( $key, $key . ' should be an array instead of a string.', '2.7' );
$coupon['excluded_product_ids'] = wc_string_to_array( $value );
}
break;
case 'exclude_product_categories' :
case 'excluded_product_categories' :
if ( ! is_array( $coupon[ $key ] ) ) {
_doing_it_wrong( $key, $key . ' should be an array instead of a string.', '2.7' );
$coupon['excluded_product_categories'] = wc_string_to_array( $value );
}
break;
case 'product_ids' :
if ( ! is_array( $coupon[ $key ] ) ) {
_doing_it_wrong( $key, $key . ' should be an array instead of a string.', '2.7' );
$coupon[ $key ] = wc_string_to_array( $value );
}
break;
case 'individual_use' :
case 'free_shipping' :
case 'exclude_sale_items' :
if ( ! is_bool( $coupon[ $key ] ) ) {
_doing_it_wrong( $key, $key . ' should be true or false instead of yes or no.', '2.7' );
$coupon[ $key ] = wc_string_to_bool( $value );
}
break;
case 'expiry_date' :
$coupon['date_expires'] = $value;
break;
}
}

// BW compat
$coupon[ 'date_expires' ] = isset( $coupon[ 'date_expires' ] ) ? $coupon[ 'date_expires' ] : '';
$coupon[ 'date_expires' ] = isset( $coupon[ 'expiry_date' ] ) ? $coupon[ 'expiry_date' ] : $coupon[ 'date_expires' ];
$coupon[ 'excluded_product_ids' ] = isset( $coupon[ 'excluded_product_ids'] ) ? $coupon[ 'excluded_product_ids'] : '';
$coupon[ 'excluded_product_ids' ] = isset( $coupon[ 'exclude_product_ids'] ) ? $coupon[ 'exclude_product_ids'] : $coupon[ 'excluded_product_ids'];
$coupon[ 'excluded_product_categories' ] = isset( $coupon[ 'excluded_product_categories'] ) ? $coupon[ 'excluded_product_categories'] : '';
$coupon[ 'excluded_product_categories' ] = isset( $coupon[ 'exclude_product_categories'] ) ? $coupon[ 'exclude_product_categories'] : $coupon[ 'excluded_product_categories'];

$this->set_code( $code );
$this->set_props( $coupon );
}
Expand Down
21 changes: 21 additions & 0 deletions includes/wc-formatting-functions.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,27 @@
exit; // Exit if accessed directly
}

/**
* Converts a string (e.g. yes or no) to a bool.
* @since 2.7.0
* @param string $string
* @return bool
*/
function wc_string_to_bool( $string ) {
return is_bool( $string ) ? $string : ( $string === 'yes' || $string === 1 || $string === '1' );
}

/**
* Explode a string into an array by $delimiter and remove empty values.
* @since 2.7.0
* @param string $string
* @param string $delimiter
* @return array
*/
function wc_string_to_array( $string, $delimiter = ',' ) {
return is_array( $string ) ? $string : array_filter( explode( $delimiter, $string ) );
}

/**
* Sanitize taxonomy names. Slug format (no spaces, lowercase).
*
Expand Down
3 changes: 2 additions & 1 deletion tests/bin/travis.sh
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@ if [ $1 == 'before' ]; then

elif [ $1 == 'after' ]; then

# no Xdebug and therefore no coverage in PHP 5.2
# no Xdebug and therefore no coverage in PHP 5.2 or 5.3
[ $TRAVIS_PHP_VERSION == '5.2' ] && exit;
[ $TRAVIS_PHP_VERSION == '5.3' ] && exit;

# send coverage data to coveralls
php vendor/bin/coveralls --verbose --exclude-no-stmt
Expand Down

0 comments on commit 19f051c

Please sign in to comment.