Exemple #1
0
/**
 * Converts post type between original and newly renamed.
 *
 * @since 1.1.0
 *
 * @param string $original_slug Original post type slug.
 * @param string $new_slug      New post type slug.
 */
function cptui_convert_post_type_posts($original_slug = '', $new_slug = '')
{
    $args = array('posts_per_page' => -1, 'post_type' => $original_slug);
    $convert = new WP_Query($args);
    if ($convert->have_posts()) {
        while ($convert->have_posts()) {
            $convert->the_post();
            set_post_type(get_the_ID(), $new_slug);
        }
    }
    cptui_delete_post_type($original_slug);
}
Exemple #2
0
/**
 * Create our settings page output.
 *
 * @since 1.0.0
 *
 * @return string HTML output for the page.
 */
function cptui_manage_post_types()
{
    if (!empty($_POST)) {
        if (isset($_POST['cpt_submit'])) {
            check_admin_referer('cptui_addedit_post_type_nonce_action', 'cptui_addedit_post_type_nonce_field');
            $notice = cptui_update_post_type($_POST);
        } elseif (isset($_POST['cpt_delete'])) {
            check_admin_referer('cptui_addedit_post_type_nonce_action', 'cptui_addedit_post_type_nonce_field');
            $notice = cptui_delete_post_type($_POST);
        }
    }
    $tab = !empty($_GET) && !empty($_GET['action']) && 'edit' == $_GET['action'] ? 'edit' : 'new';
    ?>

	<div class="wrap">

	<?php 
    if (isset($notice)) {
        echo $notice;
    }
    cptui_settings_tab_menu();
    if ('edit' == $tab) {
        $post_types = get_option('cptui_post_types');
        $selected_post_type = cptui_get_current_post_type();
        if ($selected_post_type) {
            if (array_key_exists($selected_post_type, $post_types)) {
                $current = $post_types[$selected_post_type];
            }
        }
    }
    $ui = new cptui_admin_ui();
    # Will only be set if we're already on the edit screen
    if (!empty($post_types)) {
        ?>
		<form id="cptui_select_post_type" method="post">
			<p><?php 
        _e('Select a post type to edit. DO NOT EDIT the post type slug unless necessary. Changing that value registers a new post type entry for your install.', 'cpt-plugin');
        ?>
</p>
			<?php 
        cptui_post_types_dropdown($post_types);
        ?>
			<input type="submit" class="button-secondary" name="cptui_select_post_type_submit" value="<?php 
        echo esc_attr(apply_filters('cptui_post_type_submit_select', __('Select', 'cpt-plugin')));
        ?>
" />
		</form>
	<?php 
    }
    ?>

	<form method="post">
		<table class="form-table cptui-table">
			<tr>
				<td><!--LEFT SIDE-->
					<table>
						<?php 
    /*
     * Post Slug
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'name', 'textvalue' => isset($current['name']) ? esc_attr($current['name']) : '', 'maxlength' => '20', 'onblur' => 'this.value=this.value.toLowerCase()', 'labeltext' => __('Post Type Slug', 'cpt-plugin'), 'aftertext' => __('(e.g. movie)', 'cpt-plugin'), 'helptext' => esc_attr__('The post type name. Used to retrieve custom post type content. Should be short and unique', 'cpt-plugin'), 'required' => true));
    /*
     * Post Label
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'label', 'textvalue' => isset($current['label']) ? esc_attr($current['label']) : '', 'labeltext' => __('Plural Label', 'cpt-plugin'), 'aftertext' => __('(e.g. Movies)', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin')));
    /*
     * Post Singular Slug
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'singular_label', 'textvalue' => isset($current['singular_label']) ? esc_attr($current['singular_label']) : '', 'labeltext' => __('Singular Label', 'cpt-plugin'), 'aftertext' => __('(e.g. Movie)', 'cpt-plugin'), 'helptext' => esc_attr__('Custom Post Type Singular label. Used in WordPress when a singular label is needed.', 'cpt-plugin')));
    /*
     * Post Description
     */
    if (isset($current['description'])) {
        $current['description'] = stripslashes_deep($current['description']);
    }
    echo $ui->get_textarea_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'description', 'rows' => '4', 'cols' => '40', 'textvalue' => isset($current['description']) ? esc_textarea($current['description']) : '', 'labeltext' => __('Description', 'cpt-plugin'), 'helptext' => esc_attr__('Custom Post Type Description. Describe what your custom post type is used for.', 'cpt-plugin')));
    ?>
					</table>
				<p class="submit">
					<?php 
    wp_nonce_field('cptui_addedit_post_type_nonce_action', 'cptui_addedit_post_type_nonce_field');
    if (!empty($_GET) && !empty($_GET['action']) && 'edit' == $_GET['action']) {
        ?>
						<input type="submit" class="button-primary" name="cpt_submit" value="<?php 
        echo esc_attr(apply_filters('cptui_post_type_submit_edit', __('Edit Post Type', 'cpt-plugin')));
        ?>
" />
						<input type="submit" class="button-secondary" name="cpt_delete" id="cpt_submit_delete" value="<?php 
        echo esc_attr(apply_filters('cptui_post_type_submit_delete', __('Delete Post Type', 'cpt-plugin')));
        ?>
" />
					<?php 
    } else {
        ?>
						<input type="submit" class="button-primary" name="cpt_submit" value="<?php 
        echo esc_attr(apply_filters('cptui_post_type_submit_add', __('Add Post Type', 'cpt-plugin')));
        ?>
" />
					<?php 
    }
    ?>
					<input type="hidden" name="cpt_type_status" id="cpt_type_status" value="<?php 
    echo $tab;
    ?>
" />
				</p>
			</td>
			<td>
				<p> <?php 
    _e('Click headings to reveal available options.', 'cpt-plugin');
    ?>
</p>

				<div id="cptui_accordion">
					<h3 title="<?php 
    esc_attr_e('Click to expand', 'cpt-plugin');
    ?>
"><?php 
    _e('Labels', 'cpt-plugin');
    ?>
</h3>
						<div>
							<table>
							<?php 
    /*
     * Post Admin Menu Name
     */
    echo $ui->get_text_input(array('labeltext' => __('Menu Name', 'cpt-plugin'), 'helptext' => esc_attr__('Custom menu name for your custom post type.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'menu_name', 'textvalue' => isset($current['labels']['menu_name']) ? esc_attr($current['labels']['menu_name']) : '', 'aftertext' => __('(e.g. My Movies)', 'cpt-plugin')));
    /*
     * Post All Items
     */
    echo $ui->get_text_input(array('labeltext' => __('All Items', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'all_items', 'textvalue' => isset($current['labels']['all_items']) ? esc_attr($current['labels']['all_items']) : '', 'aftertext' => __('(e.g. All Movies)', 'cpt-plugin')));
    /*
     * Add New Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Add New', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'add_new', 'textvalue' => isset($current['labels']['add_new']) ? esc_attr($current['labels']['add_new']) : '', 'aftertext' => __('(e.g. Add New)', 'cpt-plugin')));
    /*
     * Add New Item Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Add New Item', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'add_new_item', 'textvalue' => isset($current['labels']['add_new_item']) ? esc_attr($current['labels']['add_new_item']) : '', 'aftertext' => __('(e.g. Add New Movie)', 'cpt-plugin')));
    /*
     * Edit Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Edit', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'edit', 'textvalue' => isset($current['labels']['edit']) ? esc_attr($current['labels']['edit']) : '', 'aftertext' => __('(e.g. Edit)', 'cpt-plugin')));
    /*
     * Edit Item Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Edit Item', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'edit_item', 'textvalue' => isset($current['labels']['edit_item']) ? esc_attr($current['labels']['edit_item']) : '', 'aftertext' => __('(e.g. Edit Movie)', 'cpt-plugin')));
    /*
     * New Item Label
     */
    echo $ui->get_text_input(array('labeltext' => __('New Item', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'new_item', 'textvalue' => isset($current['labels']['new_item']) ? esc_attr($current['labels']['new_item']) : '', 'aftertext' => __('(e.g. New Movie)', 'cpt-plugin')));
    /*
     * View Label
     */
    echo $ui->get_text_input(array('labeltext' => __('View', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'view', 'textvalue' => isset($current['labels']['view']) ? esc_attr($current['labels']['view']) : '', 'aftertext' => __('(e.g. View)', 'cpt-plugin')));
    /*
     * View Item Label
     */
    echo $ui->get_text_input(array('labeltext' => __('View Item', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'view_item', 'textvalue' => isset($current['labels']['view_item']) ? esc_attr($current['labels']['view_item']) : '', 'aftertext' => __('(e.g. View Movie)', 'cpt-plugin')));
    /*
     * Search Item Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Search Item', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'search_items', 'textvalue' => isset($current['labels']['search_items']) ? esc_attr($current['labels']['search_items']) : '', 'aftertext' => __('(e.g. Search Movie)', 'cpt-plugin')));
    /*
     * Not Found Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Not Found', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'not_found', 'textvalue' => isset($current['labels']['not_found']) ? esc_attr($current['labels']['not_found']) : '', 'aftertext' => __('(e.g. No Movies found)', 'cpt-plugin')));
    /*
     * Not Found In Trash Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Not Found in Trash', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'not_found_in_trash', 'textvalue' => isset($current['labels']['not_found_in_trash']) ? esc_attr($current['labels']['not_found_in_trash']) : '', 'aftertext' => __('(e.g. No Movies found in Trash)', 'cpt-plugin')));
    /*
     * Parent Label
     */
    echo $ui->get_text_input(array('labeltext' => __('Parent', 'cpt-plugin'), 'helptext' => esc_attr__('Post type label. Used in the admin menu for displaying post types.', 'cpt-plugin'), 'namearray' => 'cpt_labels', 'name' => 'parent', 'textvalue' => isset($current['labels']['parent']) ? esc_attr($current['labels']['parent']) : '', 'aftertext' => __('(e.g. Parent Movie)', 'cpt-plugin')));
    ?>
							</table>
						</div>
					<h3 title="<?php 
    esc_attr_e('Click to expand', 'cpt-plugin');
    ?>
"><?php 
    _e('Settings', 'cpt-plugin');
    ?>
</h3>
						<div>
							<table>
							<?php 
    /*
     * Public Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin')), array('attr' => '1', 'text' => __('True', 'cpt-plugin'), 'default' => 'true')));
    $selected = isset($current) ? disp_boolean($current['public']) : '';
    $select['selected'] = !empty($selected) ? $current['public'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'public', 'labeltext' => __('Public', 'cpt-plugin'), 'aftertext' => __('(default: True)', 'cpt-plugin'), 'helptext' => esc_attr__('Whether posts of this type should be shown in the admin UI', 'cpt-plugin'), 'selections' => $select));
    /*
     * Show UI Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin')), array('attr' => '1', 'text' => __('True', 'cpt-plugin'), 'default' => 'true')));
    $selected = isset($current) ? disp_boolean($current['show_ui']) : '';
    $select['selected'] = !empty($selected) ? $current['show_ui'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'show_ui', 'labeltext' => __('Show UI', 'cpt-plugin'), 'aftertext' => __('(default: True)', 'cpt-plugin'), 'helptext' => esc_attr__('Whether to generate a default UI for managing this post type', 'cpt-plugin'), 'selections' => $select));
    /*
     * Has Archive Boolean
     */
    echo $ui->get_tr_start() . $ui->get_th_start() . __('Has Archive', 'cpt-plugin');
    echo $ui->get_p(__('If left blank, the archive slug will default to the post type slug.', 'cpt-plugin'));
    echo $ui->get_th_end() . $ui->get_td_start();
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin'), 'default' => 'true'), array('attr' => '1', 'text' => __('True', 'cpt-plugin'))));
    $selected = isset($current) ? disp_boolean($current['has_archive']) : '';
    $select['selected'] = !empty($selected) ? $current['has_archive'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'has_archive', 'labeltext' => __('Has Archive', 'cpt-plugin'), 'aftertext' => __('(default: False)', 'cpt-plugin'), 'helptext' => esc_attr__('Whether the post type will have a post type archive page', 'cpt-plugin'), 'selections' => $select, 'wrap' => false));
    /*
     * Has Archive Input
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'has_archive_string', 'textvalue' => isset($current['has_archive_string']) ? esc_attr($current['has_archive_string']) : '', 'helptext' => esc_attr__('Slug to be used for archive page.', 'cpt-plugin'), 'wrap' => false));
    echo $ui->get_td_end() . $ui->get_tr_end();
    /*
     * Exclude From Search Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin'), 'default' => 'true'), array('attr' => '1', 'text' => __('True', 'cpt-plugin'))));
    $selected = isset($current) ? disp_boolean($current['exclude_from_search']) : '';
    $select['selected'] = !empty($selected) ? $current['exclude_from_search'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'exclude_from_search', 'labeltext' => __('Exclude From Search', 'cpt-plugin'), 'aftertext' => __('(default: False)', 'cpt-plugin'), 'helptext' => esc_attr__('Whether the post type will be searchable', 'cpt-plugin'), 'selections' => $select));
    /*
     * Capability Type Input
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'capability_type', 'textvalue' => isset($current['capability_type']) ? esc_attr($current['capability_type']) : 'post', 'labeltext' => __('Capability Type', 'cpt-plugin'), 'helptext' => esc_attr__('The post type to use for checking read, edit, and delete capabilities', 'cpt-plugin')));
    /*
     * Hierarchical Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin'), 'default' => 'true'), array('attr' => '1', 'text' => __('True', 'cpt-plugin'))));
    $selected = isset($current) ? disp_boolean($current['hierarchical']) : '';
    $select['selected'] = !empty($selected) ? $current['hierarchical'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'hierarchical', 'labeltext' => __('Hierarchical', 'cpt-plugin'), 'aftertext' => __('(default: False)', 'cpt-plugin'), 'helptext' => esc_attr__('Whether the post type can have parent-child relationships', 'cpt-plugin'), 'selections' => $select));
    /*
     * Rewrite Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin')), array('attr' => '1', 'text' => __('True', 'cpt-plugin'), 'default' => 'true')));
    $selected = isset($current) ? disp_boolean($current['rewrite']) : '';
    $select['selected'] = !empty($selected) ? $current['rewrite'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'rewrite', 'labeltext' => __('Rewrite', 'cpt-plugin'), 'aftertext' => __('(default: True)', 'cpt-plugin'), 'helptext' => esc_attr__('Triggers the handling of rewrites for this post type', 'cpt-plugin'), 'selections' => $select));
    /*
     * Rewrite Slug Input
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'rewrite_slug', 'textvalue' => isset($current['rewrite_slug']) ? esc_attr($current['rewrite_slug']) : '', 'labeltext' => __('Custom Rewrite Slug', 'cpt-plugin'), 'aftertext' => __('(default: post type name)', 'cpt-plugin'), 'helptext' => esc_attr__('Custom slug to use instead of the default.', 'cpt-plugin')));
    /*
     * Rewrite With Front Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin')), array('attr' => '1', 'text' => __('True', 'cpt-plugin'), 'default' => 'true')));
    $selected = isset($current) ? disp_boolean($current['rewrite_withfront']) : '';
    $select['selected'] = !empty($selected) ? $current['rewrite_withfront'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'rewrite_withfront', 'labeltext' => __('With Front', 'cpt-plugin'), 'aftertext' => __('(default: True)', 'cpt-plugin'), 'helptext' => esc_attr__('Should the permastruct be prepended with the front base.', 'cpt-plugin'), 'selections' => $select));
    /*
     * Query Var Boolean
     */
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin')), array('attr' => '1', 'text' => __('True', 'cpt-plugin'), 'default' => 'true')));
    $selected = isset($current) ? disp_boolean($current['query_var']) : '';
    $select['selected'] = !empty($selected) ? $current['query_var'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'query_var', 'labeltext' => __('Query Var', 'cpt-plugin'), 'aftertext' => __('(default: True)', 'cpt-plugin'), 'helptext' => esc_attr__('Should the permastruct be prepended with the front base.', 'cpt-plugin'), 'selections' => $select));
    echo $ui->get_tr_start() . $ui->get_th_start() . __('Menu Position', 'cpt-plugin');
    echo $ui->get_help(esc_attr__('The position in the menu order the post type should appear. show_in_menu must be true.', 'cpt-plugin'));
    echo $ui->get_p(__('See <a href="http://codex.wordpress.org/Function_Reference/register_post_type#Parameters">Available options</a> in the "menu_position" section. Range of 5-100', 'cpt-plugin'));
    echo $ui->get_th_end() . $ui->get_td_start();
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'menu_position', 'textvalue' => isset($current['menu_position']) ? esc_attr($current['menu_position']) : '', 'helptext' => esc_attr__('URL or Dashicon value for image to be used as menu icon.', 'cpt-plugin'), 'wrap' => false));
    echo $ui->get_td_end() . $ui->get_tr_end();
    /*
     * Show In Menu Boolean
     */
    echo $ui->get_tr_start() . $ui->get_th_start() . __('Show in Menu', 'cpt-plugin');
    echo $ui->get_p(__('"Show UI" must be "true". If an existing top level page such as "tools.php" is indicated for second input, post type will be sub menu of that.', 'cpt-plugin'));
    echo $ui->get_th_end() . $ui->get_td_start();
    $select = array('options' => array(array('attr' => '0', 'text' => __('False', 'cpt-plugin')), array('attr' => '1', 'text' => __('True', 'cpt-plugin'), 'default' => 'true')));
    $selected = isset($current) ? disp_boolean($current['show_in_menu']) : '';
    $select['selected'] = !empty($selected) ? $current['show_in_menu'] : '';
    echo $ui->get_select_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'show_in_menu', 'labeltext' => __('Show In Menu', 'cpt-plugin'), 'aftertext' => __('(default: True)', 'cpt-plugin'), 'helptext' => esc_attr__('Whether to show the post type in the admin menu and where to show that menu. Note that show_ui must be true', 'cpt-plugin'), 'selections' => $select, 'wrap' => false));
    /*
     * Show In Menu Input
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'show_in_menu_string', 'textvalue' => isset($current['show_in_menu_string']) ? esc_attr($current['show_in_menu_string']) : '', 'helptext' => esc_attr__('URL to image to be used as menu icon.', 'cpt-plugin'), 'wrap' => false));
    echo $ui->get_td_end() . $ui->get_tr_end();
    /*
     * Menu Icon
     */
    echo $ui->get_text_input(array('namearray' => 'cpt_custom_post_type', 'name' => 'menu_icon', 'textvalue' => isset($current['menu_icon']) ? esc_attr($current['menu_icon']) : '', 'labeltext' => __('Menu Icon', 'cpt-plugin'), 'aftertext' => __('(Full URL for icon or Dashicon class)', 'cpt-plugin'), 'helptext' => esc_attr__('URL to image to be used as menu icon or Dashicon class to use instead.', 'cpt-plugin')));
    echo $ui->get_tr_start() . $ui->get_th_start() . __('Supports', 'cpt-plugin') . $ui->get_th_end() . $ui->get_td_start();
    /*
     * Supports Title Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'title', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('title', $current['supports']) ? 'true' : 'false', 'name' => 'title', 'namearray' => 'cpt_supports', 'textvalue' => 'title', 'labeltext' => __('Title', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the title meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Editor Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'editor', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('editor', $current['supports']) ? 'true' : 'false', 'name' => 'editor', 'namearray' => 'cpt_supports', 'textvalue' => 'editor', 'labeltext' => __('Editor', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the content editor meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Excerpt Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'excerpt', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('excerpt', $current['supports']) ? 'true' : 'false', 'name' => 'excerpt', 'namearray' => 'cpt_supports', 'textvalue' => 'excerpt', 'labeltext' => __('Excerpt', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the excerpt meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Trackbacks Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'trackbacks', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('trackbacks', $current['supports']) ? 'true' : 'false', 'name' => 'trackbacks', 'namearray' => 'cpt_supports', 'textvalue' => 'trackbacks', 'labeltext' => __('Trackbacks', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the trackbacks meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Custom Fields Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'custom-fields', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('custom-fields', $current['supports']) ? 'true' : 'false', 'name' => 'custom-fields', 'namearray' => 'cpt_supports', 'textvalue' => 'custom-fields', 'labeltext' => __('Custom Fields', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the custom fields meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Comments Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'comments', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('comments', $current['supports']) ? 'true' : 'false', 'name' => 'comments', 'namearray' => 'cpt_supports', 'textvalue' => 'comments', 'labeltext' => __('Comments', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the comments meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Revisions Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'revisions', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('revisions', $current['supports']) ? 'true' : 'false', 'name' => 'revisions', 'namearray' => 'cpt_supports', 'textvalue' => 'revisions', 'labeltext' => __('Revisions', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the revisions meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Post Thumbnail Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'thumbnail', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('thumbnail', $current['supports']) ? 'true' : 'false', 'name' => 'thumbnail', 'namearray' => 'cpt_supports', 'textvalue' => 'thumbnail', 'labeltext' => __('Featured Image', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the featured image meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Author Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'author', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('author', $current['supports']) ? 'true' : 'false', 'name' => 'author', 'namearray' => 'cpt_supports', 'textvalue' => 'author', 'labeltext' => __('Author', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the author meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Page Attributes Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'page-attributes', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('page-attributes', $current['supports']) ? 'true' : 'false', 'name' => 'page-attributes', 'namearray' => 'cpt_supports', 'textvalue' => 'page-attributes', 'labeltext' => __('Page Attributes', 'cpt-plugin'), 'helptext' => esc_attr__('Adds the page attribute meta box when creating content for this custom post type', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    /*
     * Supports Post Formats Checkbox
     */
    echo $ui->get_check_input(array('checkvalue' => 'post-formats', 'checked' => !empty($current['supports']) && is_array($current['supports']) && in_array('post-formats', $current['supports']) ? 'true' : 'false', 'name' => 'post-formats', 'namearray' => 'cpt_supports', 'textvalue' => 'post-formats', 'labeltext' => __('Post Formats', 'cpt-plugin'), 'helptext' => esc_attr__('Adds post format support', 'cpt-plugin'), 'default' => true, 'wrap' => false));
    echo $ui->get_p(__('Use the option below to explicitly set "supports" to false.', 'cpt-plugin'));
    echo $ui->get_check_input(array('checkvalue' => 'none', 'checked' => !empty($current['supports']) && (is_array($current['supports']) && in_array('none', $current['supports'])) ? 'true' : 'false', 'name' => 'none', 'namearray' => 'cpt_supports', 'textvalue' => 'none', 'labeltext' => __('None', 'cpt-plugin'), 'helptext' => esc_attr__('Remove all support features', 'cpt-plugin'), 'default' => false, 'wrap' => false));
    echo $ui->get_td_end() . $ui->get_tr_end();
    echo $ui->get_tr_start() . $ui->get_th_start() . __('Built-in Taxonomies', 'cpt-plugin') . $ui->get_th_end() . $ui->get_td_start();
    /**
     * Filters the arguments for taxonomies to list for post type association.
     *
     * @since 1.0.0
     *
     * @param array $value Array of default arguments.
     */
    $args = apply_filters('cptui_attach_taxonomies_to_post_type', array('public' => true));
    /**
     * Filters the arguments for output type for returned results.
     *
     * @since 1.0.0
     *
     * @param string $value Default output type.
     */
    $output = apply_filters('cptui_attach_taxonomies_to_post_type_output', 'objects');
    # If they don't return an array, fall back to the original default. Don't need to check for empty, because empty array is default for $args param in get_post_types anyway.
    if (!is_array($args)) {
        $args = array('public' => true);
    }
    $add_taxes = get_taxonomies($args, $output);
    unset($add_taxes['nav_menu']);
    unset($add_taxes['post_format']);
    foreach ($add_taxes as $add_tax) {
        /*
         * Supports Taxonomies Checkbox
         */
        echo $ui->get_check_input(array('checkvalue' => $add_tax->name, 'checked' => !empty($current['taxonomies']) && is_array($current['taxonomies']) && in_array($add_tax->name, $current['taxonomies']) ? 'true' : 'false', 'name' => $add_tax->name, 'namearray' => 'cpt_addon_taxes', 'textvalue' => $add_tax->name, 'labeltext' => $add_tax->label, 'helptext' => sprintf(esc_attr__('Adds %s support', 'cpt-plugin'), $add_tax->label), 'wrap' => false));
    }
    echo $ui->get_td_end() . $ui->get_tr_end();
    ?>
							</table>
						</div>
						<?php 
    if ('new' == $tab) {
        ?>
						<h3 title="<?php 
        esc_attr_e('Click to expand', 'cpt-plugin');
        ?>
"><?php 
        _e('Starter Notes', 'cpt-plugin');
        ?>
</h3>
							<div><ol>
								<?php 
        echo '<li>' . sprintf(__('Post Type names should have %smax 20 characters%s, and only contain alphanumeric, lowercase characters, underscores in place of spaces and letters that do not have accents. Reserved names: post, page, attachment, revision, nav_menu_item.', 'cpt-plugin'), '<strong class="wp-ui-highlight">', '</strong>');
        echo '<li>' . sprintf(__('If you are unfamiliar with the advanced post type settings, just fill in the %sPost Type Name%s and %sLabel%s fields. Remaining settings will use default values. Labels, if left blank, will be automatically created based on the post type name. Hover over the question mark for more details.', 'cpt-plugin'), '<strong class="wp-ui-highlight">', '</strong>', '<strong class="wp-ui-highlight">', '</strong>');
        echo '<li>' . sprintf(__('Deleting custom post types will %sNOT%s delete any content into the database or added to those post types. You can easily recreate your post types and the content will still exist.', 'cpt-plugin'), '<strong class="wp-ui-highlight">', '</strong>');
        ?>
							</ol></div>
						<?php 
    }
    ?>
				</td>
			</tr>
		</table>
	</form>
	</div><!-- End .wrap -->
<?php 
}
Exemple #3
0
/**
 * Handle the save and deletion of post type data.
 *
 * @since 1.4.0
 */
function cptui_process_post_type()
{
    if (defined('DOING_AJAX') && DOING_AJAX) {
        return;
    }
    if (!is_admin()) {
        return;
    }
    if (!empty($_GET) && isset($_GET['page']) && 'cptui_manage_post_types' !== $_GET['page']) {
        return;
    }
    if (!empty($_POST)) {
        $result = '';
        if (isset($_POST['cpt_submit'])) {
            check_admin_referer('cptui_addedit_post_type_nonce_action', 'cptui_addedit_post_type_nonce_field');
            $result = cptui_update_post_type($_POST);
        } elseif (isset($_POST['cpt_delete'])) {
            check_admin_referer('cptui_addedit_post_type_nonce_action', 'cptui_addedit_post_type_nonce_field');
            $result = cptui_delete_post_type($_POST);
            add_filter('cptui_post_type_deleted', '__return_true');
        }
        if ($result) {
            add_action('admin_notices', "cptui_{$result}_admin_notice");
        }
    }
}