如何获取订单日期 + 30 天到我的 wooCommerce php 代码



我正在Woocommerce 3.5的主订单区域中创建一个列,该列将显示客户名称+ 手动创建订单日期添加的30天。如何使用我拥有的代码执行此操作?

add_filter( 'manage_edit-shop_order_columns','custom_column_eldest_players', 20 ); 
function custom_column_eldest_players($columns)
{
$reordered_columns = array();

foreach( $columns as $key => $column){
    $reordered_columns[$key] = $column;
    if( $key ==  'order_status' ){
        $reordered_columns['skb-client'] = __( 'Customer - Expiration (30 Days)','theme_domain');
    }
}
return $reordered_columns;
}
add_action( 'manage_shop_order_posts_custom_column' , 'custom_orders_list_column_content', 20, 2 );
function custom_orders_list_column_content( $column, $post_id )
{
if ( 'skb-client' != $column ) return;
$date = 'now';
$date = strtotime($date);
$date = strtotime('+30 day', $date);

$user_id = get_post_meta( $post_id, '_customer_user', true );
if( ! empty($user_id) && $user_id != 0) {
    $user_data = get_userdata( $user_id );
    echo $user_data->user_login;
}
else
     echo ('<small>(<em>Guest</em>)</small> - ');
echo date('M d, Y', $date);
}

如果订单是在2019年1月16日下达的,我希望代码显示"客人姓名 - 2019年2月15日"

取而代之的是:

function custom_orders_list_column_content( $column, $post_id ){
...
   $date = 'now';
   $date = strtotime($date);
   $date = strtotime('+30 day', $date);
...
}

试试这个:

function custom_orders_list_column_content( $column, $post_id ){
...
   $Order = wc_get_order($post_id);
   $date = (new DateTime($Order->get_date_created()))->modify('+30 days');
...
}

然后像

echo $date->format('M jS, Y'); //Jan 16th, 2019

或者你想显示它。

最新更新