How to disable the Post Formats UI in WordPress 3.6+

Update: The new UI was pulled before the release of 3.6 and its development will continue in a plugin until it’s ready for core.

WordPress 3.6 is currently in beta, and is set to come with a new post formats interface that’s right in our faces. But sometimes we don’t need post formats. Luckily we have two options. We can either hide it, or we can disable it entirely.

Hiding the Post Formats UI

Hiding it is easy. Just uncheck the box in Screen Options.
How to hide the Post Formats UI in WordPress

Disabling the Post Formats UI

But what if we want it completely disabled? That’s pretty easy too. WordPress offers a filter to disable it, and it can be done with just a single line of code.

add_filter( 'enable_post_format_ui', '__return_false' );

Easy enough, right?

How to hide pages in the WordPress admin

Sometimes it’s handy to hide pages in the WordPress admin from certain users. For example, when using WordPress as a CMS, where you define a static front page and a Posts page for all the posts, you might not want users trying to edit the Posts page since their edits won’t show up on the site anyway. A common scenario I see is users trying to edit the dummy “News” page assigned as the Posts page, or trying to change the front page of the site by editing the dummy “Home” page.

You can’t blame the users for trying to add news to their site by editing the “News” page. It makes sense. What doesn’t make sense is how WordPress does things in this regard, but that’s another discussion. To prevent this confusion, we can hide these dummy pages, or any other pages we want, from the users.

Using the code below, you can hide specific pages from all users who aren’t Administrators. It’s worth noting that this isn’t a security solution. It’s a simple piece of code for preventing confusion or accidents. If you need a real security solution, I recommend something like BU Section Editing by the fine folks at Boston University.

<?php
/*
Plugin Name: Exclude pages from admin
Plugin URI: https://www.johnparris.com/
Description: Removes pages from admin that shouldn't be edited.
Version: 1.0
Author: John Parris
Author URI: https://www.johnparris.com/
License: GPLv2
*/

function jp_exclude_pages_from_admin($query) {

	if ( ! is_admin() )
		return $query;

	global $pagenow, $post_type;

	if ( !current_user_can( 'administrator' ) && $pagenow == 'edit.php' && $post_type == 'page' )
		$query->query_vars['post__not_in'] = array( '10', '167', '205' ); // Enter your page IDs here
 

}
add_filter( 'parse_query', 'jp_exclude_pages_from_admin' );

Someone brought up the fact that this doesn’t remove the Edit Page link from the admin bar on the front end of the site. This is true. It’s worth mentioning again that this isn’t a security solution. It’s a simple piece of code to keep people from getting confused or accidentally messing something up. Having said that, here’s a little piece of code for hiding the Edit Page link.

// Remove the Edit link from the admin bar
function jp_remove_admin_bar_edit_link() {

	if( ! current_user_can( 'administrator' ) ) {
		
		global $wp_admin_bar;
		$wp_admin_bar->remove_menu( 'edit' );
	}
}
add_action( 'wp_before_admin_bar_render', 'jp_remove_admin_bar_edit_link' );

Feel free to combine the two pieces of code. For more details about the Roles and Capabilities of WordPress, see this page.

Hide WordPress update notices from non-admin users

When an update is available for WordPress, it shows a notice at the top of the screen in the administrative backend. It does this for all users, including those who don’t have access to install the updates. If you want to hide the update message from users who cannot install updates, such as editors, authors and contributors, you can easily do that. The following code will hide the update message from users who do not have the manage_options capability, which on a default WordPress installation would be everyone except Administrators or Super Admins. Visit the codex for more information about WordPress roles and capabilities.

/* Only show WordPress update nag to admins */
function jp_proper_update_nag() {
  if ( !current_user_can( 'manage_options' ) ) {
    remove_action( 'admin_notices', 'update_nag', 3 );
  }
}
add_action( 'admin_notices', 'jp_proper_update_nag', 1 );

Exclude certain pages from WordPress search results

For various reasons, we may need to exclude certain pages from WordPress search results. This isn’t the same as excluding all pages from the search results. We only want to exclude specific pages. Here’s one way to do that. Add this code to your child theme’s functions.php, or better yet make it a plugin. If you don’t know how to make a custom plugin, you can do that easily with Pluginception.

Don’t want to manage this manually, or not comfortable adding custom code to your site? Check out Search Control for WordPress. It makes this much easier for you!

function jp_search_filter( $query ) {
	if ( ! $query->is_admin && $query->is_search && $query->is_main_query() ) {
		$query->set( 'post__not_in', array( 10,11,20,105 ) );
	}
}
add_action( 'pre_get_posts', 'jp_search_filter' );

In the example above, we’re excluding pages with IDs 10, 11, 20, and 105 from the search results. You will need to change these numbers to match the IDs of the pages you want to exclude.

The WP_Query class in WordPress is a powerful tool we have at our disposal for customizing the content shown on our sites. Check out the WP_Query documentation to see all the things it can do.

How to remove WordPress post meta boxes

The WordPress post screen contains a number of meta boxes that allow you to do things with your posts. For example, you can select the post category in the Categories meta box, and you can control the comments setting for individual posts in the Discussion meta box. But, what if you want to prevent some users from changing these things? No problem. You can disable any of the meta boxes with a few lines of code.

Let’s say you want to prevent users with the Contributors and Authors roles from disabling comments on a post. Worded another way, you only want users with the edit_others_posts capability to be able to disable comments. Here’s how you can do that.

Heads up
At this point it’s worth noting that we’re talking about a WordPress site using the default user roles of Subscriber, Contributor, Author, Editor, and Administrator. If you have custom roles, you may need to adjust the code to fit your needs.
/**
 * Remove the Discussion meta box for users without
 * the 'edit_others_posts' capability.
 */
function jp_remove_discussion_post_meta_box() {

  if ( !current_user_can( 'edit_others_posts' ) ) {
    remove_meta_box( 'commentstatusdiv', 'post', 'normal' );
  }

}
add_action( 'admin_menu', 'jp_remove_discussion_post_meta_box' );

Or let’s say you want to prevent users from adding tags to a post. You can disable the Tags meta box with the following code.

/**
 * Remove the Tags meta box for all users except administrators
 */
function jp_remove_tags_post_meta_box() {

  if ( !current_user_can( 'administrator' ) ) {
    remove_meta_box( 'tagsdiv-post_tag', 'post', 'normal' );
  }

}
add_action( 'admin_menu', 'jp_remove_tags_post_meta_box' );

WordPress has a way to disable all of the meta boxes. Here’s a list of the meta boxes and the HTML id attribute needed to remove them.

Author - 'authordiv'
Category - 'categorydiv'
Comments - 'commentsdiv'
Discussion - 'commentstatusdiv'
Formats - 'formatdiv'
Attributes - 'pageparentdiv'
Custom fields - 'postcustom'
Excerpt - 'postexcerpt'
Featured Image - 'postimagediv'
Revisions - 'revisionsdiv'
Slug - 'slugdiv'
Publish - 'submitdiv'
Tags - 'tagsdiv-post_tag'
Trackbacks - 'trackbacksdiv'

WordPress offers a number of capabilities you can target for controlling your site. Check out the Roles and Capabilities page for all the details.

Redirect WordPress users during logout

Normally in WordPress when a user logs out, he is directed to the login page. But what if we want to redirect users to another page? No problem.

With the following code we can redirect users to the home page when they log out.

function jp_logout_redirect( $logout_url ) {
  return $logout_url . '&amp;redirect_to=' . urlencode( home_url() );
}
add_filter( 'logout_url', 'jp_logout_redirect' );

 

What if we need to redirect users to a special page on our site? Just as easy.

function jp_logout_redirect( $logout_url ) {
  return $logout_url . '&amp;redirect_to=' . urlencode( home_url() . '/our/special/page' );
}
add_filter( 'logout_url', 'jp_logout_redirect' );

Remove the WordPress logo from the admin bar

If you’re like me, you’ve accidentally clicked the WordPress logo in the admin bar a hundred times while meaning to go to the main Dashboard screen. That logo just gets in my way. I already know about WordPress, so I don’t need a link to the “about” page cluttering up my admin bar. Using the simple code below, we can remove the logo and dropdown menu and make things a little easier on us.

function jp_remove_admin_bar_logo() {
  global $wp_admin_bar;
  $wp_admin_bar->remove_menu( 'wp-logo' );
}
add_action( 'wp_before_admin_bar_render', 'jp_remove_admin_bar_logo', 0 );

Redirect WordPress users during login

Normally in WordPress when a user logs in, he is directed to some place in the administrative back end. If he is assigned the role of Subscriber, this usually sends him to his profile page, which isn’t very useful under most circumstances. If he is assigned the role of Contributor, Author, Editor or Administrator, he is directed to the Dashboard screen.

But what if we want to redirect users to a specific page in the back end or some other page on the front end? For example, maybe we have a special page set up just for Contributors. In WordPress we can redirect users based on their roles or capabilities. Here is an example.

function jp_login_redirect_contributors() {
  if ( current_user_can( 'contributor' ) ){
    return '/redirect/path';
  }
}
add_filter( 'login_redirect', 'jp_login_redirect_contributors' );

In this example, users assigned the role of Contributor are redirected to /redirect/path. WordPress has a number of roles and capabilities built in that we can target, and we can easily create custom roles and capabilities using plugins like Members.

Using these simple methods we can easily create custom workflows that make life easier in WordPress.

Multiple excerpt lengths in WordPress

The default WordPress excerpt length is 55 words. Sometimes we need to change this, and sometimes we need multiple excerpt lengths depending on where we are. For example, we might want a short excerpt on the home page and the default excerpt for everywhere else – archives, author pages, etc.

function jp_multiple_excerpt_lengths($length) {
	if ( is_front_page() ) {
		return 15;
	}

	return 55;
}
add_filter( 'excerpt_length', 'jp_multiple_excerpt_lengths' );

The example above changes the excerpt length on the front page, but WordPress comes with numerous conditional tags we can use in our themes, like is_category and is_archive.

We can even add extra conditional cases to the code above. Let’s say we want a short excerpt on the front page, a longer one on author pages, and the default everywhere else.

function jp_multiple_excerpt_lengths($length) {
	if ( is_front_page() ) {
		return 15;

	} elseif ( is_author() ) {
		return 65;

	} else {
		return 55;

	}
}
add_filter( 'excerpt_length', 'jp_multiple_excerpt_lengths' );