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.
- Controls for Flexi Pages Widget
- Pages listed on the home page when “List sub-pages only in parent and related pages in the hierarchy” option is selected.
- 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
Downloaded a total of 4566 times
You are free to use the plugin under terms specified by GPL.
If you like the widget and find it to be useful, please consider making a donation. Any amount will be thankfully accepted.
Installation
- Unzip the compressed file and upload ‘flexi-pages.php’ file (or ‘flexi-pages’ directory) directory to the ‘/wp-content/plugins/’ directory
- Activate the plugin ‘Flexi Pages Widget’ through the ‘Plugins’ menu in WordPress admin
- Go to WP Admin » Presentation » Widgets, drag ‘Flexi Pages 1′ widget into the sidebar and choose your options
- 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
- 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.
- 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.
- 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








#1: sec says:
Just installed the plugin, and got this error:
“Warning: Invalid argument supplied for foreach() in /plugins/flexi-pages/flexi-pages.php on line 67″
Any clues?