class-walker-nav-menu-checklist.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <?php
  2. /**
  3. * Navigation Menu API: Walker_Nav_Menu_Checklist class
  4. *
  5. * @package WordPress
  6. * @subpackage Administration
  7. * @since 4.4.0
  8. */
  9. /**
  10. * Create HTML list of nav menu input items.
  11. *
  12. * @since 3.0.0
  13. * @uses Walker_Nav_Menu
  14. */
  15. class Walker_Nav_Menu_Checklist extends Walker_Nav_Menu {
  16. /**
  17. * @param array $fields
  18. */
  19. public function __construct( $fields = false ) {
  20. if ( $fields ) {
  21. $this->db_fields = $fields;
  22. }
  23. }
  24. /**
  25. * Starts the list before the elements are added.
  26. *
  27. * @see Walker_Nav_Menu::start_lvl()
  28. *
  29. * @since 3.0.0
  30. *
  31. * @param string $output Used to append additional content (passed by reference).
  32. * @param int $depth Depth of page. Used for padding.
  33. * @param array $args Not used.
  34. */
  35. public function start_lvl( &$output, $depth = 0, $args = array() ) {
  36. $indent = str_repeat( "\t", $depth );
  37. $output .= "\n$indent<ul class='children'>\n";
  38. }
  39. /**
  40. * Ends the list of after the elements are added.
  41. *
  42. * @see Walker_Nav_Menu::end_lvl()
  43. *
  44. * @since 3.0.0
  45. *
  46. * @param string $output Used to append additional content (passed by reference).
  47. * @param int $depth Depth of page. Used for padding.
  48. * @param array $args Not used.
  49. */
  50. public function end_lvl( &$output, $depth = 0, $args = array() ) {
  51. $indent = str_repeat( "\t", $depth );
  52. $output .= "\n$indent</ul>";
  53. }
  54. /**
  55. * Start the element output.
  56. *
  57. * @see Walker_Nav_Menu::start_el()
  58. *
  59. * @since 3.0.0
  60. *
  61. * @global int $_nav_menu_placeholder
  62. *
  63. * @param string $output Used to append additional content (passed by reference).
  64. * @param object $item Menu item data object.
  65. * @param int $depth Depth of menu item. Used for padding.
  66. * @param array $args Not used.
  67. * @param int $id Not used.
  68. */
  69. public function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) {
  70. global $_nav_menu_placeholder;
  71. $_nav_menu_placeholder = ( 0 > $_nav_menu_placeholder ) ? intval( $_nav_menu_placeholder ) - 1 : -1;
  72. $possible_object_id = isset( $item->post_type ) && 'nav_menu_item' == $item->post_type ? $item->object_id : $_nav_menu_placeholder;
  73. $possible_db_id = ( ! empty( $item->ID ) ) && ( 0 < $possible_object_id ) ? (int) $item->ID : 0;
  74. $indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';
  75. $output .= $indent . '<li>';
  76. $output .= '<label class="menu-item-title">';
  77. $output .= '<input type="checkbox" class="menu-item-checkbox';
  78. if ( ! empty( $item->front_or_home ) ) {
  79. $output .= ' add-to-top';
  80. }
  81. $output .= '" name="menu-item[' . $possible_object_id . '][menu-item-object-id]" value="' . esc_attr( $item->object_id ) . '" /> ';
  82. if ( ! empty( $item->label ) ) {
  83. $title = $item->label;
  84. } elseif ( isset( $item->post_type ) ) {
  85. /** This filter is documented in wp-includes/post-template.php */
  86. $title = apply_filters( 'the_title', $item->post_title, $item->ID );
  87. }
  88. $output .= isset( $title ) ? esc_html( $title ) : esc_html( $item->title );
  89. if ( empty( $item->label ) && isset( $item->post_type ) && 'page' === $item->post_type ) {
  90. // Append post states.
  91. $output .= _post_states( $item, false );
  92. }
  93. $output .= '</label>';
  94. // Menu item hidden fields
  95. $output .= '<input type="hidden" class="menu-item-db-id" name="menu-item[' . $possible_object_id . '][menu-item-db-id]" value="' . $possible_db_id . '" />';
  96. $output .= '<input type="hidden" class="menu-item-object" name="menu-item[' . $possible_object_id . '][menu-item-object]" value="' . esc_attr( $item->object ) . '" />';
  97. $output .= '<input type="hidden" class="menu-item-parent-id" name="menu-item[' . $possible_object_id . '][menu-item-parent-id]" value="' . esc_attr( $item->menu_item_parent ) . '" />';
  98. $output .= '<input type="hidden" class="menu-item-type" name="menu-item[' . $possible_object_id . '][menu-item-type]" value="' . esc_attr( $item->type ) . '" />';
  99. $output .= '<input type="hidden" class="menu-item-title" name="menu-item[' . $possible_object_id . '][menu-item-title]" value="' . esc_attr( $item->title ) . '" />';
  100. $output .= '<input type="hidden" class="menu-item-url" name="menu-item[' . $possible_object_id . '][menu-item-url]" value="' . esc_attr( $item->url ) . '" />';
  101. $output .= '<input type="hidden" class="menu-item-target" name="menu-item[' . $possible_object_id . '][menu-item-target]" value="' . esc_attr( $item->target ) . '" />';
  102. $output .= '<input type="hidden" class="menu-item-attr-title" name="menu-item[' . $possible_object_id . '][menu-item-attr-title]" value="' . esc_attr( $item->attr_title ) . '" />';
  103. $output .= '<input type="hidden" class="menu-item-classes" name="menu-item[' . $possible_object_id . '][menu-item-classes]" value="' . esc_attr( implode( ' ', $item->classes ) ) . '" />';
  104. $output .= '<input type="hidden" class="menu-item-xfn" name="menu-item[' . $possible_object_id . '][menu-item-xfn]" value="' . esc_attr( $item->xfn ) . '" />';
  105. }
  106. } // Walker_Nav_Menu_Checklist