%s', esc_url( home_url() ), get_bloginfo( 'name' ) );
}
/**
* Displays a link to WordPress.org.
*
* @since 1.0.0
* @access public
* @return void
*/
function hoot_wp_link() {
echo hoot_get_wp_link();
}
/**
* Returns a link to WordPress.org.
*
* @since 1.0.0
* @access public
* @return string
*/
function hoot_get_wp_link() {
return sprintf( '%s', esc_attr__( 'State-of-the-art semantic personal publishing platform', 'chromatic' ), __( 'WordPress', 'chromatic' ) );
}
/**
* Displays a link to theme on WordPress.org.
*
* @since 1.1.4
* @access public
* @param string $link
* @param string $anchor
* @return void
*/
function hoot_wp_theme_link( $link = '', $anchor = '' ) {
echo hoot_get_wp_theme_link( $link, $anchor );
}
/**
* Returns a link to theme on WordPress.org.
*
* @since 1.1.4
* @access public
* @param string $link
* @param string $anchor
* @return string
*/
function hoot_get_wp_theme_link( $link = '', $anchor = '' ) {
/* Get Theme */
$theme = wp_get_theme( get_stylesheet() );
$name = $theme->display( 'Name', false, true );
$link = ( empty( $link ) ) ? 'https://wordpress.org/themes/' . THEME_SLUG : $link;
$anchor = ( empty( $anchor ) ) ? sprintf( __( '%s WordPress Theme', 'chromatic' ), $name ) : $anchor;
$title = sprintf( __( '%s WordPress Theme', 'chromatic' ), $name );
return sprintf( '%s', esc_url( $link ), esc_attr( $title ), esc_html( $anchor ) );
}
/**
* Displays a link to the theme URI.
*
* @since 1.0.0
* @access public
* @param string $link
* @param string $anchor
* @return void
*/
function hoot_theme_link( $link = '', $anchor = '' ) {
echo hoot_get_theme_link( $link, $anchor );
}
/**
* Returns a link to the theme URI.
*
* @since 1.0.0
* @access public
* @param string $link
* @param string $anchor
* @return string
*/
function hoot_get_theme_link( $link = '', $anchor = '' ) {
/* Get Theme */
$theme = wp_get_theme( get_stylesheet() );
$name = $theme->display( 'Name', false, true );
$link = ( empty( $link ) ) ? $theme->get( 'ThemeURI' ) : $link;
$anchor = ( empty( $anchor ) ) ? $name : $anchor;
$title = sprintf( __( '%s WordPress Theme', 'chromatic' ), $name );
return sprintf( '%s', esc_url( $link ), esc_attr( $title ), esc_html( $anchor ) );
}
/**
* Gets the "blog" (posts page) page URL. `home_url()` will not always work for this because it
* returns the front page URL. Sometimes the blog page URL is set to a different page. This
* function handles both scenarios.
*
* @since 1.0.0
* @access public
* @return string
*/
function hoot_get_blog_url() {
$blog_url = '';
if ( 'posts' === get_option( 'show_on_front' ) )
$blog_url = esc_url( home_url() );
elseif ( 0 < ( $page_for_posts = get_option( 'page_for_posts' ) ) )
$blog_url = esc_url( get_permalink( $page_for_posts ) );
return $blog_url;
}
/**
* Outputs the site description.
*
* @since 1.0.0
* @access public
* @return void
*/
function hoot_site_description() {
echo hoot_get_site_description();
}
/**
* Returns the site description wrapped in an `
` tag.
*
* @since 1.0.0
* @access public
* @return string
*/
function hoot_get_site_description() {
if ( $desc = get_bloginfo( 'description' ) )
$desc = sprintf( '%s
', hoot_get_attr( 'site-description' ), $desc );
return apply_filters( 'hoot_site_description', $desc );
}
/**
* Outputs the loop title.
*
* @since 1.0.0
* @access public
* @return void
*/
function hoot_loop_title() {
echo hoot_get_loop_title();
}
/**
* Gets the loop title. This function should only be used on archive-type pages, such as archive, blog, and
* search results pages. It outputs the title of the page.
*
* @link http://core.trac.wordpress.org/ticket/21995
* @since 1.0.0
* @access public
* @return string
*/
function hoot_get_loop_title() {
$loop_title = $loop_title_suffix = '';
if ( is_home() && !is_front_page() )
$loop_title = get_post_field( 'post_title', get_queried_object_id() );
elseif ( is_category() )
$loop_title = single_cat_title( '', false );
elseif ( is_tag() )
$loop_title = single_tag_title( '', false );
elseif ( is_tax() )
$loop_title = single_term_title( '', false );
elseif ( is_author() )
$loop_title = hoot_single_author_title( '', false );
elseif ( is_search() )
$loop_title = hoot_search_title( '', false );
elseif ( is_post_type_archive() )
$loop_title = post_type_archive_title( '', false );
elseif ( get_query_var( 'minute' ) && get_query_var( 'hour' ) )
$loop_title = hoot_single_minute_hour_title( '', false );
elseif ( get_query_var( 'minute' ) )
$loop_title = hoot_single_minute_title( '', false );
elseif ( get_query_var( 'hour' ) )
$loop_title = hoot_single_hour_title( '', false );
elseif ( is_day() )
$loop_title = hoot_single_day_title( '', false );
elseif ( get_query_var( 'w' ) )
$loop_title = hoot_single_week_title( '', false );
elseif ( is_month() )
$loop_title = single_month_title( ' ', false );
elseif ( is_year() )
$loop_title = hoot_single_year_title( '', false );
elseif ( is_archive() )
$loop_title = hoot_single_archive_title( '', false );
$loop_title = apply_filters( 'hoot_loop_title', $loop_title );
/* If the current page is a paged page. */
if ( ( ( $page = get_query_var( 'paged' ) ) || ( $page = get_query_var( 'page' ) ) ) && $page > 1 ) {
$paged = number_format_i18n( absint( $page ) );
$loop_title_suffix = ' ' . sprintf( __( '(Page %s)', 'chromatic' ), $paged ) . '';
$loop_title_suffix = apply_filters( 'hoot_loop_title_suffix', $loop_title_suffix, $paged );
}
return $loop_title . $loop_title_suffix;
}
/**
* Outputs the loop description.
*
* @since 1.0.0
* @access public
* @return void
*/
function hoot_loop_description() {
echo hoot_get_loop_description();
}
/**
* Gets the loop description. This function should only be used on archive-type pages, such as archive, blog, and
* search results pages. It outputs the description of the page.
*
* @link http://core.trac.wordpress.org/ticket/21995
* @since 1.0.0
* @access public
* @return string
*/
function hoot_get_loop_description() {
$loop_desc = '';
if ( is_home() && !is_front_page() )
$loop_desc = get_post_field( 'post_content', get_queried_object_id(), 'raw' );
elseif ( is_category() )
$loop_desc = get_term_field( 'description', get_queried_object_id(), 'category', 'raw' );
elseif ( is_tag() )
$loop_desc = get_term_field( 'description', get_queried_object_id(), 'post_tag', 'raw' );
elseif ( is_tax() )
$loop_desc = get_term_field( 'description', get_queried_object_id(), get_query_var( 'taxonomy' ), 'raw' );
elseif ( is_author() )
$loop_desc = get_the_author_meta( 'description', get_query_var( 'author' ) );
elseif ( is_search() ) {
$search_query = get_search_query();
$loop_desc = sprintf( __( 'You are browsing the search results for “%s”', 'chromatic' ), $search_query );
$title = apply_filters( 'hoot_search_description', $loop_desc, $search_query );
}
elseif ( is_post_type_archive() )
$loop_desc = get_post_type_object( get_query_var( 'post_type' ) )->description;
elseif ( is_time() )
$loop_desc = __( 'You are browsing the site archives by time.', 'chromatic' );
elseif ( is_day() )
$loop_desc = sprintf( __( 'You are browsing the site archives for %s.', 'chromatic' ), hoot_single_day_title( '', false ) );
elseif ( is_month() )
$loop_desc = sprintf( __( 'You are browsing the site archives for %s.', 'chromatic' ), single_month_title( ' ', false ) );
elseif ( is_year() )
$loop_desc = sprintf( __( 'You are browsing the site archives for %s.', 'chromatic' ), hoot_single_year_title( '', false ) );
elseif ( is_archive() )
$loop_desc = __( 'You are browsing the site archives.', 'chromatic' );
return apply_filters( 'hoot_loop_description', $loop_desc );
}
/**
* Retrieve the general archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_archive_title( $prefix = '', $display = true ) {
$title = $prefix . __( 'Archives', 'chromatic' );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the author archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_author_title( $prefix = '', $display = true ) {
$title = $prefix . get_the_author_meta( 'display_name', get_query_var( 'author' ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the year archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_year_title( $prefix = '', $display = true ) {
$title = $prefix . get_the_date( _x( 'Y', 'yearly archives date format', 'chromatic' ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the week archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_week_title( $prefix = '', $display = true ) {
/* Translators: 1 is the week number and 2 is the year. */
$title = $prefix . sprintf( __( 'Week %1$s of %2$s', 'chromatic' ), get_the_time( _x( 'W', 'weekly archives date format', 'chromatic' ) ), get_the_time( _x( 'Y', 'yearly archives date format', 'chromatic' ) ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the day archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_day_title( $prefix = '', $display = true ) {
$title = $prefix . get_the_date( _x( 'F j, Y', 'daily archives date format', 'chromatic' ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the hour archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_hour_title( $prefix = '', $display = true ) {
$title = $prefix . get_the_time( _x( 'g a', 'hour archives time format', 'chromatic' ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the minute archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_minute_title( $prefix = '', $display = true ) {
/* Translators: Minute archive title. %s is the minute time format. */
$title = $prefix . sprintf( __( 'Minute %s', 'chromatic' ), get_the_time( _x( 'i', 'minute archives time format', 'chromatic' ) ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the minute + hour archive title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_single_minute_hour_title( $prefix = '', $display = true ) {
$title = $prefix . get_the_time( _x( 'g:i a', 'minute and hour archives time format', 'chromatic' ) );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the search results title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_search_title( $prefix = '', $display = true ) {
$search_query = get_search_query();
/* Translators: %s is the search query. The HTML entities are opening and closing curly quotes. */
$title = $prefix . sprintf( __( 'Search results for “%s”', 'chromatic' ), $search_query );
$title = apply_filters( 'hoot_search_title', $title, $search_query );
if ( false === $display )
return $title;
echo $title;
}
/**
* Retrieve the 404 page title.
*
* @since 1.0.0
* @access public
* @param string $prefix
* @param bool $display
* @return string
*/
function hoot_404_title( $prefix = '', $display = true ) {
$title = $prefix . __( '404 Not Found', 'chromatic' );
$title = apply_filters( 'hoot_404_title', $title );
if ( false === $display )
return $title;
echo $title;
}
/**
* Display Site Performance Data
*
* @since 1.0.0
* @access public
* @return void
*/
function hoot_developer_data( $commented = true ) {
ob_start();
echo get_num_queries() . ' ' . __( 'queries.', 'chromatic' ) . ' ';
timer_stop(1);
echo ' ' . __( 'seconds.', 'chromatic' ) . ' ' . ( memory_get_peak_usage(1) / 1024 ) / 1024 . 'MB';
$out = ob_get_contents();
ob_end_clean();
return $out;
}