Список заказов администратора фильтра WooCommerce на основе добавленного настраиваемого поля заголовка - PullRequest
1 голос
/ 01 апреля 2019

В WooCommerce я добавил новый пользовательский столбец «Язык» в список заказов администратора с пользовательскими значениями «Японский» или «Не японский».

Как добавить параметр фильтра для японского и неяпонского языков.

enter image description here

Я добавил раскрывающийся список фильтров, используя следующий код:

add_action( 'restrict_manage_posts', 'wpse45436_admin_posts_filter_restrict_manage_posts' );
function wpse45436_admin_posts_filter_restrict_manage_posts(){
    global $post_type;
    if( $post_type == 'shop_order' ) {
        //change this to the list of values you want to show
        //in 'label' => 'value' format
        $values = array(
            'Japanese' => 'Japanese', 
            'Non Japanese' => 'Non Japanese',
        );
        ?>
        <select name="ADMIN_FILTER_FIELD_VALUE">
        <option value=""><?php _e('Filter By ', 'wose45436'); ?></option>
        <?php
            $current_v = isset($_GET['ADMIN_FILTER_FIELD_VALUE'])? $_GET['ADMIN_FILTER_FIELD_VALUE']:'';
            foreach ($values as $label => $value) {
                printf (
                    '<option value="%s"%s>%s</option>',
                    $value,
                    $value == $current_v? ' selected="selected"':'',
                    $label
                );
            }
        ?>
        </select>
        <?php
    }
}

Я также добавил код для фильтрации списка заказов, но он не работает, вот мой код:

add_action( 'pre_get_posts', 'apply_my_custom_product_filters' );
function apply_my_custom_product_filters( $query ) {

    global $pagenow;
    $paged = (get_query_var('paged')) ? get_query_var('paged') : 1; 
    if ( $query->is_admin && $pagenow == 'edit.php' && isset( $_GET['ADMIN_FILTER_FIELD_VALUE'] ) && $_GET['ADMIN_FILTER_FIELD_VALUE'] != '' && $_GET['post_type'] == 'shop_order' ) {

       $meta_key_query = array(
          array(
              'meta_key'     => 'order_add_language',
              'value'   => esc_attr( $_GET['ADMIN_FILTER_FIELD_VALUE'] ),
              'compare' => '=',
          ),
          'posts_per_page' => 10,
          'paged' => $paged,
      );

      $query->set( 'meta_query', $meta_key_query );
    }
}

Ответы [ 2 ]

0 голосов
/ 01 апреля 2019

В вашем коде есть ошибки… Попробуйте следующий пересмотренный код:

add_action( 'restrict_manage_posts', 'display_admin_shop_order_language_filter' );
function display_admin_shop_order_language_filter(){
    global $pagenow, $post_type;

    if( 'shop_order' === $post_type && 'edit.php' === $pagenow ) {
        $domain    = 'woocommerce';
        $languages = array( __('Japanese', $domain) => __('Non Japanese', $domain) );
        $current   = isset($_GET['filter_shop_order_language'])? $_GET['filter_shop_order_language'] : ''

        echo '<select name="filter_shop_order_language">
        <option value="">' . __('Filter By ', $domain) . '</option>';

        foreach ( $languages as $value ) {
            printf( '<option value="%s"%s>%s</option>', $value, 
                $value === $current ? '" selected="selected"' : '', $value );
        }
        echo '</select>';
    }
}

add_action( 'pre_get_posts', 'process_admin_shop_order_language_filter' );
function process_admin_shop_order_language_filter( $query ) {
    global $pagenow;

    if ( $query->is_admin && $pagenow == 'edit.php' && isset( $_GET['filter_shop_order_language'] ) 
        && $_GET['filter_shop_order_language'] != '' && $_GET['post_type'] == 'shop_order' ) {

        $meta_query = $query->get( 'meta_query' ); // Get the current "meta query"

        $meta_query[] = array( // Add to "meta query"
            'meta_key' => 'order_add_language',
            'value'    => esc_attr( $_GET['filter_shop_order_language'] ),
        );
        $query->set( 'meta_query', $meta_query ); // Set the new "meta query"

        $query->set( 'posts_per_page', 10 ); // Set "posts per page"

        $query->set( 'paged', ( get_query_var('paged') ? get_query_var('paged') : 1 ) ); // Set "paged"
    }
}

Код находится в файле function.php вашей активной дочерней темы (или активной темы).Должно работать.

0 голосов
/ 01 апреля 2019

Это неправильно в вашем meta_key_query. Вы можете попробовать этот код.

add_action( 'pre_get_posts', 'apply_my_custom_product_filters' );
function apply_my_custom_product_filters( $query ) {

    global $pagenow;
    $paged = (get_query_var('paged')) ? get_query_var('paged') : 1; 
    if ( $query->is_admin && $pagenow == 'edit.php' && isset( $_GET['ADMIN_FILTER_FIELD_VALUE'] ) && $_GET['ADMIN_FILTER_FIELD_VALUE'] != '' && $_GET['post_type'] == 'shop_order' ) {

      $meta_key_query = array(
        array(
          'meta_key'     => 'order_add_language',
          'value'   => esc_attr( $_GET['ADMIN_FILTER_FIELD_VALUE'] ),
        )
      );
      $query->set( 'meta_query', $meta_key_query );

    }

}
...