在WooCommerce订阅订单中获取结帐自定义字段值

时间:2017-08-28 18:41:26

标签: php wordpress woocommerce checkout woocommerce-subscriptions

为什么我无法从Woocommerce结帐字段中检索数据,以便在订单处理时更新订阅数据?

我想根据客户在结账时的频率请求更新下一个续订日期。这是我的代码:

1)设置结帐字段:

add_action( 'woocommerce_after_order_notes', 'hgf_custom_checkout_field' );

function hgf_custom_checkout_field( $checkout ) {
global $woocommerce;

    woocommerce_form_field( 'frequency', array(
        'type'          => 'select',
        'required'          => true,
        'class'         => array('form-row-wide'),
        'label'         => __('Change this any time, just email.'),
        'options'     => array(
            'blank'     => __( 'Select frequency preference', 'woocommerce' ),              
            1 => __( 'Every Week', 'woocommerce' ),
            2 => __( 'Every Other Week' , 'woocommerce' ),
            3 => __( 'Once Per Month' , 'woocommerce' )
                )
            ), $checkout->get_value( 'frequency' ));
            echo '</div>';
}

2)更新订单元。这会在客户订单上创建两个自定义字段,并更新订阅的结算间隔:

add_action( 'woocommerce_checkout_update_order_meta', 'hgf_checkout_field_update_order_meta' );
function hgf_checkout_field_update_order_meta( $order_id ) {

    if ( ! empty( $_POST['frequency'] ) ) {

        update_post_meta( $order_id, 'frequency', $_POST['frequency'] );
        update_post_meta( $order_id, 'billing_interval', $_POST['frequency'] );
    }

}

3)更新续订日期
对于最后一部分,我可以使用我选择的虚拟日期更新续订日期(例如:$renewal date = "2018-12-15",但是当我尝试将其读取为'billing_interval'字段时,它将恢复为{ {1}}默认。

else

这是我尝试的所有不同方式:

    add_action( 'woocommerce_checkout_create_subscription', 'hgf_next_renewal' );
    function hgf_next_renewal( $subscription, $timezone='site' ) {

        $billing_interval = get_post_meta( get_the_ID(), 'billing_interval', true); 

    if( $billing_interval == 2 ) {
        $renewal_date = date( 'Y-m-d H:i:s', strtotime( "2017-10-01" ) ) /* date( 'Y-m-d H:i:s', strtotime( "+2 weeks" ) ) */ ;
    } if( $billing_interval == 4 ) {
        $renewal_date = date( 'Y-m-d H:i:s', strtotime( "2017-12-01" ) ) /* date( 'Y-m-d H:i:s', strtotime( "+4 weeks" ) ) */ ;
    } else {
        $renewal_date = date( 'Y-m-d H:i:s' ) ) /* date( 'Y-m-d H:i:s', strtotime( $renewal_date) ) */ ;
    }

        $subscription->update_dates( array(
            'next_payment' => $renewal_date,
            ) );

        return $subscription;
    }

有人知道为什么我在1) $billing_interval = $subscription->get_billing_interval(); 2) $billing_interval = get_post_meta( $subscription->get_ID(), 'billing_interval', true); 3) $billing_interval = get_post_meta( $order_id, 'billing_interval', true); 4) $subscriptions = wcs_get_users_subscriptions( $user_id ); foreach ( $subscriptions as $sub ) { $billing_interval = get_post_meta( $sub->get_order_number(), '_billing_interval', true); } 5) $billing_interval = $checkout->get_value( 'frequency' ); 行动中无法从结帐字段中检索值吗?

1 个答案:

答案 0 :(得分:1)

当您在订单元数据中保存 'billing_interval' 自定义字段时,您无法通过订阅对象或ID获取此自定义字段...您需要先获得父订单ID

  

要从订阅对象获取父订单ID ,您需要使用WC_Order method get_parent_id()

所以,只有你的“其他”$renewal_date ...

才是完全正常的

所以你将以这种方式在你的函数中设置它:

add_action( 'woocommerce_checkout_create_subscription', 'hgf_next_renewal' );
function hgf_next_renewal( $subscription, $timezone='site' ) {

    // MISSING!: The parent order ID to set below
    $order_parent_id = $subscription->get_parent_id();

    $billing_interval = get_post_meta( $order_parent_id, 'billing_interval', true);

    if( $billing_interval == 2 ) {
        $renewal_date = date( 'Y-m-d H:i:s', strtotime( "2017-10-01" ) ) /* date( 'Y-m-d H:i:s', strtotime( "+2 weeks" ) ) */ ;
    } elseif( $billing_interval == 4 ) {
        $renewal_date = date( 'Y-m-d H:i:s', strtotime( "2017-12-01" ) ) /* date( 'Y-m-d H:i:s', strtotime( "+4 weeks" ) ) */ ;
    } else {
        $renewal_date = date( 'Y-m-d H:i:s', strtotime( "2017-09-01" ) ) /* date( 'Y-m-d H:i:s' ) */ ;
    }

    $subscription->update_dates( array(
        'next_payment' => $renewal_date,
    ) );

    return $subscription;
}

代码放在活动子主题(或主题)的function.php文件中,或者放在任何插件文件中。

我没有测试你的代码是真的,但它没有抛出任何错误,这次应该适合你。