2
0
Fork 0
mirror of https://github.com/discourse/wp-discourse.git synced 2025-10-03 08:59:21 +08:00
wp-discourse/templates/html-templates.php
2018-04-18 13:45:46 -07:00

234 lines
6.5 KiB
PHP

<?php
/**
* Returns HTML templates used for publishing to Discourse and for displaying comments on the WordPress site.
*
* Templates and implementation copied from @aliso's commit:
* https://github.com/10up/wp-discourse/commit/5c9d43c4333e136204d5a3b07192f4b368c3f518.
*
* @link https://github.com/discourse/wp-discourse/blob/master/lib/html-templates.php
* @package WPDiscourse
*/
namespace WPDiscourse\Templates;
/**
* Class HTMLTemplates
*/
class HTMLTemplates {
/**
* Gets the 'discourse_configurable_text' options.
*
* @param string $option The option key.
*
* @return string
*/
protected static function get_text_options( $option ) {
$text_options = get_option( 'discourse_configurable_text' );
$text = ! empty( $text_options[ $option ] ) ? $text_options[ $option ] : '';
return $text;
}
/**
* Sets the target attribute.
*
* @return string
*/
protected static function target() {
$comment_options = get_option( 'discourse_comment' );
if ( ! empty( $comment_options['discourse-new-tab'] ) ) {
return 'target="_blank"';
}
return '';
}
/**
* HTML template for replies.
*
* Can be customized from within a theme using the filter provided.
*
* Available tags:
* {comments}, {discourse_url}, {discourse_url_name},
* {topic_url}, {more_replies}, {participants}
*
* @static
*
* @return mixed|void
*/
public static function replies_html() {
ob_start();
?>
<div id="comments" class="comments-area discourse-comments-area">
<h2 class="comments-title discourse-comments-title"><?php esc_html( self::get_text_options( 'notable-replies-text' ) ); ?></h2>
<ol class="comment-list">{comments}</ol>
<div class="respond comment-respond">
<h3 id="reply-title" class="comment-reply-title">
<?php esc_html( self::get_text_options( 'continue-discussion-text' ) . ' ' ); ?>
<a <?php self::target(); ?> href="{topic_url}">
{discourse_url_name}
</a>
</h3>
<p class="more-replies">{more_replies}</p>
<div class="comment-reply-title">
<h4 class="discourse-participants"><?php esc_html( self::get_text_options( 'participants-text' ) ); ?></h4>
<p>{participants}</p>
</div>
</div><!-- #respond -->
</div>
<?php
$output = ob_get_clean();
return apply_filters( 'discourse_replies_html', $output );
}
/**
* HTML template for no replies.
*
* Can be customized from within a theme using the filter provided.
*
* Available tags:
* {comments}, {discourse_url}, {discourse_url_name}, {topic_url}
*
* @param null/string $discourse_comments_number The number of comments that are displayed on Discourse.
* @static
* @return mixed|void
*/
public static function no_replies_html( $discourse_comments_number = null ) {
ob_start();
?>
<div id="comments" class="comments-area">
<div class="respond comment-respond">
<h3 id="reply-title" class="comment-reply-title">
<?php
$text = $discourse_comments_number > 0 ? self::get_text_options( 'join-discussion-text' ) : self::get_text_options( 'start-discussion-text' );
?>
<?php esc_html( $text ) . ' '; ?>
<a <?php self::target(); ?> href="{topic_url}">
{discourse_url_name}
</a></h3>
</div><!-- #respond -->
</div>
<?php
$output = ob_get_clean();
return apply_filters( 'discourse_no_replies_html', $output );
}
/**
* The template that is displayed in the comments section after a post is created
* with bad credentials.
* This template is displayed in the comments section when there is no `discourse_permalink`
* index in the response returned from `Discourse::sync_to_discourse_work`
*
* Can be customized in the theme using the filter provided.
*
* @return mixed|void
*/
public static function bad_response_html() {
ob_start();
?>
<div class="respond comment-respond">
<div class="comment-reply-title discourse-no-connection-notice">
<p><?php esc_html( self::get_text_options( 'comments-not-available-text' ) ); ?></p>
</div>
</div>
<?php
$output = ob_get_clean();
return apply_filters( 'discourse_no_connection_html', $output );
}
/**
* HTML template for each comment
*
* Can be customized from within a theme using the filter provided.
*
* Available tags:
* {discourse_url}, {discourse_url_name}, {topic_url},
* {avatar_url}, {user_url}, {username}, {fullname},
* {comment_body}, {comment_created_at}, {comment_url}
*
* @static
* @return mixed|void
*/
public static function comment_html() {
ob_start();
?>
<li class="comment even thread-even depth-1">
<article class="comment-body">
<footer class="comment-meta">
<div class="comment-author vcard">
<img alt="" src="{avatar_url}" class="avatar avatar-64 photo avatar-default"
height="64"
width="64">
<b class="fn"><a href="{topic_url}" rel="external"
class="url">{username}</a></b>
<span class="says screen-reader-text"><?php esc_html( 'says:', 'wp-discourse' ); ?></span><!-- screen reader text -->
</div>
<!-- .comment-author -->
<div class="comment-metadata">
<time pubdate="" datetime="{comment_created_at}">{comment_created_at}</time>
</div>
<!-- .comment-metadata -->
</footer>
<!-- .comment-meta -->
<div class="comment-content">{comment_body}</div>
<!-- .comment-content -->
</article>
<!-- .comment-body -->
</li>
<?php
$output = ob_get_clean();
return apply_filters( 'discourse_comment_html', $output );
}
/**
* HTML template for each participant
*
* Can be customized from within a theme using the filter provided.
*
* Available tags:
* {discourse_url}, {discourse_url_name}, {topic_url},
* {avatar_url}, {user_url}, {username}
*
* @static
* @return mixed|void
*/
public static function participant_html() {
ob_start();
?>
<img alt="" src="{avatar_url}" class="avatar avatar-25 photo avatar-default" height="25"
width="25">
<?php
$output = ob_get_clean();
return apply_filters( 'discourse_participant_html', $output );
}
/**
* HTML template for published byline
*
* Can be customized from within a theme using the filter provided.
*
* Available tags:
* {excerpt}, {blogurl}, {author}, {thumbnail}, {featuredimage}
*
* @static
* @return mixed|void
*/
public static function publish_format_html() {
ob_start();
?>
<small><?php esc_html( self::get_text_options( 'published-at-text' ) ); ?>
{blogurl}
</small><br>{excerpt}
<?php
$output = ob_get_clean();
return apply_filters( 'discourse_publish_format_html', $output );
}
}