Version Description
Download this release
Release Info
Developer | Mat Lipe |
Plugin | Advanced Sidebar Menu |
Version | 5.0.4 |
Comparing to | |
See all releases |
Code changes from version 5.0.3 to 5.0.4
- advanced-sidebar-menu.php +2 -2
- classes/Advanced_Sidebar_Menu_Deprecated.php +3 -1
- classes/advancedSidebarMenu.php +31 -10
- readme.txt +2 -2
- widgets/page.widget.php +303 -260
advanced-sidebar-menu.php
CHANGED
@@ -4,11 +4,11 @@ Plugin Name: Advanced Sidebar Menu
|
|
4 |
Plugin URI: http://matlipe.com/advanced-sidebar-menu/
|
5 |
Description: Creates dynamic menu based on child/parent relationship.
|
6 |
Author: Mat Lipe
|
7 |
-
Version: 5.0.
|
8 |
Author URI: http://matlipe.com
|
9 |
*/
|
10 |
|
11 |
-
define( 'ADVANCED_SIDEBAR_BASIC_VERSION', '5.0.
|
12 |
|
13 |
|
14 |
#-- Define Constants
|
4 |
Plugin URI: http://matlipe.com/advanced-sidebar-menu/
|
5 |
Description: Creates dynamic menu based on child/parent relationship.
|
6 |
Author: Mat Lipe
|
7 |
+
Version: 5.0.4
|
8 |
Author URI: http://matlipe.com
|
9 |
*/
|
10 |
|
11 |
+
define( 'ADVANCED_SIDEBAR_BASIC_VERSION', '5.0.4' );
|
12 |
|
13 |
|
14 |
#-- Define Constants
|
classes/Advanced_Sidebar_Menu_Deprecated.php
CHANGED
@@ -16,7 +16,9 @@ class Advanced_Sidebar_Menu_Deprecated {
|
|
16 |
function page_children( $pID ) {
|
17 |
global $wpdb, $table_prefix;
|
18 |
|
19 |
-
|
|
|
|
|
20 |
|
21 |
}
|
22 |
|
16 |
function page_children( $pID ) {
|
17 |
global $wpdb, $table_prefix;
|
18 |
|
19 |
+
_deprecated_function( 'advancedSidebarMenu::page_children', "5.0.0", 'advancedSidebarMenu::hasChildren' );
|
20 |
+
|
21 |
+
return $wpdb->get_results( "SELECT ID FROM " . $table_prefix . "posts WHERE post_parent = " . $pID . " AND post_type = $this->post_type AND post_status='publish' ORDER By " . $this->order_by );
|
22 |
|
23 |
}
|
24 |
|
classes/advancedSidebarMenu.php
CHANGED
@@ -18,25 +18,46 @@ class advancedSidebarMenu extends Advanced_Sidebar_Menu_Deprecated {
|
|
18 |
var $order_by;
|
19 |
var $taxonomy; //For filters to override the taxonomy
|
20 |
var $current_term; //Current category or taxonomy
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
21 |
public $levels = 100;
|
22 |
|
23 |
|
24 |
/**
|
25 |
-
* Check is a
|
26 |
*
|
27 |
* @since 8.29.13
|
28 |
*
|
29 |
* @param int $postId
|
|
|
|
|
30 |
*/
|
31 |
-
function hasChildren( $postId )
|
32 |
-
|
33 |
-
|
34 |
-
|
35 |
-
|
36 |
-
|
37 |
-
|
38 |
-
|
39 |
-
|
|
|
40 |
if( count( $children ) != 0 ){
|
41 |
return true;
|
42 |
} else {
|
18 |
var $order_by;
|
19 |
var $taxonomy; //For filters to override the taxonomy
|
20 |
var $current_term; //Current category or taxonomy
|
21 |
+
|
22 |
+
/**
|
23 |
+
* args
|
24 |
+
*
|
25 |
+
* Widget Args
|
26 |
+
*
|
27 |
+
* @var array
|
28 |
+
*/
|
29 |
+
public $args = array();
|
30 |
+
|
31 |
+
/**
|
32 |
+
* post_type
|
33 |
+
*
|
34 |
+
* @var string
|
35 |
+
*/
|
36 |
+
public $post_type = 'page';
|
37 |
+
|
38 |
+
|
39 |
public $levels = 100;
|
40 |
|
41 |
|
42 |
/**
|
43 |
+
* Check is a post has children by id
|
44 |
*
|
45 |
* @since 8.29.13
|
46 |
*
|
47 |
* @param int $postId
|
48 |
+
*
|
49 |
+
* @return bool
|
50 |
*/
|
51 |
+
function hasChildren( $postId ){
|
52 |
+
$args = array(
|
53 |
+
'post_parent' => $postId,
|
54 |
+
'fields' => 'ids',
|
55 |
+
'post_type' => get_post_type( $postId ),
|
56 |
+
'post_status' => 'publish'
|
57 |
+
);
|
58 |
+
|
59 |
+
$children = get_children( $args );
|
60 |
+
|
61 |
if( count( $children ) != 0 ){
|
62 |
return true;
|
63 |
} else {
|
readme.txt
CHANGED
@@ -4,8 +4,8 @@ Contributors: Mat Lipe
|
|
4 |
Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=paypal%40lipeimagination%2einfo&lc=US&item_name=Advanced%20Sidebar%20Menu&no_note=0¤cy_code=USD&bn=PP%2dDonationsBF%3abtn_donateCC_LG%2egif%3aNonHostedGuest
|
5 |
Tags: menus, sidebar menu, heirchy, category menu, pages menu
|
6 |
Requires at least: 3.8.0
|
7 |
-
Tested up to: 4.1.
|
8 |
-
Stable tag: 5.0.
|
9 |
|
10 |
Creates a widget for both page and categories that will display the current page/category and all child pages or categories.
|
11 |
|
4 |
Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=paypal%40lipeimagination%2einfo&lc=US&item_name=Advanced%20Sidebar%20Menu&no_note=0¤cy_code=USD&bn=PP%2dDonationsBF%3abtn_donateCC_LG%2egif%3aNonHostedGuest
|
5 |
Tags: menus, sidebar menu, heirchy, category menu, pages menu
|
6 |
Requires at least: 3.8.0
|
7 |
+
Tested up to: 4.1.1
|
8 |
+
Stable tag: 5.0.4
|
9 |
|
10 |
Creates a widget for both page and categories that will display the current page/category and all child pages or categories.
|
11 |
|
widgets/page.widget.php
CHANGED
@@ -1,265 +1,308 @@
|
|
1 |
-
<?php
|
2 |
-
|
3 |
-
|
4 |
-
|
5 |
-
|
6 |
-
|
7 |
-
|
8 |
-
|
9 |
-
|
10 |
-
|
11 |
-
|
12 |
-
|
|
|
|
|
13 |
class advanced_sidebar_menu_page extends WP_Widget {
|
14 |
-
|
15 |
-
|
16 |
-
|
17 |
-
|
18 |
-
|
19 |
-
|
20 |
-
|
21 |
-
|
22 |
-
|
23 |
-
|
24 |
-
|
25 |
-
|
26 |
-
|
27 |
-
|
28 |
-
|
29 |
-
|
30 |
-
|
31 |
-
|
32 |
-
|
33 |
-
|
34 |
-
|
35 |
-
|
36 |
-
|
37 |
-
|
38 |
-
|
39 |
-
'description' => __('Creates a menu of all the pages using the child/parent relationship', 'advanced-sidebar-menu')
|
40 |
);
|
41 |
-
|
42 |
-
|
43 |
);
|
44 |
|
45 |
-
|
46 |
-
|
47 |
-
|
48 |
-
|
49 |
-
|
50 |
-
|
51 |
-
|
52 |
-
|
53 |
-
|
54 |
-
|
55 |
-
|
56 |
-
|
57 |
-
|
58 |
-
|
59 |
-
|
60 |
-
|
61 |
-
|
62 |
-
|
63 |
-
|
64 |
-
|
65 |
-
|
66 |
-
|
67 |
-
|
68 |
-
|
69 |
-
|
70 |
-
|
71 |
-
|
72 |
-
|
73 |
-
|
74 |
-
|
75 |
-
|
76 |
-
|
77 |
-
|
78 |
-
|
79 |
-
|
80 |
-
|
81 |
-
|
82 |
-
|
83 |
-
|
84 |
-
|
85 |
-
|
86 |
-
|
87 |
-
|
88 |
-
|
89 |
-
|
90 |
-
|
91 |
-
|
92 |
-
|
93 |
-
|
94 |
-
|
95 |
-
|
96 |
-
|
97 |
-
|
98 |
-
|
99 |
-
|
100 |
-
|
101 |
-
|
102 |
-
|
103 |
-
|
104 |
-
|
105 |
-
|
106 |
-
|
107 |
-
|
108 |
-
|
109 |
-
|
110 |
-
|
111 |
-
|
112 |
-
|
113 |
-
|
114 |
-
|
115 |
-
|
116 |
-
|
117 |
-
|
118 |
-
|
119 |
-
|
120 |
-
|
121 |
-
|
122 |
-
|
123 |
-
|
124 |
-
|
125 |
-
|
126 |
-
|
127 |
-
|
128 |
-
|
129 |
-
|
130 |
-
|
131 |
-
|
132 |
-
|
133 |
-
|
134 |
-
|
135 |
-
|
136 |
-
|
137 |
-
|
138 |
-
|
139 |
-
|
140 |
-
|
141 |
-
|
142 |
-
|
143 |
-
* Handles the saving of the widget
|
144 |
-
*
|
145 |
-
* @filters apply_filters('advanced_sidebar_menu_page_widget_update', $newInstance, $oldInstance );
|
146 |
-
*
|
147 |
-
* @since 4.26.13
|
148 |
-
*/
|
149 |
-
function update( $newInstance, $oldInstance ) {
|
150 |
-
$newInstance['exclude'] = strip_tags($newInstance['exclude']);
|
151 |
-
|
152 |
-
$newInstance = apply_filters('advanced_sidebar_menu_page_widget_update', $newInstance, $oldInstance );
|
153 |
-
|
154 |
-
return $newInstance;
|
155 |
-
}
|
156 |
-
|
157 |
-
|
158 |
-
#---------------------------------------------------------------------------------------------------------------------------
|
159 |
-
|
160 |
-
/**
|
161 |
-
* Outputs the page list
|
162 |
-
* @see WP_Widget::widget()
|
163 |
-
*
|
164 |
-
* @uses for custom post types send the type to the filter titled 'advanced_sidebar_menu_post_type'
|
165 |
-
* @uses change the top parent manually with the filter 'advanced_sidebar_menu_top_parent'
|
166 |
-
* @uses change the order of the 2nd level pages with 'advanced_sidebar_menu_order_by' filter
|
167 |
-
*
|
168 |
-
* @filter apply_filters('advanced_sidebar_menu_page_widget_output',$content, $args, $instance );
|
169 |
-
* apply_filters('advanced_sidebar_menu_order_by', 'menu_order', $post, $args, $instance );
|
170 |
-
* apply_filters('advanced_sidebar_menu_top_parent', $top_parent, $post, $args, $instance );
|
171 |
-
* apply_filters('advanced_sidebar_menu_post_type', 'page', $args, $instance );
|
172 |
-
*
|
173 |
-
*
|
174 |
-
*
|
175 |
-
* @see Geansai - pointed out a notice level error. Thanks Geansai!!
|
176 |
-
*/
|
177 |
-
function widget($args, $instance) {
|
178 |
-
global $wpdb, $post, $table_prefix;
|
179 |
-
|
180 |
-
$asm = new advancedSidebarMenu();
|
181 |
-
$asm->instance = $instance;
|
182 |
-
$asm->args = $args;
|
183 |
-
|
184 |
-
do_action( 'advanced_sidebar_menu_widget_pre_render', $asm, $this );
|
185 |
-
|
186 |
-
//The excluded pages
|
187 |
-
$exclude = apply_filters( 'advanced_sidebar_menu_excluded_pages', explode(',', $instance['exclude']), $post, $args, $instance, $asm );
|
188 |
-
$asm->exclude = $exclude;
|
189 |
-
|
190 |
-
extract($args);
|
191 |
-
|
192 |
-
//Filter this one with a 'single' for a custom post type will default to working for pages only
|
193 |
-
$post_type = apply_filters('advanced_sidebar_menu_post_type', 'page', $args, $instance, $asm );
|
194 |
-
$asm->post_type = $post_type;
|
195 |
-
|
196 |
-
//Add a has_children class to appropriate pages
|
197 |
-
add_filter( 'page_css_class', array( $asm, 'hasChildrenClass' ), 2, 2 );
|
198 |
-
|
199 |
-
//Add the default classes to pages from a custom post type
|
200 |
-
if( $asm->post_type != 'page' ){
|
201 |
-
add_filter( 'page_css_class', array( $asm, 'custom_post_type_css' ), 2, 4 );
|
202 |
-
}
|
203 |
-
|
204 |
-
|
205 |
-
$proper_single = !( is_page() || ( is_single() && $asm->post_type == get_post_type() ) );
|
206 |
-
//Filter the single post check if try to display the menu somewhere else like a category page
|
207 |
-
if( apply_filters( 'advanced_sidebar_menu_proper_single', $proper_single, $args, $instance, $asm ) ){
|
208 |
-
return;
|
209 |
}
|
210 |
-
|
211 |
-
|
212 |
-
|
213 |
-
|
214 |
-
|
215 |
-
|
216 |
-
|
217 |
-
|
218 |
-
|
219 |
-
|
220 |
-
|
221 |
-
|
222 |
-
|
223 |
-
|
224 |
-
|
225 |
-
|
226 |
-
|
227 |
-
|
228 |
-
|
229 |
-
|
230 |
-
|
231 |
-
|
232 |
-
|
233 |
-
|
234 |
-
|
235 |
-
|
236 |
-
|
237 |
-
|
238 |
-
|
239 |
-
|
240 |
-
|
241 |
-
|
242 |
-
|
243 |
-
|
244 |
-
|
245 |
-
|
246 |
-
|
247 |
-
|
248 |
-
|
249 |
-
|
250 |
-
|
251 |
-
|
252 |
-
|
253 |
-
|
254 |
-
|
255 |
-
|
256 |
-
|
257 |
-
|
258 |
-
|
259 |
-
|
260 |
-
|
261 |
-
|
262 |
-
|
263 |
-
|
264 |
-
|
265 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
<?php
|
2 |
+
|
3 |
+
|
4 |
+
/**
|
5 |
+
* Advanced Sidebar Menu Page
|
6 |
+
*
|
7 |
+
* Creates a Widget of parent Child Pages
|
8 |
+
*
|
9 |
+
* @author mat lipe <mat@matlipe.com>
|
10 |
+
*
|
11 |
+
* @package Advanced Sidebar Menu
|
12 |
+
* @class advanced_sidebar_menu_page
|
13 |
+
*
|
14 |
+
*/
|
15 |
class advanced_sidebar_menu_page extends WP_Widget {
|
16 |
+
|
17 |
+
private $defaults = array(
|
18 |
+
'title' => false,
|
19 |
+
'include_parent' => false,
|
20 |
+
'include_childless_parent' => false,
|
21 |
+
'order_by' => 'menu_order',
|
22 |
+
'css' => false,
|
23 |
+
'exclude' => false,
|
24 |
+
'legacy_mode' => false,
|
25 |
+
'display_all' => false,
|
26 |
+
'levels' => 1
|
27 |
+
);
|
28 |
+
|
29 |
+
|
30 |
+
/**
|
31 |
+
* Build the widget like a BOSS
|
32 |
+
*
|
33 |
+
* @since 4.5.13
|
34 |
+
*
|
35 |
+
*/
|
36 |
+
function __construct(){
|
37 |
+
/* Widget settings. */
|
38 |
+
$widget_ops = array(
|
39 |
+
'classname' => 'advanced-sidebar-menu',
|
40 |
+
'description' => __( 'Creates a menu of all the pages using the child/parent relationship', 'advanced-sidebar-menu' )
|
|
|
41 |
);
|
42 |
+
$control_ops = array(
|
43 |
+
'width' => 290
|
44 |
);
|
45 |
|
46 |
+
/* Create the widget. */
|
47 |
+
$this->WP_Widget( 'advanced_sidebar_menu', __( 'Advanced Sidebar Pages Menu', 'advanced-sidebar-menu' ), $widget_ops, $control_ops );
|
48 |
+
|
49 |
+
}
|
50 |
+
|
51 |
+
|
52 |
+
/**
|
53 |
+
* Output a simple widget Form
|
54 |
+
* Not of ton of options here but who need them
|
55 |
+
* Most of the magic happens automatically
|
56 |
+
*
|
57 |
+
* @filters do_action('advanced_sidebar_menu_page_widget_form', $instance, $this->get_field_name('parent_only'), $this->get_field_id('parent_only'));
|
58 |
+
*
|
59 |
+
* @since 11.4.13
|
60 |
+
*/
|
61 |
+
function form( $instance ){
|
62 |
+
|
63 |
+
$instance = wp_parse_args( $instance, $this->defaults );
|
64 |
+
|
65 |
+
?>
|
66 |
+
<p> <?php _e( 'Title', 'advanced-sidebar-menu' ); ?>
|
67 |
+
<br>
|
68 |
+
<input id="<?php echo $this->get_field_id( 'title' ); ?>"
|
69 |
+
name="<?php echo $this->get_field_name( 'title' ); ?>" class="widefat" type="text" value="<?php echo $instance[ 'title' ]; ?>"/>
|
70 |
+
</p>
|
71 |
+
|
72 |
+
<p> <?php _e( 'Include Parent Page', 'advanced-sidebar-menu' ); ?>:
|
73 |
+
<input id="<?php echo $this->get_field_id( 'include_parent' ); ?>"
|
74 |
+
name="<?php echo $this->get_field_name( 'include_parent' ); ?>" type="checkbox" value="checked"
|
75 |
+
<?php echo $instance[ 'include_parent' ]; ?>/>
|
76 |
+
</p>
|
77 |
+
|
78 |
+
|
79 |
+
<p> <?php _e( 'Include Parent Even With No Children', 'advanced-sidebar-menu' ); ?>:
|
80 |
+
<input id="<?php echo $this->get_field_id( 'include_childless_parent' ); ?>"
|
81 |
+
name="<?php echo $this->get_field_name( 'include_childless_parent' ); ?>" type="checkbox" value="checked"
|
82 |
+
<?php echo $instance[ 'include_childless_parent' ]; ?>/>
|
83 |
+
</p>
|
84 |
+
|
85 |
+
<p> <?php _e( 'Order By', 'advanced-sidebar-menu' ); ?>:
|
86 |
+
<select id="<?php echo $this->get_field_id( 'order_by' ); ?>"
|
87 |
+
name="<?php echo $this->get_field_name( 'order_by' ); ?>">
|
88 |
+
<?php
|
89 |
+
|
90 |
+
$order_by = array(
|
91 |
+
'menu_order' => 'Page Order',
|
92 |
+
'post_title' => 'Title',
|
93 |
+
'post_date' => 'Published Date'
|
94 |
+
);
|
95 |
+
|
96 |
+
foreach( $order_by as $key => $order ){
|
97 |
+
|
98 |
+
printf( '<option value="%s" %s>%s</option>', $key, selected( $instance[ 'order_by' ], $key, false ), $order );
|
99 |
+
}
|
100 |
+
?>
|
101 |
+
</select>
|
102 |
+
</p>
|
103 |
+
|
104 |
+
<p> <?php _e( "Use this Plugin's Styling", 'advanced-sidebar-menu' ); ?>:
|
105 |
+
<input id="<?php echo $this->get_field_id( 'css' ); ?>"
|
106 |
+
name="<?php echo $this->get_field_name( 'css' ); ?>" type="checkbox" value="checked"
|
107 |
+
<?php echo $instance[ 'css' ]; ?>/>
|
108 |
+
</p>
|
109 |
+
|
110 |
+
<p> <?php _e( "Pages to Exclude (ids), Comma Separated", 'advanced-sidebar-menu' ); ?>:
|
111 |
+
<input id="<?php echo $this->get_field_id( 'exclude' ); ?>"
|
112 |
+
name="<?php echo $this->get_field_name( 'exclude' ); ?>" class="widefat" type="text" value="<?php echo $instance[ 'exclude' ]; ?>"/>
|
113 |
+
</p>
|
114 |
+
|
115 |
+
<p> <?php _e( "Legacy Mode: (use pre 4.0 structure and css)", 'advanced-sidebar-menu' ); ?>
|
116 |
+
<input id="<?php echo $this->get_field_name( 'legacy_mode' ); ?>"
|
117 |
+
name="<?php echo $this->get_field_name( 'legacy_mode' ); ?>" type="checkbox" value="checked"
|
118 |
+
<?php echo $instance[ 'legacy_mode' ]; ?>/>
|
119 |
+
</p>
|
120 |
+
|
121 |
+
<p> <?php _e( "Always Display Child Pages", 'advanced-sidebar-menu' ); ?>:
|
122 |
+
<input id="<?php echo $this->get_field_id( 'display_all' ); ?>"
|
123 |
+
name="<?php echo $this->get_field_name( 'display_all' ); ?>" type="checkbox" value="checked"
|
124 |
+
onclick="javascript:asm_reveal_element( 'levels-<?php echo $this->get_field_id( 'levels' ); ?>' )"
|
125 |
+
<?php echo $instance[ 'display_all' ]; ?>/>
|
126 |
+
</p>
|
127 |
+
|
128 |
+
<span id="levels-<?php echo $this->get_field_id( 'levels' ); ?>" style="<?php
|
129 |
+
if( $instance[ 'display_all' ] == 'checked' ){
|
130 |
+
echo 'display:block';
|
131 |
+
} else {
|
132 |
+
echo 'display:none';
|
133 |
+
} ?>">
|
134 |
+
<p> <?php _e( "Levels to Display", 'advanced-sidebar-menu' ); ?>:
|
135 |
+
<select id="<?php echo $this->get_field_id( 'levels' ); ?>"
|
136 |
+
name="<?php echo $this->get_field_name( 'levels' ); ?>">
|
137 |
+
<?php
|
138 |
+
for( $i = 1; $i < 6; $i ++ ){
|
139 |
+
if( $i == $instance[ 'levels' ] ){
|
140 |
+
echo '<option value="' . $i . '" selected>' . $i . '</option>';
|
141 |
+
} else {
|
142 |
+
echo '<option value="' . $i . '">' . $i . '</option>';
|
143 |
+
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
144 |
}
|
145 |
+
echo '</select></p></span>';
|
146 |
+
|
147 |
+
do_action( 'advanced_sidebar_menu_page_widget_form', $instance, $this->get_field_name( 'parent_only' ), $this->get_field_id( 'parent_only' ), $this );
|
148 |
+
|
149 |
+
do_action( 'advanced_sidebar_menu_after_widget_form', $instance, $this );
|
150 |
+
|
151 |
+
|
152 |
+
}
|
153 |
+
|
154 |
+
|
155 |
+
/**
|
156 |
+
* Handles the saving of the widget
|
157 |
+
*
|
158 |
+
* @filters apply_filters('advanced_sidebar_menu_page_widget_update', $newInstance, $oldInstance );
|
159 |
+
*
|
160 |
+
* @since 4.26.13
|
161 |
+
*/
|
162 |
+
function update( $newInstance, $oldInstance ){
|
163 |
+
$newInstance[ 'exclude' ] = strip_tags( $newInstance[ 'exclude' ] );
|
164 |
+
|
165 |
+
$newInstance = apply_filters( 'advanced_sidebar_menu_page_widget_update', $newInstance, $oldInstance );
|
166 |
+
|
167 |
+
return $newInstance;
|
168 |
+
}
|
169 |
+
|
170 |
+
|
171 |
+
#---------------------------------------------------------------------------------------------------------------------------
|
172 |
+
|
173 |
+
/**
|
174 |
+
* Outputs the page list
|
175 |
+
*
|
176 |
+
* @see WP_Widget::widget()
|
177 |
+
*
|
178 |
+
* @uses for custom post types send the type to the filter titled 'advanced_sidebar_menu_post_type'
|
179 |
+
* @uses change the top parent manually with the filter 'advanced_sidebar_menu_top_parent'
|
180 |
+
* @uses change the order of the 2nd level pages with 'advanced_sidebar_menu_order_by' filter
|
181 |
+
*
|
182 |
+
* @filter apply_filters('advanced_sidebar_menu_page_widget_output',$content, $args, $instance );
|
183 |
+
* apply_filters('advanced_sidebar_menu_order_by', 'menu_order', $post, $args, $instance );
|
184 |
+
* apply_filters('advanced_sidebar_menu_top_parent', $top_parent, $post, $args, $instance );
|
185 |
+
* apply_filters('advanced_sidebar_menu_post_type', 'page', $args, $instance );
|
186 |
+
*
|
187 |
+
*
|
188 |
+
*
|
189 |
+
* @see Geansai - pointed out a notice level error. Thanks Geansai!!
|
190 |
+
*/
|
191 |
+
function widget( $args, $instance ){
|
192 |
+
global $post;
|
193 |
+
|
194 |
+
$asm = new advancedSidebarMenu();
|
195 |
+
$asm->instance = $instance;
|
196 |
+
$asm->args = $args;
|
197 |
+
$asm->exclude = apply_filters( 'advanced_sidebar_menu_excluded_pages', explode( ',', $instance[ 'exclude' ] ), $post, $asm->args, $asm->instance, $asm );
|
198 |
+
|
199 |
+
do_action( 'advanced_sidebar_menu_widget_pre_render', $asm, $this );
|
200 |
+
|
201 |
+
extract( $args );
|
202 |
+
|
203 |
+
$filter_args = array(
|
204 |
+
1 => $asm->args,
|
205 |
+
2 => $asm->instance,
|
206 |
+
3 => $asm
|
207 |
+
);
|
208 |
+
|
209 |
+
$filter_args[ 0 ] = 'page';
|
210 |
+
$asm->post_type = $post_type = apply_filters_ref_array( 'advanced_sidebar_menu_post_type', $filter_args );
|
211 |
+
|
212 |
+
add_filter( 'page_css_class', array( $asm, 'hasChildrenClass' ), 2, 2 );
|
213 |
+
if( $asm->post_type != 'page' ){
|
214 |
+
add_filter( 'page_css_class', array( $asm, 'custom_post_type_css' ), 2, 4 );
|
215 |
+
}
|
216 |
+
|
217 |
+
$proper_single = !( is_page() || ( is_single() && $asm->post_type == get_post_type() ) );
|
218 |
+
$filter_args[ 0 ] = $proper_single;
|
219 |
+
if( apply_filters_ref_array( 'advanced_sidebar_menu_proper_single', $filter_args ) ){
|
220 |
+
return;
|
221 |
+
}
|
222 |
+
|
223 |
+
if( $post->ancestors ){
|
224 |
+
$ancestors = $post->ancestors;
|
225 |
+
$top_parent = end( $ancestors );
|
226 |
+
} else {
|
227 |
+
$top_parent = $post->ID;
|
228 |
+
}
|
229 |
+
|
230 |
+
$filter_args[ 0 ] = $top_parent;
|
231 |
+
$asm->top_id = $top_parent = apply_filters_ref_array( 'advanced_sidebar_menu_top_parent', $filter_args );
|
232 |
+
if( get_post_type( $asm->top_id ) != $asm->post_type ){
|
233 |
+
return;
|
234 |
+
}
|
235 |
+
|
236 |
+
unset( $filter_args[ 0 ] );
|
237 |
+
array_unshift( $filter_args, $post );
|
238 |
+
array_unshift( $filter_args, $instance[ 'order_by' ] );
|
239 |
+
|
240 |
+
$asm->order_by = $order_by = apply_filters_ref_array( 'advanced_sidebar_menu_order_by', $filter_args );
|
241 |
+
|
242 |
+
$child_pages = $this->get_child_pages( $asm, $filter_args );
|
243 |
+
|
244 |
+
#---- if there are no children do not display the parent unless it is check to do so
|
245 |
+
if( ( !empty( $child_pages ) ) || $asm->checked( 'include_childless_parent' ) && ( !in_array( $top_parent, $asm->exclude ) ) ){
|
246 |
+
|
247 |
+
$legacy = $asm->checked( 'legacy_mode' );
|
248 |
+
|
249 |
+
if( $asm->checked( 'css' ) ){
|
250 |
+
echo '<style type="text/css">';
|
251 |
+
include( $asm->file_hyercy( 'sidebar-menu.css', $legacy ) );
|
252 |
+
echo '</style>';
|
253 |
+
}
|
254 |
+
|
255 |
+
echo $before_widget;
|
256 |
+
$content = '';
|
257 |
+
require( $asm->file_hyercy( 'page_list.php', $legacy ) );
|
258 |
+
echo apply_filters( 'advanced_sidebar_menu_page_widget_output', $content, $args, $instance );
|
259 |
+
echo $after_widget;
|
260 |
+
|
261 |
+
}
|
262 |
+
|
263 |
+
}
|
264 |
+
|
265 |
+
|
266 |
+
/**
|
267 |
+
* get_child_pages
|
268 |
+
*
|
269 |
+
* Get the children's ids of the top level parent
|
270 |
+
*
|
271 |
+
* @param advancedSidebarMenu $asm
|
272 |
+
* @param array $filter_args
|
273 |
+
*
|
274 |
+
* @filter advanced_sidebar_menu_child_pages
|
275 |
+
*
|
276 |
+
* @return mixed
|
277 |
+
*/
|
278 |
+
private function get_child_pages( $asm, $filter_args ){
|
279 |
+
global $wpdb;
|
280 |
+
$_excluded = '';
|
281 |
+
|
282 |
+
if( !empty( $asm->exclude ) ){
|
283 |
+
$asm->exclude = array_filter( $asm->exclude );
|
284 |
+
if( !empty( $asm->exclude ) ){
|
285 |
+
foreach( $asm->exclude as $k => $_exclude ){
|
286 |
+
$asm->exclude[ $k ] = (int) $_exclude;
|
287 |
+
}
|
288 |
+
$_excluded = "AND ID NOT IN (" . implode( ',', $asm->exclude ) . ")";
|
289 |
+
}
|
290 |
+
}
|
291 |
+
|
292 |
+
$query = "SELECT ID FROM $wpdb->posts
|
293 |
+
WHERE post_parent = $asm->top_id
|
294 |
+
AND post_status='publish'
|
295 |
+
AND post_type='$asm->post_type'
|
296 |
+
$_excluded
|
297 |
+
Order by $asm->order_by";
|
298 |
+
|
299 |
+
$child_pages = $wpdb->get_col( $query );
|
300 |
+
|
301 |
+
$filter_args[ 0 ] = $child_pages;
|
302 |
+
$child_pages = apply_filters_ref_array( 'advanced_sidebar_menu_child_pages', $filter_args );
|
303 |
+
|
304 |
+
return $child_pages;
|
305 |
+
|
306 |
+
}
|
307 |
+
|
308 |
+
}
|