| Total Complexity | 42 | 
| Total Lines | 491 | 
| Duplicated Lines | 0 % | 
| Changes | 0 | ||
Complex classes like Renderer often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes.
Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.
While breaking up the class, it is a good idea to analyze how other classes use Renderer, and based on these observations, apply Extract Interface, too.
| 1 | <?php | ||
| 15 | abstract class Renderer extends Fetcher { | ||
| 16 | /** | ||
| 17 | * Slug for the form fields. | ||
| 18 | * | ||
| 19 | * @var string | ||
| 20 | */ | ||
| 21 | protected $field_slug; | ||
| 22 | |||
| 23 | /** | ||
| 24 | * Render post status including custom post status. | ||
| 25 | * | ||
| 26 | * @param string $post_type The post type for which the post status should be displayed. | ||
| 27 | */ | ||
| 28 | 	protected function render_post_status( $post_type = 'post' ) { | ||
| 29 | $post_statuses = $this->get_post_statuses(); | ||
| 30 | $post_count = wp_count_posts( $post_type ); | ||
| 31 | |||
| 32 | foreach ( $post_statuses as $post_status ) : ?> | ||
| 33 | <tr> | ||
| 34 | <td> | ||
| 35 | <input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>[]" id="smbd_<?php echo esc_attr( $post_status->name ); ?>" | ||
| 36 | value="<?php echo esc_attr( $post_status->name ); ?>" type="checkbox"> | ||
| 37 | |||
| 38 | <label for="smbd_<?php echo esc_attr( $post_status->name ); ?>"> | ||
| 39 | <?php echo esc_html( $post_status->label ), ' '; ?> | ||
| 40 | <?php if ( property_exists( $post_count, $post_status->name ) ) : ?> | ||
| 41 | 							(<?php echo absint( $post_count->{ $post_status->name } ) . ' ', __( 'Posts', 'bulk-delete' ); ?>) | ||
| 42 | <?php endif; ?> | ||
| 43 | </label> | ||
| 44 | </td> | ||
| 45 | </tr> | ||
| 46 | <?php endforeach; | ||
| 47 | } | ||
| 48 | |||
| 49 | /** | ||
| 50 | * Render Post Types as radio buttons. | ||
| 51 | */ | ||
| 52 | 	protected function render_post_type_as_radios() { | ||
| 72 | } | ||
| 73 | |||
| 74 | /** | ||
| 75 | * Render Post type with status and post count checkboxes. | ||
| 76 | */ | ||
| 77 | 	protected function render_post_type_with_status() { | ||
| 78 | $post_types_by_status = $this->get_post_types_by_status(); | ||
| 79 | ?> | ||
| 80 | <tr> | ||
| 81 | <td scope="row" colspan="2"> | ||
| 82 | <select class="enhanced-post-types-with-status" multiple="multiple" name="smbd_<?php echo esc_attr( $this->field_slug ); ?>[]"> | ||
| 83 | <?php foreach ( $post_types_by_status as $post_type => $all_status ) : ?> | ||
| 84 | <optgroup label="<?php echo esc_html( $post_type ); ?>"> | ||
| 85 | <?php foreach ( $all_status as $status_key => $status_value ) : ?> | ||
| 86 | <option value="<?php echo esc_attr( $status_key ); ?>"><?php echo esc_html( $status_value ); ?></option> | ||
| 87 | <?php endforeach; ?> | ||
| 88 | </optgroup> | ||
| 89 | <?php endforeach; ?> | ||
| 90 | </select> | ||
| 91 | </td> | ||
| 92 | </tr> | ||
| 93 | <?php | ||
| 94 | } | ||
| 95 | |||
| 96 | /** | ||
| 97 | * Split post type and status. | ||
| 98 | * | ||
| 99 | * @param string $str Post type and status combination. | ||
| 100 | * | ||
| 101 | * @return array Post type and status as elements of array. | ||
| 102 | */ | ||
| 103 | 	protected function split_post_type_and_status( $str ) { | ||
| 104 | $type_status = array(); | ||
| 105 | |||
| 106 | $str_arr = explode( '-', $str ); | ||
| 107 | |||
| 108 | 		if ( count( $str_arr ) > 1 ) { | ||
| 109 | $type_status['status'] = end( $str_arr ); | ||
| 110 | $type_status['type'] = implode( '-', array_slice( $str_arr, 0, - 1 ) ); | ||
| 111 | 		} else { | ||
| 112 | $type_status['status'] = 'publish'; | ||
| 113 | $type_status['type'] = $str; | ||
| 114 | } | ||
| 115 | |||
| 116 | return $type_status; | ||
| 117 | } | ||
| 118 | |||
| 119 | /** | ||
| 120 | * Render user role dropdown. | ||
| 121 | */ | ||
| 122 | 	protected function render_user_role_dropdown() { | ||
| 123 | global $wp_roles; | ||
| 124 | ?> | ||
| 125 | |||
| 126 | <select name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_roles[]" class="enhanced-role-dropdown" | ||
| 127 | multiple="multiple" data-placeholder="<?php _e( 'Select User Role', 'bulk-delete' ); ?>"> | ||
| 128 | |||
| 129 | <?php foreach ( $wp_roles->roles as $role => $role_details ) : ?> | ||
| 130 | <option value="<?php echo esc_attr( $role ); ?>"> | ||
| 131 | 					<?php echo esc_html( $role_details['name'] ), ' (', absint( $this->get_user_count_by_role( $role ) ), ' ', __( 'Users', 'bulk-delete' ), ')'; ?> | ||
| 132 | </option> | ||
| 133 | <?php endforeach; ?> | ||
| 134 | </select> | ||
| 135 | |||
| 136 | <?php | ||
| 137 | } | ||
| 138 | |||
| 139 | /** | ||
| 140 | * Render Post type dropdown. | ||
| 141 | */ | ||
| 142 | 	protected function render_post_type_dropdown() { | ||
| 143 | bd_render_post_type_dropdown( $this->field_slug ); | ||
| 144 | } | ||
| 145 | |||
| 146 | /** | ||
| 147 | * Render Taxonomy dropdown. | ||
| 148 | */ | ||
| 149 | 	protected function render_taxonomy_dropdown() { | ||
| 150 | $taxonomies = get_taxonomies( array(), 'objects' ); | ||
| 151 | ?> | ||
| 152 | |||
| 153 | <select name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_taxonomy" class="enhanced-taxonomy-list" data-placeholder="<?php _e( 'Select Taxonomy', 'bulk-delete' ); ?>"> | ||
| 154 | <?php foreach ( $taxonomies as $taxonomy ) : ?> | ||
| 155 | <option value="<?php echo esc_attr( $taxonomy->name ); ?>"> | ||
| 156 | 					<?php echo esc_html( $taxonomy->label . ' (' . $taxonomy->name . ')' ); ?> | ||
| 157 | </option> | ||
| 158 | <?php endforeach; ?> | ||
| 159 | </select> | ||
| 160 | <?php | ||
| 161 | } | ||
| 162 | |||
| 163 | /** | ||
| 164 | * Render Category dropdown. | ||
| 165 | */ | ||
| 166 | 	protected function render_category_dropdown() { | ||
| 167 | $categories = $this->get_categories(); | ||
| 168 | ?> | ||
| 169 | |||
| 170 | <select name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_category[]" data-placeholder="<?php _e( 'Select Categories', 'bulk-delete' ); ?>" | ||
| 171 | class="<?php echo sanitize_html_class( $this->enable_ajax_if_needed_to_dropdown_class_name( count( $categories ), 'select2-taxonomy' ) ); ?>" | ||
| 172 | data-taxonomy="category" multiple> | ||
| 173 | |||
| 174 | <option value="all"> | ||
| 175 | <?php _e( 'All Categories', 'bulk-delete' ); ?> | ||
| 176 | </option> | ||
| 177 | |||
| 178 | <?php foreach ( $categories as $category ) : ?> | ||
| 179 | <option value="<?php echo absint( $category->cat_ID ); ?>"> | ||
| 180 | 					<?php echo esc_html( $category->cat_name ), ' (', absint( $category->count ), ' ', __( 'Posts', 'bulk-delete' ), ')'; ?> | ||
| 181 | </option> | ||
| 182 | <?php endforeach; ?> | ||
| 183 | |||
| 184 | </select> | ||
| 185 | <?php | ||
| 186 | } | ||
| 187 | |||
| 188 | /** | ||
| 189 | * Render String based comparison operators dropdown. | ||
| 190 | */ | ||
| 191 | 	protected function render_string_comparison_operators() { | ||
| 192 | ?> | ||
| 193 | <select name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_operator"> | ||
| 194 | <option value="equal_to"><?php _e( 'equal to', 'bulk-delete' ); ?></option> | ||
| 195 | <option value="not_equal_to"><?php _e( 'not equal to', 'bulk-delete' ); ?></option> | ||
| 196 | <option value="starts_with"><?php _e( 'starts with', 'bulk-delete' ); ?></option> | ||
| 197 | <option value="ends_with"><?php _e( 'ends with', 'bulk-delete' ); ?></option> | ||
| 198 | <option value="contains"><?php _e( 'contains', 'bulk-delete' ); ?></option> | ||
| 199 | <option value="not_contains"><?php _e( 'not contains', 'bulk-delete' ); ?></option> | ||
| 200 | </select> | ||
| 201 | <?php | ||
| 202 | } | ||
| 203 | |||
| 204 | /** | ||
| 205 | * Render number based comparison operators dropdown. | ||
| 206 | */ | ||
| 207 | 	protected function render_number_comparison_operators() { | ||
| 208 | ?> | ||
| 209 | <select name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_operator"> | ||
| 210 | <option value="equal_to"><?php _e( 'equal to', 'bulk-delete' ); ?></option> | ||
| 211 | <option value="not_equal_to"><?php _e( 'not equal to', 'bulk-delete' ); ?></option> | ||
| 212 | <option value="less_than"><?php _e( 'less than', 'bulk-delete' ); ?></option> | ||
| 213 | <option value="greater_than"><?php _e( 'greater than', 'bulk-delete' ); ?></option> | ||
| 214 | </select> | ||
| 215 | <?php | ||
| 216 | } | ||
| 217 | |||
| 218 | /** | ||
| 219 | * Render Tags dropdown. | ||
| 220 | */ | ||
| 221 | 	protected function render_tags_dropdown() { | ||
| 239 | <?php | ||
| 240 | } | ||
| 241 | |||
| 242 | /** | ||
| 243 | * Get the class name for select2 dropdown based on the number of items present. | ||
| 244 | * | ||
| 245 | * @param int $count The number of items present. | ||
| 246 | * @param string $class_name Primary class name. | ||
| 247 | * | ||
| 248 | * @return string Class name. | ||
| 249 | */ | ||
| 250 | 	protected function enable_ajax_if_needed_to_dropdown_class_name( $count, $class_name ) { | ||
| 251 | 		if ( $count >= $this->get_enhanced_select_threshold() ) { | ||
| 252 | $class_name .= '-ajax'; | ||
| 253 | } | ||
| 254 | |||
| 255 | return $class_name; | ||
| 256 | } | ||
| 257 | |||
| 258 | /** | ||
| 259 | * Render Sticky Posts dropdown. | ||
| 260 | */ | ||
| 261 | 	protected function render_sticky_posts_dropdown() { | ||
| 293 | <?php | ||
| 294 | } | ||
| 295 | |||
| 296 | /** | ||
| 297 | * Renders exclude sticky posts checkbox. | ||
| 298 | */ | ||
| 299 | 	protected function render_exclude_sticky_settings() { | ||
| 300 | if ( $this->are_sticky_posts_present() ) : // phpcs:ignore?> | ||
| 301 | <tr> | ||
| 302 | <td scope="row"> | ||
| 303 | <input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_exclude_sticky" id="smbd_<?php echo esc_attr( $this->field_slug ); ?>_exclude_sticky" value="true" type="checkbox"> | ||
| 304 | </td> | ||
| 305 | <td> | ||
| 306 | <label for="smbd_<?php echo esc_attr( $this->field_slug ); ?>_exclude_sticky"><?php _e( 'Exclude sticky posts', 'bulk-delete' ); ?></label> | ||
| 307 | </td> | ||
| 308 | </tr> | ||
| 309 | <?php endif; // phpcs:ignore?> | ||
| 310 | <?php | ||
| 311 | } | ||
| 312 | |||
| 313 | /** | ||
| 314 | * Render Post Types as checkboxes. | ||
| 315 | * | ||
| 316 | * @since 5.6.0 | ||
| 317 | * | ||
| 318 | * @param string $name Name of post type checkboxes. | ||
| 319 | */ | ||
| 320 | 	protected function render_post_type_checkboxes( $name ) { | ||
| 321 | $post_types = bd_get_post_types(); | ||
| 322 | ?> | ||
| 323 | |||
| 324 | <?php foreach ( $post_types as $post_type ) : ?> | ||
| 325 | |||
| 326 | <tr> | ||
| 327 | <td scope="row"> | ||
| 328 | <input type="checkbox" name="<?php echo esc_attr( $name ); ?>[]" value="<?php echo esc_attr( $post_type->name ); ?>" | ||
| 329 | id="smbd_post_type_<?php echo esc_html( $post_type->name ); ?>" checked> | ||
| 330 | |||
| 331 | <label for="smbd_post_type_<?php echo esc_html( $post_type->name ); ?>"> | ||
| 332 | <?php echo esc_html( $post_type->label ); ?> | ||
| 333 | </label> | ||
| 334 | </td> | ||
| 335 | </tr> | ||
| 336 | |||
| 337 | <?php endforeach; ?> | ||
| 338 | <?php | ||
| 339 | } | ||
| 340 | |||
| 341 | /** | ||
| 342 | * Render the "private post" setting fields. | ||
| 343 | */ | ||
| 344 | 	protected function render_private_post_settings() { | ||
| 345 | bd_render_private_post_settings( $this->field_slug ); | ||
| 346 | } | ||
| 347 | |||
| 348 | /** | ||
| 349 | * Get the threshold after which enhanced select should be used. | ||
| 350 | * | ||
| 351 | * @return int Threshold. | ||
| 352 | */ | ||
| 353 | 	protected function get_enhanced_select_threshold() { | ||
| 362 | } | ||
| 363 | |||
| 364 | /** | ||
| 365 | * Render sticky settings. | ||
| 366 | */ | ||
| 367 | 	protected function render_sticky_action_settings() { | ||
| 368 | ?> | ||
| 369 | <tr> | ||
| 370 | <td scope="row" colspan="2"> | ||
| 371 | <label> | ||
| 372 | <input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_sticky_action" value="unsticky" type="radio" checked> | ||
| 373 | <?php _e( 'Remove Sticky', 'bulk-delete' ); ?> | ||
| 374 | </label> | ||
| 375 | <label> | ||
| 376 | <input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_sticky_action" value="delete" type="radio"> | ||
| 377 | <?php _e( 'Delete Post', 'bulk-delete' ); ?> | ||
| 378 | </label> | ||
| 379 | </td> | ||
| 380 | </tr> | ||
| 381 | <?php | ||
| 382 | } | ||
| 383 | |||
| 384 | /** | ||
| 385 | * Render filtering table header. | ||
| 386 | */ | ||
| 387 | 	protected function render_filtering_table_header() { | ||
| 388 | bd_render_filtering_table_header(); | ||
| 389 | } | ||
| 390 | |||
| 391 | /** | ||
| 392 | * Render restrict settings. | ||
| 393 | */ | ||
| 394 | 	protected function render_restrict_settings() { | ||
| 395 | bd_render_restrict_settings( $this->field_slug, $this->item_type ); | ||
| 396 | } | ||
| 397 | |||
| 398 | /** | ||
| 399 | * Render delete settings. | ||
| 400 | */ | ||
| 401 | 	protected function render_delete_settings() { | ||
| 402 | bd_render_delete_settings( $this->field_slug ); | ||
| 403 | /** | ||
| 404 | * This action is primarily for adding delete attachment settings. | ||
| 405 | * | ||
| 406 | * @since 6.0.0 | ||
| 407 | * | ||
| 408 | * @param \BulkWP\BulkDelete\Core\Base\BaseModule The delete module. | ||
| 409 | */ | ||
| 410 | do_action( 'bd_render_attachment_settings', $this ); | ||
| 411 | } | ||
| 412 | |||
| 413 | /** | ||
| 414 | * Render limit settings. | ||
| 415 | */ | ||
| 416 | 	protected function render_limit_settings() { | ||
| 417 | bd_render_limit_settings( $this->field_slug, $this->item_type ); | ||
| 418 | } | ||
| 419 | |||
| 420 | /** | ||
| 421 | * Render cron settings based on whether scheduler is present or not. | ||
| 422 | */ | ||
| 423 | 	protected function render_cron_settings() { | ||
| 424 | $disabled_attr = 'disabled'; | ||
| 425 | 		if ( empty( $this->scheduler_url ) ) { | ||
| 426 | $disabled_attr = ''; | ||
| 427 | } | ||
| 428 | ?> | ||
| 429 | |||
| 430 | <tr> | ||
| 431 | <td scope="row" colspan="2"> | ||
| 432 | <label><input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron" value="false" type="radio" | ||
| 433 | checked="checked"> <?php _e( 'Delete now', 'bulk-delete' ); ?></label> | ||
| 434 | <label><input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron" value="true" type="radio" | ||
| 435 | id="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron" <?php echo esc_attr( $disabled_attr ); ?>> <?php _e( 'Schedule', 'bulk-delete' ); ?></label> | ||
| 436 | <input name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron_start" | ||
| 437 | id="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron_start" value="now" | ||
| 438 | type="text" <?php echo esc_attr( $disabled_attr ); ?>><?php _e( 'repeat ', 'bulk-delete' ); ?> | ||
| 439 | |||
| 440 | <select name="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron_freq" | ||
| 441 | id="smbd_<?php echo esc_attr( $this->field_slug ); ?>_cron_freq" <?php echo esc_attr( $disabled_attr ); ?>> | ||
| 442 | |||
| 443 | <option value="-1"><?php _e( "Don't repeat", 'bulk-delete' ); ?></option> | ||
| 444 | <?php | ||
| 445 | /** | ||
| 446 | * List of cron schedules. | ||
| 447 | * | ||
| 448 | * @since 6.0.0 | ||
| 449 | * | ||
| 450 | * @param array $cron_schedules List of cron schedules. | ||
| 451 | * @param \BulkWP\BulkDelete\Core\Base\BaseModule $module Module. | ||
| 452 | */ | ||
| 453 | $cron_schedules = apply_filters( 'bd_cron_schedules', wp_get_schedules(), $this ); | ||
| 454 | ?> | ||
| 455 | |||
| 456 | <?php foreach ( $cron_schedules as $key => $value ) : ?> | ||
| 457 | <option | ||
| 458 | value="<?php echo esc_attr( $key ); ?>"><?php echo esc_html( $value['display'] ); ?></option> | ||
| 459 | <?php endforeach; ?> | ||
| 460 | </select> | ||
| 461 | |||
| 462 | <?php if ( ! empty( $this->scheduler_url ) ) : ?> | ||
| 463 | <?php | ||
| 464 | $pro_class = 'bd-' . str_replace( '_', '-', $this->field_slug ) . '-pro'; | ||
| 465 | |||
| 466 | /** | ||
| 467 | * HTML class of the span that displays the 'Pro only feature' message. | ||
| 468 | * | ||
| 469 | * @since 6.0.0 | ||
| 470 | * | ||
| 471 | * @param string $pro_class HTML class. | ||
| 472 | * @param string $field_slug Field Slug of module. | ||
| 473 | * @param \BulkWP\BulkDelete\Core\Base\BaseModule $module Module. | ||
| 474 | */ | ||
| 475 | apply_filters( 'bd_pro_only_feature_class', $pro_class, $this->field_slug, $this ) | ||
| 476 | ?> | ||
| 477 | |||
| 478 | <span class="<?php echo sanitize_html_class( $pro_class ); ?>" style="color:red"> | ||
| 479 | <?php _e( 'Only available in Pro Addon', 'bulk-delete' ); ?> <a | ||
| 480 | href="<?php echo esc_url( $this->scheduler_url ); ?>">Buy now</a> | ||
| 481 | </span> | ||
| 482 | <?php endif; ?> | ||
| 483 | </td> | ||
| 484 | </tr> | ||
| 485 | |||
| 486 | <tr class="<?php echo sanitize_html_class( $pro_class ); ?>" style="display: none;"> | ||
| 487 | <td scope="row" colspan="2"> | ||
| 488 | <?php | ||
| 489 | _e( 'Enter time in <strong>Y-m-d H:i:s</strong> format or enter <strong>now</strong> to use current time.', 'bulk-delete' ); | ||
| 490 | $link = '<a href="https://bulkwp.com/docs/add-a-new-cron-schedule/">' . __( 'Click here', 'bulk-delete' ) . '</a>'; | ||
| 491 | $markup = sprintf( __( 'Want to add new a Cron schedule? %s', 'bulk-delete' ), $link ); | ||
| 492 | |||
| 493 | $content = __( 'Learn how to add your desired Cron schedule.', 'bulk-delete' ); | ||
| 494 | echo ' ' . bd_generate_help_tooltip( $markup, $content ); | ||
| 495 | ?> | ||
| 496 | </td> | ||
| 497 | </tr> | ||
| 498 | <?php | ||
| 499 | } | ||
| 500 | |||
| 501 | /** | ||
| 502 | * Render submit button. | ||
| 503 | */ | ||
| 504 | 	protected function render_submit_button() { | ||
| 506 | } | ||
| 507 | } | ||
| 508 |