繁体   English   中英

WooCommerce:添加自定义元作为隐藏订单项元供内部使用

[英]WooCommerce: Add custom meta as hidden order item meta for internal use

我想在 WooCommerce 中的订单项中添加一些元数据。 这些元字段仅供内部使用,不应可见。

我们在产品中有一些额外的字段,例如额外费用。 我想在导出订单后使用该费用。

我在这里找到了一个很好的答案: https://stackoverflow.com/a/41988701/1788961

add_action('woocommerce_checkout_create_order_line_item', 'add_custom_hiden_order_item_meta_data', 20, 4 );
function add_custom_hiden_order_item_meta_data( $item, $cart_item_key, $values, $order ) {

    // Set user meta custom field as order item meta
    if( $meta_value = get_user_meta( $order->get_user_id(), 'billing_enumber', true ) )
        $item->update_meta_data( 'pa_billing-e-number', $meta_value );
}

但是在这个例子中,来自元字段的内容将出现在客户的订单详细信息中。

有没有办法让这些字段只在后端可见并且可用于内部功能?

更新

将任何元值设置为仅在管理员订单编辑页面上可见的隐藏订单项元数据的简单方法是在元键的开头添加下划线,例如:

add_action('woocommerce_checkout_create_order_line_item', 'add_custom_hiden_order_item_meta_data', 20, 4 );
function add_custom_hiden_order_item_meta_data( $item, $cart_item_key, $values, $order ) {

    // Set user 'billing_enumber' custom field as admin order item meta (hidden from customer)
    if( $meta_value = get_user_meta( $order->get_user_id(), 'billing_enumber', true ) )
        $item->update_meta_data( '_billing_enumber', $meta_value );
}

然后,要在管理员订单项上为该元键设置一个干净的 label 名称,您可以使用:

add_filter('woocommerce_order_item_display_meta_key', 'filter_wc_order_item_display_meta_key', 20, 3 );
function filter_wc_order_item_display_meta_key( $display_key, $meta, $item ) {

    // Set user meta custom field as order item meta
    if( $meta->key === '_billing_enumber' && is_admin() )
        $display_key = __("Billing E Number", "woocommerce" );

    return $display_key;    
}

此代码位于活动子主题(或 cative 主题)的 function.php 文件中。 测试和工作。

在此处输入图像描述

add_action('woocommerce_add_order_item_meta','mau_add_values_to_order_item_meta',1,2);
if(!function_exists('mau_add_values_to_order_item_meta'))
{
  function mau_add_values_to_order_item_meta($item_id, $values)
  {
        global $woocommerce,$wpdb;
        
        $postcode = $values['postcode'];
        $extend_date_delivery = $values['extend_date_delivery'];
        $extend_date_collection = $values['extend_date_collection'];
        $pro_rental_type_choose = $values['pro_rental_type_choose'];
        if(!empty($postcode))
        {
            wc_add_order_item_meta($item_id,'postcode',$postcode);  
        }
        if(!empty($extend_date_delivery))
        {
            wc_add_order_item_meta($item_id,'extend_date_delivery',$extend_date_delivery);  
        }
        if(!empty($extend_date_collection))
        {
            wc_add_order_item_meta($item_id,'extend_date_collection',$extend_date_collection);  
        }
        if(!empty($pro_rental_type_choose))
        {
            wc_add_order_item_meta($item_id,'pro_rental_type_choose',$pro_rental_type_choose);  
        }
  }
}

add_filter( 'woocommerce_order_item_display_meta_key', 'mau_change_shipping_note_title', 20, 3 );
function mau_change_shipping_note_title( $key, $meta, $item ) {
    if ( 'postcode' === $meta->key ) { $key = __( 'Postcode', 'your_textdomain'); }
    if ( 'extend_date_delivery' === $meta->key ) { $key = __( 'Delivery Date', 'your_textdomain'); }
    if ( 'extend_date_collection' === $meta->key ) { $key = __( 'Collection Date', 'your_textdomain'); }
    if ( 'pro_rental_type_choose' === $meta->key ) { $key = __( 'Rental Type', 'your_textdomain'); }
     
    return $key;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM