【发布时间】:2020-10-15 04:29:27
【问题描述】:
我想将带有特定产品标签的订单分配给后端的特定商店经理并隐藏其余订单。
我目前正在使用Order Splitter for WooCommerce 免费插件将订单按项目(产品)拆分为单独的订单。
我发现了一个非常好的解决方案,可以使用产品类型来过滤订单:Filter orders by product post type in WooCommerce admin orders list page,我尝试对其进行编辑以仅显示特定的产品标签,但是没有成功。我做错了什么?
产品标签名为“brand1”,店长账号ID为7。
add_action( 'restrict_manage_posts', 'admin_shop_order_by_product_type_filter' );
function admin_shop_order_by_product_type_filter(){
global $pagenow, $post_type;
$whoisin = get_current_user_id();
if( 'shop_order' === $post_type && 'edit.php' === $pagenow && ($whoisin == 7) ) {
$domain = 'woocommerce';
$filter_id = 'brand1';
$current = isset($_GET[$filter_id])? $_GET[$filter_id] : '';
$query_args = ['taxonomy' => 'product_tag', 'fields' => 'names', 'orderby' => 'order'];
echo '<select name="'.$filter_id.'">
<option value="">' . __('Filter by Product Tag', $domain) . '</option>';
foreach ( get_terms($query_args) as $term_name ) {
printf( '<option value="%s"%s>%s</option>', $term_name,
$term_name === $current ? '" selected="selected"' : '', ucfirst($term_name) );
}
echo '</select>';
}
}
add_action( 'pre_get_posts','process_admin_shop_order_product_type_filter' );
function process_admin_shop_order_product_type_filter( $query ) {
global $pagenow, $post_type, $wpdb;
$filter_id = 'brand1';
$whoisin = get_current_user_id();
if ( $query->is_admin && 'edit.php' === $pagenow && 'shop_order' === $post_type
&& isset( $_GET[$filter_id] ) && $_GET[$filter_id] != '' && ($whoisin == 7)) {
$order_ids = $wpdb->get_col( "
SELECT DISTINCT o.ID
FROM {$wpdb->prefix}posts o
INNER JOIN {$wpdb->prefix}woocommerce_order_items oi
ON oi.order_id = o.ID
INNER JOIN {$wpdb->prefix}woocommerce_order_itemmeta oim
ON oi.order_item_id = oim.order_item_id
INNER JOIN {$wpdb->prefix}term_relationships tr
ON oim.meta_value = tr.object_id
INNER JOIN {$wpdb->prefix}term_taxonomy tt
ON tr.term_taxonomy_id = tt.term_taxonomy_id
INNER JOIN {$wpdb->prefix}terms t
ON tt.term_id = t.term_id
WHERE o.post_type = '$post_type'
AND oim.meta_key = '_product_id'
AND tt.taxonomy = 'product_tag'
AND t.name = '{$_GET[$filter_id]}'
");
$query->set( 'post__in', $order_ids ); // Set the new "meta query"
$query->set( 'posts_per_page', 25 ); // Set "posts per page"
$query->set( 'paged', ( get_query_var('paged') ? get_query_var('paged') : 1 ) ); // Set "paged"
}
}
【问题讨论】:
-
原始代码有 2 个函数...在您的代码中只有一个函数可以合并所有内容,所以这是主要问题...尝试先重新编写代码并更新您的问题,如果有的话…
-
哦!刚看到,谢谢!第二个函数被推到代码窗口的末尾。好吧,基本上我怎样才能在后端显示带有特定产品标签的产品订单给特定的用户ID,同时隐藏所有其他带有不同产品标签的订单?
-
你用什么插件来拆分订单?请在您的问题中添加插件名称和链接......当订单被拆分为子订单以对每个订单进行分配时,最好使用现有的挂钩(来自该插件)。
-
@LoicTheAztec 谢谢,我很感激。该插件称为 Woo Order Spliter [链接] (wordpress.org/plugins/woo-order-splitter)。我刚刚编辑了问题并添加了指向插件的链接。
标签: php woocommerce orders userid taxonomy-terms