template-tags.php
テンプレートファイルで使うタグを定義しています。全ての関数がif ( ! function_exists())
でラップされており、 子テーマのfunctions.phpで定義することで上書きが可能になっています。(基本的には、 子テーマのfunctions.php ファイルは親テーマよりも先に読み込まれるため、子テーマで同名の関数が使用されているとエラーが起きてしまいます。)
<?php /** * Custom template tags for this theme * * Eventually, some of the functionality here could be replaced by core features. * * @package _s */ if ( ! function_exists( '_s_posted_on' ) ) : /** * Prints HTML with meta information for the current post-date/time. */ function _s_posted_on() { $time_string = '<time class="entry-date published updated" datetime="%1$s">%2$s</time>'; if ( get_the_time( 'U' ) !== get_the_modified_time( 'U' ) ) { $time_string = '<time class="entry-date published" datetime="%1$s">%2$s</time><time class="updated" datetime="%3$s">%4$s</time>'; } $time_string = sprintf( $time_string, esc_attr( get_the_date( DATE_W3C ) ), esc_html( get_the_date() ), esc_attr( get_the_modified_date( DATE_W3C ) ), esc_html( get_the_modified_date() ) ); $posted_on = sprintf( /* translators: %s: post date. */ esc_html_x( 'Posted on %s', 'post date', '_s' ), '<a href="' . esc_url( get_permalink() ) . '" rel="bookmark">' . $time_string . '</a>' ); echo '<span class="posted-on">' . $posted_on . '</span>'; // WPCS: XSS OK. } endif; if ( ! function_exists( '_s_posted_by' ) ) : /** * Prints HTML with meta information for the current author. */ function _s_posted_by() { $byline = sprintf( /* translators: %s: post author. */ esc_html_x( 'by %s', 'post author', '_s' ), '<span class="author vcard"><a class="url fn n" href="' . esc_url( get_author_posts_url( get_the_author_meta( 'ID' ) ) ) . '">' . esc_html( get_the_author() ) . '</a></span>' ); echo '<span class="byline"> ' . $byline . '</span>'; // WPCS: XSS OK. } endif; if ( ! function_exists( '_s_entry_footer' ) ) : /** * Prints HTML with meta information for the categories, tags and comments. */ function _s_entry_footer() { // Hide category and tag text for pages. if ( 'post' === get_post_type() ) { /* translators: used between list items, there is a space after the comma */ $categories_list = get_the_category_list( esc_html__( ', ', '_s' ) ); if ( $categories_list ) { /* translators: 1: list of categories. */ printf( '<span class="cat-links">' . esc_html__( 'Posted in %1$s', '_s' ) . '</span>', $categories_list ); // WPCS: XSS OK. } /* translators: used between list items, there is a space after the comma */ $tags_list = get_the_tag_list( '', esc_html_x( ', ', 'list item separator', '_s' ) ); if ( $tags_list ) { /* translators: 1: list of tags. */ printf( '<span class="tags-links">' . esc_html__( 'Tagged %1$s', '_s' ) . '</span>', $tags_list ); // WPCS: XSS OK. } } if ( ! is_single() && ! post_password_required() && ( comments_open() || get_comments_number() ) ) { echo '<span class="comments-link">'; comments_popup_link( sprintf( wp_kses( /* translators: %s: post title */ __( 'Leave a Comment<span class="screen-reader-text"> on %s</span>', '_s' ), array( 'span' => array( 'class' => array(), ), ) ), get_the_title() ) ); echo '</span>'; } edit_post_link( sprintf( wp_kses( /* translators: %s: Name of current post. Only visible to screen readers */ __( 'Edit <span class="screen-reader-text">%s</span>', '_s' ), array( 'span' => array( 'class' => array(), ), ) ), get_the_title() ), '<span class="edit-link">', '</span>' ); } endif; if ( ! function_exists( '_s_post_thumbnail' ) ) : /** * Displays an optional post thumbnail. * * Wraps the post thumbnail in an anchor element on index views, or a div * element when on single views. */ function _s_post_thumbnail() { if ( post_password_required() || is_attachment() || ! has_post_thumbnail() ) { return; } if ( is_singular() ) : ?> <div class="post-thumbnail"> <?php the_post_thumbnail(); ?> </div><!-- .post-thumbnail --> <?php else : ?> <a class="post-thumbnail" href="<?php the_permalink(); ?>" aria-hidden="true" tabindex="-1"> <?php the_post_thumbnail( 'post-thumbnail', array( 'alt' => the_title_attribute( array( 'echo' => false, ) ), ) ); ?> </a> <?php endif; // End is_singular(). } endif;
_s_posted_on()
content.phpとcontent-search.phpで、投稿日を表示するために使われています。
get_the_time( ‘U’ ) の’U’はユニックスタイムスタンプの時間を表しています。
get_the_date( DATE_W3C ) の DATE_W3Cは、 World Wide Web Consortium での日付表記を表しています。
_s_posted_by()
content.phpとcontent-search.phpで、投稿者を表示するために使われています。
_s_entry_footer()
content.phpとcontent-search.phpで、記事の最後に表示されるメタ情報、カテゴリー、タグ、コメント、編集へのリンクを表示するために使われています。
_s_post_thumbnail()
content.php、content-page.phpとcontent-search.phpで、サムネイルを表示するために使われています。