astra_breadcrumb_get_items( array $args )
Gets the items for the RDFa Breadcrumb.
Description
Parameters
- $args
-
(array) (Required) Mixed arguments for the menu.
Source
File: addons/advanced-headers/classes/astra-breadcrumbs.php
function astra_breadcrumb_get_items( $args ) {
global $wp_query;
$item = array();
$show_on_front = get_option( 'show_on_front' );
/* Link to front page. */
if ( ! is_front_page() ) {
$item[] = '<span class="ast-breadcrumbs-link-wrap" itemprop="itemListElement" itemscope itemtype="https://schema.org/ListItem"><a itemprop="item" rel="v:url" property="v:title" href="' . esc_url( home_url( '/' ) ) . '"><span itemprop="name">' . $args['home'] . '</span><meta itemprop="position" content="${content}"/></a></span>';
}
/* If woocommerce is installed and we're on a woocommerce page. */
if ( function_exists( 'is_woocommerce' ) && is_woocommerce() ) {
woocommerce_breadcrumb();
return false;
}
/* Front page. */
if ( is_home() && ! ( is_front_page() && is_home() ) ) {
// Blog page.
$id = astra_get_post_id();
$home_page = get_page( $wp_query->get_queried_object_id() );
$item = array_merge( $item, astra_breadcrumb_get_parents( $home_page->post_parent ) );
$item['last'] = '<span itemprop="name">' . get_the_title( $id ) . '</span>';
} elseif ( function_exists( 'is_bbpress' ) && is_bbpress() ) {
$item = array_merge( $item, astra_breadcrumb_get_bbpress_items() );
// If viewing a singular post.
} elseif ( is_singular() ) {
$post = $wp_query->get_queried_object();
$post_id = (int) $wp_query->get_queried_object_id();
$post_type = $post->post_type;
$post_type_object = get_post_type_object( $post_type );
if ( 'post' === $post_type && $args['show_blog'] ) {
$item[] = '<span class="ast-breadcrumbs-link-wrap" itemprop="itemListElement" itemscope itemtype="https://schema.org/ListItem"><a itemprop="item" rel="v:url" property="v:title" href="' . get_permalink( get_option( 'page_for_posts' ) ) . '"><span itemprop="name">' . get_the_title( get_option( 'page_for_posts' ) ) . '</span></a></span>';
}
if ( 'page' !== $post_type ) {
/* If there's an archive page, add it. */
if ( function_exists( 'get_post_type_archive_link' ) && ! empty( $post_type_object->has_archive ) ) {
$item[] = '<span class="ast-breadcrumbs-link-wrap" itemprop="itemListElement" itemscope itemtype="https://schema.org/ListItem"><a itemprop="item" rel="v:url" property="v:title" href="' . get_post_type_archive_link( $post_type ) . '" title="' . esc_attr( $post_type_object->labels->name ) . '"><span itemprop="name">' . $post_type_object->labels->name . '</span></a></span>';
}
if ( isset( $args[ "singular_{$post_type}_taxonomy" ] ) && is_taxonomy_hierarchical( $args[ "singular_{$post_type}_taxonomy" ] ) ) {
$terms = wp_get_object_terms( $post_id, $args[ "singular_{$post_type}_taxonomy" ] );
if ( isset( $terms[0] ) ) {
$item = array_merge( $item, astra_breadcrumb_get_term_parents( $terms[0], $args[ "singular_{$post_type}_taxonomy" ] ) );
}
} elseif ( isset( $args[ "singular_{$post_type}_taxonomy" ] ) ) {
$item[] = get_the_term_list( $post_id, $args[ "singular_{$post_type}_taxonomy" ], '', ', ', '' );
}
}
$post_parent = ( isset( $wp_query->post->post_parent ) ) ? $wp_query->post->post_parent : '';
$parents = astra_breadcrumb_get_parents( $post_parent );
if ( ( is_post_type_hierarchical( $wp_query->post->post_type ) || 'attachment' === $wp_query->post->post_type ) && $parents ) {
$item = array_merge( $item, $parents );
}
$item['last'] = '<span itemprop="name">' . get_the_title() . '</span>';
// If viewing any type of archive.
} elseif ( is_archive() ) {
if ( is_category() || is_tag() || is_tax() ) {
$term = $wp_query->get_queried_object();
$taxonomy = get_taxonomy( $term->taxonomy );
$parents = astra_breadcrumb_get_term_parents( $term->parent, $term->taxonomy );
if ( ( is_taxonomy_hierarchical( $term->taxonomy ) && $term->parent ) && $parents ) {
$item = array_merge( $item, $parents );
}
$item['last'] = '<span itemprop="name">' . $term->name . '</span>';
} elseif ( function_exists( 'is_post_type_archive' ) && is_post_type_archive() ) {
$post_type_object = get_post_type_object( get_query_var( 'post_type' ) );
$item['last'] = '<span itemprop="name">' . $post_type_object->labels->name . '</span>';
} elseif ( is_date() ) {
if ( is_day() ) {
$item['last'] = '<span itemprop="name">' . $args['archive-prefix'] . get_the_time( 'F j, Y' ) . '</span>';
} elseif ( is_month() ) {
$item['last'] = '<span itemprop="name">' . $args['archive-prefix'] . single_month_title( ' ', false ) . '</span>';
} elseif ( is_year() ) {
$item['last'] = '<span itemprop="name">' . $args['archive-prefix'] . get_the_time( 'Y' ) . '</span>';
}
} elseif ( is_author() ) {
$item['last'] = '<span itemprop="name">' . $args['author-prefix'] . get_the_author_meta( 'display_name', ( isset( $wp_query->post->post_author ) ) ? $wp_query->post->post_author : '' ) . '</span>';
}
// If viewing search results.
} elseif ( is_search() ) {
$item['last'] = '<span itemprop="name">' . $args['search-prefix'] . stripslashes( wp_strip_all_tags( get_search_query() ) ) . '</span>';
// If viewing a 404 error page.
} elseif ( is_404() ) {
$item['last'] = '<span itemprop="name">' . $args['404-title'] . '</span>';
}
$keys = array_keys( $item );
$index_max = count( $item );
for ( $index = 0; $index < $index_max; $index++ ) {
$item[ $keys[ $index ] ] = str_replace( '${content}', $index + 1, $item[ $keys[ $index ] ] );
}
return apply_filters( 'astra_breadcrumb_items', $item );
}
Expand full source code Collapse full source code View on Trac
Changelog
| Version | Description |
|---|---|
| 1.0.0 | Introduced. |