Я пытаюсь отсортировать мои столбцы по алфавиту, но когда я использую функцию 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?