Сортировка основных ACF в столбце админ. - PullRequest
0 голосов
/ 11 января 2019

Я пытаюсь отсортировать мои столбцы по алфавиту, но когда я использую функцию pre_get_posts (), это нарушает работу сайта. Я предполагаю, что это потому, что ACF, который я использую, представляет собой просто двухбуквенное текстовое поле, и я не знаю, как ссылаться на это в функции

    function get_geoCode($post_ID) {
    $geoCode = the_field('geo_code');
    if ($geoCode) {
        return $geoCode;
   }
}
function geo_row($defaults) {
    $defaults['geo_col'] = 'Geo Code';
    return $defaults;
}

function geo_row_content($column_name, $post_ID) {
    if ($column_name == 'geo_col') {
        $geo_code_id = get_geoCode($post_ID);
        if ($geo_code_id) {
            echo  $geo_code_id;
         }
     }
}


// CALL THE ABOVE FUNCTIONS +  FILTERS
add_filter('manage_page_posts_columns', 'geo_row', 10);
 add_filter('manage_edit-page_sortable_columns', 'geo_columns');

function geo_columns( $columns ) {
   $columns['geo_col'] = 'Geo Code';

   //To make a column 'un-sortable' remove it from the array
    //unset($columns['date']);

    return $columns;
}

add_action('manage_page_posts_custom_column', 'geo_row_content', 10, 2);

 add_action( 'pre_get_posts', 'geoCol_orderby' );
function geoCol_orderby( $query ) {
    if( ! is_admin() )
          return;

    $orderby = $query->get( 'orderby');

    if( 'Geo Code' == $orderby ) {
        $query->set('meta_key','geo_col');
        $query->set('orderby','meta_value_num');
    }
}

Таким образом, столбец отображается с текстовым значением ACF, но сортируется по алфавиту. Если я активирую функцию pre_get_posts, она ломает сайт

Есть идеи, как получить алфавитное значение из текстового поля ACF?

...