Unregisters a post type.
Description
Cannot be used to unregister built-in post types.
Parameters
$post_typestringrequired- Post type to unregister.
Source
function unregister_post_type( $post_type ) {
global $wp_post_types;
if ( ! post_type_exists( $post_type ) ) {
return new WP_Error( 'invalid_post_type', __( 'Invalid post type.' ) );
}
$post_type_object = get_post_type_object( $post_type );
// Do not allow unregistering internal post types.
if ( $post_type_object->_builtin ) {
return new WP_Error( 'invalid_post_type', __( 'Unregistering a built-in post type is not allowed' ) );
}
$post_type_object->remove_supports();
$post_type_object->remove_rewrite_rules();
$post_type_object->unregister_meta_boxes();
$post_type_object->remove_hooks();
$post_type_object->unregister_taxonomies();
unset( $wp_post_types[ $post_type ] );
/**
* Fires after a post type was unregistered.
*
* @since 4.5.0
*
* @param string $post_type Post type key.
*/
do_action( 'unregistered_post_type', $post_type );
return true;
}
Hooks
- do_action( ‘unregistered_post_type’,
string $post_type ) Fires after a post type was unregistered.
Changelog
| Version | Description |
|---|---|
| 4.5.0 | Introduced. |
Unregister the Custom Post Type simple example:
Disable announcement CPT if it is not main site.
Unregister or Disable One or More Custom Post Types with Clean and Optimized Code
function disable_oraiste_custom_post_types() {
$post_types = [‘clients’, ‘portfolio’, ‘team’, ‘testimonial’];
foreach ($post_types as $post_type) {
if (post_type_exists($post_type)) {
unregister_post_type($post_type);
}
}
}
add_action(‘init’, ‘disable_oraiste_custom_post_types’, 20);
From WordPress Uninstall Method document ( https://developer.wordpress.org/plugins/plugin-basics/uninstall-methods/ ), they recommend you to remove data (including options, tables) from DB.
So, unregister custom post type should be called on uninstall method.
Here is example:
‘cpt_customposttype’,
‘numberposts’ => -1,
];
$posts = new WP_Query($args);
while ($posts->have_posts()) {
$posts->the_post();
wp_delete_post(get_the_ID() , true);
}
// unregister custom post type
unregister_post_type(‘cpt_customposttype’);
// flush rewrite rules.
flush_rewrite_rules() ;
}
register_uninstall_hook(__FILE__, ‘cpt_uninstall’);
?>
By default, `unregister_post_type() ` will not flush rewrite rules, will not delete existing posts of its type.
The example above do it all.