Тип користувальницької пошти одно- {custom} .php не працює


19

Я створив тип користувальницького типу з назвою машини special_media_post, а wordpress просто не бачить єдиного-special_media_post.php. Я в цілковитій програші. Він продовжує дефолтувати до index.php

Ось мій код мого користувальницького типу публікації та його таксономій:

//Post and Taxonomy stuff
//Register Custom Post Type
function special_media_post() {
$labels = array(
    'name'                => _x( 'Media Posts', 'Post Type General Name', 'text_domain' ),
    'singular_name'       => _x( 'Media Post', 'Post Type Singular Name', 'text_domain' ),
    'menu_name'           => __( 'Media Post', 'text_domain' ),
    'parent_item_colon'   => __( 'Media Post:', 'text_domain' ),
    'all_items'           => __( 'All Media Posts', 'text_domain' ),
    'view_item'           => __( 'View Media Post', 'text_domain' ),
    'add_new_item'        => __( 'Add New Media Post', 'text_domain' ),
    'add_new'             => __( 'New Media Post', 'text_domain' ),
    'edit_item'           => __( 'Edit Media Post', 'text_domain' ),
    'update_item'         => __( 'Update Media Post', 'text_domain' ),
    'search_items'        => __( 'Search Media Posts', 'text_domain' ),
    'not_found'           => __( 'No media posts found', 'text_domain' ),
    'not_found_in_trash'  => __( 'No media posts found in Trash', 'text_domain' ),
);

$rewrite = array(
    'slug'                => 'mediapost',
    'with_front'          => true,
    'pages'               => true,
    'feeds'               => true,
);

$args = array(
    'label'               => __( 'mediapost', 'text_domain' ),
    'description'         => __( 'Post Type for Media', 'text_domain' ),
    'labels'              => $labels,
    'supports'            => array( 'title', 'editor', 'custom-fields', ),
    'taxonomies'          => array( 'year', 'type' ),
    'hierarchical'        => false,
    '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,
    'query_var'           => 'mediapost',
    'rewrite'             => $rewrite,
    'capability_type'     => 'page',
);

register_post_type( 'special_media_post', $args );
}

// Register Custom Taxonomy
function media_year()  {
$labels = array(
    'name'                       => _x( 'Years', 'Taxonomy General Name', 'text_domain' ),
    'singular_name'              => _x( 'Year', 'Taxonomy Singular Name', 'text_domain' ),
    'menu_name'                  => __( 'Year', 'text_domain' ),
    'all_items'                  => __( 'All Years', 'text_domain' ),
    'parent_item'                => __( 'Parent Year', 'text_domain' ),
    'parent_item_colon'          => __( 'Parent Year:', 'text_domain' ),
    'new_item_name'              => __( 'New Year Name', 'text_domain' ),
    'add_new_item'               => __( 'Add New Year', 'text_domain' ),
    'edit_item'                  => __( 'Edit Year', 'text_domain' ),
    'update_item'                => __( 'Update Year', 'text_domain' ),
    'separate_items_with_commas' => __( 'Separate years with commas', 'text_domain' ),
    'search_items'               => __( 'Search years', 'text_domain' ),
    'add_or_remove_items'        => __( 'Add or remove years', 'text_domain' ),
    'choose_from_most_used'      => __( 'Choose from the most used yearss', 'text_domain' ),
);

$rewrite = array(
    'slug'                       => 'year',
    'with_front'                 => true,
    'hierarchical'               => true,
);

$capabilities = array(
    'manage_terms'               => 'manage_categories',
    'edit_terms'                 => 'manage_categories',
    'delete_terms'               => 'manage_categories',
    'assign_terms'               => 'edit_posts',
);

$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'                  => 'year',
    'rewrite'                    => $rewrite,
    'capabilities'               => $capabilities,
);

register_taxonomy( 'year', 'special_media_post', $args );
}

// Register Custom Taxonomy
function media_type()  {
$labels = array(
    'name'                       => _x( 'Types', 'Taxonomy General Name', 'text_domain' ),
    'singular_name'              => _x( 'Type', 'Taxonomy Singular Name', 'text_domain' ),
    'menu_name'                  => __( 'Type', 'text_domain' ),
    'all_items'                  => __( 'All Types', 'text_domain' ),
    'parent_item'                => __( 'Parent Type', 'text_domain' ),
    'parent_item_colon'          => __( 'Parent Type:', 'text_domain' ),
    'new_item_name'              => __( 'New Type Name', 'text_domain' ),
    'add_new_item'               => __( 'Add New Type', 'text_domain' ),
    'edit_item'                  => __( 'Edit Type', 'text_domain' ),
    'update_item'                => __( 'Update Type', 'text_domain' ),
    'separate_items_with_commas' => __( 'Separate types with commas', 'text_domain' ),
    'search_items'               => __( 'Search types', 'text_domain' ),
    'add_or_remove_items'        => __( 'Add or remove types', 'text_domain' ),
    'choose_from_most_used'      => __( 'Choose from the most used types', 'text_domain' ),
);

$rewrite = array(
    'slug'                       => 'type',
    'with_front'                 => true,
    'hierarchical'               => true,
);

$capabilities = array(
    'manage_terms'               => 'manage_categories',
    'edit_terms'                 => 'manage_categories',
    'delete_terms'               => 'manage_categories',
    'assign_terms'               => 'edit_posts',
);

$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'                  => 'media_type',
    'rewrite'                    => $rewrite,
    'capabilities'               => $capabilities,
);

register_taxonomy( 'type', 'special_media_post', $args );
}

// Hook into the 'init' action
add_action( 'init', 'special_media_post', 0 );

// Hook into the 'init' action
add_action( 'init', 'media_year', 0 );

// Hook into the 'init' action
add_action( 'init', 'media_type', 0 );

Якщо є щось інше, що вам потрібно побачити, я можу це поставити, але він навіть не бачить, якщо я поклав сюди ехо "Hello World". Тож просто не бачити ані єдиного-спеціального_медіа_пост.php, ані архіву-спеціального_медіа_пост.php

Відповіді:


57

Зайдіть на сторінку постійних посилань (яка її змиває) і перевірте ще раз. WordPress, ймовірно, просто потрібно натиснути, щоб визнати ваше доповнення до ієрархії.


2
Оце Так! працює як чарівність, витрачається 1 годину :(
Мохаммед Суфіан

5

Змініть код

Від:

 'has_archive'         => true,

До:

 'has_archive'         => false,

А потім перейдіть на сторінку постійної посилання, змініть її за замовчуванням і поверніться до своєї "досить постійної посилання"

% імені% /

Тепер це має працювати.

Причина, по якій вона не переходить на сторінку єдиного {custom_post_type} .php, пов’язана з has_archive. Якщо параметр has_archive встановлено на true, він шукатиме архів- {custom_post_type} .php замість однієї сторінки.

Сподіваюся, це спрацювало.


1
Я не впевнений, що це правда. Перегляд однієї публікації - це перегляд однієї публікації, підтримує чи тип публікації архівні покази архівів чи ні.
Чіп Беннетт

Це рішення, яке я опублікував, - це те, як я вирішив свою проблему на саморозробленій темі. Коли моя сторінка з єдиним повідомленням тепер показала б, що я хотів побачити.
Веслі Чеун

3
Можливо, що виправлення виходить із скидання структури постійної посилання, що, в свою чергу, змило правила перезапису.
Чіп Беннетт

2
Налаштування "has_archive" не впливає на те, чи підтримується один чи {post_type} .php шаблон для одного запиту.
Жуль

Працює як шарм. Спасибі чувак!
user1202416

1

Доброю практикою також є використання register_activation_hook()та register_deactivation_hook()створення нових типів вмісту.

Здається, що нові нові типи вмісту завжди не вдасться переписати. Щоб цього уникнути, поставте у зворотний виклик register_activation_hook () flush_rewrite_rules()і свою реєстраційну нову функцію вмісту. Я не знаю чому, але, мабуть, це уникне цієї проблеми. Подивіться:

register_activation_hook( __FILE__, 'your_active_hook' );

function your_active_hook() {
    special_media_post();
    flush_rewrite_rules();
}

0

Я скопіював ваш код, очистив правила переписання через Адміністратор, і тепер Тема використовує правильні шаблони, коли я відвідую медіа-пост.

Правила перезапису потрібно змити один раз, використовуючи гачок after_switch_theme. Це забезпечить автоматичне зчитування правил перезапису після активації теми "Тема".

Ви можете використовувати цей код (прямо з Кодексу):

add_action( 'init', 'theme_prefix_cpt_init' );
function theme_prefix_cpt_init() {
    register_post_type( ... );
}

function theme_prefix_rewrite_flush() {
    flush_rewrite_rules();
}
add_action( 'after_switch_theme', 'theme_prefix_rewrite_flush' );

Будь ласка, зверніться до WordPress Codex для отримання додаткової інформації: http://codex.wordpress.org/Function_Reference/register_post_type

EDIT: У такому випадку плагін Inspect Rewrite Rules дуже зручний, тому що він дозволяє бачити правила, підключені до вашого спеціального типу публікації: http://wordpress.org/extend/plugins/rewrite-rules-inspector/

З іншого боку, зверніть увагу, що рекомендованим місцем для розміщення користувальницьких типів публікації є плагін, а не тема.

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.