У меня есть пользовательский тип постов Products в моем проекте WordPress. CPT имеет несколько пользовательских полей и две таксономии, которые могут быть прикреплены к нему. Я могу добавлять / редактировать / удалять все это в админке WordPress без проблем.
Моя проблема, с которой я сейчас борюсь, - это отображение пользовательских типов сообщений в передней части. Если я зайду в раздел администрирования РЕДАКТИРОВАТЬ ПРОДУКТ, я вижу Постоянную ссылку для каждого отдельного продукта (я даже вижу ссылки для каждой таксономии), но при щелчке по ним появляется 404.
Я бы хотел иметь возможность напрямую ссылаться на продукты (например, http://localhost:8888/project/product/productname/), как это показано на странице «Редактировать CPT»). Я также хотел бы перечислить продукты, если они выбирают только таксономии для этих продуктов. Надеюсь, что это имеет смысл.
Есть ли способ сделать это без необходимости создавать страницы для каждой таксономии и продукта? Я впервые показываю CPT (любые сообщения на этот счет), поэтому у меня возникают проблемы, когда я оборачиваюсь вокруг него. Нужно ли мне создавать страницы для них?
Спасибо!
Вот мой тип сообщения:
/* CUSTOM POST TYPE AREA FOR PRODUCTS */
add_action( 'init', 'create_product_post_type' );
function create_product_post_type()
{
$labels = array(
'name' => _x('Products', 'post type general name'),
'singular_name' => _x('Product', 'post type singular name'),
'add_new' => _x('Add New', 'products'),
'add_new_item' => __('Add New Product'),
'edit_item' => __('Edit Product'),
'new_item' => __('New Product'),
'view_item' => __('View Product'),
'search_item' => __('Search Products'),
'not_found' => __('No products found'),
'not_found_in_trash' => __('No products found in Trash'),
'parent_item_colon' => '',
'menu_name' => 'Products'
);
$args = array(
'label' => __('Products'),
'labels' => $labels,
'public' => true,
'can_export' => true,
'show_ui' => true,
'_builtin' => false,
'capability_type' => 'post',
'menu_icon' => get_bloginfo('template_url').'/functions/images/product.png',
'hierarchical' => false,
//'rewrite' => array( "slug" => "product" ),
'supports' => array('title'), //MAYBE add thumbnail later!
'show_in_nav_menus' => true
);
register_post_type( 'products', $args);
}
//*********************************************************************//
//**************Custom Taxonomy for Products***************************//
//*********************************************************************//
/* CUSTOM TAXONOMY FOR PRODUCTS POST */
function create_productcategory_taxonomy() {
$labels = array(
'name' => _x( 'Categories', 'taxonomy general name' ),
'singular_name' =>_x( 'Category', 'taxonomy singular name' ),
'search_items' => __( 'Search Categories' ),
'popular_items' => __( 'Popular Categories' ),
'all_items' => __( 'All Categories' ),
'parent_item' => null,
'parent_item_colon' => null,
'edit_item' => __( 'Edit Product Category' ),
'update_item' => __( 'Update Product Category' ),
'add_new_item' => __( 'Add New Product Category' ),
'new_item_name' => __( 'New Product Category' ),
'separate_items_with_commas' => __( 'Separate categories with commas' ),
'add_or_remove_items' => __( 'Add or remove product categories' ),
'choose_from_most_used' => __( 'Choose from the most used categories' )
);
register_taxonomy('productcategory', 'products', array (
'label' => __('Product Category'),
'labels' => $labels,
'hierarchical' => true,
'show_ui' => true,
'query_var' => true,
'rewrite' => array( 'slug' => 'product-category'),
));
}
function create_product_type_taxonomy() {
$labels = array(
'name' => _x( 'Types', 'taxonomy general name' ),
'singular_name' =>_x( 'Type', 'taxonomy singular name' ),
'search_items' => __( 'Search Types' ),
'popular_items' => __( 'Popular Types' ),
'all_items' => __( 'All Types' ),
'parent_item' => null,
'parent_item_colon' => null,
'edit_item' => __( 'Edit Product Type' ),
'update_item' => __( 'Update Product Type' ),
'add_new_item' => __( 'Add New Product Type' ),
'new_item_name' => __( 'New Product Type' ),
'menu_name' => __( 'Types' )
);
register_taxonomy('producttype', 'products', array (
'label' => __('Product Type'),
'labels' => $labels,
'hierarchical' => true,
'show_ui' => true,
'query_var' => true,
'rewrite' => array( 'slug' => 'product-type'),
));
}
add_action( 'init', 'create_productcategory_taxonomy', 0 );
add_action( 'init', 'create_product_type_taxonomy', 0 );