Filter orders by specific meta fields in WooCommerce admin orders list

后端 未结 1 580
孤街浪徒
孤街浪徒 2020-12-11 08:22

Can anyone let me know, how can i add / set filter by company name in woo-commerce order page.

and please share functions or show my error so i can solved it.

<
相关标签:
1条回答
  • 2020-12-11 08:38

    To filter orders by meta fields on admin orders list, you will use the following (where you will define in the 1st function below the metakey / label pairs that will filter orders):

    // Custom function where metakeys / labels pairs are defined
    function get_filter_shop_order_meta( $domain = 'woocommerce' ){
        // Add below the metakey / label pairs to filter orders
        return [
            '_billing_company' => __('Billing company', $domain),
            '_order_total'     => __('Gran total', $domain), 
        ];
    }
    
    // Add a dropdown to filter orders by meta
    add_action( 'restrict_manage_posts', 'display_admin_shop_order_by_meta_filter' );
    function display_admin_shop_order_by_meta_filter(){
        global $pagenow, $typenow;
    
        if( 'shop_order' === $typenow && 'edit.php' === $pagenow ) {
            $domain    = 'woocommerce';
            $filter_id = 'filter_shop_order_by_meta';
            $current   = isset($_GET[$filter_id])? $_GET[$filter_id] : '';
    
            echo '<select name="'.$filter_id.'">
            <option value="">' . __('Filter by meta…', $domain) . '</option>';
    
            $options = get_filter_shop_order_meta( $domain );
    
            foreach ( $options as $key => $label ) {
                printf( '<option value="%s"%s>%s</option>', $key, 
                    $key === $current ? '" selected="selected"' : '', $label );
            }
            echo '</select>';
        }
    }
    
    // Process the filter dropdown for orders by Marketing optin
    add_filter( 'request', 'process_admin_shop_order_marketing_by_meta', 99 );
    function process_admin_shop_order_marketing_by_meta( $vars ) {
        global $pagenow, $typenow;
        
        $filter_id = 'filter_shop_order_by_meta';
    
        if ( $pagenow == 'edit.php' && 'shop_order' === $typenow 
        && isset( $_GET[$filter_id] ) && ! empty($_GET[$filter_id]) ) {
            $vars['meta_key']   = $_GET[$filter_id];
            $vars['orderby']    = 'meta_value';
        }
        return $vars;
    }
    
    // (Optional) Make a custom meta field searchable from the admin order list search field
    add_filter( 'woocommerce_shop_order_search_fields', 'shop_order_meta_search_fields', 10, 1 );
    function shop_order_meta_search_fields( $meta_keys ){
        foreach ( get_filter_shop_order_meta() as $meta_key => $label ) {
            $meta_keys[] = $meta_key;
        }
        return $meta_keys;
    }
    

    Code goes in functions.php file of your active child theme (or active theme). Tested and works.

    0 讨论(0)
提交回复
热议问题