Как получить рубрики кастомных записей в WordPress

Как получить рубрики кастомных записей в WordPress

В вордпрессе часто приходится работать с кастомными записями — их делают как сами вэбмастера для удобства, так и различные плагины. Это очень удобно, так как типы записей по умолчанию ориентированы на блог, а если нужно что-то посерьезней, то без кастомных типов не обойтись.

Самым ярким примером может быть портфолио. Например фирма делает каркасные дома, и для владельца сайта было бы намного удобней, понятней добавлять в систему объект «Дом» у которого есть привычные ему свойства (например стоимость, срок строительства, изображение), а не объект типа «Запись»

Итак, регистрируем в плагине или в functions.php новый тип записи при помощи

function custom_post_type_faq() {

	$labels = array(
		'name'                  => _x( 'Полезно знать', 'Post Type General Name', 'text_domain' ),
		'singular_name'         => _x( 'Полезно знать', 'Post Type Singular Name', 'text_domain' ),
		'menu_name'             => __( 'Статьи / Полезно знать', 'text_domain' ),
		'name_admin_bar'        => __( 'Post Type', 'text_domain' ),
		'archives'              => __( 'Item Archives', 'text_domain' ),
		'attributes'            => __( 'Item Attributes', 'text_domain' ),
		'parent_item_colon'     => __( 'Parent Item:', 'text_domain' ),
		'all_items'             => __( 'Все статьи', 'text_domain' ),
		'add_new_item'          => __( 'Добавить статью', 'text_domain' ),
		'add_new'               => __( 'Добавить статью', 'text_domain' ),
		'new_item'              => __( 'Добавить статью', 'text_domain' ),
		'edit_item'             => __( 'Edit Item', 'text_domain' ),
		'update_item'           => __( 'Update Item', 'text_domain' ),
		'view_item'             => __( 'View Item', 'text_domain' ),
		'view_items'            => __( 'View Items', 'text_domain' ),
		'search_items'          => __( 'Search Item', 'text_domain' ),
		'not_found'             => __( 'Not found', 'text_domain' ),
		'not_found_in_trash'    => __( 'Not found in Trash', 'text_domain' ),
		'featured_image'        => __( 'Featured Image', 'text_domain' ),
		'set_featured_image'    => __( 'Set featured image', 'text_domain' ),
		'remove_featured_image' => __( 'Remove featured image', 'text_domain' ),
		'use_featured_image'    => __( 'Use as featured image', 'text_domain' ),
		'insert_into_item'      => __( 'Insert into item', 'text_domain' ),
		'uploaded_to_this_item' => __( 'Uploaded to this item', 'text_domain' ),
		'items_list'            => __( 'Items list', 'text_domain' ),
		'items_list_navigation' => __( 'Items list navigation', 'text_domain' ),
		'filter_items_list'     => __( 'Filter items list', 'text_domain' ),
	);
	$args = array(
		'label'                 => __( 'faq', 'text_domain' ),
		'description'           => __( 'faqPost Type Description', 'text_domain' ),
		'labels'                => $labels,
		'supports'              => array( ),
		'taxonomies'            => array('faq-cats'),
		'hierarchical'          => false,
		'public'                => true,
		'show_ui'               => true,
		'show_in_menu'          => true,
		'menu_position'         => 5,
		'show_in_admin_bar'     => true,
		'show_in_nav_menus'     => true,
		'can_export'            => true,
		'has_archive'           => true,
		'exclude_from_search'   => false,
		'publicly_queryable'    => true,
		'capability_type'       => 'post',
	);
	register_post_type( 'faq', $args );

}
add_action( 'init', 'custom_post_type_faq', 0 );

Зарегистрировали. Теперь добавляем новую таксономию

add_action( 'init', 'create_taxonomy',99 );
function create_taxonomy(){

	// список параметров: wp-kama.ru/function/get_taxonomy_labels
	register_taxonomy( 'faq-cats', [ 'faq' ], [ 
		'label'                 => '', // определяется параметром $labels->name
		'labels'                => [
			'name'              => 'Рубрики faq',
			'singular_name'     => 'Рубрика faq',
			'search_items'      => 'Search Genres',
			'all_items'         => 'Все рубрики faq',
			'view_item '        => 'Смотреть рубрики faq',
			'parent_item'       => 'Родительская рубрика',
			'parent_item_colon' => 'Родительская рубрика:',
			'edit_item'         => 'Редактировать рубрику',
			'update_item'       => 'Обновить рубрику',
			'add_new_item'      => 'Добавить новую рубрику',
			'new_item_name'     => 'Имя новой рубрики',
			'menu_name'         => 'Рубрики Faq',
		],
		'description'           => '', // описание таксономии
		'public'                => true,
		// 'publicly_queryable'    => null, // равен аргументу public
		'show_in_nav_menus'     => true, // равен аргументу public
		// 'show_ui'               => true, // равен аргументу public
		// 'show_in_menu'          => true, // равен аргументу show_ui
		// 'show_tagcloud'         => true, // равен аргументу show_ui
		// 'show_in_quick_edit'    => null, // равен аргументу show_ui
		'hierarchical'          => true,

		'rewrite'               => true,
		//'query_var'             => $taxonomy, // название параметра запроса
		'capabilities'          => array(),
		'meta_box_cb'           => null, // html метабокса. callback: `post_categories_meta_box` или `post_tags_meta_box`. false — метабокс отключен.
		'show_admin_column'     => true, // авто-создание колонки таксы в таблице ассоциированного типа записи. (с версии 3.5)
		'show_in_rest'          => null, // добавить в REST API
		'rest_base'             => null, // $taxonomy
		// '_builtin'              => false,
		//'update_count_callback' => '_update_post_term_count',
	] );
}

Теперь можно создавать новые рубрики новых записей и затем в цикле WordPress получить их так:

$terms = get_the_terms($post->ID,’taxonomy’);

Евгений

Яндекс.Метрика