URL-адреса настраиваемых типов сообщений и таксономии WordPress

Я создал собственный тип сообщения и таксономию, чтобы у меня была структура / эпизодов для страницы архива, которая показывала бы все дочерние «термины», / эпизоды / пользовательский термин, чтобы показать архив определенного термина, и / эпизоды / настраиваемый термин / заголовок сообщения для отображения отдельных сообщений.

Я смог получить / Episodes / custom-term, работающий для любого настраиваемого термина, который я создаю. Однако я получаю 404 для / эпизодов, а также 404 для / эпизодов / custom-term / post-title.

В CMS, когда я публикую пост, предполагая, что мой пользовательский термин - «Первый сезон», а заголовок поста - «Образец эпизода». Вы можете перейти в / эпизоды / сезон-один, и он будет использовать шаблон «taxonomy-episode_category.php» для вывода всех сообщений в первом сезоне. При создании поста он также знает, что постоянная ссылка / эпизоды / сезон один / образец-эпизод, однако достигает страницы 404.

Я не уверен, что делать дальше или делаю это неправильно.

function episodes() {

$labels = array(
'name'                => _x( 'Episodes', 'Post Type General Name', 'text_domain' ),
'singular_name'       => _x( 'Episodes', 'Post Type Singular Name', 'text_domain' ),
'menu_name'           => __( 'Episodes', 'text_domain' ),
'parent_item_colon'   => __( 'Parent Item:', 'text_domain' ),
'all_items'           => __( 'All Episodes', 'text_domain' ),
'view_item'           => __( 'View Item', 'text_domain' ),
'add_new_item'        => __( 'Add New Item', 'text_domain' ),
'add_new'             => __( 'Add new episode', 'text_domain' ),
'edit_item'           => __( 'Edit Item', 'text_domain' ),
'update_item'         => __( 'Update Item', 'text_domain' ),
'search_items'        => __( 'Search Item', 'text_domain' ),
'not_found'           => __( 'Not found', 'text_domain' ),
'not_found_in_trash'  => __( 'Not found in Trash', 'text_domain' )
);

$rewrite = array(
'slug'                => 'episodes/%episode_cat%',
'with_front'          => false,
'pages'               => true,
'feeds'               => true
);
$args = array(
'label'               => __( 'episodes', 'text_domain' ),
'description'         => __( 'All episodes', 'text_domain' ),
'labels'              => $labels,
'supports'            => array('title' ),
'hierarchical'        => true,
'public'              => true,
'show_ui'             => true,
'show_in_menu'        => true,
'show_in_nav_menus'   => true,
'show_in_admin_bar'   => true,
'menu_position'       => 5,
'can_export'          => true,
'has_archive'         => true,
'exclude_from_search' => false,
'publicly_queryable'  => true,
'rewrite'             => $rewrite,
'capability_type'     => 'page',
'query_var'           => true,
'_builtin'            => false
);
register_post_type( 'episodes_listing', $args );

}

add_action( 'init', 'episodes', 0 );

function episodes_taxomony() {

 $labels = array(
'name'                       => _x( 'Episodes Categories', 'Taxonomy General Name', 'text_domain' ),
'singular_name'              => _x( 'Episodes', 'Taxonomy Singular Name', 'text_domain' ),
'menu_name'                  => __( 'Episode Categories', 'text_domain' ),
'all_items'                  => __( 'All Items', 'text_domain' ),
'parent_item'                => __( 'Parent Item', 'text_domain' ),
'parent_item_colon'          => __( 'Parent Item:', 'text_domain' ),
'new_item_name'              => __( 'New Item Name', 'text_domain' ),
'add_new_item'               => __( 'Add new episode', 'text_domain' ),
'edit_item'                  => __( 'Edit Item', 'text_domain' ),
'update_item'                => __( 'Update Item', 'text_domain' ),
'separate_items_with_commas' => __( 'Separate items with commas', 'text_domain' ),
'search_items'               => __( 'Search Items', 'text_domain' ),
'add_or_remove_items'        => __( 'Add or remove items', 'text_domain' ),
'choose_from_most_used'      => __( 'Choose from the most used items', 'text_domain' ),
'not_found'                  => __( 'Not Found', 'text_domain' )
);
$rewrite = array(
'slug'                       => 'episodes',
'with_front'                 => false,
'hierarchical'               => true

);
$args = array(
'labels'                     => $labels,
'hierarchical'               => true,
'public'                     => true,
'show_ui'                    => true,
'show_admin_column'          => true,
'show_in_nav_menus'          => true,
'show_tagcloud'              => true,
'query_var'                  => true,
'rewrite'                    => $rewrite
);
register_taxonomy( 'episodes_category', array('episodes_listing'), $args );

}


add_action( 'init', 'episodes_taxomony', 0 );

function filter_post_type_link($link, $post)
{ 
 if ($post->post_type != 'episodes_listing')
  return $link;

 if ($cats = get_the_terms($post->ID, 'episodes_category')) {

  $link = str_replace('%episode_cat%', array_pop($cats)->slug, $link);
  return $link;
 }
}
add_filter('post_type_link', 'filter_post_type_link', 10, 2);

person James    schedule 10.09.2014    source источник
comment
Вы нашли ответ на этот вопрос?   -  person dclawson    schedule 29.06.2015


Ответы (1)


Оказывается, разбивка на страницы работала правильно, когда я установил структуру постоянных ссылок по умолчанию вместо имени сообщения. Чтобы использовать имя сообщения, я смог использовать точный код вместе с новой функцией:

function add_rewrite_rules() { 
  add_rewrite_rule('episodes/(.+?)/page/?([0-9]{1,})/?$', 'index.php', 'top'); 
} 
add_filter('init', 'add_rewrite_rules')
person James    schedule 30.06.2015