comments_popup_link

Выводит ссылку на всплывающее окно комментирования, работает при использовании скрипта comments_popup_script(), если этот скрипт не вызывается, то будет выведена простая ссылка на комментирование.

Как будет выглядеть всплывающее окно определяется файлом шаблона: comments-popup.php.

Этот Тег шаблона должен быть внутри Цикла WordPress или цикла комментариев.

Функция ничего не выводит, если отображаются отдельные страницы записей: is_single() или is_page().

Хуки из функции:
comments_popup_link_attributes
respond_link
Возвращает

html код ссылки.

Использование

comments_popup_link( $zero, $one, $more, $css_class, $none);
$zero(строка)
Текст для показа, когда нет комментариев.
По умолчанию: ‘Нет комментариев’
$one(строка)
Текст для показа, если 1 комментарий.
По умолчанию: ‘1 комментарий’
$more(строка)
Текст для показа, если более одного комментария.
По умолчанию: ‘%1$s комментариев’
$css_class(строка)
Название css класса для ссылки. По умолчанию класс не задается.
По умолчанию: ”
$none(строка)
Текст для показа, если у записи комментирование отключено.
По умолчанию: ‘Комментирование отключено’

Примеры

#1. Вывод ссылки на всплывающее окно комментирования на страницах архивов.

Нужно чтобы можно было комментировать статью не переходя к самой статье:

<?php
function comments_popup_link( $zero = false, $one = false, $more = false, $css_class = '', $none = false ) {
	$id = get_the_ID();
	$title = get_the_title();
	$number = get_comments_number( $id );

	if ( false === $zero ) {
		/* translators: %s: post title */
		$zero = sprintf( __( 'No Comments<span class="screen-reader-text"> on %s</span>' ), $title );
	}

	if ( false === $one ) {
		/* translators: %s: post title */
		$one = sprintf( __( '1 Comment<span class="screen-reader-text"> on %s</span>' ), $title );
	}

	if ( false === $more ) {
		/* translators: 1: Number of comments 2: post title */
		$more = _n( '%1$s Comment<span class="screen-reader-text"> on %2$s</span>', '%1$s Comments<span class="screen-reader-text"> on %2$s</span>', $number );
		$more = sprintf( $more, number_format_i18n( $number ), $title );
	}

	if ( false === $none ) {
		/* translators: %s: post title */
		$none = sprintf( __( 'Comments Off<span class="screen-reader-text"> on %s</span>' ), $title );
	}

	if ( 0 == $number && !comments_open() && !pings_open() ) {
		echo '<span' . ((!empty($css_class)) ? ' class="' . esc_attr( $css_class ) . '"' : '') . '>' . $none . '</span>';
		return;
	}

	if ( post_password_required() ) {
		_e( 'Enter your password to view comments.' );
		return;
	}

	echo '<a href="';
	if ( 0 == $number ) {
		$respond_link = get_permalink() . '#respond';
		/**
		 * Filters the respond link when a post has no comments.
		 *
		 * @since 4.4.0
		 *
		 * @param string $respond_link The default response link.
		 * @param integer $id The post ID.
		 */
		echo apply_filters( 'respond_link', $respond_link, $id );
	} else {
		comments_link();
	}
	echo '"';

	if ( !empty( $css_class ) ) {
		echo ' class="'.$css_class.'" ';
	}

	$attributes = '';
	/**
	 * Filters the comments link attributes for display.
	 *
	 * @since 2.5.0
	 *
	 * @param string $attributes The comments link attributes. Default empty.
	 */
	echo apply_filters( 'comments_popup_link_attributes', $attributes );

	echo '>';
	comments_number( $zero, $one, $more );
	echo '</a>';
}