%2$s'; if ( get_the_time( 'U' ) !== get_the_modified_time( 'U' ) ) { $time_string = ''; } $time_string = sprintf( $time_string, esc_attr( get_the_date( 'c' ) ), esc_html( get_the_date() ), esc_attr( get_the_modified_date( 'c' ) ), esc_html( get_the_modified_date() ) ); if ( is_sticky() ) { $posted_on = '' . esc_html__( 'Featured', 'button-2' ) . ''; } else { $posted_on = '' . $time_string . ''; } $byline = ' '; echo '' . $posted_on . ' '; // WPCS: XSS OK. if ( ! is_single() && ! post_password_required() && ( comments_open() || get_comments_number() ) ) { echo ''; comments_popup_link( esc_html__( 'Leave a comment', 'button-2' ), esc_html__( '1 Comment', 'button-2' ), esc_html__( '% Comments', 'button-2' ) ); echo ''; } edit_post_link( sprintf( /* translators: %s: Name of current post */ esc_html__( 'Edit %s', 'button-2' ), the_title( '"', '"', false ) ), '', '' ); } endif; if ( ! function_exists( 'button_2_entry_footer' ) ) : /** * Prints HTML with meta information for the tags and comments. */ function button_2_entry_footer() { // Hide tag text for pages and archives if ( 'post' == get_post_type() && is_single() ) { the_tags( '
' ); } } endif; if ( ! function_exists( 'button_2_entry_cats' ) ) : /** * Prints HTML with meta information for the categories. */ function button_2_entry_cats() { // Hide category text for pages. if ( 'post' == get_post_type() ) { /* translators: used between list items, there is a space */ $categories_list = get_the_category_list( esc_html__( ' · ', 'button-2' ) ); if ( $categories_list && button_2_categorized_blog() ) { printf( '%1$s', $categories_list ); // WPCS: XSS OK. } } } endif; /** * Returns true if a blog has more than 1 category. * * @return bool */ function button_2_categorized_blog() { if ( false === ( $all_the_cool_cats = get_transient( 'button_2_categories' ) ) ) { // Create an array of all the categories that are attached to posts. $all_the_cool_cats = get_categories( array( 'fields' => 'ids', 'hide_empty' => 1, // We only need to know if there is more than one category. 'number' => 2, ) ); // Count the number of categories that are attached to the posts. $all_the_cool_cats = is_countable( $all_the_cool_cats ) ? count( $all_the_cool_cats ) : 0; set_transient( 'button_2_categories', $all_the_cool_cats ); } if ( $all_the_cool_cats > 1 ) { // This blog has more than 1 category so button_2_categorized_blog should return true. return true; } else { // This blog has only 1 category so button_2_categorized_blog should return false. return false; } } /** * Flush out the transients used in button_2_categorized_blog. */ function button_2_category_transient_flusher() { if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) { return; } // Like, beat it. Dig? delete_transient( 'button_2_categories' ); } add_action( 'edit_category', 'button_2_category_transient_flusher' ); add_action( 'save_post', 'button_2_category_transient_flusher' ); if ( ! function_exists( 'button_2_continue_reading_link' ) ) : /** * Returns an ellipsis and "Continue reading" plus off-screen title link for excerpts */ function button_2_continue_reading_link() { return '… ' . sprintf( __( 'Continue reading %1$s', 'button-2' ), esc_attr( strip_tags( get_the_title() ) ) ) . ''; } endif; // button_2_continue_reading_link /** * Replaces "[...]" (appended to automatically generated excerpts) with button_2_continue_reading_link(). * * To override this in a child theme, remove the filter and add your own * function tied to the excerpt_more filter hook. */ function button_2_auto_excerpt_more() { return button_2_continue_reading_link(); } add_filter( 'excerpt_more', 'button_2_auto_excerpt_more' ); /** * Returns the URL from the post. * * @uses get_the_link() to get the URL in the post meta (if it exists) or * the first link found in the post content. * * Falls back to the post permalink if no URL is found in the post. * * @return string URL */ function button_2_get_link_url() { $content = get_the_content(); $has_url = get_url_in_content( $content ); return ( $has_url ) ? $has_url : apply_filters( 'the_permalink', get_permalink() ); }