diff --git a/includes/output/class-displayfeaturedimagegenesis-output-term.php b/includes/output/class-displayfeaturedimagegenesis-output-term.php
new file mode 100644
index 0000000..c7adfdc
--- /dev/null
+++ b/includes/output/class-displayfeaturedimagegenesis-output-term.php
@@ -0,0 +1,180 @@
+instance = $instance;
+ $this->args = $this->update_args( $args );
+ $this->term = $term;
+ $this->id_base = $id_base ? $id_base : 'display-featured-image-genesis-term';
+ $this->init();
+ }
+
+ /**
+ * Output the featured term.
+ * @since 3.1.0
+ */
+ private function init() {
+ if ( ! empty( $this->instance['title'] ) ) {
+ echo wp_kses_post( $this->args['before_title'] . apply_filters( 'widget_title', $this->instance['title'], $this->instance, $this->id_base ) . $this->args['after_title'] );
+ }
+
+ $title = displayfeaturedimagegenesis_get_term_meta( $this->term, 'headline' );
+ if ( ! $title ) {
+ $title = $this->term->name;
+ }
+ $permalink = get_term_link( $this->term );
+
+ $this->do_image( $title, $permalink );
+
+ $this->do_title( $title, $permalink );
+
+ $this->do_content();
+
+ $this->do_archive_link();
+ }
+
+ /**
+ * Echo the term image with markup.
+ *
+ * @param $term_id
+ * @param $title
+ * @param $permalink
+ */
+ private function do_image( $title, $permalink ) {
+ $term_image = displayfeaturedimagegenesis_get_term_image( $this->instance['term'] );
+ if ( ! $term_image ) {
+ return;
+ }
+ $image = wp_get_attachment_image(
+ $term_image,
+ $this->instance['image_size'],
+ false,
+ array(
+ 'alt' => $title,
+ )
+ );
+
+ if ( $this->instance['show_image'] && $image ) {
+ $role = empty( $this->instance['show_title'] ) ? '' : 'aria-hidden="true"';
+ printf( '%s', esc_url( $permalink ), esc_html( $title ), esc_attr( $this->instance['image_alignment'] ), $role, wp_kses_post( $image ) );
+ }
+ }
+
+ /**
+ * Echo the term title with markup.
+ *
+ * @param $title
+ * @param $permalink
+ */
+ private function do_title( $title, $permalink ) {
+ if ( ! $this->instance['show_title'] ) {
+ return;
+ }
+
+ if ( empty( $this->instance['show_title'] ) ) {
+ return;
+ }
+ $title_output = sprintf( '
', esc_url( $permalink ), esc_html( $title ) );
+ if ( ! genesis_html5() ) {
+ $title_output = sprintf( '', esc_url( $permalink ), esc_html( $title ) );
+ }
+ echo wp_kses_post( $title_output );
+ }
+
+ /**
+ * Echo the term intro text or description.
+ */
+ private function do_content() {
+ if ( ! $this->instance['show_content'] ) {
+ return;
+ }
+
+ echo genesis_html5() ? '' : '';
+
+ $intro_text = displayfeaturedimagegenesis_get_term_meta( $this->term, 'intro_text' );
+ $intro_text = apply_filters( 'display_featured_image_genesis_term_description', $intro_text );
+ if ( ! $intro_text ) {
+ $intro_text = $this->term->description;
+ }
+
+ if ( 'custom' === $this->instance['show_content'] ) {
+ $intro_text = $this->instance['custom_content'];
+ }
+
+ echo wp_kses_post( wpautop( $intro_text ) );
+
+ echo genesis_html5() ? '
' : '';
+ }
+
+ /**
+ * Echo the term archive link.
+ */
+ private function do_archive_link() {
+ if ( ! $this->instance['archive_link'] || ! $this->instance['archive_link_text'] ) {
+ return;
+ }
+ printf(
+ '%s
',
+ esc_url( get_term_link( $this->term ) ),
+ esc_html( $this->instance['archive_link_text'] )
+ );
+ }
+
+ /**
+ * Update the "sidebar" args with some defaults (really only needed for the title).
+ *
+ * @param array $args
+ *
+ * @return array
+ * @since 1.7.0
+ *
+ */
+ private function update_args( $args ) {
+ $defaults = array(
+ 'before_title' => '',
+ 'after_title' => '
',
+ );
+
+ return wp_parse_args( $args, $defaults );
+ }
+}
diff --git a/includes/widgets/displayfeaturedimagegenesis-taxonomy-widget.php b/includes/widgets/displayfeaturedimagegenesis-taxonomy-widget.php
index ca170d2..b05730c 100644
--- a/includes/widgets/displayfeaturedimagegenesis-taxonomy-widget.php
+++ b/includes/widgets/displayfeaturedimagegenesis-taxonomy-widget.php
@@ -82,120 +82,16 @@ class Display_Featured_Image_Genesis_Widget_Taxonomy extends WP_Widget {
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'];
- }
-
- $this->do_image( $term_id, $title, $permalink, $instance );
-
- $this->do_title( $title, $permalink, $instance );
-
- $this->do_content( $term, $instance );
-
- $this->do_archive_link( $term, $instance );
+ include plugin_dir_path( dirname( __FILE__ ) ) . 'output/class-displayfeaturedimagegenesis-output-term.php';
+ new DisplayFeaturedImageGenesisOutputTerm( $instance, $args, $term, $this->id_base );
echo $args['after_widget'];
}
- /**
- * Echo the term image with markup.
- *
- * @param $term_id
- * @param $title
- * @param $permalink
- * @param $instance
- */
- protected function do_image( $term_id, $title, $permalink, $instance ) {
- $term_image = displayfeaturedimagegenesis_get_term_image( $term_id );
- if ( ! $term_image ) {
- return;
- }
- $image = wp_get_attachment_image( $term_image, $instance['image_size'], false, array(
- 'alt' => $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 ) );
- }
- }
-
- /**
- * Echo the term title with markup.
- *
- * @param $title
- * @param $permalink
- * @param $instance
- */
- protected function do_title( $title, $permalink, $instance ) {
- if ( ! $instance['show_title'] ) {
- return;
- }
-
- if ( ! empty( $instance['show_title'] ) ) {
-
- $title_output = sprintf( '', esc_url( $permalink ), esc_html( $title ) );
- if ( genesis_html5() ) {
- $title_output = sprintf( '', esc_url( $permalink ), esc_html( $title ) );
- }
- echo wp_kses_post( $title_output );
- }
- }
-
- /**
- * Echo the term intro text or description.
- *
- * @param $term
- * @param $instance
- */
- protected function do_content( $term, $instance ) {
- if ( ! $instance['show_content'] ) {
- return;
- }
-
- 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;
- }
-
- if ( 'custom' === $instance['show_content'] ) {
- $intro_text = $instance['custom_content'];
- }
-
- echo wp_kses_post( wpautop( $intro_text ) );
-
- echo genesis_html5() ? '
' : '';
- }
-
- /**
- * Echo the term archive link.
- *
- * @param $term
- * @param $instance
- */
- protected function do_archive_link( $term, $instance ) {
- if ( ! $instance['archive_link'] || ! $instance['archive_link_text'] ) {
- return;
- }
- printf( '%s
',
- esc_url( get_term_link( $term ) ),
- esc_html( $instance['archive_link_text'] )
- );
- }
-
/**
* Update a particular instance.
*