Displaying description on a classic recent post element

Good afternoon,

I have a page on my site that displays the latest posts using the ‘classic recent posts’. I have modified it to my liking but I cannot work out how to display the first 60 characters of the post itself.

The code is as follows:

function x_shortcode_recent_posts_v2code( $atts ) {
  extract( shortcode_atts( array(
'id'           => '',
'class'        => '',
'style'        => '',
'type'         => 'post',
'count'        => '',
'category'     => '',
'offset'       => '',
'orientation'  => '',
'show_excerpt' => 'false',
'no_sticky'    => '',
'no_image'     => '',
'fade'         => ''
  ), $atts, 'x_recent_posts' ) );

  $allowed_post_types = apply_filters( 'cs_recent_posts_post_types', array( 'post' => 'post' ) );
  $type = ( isset( $allowed_post_types[$type] ) ) ? $allowed_post_types[$type] : 'post';

  $id            = ( $id           != ''     ) ? 'id="' . esc_attr( $id ) . '"' : '';
  $class         = ( $class        != ''     ) ? 'x-recent-posts cf ' . esc_attr( $class ) : 'x-recent-posts cf';
  $style         = ( $style        != ''     ) ? 'style="' . $style . '"' : '';
  $count         = ( $count        != ''     ) ? $count : 3;
  $category      = ( $category     != ''     ) ? $category : '';
  $category_type = ( $type         == 'post' ) ? 'category_name' : 'portfolio-category';
  $offset        = ( $offset       != ''     ) ? $offset : 0;
  $orientation   = ( $orientation  != ''     ) ? ' ' . $orientation : ' horizontal';
  $show_excerpt  = ( $show_excerpt == 'true' );
  $no_sticky     = ( $no_sticky    == 'true' );
  $no_image      = ( $no_image     == 'true' ) ? $no_image : '';
  $fade          = ( $fade         == 'true' ) ? $fade : 'false';

  $js_params = array(
'fade' => ( $fade == 'true' )
  );

  $data = cs_generate_data_attributes( 'recent_posts', $js_params );

  $output = "<div {$id} class=\"{$class}{$orientation}\" {$style} {$data} data-fade=\"{$fade}\" >";

$q = new WP_Query( array(
  'orderby'             => 'date',
  'post_type'           => "{$type}",
  'posts_per_page'      => "{$count}",
  'offset'              => "{$offset}",
  "{$category_type}"    => "{$category}",
  'ignore_sticky_posts' => $no_sticky
) );

if ( $q->have_posts() ) : while ( $q->have_posts() ) : $q->the_post();

  if ( $no_image == 'true' ) {
    $image_output       = '';
    $image_output_class = 'no-image';
  } else {
    $image              = wp_get_attachment_image_src( get_post_thumbnail_id(), 'entry-cropped' );
    $bg_image           = ( $image[0] != '' ) ? ' style="background-image: url(' . $image[0] . ');"' : '';
    $image_output       = '<div class="x-recent-posts-img"' . $bg_image . '></div>';
    $image_output_class = 'with-image';
  }

  $excerpt = ( $show_excerpt ) ? '<div class="x-recent-posts-excerpt"><p>' . preg_replace('/<a.*?more-link.*?<\/a>/', '', cs_get_raw_excerpt() ) . '</p></div>' : '';

  $output .= '<a class="x-recent-post' . $count . ' ' . $image_output_class . '" href="' . get_permalink( get_the_ID() ) . '" title="' . esc_attr( sprintf( __( 'Permalink to: "%s"', 'cornerstone' ), the_title_attribute( 'echo=0' ) ) ) . '">'
             . '<article id="post-' . get_the_ID() . '" class="' . implode( ' ', get_post_class() ) . '">'
               . '<div class="entry-wrap">'
                 . $image_output
                 . '<div class="x-recent-posts-content">'
                   . '<h3 class="h-recent-posts">' . get_the_title() . '</h3>'
                   . '<span class="x-recent-posts-date">' . get_the_date() . '</span>'
                    . $excerpt
                    . '<span class="x-btn x-btn-rounded x-btn-regular">Acess Now</span>'
                 . '</div>'
               . '</div>'
             . '</article>'
           . '</a>';

endwhile; endif; wp_reset_postdata();

  $output .= '</div>';

  return $output;
}

add_action('wp_head', 'change_recent_posts_to_v2');

function change_recent_posts_to_v2() {
remove_shortcode( 'x_recent_posts' );
add_shortcode( 'x_recent_posts', 'x_shortcode_recent_posts_v2code' );
}

if ( ! function_exists( 'x_excerpt_string' ) ) :
  function x_excerpt_string( $more ) {

$stack = x_get_stack();

if ( $stack == 'integrity' ) {
  return ' ... <div><a href="' . get_permalink() . '" class="more-link">' . __( 'More', '__x__' ) . '</a></div>';
} else if ( $stack == 'renew' ) {
  return ' ... <a href="' . get_permalink() . '" class="more-link">' . __( 'More', '__x__' ) . '</a>';
} else if ( $stack == 'icon' ) {
  return ' ...';
} else if ( $stack == 'ethos' ) {
  return ' ...';
}

  }
  add_filter( 'excerpt_more', 'x_excerpt_string' );
endif;

Login Details are in the secure note along with the page it can be seen on

Thank you
Jason

Hi There,

Could you please try adding the following code into your child theme’s functions.php file and see if that helps.

// Excerpt Custom Length
// =============================================================================
function x_excerpt_length( $length ) {
    return 20;
}  
add_filter( 'excerpt_length', 'x_excerpt_length' );

You can refer more information here (https://codex.wordpress.org/Plugin_API/Filter_Reference/excerpt_length).

Hope that helps.

Good morning and thank you for this - I have inserted it into the child theme’s functions.php file and nothing has happened

Kind Regards,
Jason

Hi There,

Please update your code to this:

function x_shortcode_recent_posts_v2code( $atts ) {
  extract( shortcode_atts( array(
'id'           => '',
'class'        => '',
'style'        => '',
'type'         => 'post',
'count'        => '',
'category'     => '',
'offset'       => '',
'orientation'  => '',
'show_excerpt' => 'false',
'no_sticky'    => '',
'no_image'     => '',
'fade'         => ''
  ), $atts, 'x_recent_posts' ) );

  $allowed_post_types = apply_filters( 'cs_recent_posts_post_types', array( 'post' => 'post' ) );
  $type = ( isset( $allowed_post_types[$type] ) ) ? $allowed_post_types[$type] : 'post';

  $id            = ( $id           != ''     ) ? 'id="' . esc_attr( $id ) . '"' : '';
  $class         = ( $class        != ''     ) ? 'x-recent-posts cf ' . esc_attr( $class ) : 'x-recent-posts cf';
  $style         = ( $style        != ''     ) ? 'style="' . $style . '"' : '';
  $count         = ( $count        != ''     ) ? $count : 3;
  $category      = ( $category     != ''     ) ? $category : '';
  $category_type = ( $type         == 'post' ) ? 'category_name' : 'portfolio-category';
  $offset        = ( $offset       != ''     ) ? $offset : 0;
  $orientation   = ( $orientation  != ''     ) ? ' ' . $orientation : ' horizontal';
  $show_excerpt  = ( $show_excerpt == 'true' );
  $no_sticky     = ( $no_sticky    == 'true' );
  $no_image      = ( $no_image     == 'true' ) ? $no_image : '';
  $fade          = ( $fade         == 'true' ) ? $fade : 'false';

  $js_params = array(
'fade' => ( $fade == 'true' )
  );

  $data = cs_generate_data_attributes( 'recent_posts', $js_params );

  $output = "<div {$id} class=\"{$class}{$orientation}\" {$style} {$data} data-fade=\"{$fade}\" >";

$q = new WP_Query( array(
  'orderby'             => 'date',
  'post_type'           => "{$type}",
  'posts_per_page'      => "{$count}",
  'offset'              => "{$offset}",
  "{$category_type}"    => "{$category}",
  'ignore_sticky_posts' => $no_sticky
) );

if ( $q->have_posts() ) : while ( $q->have_posts() ) : $q->the_post();

  if ( $no_image == 'true' ) {
    $image_output       = '';
    $image_output_class = 'no-image';
  } else {
    $image              = wp_get_attachment_image_src( get_post_thumbnail_id(), 'entry-cropped' );
    $bg_image           = ( $image[0] != '' ) ? ' style="background-image: url(' . $image[0] . ');"' : '';
    $image_output       = '<div class="x-recent-posts-img"' . $bg_image . '></div>';
    $image_output_class = 'with-image';
  }

  $excerpt = ( $show_excerpt ) ? '<div class="x-recent-posts-excerpt"><p>' . preg_replace('/<a.*?more-link.*?<\/a>/', '', wp_trim_words( cs_get_raw_excerpt(), 60) ) . '</p></div>' : '';

  $output .= '<a class="x-recent-post' . $count . ' ' . $image_output_class . '" href="' . get_permalink( get_the_ID() ) . '" title="' . esc_attr( sprintf( __( 'Permalink to: "%s"', 'cornerstone' ), the_title_attribute( 'echo=0' ) ) ) . '">'
             . '<article id="post-' . get_the_ID() . '" class="' . implode( ' ', get_post_class() ) . '">'
               . '<div class="entry-wrap">'
                 . $image_output
                 . '<div class="x-recent-posts-content">'
                   . '<h3 class="h-recent-posts">' . get_the_title() . '</h3>'
                   . '<span class="x-recent-posts-date">' . get_the_date() . '</span>'
                    . $excerpt
                    . '<span class="x-btn x-btn-rounded x-btn-regular">Acess Now</span>'
                 . '</div>'
               . '</div>'
             . '</article>'
           . '</a>';

endwhile; endif; wp_reset_postdata();

  $output .= '</div>';

  return $output;
}

add_action('wp_head', 'change_recent_posts_to_v2');

function change_recent_posts_to_v2() {
remove_shortcode( 'x_recent_posts' );
add_shortcode( 'x_recent_posts', 'x_shortcode_recent_posts_v2code' );
}

if ( ! function_exists( 'x_excerpt_string' ) ) :
  function x_excerpt_string( $more ) {

$stack = x_get_stack();

if ( $stack == 'integrity' ) {
  return ' ... <div><a href="' . get_permalink() . '" class="more-link">' . __( 'More', '__x__' ) . '</a></div>';
} else if ( $stack == 'renew' ) {
  return ' ... <a href="' . get_permalink() . '" class="more-link">' . __( 'More', '__x__' ) . '</a>';
} else if ( $stack == 'icon' ) {
  return ' ...';
} else if ( $stack == 'ethos' ) {
  return ' ...';
}

  }
  add_filter( 'excerpt_more', 'x_excerpt_string' );
endif;

Let us know how it goes!

Good morning and thank you for the quick response

I have updated and nothing has happened

Kind Regards

Hi There,

Can you please send us your website details so that we can have a look.

Please provide following information:
Set it as Secure Note

  • Link to your site
  • WordPress Admin username / password
  • FTP credentials
    All the best!

Good morning team! All details you requested are in the secure note at the top

Thank you!
Jason

Hi Jason,

I change this line of code from false to true and it showed the excerpt.

'show_excerpt' => 'true',

Please check - https://voiceovercoach.co.uk/resources/

Thanks

Oh that is perfect thank you very much!!

You are most welcome!

Oh sorry I just noticed that on the resources page the titles are cut off - what do I need to do so the user can view the full version? The description is fine as it is

Thank you!
Jason

Hi There,

Thanks for writing in!

Please add this CSS to your Theme option -> Global CSS and let us know how this goes.

.x-recent-posts .h-recent-posts, 
.x-recent-posts .x-recent-posts-date {
 white-space: normal !important;
}

if you want the change to be reflect in that page only please use this CSS instead.

.page-id-361 .x-recent-posts .h-recent-posts, 
.page-id-361 .x-recent-posts .x-recent-posts-date {
 white-space: normal !important;
}

Hope this helps!

I have gone for the second option thank you!

Super fast!
Jason

You’re welcome! :slight_smile:

This topic was automatically closed 10 days after the last reply. New replies are no longer allowed.