autoship_create_scheduled_order_next_occurrence
(src > orders.php) Inside the autoship_get_scheduled_order_data function, and an be used to modify the next_occurence date for each order. The filter takes the 1. next_occurrence, 2. frequency_type, 3. frequency, 4. creation_date, and 5. WC Order object as parameters and expects a return value in 'Y-m-d H:i:s' format.
Example
/**
* Globally change Scheduled Orders' next occurrence date to a Monday if date falls on a Sat or Sun
*
* @param string $next_occurrence The current assigned next occurrence date
* @param string $frequency_type. The frequency type assigned to this product
* @param int $frequency. The actual frequency duration.
* @param string $creation_date The creation date for the order.
* Date should be in Y-m-d H:i:s format ( 2019-07-19 15:21:39 )
* @return string The filtered next occurrence date should be in Y-m-d\TH:i:s format.
*/
function xx_change_next_occurrence_date ($next_occurrence, $frequency_type, $frequency, $creation_date, $wc_order){
// Call the API to get the calculated next occurrence date based off creation.
$calculated_date = autoship_calculate_scheduled_order_next_occurrence ( $frequency_type, $frequency, $creation_date );
// Check for API errors.
if ( is_wp_error( $calculated_date ) )
return $next_occurrence;
// Get the day for the current date time string.
$day = date("D", strtotime( $calculated_date ));
// if day is Sat add 2 days to next occurrence
// else if day is Sun add 1 day to next occurrence
if ( $day == 'Sat' ){
$next_occurrence = date("Y-m-d\TH:i:s", strtotime( $calculated_date ) + 172800);
} else if ( $day == 'Sun' ){
$next_occurrence = date("Y-m-d\TH:i:s", strtotime( $calculated_date ) + 86400);
}
return $next_occurrence;
}
add_filter('autoship_create_scheduled_order_next_occurrence', 'xx_change_next_occurrence_date', 10, 5);