Exclude Pages

June 13, 2012

Exclude Pages Plugin

This plugin adds a checkbox, “include this page in menus”, uncheck this to exclude pages from the page navigation that users see on your site.

This plugin adds a checkbox, “include this page in menus”, uncheck this to exclude pages from the page navigation that users see on your site.

Any issues: contact me.This plugin adds a checkbox, “include this page in menus”, which is checked by default. If you uncheck
it, the page will not appear in any listings of pages (which includes, and is usually limited to, your
page navigation menus).

Pages which are children of excluded pages also do not show up in menu listings. (An alert in the editing screen,
underneath the “include” checkbox allows you to track down which ancestor page is affecting child pages
in this way.)

Advanced Usage

It is possible to temporarily pause and resume the effect of Exclude Pages by using the new <?php pause_exclude_pages(); ?> and <?php resume_exclude_pages(); ?> templates tags. The following code will show a list of all pages in your site, even those normally hidden:

<?php pause_exclude_pages(); ?> <?php wp_list_pages('title_li=<h2>Pages</h2>' ); ?> <?php resume_exclude_pages(); ?> 

You can also get an array the IDs of the pages which are excluded by calling the function ep_get_excluded_ids();, you can then use these IDs as you wish (e.g. feed them into raw MySQL queries).

Note to other plugin authors:

The plugin does not operate on wp_list_pages while the user is on an admin page, if this is an issue you can take advantage of the ep_admin_bail_out filter and create a filter function which returns false to allow Exclude Pages to operate in the admin area.

Another note:

If your plugins or themes don’t use the standard WordPress functions to create their menus then they won’t work. To get them to work you will need to track down the bit of code in the theme/plugin which gets the pages and change it to apply the filter “get_pages” (I cannot be responsible for any unforseen effects of the changes you make, so please test thoroughly). The change to getting pages will probably look something like this:

$pages = apply_filters( 'get_pages', $pages ); 

Please contact me if you’re completely stuck and we can discuss possible solutions.

Exclude pages is incompatible with:

Requests & Bug Reports

I’m simply noting requests & bug reports here, I’ve not necessarily looked into any of these.

None!

Installation

  1. Upload exclude_pages.php to the /wp-content/plugins/ directory
  2. Activate the plugin through the ‘Plugins’ menu in WordPress
  3. Create or edit a page, and enjoy the frisson of excitement as you exclude it from the navigation

Screenshots

  1. WP 2.5 - Showing the control on the editing screen to exclude a page from the navigation

    WP 2.5 - Showing the control on the editing screen to exclude a page from the navigation

  2. WP 2.5 - Showing the control and warning for a page which is the child of an excluded page

    WP 2.5 - Showing the control and warning for a page which is the child of an excluded page

  3. Pre WP 2.5 - Showing the control on the editing screen to exclude a page from the navigation

    Pre WP 2.5 - Showing the control on the editing screen to exclude a page from the navigation

  4. Pre WP 2.5 - Showing the control and warning for a page which is the child of an excluded page

    Pre WP 2.5 - Showing the control and warning for a page which is the child of an excluded page

FAQ

Installation Instructions

  1. Upload exclude_pages.php to the /wp-content/plugins/ directory
  2. Activate the plugin through the ‘Plugins’ menu in WordPress
  3. Create or edit a page, and enjoy the frisson of excitement as you exclude it from the navigation

Changelog

v1.92

  • BUGFIX: Fix deprecated notice when WP_DEBUG is true, thanks hansfordmc
  • Tested up to WordPress v3.3

v1.91 2011/08/26

  • BUGFIX: Prevent notice from appearing, thanks Ray

v1.9 2010/6/16

  • Tested with WP 3.2.1
  • ENHANCEMENT: Detects the use of WP menus and advises the user accordingly

v1.8.4 2010/5/21

v1.8.3 2010/5/20

v1.8.2 2010/5/14

Dear Non-English Exclude Pages Users,

This release includes the facility for Exclude Pages to be translated into languages other than English. Please contact me if you want to translate Exclude Pages into your language.

Sorry it took so long.

Best regards,

Simon

  • DROPPED SUPPORT FOR WORDPRESS VERSIONS PRIOR TO VERSION 2.7
  • BUGFIX: Everything was reporting that it was excluded by an ancestor for some reason. Crazy. Fixed now.
  • LOCALISATION: Added POT file! Woo hoo!

v1.8.1 2010/4/19

  • BUGFIX: Check for existence of parent object before attempting to use it. (Thanks to Robert Kosara for the bug report.)

v1.8 2009/10/27

  • BUGFIX: PHP 5.3 doesn’t like the fact that parameters marked as passed by reference as passed as value. Params now not marked as passed by ref.

v1.7 2009/7/29

  • ENHANCEMENT: You can now turn the Exclude Pages functionality off in the admin area through use of a filter (this is mainly of advantage to other plugin and theme author).

v1.6 2009/6/8

  • ENHANCEMENT: You can now turn the Exclude Pages functionality off before showing navigation which you want to be comprehensive (and show pages you’ve normally hidden). This is done with the new <?php pause_exclude_pages(); ?> and <?php resume_exclude_pages(); ?> templates tags.

v1.51 2009/4/23

  • FIX: Was throwing an error when $pages turned out not to be an array. Thanks to (Sandra)[http://www.vinyltangerine.com/] for reporting this.

v1.5 2008/11/03

  • ENHANCEMENT: Now compatible with WP 2.7-beta1
  • DOCS: Added a list of incompatible plugins
  • DOCS: Added a list of incompatible themes

v1.4 2008/01/02

  • ENHANCEMENT: Now compatible with WP 2.5
  • FIX: Pages are also excluded from the “Front page displays:” > “Posts page:” admin menu. (Reported by Ed Foley) This plugin now checks if it’s within the admin area, and does nothing if it is.

v1.3 2008/01/02

  • FIXED: Descendant (e.g. child) pages were only being checked to a depth of 1 generation.
  • FIXED: The link to visit the hidden ancestor page from an affected descendant page was hard-coded to my development blog URL. (Reported by webdragon777)
  • FIXED: Stripped out some stray error logging code.

v1.2 2007/11/21

  • ENHANCEMENT: Child pages of an excluded page are now also hidden. There is also a warning message in the edit screen for any child page with a hidden ancestor, informing the person editing that the page is effectively hidden; a link is provided to edit the ancestor affecting the child page.

v1.1 2007/11/10

  • FIXED: Pages not created manually using “Write Page” were always excluded from the navigation, meaning the admin has to edit the page to manually include them. Pages created by other plugins are not always included in the navigation, if you want to exclude them (a less common scenario) you have to edit them and uncheck the box. (Reported by Nudnik)

Details

  • Version: 1.92
  • Active installations: 40,000
  • WordPress Version: 2.2.3
  • Tested up to: 3.4.2

Ratings


5 Stars
4 Stars
3 Stars
2 Stars
1 Stars