How to Create a Custom Post Type in a Plugin

Custom post types in WordPress are a handy way to create a new type of post for specific type of information. A custom post type (CPT) provides the ability to organize your WordPress site without creating new categories.  Once a CPT is created there are a few options available to display the post.  For instance, a new page templates can be created or a new shortcode could be made available to display the post information.  In this post we will focus on creating a CPT for members of a roster.

If you are unfamiliar with how to create a plugin you can follow the steps in How to Create a WordPress Plugin. These steps will guide you through the basics of creating a WordPress plugin. For brevity’s sake I am going to keep the basics minimal and only focus on what is needed to create a CPT.

Step 1  Create a plugin folder

Create a new folder in the wp-content\plugins folder called my-cpt-plugin.

Step 2  Create the plugin PHP file

Add a new text file to the my-cpt-plugin folder and name it my-cpt-plugin.php.

Step 3  Add a plugin information header

Now we have to tell WordPress this is a plugin and give it the information it needs to display on the Plugins panel on the WordPress admin page. Open the my-cpt-plugin.php file and add the following text.

1
2
3
4
5
6
7
8
9
10
11
<?php
/*
    Plugin Name: My Custom Post Type Plugin
    Plugin URI: http://www.duhjones.com/
    Description: This is my first Custom Post Type plugin.
    Author: Frank Jones
    Version: 1.0
    Author URI: http://www.duhjones.com/
*/
 
?>

After saving this file you should be able to now see your plugin in the Plugins panel on the WordPress admin page.

Step 4  Add Custom Post Type code

Add the following code just below the information header in the my-cpt-plugin.php file. This code will create a new CPT in WordPress.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
add_action( 'init', 'mycpt_create_member' );
  
 function mycpt_create_member() {
    register_post_type(
        'mycpt_member',
        array(
            'labels' => array(
                'name' => __( 'Roster' ),
                'singular_name' => __('Roster'),
                'add_new_item' => __(''),
                'add_new' => __('Add New Member'),
                'edit_item' => __('Edit Member'),
                'new_item' => __('New Member'),
                'all_items' => __('All Members'),
                'view_item' => __('View Member'),
                'search_items' => __('Search Members'),
                'not_found' => __('No Members found'),
                'not_found_in_trash' => __('No Members found in Trash'),
                'parent_item_colon' => '',
                'menu_name' => 'Roster'
            ),
            'hierarchical' => true,
            'description' => 'Roster members and descriptions',
            'supports' => array('title', 'editor', 'thumbnail', 'custom-fields', 'page-attributes'),
            'public' => true,
            'show_ui' => true,
            'show_in_menu' => true,
            'menu_position' => 25,
            'show_in_nav_menus' => true,
            'publicly_queryable' => true,
            'exclude_from_search' => false,
            'has_archive' => true,
            'query_var' => true,
            'can_export' => true,
            'rewrite' => true,
            'capability_type' => 'post'
        )
    );
}

Instead of explaining each line I will just point out a few highlights. For more information about the various options refer to the WordPress Codex. I have found WordPress does a pretty good job of documenting their functions.

A couple of things to take note on in this code…

line 1  This is the action hook that tells WordPress to run your function right after WordPress initializes, but before everything else.
line 5  This is the name of the CPT as WordPress will know it. This is important later when you want to create a custom taxonomy for you new post type
lines 6-21  These lines define the text that will be displayed at various points in the WordPress admin page for the CPT.
lines 22-36  These lines define different options about the CPT.

I highly recommend checking out the WordPress Codex to explore the various available labels and options.

Step 5  Activate the plugin

Once you activate the plugin you should see a menu option added to the WordPress admin page.

Summary

Now that you have successfully created a new post type there are a plethora of options available to you. You can create a new taxonomy to further customize the post type. You can add a new page template to display your new custom post type. You can also create a shortcode to display information from the new post type.

Leave a Reply