Автоматически отменять заказ через X дней, если нет оплаты в WooCommercePhp

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Автоматически отменять заказ через X дней, если нет оплаты в WooCommerce

Сообщение Anonymous »

Мне удалось собрать это после поиска в Интернете, но это не работает. Моя цель — автоматически отменить ВСЕ заказы со статусом «Удержание», независимо от платежного шлюза, если заказ не был оплачен в течение трех дней.

Код явно неполный. и я прошу помощи, чтобы завершить его. Я проверял его с -1 минутой, чтобы увидеть, произошло ли что-нибудь. Это не так.

function get_unpaid_orders() {
global $wpdb;

$unpaid_orders = $wpdb->get_col( $wpdb->prepare( "
SELECT posts.ID
FROM {$wpdb->posts} AS posts
WHERE posts.post_status = 'wc-on-hold'
AND posts.post_date < %s
", date( 'Y-m-d H:i:s', strtotime('-1 minute') ) ) );

return $unpaid_orders;
}

add_action( 'woocommerce_cancel_unpaid_submitted', 'cancel_unpaid_orders' );
function cancel_unpaid_orders() {
$unpaid_orders = get_unpaid_orders();

if ( $unpaid_orders ) {
foreach ( $unpaid_orders as $unpaid_order ) {
$order = wc_get_order( $unpaid_order );
$cancel_order = true;

foreach ( $order->get_items() as $item_key => $item_values) {
$manage_stock = get_post_meta( $item_values, '_manage_stock', true );
if ( $manage_stock == "yes" ) {
$payment_method = $order->get_payment_method();
if ( $payment_method == "bacs" ) {
$cancel_order = false;
}
}
}
if ( $cancel_order == true ) {
$order -> update_status( 'cancelled', __( 'The order was cancelled due to no payment from customer.', 'woocommerce') );
}
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/557 ... oocommerce
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»