| 1 | <?php |
|---|
| 2 | /** |
|---|
| 3 | * Terms List Table class. |
|---|
| 4 | * |
|---|
| 5 | * @package WordPress |
|---|
| 6 | * @subpackage List_Table |
|---|
| 7 | * @since 3.1.0 |
|---|
| 8 | * @access private |
|---|
| 9 | */ |
|---|
| 10 | class WP_Terms_List_Table extends WP_List_Table { |
|---|
| 11 | |
|---|
| 12 | |
|---|
| 13 | public $callback_args; |
|---|
| 14 | |
|---|
| 15 | private $level; |
|---|
| 16 | |
|---|
| 17 | /** |
|---|
| 18 | * Constructor. |
|---|
| 19 | * |
|---|
| 20 | * @since 3.1.0 |
|---|
| 21 | * @access public |
|---|
| 22 | * |
|---|
| 23 | * @see WP_List_Table::__construct() for more information on default arguments. |
|---|
| 24 | * |
|---|
| 25 | * @global string $post_type |
|---|
| 26 | * @global string $taxonomy |
|---|
| 27 | * @global string $action |
|---|
| 28 | * @global object $tax |
|---|
| 29 | * |
|---|
| 30 | * @param array $args An associative array of arguments. |
|---|
| 31 | */ |
|---|
| 32 | public function __construct( $args = array() ) { |
|---|
| 33 | global $post_type, $taxonomy, $action, $tax; |
|---|
| 34 | |
|---|
| 35 | parent::__construct( array( |
|---|
| 36 | 'plural' => 'tags', |
|---|
| 37 | 'singular' => 'tag', |
|---|
| 38 | 'screen' => isset( $args['screen'] ) ? $args['screen'] : null, |
|---|
| 39 | ) ); |
|---|
| 40 | |
|---|
| 41 | $action = $this->screen->action; |
|---|
| 42 | $post_type = $this->screen->post_type; |
|---|
| 43 | $taxonomy = $this->screen->taxonomy; |
|---|
| 44 | |
|---|
| 45 | if ( empty( $taxonomy ) ) |
|---|
| 46 | $taxonomy = 'post_tag'; |
|---|
| 47 | |
|---|
| 48 | if ( ! taxonomy_exists( $taxonomy ) ) |
|---|
| 49 | wp_die( __( 'Invalid taxonomy' ) ); |
|---|
| 50 | |
|---|
| 51 | $tax = get_taxonomy( $taxonomy ); |
|---|
| 52 | |
|---|
| 53 | // @todo Still needed? Maybe just the show_ui part. |
|---|
| 54 | if ( empty( $post_type ) || !in_array( $post_type, get_post_types( array( 'show_ui' => true ) ) ) ) |
|---|
| 55 | $post_type = 'post'; |
|---|
| 56 | |
|---|
| 57 | } |
|---|
| 58 | |
|---|
| 59 | /** |
|---|
| 60 | * |
|---|
| 61 | * @return bool |
|---|
| 62 | */ |
|---|
| 63 | public function ajax_user_can() { |
|---|
| 64 | return current_user_can( get_taxonomy( $this->screen->taxonomy )->cap->manage_terms ); |
|---|
| 65 | } |
|---|
| 66 | |
|---|
| 67 | /** |
|---|
| 68 | * @access public |
|---|
| 69 | */ |
|---|
| 70 | public function prepare_items() { |
|---|
| 71 | $tags_per_page = $this->get_items_per_page( 'edit_' . $this->screen->taxonomy . '_per_page' ); |
|---|
| 72 | |
|---|
| 73 | if ( 'post_tag' == $this->screen->taxonomy ) { |
|---|
| 74 | /** |
|---|
| 75 | * Filter the number of terms displayed per page for the Tags list table. |
|---|
| 76 | * |
|---|
| 77 | * @since 2.8.0 |
|---|
| 78 | * |
|---|
| 79 | * @param int $tags_per_page Number of tags to be displayed. Default 20. |
|---|
| 80 | */ |
|---|
| 81 | $tags_per_page = apply_filters( 'edit_tags_per_page', $tags_per_page ); |
|---|
| 82 | |
|---|
| 83 | /** |
|---|
| 84 | * Filter the number of terms displayed per page for the Tags list table. |
|---|
| 85 | * |
|---|
| 86 | * @since 2.7.0 |
|---|
| 87 | * @deprecated 2.8.0 Use edit_tags_per_page instead. |
|---|
| 88 | * |
|---|
| 89 | * @param int $tags_per_page Number of tags to be displayed. Default 20. |
|---|
| 90 | */ |
|---|
| 91 | $tags_per_page = apply_filters( 'tagsperpage', $tags_per_page ); |
|---|
| 92 | } elseif ( 'category' == $this->screen->taxonomy ) { |
|---|
| 93 | /** |
|---|
| 94 | * Filter the number of terms displayed per page for the Categories list table. |
|---|
| 95 | * |
|---|
| 96 | * @since 2.8.0 |
|---|
| 97 | * |
|---|
| 98 | * @param int $tags_per_page Number of categories to be displayed. Default 20. |
|---|
| 99 | */ |
|---|
| 100 | $tags_per_page = apply_filters( 'edit_categories_per_page', $tags_per_page ); |
|---|
| 101 | } |
|---|
| 102 | |
|---|
| 103 | $search = !empty( $_REQUEST['s'] ) ? trim( wp_unslash( $_REQUEST['s'] ) ) : ''; |
|---|
| 104 | |
|---|
| 105 | $args = array( |
|---|
| 106 | 'search' => $search, |
|---|
| 107 | 'page' => $this->get_pagenum(), |
|---|
| 108 | 'number' => $tags_per_page, |
|---|
| 109 | ); |
|---|
| 110 | |
|---|
| 111 | if ( !empty( $_REQUEST['orderby'] ) ) |
|---|
| 112 | $args['orderby'] = trim( wp_unslash( $_REQUEST['orderby'] ) ); |
|---|
| 113 | |
|---|
| 114 | if ( !empty( $_REQUEST['order'] ) ) |
|---|
| 115 | $args['order'] = trim( wp_unslash( $_REQUEST['order'] ) ); |
|---|
| 116 | |
|---|
| 117 | $this->callback_args = $args; |
|---|
| 118 | |
|---|
| 119 | $this->set_pagination_args( array( |
|---|
| 120 | 'total_items' => wp_count_terms( $this->screen->taxonomy, compact( 'search' ) ), |
|---|
| 121 | 'per_page' => $tags_per_page, |
|---|
| 122 | ) ); |
|---|
| 123 | } |
|---|
| 124 | |
|---|
| 125 | /** |
|---|
| 126 | * |
|---|
| 127 | * @return bool |
|---|
| 128 | */ |
|---|
| 129 | public function has_items() { |
|---|
| 130 | // todo: populate $this->items in prepare_items() |
|---|
| 131 | return true; |
|---|
| 132 | } |
|---|
| 133 | |
|---|
| 134 | /** |
|---|
| 135 | * @access public |
|---|
| 136 | */ |
|---|
| 137 | public function no_items() { |
|---|
| 138 | echo get_taxonomy( $this->screen->taxonomy )->labels->not_found; |
|---|
| 139 | } |
|---|
| 140 | |
|---|
| 141 | /** |
|---|
| 142 | * |
|---|
| 143 | * @return array |
|---|
| 144 | */ |
|---|
| 145 | protected function get_bulk_actions() { |
|---|
| 146 | $actions = array(); |
|---|
| 147 | $actions['delete'] = __( 'Delete' ); |
|---|
| 148 | |
|---|
| 149 | return $actions; |
|---|
| 150 | } |
|---|
| 151 | |
|---|
| 152 | /** |
|---|
| 153 | * |
|---|
| 154 | * @return string |
|---|
| 155 | */ |
|---|
| 156 | public function current_action() { |
|---|
| 157 | if ( isset( $_REQUEST['action'] ) && isset( $_REQUEST['delete_tags'] ) && ( 'delete' == $_REQUEST['action'] || 'delete' == $_REQUEST['action2'] ) ) |
|---|
| 158 | return 'bulk-delete'; |
|---|
| 159 | |
|---|
| 160 | return parent::current_action(); |
|---|
| 161 | } |
|---|
| 162 | |
|---|
| 163 | /** |
|---|
| 164 | * |
|---|
| 165 | * @return array |
|---|
| 166 | */ |
|---|
| 167 | public function get_columns() { |
|---|
| 168 | $taxonomy = $this->screen->taxonomy; |
|---|
| 169 | |
|---|
| 170 | $columns = array( |
|---|
| 171 | 'cb' => '<input type="checkbox" />', |
|---|
| 172 | 'name' => _x( 'Name', 'term name' ), |
|---|
| 173 | 'description' => __( 'Description' ), |
|---|
| 174 | 'slug' => __( 'Slug' ), |
|---|
| 175 | ); |
|---|
| 176 | |
|---|
| 177 | if ( 'link_category' == $this->screen->taxonomy ) { |
|---|
| 178 | $columns['links'] = __( 'Links' ); |
|---|
| 179 | } else { |
|---|
| 180 | $columns['posts'] = _x( 'Count', 'Number/count of items' ); |
|---|
| 181 | } |
|---|
| 182 | |
|---|
| 183 | $columns = apply_filters( "manage_{$taxonomy}_columns", $columns ); |
|---|
| 184 | |
|---|
| 185 | return apply_filters( "manage_{$taxonomy}_posts_columns", $columns ); |
|---|
| 186 | } |
|---|
| 187 | |
|---|
| 188 | /** |
|---|
| 189 | * |
|---|
| 190 | * @return array |
|---|
| 191 | */ |
|---|
| 192 | protected function get_sortable_columns() { |
|---|
| 193 | return array( |
|---|
| 194 | 'name' => 'name', |
|---|
| 195 | 'description' => 'description', |
|---|
| 196 | 'slug' => 'slug', |
|---|
| 197 | 'posts' => 'count', |
|---|
| 198 | 'links' => 'count' |
|---|
| 199 | ); |
|---|
| 200 | } |
|---|
| 201 | |
|---|
| 202 | /** |
|---|
| 203 | * @access public |
|---|
| 204 | */ |
|---|
| 205 | public function display_rows_or_placeholder() { |
|---|
| 206 | $taxonomy = $this->screen->taxonomy; |
|---|
| 207 | |
|---|
| 208 | $args = wp_parse_args( $this->callback_args, array( |
|---|
| 209 | 'page' => 1, |
|---|
| 210 | 'number' => 20, |
|---|
| 211 | 'search' => '', |
|---|
| 212 | 'hide_empty' => 0 |
|---|
| 213 | ) ); |
|---|
| 214 | |
|---|
| 215 | $page = $args['page']; |
|---|
| 216 | |
|---|
| 217 | // Set variable because $args['number'] can be subsequently overridden. |
|---|
| 218 | $number = $args['number']; |
|---|
| 219 | |
|---|
| 220 | $args['offset'] = $offset = ( $page - 1 ) * $number; |
|---|
| 221 | |
|---|
| 222 | // Convert it to table rows. |
|---|
| 223 | $count = 0; |
|---|
| 224 | |
|---|
| 225 | if ( is_taxonomy_hierarchical( $taxonomy ) && ! isset( $args['orderby'] ) ) { |
|---|
| 226 | // We'll need the full set of terms then. |
|---|
| 227 | $args['number'] = $args['offset'] = 0; |
|---|
| 228 | } |
|---|
| 229 | $terms = get_terms( $taxonomy, $args ); |
|---|
| 230 | |
|---|
| 231 | if ( empty( $terms ) || ! is_array( $terms ) ) { |
|---|
| 232 | echo '<tr class="no-items"><td class="colspanchange" colspan="' . $this->get_column_count() . '">'; |
|---|
| 233 | $this->no_items(); |
|---|
| 234 | echo '</td></tr>'; |
|---|
| 235 | return; |
|---|
| 236 | } |
|---|
| 237 | |
|---|
| 238 | if ( is_taxonomy_hierarchical( $taxonomy ) && ! isset( $args['orderby'] ) ) { |
|---|
| 239 | if ( ! empty( $args['search'] ) ) {// Ignore children on searches. |
|---|
| 240 | $children = array(); |
|---|
| 241 | } else { |
|---|
| 242 | $children = _get_term_hierarchy( $taxonomy ); |
|---|
| 243 | } |
|---|
| 244 | // Some funky recursion to get the job done( Paging & parents mainly ) is contained within, Skip it for non-hierarchical taxonomies for performance sake |
|---|
| 245 | $this->_rows( $taxonomy, $terms, $children, $offset, $number, $count ); |
|---|
| 246 | } else { |
|---|
| 247 | foreach ( $terms as $term ) { |
|---|
| 248 | $this->single_row( $term ); |
|---|
| 249 | } |
|---|
| 250 | } |
|---|
| 251 | } |
|---|
| 252 | |
|---|
| 253 | /** |
|---|
| 254 | * @param string $taxonomy |
|---|
| 255 | * @param array $terms |
|---|
| 256 | * @param array $children |
|---|
| 257 | * @param int $start |
|---|
| 258 | * @param int $per_page |
|---|
| 259 | * @param int $count |
|---|
| 260 | * @param int $parent |
|---|
| 261 | * @param int $level |
|---|
| 262 | */ |
|---|
| 263 | private function _rows( $taxonomy, $terms, &$children, $start, $per_page, &$count, $parent = 0, $level = 0 ) { |
|---|
| 264 | |
|---|
| 265 | |
|---|
| 266 | $end = $start + $per_page; |
|---|
| 267 | |
|---|
| 268 | foreach ( $terms as $key => $term ) { |
|---|
| 269 | |
|---|
| 270 | if ( $count >= $end ) |
|---|
| 271 | break; |
|---|
| 272 | |
|---|
| 273 | if ( $term->parent != $parent && empty( $_REQUEST['s'] ) ) |
|---|
| 274 | continue; |
|---|
| 275 | |
|---|
| 276 | // If the page starts in a subtree, print the parents. |
|---|
| 277 | if ( $count == $start && $term->parent > 0 && empty( $_REQUEST['s'] ) ) { |
|---|
| 278 | $my_parents = $parent_ids = array(); |
|---|
| 279 | $p = $term->parent; |
|---|
| 280 | while ( $p ) { |
|---|
| 281 | $my_parent = get_term( $p, $taxonomy ); |
|---|
| 282 | $my_parents[] = $my_parent; |
|---|
| 283 | $p = $my_parent->parent; |
|---|
| 284 | if ( in_array( $p, $parent_ids ) ) // Prevent parent loops. |
|---|
| 285 | break; |
|---|
| 286 | $parent_ids[] = $p; |
|---|
| 287 | } |
|---|
| 288 | unset( $parent_ids ); |
|---|
| 289 | |
|---|
| 290 | $num_parents = count( $my_parents ); |
|---|
| 291 | while ( $my_parent = array_pop( $my_parents ) ) { |
|---|
| 292 | echo "\t"; |
|---|
| 293 | $this->single_row( $my_parent, $level - $num_parents ); |
|---|
| 294 | $num_parents--; |
|---|
| 295 | } |
|---|
| 296 | } |
|---|
| 297 | |
|---|
| 298 | if ( $count >= $start ) { |
|---|
| 299 | echo "\t"; |
|---|
| 300 | $this->single_row( $term, $level ); |
|---|
| 301 | } |
|---|
| 302 | |
|---|
| 303 | ++$count; |
|---|
| 304 | |
|---|
| 305 | unset( $terms[$key] ); |
|---|
| 306 | |
|---|
| 307 | if ( isset( $children[$term->term_id] ) && empty( $_REQUEST['s'] ) ) |
|---|
| 308 | $this->_rows( $taxonomy, $terms, $children, $start, $per_page, $count, $term->term_id, $level + 1 ); |
|---|
| 309 | } |
|---|
| 310 | } |
|---|
| 311 | |
|---|
| 312 | /** |
|---|
| 313 | * @global string $taxonomy |
|---|
| 314 | * @param object $tag |
|---|
| 315 | * @param int $level |
|---|
| 316 | */ |
|---|
| 317 | public function single_row( $tag, $level = 0 ) { |
|---|
| 318 | global $taxonomy; |
|---|
| 319 | $tag = sanitize_term( $tag, $taxonomy ); |
|---|
| 320 | |
|---|
| 321 | $this->level = $level; |
|---|
| 322 | |
|---|
| 323 | echo '<tr id="tag-' . $tag->term_id . '">'; |
|---|
| 324 | $this->single_row_columns( $tag ); |
|---|
| 325 | echo '</tr>'; |
|---|
| 326 | } |
|---|
| 327 | |
|---|
| 328 | /** |
|---|
| 329 | * @param object $tag |
|---|
| 330 | * @return string |
|---|
| 331 | */ |
|---|
| 332 | public function column_cb( $tag ) { |
|---|
| 333 | $default_term = get_option( 'default_' . $this->screen->taxonomy ); |
|---|
| 334 | |
|---|
| 335 | if ( current_user_can( get_taxonomy( $this->screen->taxonomy )->cap->delete_terms ) && $tag->term_id != $default_term ) |
|---|
| 336 | return '<label class="screen-reader-text" for="cb-select-' . $tag->term_id . '">' . sprintf( __( 'Select %s' ), $tag->name ) . '</label>' |
|---|
| 337 | . '<input type="checkbox" name="delete_tags[]" value="' . $tag->term_id . '" id="cb-select-' . $tag->term_id . '" />'; |
|---|
| 338 | |
|---|
| 339 | return ' '; |
|---|
| 340 | } |
|---|
| 341 | |
|---|
| 342 | /** |
|---|
| 343 | * @param object $tag |
|---|
| 344 | * @return string |
|---|
| 345 | */ |
|---|
| 346 | public function column_name( $tag ) { |
|---|
| 347 | $taxonomy = $this->screen->taxonomy; |
|---|
| 348 | |
|---|
| 349 | $pad = str_repeat( '— ', max( 0, $this->level ) ); |
|---|
| 350 | |
|---|
| 351 | /** |
|---|
| 352 | * Filter display of the term name in the terms list table. |
|---|
| 353 | * |
|---|
| 354 | * The default output may include padding due to the term's |
|---|
| 355 | * current level in the term hierarchy. |
|---|
| 356 | * |
|---|
| 357 | * @since 2.5.0 |
|---|
| 358 | * |
|---|
| 359 | * @see WP_Terms_List_Table::column_name() |
|---|
| 360 | * |
|---|
| 361 | * @param string $pad_tag_name The term name, padded if not top-level. |
|---|
| 362 | * @param object $tag Term object. |
|---|
| 363 | */ |
|---|
| 364 | $name = apply_filters( 'term_name', $pad . ' ' . $tag->name, $tag ); |
|---|
| 365 | |
|---|
| 366 | $qe_data = get_term( $tag->term_id, $taxonomy, OBJECT, 'edit' ); |
|---|
| 367 | $edit_link = esc_url( get_edit_term_link( $tag->term_id, $taxonomy, $this->screen->post_type ) ); |
|---|
| 368 | |
|---|
| 369 | $out = '<strong><a class="row-title" href="' . $edit_link . '" title="' . esc_attr( sprintf( __( 'Edit “%s”' ), $name ) ) . '">' . $name . '</a></strong><br />'; |
|---|
| 370 | |
|---|
| 371 | $out .= '<div class="hidden" id="inline_' . $qe_data->term_id . '">'; |
|---|
| 372 | $out .= '<div class="name">' . $qe_data->name . '</div>'; |
|---|
| 373 | |
|---|
| 374 | /** This filter is documented in wp-admin/edit-tag-form.php */ |
|---|
| 375 | $out .= '<div class="slug">' . apply_filters( 'editable_slug', $qe_data->slug ) . '</div>'; |
|---|
| 376 | $out .= '<div class="parent">' . $qe_data->parent . '</div></div>'; |
|---|
| 377 | |
|---|
| 378 | return $out; |
|---|
| 379 | } |
|---|
| 380 | |
|---|
| 381 | /** |
|---|
| 382 | * Gets the name of the default primary column. |
|---|
| 383 | * |
|---|
| 384 | * @since 4.3.0 |
|---|
| 385 | * @access protected |
|---|
| 386 | * |
|---|
| 387 | * @return string Name of the default primary column, in this case, 'name'. |
|---|
| 388 | */ |
|---|
| 389 | protected function get_default_primary_column_name() { |
|---|
| 390 | return 'name'; |
|---|
| 391 | } |
|---|
| 392 | |
|---|
| 393 | /** |
|---|
| 394 | * Generates and displays row action links. |
|---|
| 395 | * |
|---|
| 396 | * @since 4.3.0 |
|---|
| 397 | * @access protected |
|---|
| 398 | * |
|---|
| 399 | * @param object $tag Tag being acted upon. |
|---|
| 400 | * @param string $column_name Current column name. |
|---|
| 401 | * @param string $primary Primary column name. |
|---|
| 402 | * @return string Row actions output for terms. |
|---|
| 403 | */ |
|---|
| 404 | protected function handle_row_actions( $tag, $column_name, $primary ) { |
|---|
| 405 | if ( $primary !== $column_name ) { |
|---|
| 406 | return ''; |
|---|
| 407 | } |
|---|
| 408 | |
|---|
| 409 | |
|---|
| 410 | $taxonomy = $this->screen->taxonomy; |
|---|
| 411 | $tax = get_taxonomy( $taxonomy ); |
|---|
| 412 | $default_term = get_option( 'default_' . $taxonomy ); |
|---|
| 413 | |
|---|
| 414 | $edit_link = esc_url( get_edit_term_link( $tag->term_id, $taxonomy, $this->screen->post_type ) ); |
|---|
| 415 | |
|---|
| 416 | $actions = array(); |
|---|
| 417 | if ( current_user_can( $tax->cap->edit_terms ) ) { |
|---|
| 418 | $actions['edit'] = '<a href="' . $edit_link . '">' . __( 'Edit' ) . '</a>'; |
|---|
| 419 | $actions['inline hide-if-no-js'] = '<a href="#" class="editinline">' . __( 'Quick Edit' ) . '</a>'; |
|---|
| 420 | } |
|---|
| 421 | if ( current_user_can( $tax->cap->delete_terms ) && $tag->term_id != $default_term ) |
|---|
| 422 | $actions['delete'] = "<a class='delete-tag' href='" . wp_nonce_url( "edit-tags.php?action=delete&taxonomy=$taxonomy&tag_ID=$tag->term_id", 'delete-tag_' . $tag->term_id ) . "'>" . __( 'Delete' ) . "</a>"; |
|---|
| 423 | if ( $tax->public ) |
|---|
| 424 | $actions['view'] = '<a href="' . get_term_link( $tag ) . '">' . __( 'View' ) . '</a>'; |
|---|
| 425 | |
|---|
| 426 | /** |
|---|
| 427 | * Filter the action links displayed for each term in the Tags list table. |
|---|
| 428 | * |
|---|
| 429 | * @since 2.8.0 |
|---|
| 430 | * @deprecated 3.0.0 Use {$taxonomy}_row_actions instead. |
|---|
| 431 | * |
|---|
| 432 | * @param array $actions An array of action links to be displayed. Default |
|---|
| 433 | * 'Edit', 'Quick Edit', 'Delete', and 'View'. |
|---|
| 434 | * @param object $tag Term object. |
|---|
| 435 | */ |
|---|
| 436 | $actions = apply_filters( 'tag_row_actions', $actions, $tag ); |
|---|
| 437 | |
|---|
| 438 | /** |
|---|
| 439 | * Filter the action links displayed for each term in the terms list table. |
|---|
| 440 | * |
|---|
| 441 | * The dynamic portion of the hook name, `$taxonomy`, refers to the taxonomy slug. |
|---|
| 442 | * |
|---|
| 443 | * @since 3.0.0 |
|---|
| 444 | * |
|---|
| 445 | * @param array $actions An array of action links to be displayed. Default |
|---|
| 446 | * 'Edit', 'Quick Edit', 'Delete', and 'View'. |
|---|
| 447 | * @param object $tag Term object. |
|---|
| 448 | */ |
|---|
| 449 | $actions = apply_filters( "{$taxonomy}_row_actions", $actions, $tag ); |
|---|
| 450 | |
|---|
| 451 | return $this->row_actions( $actions ); |
|---|
| 452 | } |
|---|
| 453 | |
|---|
| 454 | /** |
|---|
| 455 | * @param object $tag |
|---|
| 456 | * @return string |
|---|
| 457 | */ |
|---|
| 458 | public function column_description( $tag ) { |
|---|
| 459 | return $tag->description; |
|---|
| 460 | } |
|---|
| 461 | |
|---|
| 462 | /** |
|---|
| 463 | * @param object $tag |
|---|
| 464 | * @return string |
|---|
| 465 | */ |
|---|
| 466 | public function column_slug( $tag ) { |
|---|
| 467 | /** This filter is documented in wp-admin/edit-tag-form.php */ |
|---|
| 468 | return apply_filters( 'editable_slug', $tag->slug ); |
|---|
| 469 | } |
|---|
| 470 | |
|---|
| 471 | /** |
|---|
| 472 | * @param object $tag |
|---|
| 473 | * @return string |
|---|
| 474 | */ |
|---|
| 475 | public function column_posts( $tag ) { |
|---|
| 476 | $count = number_format_i18n( $tag->count ); |
|---|
| 477 | |
|---|
| 478 | $tax = get_taxonomy( $this->screen->taxonomy ); |
|---|
| 479 | |
|---|
| 480 | $ptype_object = get_post_type_object( $this->screen->post_type ); |
|---|
| 481 | if ( ! $ptype_object->show_ui ) |
|---|
| 482 | return $count; |
|---|
| 483 | |
|---|
| 484 | if ( $tax->query_var ) { |
|---|
| 485 | $args = array( $tax->query_var => $tag->slug ); |
|---|
| 486 | } else { |
|---|
| 487 | $args = array( 'taxonomy' => $tax->name, 'term' => $tag->slug ); |
|---|
| 488 | } |
|---|
| 489 | |
|---|
| 490 | |
|---|
| 491 | if ( 'post' != $this->screen->post_type ) |
|---|
| 492 | $args['post_type'] = $this->screen->post_type; |
|---|
| 493 | |
|---|
| 494 | if ( 'attachment' == $this->screen->post_type ) |
|---|
| 495 | return "<a href='" . esc_url ( add_query_arg( $args, 'upload.php' ) ) . "'>$count</a>"; |
|---|
| 496 | |
|---|
| 497 | return "<a href='" . esc_url ( add_query_arg( $args, 'edit.php' ) ) . "'>$count</a>"; |
|---|
| 498 | } |
|---|
| 499 | |
|---|
| 500 | /** |
|---|
| 501 | * @param object $tag |
|---|
| 502 | * @return string |
|---|
| 503 | */ |
|---|
| 504 | public function column_links( $tag ) { |
|---|
| 505 | $count = number_format_i18n( $tag->count ); |
|---|
| 506 | if ( $count ) |
|---|
| 507 | $count = "<a href='link-manager.php?cat_id=$tag->term_id'>$count</a>"; |
|---|
| 508 | return $count; |
|---|
| 509 | } |
|---|
| 510 | |
|---|
| 511 | /** |
|---|
| 512 | * @param object $tag |
|---|
| 513 | * @param string $column_name |
|---|
| 514 | * @return string |
|---|
| 515 | */ |
|---|
| 516 | public function column_default( $tag, $column_name ) { |
|---|
| 517 | |
|---|
| 518 | /** |
|---|
| 519 | * Filter the displayed columns in the terms list table. |
|---|
| 520 | * |
|---|
| 521 | * The dynamic portion of the hook name, `$this->screen->taxonomy`, |
|---|
| 522 | * refers to the slug of the current taxonomy. |
|---|
| 523 | * |
|---|
| 524 | * @since 2.8.0 |
|---|
| 525 | * |
|---|
| 526 | * @param string $string Blank string. |
|---|
| 527 | * @param string $column_name Name of the column. |
|---|
| 528 | * @param int $term_id Term ID. |
|---|
| 529 | */ |
|---|
| 530 | do_action( "manage_{$this->screen->taxonomy}_custom_column", $column_name, $tag->term_id ); |
|---|
| 531 | // return apply_filters( "manage_{$this->screen->taxonomy}_custom_column", $column_name, $tag->term_id ); |
|---|
| 532 | } |
|---|
| 533 | |
|---|
| 534 | /** |
|---|
| 535 | * Outputs the hidden row displayed when inline editing |
|---|
| 536 | * |
|---|
| 537 | * @since 3.1.0 |
|---|
| 538 | */ |
|---|
| 539 | public function inline_edit() { |
|---|
| 540 | $tax = get_taxonomy( $this->screen->taxonomy ); |
|---|
| 541 | |
|---|
| 542 | if ( ! current_user_can( $tax->cap->edit_terms ) ) |
|---|
| 543 | return; |
|---|
| 544 | ?> |
|---|
| 545 | |
|---|
| 546 | <form method="get"><table style="display: none"><tbody id="inlineedit"> |
|---|
| 547 | <tr id="inline-edit" class="inline-edit-row" style="display: none"><td colspan="<?php echo $this->get_column_count(); ?>" class="colspanchange"> |
|---|
| 548 | |
|---|
| 549 | |
|---|
| 550 | <fieldset><div class="inline-edit-col"> |
|---|
| 551 | <h4><?php _e( 'Quick Edit' ); ?></h4> |
|---|
| 552 | |
|---|
| 553 | <label> |
|---|
| 554 | <span class="title"><?php _ex( 'Name', 'term name' ); ?></span> |
|---|
| 555 | <span class="input-text-wrap"><input type="text" name="name" class="ptitle" value="" /></span> |
|---|
| 556 | </label> |
|---|
| 557 | <?php if ( !global_terms_enabled() ) { ?> |
|---|
| 558 | <label> |
|---|
| 559 | <span class="title"><?php _e( 'Slug' ); ?></span> |
|---|
| 560 | <span class="input-text-wrap"><input type="text" name="slug" class="ptitle" value="" /></span> |
|---|
| 561 | </label> |
|---|
| 562 | <?php } ?> |
|---|
| 563 | </div></fieldset> |
|---|
| 564 | <?php |
|---|
| 565 | |
|---|
| 566 | $core_columns = array( 'cb' => true, 'description' => true, 'name' => true, 'slug' => true, 'posts' => true ); |
|---|
| 567 | |
|---|
| 568 | list( $columns ) = $this->get_column_info(); |
|---|
| 569 | |
|---|
| 570 | foreach ( $columns as $column_name => $column_display_name ) { |
|---|
| 571 | if ( isset( $core_columns[$column_name] ) ) |
|---|
| 572 | continue; |
|---|
| 573 | |
|---|
| 574 | /** This action is documented in wp-admin/includes/class-wp-posts-list-table.php */ |
|---|
| 575 | do_action( 'quick_edit_custom_box', $column_name, 'edit-tags', $this->screen->taxonomy ); |
|---|
| 576 | } |
|---|
| 577 | |
|---|
| 578 | ?> |
|---|
| 579 | |
|---|
| 580 | <p class="inline-edit-save submit"> |
|---|
| 581 | <a href="#inline-edit" class="cancel button-secondary alignleft"><?php _e( 'Cancel' ); ?></a> |
|---|
| 582 | <a href="#inline-edit" class="save button-primary alignright"><?php echo $tax->labels->update_item; ?></a> |
|---|
| 583 | <span class="spinner"></span> |
|---|
| 584 | <span class="error" style="display:none;"></span> |
|---|
| 585 | <?php wp_nonce_field( 'taxinlineeditnonce', '_inline_edit', false ); ?> |
|---|
| 586 | <input type="hidden" name="taxonomy" value="<?php echo esc_attr( $this->screen->taxonomy ); ?>" /> |
|---|
| 587 | <input type="hidden" name="post_type" value="<?php echo esc_attr( $this->screen->post_type ); ?>" /> |
|---|
| 588 | <br class="clear" /> |
|---|
| 589 | </p> |
|---|
| 590 | </td></tr> |
|---|
| 591 | </tbody></table></form> |
|---|
| 592 | <?php |
|---|
| 593 | } |
|---|
| 594 | } |
|---|