Flexi Pages Widget

Download Latest version: 1.4.1 (updated on 21 May 2008)

Flexi Pages Widget is a highly configurable widget to list pages and sub-pages in WordPress sidebar. User friendly widget control comes with plenty of options. ‘Flexi Pages’ widget can be used as an alternative to the default WordPress ‘Pages’ widget.

Features

  • Option to display sub-pages only in parent page and related pages.
  • Option to easily select and exclude certain pages from getting displayed in the list. Alternatively, only certain pages can be displayed by using the ‘include’ option.
  • Option to include a link to the home page.
  • Other options include title, sort column/order, text to be displayed for home page link, other display and depth options.
  • Multiple instances of the widget — upto nine instances of the widget can be added to the sidebar
  • Instead of using the widget, the function flexipages() can be called from anywhere in the template (more information).

Screenshots

Click on a thumbnail for full size image.

Flexi Pages Widget — screenshot 1
Flexi Pages Widget — screenshot 2Flexi Pages Widget — screenshot 3

  1. Controls for Flexi Pages Widget
  2. Pages listed on the home page when “List sub-pages only in parent and related pages in the hierarchy” option is selected.
  3. Pages listed on a page having sub pages. You can see the sub-pages expand here while only top level pages are listed in the home page on screenshot 2. Same settings as screenshot 2.

Download

Requires atleast WordPress version 2.1. Tested upto WordPress 2.5

Download Flexi Pages Widget plugin for WordPress Version 1.4.1

Downloaded a total of 5232 times

You are free to use the plugin under terms specified by GPL.

Installation

  1. Unzip the compressed file and upload ‘flexi-pages.php’ file (or ‘flexi-pages’ directory) directory to the ‘/wp-content/plugins/’ directory
  2. Activate the plugin ‘Flexi Pages Widget’ through the ‘Plugins’ menu in WordPress admin
  3. Go to WP Admin » Presentation » Widgets, drag ‘Flexi Pages 1′ widget into the sidebar and choose your options
  4. An option to select multiple instances of the widget is available in the widgets page. You can have upto 9 instances of the widget

Contact me for suggestions/questions/feature requests/bug reports. You can also leave your message here as a comment.

The flexipages() template function

Instead of using the sidebar widget, the function flexipages() can be used as a template function to display the list of pages. All options available for wp_list_pages() can also be used for flexipages(). Additionally in flexipages(), the depth parameter has two more choices (-2 and -3), and there is an extra parameter to display a link to the blog home page.

depth (integer)

This parameter controls how many levels in the hierarchy of pages are to be included in the list generated by flexipages. The default value is -2.

  • 0 - All pages and sub-pages displayed in hierarchical (indented) form.
  • -1 - All pages in sub-pages displayed in flat (no indent) form.
  • -2 (Default) - List sub-pages only in parent and related pages in hierarchy.
  • -3 - Similar to ‘-2′ above, but siblings of parent pages won’t be displayed. Only top level pages and pages in the hierarchy will show up.
  • 1 - Show only top level Pages
  • 2 - Value of 2 (or greater) specifies the depth (or level) to descend in displaying Pages.

home_link (string)

If a value is specified for this parameter, a link to the home page of the blog will be displayed on top of the list of pages. The link text will be the value specified. For example, flexipages('home_link=Home') will display a link to the home page with link text as ‘Home’.

In addition to the above two, all other parameters used with wp_list_pages() can also be used with flexipages(). Refer WordPress documentation for more details about the wp_list_pages() function and to know about how to pass the parameters into the function.

Frequently Asked Questions

  1. After selecting a few pages for exclusion, isn’t it possible to deselect all pages? There is always one page selected for exclusion.
    • It is possible to deselect all pages. Hold the ‘Ctrl’ key in your keyboard and click on the name of the page that’s not getting deselected.
  2. When the option “List sub-pages only in parent and related pages in hierarchy” is selected, top level pages, children and siblings of the current page, and siblings of the parent page get listed. Is it possible to get rid of siblings of parent page on a subpage while using this option?
    • Yes. But you have to select the ‘Custom depth level’ option to achieve this. Enter the number ‘-3′ for custom depth. This way only top level pages and pages in the hierarchy will show up.
  3. Is there an option to list only sub pages and hide the parent pages?
    • Although such an option does not exist, the ‘Include’ option can be used to achieve this. Select ‘Include’ instead of ‘Exclude’ and select all the pages you want to be listed. Pages left out won’t be displayed.

Change Log

2008-05-21: Version 1.4.1

  • Bug fixes (issues regarding include/exclude sub-pages only with ‘List sub-pages only in parent and related pages in hierarchy’ option.)

2008-04-06: Version 1.4

  • Fixed the odd behaviour when the widget is placed below the recent posts widget.
  • Removed the redundant check box for home page link in widget controls
  • Tested with WordPress 2.5; widget control box styling compatible with WP 2.5

2008-02-19: Version 1.3

  • Multiple instances of the widget
  • Added ‘Include pages’ option
  • flexipages() template function
  • Other minor improvements

2007-08-31: Version 1.2

  • Added option to provide a custom text for the home page link
  • Custom depth of ‘-3′ will display only parents, siblings and children along with top level pages. Parents’ siblings wont be displayed.
  • Few other improvements and some optimization.
  • Tested with WordPress 2.3-beta1.

2007-08-22: Version 1.1.2

  • Fixed the missing </li> tag for home link
  • Added class name (page_item, current_page_item) for home link

2007-08-17: Version 1.1.1

  • bug fix
  • tested with WordPress 2.2.2

2007-08-12: Version 1.1

  • bug fix

2007-08-08: Version 1.0

  • Initial release

220 Comments

  1. Ricky says:

    I’m sure it’s something simple, but I just can’t seem to do it. I installed and activated the widget, and it works perfect. The problem I have is, the widget is underneath everything else on my sidebar. Where or what file would I go about editting, to move the widget to the top of the sidebar? Thanks in advance.

  2. Srini says:

    Ricky, go to WP admin -> Presentation -> Widgets and drag the ‘Flexi Pages’ box to the top of the sidebar. If the widget still remains in the bottom, you probably will have to edit the sidebar.php file of the theme you are using.

  3. Ricky says:

    In the WP Admin -> Presentation -> Widgets section, flexi-pages is the only widget there. The theme I’m using has 3 columns, so a l_sidebar.php and a r_sidebar.php. I looked in those files, but can’t find anything that make reference to flexi-pages.

    Hmm.. when WP installs flexi-pages, what files besides sidebar.php does the widget modify?

  4. Srini says:

    The widget doesn’t modify any file, but the theme you are using is probably designed in such a way that the widgets are pushed to the bottom. You will have to modify one of the sidebar files or both… contact the theme author, or drop me a line giving details about the theme, I’ll try to help you out.

  5. vincent says:

    cool widget. thank you
    is it possible to open all the subpages at once? just not one level at a time?

  6. Scott Supak says:

    Would be really cool if it didn’t show the home page link while on the home page…

  7. Skitzo says:

    Hey Srini, Love this plugin, does exactly what I need, however, when using the “List sub-pages only in parent and in related pages in Heirarchy”. When you select a parent page that has sub-pages, The closing tag doesn’t show up until after the sub-page listing, so all of the subpages use the same highlighting as an active page becuase the sytle is tied to the tag.
    Is it a template issue, or just a minor bug?

  8. Melissa says:

    I installed this and added the widget to my sidebar but I can’t seem to find the options. Should they be on the same widget admin page? Because they’re not. I’m running Wordpress 2.3.2

  9. Steve says:

    Hey, I love this widget, just one question though, is it possible to make it so the page being viewed is bold/highlighted/italicized/etc in the menu?

  10. Srini says:

    Sorry all, I couldn’t reply your queries earlier as I was away on a holiday last week. Let’s look at everything one by one.

    @Scott Supak: Thanks for the suggestion. I will make it that way in future versions.

    @Skitzo: It’s not a bug, just a styling issue. You have defined styling for .current-page-item a, but not for .current-page-item a a. So, the latter is inheriting the styling of the former. Contact me if you need further help with this.

    @Melissa: pease refer this.

    @Steve: The page being viewed will be classed as ‘current-page-item’, so in your stylesheet just add .current-page-item {font-weight:bold} or any styling you want.

    @vincent: Sorry I don’t understand. Please explain.

Leave a Reply