Diff
checker
文本
文本
圖像
文檔
Excel
文件夾
Legal
Enterprise
桌面版
定價
登入
下載 Diffchecker 桌面版
比較文本
尋找兩個文字檔案之間的差異
工具
歷史
即時編輯器
隱藏空白變更
摺疊未變更行
關閉換行
檢視
拆分
統一
比對精度
智能
單詞
字符
文字樣式
變更外觀
語法突出顯示
選擇語法
忽略
文字轉換
前往第一個差異
編輯輸入
Diffchecker Desktop
執行Diffchecker最安全的方式。取得Diffchecker桌面應用程式:您的差異永遠不會離開您的電腦!
取得桌面版
Untitled diff
建立於
11 年前
差異永不過期
清除
匯出
分享
解釋
4 刪除
行
總計
刪除
字符
總計
刪除
要繼續使用此功能,請升級到
Diff
checker
Pro
查看價格
496 行
全部複製
14 新增
行
總計
新增
字符
總計
新增
要繼續使用此功能,請升級到
Diff
checker
Pro
查看價格
508 行
全部複製
<?php
<?php
/*
/*
Plugin Name: Hierarchical Pages
Plugin Name: Hierarchical Pages
Version: 1.4
Version: 1.4
Plugin URI: http://www.saltriversystems.com/website/hierpage/
Plugin URI: http://www.saltriversystems.com/website/hierpage/
Description: Adds sidebar widgets to display a context-based list of "nearby" pages, and to display nested categories.
Description: Adds sidebar widgets to display a context-based list of "nearby" pages, and to display nested categories.
Author: William Lindley
Author: William Lindley
Author URI: http://www.wlindley.com/
Author URI: http://www.wlindley.com/
License: GPL2
License: GPL2
*/
*/
/* Copyright 2007-2012 William Lindley (email : wlindley -at- wlindley -dot- com)
/* Copyright 2007-2012 William Lindley (email : wlindley -at- wlindley -dot- com)
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
(at your option) any later version.
This program is distributed in the hope that it will be useful,
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
*/
if (!class_exists('SRCS_WP_Widget')) {
if (!class_exists('SRCS_WP_Widget')) {
class SRCS_WP_Widget extends WP_Widget
class SRCS_WP_Widget extends WP_Widget
{
{
function form_html($instance) {
function form_html($instance) {
$option_menu = $this->known_params(1);
$option_menu = $this->known_params(1);
foreach (array_keys($option_menu) as $param) {
foreach (array_keys($option_menu) as $param) {
$param_display[$param] = htmlspecialchars($instance[$param]);
$param_display[$param] = htmlspecialchars($instance[$param]);
}
}
foreach ($option_menu as $option_name => $option) {
foreach ($option_menu as $option_name => $option) {
$checkval='';
$checkval='';
$desc = '';
$desc = '';
if ($option['desc'])
if ($option['desc'])
$desc = "<br /><small>{$option['desc']}</small>";
$desc = "<br /><small>{$option['desc']}</small>";
switch ($option['type']) {
switch ($option['type']) {
case 'checkbox':
case 'checkbox':
if ($instance[$option_name]) // special HTML and override value
if ($instance[$option_name]) // special HTML and override value
$checkval = 'checked="yes" ';
$checkval = 'checked="yes" ';
$param_display[$option_name] = 'yes';
$param_display[$option_name] = 'yes';
break;
break;
case '':
case '':
$option['type'] = 'text';
$option['type'] = 'text';
break;
break;
}
}
print '<p style="text-align:right;"><label for="' . $this->get_field_name($option_name) . '">' .
print '<p style="text-align:right;"><label for="' . $this->get_field_name($option_name) . '">' .
__($option['title']) .
__($option['title']) .
' <input style="width: 200px;" id="' . $this->get_field_id($option_name) .
' <input style="width: 200px;" id="' . $this->get_field_id($option_name) .
'" name="' . $this->get_field_name($option_name) .
'" name="' . $this->get_field_name($option_name) .
"\" type=\"{$option['type']}\" {$checkval}value=\"{$param_display[$option_name]}\" /></label>$desc</p>";
"\" type=\"{$option['type']}\" {$checkval}value=\"{$param_display[$option_name]}\" /></label>$desc</p>";
}
}
}
}
}
}
}
}
class HierPageWidget extends SRCS_WP_Widget
class HierPageWidget extends SRCS_WP_Widget
{
{
/**
/**
* Declares the HierPageWidget class.
* Declares the HierPageWidget class.
*
*
*/
*/
function HierPageWidget(){
function HierPageWidget(){
$widget_ops = array('classname' => 'widget_hier_page', 'description' => __( "Hierarchical Page Directory Widget") );
$widget_ops = array('classname' => 'widget_hier_page', 'description' => __( "Hierarchical Page Directory Widget") );
$control_ops = array('width' => 300, 'height' => 300);
$control_ops = array('width' => 300, 'height' => 300);
$this->WP_Widget('hierpage', __('Hierarchical Pages'), $widget_ops, $control_ops);
$this->WP_Widget('hierpage', __('Hierarchical Pages'), $widget_ops, $control_ops);
}
}
/**
/**
* Helper function
* Helper function
*
*
*/
*/
function hierpages_list_pages($args = '') {
function hierpages_list_pages($args = '') {
global $post;
global $post;
global $wp_query;
global $wp_query;
if ( !isset($args['echo']) )
if ( !isset($args['echo']) )
$args['echo'] = 1;
$args['echo'] = 1;
$output = '';
$output = '';
複製
已複製
複製
已複製
if(!$args['post_type'])$args['post_type'] = 'page';
// Query pages. NOTE: The array is sorted in alphabetical, or menu, order.
// Query pages. NOTE: The array is sorted in alphabetical, or menu, order.
$pages = & get_pages($args);
$pages = & get_pages($args);
複製
已複製
複製
已複製
$page_info = Array();
$page_info = Array();
if ( $pages ) {
if ( $pages ) {
$current_post = $wp_query->get_queried_object_id();
$current_post = $wp_query->get_queried_object_id();
foreach ( $pages as $page ) {
foreach ( $pages as $page ) {
$page_info[$page->ID]['parent'] = $page->post_parent;
$page_info[$page->ID]['parent'] = $page->post_parent;
$page_info[$page->post_parent]['children'][] = $page->ID;
$page_info[$page->post_parent]['children'][] = $page->ID;
}
}
// Display the front page?
// Display the front page?
$front_page = -1; // assume no static front page
$front_page = -1; // assume no static front page
if ('page' == get_option('show_on_front')) {
if ('page' == get_option('show_on_front')) {
$front_page = get_option('page_on_front');
$front_page = get_option('page_on_front');
// Regard flag: always show front page? Otherwise: Show front page only if it has children
// Regard flag: always show front page? Otherwise: Show front page only if it has children
if (($args['show_home'] == 'yes') || (sizeof($page_info[$front_page]['children']))) {
if (($args['show_home'] == 'yes') || (sizeof($page_info[$front_page]['children']))) {
$page_info[$front_page]['show'] = 1; // always show front page
$page_info[$front_page]['show'] = 1; // always show front page
}
}
}
}
// add all children of the root node, but only to single depth.
// add all children of the root node, but only to single depth.
if ($args['show_root'] == 'yes') {
if ($args['show_root'] == 'yes') {
foreach ( $page_info[0]['children'] as $child ) {
foreach ( $page_info[0]['children'] as $child ) {
if ($child != $front_page) {
if ($child != $front_page) {
$page_info[$child]['show'] = 1;
$page_info[$child]['show'] = 1;
}
}
}
}
}
}
複製
已複製
複製
已複製
if (is_
page(
)) {
if (is_
post_type_hierarchical($args['post_type']
)) {
if ($post->ID != $front_page ) {
if ($post->ID != $front_page ) {
// The current page is always shown, unless it is the static front page (see above)
// The current page is always shown, unless it is the static front page (see above)
$page_info[$post->ID]['show'] = 1;
$page_info[$post->ID]['show'] = 1;
}
}
複製
已複製
複製
已複製
// show the current page's children, if any.
// show the current page's children, if any.
if (is_array($page_info[$current_post]['children'] )) {
if (is_array($page_info[$current_post]['children'] )) {
foreach ( $page_info[$current_post]['children'] as $child ) {
foreach ( $page_info[$current_post]['children'] as $child ) {
$page_info[$child]['show'] = 1;
$page_info[$child]['show'] = 1;
}
}
}
}
複製
已複製
複製
已複製
$post_parent = $page_info[$current_post]['parent'];
$post_parent = $page_info[$current_post]['parent'];
if ($post_parent && ($args['show_siblings'] == 'yes')) {
if ($post_parent && ($args['show_siblings'] == 'yes')) {
// if showing siblings, add the current page's parent's other children.
// if showing siblings, add the current page's parent's other children.
foreach ( $page_info[$post_parent]['children'] as $child ) {
foreach ( $page_info[$post_parent]['children'] as $child ) {
if ($child != $front_page) {
if ($child != $front_page) {
$page_info[$child]['show'] = 1;
$page_info[$child]['show'] = 1;
}
}
}
}
// Also show parent node's siblings.
// Also show parent node's siblings.
$post_grandparent = $page_info[$post_parent]['parent'];
$post_grandparent = $page_info[$post_parent]['parent'];
if ($post_grandparent) {
if ($post_grandparent) {
foreach ( $page_info[$post_grandparent]['children'] as $child ) {
foreach ( $page_info[$post_grandparent]['children'] as $child ) {
if ($child != $front_page) {
if ($child != $front_page) {
$page_info[$child]['show'] = 1;
$page_info[$child]['show'] = 1;
}
}
}
}
}
}
}
}
複製
已複製
複製
已複製
// add all ancestors of the current page.
// add all ancestors of the current page.
while ($post_parent) {
while ($post_parent) {
$page_info[$post_parent]['show'] = 1;
$page_info[$post_parent]['show'] = 1;
// show that page's children, if any.
// show that page's children, if any.
if (is_array($page_info[$post_parent]['children'] )) {
if (is_array($page_info[$post_parent]['children'] )) {
foreach ( $page_info[$post_parent]['children'] as $child ) {
foreach ( $page_info[$post_parent]['children'] as $child ) {
$page_info[$child]['show'] = 1;
$page_info[$child]['show'] = 1;
}
}
}
}
$post_parent = $page_info[$post_parent]['parent'];
$post_parent = $page_info[$post_parent]['parent'];
}
}
}
}
// Add pages that were selected
// Add pages that were selected
$my_includes = Array();
$my_includes = Array();
複製
已複製
複製
已複製
foreach ( $pages as $page ) {
foreach ( $pages as $page ) {
if ($page_info[$page->ID]['show']) {
if ($page_info[$page->ID]['show']) {
$my_includes[] = $page->ID;
$my_includes[] = $page->ID;
}
}
}
}
if ($args['child_of']) {
if ($args['child_of']) {
$my_includes[] = $args['child_of'];
$my_includes[] = $args['child_of'];
}
}
if (!empty($my_includes)) {
if (!empty($my_includes)) {
// List pages, if any. Blank title_li suppresses unwanted elements.
// List pages, if any. Blank title_li suppresses unwanted elements.
$output .= wp_list_pages( Array('title_li' => '',
$output .= wp_list_pages( Array('title_li' => '',
'sort_column' => $args['sort_column'],
'sort_column' => $args['sort_column'],
'sort_order' => $args['sort_order'],
'sort_order' => $args['sort_order'],
複製
已複製
複製
已複製
'include' => $my_includes
) );
'include' => $my_includes
,
'post_type'=> $args['post_type']
) );
}
}
}
}
複製
已複製
複製
已複製
$output = apply_filters('wp_list_pages', $output);
$output = apply_filters('wp_list_pages', $output);
if ( $args['echo'] )
if ( $args['echo'] )
echo $output;
echo $output;
else
else
return $output;
return $output;
}
}
/**
/**
* Displays the Widget
* Displays the Widget
*
*
*/
*/
function widget($args, $instance){
function widget($args, $instance){
$title = apply_filters('widget_title', empty($instance['title']) ? '' : $instance['title']);
$title = apply_filters('widget_title', empty($instance['title']) ? '' : $instance['title']);
$known_params = $this->known_params(0);
$known_params = $this->known_params(0);
foreach ($known_params as $param) {
foreach ($known_params as $param) {
if (strlen($instance[$param])) {
if (strlen($instance[$param])) {
$page_options[$param] = $instance[$param];
$page_options[$param] = $instance[$param];
}
}
}
}
if ($instance['menu_order'] == 'yes') { // Deprecated, eliminated upon form display (see below)
if ($instance['menu_order'] == 'yes') { // Deprecated, eliminated upon form display (see below)
$page_options['sort_column']='menu_order,post_title';
$page_options['sort_column']='menu_order,post_title';
}
}
print $args['before_widget'];
print $args['before_widget'];
if ( $title )
if ( $title )
print "{$args['before_title']}{$title}{$args['after_title']}";
print "{$args['before_title']}{$title}{$args['after_title']}";
print '<ul>';
print '<ul>';
$this->hierpages_list_pages($page_options);
$this->hierpages_list_pages($page_options);
print "</ul>{$args['after_widget']}";
print "</ul>{$args['after_widget']}";
}
}
function known_params ($options = 0) {
function known_params ($options = 0) {
$option_menu = array('title' => array('title' => 'Title:'),
$option_menu = array('title' => array('title' => 'Title:'),
'show_siblings' => array('title' => 'Show siblings to the current page?',
'show_siblings' => array('title' => 'Show siblings to the current page?',
'type' => 'checkbox'),
'type' => 'checkbox'),
'show_root' => array('title' => 'Always show top-level pages?',
'show_root' => array('title' => 'Always show top-level pages?',
'type' => 'checkbox'),
'type' => 'checkbox'),
'show_home' => array('title' => 'Show the static home page?',
'show_home' => array('title' => 'Show the static home page?',
'desc' => '(always shown if it has child pages)',
'desc' => '(always shown if it has child pages)',
'type' => 'checkbox'),
'type' => 'checkbox'),
'child_of' => array('title' => 'Root page ID:'),
'child_of' => array('title' => 'Root page ID:'),
'exclude' => array('title' => 'Exclude pages:',
'exclude' => array('title' => 'Exclude pages:',
'desc' => 'List of page IDs to exclude'),
'desc' => 'List of page IDs to exclude'),
'sort_column' => array('title' => 'Sort field:',
'sort_column' => array('title' => 'Sort field:',
'desc' => 'Comma-separated list: <em>post_title, menu_order, post_date, post_modified, ID, post_author, post_name</em>'),
'desc' => 'Comma-separated list: <em>post_title, menu_order, post_date, post_modified, ID, post_author, post_name</em>'),
'sort_order' => array('title' => 'Sort direction:',
'sort_order' => array('title' => 'Sort direction:',
'desc' => '(default: ASC)'),
'desc' => '(default: ASC)'),
'meta_key' => array('title' => 'Meta Key:'),
'meta_key' => array('title' => 'Meta Key:'),
'meta_value' => array('title' => 'Meta-key Value:',
'meta_value' => array('title' => 'Meta-key Value:',
'desc' => 'for selecting pages by custom fields'),
'desc' => 'for selecting pages by custom fields'),
'authors' => array('title' => 'Authors:'),
'authors' => array('title' => 'Authors:'),
'post_status' => array('title' => 'Post status:',
'post_status' => array('title' => 'Post status:',
'desc' => '(default: publish)'),
'desc' => '(default: publish)'),
複製
已複製
複製
已複製
'post_type' => array('title' => 'Post type:',
'desc' => '(default: page)'),
);
);
return ($options ? $option_menu : array_keys($option_menu));
return ($options ? $option_menu : array_keys($option_menu));
}
}
/**
/**
* Saves the widget's settings.
* Saves the widget's settings.
*
*
*/
*/
function update($new_instance, $old_instance){
function update($new_instance, $old_instance){
$instance = $old_instance;
$instance = $old_instance;
$known_params = $this->known_params();
$known_params = $this->known_params();
unset($instance['menu_order']);
unset($instance['menu_order']);
foreach ($known_params as $param) {
foreach ($known_params as $param) {
$instance[$param] = strip_tags(stripslashes($new_instance[$param]));
$instance[$param] = strip_tags(stripslashes($new_instance[$param]));
}
}
$instance['sort_order'] = strtolower($instance['sort_order']) == 'desc'?'DESC':'ASC';
$instance['sort_order'] = strtolower($instance['sort_order']) == 'desc'?'DESC':'ASC';
return $instance;
return $instance;
}
}
/**
/**
* Creates the edit form for the widget.
* Creates the edit form for the widget.
*
*
*/
*/
function form($instance){
function form($instance){
$instance = wp_parse_args( (array) $instance, array('title'=>'') );
$instance = wp_parse_args( (array) $instance, array('title'=>'') );
if ($instance['menu_order']) {
if ($instance['menu_order']) {
$instance['sort_column'] = 'menu_order,post_title';
$instance['sort_column'] = 'menu_order,post_title';
}
}
if (empty($instance['sort_column'])) {
if (empty($instance['sort_column'])) {
$instance['sort_column'] = 'post_title';
$instance['sort_column'] = 'post_title';
}
}
$this->form_html($instance);
$this->form_html($instance);
}
}
}// END class
}// END class
/**
/**
* Register Hierarchical Pages widget.
* Register Hierarchical Pages widget.
*
*
* Calls 'widgets_init' action after the widget has been registered.
* Calls 'widgets_init' action after the widget has been registered.
*/
*/
function HierPageInit() {
function HierPageInit() {
register_widget('HierPageWidget');
register_widget('HierPageWidget');
}
}
/*
/*
* Plugin Name: Hierarchical Categories (combined with Hierarchical Pages)
* Plugin Name: Hierarchical Categories (combined with Hierarchical Pages)
* Plugin URI: http://www.wlindley.com/
* Plugin URI: http://www.wlindley.com/
* Description: Adds a sidebar widget to display a context-based list of "nearby" categories.
* Description: Adds a sidebar widget to display a context-based list of "nearby" categories.
* Author: William Lindley
* Author: William Lindley
* Author URI: http://www.wlindley.com/
* Author URI: http://www.wlindley.com/
*/
*/
class HierCatWidget extends SRCS_WP_Widget
class HierCatWidget extends SRCS_WP_Widget
{
{
/**
/**
* Declares our class.
* Declares our class.
*
*
*/
*/
function HierCatWidget(){
function HierCatWidget(){
$widget_ops = array('classname' => 'widget_hier_cat', 'description' => __( "Hierarchical Category Widget") );
$widget_ops = array('classname' => 'widget_hier_cat', 'description' => __( "Hierarchical Category Widget") );
$control_ops = array('width' => 300, 'height' => 300);
$control_ops = array('width' => 300, 'height' => 300);
$this->WP_Widget('hiercat', __('Hierarchical Categories'), $widget_ops, $control_ops);
$this->WP_Widget('hiercat', __('Hierarchical Categories'), $widget_ops, $control_ops);
}
}
/**
/**
* Helper function
* Helper function
*
*
*/
*/
function hiercat_list_cats($args) {
function hiercat_list_cats($args) {
global $post;
global $post;
global $wp_query;
global $wp_query;
if ( !isset($args['echo']) )
if ( !isset($args['echo']) )
$args['echo'] = 1;
$args['echo'] = 1;
$sort_column = $args['sort_column'];
$sort_column = $args['sort_column'];
$output = '';
$output = '';
// Query categories.
// Query categories.
$cats = & get_categories($args);
$cats = & get_categories($args);
if ($cats['errors']) {
if ($cats['errors']) {
print "<pre>"; print_r($cats); print "</pre>";
print "<pre>"; print_r($cats); print "</pre>";
return;
return;
}
}
$cat_info = Array();
$cat_info = Array();
if ( $cats ) {
if ( $cats ) {
$current_cat = $wp_query->get_queried_object_id();
$current_cat = $wp_query->get_queried_object_id();
foreach ( $cats as $cat ) {
foreach ( $cats as $cat ) {
$cat_info[$cat->term_id]['parent'] = $cat->category_parent;
$cat_info[$cat->term_id]['parent'] = $cat->category_parent;
$cat_info[$cat->category_parent]['children'][] = $cat->term_id;
$cat_info[$cat->category_parent]['children'][] = $cat->term_id;
}
}
// add all children of the root node, but only to single depth.
// add all children of the root node, but only to single depth.
foreach ( $cat_info[0]['children'] as $child ) {
foreach ( $cat_info[0]['children'] as $child ) {
$cat_info[$child]['show'] = 1;
$cat_info[$child]['show'] = 1;
}
}
// If currently displaying a category, taxonomy, or tag; AND
// If currently displaying a category, taxonomy, or tag; AND
// if it is the same as the one in this widget...
// if it is the same as the one in this widget...
if ((is_category() || is_tax() || is_tag()) &&
if ((is_category() || is_tax() || is_tag()) &&
($args['taxonomy'] == get_queried_object()->taxonomy ) ) {
($args['taxonomy'] == get_queried_object()->taxonomy ) ) {
// show the current category's children, if any.
// show the current category's children, if any.
if (is_array($cat_info[$current_cat]['children'] )) {
if (is_array($cat_info[$current_cat]['children'] )) {
foreach ( $cat_info[$current_cat]['children'] as $child ) {
foreach ( $cat_info[$current_cat]['children'] as $child ) {
$cat_info[$child]['show'] = 1;
$cat_info[$child]['show'] = 1;
}
}
}
}
$cat_parent = $cat_info[$current_cat]['parent'];
$cat_parent = $cat_info[$current_cat]['parent'];
if ($cat_parent && ($args['show_siblings'] == 'yes')) {
if ($cat_parent && ($args['show_siblings'] == 'yes')) {
// if showing siblings, add the current category's parent's other children.
// if showing siblings, add the current category's parent's other children.
foreach ( $cat_info[$cat_parent]['children'] as $child ) {
foreach ( $cat_info[$cat_parent]['children'] as $child ) {
$cat_info[$child]['show'] = 1;
$cat_info[$child]['show'] = 1;
}
}
# Also show parent node's siblings.
# Also show parent node's siblings.
$cat_grandparent = $cat_info[$cat_parent]['parent'];
$cat_grandparent = $cat_info[$cat_parent]['parent'];
if ($cat_grandparent) {
if ($cat_grandparent) {
foreach ( $cat_info[$cat_grandparent]['children'] as $child ) {
foreach ( $cat_info[$cat_grandparent]['children'] as $child ) {
$cat_info[$child]['show'] = 1;
$cat_info[$child]['show'] = 1;
}
}
}
}
}
}
// add all ancestors of the current category.
// add all ancestors of the current category.
while ($cat_parent) {
while ($cat_parent) {
$cat_info[$cat_parent]['show'] = 1;
$cat_info[$cat_parent]['show'] = 1;
$cat_parent = $cat_info[$cat_parent]['parent'];
$cat_parent = $cat_info[$cat_parent]['parent'];
}
}
}
}
$my_includes = Array();
$my_includes = Array();
// Add categories that were selected
// Add categories that were selected
foreach ( $cats as $cat ) {
foreach ( $cats as $cat ) {
if ($cat_info[$cat->term_id]['show']) {
if ($cat_info[$cat->term_id]['show']) {
$my_includes[] =$cat->term_id;
$my_includes[] =$cat->term_id;
}
}
}
}
if (!empty($my_includes)) {
if (!empty($my_includes)) {
// List categories, if any. Blank title_li suppresses unwanted elements.
// List categories, if any. Blank title_li suppresses unwanted elements.
$qargs = Array('title_li' => '', 'hide_empty' => 0, 'include' => $my_includes,
$qargs = Array('title_li' => '', 'hide_empty' => 0, 'include' => $my_includes,
'order' => $args['order'], 'orderby' => $args['orderby'],
'order' => $args['order'], 'orderby' => $args['orderby'],
'show_count' => $args['show_count']);
'show_count' => $args['show_count']);
if (!empty($args['taxonomy'])) {
if (!empty($args['taxonomy'])) {
$qargs['taxonomy'] = $args['taxonomy'];
$qargs['taxonomy'] = $args['taxonomy'];
}
}
$output .= wp_list_categories( $qargs );
$output .= wp_list_categories( $qargs );
}
}
}
}
$output = apply_filters('wp_list_categories', $output);
$output = apply_filters('wp_list_categories', $output);
if ( $args['echo'] )
if ( $args['echo'] )
echo $output;
echo $output;
else
else
return $output;
return $output;
}
}
function known_params ($options = 0) {
function known_params ($options = 0) {
$option_menu = array('title' => array('title' => 'Title:'),
$option_menu = array('title' => array('title' => 'Title:'),
'show_siblings' => array('title' => 'Show siblings to the current category?',
'show_siblings' => array('title' => 'Show siblings to the current category?',
'type' => 'checkbox'),
'type' => 'checkbox'),
'include' => array('title' => 'Include:',
'include' => array('title' => 'Include:',
'desc' => 'Comma-delimited list of category IDs, or blank for all'),
'desc' => 'Comma-delimited list of category IDs, or blank for all'),
'exclude' => array('title' => 'Exclude:'),
'exclude' => array('title' => 'Exclude:'),
'orderby' => array('title' => 'Sort field:',
'orderby' => array('title' => 'Sort field:',
'desc' => 'Enter one of: <em>name, count, term_group, slug</em> or a custom value. Default: name'),
'desc' => 'Enter one of: <em>name, count, term_group, slug</em> or a custom value. Default: name'),
'order' => array('title' => 'Sort direction:',
'order' => array('title' => 'Sort direction:',
'desc' => '(default: ASC)'),
'desc' => '(default: ASC)'),
'child_of' => array('title' => 'Only display Categories below this ID'),
'child_of' => array('title' => 'Only display Categories below this ID'),
'hide_empty' => array('title' => 'Hide empty categories?',
'hide_empty' => array('title' => 'Hide empty categories?',
'type' => 'checkbox'),
'type' => 'checkbox'),
'show_count' => array('title' => 'Show count of category entries?',
'show_count' => array('title' => 'Show count of category entries?',
'type' => 'checkbox'),
'type' => 'checkbox'),
'taxonomy' => array('title' => 'Custom taxonomy:'),
'taxonomy' => array('title' => 'Custom taxonomy:'),
);
);
if ($options) {
if ($options) {
$taxons = get_taxonomies();
$taxons = get_taxonomies();
$option_menu['taxonomy']['desc'] = 'Enter one of: <em>' .
$option_menu['taxonomy']['desc'] = 'Enter one of: <em>' .
implode(', ',array_keys($taxons)) . '</em> or blank for post categories.';
implode(', ',array_keys($taxons)) . '</em> or blank for post categories.';
}
}
return ($options ? $option_menu : array_keys($option_menu));
return ($options ? $option_menu : array_keys($option_menu));
}
}
/**
/**
* Displays the Widget
* Displays the Widget
*
*
*/
*/
function widget($args, $instance){
function widget($args, $instance){
$known_params = $this->known_params(0);
$known_params = $this->known_params(0);
foreach ($known_params as $param) {
foreach ($known_params as $param) {
if (strlen($instance[$param]))
if (strlen($instance[$param]))
$cat_options[$param] = $instance[$param];
$cat_options[$param] = $instance[$param];
}
}
$cat_options['title'] = apply_filters('widget_title', $cat_options['title']);
$cat_options['title'] = apply_filters('widget_title', $cat_options['title']);
// WordPress defaults to hiding: thus, always specify.
// WordPress defaults to hiding: thus, always specify.
$cat_options['hide_empty'] = $cat_options['hide_empty'] == 'yes' ? 1 : 0;
$cat_options['hide_empty'] = $cat_options['hide_empty'] == 'yes' ? 1 : 0;
print $args['before_widget'];
print $args['before_widget'];
if ( strlen($cat_options['title']) )
if ( strlen($cat_options['title']) )
print "{$args['before_title']}{$cat_options['title']}{$args['after_title']}";
print "{$args['before_title']}{$cat_options['title']}{$args['after_title']}";
print "<ul>";
print "<ul>";
$this->hiercat_list_cats($cat_options);
$this->hiercat_list_cats($cat_options);
print "</ul>{$after_widget}";
print "</ul>{$after_widget}";
}
}
/**
/**
* Saves the widget's settings.
* Saves the widget's settings.
*
*
*/
*/
function update($new_instance, $old_instance){
function update($new_instance, $old_instance){
$instance = $old_instance;
$instance = $old_instance;
$known_params = $this->known_params();
$known_params = $this->known_params();
foreach ($known_params as $param) {
foreach ($known_params as $param) {
$instance[$param] = strip_tags(stripslashes($new_instance[$param]));
$instance[$param] = strip_tags(stripslashes($new_instance[$param]));
}
}
return $instance;
return $instance;
}
}
/**
/**
* Creates the edit form for the widget.
* Creates the edit form for the widget.
*
*
*/
*/
function form($instance){
function form($instance){
//Defaults
//Defaults
$instance = wp_parse_args( (array) $instance, array('title'=>'') );
$instance = wp_parse_args( (array) $instance, array('title'=>'') );
$this->form_html($instance);
$this->form_html($instance);
}
}
}// END class
}// END class
/**
/**
* Register Hierarchical Categories widget.
* Register Hierarchical Categories widget.
*
*
* Calls 'widgets_init' action after the widget has been registered.
* Calls 'widgets_init' action after the widget has been registered.
*/
*/
function HierCatInit() {
function HierCatInit() {
register_widget('HierCatWidget');
register_widget('HierCatWidget');
}
}
/*
/*
* Initialize both widgets
* Initialize both widgets
*/
*/
add_action('widgets_init', 'HierCatInit');
add_action('widgets_init', 'HierCatInit');
add_action('widgets_init', 'HierPageInit');
add_action('widgets_init', 'HierPageInit');
?>
?>
已保存差異
原始文本
開啟檔案
<?php /* Plugin Name: Hierarchical Pages Version: 1.4 Plugin URI: http://www.saltriversystems.com/website/hierpage/ Description: Adds sidebar widgets to display a context-based list of "nearby" pages, and to display nested categories. Author: William Lindley Author URI: http://www.wlindley.com/ License: GPL2 */ /* Copyright 2007-2012 William Lindley (email : wlindley -at- wlindley -dot- com) This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ if (!class_exists('SRCS_WP_Widget')) { class SRCS_WP_Widget extends WP_Widget { function form_html($instance) { $option_menu = $this->known_params(1); foreach (array_keys($option_menu) as $param) { $param_display[$param] = htmlspecialchars($instance[$param]); } foreach ($option_menu as $option_name => $option) { $checkval=''; $desc = ''; if ($option['desc']) $desc = "<br /><small>{$option['desc']}</small>"; switch ($option['type']) { case 'checkbox': if ($instance[$option_name]) // special HTML and override value $checkval = 'checked="yes" '; $param_display[$option_name] = 'yes'; break; case '': $option['type'] = 'text'; break; } print '<p style="text-align:right;"><label for="' . $this->get_field_name($option_name) . '">' . __($option['title']) . ' <input style="width: 200px;" id="' . $this->get_field_id($option_name) . '" name="' . $this->get_field_name($option_name) . "\" type=\"{$option['type']}\" {$checkval}value=\"{$param_display[$option_name]}\" /></label>$desc</p>"; } } } } class HierPageWidget extends SRCS_WP_Widget { /** * Declares the HierPageWidget class. * */ function HierPageWidget(){ $widget_ops = array('classname' => 'widget_hier_page', 'description' => __( "Hierarchical Page Directory Widget") ); $control_ops = array('width' => 300, 'height' => 300); $this->WP_Widget('hierpage', __('Hierarchical Pages'), $widget_ops, $control_ops); } /** * Helper function * */ function hierpages_list_pages($args = '') { global $post; global $wp_query; if ( !isset($args['echo']) ) $args['echo'] = 1; $output = ''; // Query pages. NOTE: The array is sorted in alphabetical, or menu, order. $pages = & get_pages($args); $page_info = Array(); if ( $pages ) { $current_post = $wp_query->get_queried_object_id(); foreach ( $pages as $page ) { $page_info[$page->ID]['parent'] = $page->post_parent; $page_info[$page->post_parent]['children'][] = $page->ID; } // Display the front page? $front_page = -1; // assume no static front page if ('page' == get_option('show_on_front')) { $front_page = get_option('page_on_front'); // Regard flag: always show front page? Otherwise: Show front page only if it has children if (($args['show_home'] == 'yes') || (sizeof($page_info[$front_page]['children']))) { $page_info[$front_page]['show'] = 1; // always show front page } } // add all children of the root node, but only to single depth. if ($args['show_root'] == 'yes') { foreach ( $page_info[0]['children'] as $child ) { if ($child != $front_page) { $page_info[$child]['show'] = 1; } } } if (is_page()) { if ($post->ID != $front_page ) { // The current page is always shown, unless it is the static front page (see above) $page_info[$post->ID]['show'] = 1; } // show the current page's children, if any. if (is_array($page_info[$current_post]['children'] )) { foreach ( $page_info[$current_post]['children'] as $child ) { $page_info[$child]['show'] = 1; } } $post_parent = $page_info[$current_post]['parent']; if ($post_parent && ($args['show_siblings'] == 'yes')) { // if showing siblings, add the current page's parent's other children. foreach ( $page_info[$post_parent]['children'] as $child ) { if ($child != $front_page) { $page_info[$child]['show'] = 1; } } // Also show parent node's siblings. $post_grandparent = $page_info[$post_parent]['parent']; if ($post_grandparent) { foreach ( $page_info[$post_grandparent]['children'] as $child ) { if ($child != $front_page) { $page_info[$child]['show'] = 1; } } } } // add all ancestors of the current page. while ($post_parent) { $page_info[$post_parent]['show'] = 1; // show that page's children, if any. if (is_array($page_info[$post_parent]['children'] )) { foreach ( $page_info[$post_parent]['children'] as $child ) { $page_info[$child]['show'] = 1; } } $post_parent = $page_info[$post_parent]['parent']; } } // Add pages that were selected $my_includes = Array(); foreach ( $pages as $page ) { if ($page_info[$page->ID]['show']) { $my_includes[] = $page->ID; } } if ($args['child_of']) { $my_includes[] = $args['child_of']; } if (!empty($my_includes)) { // List pages, if any. Blank title_li suppresses unwanted elements. $output .= wp_list_pages( Array('title_li' => '', 'sort_column' => $args['sort_column'], 'sort_order' => $args['sort_order'], 'include' => $my_includes) ); } } $output = apply_filters('wp_list_pages', $output); if ( $args['echo'] ) echo $output; else return $output; } /** * Displays the Widget * */ function widget($args, $instance){ $title = apply_filters('widget_title', empty($instance['title']) ? '' : $instance['title']); $known_params = $this->known_params(0); foreach ($known_params as $param) { if (strlen($instance[$param])) { $page_options[$param] = $instance[$param]; } } if ($instance['menu_order'] == 'yes') { // Deprecated, eliminated upon form display (see below) $page_options['sort_column']='menu_order,post_title'; } print $args['before_widget']; if ( $title ) print "{$args['before_title']}{$title}{$args['after_title']}"; print '<ul>'; $this->hierpages_list_pages($page_options); print "</ul>{$args['after_widget']}"; } function known_params ($options = 0) { $option_menu = array('title' => array('title' => 'Title:'), 'show_siblings' => array('title' => 'Show siblings to the current page?', 'type' => 'checkbox'), 'show_root' => array('title' => 'Always show top-level pages?', 'type' => 'checkbox'), 'show_home' => array('title' => 'Show the static home page?', 'desc' => '(always shown if it has child pages)', 'type' => 'checkbox'), 'child_of' => array('title' => 'Root page ID:'), 'exclude' => array('title' => 'Exclude pages:', 'desc' => 'List of page IDs to exclude'), 'sort_column' => array('title' => 'Sort field:', 'desc' => 'Comma-separated list: <em>post_title, menu_order, post_date, post_modified, ID, post_author, post_name</em>'), 'sort_order' => array('title' => 'Sort direction:', 'desc' => '(default: ASC)'), 'meta_key' => array('title' => 'Meta Key:'), 'meta_value' => array('title' => 'Meta-key Value:', 'desc' => 'for selecting pages by custom fields'), 'authors' => array('title' => 'Authors:'), 'post_status' => array('title' => 'Post status:', 'desc' => '(default: publish)'), ); return ($options ? $option_menu : array_keys($option_menu)); } /** * Saves the widget's settings. * */ function update($new_instance, $old_instance){ $instance = $old_instance; $known_params = $this->known_params(); unset($instance['menu_order']); foreach ($known_params as $param) { $instance[$param] = strip_tags(stripslashes($new_instance[$param])); } $instance['sort_order'] = strtolower($instance['sort_order']) == 'desc'?'DESC':'ASC'; return $instance; } /** * Creates the edit form for the widget. * */ function form($instance){ $instance = wp_parse_args( (array) $instance, array('title'=>'') ); if ($instance['menu_order']) { $instance['sort_column'] = 'menu_order,post_title'; } if (empty($instance['sort_column'])) { $instance['sort_column'] = 'post_title'; } $this->form_html($instance); } }// END class /** * Register Hierarchical Pages widget. * * Calls 'widgets_init' action after the widget has been registered. */ function HierPageInit() { register_widget('HierPageWidget'); } /* * Plugin Name: Hierarchical Categories (combined with Hierarchical Pages) * Plugin URI: http://www.wlindley.com/ * Description: Adds a sidebar widget to display a context-based list of "nearby" categories. * Author: William Lindley * Author URI: http://www.wlindley.com/ */ class HierCatWidget extends SRCS_WP_Widget { /** * Declares our class. * */ function HierCatWidget(){ $widget_ops = array('classname' => 'widget_hier_cat', 'description' => __( "Hierarchical Category Widget") ); $control_ops = array('width' => 300, 'height' => 300); $this->WP_Widget('hiercat', __('Hierarchical Categories'), $widget_ops, $control_ops); } /** * Helper function * */ function hiercat_list_cats($args) { global $post; global $wp_query; if ( !isset($args['echo']) ) $args['echo'] = 1; $sort_column = $args['sort_column']; $output = ''; // Query categories. $cats = & get_categories($args); if ($cats['errors']) { print "<pre>"; print_r($cats); print "</pre>"; return; } $cat_info = Array(); if ( $cats ) { $current_cat = $wp_query->get_queried_object_id(); foreach ( $cats as $cat ) { $cat_info[$cat->term_id]['parent'] = $cat->category_parent; $cat_info[$cat->category_parent]['children'][] = $cat->term_id; } // add all children of the root node, but only to single depth. foreach ( $cat_info[0]['children'] as $child ) { $cat_info[$child]['show'] = 1; } // If currently displaying a category, taxonomy, or tag; AND // if it is the same as the one in this widget... if ((is_category() || is_tax() || is_tag()) && ($args['taxonomy'] == get_queried_object()->taxonomy ) ) { // show the current category's children, if any. if (is_array($cat_info[$current_cat]['children'] )) { foreach ( $cat_info[$current_cat]['children'] as $child ) { $cat_info[$child]['show'] = 1; } } $cat_parent = $cat_info[$current_cat]['parent']; if ($cat_parent && ($args['show_siblings'] == 'yes')) { // if showing siblings, add the current category's parent's other children. foreach ( $cat_info[$cat_parent]['children'] as $child ) { $cat_info[$child]['show'] = 1; } # Also show parent node's siblings. $cat_grandparent = $cat_info[$cat_parent]['parent']; if ($cat_grandparent) { foreach ( $cat_info[$cat_grandparent]['children'] as $child ) { $cat_info[$child]['show'] = 1; } } } // add all ancestors of the current category. while ($cat_parent) { $cat_info[$cat_parent]['show'] = 1; $cat_parent = $cat_info[$cat_parent]['parent']; } } $my_includes = Array(); // Add categories that were selected foreach ( $cats as $cat ) { if ($cat_info[$cat->term_id]['show']) { $my_includes[] =$cat->term_id; } } if (!empty($my_includes)) { // List categories, if any. Blank title_li suppresses unwanted elements. $qargs = Array('title_li' => '', 'hide_empty' => 0, 'include' => $my_includes, 'order' => $args['order'], 'orderby' => $args['orderby'], 'show_count' => $args['show_count']); if (!empty($args['taxonomy'])) { $qargs['taxonomy'] = $args['taxonomy']; } $output .= wp_list_categories( $qargs ); } } $output = apply_filters('wp_list_categories', $output); if ( $args['echo'] ) echo $output; else return $output; } function known_params ($options = 0) { $option_menu = array('title' => array('title' => 'Title:'), 'show_siblings' => array('title' => 'Show siblings to the current category?', 'type' => 'checkbox'), 'include' => array('title' => 'Include:', 'desc' => 'Comma-delimited list of category IDs, or blank for all'), 'exclude' => array('title' => 'Exclude:'), 'orderby' => array('title' => 'Sort field:', 'desc' => 'Enter one of: <em>name, count, term_group, slug</em> or a custom value. Default: name'), 'order' => array('title' => 'Sort direction:', 'desc' => '(default: ASC)'), 'child_of' => array('title' => 'Only display Categories below this ID'), 'hide_empty' => array('title' => 'Hide empty categories?', 'type' => 'checkbox'), 'show_count' => array('title' => 'Show count of category entries?', 'type' => 'checkbox'), 'taxonomy' => array('title' => 'Custom taxonomy:'), ); if ($options) { $taxons = get_taxonomies(); $option_menu['taxonomy']['desc'] = 'Enter one of: <em>' . implode(', ',array_keys($taxons)) . '</em> or blank for post categories.'; } return ($options ? $option_menu : array_keys($option_menu)); } /** * Displays the Widget * */ function widget($args, $instance){ $known_params = $this->known_params(0); foreach ($known_params as $param) { if (strlen($instance[$param])) $cat_options[$param] = $instance[$param]; } $cat_options['title'] = apply_filters('widget_title', $cat_options['title']); // WordPress defaults to hiding: thus, always specify. $cat_options['hide_empty'] = $cat_options['hide_empty'] == 'yes' ? 1 : 0; print $args['before_widget']; if ( strlen($cat_options['title']) ) print "{$args['before_title']}{$cat_options['title']}{$args['after_title']}"; print "<ul>"; $this->hiercat_list_cats($cat_options); print "</ul>{$after_widget}"; } /** * Saves the widget's settings. * */ function update($new_instance, $old_instance){ $instance = $old_instance; $known_params = $this->known_params(); foreach ($known_params as $param) { $instance[$param] = strip_tags(stripslashes($new_instance[$param])); } return $instance; } /** * Creates the edit form for the widget. * */ function form($instance){ //Defaults $instance = wp_parse_args( (array) $instance, array('title'=>'') ); $this->form_html($instance); } }// END class /** * Register Hierarchical Categories widget. * * Calls 'widgets_init' action after the widget has been registered. */ function HierCatInit() { register_widget('HierCatWidget'); } /* * Initialize both widgets */ add_action('widgets_init', 'HierCatInit'); add_action('widgets_init', 'HierPageInit'); ?>
更改後文本
開啟檔案
<?php /* Plugin Name: Hierarchical Pages Version: 1.4 Plugin URI: http://www.saltriversystems.com/website/hierpage/ Description: Adds sidebar widgets to display a context-based list of "nearby" pages, and to display nested categories. Author: William Lindley Author URI: http://www.wlindley.com/ License: GPL2 */ /* Copyright 2007-2012 William Lindley (email : wlindley -at- wlindley -dot- com) This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ if (!class_exists('SRCS_WP_Widget')) { class SRCS_WP_Widget extends WP_Widget { function form_html($instance) { $option_menu = $this->known_params(1); foreach (array_keys($option_menu) as $param) { $param_display[$param] = htmlspecialchars($instance[$param]); } foreach ($option_menu as $option_name => $option) { $checkval=''; $desc = ''; if ($option['desc']) $desc = "<br /><small>{$option['desc']}</small>"; switch ($option['type']) { case 'checkbox': if ($instance[$option_name]) // special HTML and override value $checkval = 'checked="yes" '; $param_display[$option_name] = 'yes'; break; case '': $option['type'] = 'text'; break; } print '<p style="text-align:right;"><label for="' . $this->get_field_name($option_name) . '">' . __($option['title']) . ' <input style="width: 200px;" id="' . $this->get_field_id($option_name) . '" name="' . $this->get_field_name($option_name) . "\" type=\"{$option['type']}\" {$checkval}value=\"{$param_display[$option_name]}\" /></label>$desc</p>"; } } } } class HierPageWidget extends SRCS_WP_Widget { /** * Declares the HierPageWidget class. * */ function HierPageWidget(){ $widget_ops = array('classname' => 'widget_hier_page', 'description' => __( "Hierarchical Page Directory Widget") ); $control_ops = array('width' => 300, 'height' => 300); $this->WP_Widget('hierpage', __('Hierarchical Pages'), $widget_ops, $control_ops); } /** * Helper function * */ function hierpages_list_pages($args = '') { global $post; global $wp_query; if ( !isset($args['echo']) ) $args['echo'] = 1; $output = ''; if(!$args['post_type'])$args['post_type'] = 'page'; // Query pages. NOTE: The array is sorted in alphabetical, or menu, order. $pages = & get_pages($args); $page_info = Array(); if ( $pages ) { $current_post = $wp_query->get_queried_object_id(); foreach ( $pages as $page ) { $page_info[$page->ID]['parent'] = $page->post_parent; $page_info[$page->post_parent]['children'][] = $page->ID; } // Display the front page? $front_page = -1; // assume no static front page if ('page' == get_option('show_on_front')) { $front_page = get_option('page_on_front'); // Regard flag: always show front page? Otherwise: Show front page only if it has children if (($args['show_home'] == 'yes') || (sizeof($page_info[$front_page]['children']))) { $page_info[$front_page]['show'] = 1; // always show front page } } // add all children of the root node, but only to single depth. if ($args['show_root'] == 'yes') { foreach ( $page_info[0]['children'] as $child ) { if ($child != $front_page) { $page_info[$child]['show'] = 1; } } } if (is_post_type_hierarchical($args['post_type'])) { if ($post->ID != $front_page ) { // The current page is always shown, unless it is the static front page (see above) $page_info[$post->ID]['show'] = 1; } // show the current page's children, if any. if (is_array($page_info[$current_post]['children'] )) { foreach ( $page_info[$current_post]['children'] as $child ) { $page_info[$child]['show'] = 1; } } $post_parent = $page_info[$current_post]['parent']; if ($post_parent && ($args['show_siblings'] == 'yes')) { // if showing siblings, add the current page's parent's other children. foreach ( $page_info[$post_parent]['children'] as $child ) { if ($child != $front_page) { $page_info[$child]['show'] = 1; } } // Also show parent node's siblings. $post_grandparent = $page_info[$post_parent]['parent']; if ($post_grandparent) { foreach ( $page_info[$post_grandparent]['children'] as $child ) { if ($child != $front_page) { $page_info[$child]['show'] = 1; } } } } // add all ancestors of the current page. while ($post_parent) { $page_info[$post_parent]['show'] = 1; // show that page's children, if any. if (is_array($page_info[$post_parent]['children'] )) { foreach ( $page_info[$post_parent]['children'] as $child ) { $page_info[$child]['show'] = 1; } } $post_parent = $page_info[$post_parent]['parent']; } } // Add pages that were selected $my_includes = Array(); foreach ( $pages as $page ) { if ($page_info[$page->ID]['show']) { $my_includes[] = $page->ID; } } if ($args['child_of']) { $my_includes[] = $args['child_of']; } if (!empty($my_includes)) { // List pages, if any. Blank title_li suppresses unwanted elements. $output .= wp_list_pages( Array('title_li' => '', 'sort_column' => $args['sort_column'], 'sort_order' => $args['sort_order'], 'include' => $my_includes, 'post_type'=> $args['post_type'] ) ); } } $output = apply_filters('wp_list_pages', $output); if ( $args['echo'] ) echo $output; else return $output; } /** * Displays the Widget * */ function widget($args, $instance){ $title = apply_filters('widget_title', empty($instance['title']) ? '' : $instance['title']); $known_params = $this->known_params(0); foreach ($known_params as $param) { if (strlen($instance[$param])) { $page_options[$param] = $instance[$param]; } } if ($instance['menu_order'] == 'yes') { // Deprecated, eliminated upon form display (see below) $page_options['sort_column']='menu_order,post_title'; } print $args['before_widget']; if ( $title ) print "{$args['before_title']}{$title}{$args['after_title']}"; print '<ul>'; $this->hierpages_list_pages($page_options); print "</ul>{$args['after_widget']}"; } function known_params ($options = 0) { $option_menu = array('title' => array('title' => 'Title:'), 'show_siblings' => array('title' => 'Show siblings to the current page?', 'type' => 'checkbox'), 'show_root' => array('title' => 'Always show top-level pages?', 'type' => 'checkbox'), 'show_home' => array('title' => 'Show the static home page?', 'desc' => '(always shown if it has child pages)', 'type' => 'checkbox'), 'child_of' => array('title' => 'Root page ID:'), 'exclude' => array('title' => 'Exclude pages:', 'desc' => 'List of page IDs to exclude'), 'sort_column' => array('title' => 'Sort field:', 'desc' => 'Comma-separated list: <em>post_title, menu_order, post_date, post_modified, ID, post_author, post_name</em>'), 'sort_order' => array('title' => 'Sort direction:', 'desc' => '(default: ASC)'), 'meta_key' => array('title' => 'Meta Key:'), 'meta_value' => array('title' => 'Meta-key Value:', 'desc' => 'for selecting pages by custom fields'), 'authors' => array('title' => 'Authors:'), 'post_status' => array('title' => 'Post status:', 'desc' => '(default: publish)'), 'post_type' => array('title' => 'Post type:', 'desc' => '(default: page)'), ); return ($options ? $option_menu : array_keys($option_menu)); } /** * Saves the widget's settings. * */ function update($new_instance, $old_instance){ $instance = $old_instance; $known_params = $this->known_params(); unset($instance['menu_order']); foreach ($known_params as $param) { $instance[$param] = strip_tags(stripslashes($new_instance[$param])); } $instance['sort_order'] = strtolower($instance['sort_order']) == 'desc'?'DESC':'ASC'; return $instance; } /** * Creates the edit form for the widget. * */ function form($instance){ $instance = wp_parse_args( (array) $instance, array('title'=>'') ); if ($instance['menu_order']) { $instance['sort_column'] = 'menu_order,post_title'; } if (empty($instance['sort_column'])) { $instance['sort_column'] = 'post_title'; } $this->form_html($instance); } }// END class /** * Register Hierarchical Pages widget. * * Calls 'widgets_init' action after the widget has been registered. */ function HierPageInit() { register_widget('HierPageWidget'); } /* * Plugin Name: Hierarchical Categories (combined with Hierarchical Pages) * Plugin URI: http://www.wlindley.com/ * Description: Adds a sidebar widget to display a context-based list of "nearby" categories. * Author: William Lindley * Author URI: http://www.wlindley.com/ */ class HierCatWidget extends SRCS_WP_Widget { /** * Declares our class. * */ function HierCatWidget(){ $widget_ops = array('classname' => 'widget_hier_cat', 'description' => __( "Hierarchical Category Widget") ); $control_ops = array('width' => 300, 'height' => 300); $this->WP_Widget('hiercat', __('Hierarchical Categories'), $widget_ops, $control_ops); } /** * Helper function * */ function hiercat_list_cats($args) { global $post; global $wp_query; if ( !isset($args['echo']) ) $args['echo'] = 1; $sort_column = $args['sort_column']; $output = ''; // Query categories. $cats = & get_categories($args); if ($cats['errors']) { print "<pre>"; print_r($cats); print "</pre>"; return; } $cat_info = Array(); if ( $cats ) { $current_cat = $wp_query->get_queried_object_id(); foreach ( $cats as $cat ) { $cat_info[$cat->term_id]['parent'] = $cat->category_parent; $cat_info[$cat->category_parent]['children'][] = $cat->term_id; } // add all children of the root node, but only to single depth. foreach ( $cat_info[0]['children'] as $child ) { $cat_info[$child]['show'] = 1; } // If currently displaying a category, taxonomy, or tag; AND // if it is the same as the one in this widget... if ((is_category() || is_tax() || is_tag()) && ($args['taxonomy'] == get_queried_object()->taxonomy ) ) { // show the current category's children, if any. if (is_array($cat_info[$current_cat]['children'] )) { foreach ( $cat_info[$current_cat]['children'] as $child ) { $cat_info[$child]['show'] = 1; } } $cat_parent = $cat_info[$current_cat]['parent']; if ($cat_parent && ($args['show_siblings'] == 'yes')) { // if showing siblings, add the current category's parent's other children. foreach ( $cat_info[$cat_parent]['children'] as $child ) { $cat_info[$child]['show'] = 1; } # Also show parent node's siblings. $cat_grandparent = $cat_info[$cat_parent]['parent']; if ($cat_grandparent) { foreach ( $cat_info[$cat_grandparent]['children'] as $child ) { $cat_info[$child]['show'] = 1; } } } // add all ancestors of the current category. while ($cat_parent) { $cat_info[$cat_parent]['show'] = 1; $cat_parent = $cat_info[$cat_parent]['parent']; } } $my_includes = Array(); // Add categories that were selected foreach ( $cats as $cat ) { if ($cat_info[$cat->term_id]['show']) { $my_includes[] =$cat->term_id; } } if (!empty($my_includes)) { // List categories, if any. Blank title_li suppresses unwanted elements. $qargs = Array('title_li' => '', 'hide_empty' => 0, 'include' => $my_includes, 'order' => $args['order'], 'orderby' => $args['orderby'], 'show_count' => $args['show_count']); if (!empty($args['taxonomy'])) { $qargs['taxonomy'] = $args['taxonomy']; } $output .= wp_list_categories( $qargs ); } } $output = apply_filters('wp_list_categories', $output); if ( $args['echo'] ) echo $output; else return $output; } function known_params ($options = 0) { $option_menu = array('title' => array('title' => 'Title:'), 'show_siblings' => array('title' => 'Show siblings to the current category?', 'type' => 'checkbox'), 'include' => array('title' => 'Include:', 'desc' => 'Comma-delimited list of category IDs, or blank for all'), 'exclude' => array('title' => 'Exclude:'), 'orderby' => array('title' => 'Sort field:', 'desc' => 'Enter one of: <em>name, count, term_group, slug</em> or a custom value. Default: name'), 'order' => array('title' => 'Sort direction:', 'desc' => '(default: ASC)'), 'child_of' => array('title' => 'Only display Categories below this ID'), 'hide_empty' => array('title' => 'Hide empty categories?', 'type' => 'checkbox'), 'show_count' => array('title' => 'Show count of category entries?', 'type' => 'checkbox'), 'taxonomy' => array('title' => 'Custom taxonomy:'), ); if ($options) { $taxons = get_taxonomies(); $option_menu['taxonomy']['desc'] = 'Enter one of: <em>' . implode(', ',array_keys($taxons)) . '</em> or blank for post categories.'; } return ($options ? $option_menu : array_keys($option_menu)); } /** * Displays the Widget * */ function widget($args, $instance){ $known_params = $this->known_params(0); foreach ($known_params as $param) { if (strlen($instance[$param])) $cat_options[$param] = $instance[$param]; } $cat_options['title'] = apply_filters('widget_title', $cat_options['title']); // WordPress defaults to hiding: thus, always specify. $cat_options['hide_empty'] = $cat_options['hide_empty'] == 'yes' ? 1 : 0; print $args['before_widget']; if ( strlen($cat_options['title']) ) print "{$args['before_title']}{$cat_options['title']}{$args['after_title']}"; print "<ul>"; $this->hiercat_list_cats($cat_options); print "</ul>{$after_widget}"; } /** * Saves the widget's settings. * */ function update($new_instance, $old_instance){ $instance = $old_instance; $known_params = $this->known_params(); foreach ($known_params as $param) { $instance[$param] = strip_tags(stripslashes($new_instance[$param])); } return $instance; } /** * Creates the edit form for the widget. * */ function form($instance){ //Defaults $instance = wp_parse_args( (array) $instance, array('title'=>'') ); $this->form_html($instance); } }// END class /** * Register Hierarchical Categories widget. * * Calls 'widgets_init' action after the widget has been registered. */ function HierCatInit() { register_widget('HierCatWidget'); } /* * Initialize both widgets */ add_action('widgets_init', 'HierCatInit'); add_action('widgets_init', 'HierPageInit'); ?>
尋找差異