在woocommerce管理产品列表中为特定产品属性添加过滤器下拉列表

时间:2019-02-05 05:07:55

标签: woocommerce

在Woocommerce中,在管理产品列表中,我需要为特定属性过滤产品。

基于Add a filter dropdown for product tags in woocommerce admin product list答案代码,我对 pa_proizvoditel产品属性的过滤产品进行了一些更改:

add_action('restrict_manage_posts', 'product_attr_sorting');
function product_attr_sorting() {
    global $typenow;
    $taxonomy  = 'pa_proizvoditel';
    if ( $typenow == 'product' ) {
        $selected      = isset($_GET[$taxonomy]) ? $_GET[$taxonomy] : '';
        $info_taxonomy = get_taxonomy($taxonomy);
        wp_dropdown_categories(array(
            'show_option_all' => __("Attr {$info_taxonomy->label}"),
            'taxonomy'        => $taxonomy,
            'name'            => $taxonomy,
            'orderby'         => 'name',
            'selected'        => $selected,
            'show_count'      => true,
            'hide_empty'      => true,
        ));
    };
}

add_filter('parse_query', 'product_attr_sorting_query');
function product_attr_sorting_query($query) {
    global $pagenow;
    $taxonomy  = 'pa_proizvoditel';
    $q_vars    = &$query->query_vars;
    if ( $pagenow == 'edit.php' && isset($q_vars['post_type']) && $q_vars['post_type'] == 'product' && isset($q_vars[$taxonomy]) && is_numeric($q_vars[$taxonomy]) && $q_vars[$taxonomy] != 0 ) {
        $term = get_term_by('id', $q_vars[$taxonomy], $taxonomy);
        $q_vars[$taxonomy] = $term->slug;
    }
}

但是,当您选择一个值并单击“过滤器”按钮时,页面将更新,但是产品没有被过滤(所有产品的完整列表)。

感谢您对解决此问题的任何帮助。

Спасибозапомощь。 Понялкодраб​​отает(первыйкодпробовалвверсии2.5)наверсияхwoocommerceниже3Воткод,которыйработаетнаверсиивыше3(проверенона3.5+)Янезнаю,вчемдело,ноуменяесть

function filter_proizvoditel_admin_sort( &$query )
{
if ( 
is_admin() 
AND 'edit.php' === $GLOBALS['pagenow']
AND isset( $_GET['pa_proizvoditel'] )
AND '-1' != $_GET['pa_proizvoditel']
)
{
$query->query_vars['tax_query'] = array( array(
     'taxonomy' => 'pa_proizvoditel'
    ,'field'    => 'ID'
    ,'terms'    => array( $_GET['pa_proizvoditel'] )
) );
}
}
add_filter( 'parse_query', 'filter_proizvoditel_admin_sort' );

function filter_proizvoditel_form()
{
$selected      = isset($_GET['pa_proizvoditel']) ? $_GET['pa_proizvoditel'] : '';
wp_dropdown_categories( array(
 'taxonomy'         => 'pa_proizvoditel',
'hide_empty'       => 0,
'name'             => 'pa_proizvoditel',
'show_option_none' => 'Все производители',
    'show_count'      => false,
    'hide_empty'      => true,
    'selected'        => $selected
) );
}
add_action( 'restrict_manage_posts', 'filter_proizvoditel_form', 25 );

2 个答案:

答案 0 :(得分:0)

我已经测试了您的版本代码,它适用于任何已定义的产品属性分类法。现在有一些未成年人的错误,例如parse_query钩子是动作钩子(而不是过滤器钩子)

例如,我在下面重新访问的代码中使用产品属性分类法pa_color

add_action('restrict_manage_posts', 'product_attribute_sorting_dropdown');
function product_attribute_sorting_dropdown() {
    global $typenow;
    $taxonomy  = 'pa_color';
    if ( $typenow == 'product' ) {
        $selected      = isset($_GET[$taxonomy]) ? $_GET[$taxonomy] : '';
        $info_taxonomy = get_taxonomy($taxonomy);
        wp_dropdown_categories(array(
            'show_option_all' => __("Attribute {$info_taxonomy->label}"),
            'taxonomy'        => $taxonomy,
            'name'            => $taxonomy,
            'orderby'         => 'name',
            'selected'        => $selected,
            'show_count'      => true,
            'hide_empty'      => true,
        ));
    };
}

add_action('parse_query', 'product_attribute_sorting_query');
function product_attribute_sorting_query( $query ) {
    global $pagenow;
    $taxonomy  = 'pa_color';
    $q_vars    = &$query->query_vars;
    if ( $pagenow == 'edit.php' && isset($q_vars['post_type']) && $q_vars['post_type'] == 'product' && isset($q_vars[$taxonomy]) && is_numeric($q_vars[$taxonomy]) && $q_vars[$taxonomy] != 0 ) {
        $term = get_term_by('id', $q_vars[$taxonomy], $taxonomy);
        $q_vars[$taxonomy] = $term->slug;
    }
}

代码进入您的活动子主题(或活动主题)的function.php文件中。经过测试并可以在Woocommerce 3+版本(肯定)上工作。

我得到以下产品属性下拉列表:

enter image description here

然后,当我使用 blue (5) 进行过滤时,我得到了正确数量的过滤产品:

enter image description here

相关:Add a filter dropdown for product tags in woocommerce admin product list

答案 1 :(得分:0)

我稍微更改了您的代码,现在可以 100%。

我的产品属性标签为“ dobavitelj_xml”,但您必须附加“ pa _ ”,因此我的分类标签为“ pa_dobavitelj_xml”。

add_action('restrict_manage_posts', 'product_attribute_sorting_dropdown');
function product_attribute_sorting_dropdown() {
    global $typenow;
    $taxonomy  = 'pa_dobavitelj_xml';
    if ( $typenow == 'product' ) {
        $selected      = isset($_GET[$taxonomy]) ? $_GET[$taxonomy] : '';
        $info_taxonomy = get_taxonomy($taxonomy);
        
        wp_dropdown_categories(array(
            'show_option_all' => __("{$info_taxonomy->labels->name}"),
            'taxonomy'        => $taxonomy,
            'name'            => $taxonomy,
            'orderby'         => 'name',
            'selected'        => $selected,
            'show_count'      => true,
            'hide_empty'      => false,
        ));
    };
}

add_action('parse_query', 'product_attribute_sorting_query');
function product_attribute_sorting_query( $query ) {
    global $pagenow;
    $taxonomy  = 'pa_dobavitelj_xml';
    $q_vars    = &$query->query_vars;

if ( $pagenow == 'edit.php' && isset($q_vars['post_type']) && $q_vars['post_type'] == 'product' && isset($_GET[$taxonomy]) && is_numeric($_GET[$taxonomy]) && $_GET[$taxonomy] != 0) {
        
        $tax_query = (array) $query->get('tax_query');
        $term = get_term_by('id', $_GET[$taxonomy], $taxonomy);

        $tax_query[] = array(
               'taxonomy' => $taxonomy,
               'field' => 'slug',
               'terms' => array($term->slug), 
               'operator' => 'AND'
        );
    
        $query->set( 'tax_query', $tax_query );
    }
}