'classifyed_widget_social', 'description' => esc_html__( 'Social Icons Widget', 'classifyed' ), ); parent::__construct( 'classifyed-social', esc_html__( 'Classifyed: Social', 'classifyed' ), $opts ); } /** * Echo the widget content. * * @since 1.0.0 * * @param array $args Display arguments including before_title, after_title, * before_widget, and after_widget. * @param array $instance The settings for the particular instance of the widget. */ function widget( $args, $instance ) { $title = apply_filters( 'widget_title', empty( $instance['title'] ) ? '' : $instance['title'], $instance, $this->id_base ); echo $args['before_widget']; // Render title. if ( ! empty( $title ) ) { echo $args['before_title'] . $title . $args['after_title']; } $nav_menu_locations = get_nav_menu_locations(); $menu_id = 0; if ( isset( $nav_menu_locations['social'] ) && absint( $nav_menu_locations['social'] ) > 0 ) { $menu_id = absint( $nav_menu_locations['social'] ); } if ( $menu_id > 0 ) { $menu_items = wp_get_nav_menu_items( $menu_id ); if ( ! empty( $menu_items ) ) { echo ''; } } echo $args['after_widget']; } /** * Update widget instance. * * @since 1.0.0 * * @param array $new_instance New settings for this instance as input by the user via * {@see WP_Widget::form()}. * @param array $old_instance Old settings for this instance. * @return array Settings to save or bool false to cancel saving. */ function update( $new_instance, $old_instance ) { $instance = $old_instance; $instance['title'] = esc_html( strip_tags( $new_instance['title'] ) ); return $instance; } /** * Output the settings update form. * * @since 1.0.0 * * @param array $instance Current settings. */ function form( $instance ) { // Defaults. $instance = wp_parse_args( (array) $instance, array( 'title' => '', ) ); $title = esc_attr( $instance['title'] ); // Fetch navigation. $nav_menu_locations = get_nav_menu_locations(); $is_menu_set = false; if ( isset( $nav_menu_locations['social'] ) && absint( $nav_menu_locations['social'] ) > 0 ) { $is_menu_set = true; } ?>