* @license GPL-2.0+ * @link https://robincornett.com * @copyright 2014-2016 Robin Cornett Creative, LLC * @since 2.0.0 */ /** * Genesis Featured Taxonomy widget class. * * @since 2.0.0 * */ class Display_Featured_Image_Genesis_Widget_Taxonomy extends WP_Widget { /** * Holds widget settings defaults, populated in constructor. * * @var array */ protected $defaults; /** * Constructor. Set the default widget options and create widget. * * @since 2.0.0 */ function __construct() { $this->defaults = array( 'title' => '', 'taxonomy' => 'category', 'term' => 'none', 'show_image' => 0, 'image_alignment' => '', 'image_size' => 'medium', 'show_title' => 0, 'show_content' => 0, ); $widget_ops = array( 'classname' => 'featured-term', 'description' => __( 'Displays a term with its featured image', 'display-featured-image-genesis' ), 'customize_selective_refresh' => true, ); $control_ops = array( 'id_base' => 'featured-taxonomy', 'width' => 505, 'height' => 350, ); parent::__construct( 'featured-taxonomy', __( 'Display Featured Term Image', 'display-featured-image-genesis' ), $widget_ops, $control_ops ); add_action( 'wp_ajax_widget_selector', array( $this, 'term_action_callback' ) ); } /** * Echo the widget content. * * @since 2.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 ) { global $wp_query, $_genesis_displayed_ids; // Merge with defaults $instance = wp_parse_args( (array) $instance, $this->defaults ); $term_id = $instance['term']; $term = get_term_by( 'id', $term_id, $instance['taxonomy'] ); if ( ! $term ) { return; } $title = displayfeaturedimagegenesis_get_term_meta( $term, 'headline' ); if ( ! $title ) { $title = $term->name; } $permalink = get_term_link( $term ); $args['before_widget'] = str_replace( 'class="widget ', 'class="widget ' . $term->slug . ' ', $args['before_widget'] ); echo $args['before_widget']; if ( ! empty( $instance['title'] ) ) { echo $args['before_title'] . apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base ) . $args['after_title']; } $image = ''; $term_image = displayfeaturedimagegenesis_get_term_image( $term_id ); if ( $term_image ) { $image_src = wp_get_attachment_image_src( $term_image, $instance['image_size'] ); if ( $image_src ) { $image = '' . esc_html( $title ) . ''; } if ( $instance['show_image'] && $image ) { $role = empty( $instance['show_title'] ) ? '' : 'aria-hidden="true"'; printf( '%s', esc_url( $permalink ), esc_html( $title ), esc_attr( $instance['image_alignment'] ), $role, wp_kses_post( $image ) ); } } if ( $instance['show_title'] ) { if ( ! empty( $instance['show_title'] ) ) { $title_output = sprintf( '

%s

', esc_url( $permalink ), esc_html( $title ) ); if ( genesis_html5() ) { $title_output = sprintf( '

%s

', esc_url( $permalink ), esc_html( $title ) ); } echo wp_kses_post( $title_output ); } } if ( $instance['show_content'] ) { echo genesis_html5() ? '
' : ''; $intro_text = displayfeaturedimagegenesis_get_term_meta( $term, 'intro_text' ); $intro_text = apply_filters( 'display_featured_image_genesis_term_description', $intro_text ); if ( ! $intro_text ) { $intro_text = $term->description; } echo wp_kses_post( wpautop( $intro_text ) ); echo genesis_html5() ? '
' : ''; } echo $args['after_widget']; } /** * Update a particular instance. * * This function should check that $new_instance is set correctly. * The newly calculated value of $instance should be returned. * If "false" is returned, the instance won't be saved/updated. * * @since 2.0.0 * * @param array $new_instance New settings for this instance as input by the user via 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 ) { $new_instance['title'] = strip_tags( $new_instance['title'] ); return $new_instance; } /** * Echo the settings update form. * * @since 2.0.0 * * @param array $instance Current settings */ function form( $instance ) { // Merge with defaults $instance = wp_parse_args( (array) $instance, $this->defaults ); ?>

/>

/>

/>

'name', 'order' => 'ASC', 'hide_empty' => false, ); $terms = get_terms( $_POST['taxonomy'], $args ); // Build an appropriate JSON response containing this info $list['none'] = '--'; foreach ( $terms as $term ) { $list[ $term->term_id ] = esc_attr( $term->name ); } // And emit it $emit = json_encode( $list ); if ( function_exists( 'wp_json_encode' ) ) { $emit = wp_json_encode( $list ); } echo $emit; die(); } }