Add data-icon input to Wordpress custom menu links

I need to add a data-icon="" input to my Wordpress Custom Menu input box thing. This is so I can use an icon font and type the code in for a specific icon and in the CSS use pseudo elements to match it up and display the icon.

I've found loads of tutorials which show how to extend the Walker_Nav_Menu class so I can add an attribute, but none of them extend this into adding a new input box on the Wordpress Custom Menu screen (http://cl.ly/Sn0C) and then having the value of this displayed in the HTML.

I've used this code to add a data-icon input box on the Custom Menu admin screen (http://cl.ly/SmqM) but I'm not good enough at PHP to link it up to the Walker_Nav_Menu extension class to show the data-icon value in the HTML. Can anyone help me out? Thanks :)

I would prefer if this could be done in functions.php and/or without the use of a plugin. Thanks!

Btw, here is my Walker_Nav_Menu extension class code:

class data_type_walker extends Walker_Nav_Menu {
      function start_el($output, $item, $depth, $args) {
           global $wp_query;
           $indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';

           $class_names = $value = '';

           $classes = empty( $item-classes ) ? array() : (array) $item-classes;

           $class_names = join( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item ) );
           $class_names = ' class="'. esc_attr( $class_names ) . '"';

           $output .= $indent . 'li id="menu-item-'. $item-ID . '"' . $value . $class_names .'';

           $attributes  = ! empty( $item-attr_title ) ? ' title="'     . esc_attr( $item-attr_title       ) .'"' : '';
           $attributes .= ! empty( $item-target )     ? ' target="'    . esc_attr( $item-target           ) .'"' : '';
           $attributes .= ! empty( $item-xfn )        ? ' rel="'       . esc_attr( $item-xfn              ) .'"' : '';
           $attributes .= ! empty( $item-url )        ? ' href="'      . esc_attr( $item-url              ) .'"' : '';
           $attributes .= ! empty( $item-data_icon )  ? ' data-icon="' . esc_attr( $item-data_icon        ) .'"' : '';

           $prepend = '';
           $append = '';

           if($depth != 0) {
                 $description = $append = $prepend = "";
           }

            $item_output = $args-before;
            $item_output .= 'a'. $attributes .' aria-hidden="true"';
            $item_output .= $args-link_before .$prepend.apply_filters( 'the_title', $item-title, $item-ID ).$append;
            $item_output .= $description.$args-link_after;
            $item_output .= '/a';
            $item_output .= $args-after;

            $output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args );
        }
}

EDIT: Chittaranjan asked me for some more info so here goes:

I'm calling this new extension (data_type_walker) on the class Walker_Nav_Menu in my header.php file where my nav menu is located. Calling it as follows:

?php wp_nav_menu( array( 'theme_location' = 'primary', 'container' = false, 'menu_class'= 'nav-menu', 'walker' = new data_type_walker() ) ); ?

The output should be something like this:

li class="all the various wordpress menu classes"a href="url" data-icon="whatever input I choose in the Custom Menu Admin section" aria-hidden="true"navigation text link/a/li

Topic screen-options navigation menus Wordpress

Category Web


Another option is to toggle the CSS Classes checkbox under screen option, WP Admin > Appearance > Menus, and attach the icon to a CSS class.

And add your icons using psuedo selectors to the CSS class.

enter image description here

enter image description here

About

Geeks Mental is a community that publishes articles and tutorials about Web, Android, Data Science, new techniques and Linux security.