2006-04-19 12:13:28 +02:00
< ? php
2007-12-26 18:18:13 +01:00
/**
* Comment template functions
*
* These functions are meant to live inside of the WordPress loop .
*
* @ package WordPress
* @ subpackage Template
2006-04-19 12:13:28 +02:00
*/
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the author of the current comment .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* If the comment has an empty comment_author field , then 'Anonymous' person is
* assumed .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls 'get_comment_author' hook on the comment author
*
* @ return string The comment author
*/
2006-04-19 12:13:28 +02:00
function get_comment_author () {
global $comment ;
if ( empty ( $comment -> comment_author ) )
$author = __ ( 'Anonymous' );
else
$author = $comment -> comment_author ;
return apply_filters ( 'get_comment_author' , $author );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses apply_filters () Calls 'comment_author' on comment author before displaying
*/
2006-04-19 12:13:28 +02:00
function comment_author () {
$author = apply_filters ( 'comment_author' , get_comment_author () );
echo $author ;
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the email of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls the 'get_comment_author_email' hook on the comment author email
* @ uses $comment
*
* @ return string The current comment author ' s email
*/
2006-04-19 12:13:28 +02:00
function get_comment_author_email () {
global $comment ;
return apply_filters ( 'get_comment_author_email' , $comment -> comment_author_email );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the email of the author of the current global $comment .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* Care should be taken to protect the email address and assure that email
* harvesters do not capture your commentors ' email address . Most assume that
* their email address will not appear in raw form on the blog . Doing so will
* enable anyone , including those that people don ' t want to get the email
* address and use it for their own means good and bad .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses apply_filters () Calls 'author_email' hook on the author email
*/
2006-04-19 12:13:28 +02:00
function comment_author_email () {
echo apply_filters ( 'author_email' , get_comment_author_email () );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the html email link to the author of the current comment .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* Care should be taken to protect the email address and assure that email
* harvesters do not capture your commentors ' email address . Most assume that
* their email address will not appear in raw form on the blog . Doing so will
* enable anyone , including those that people don ' t want to get the email
* address and use it for their own means good and bad .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses apply_filters () Calls 'comment_email' hook for the display of the comment author ' s email
* @ global object $comment The current Comment row object
*
* @ param string $linktext The text to display instead of the comment author ' s email address
* @ param string $before The text or HTML to display before the email link .
* @ param string $after The text or HTML to display after the email link .
*/
2006-04-19 12:13:28 +02:00
function comment_author_email_link ( $linktext = '' , $before = '' , $after = '' ) {
global $comment ;
$email = apply_filters ( 'comment_email' , $comment -> comment_author_email );
if (( ! empty ( $email )) && ( $email != '@' )) {
$display = ( $linktext != '' ) ? $linktext : $email ;
echo $before ;
echo " <a href='mailto: $email '> $display </a> " ;
echo $after ;
}
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the html link to the url of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls 'get_comment_author_link' hook on the complete link HTML or author
*
* @ return string Comment Author name or HTML link for author ' s URL
*/
2006-04-19 12:13:28 +02:00
function get_comment_author_link () {
2007-12-26 18:18:13 +01:00
/** @todo Only call these functions when they are needed. Include in if... else blocks */
2006-04-19 12:13:28 +02:00
$url = get_comment_author_url ();
$author = get_comment_author ();
if ( empty ( $url ) || 'http://' == $url )
$return = $author ;
else
$return = " <a href=' $url ' rel='external nofollow'> $author </a> " ;
return apply_filters ( 'get_comment_author_link' , $return );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the html link to the url of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ see get_comment_author_link () Echos result
*/
2006-04-19 12:13:28 +02:00
function comment_author_link () {
echo get_comment_author_link ();
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the IP address of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $comment
2008-02-05 07:47:27 +01:00
* @ uses apply_filters ()
2007-12-26 18:18:13 +01:00
*
* @ return unknown
*/
2006-04-19 12:13:28 +02:00
function get_comment_author_IP () {
global $comment ;
return apply_filters ( 'get_comment_author_IP' , $comment -> comment_author_IP );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the IP address of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ see get_comment_author_IP () Echos Result
*/
2006-04-19 12:13:28 +02:00
function comment_author_IP () {
echo get_comment_author_IP ();
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the url of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls 'get_comment_author_url' hook on the comment author ' s URL
*
* @ return string
*/
2006-04-19 12:13:28 +02:00
function get_comment_author_url () {
global $comment ;
return apply_filters ( 'get_comment_author_url' , $comment -> comment_author_url );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the url of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
2008-02-05 07:47:27 +01:00
* @ uses apply_filters ()
2007-12-26 18:18:13 +01:00
* @ uses get_comment_author_url () Retrieves the comment author ' s URL
*/
2006-04-19 12:13:28 +02:00
function comment_author_url () {
echo apply_filters ( 'comment_url' , get_comment_author_url ());
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieves the HTML link of the url of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* $linktext parameter is only used if the URL does not exist for the comment
* author . If the URL does exist then the URL will be used and the $linktext
* will be ignored .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* Encapsulate the HTML link between the $before and $after . So it will appear
* in the order of $before , link , and finally $after .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls the 'get_comment_author_url_link' on the complete HTML before returning .
*
* @ param string $linktext The text to display instead of the comment author ' s email address
* @ param string $before The text or HTML to display before the email link .
* @ param string $after The text or HTML to display after the email link .
* @ return string The HTML link between the $before and $after parameters
*/
2006-04-19 12:13:28 +02:00
function get_comment_author_url_link ( $linktext = '' , $before = '' , $after = '' ) {
$url = get_comment_author_url ();
$display = ( $linktext != '' ) ? $linktext : $url ;
$display = str_replace ( 'http://www.' , '' , $display );
$display = str_replace ( 'http://' , '' , $display );
if ( '/' == substr ( $display , - 1 ) )
$display = substr ( $display , 0 , - 1 );
$return = " $before <a href=' $url ' rel='external'> $display </a> $after " ;
return apply_filters ( 'get_comment_author_url_link' , $return );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the HTML link of the url of the author of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ see get_comment_author_url_link () Echos result
*
* @ param string $linktext The text to display instead of the comment author ' s email address
* @ param string $before The text or HTML to display before the email link .
* @ param string $after The text or HTML to display after the email link .
*/
2006-04-19 12:13:28 +02:00
function comment_author_url_link ( $linktext = '' , $before = '' , $after = '' ) {
echo get_comment_author_url_link ( $linktext , $before , $after );
}
2008-08-21 01:48:09 +02:00
/**
* Generates semantic classes for each comment element
*
* @ since 2.7
*
* @ param string | array $class One or more classes to add to the class list
* @ param int $comment_id An optional comment ID
* @ param int $post_id An optional post ID
*/
2008-09-11 21:25:50 +02:00
function comment_class ( $class = '' , $comment_id = null , $post_id = null , $echo = true ) {
// Separates classes with a single space, collates classes for comment DIV
$class = 'class="' . join ( ' ' , get_comment_class ( $class , $comment_id , $post_id ) ) . '"' ;
if ( $echo )
echo $class ;
else
return $class ;
2008-08-21 01:48:09 +02:00
}
/**
* Returns the classes for the comment div as an array
*
* @ since 2.7
*
* @ param string | array $class One or more classes to add to the class list
* @ param int $comment_id An optional comment ID
* @ param int $post_id An optional post ID
* @ return array Array of classes
*/
function get_comment_class ( $class = '' , $comment_id = null , $post_id = null ) {
static $comment_alt ;
$comment = get_comment ( $comment_id );
$classes = array ();
// Get the comment type (comment, trackback),
$classes [] = $comment -> comment_type ;
// If the comment author has an id (registered), then print the log in name
if ( $comment -> user_id > 0 && $user = get_userdata ( $comment -> user_id ) ) {
// For all registered users, 'byuser'
$classes [] = 'byuser comment-author-' . $user -> user_nicename ;
// For comment authors who are the author of the post
if ( $post = get_post ( $post_id ) ) {
if ( $comment -> user_id === $post -> post_author )
$classes [] = 'bypostauthor' ;
}
}
if ( empty ( $comment_alt ) )
$comment_alt = 0 ;
2008-09-11 21:25:50 +02:00
if ( $comment_alt % 2 ) {
2008-08-21 01:48:09 +02:00
$classes [] = 'odd' ;
2008-09-11 21:25:50 +02:00
$classes [] = 'alt' ;
} else {
2008-08-21 01:48:09 +02:00
$classes [] = 'even' ;
2008-09-11 21:25:50 +02:00
}
2008-08-21 01:48:09 +02:00
$comment_alt ++ ;
if ( ! empty ( $class ) ) {
if ( ! is_array ( $class ) )
$class = preg_split ( '#\s+#' , $class );
$classes = array_merge ( $classes , $class );
}
return apply_filters ( 'comment_class' , $classes , $class , $comment_id , $post_id );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the comment date of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls 'get_comment_date' hook with the formated date and the $d parameter respectively
* @ uses $comment
*
* @ param string $d The format of the date ( defaults to user ' s config )
* @ return string The comment ' s date
*/
2006-04-19 12:13:28 +02:00
function get_comment_date ( $d = '' ) {
global $comment ;
if ( '' == $d )
2006-08-30 23:46:31 +02:00
$date = mysql2date ( get_option ( 'date_format' ), $comment -> comment_date );
2006-04-19 12:13:28 +02:00
else
$date = mysql2date ( $d , $comment -> comment_date );
2006-11-20 02:46:20 +01:00
return apply_filters ( 'get_comment_date' , $date , $d );
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the comment date of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
*
* @ param string $d The format of the date ( defaults to user ' s config )
*/
2006-04-19 12:13:28 +02:00
function comment_date ( $d = '' ) {
echo get_comment_date ( $d );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the excerpt of the current comment .
2007-12-26 18:18:13 +01:00
*
* Will cut each word and only output the first 20 words with '...' at the end .
* If the word count is less than 20 , then no truncating is done and no '...'
* will appear .
*
* @ since 1.5
* @ uses $comment
* @ uses apply_filters () Calls 'get_comment_excerpt' on truncated comment
*
* @ return string The maybe truncated comment with 20 words or less
*/
2006-04-19 12:13:28 +02:00
function get_comment_excerpt () {
global $comment ;
$comment_text = strip_tags ( $comment -> comment_content );
$blah = explode ( ' ' , $comment_text );
if ( count ( $blah ) > 20 ) {
$k = 20 ;
$use_dotdotdot = 1 ;
} else {
$k = count ( $blah );
$use_dotdotdot = 0 ;
}
$excerpt = '' ;
for ( $i = 0 ; $i < $k ; $i ++ ) {
$excerpt .= $blah [ $i ] . ' ' ;
}
$excerpt .= ( $use_dotdotdot ) ? '...' : '' ;
return apply_filters ( 'get_comment_excerpt' , $excerpt );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the excerpt of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.2
* @ uses apply_filters () Calls 'comment_excerpt' hook before displaying excerpt
*/
2006-04-19 12:13:28 +02:00
function comment_excerpt () {
echo apply_filters ( 'comment_excerpt' , get_comment_excerpt () );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the comment id of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $comment
* @ uses apply_filters () Calls the 'get_comment_ID' hook for the comment ID
*
* @ return int The comment ID
*/
2006-04-19 12:13:28 +02:00
function get_comment_ID () {
global $comment ;
return apply_filters ( 'get_comment_ID' , $comment -> comment_ID );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the comment id of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ see get_comment_ID () Echos Result
*/
2006-04-19 12:13:28 +02:00
function comment_ID () {
echo get_comment_ID ();
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the link to the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $comment
*
2008-08-05 00:29:37 +02:00
* @ param object | string | int $comment Comment to retrieve .
2007-12-26 18:18:13 +01:00
* @ return string The permalink to the current comment
*/
2008-08-05 00:29:37 +02:00
function get_comment_link ( $comment = null ) {
$comment = get_comment ( $comment );
2006-04-19 12:13:28 +02:00
return get_permalink ( $comment -> comment_post_ID ) . '#comment-' . $comment -> comment_ID ;
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieves the link to the current post comments .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
*
* @ return string The link to the comments
*/
2006-04-19 12:13:28 +02:00
function get_comments_link () {
return get_permalink () . '#comments' ;
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the link to the current post comments .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
*
2008-01-04 20:36:34 +01:00
* @ param string $deprecated Not Used
* @ param bool $deprecated Not Used
2007-12-26 18:18:13 +01:00
*/
2008-01-04 20:36:34 +01:00
function comments_link ( $deprecated = '' , $deprecated = '' ) {
2007-12-26 18:18:13 +01:00
echo get_comments_link ();
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the amount of comments a post has .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls the 'get_comments_number' hook on the number of comments
*
* @ param int $post_id The Post ID
* @ return int The number of comments a post has
*/
2006-04-19 12:13:28 +02:00
function get_comments_number ( $post_id = 0 ) {
2008-01-04 20:36:34 +01:00
global $id ;
2006-04-19 12:13:28 +02:00
$post_id = ( int ) $post_id ;
if ( ! $post_id )
2007-03-23 01:59:21 +01:00
$post_id = ( int ) $id ;
2006-04-19 12:13:28 +02:00
$post = get_post ( $post_id );
if ( ! isset ( $post -> comment_count ) )
$count = 0 ;
else
$count = $post -> comment_count ;
return apply_filters ( 'get_comments_number' , $count );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the language string for the number of comments the current post has .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses $id
* @ uses apply_filters () Calls the 'comments_number' hook on the output and number of comments respectively .
*
* @ param string $zero Text for no comments
* @ param string $one Text for one comment
* @ param string $more Text for more than one comment
* @ param string $deprecated Not used .
*/
2007-03-26 01:18:19 +02:00
function comments_number ( $zero = false , $one = false , $more = false , $deprecated = '' ) {
2006-11-19 08:45:28 +01:00
global $id ;
$number = get_comments_number ( $id );
if ( $number > 1 )
2008-05-08 19:54:40 +02:00
$output = str_replace ( '%' , number_format_i18n ( $number ), ( false === $more ) ? __ ( '% Comments' ) : $more );
2006-11-19 08:45:28 +01:00
elseif ( $number == 0 )
$output = ( false === $zero ) ? __ ( 'No Comments' ) : $zero ;
else // must be one
$output = ( false === $one ) ? __ ( '1 Comment' ) : $one ;
echo apply_filters ( 'comments_number' , $output , $number );
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the text of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $comment
*
* @ return string The comment content
*/
2006-04-19 12:13:28 +02:00
function get_comment_text () {
global $comment ;
return apply_filters ( 'get_comment_text' , $comment -> comment_content );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the text of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses apply_filters () Passes the comment content through the 'comment_text' hook before display
* @ uses get_comment_text () Gets the comment content
*/
2006-04-19 12:13:28 +02:00
function comment_text () {
echo apply_filters ( 'comment_text' , get_comment_text () );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the comment time of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $comment
* @ uses apply_filter () Calls 'get_comment_time' hook with the formatted time , the $d parameter , and $gmt parameter passed .
*
* @ param string $d Optional . The format of the time ( defaults to user ' s config )
* @ param bool $gmt Whether to use the GMT date
* @ return string The formatted time
*/
2006-04-19 12:13:28 +02:00
function get_comment_time ( $d = '' , $gmt = false ) {
global $comment ;
$comment_date = $gmt ? $comment -> comment_date_gmt : $comment -> comment_date ;
if ( '' == $d )
2006-08-30 23:46:31 +02:00
$date = mysql2date ( get_option ( 'time_format' ), $comment_date );
2006-04-19 12:13:28 +02:00
else
$date = mysql2date ( $d , $comment_date );
2006-11-20 02:46:20 +01:00
return apply_filters ( 'get_comment_time' , $date , $d , $gmt );
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the comment time of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
*
* @ param string $d Optional . The format of the time ( defaults to user ' s config )
*/
2006-04-19 12:13:28 +02:00
function comment_time ( $d = '' ) {
echo get_comment_time ( $d );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve the comment type of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $comment
* @ uses apply_filters () Calls the 'get_comment_type' hook on the comment type
*
* @ return string The comment type
*/
2006-04-19 12:13:28 +02:00
function get_comment_type () {
global $comment ;
if ( '' == $comment -> comment_type )
$comment -> comment_type = 'comment' ;
return apply_filters ( 'get_comment_type' , $comment -> comment_type );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Display the comment type of the current comment .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
*
* @ param string $commenttxt The string to display for comment type
* @ param string $trackbacktxt The string to display for trackback type
* @ param string $pingbacktxt The string to display for pingback type
*/
2006-04-19 12:13:28 +02:00
function comment_type ( $commenttxt = 'Comment' , $trackbacktxt = 'Trackback' , $pingbacktxt = 'Pingback' ) {
$type = get_comment_type ();
switch ( $type ) {
case 'trackback' :
echo $trackbacktxt ;
break ;
case 'pingback' :
echo $pingbacktxt ;
break ;
default :
echo $commenttxt ;
}
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Retrieve The current post ' s trackback URL .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* There is a check to see if permalink ' s have been enabled and if so , will
* retrieve the pretty path . If permalinks weren ' t enabled , the ID of the
* current post is used and appended to the correct page to go to .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses apply_filters () Calls 'trackback_url' on the resulting trackback URL
* @ uses $id
*
* @ return string The trackback URL after being filtered
*/
2006-04-19 12:13:28 +02:00
function get_trackback_url () {
global $id ;
2007-08-30 01:08:44 +02:00
if ( '' != get_option ( 'permalink_structure' ) ) {
2007-03-10 07:18:43 +01:00
$tb_url = trailingslashit ( get_permalink ()) . user_trailingslashit ( 'trackback' , 'single_trackback' );
2007-08-30 01:08:44 +02:00
} else {
$tb_url = get_option ( 'siteurl' ) . '/wp-trackback.php?p=' . $id ;
}
2007-03-27 01:40:49 +02:00
return apply_filters ( 'trackback_url' , $tb_url );
2006-04-19 12:13:28 +02:00
}
2007-08-30 01:08:44 +02:00
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the current post ' s trackback URL .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses get_trackback_url () Gets the trackback url for the current post
*
2008-02-10 08:59:34 +01:00
* @ param bool $deprecated Remove backwards compat in 2.5
2007-12-26 18:18:13 +01:00
* @ return void | string Should only be used to echo the trackback URL , use get_trackback_url () for the result instead .
*/
function trackback_url ( $deprecated = true ) {
2007-08-30 01:08:44 +02:00
if ( $deprecated ) echo get_trackback_url ();
else return get_trackback_url ();
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Generates and displays the RDF for the trackback information of current post .
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
*
2008-01-04 20:36:34 +01:00
* @ param int $deprecated Not used ( Was $timezone = 0 )
2007-12-26 18:18:13 +01:00
*/
2008-01-04 20:36:34 +01:00
function trackback_rdf ( $deprecated = '' ) {
2007-06-02 01:10:03 +02:00
if ( stripos ( $_SERVER [ 'HTTP_USER_AGENT' ], 'W3C_Validator' ) === false ) {
2007-03-07 06:29:15 +01:00
echo ' < rdf : RDF xmlns : rdf = " http://www.w3.org/1999/02/22-rdf-syntax-ns# "
xmlns : dc = " http://purl.org/dc/elements/1.1/ "
xmlns : trackback = " http://madskills.com/public/xml/rss/module/trackback/ " >
< rdf : Description rdf : about = " ';
the_permalink ();
echo '"' . " \n " ;
echo ' dc:identifier="' ;
the_permalink ();
echo '"' . " \n " ;
echo ' dc:title="' . str_replace ( '--' , '--' , wptexturize ( strip_tags ( get_the_title ()))) . '"' . " \n " ;
2007-08-30 01:08:44 +02:00
echo ' trackback:ping="' . get_trackback_url () . '"' . " /> \n " ;
2007-03-07 06:29:15 +01:00
echo '</rdf:RDF>' ;
2006-04-19 12:13:28 +02:00
}
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Whether the current post is open for comments .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
* @ uses $post
*
2008-02-04 21:27:45 +01:00
* @ param int $post_id An optional post ID to check instead of the current post .
2007-12-26 18:18:13 +01:00
* @ return bool True if the comments are open
*/
2008-02-04 21:27:45 +01:00
function comments_open ( $post_id = NULL ) {
$_post = get_post ( $post_id );
2008-02-05 07:47:27 +01:00
2008-02-04 21:27:45 +01:00
$open = ( 'open' == $_post -> comment_status );
return apply_filters ( 'comments_open' , $open , $post_id );
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Whether the current post is open for pings .
2007-12-26 18:18:13 +01:00
*
* @ since 1.5
2008-02-05 07:47:27 +01:00
* @ uses $post
2007-12-26 18:18:13 +01:00
*
2008-02-04 21:27:45 +01:00
* @ param int $post_id An optional post ID to check instead of the current post .
2007-12-26 18:18:13 +01:00
* @ return bool True if pings are accepted
*/
2008-02-13 07:39:45 +01:00
function pings_open ( $post_id = NULL ) {
2008-02-04 21:27:45 +01:00
$_post = get_post ( $post_id );
2008-02-13 07:39:45 +01:00
$open = ( 'open' == $_post -> ping_status );
2008-02-04 21:27:45 +01:00
return apply_filters ( 'pings_open' , $open , $post_id );
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays form token for unfiltered comments .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* Will only display nonce token if the current user has permissions for
* unfiltered html . Won ' t display the token for other users .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* The function was backported to 2.0 . 10 and was added to versions 2.1 . 3 and
* above . Does not exist in versions prior to 2.0 . 10 in the 2.0 branch and in
* the 2.1 branch , prior to 2.1 . 3. Technically added in 2.2 . 0.
2007-12-26 18:18:13 +01:00
*
* @ since 2.0 . 10 Backported to 2.0 branch
* @ since 2.1 . 3
* @ uses $post Gets the ID of the current post for the token
*/
2007-03-15 00:10:57 +01:00
function wp_comment_form_unfiltered_html_nonce () {
global $post ;
if ( current_user_can ( 'unfiltered_html' ) )
wp_nonce_field ( 'unfiltered-html-comment_' . $post -> ID , '_wp_unfiltered_html_comment' , false );
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Loads the comment template specified in $file .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* Will not display the comments template if not on single post or page , or if
* the post does not have comments .
2007-12-26 18:18:13 +01:00
*
* Uses the WordPress database object to query for the comments . The comments
* are passed through the 'comments_array' filter hook with the list of comments
* and the post ID respectively .
*
* The $file path is passed through a filter hook called , 'comments_template'
* which includes the TEMPLATEPATH and $file combined . Tries the $filtered path
* first and if it fails it will require the default comment themplate from the
* default theme . If either does not exist , then the WordPress process will be
* halted . It is advised for that reason , that the default theme is not deleted .
*
* @ since 1.5
* @ global array $comment List of comment objects for the current post
* @ uses $wpdb
* @ uses $id
* @ uses $post
* @ uses $withcomments Will not try to get the comments if the post has none .
*
* @ param string $file Optional , default '/comments.php' . The file to load
* @ return null Returns null if no comments appear
*/
2006-04-19 12:13:28 +02:00
function comments_template ( $file = '/comments.php' ) {
global $wp_query , $withcomments , $post , $wpdb , $id , $comment , $user_login , $user_ID , $user_identity ;
2006-06-22 22:52:12 +02:00
if ( ! ( is_single () || is_page () || $withcomments ) )
return ;
2006-08-30 23:46:31 +02:00
$req = get_option ( 'require_name_email' );
2006-06-22 22:52:12 +02:00
$commenter = wp_get_current_commenter ();
2007-06-15 00:45:40 +02:00
extract ( $commenter , EXTR_SKIP );
2006-04-19 12:13:28 +02:00
2007-12-26 18:18:13 +01:00
/** @todo Use API instead of SELECTs. */
2007-04-11 05:12:11 +02:00
if ( $user_ID ) {
2007-09-27 09:34:15 +02:00
$comments = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT * FROM $wpdb->comments WHERE comment_post_ID = %d AND (comment_approved = '1' OR ( user_id = %d AND comment_approved = '0' ) ) ORDER BY comment_date " , $post -> ID , $user_ID ));
2007-09-04 01:32:58 +02:00
} else if ( empty ( $comment_author ) ) {
2007-09-27 09:34:15 +02:00
$comments = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT * FROM $wpdb->comments WHERE comment_post_ID = %d AND comment_approved = '1' ORDER BY comment_date " , $post -> ID ));
2006-04-19 12:13:28 +02:00
} else {
2007-09-27 09:34:15 +02:00
$comments = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT * FROM $wpdb->comments WHERE comment_post_ID = %d AND ( comment_approved = '1' OR ( comment_author = %s AND comment_author_email = %s AND comment_approved = '0' ) ) ORDER BY comment_date " , $post -> ID , $comment_author , $comment_author_email ));
2006-04-19 12:13:28 +02:00
}
2007-02-24 08:33:29 +01:00
// keep $comments for legacy's sake (remember $table*? ;) )
$comments = $wp_query -> comments = apply_filters ( 'comments_array' , $comments , $post -> ID );
$wp_query -> comment_count = count ( $wp_query -> comments );
2007-06-08 02:20:22 +02:00
update_comment_cache ( $comments );
2006-12-01 04:30:26 +01:00
2006-04-19 12:13:28 +02:00
define ( 'COMMENTS_TEMPLATE' , true );
2008-08-09 07:36:14 +02:00
2008-07-30 08:21:14 +02:00
$include = apply_filters ( 'comments_template' , STYLESHEETPATH . $file );
2006-04-19 12:13:28 +02:00
if ( file_exists ( $include ) )
require ( $include );
2008-07-30 08:21:14 +02:00
elseif ( file_exists ( TEMPLATEPATH . $file ) )
require ( TEMPLATEPATH . $file );
2006-04-19 12:13:28 +02:00
else
2008-07-30 08:21:14 +02:00
require ( get_theme_root () . '/default/comments.php' );
2006-04-19 12:13:28 +02:00
}
2007-12-26 18:18:13 +01:00
/**
2008-06-22 22:23:23 +02:00
* Displays the JS popup script to show a comment .
2007-12-26 18:18:13 +01:00
*
* If the $file parameter is empty , then the home page is assumed . The defaults
* for the window are 400 px by 400 px .
*
* For the comment link popup to work , this function has to be called or the
* normal comment link will be assumed .
*
* @ since 0.71
* @ global string $wpcommentspopupfile The URL to use for the popup window
* @ global int $wpcommentsjavascript Whether to use JavaScript or not . Set when function is called
*
* @ param int $width Optional . The width of the popup window
* @ param int $height Optional . The height of the popup window
* @ param string $file Optional . Sets the location of the popup window
*/
2006-04-19 12:13:28 +02:00
function comments_popup_script ( $width = 400 , $height = 400 , $file = '' ) {
2007-12-26 18:18:13 +01:00
global $wpcommentspopupfile , $wpcommentsjavascript ;
2006-04-19 12:13:28 +02:00
2007-12-26 18:18:13 +01:00
if ( empty ( $file )) {
$wpcommentspopupfile = '' ; // Use the index.
} else {
$wpcommentspopupfile = $file ;
}
2006-04-19 12:13:28 +02:00
2007-12-26 18:18:13 +01:00
$wpcommentsjavascript = 1 ;
$javascript = " <script type='text/javascript'> \n function wpopen (macagna) { \n window.open(macagna, '_blank', 'width= $width ,height= $height ,scrollbars=yes,status=yes'); \n } \n </script> \n " ;
echo $javascript ;
}
/**
2008-06-22 22:23:23 +02:00
* Displays the link to the comments popup window for the current post ID .
2007-12-26 18:18:13 +01:00
*
2008-06-22 22:23:23 +02:00
* Is not meant to be displayed on single posts and pages . Should be used on the
* lists of posts
2007-12-26 18:18:13 +01:00
*
* @ since 0.71
* @ uses $id
* @ uses $wpcommentspopupfile
* @ uses $wpcommentsjavascript
* @ uses $post
*
* @ param string $zero The string to display when no comments
* @ param string $one The string to display when only one comment is available
* @ param string $more The string to display when there are more than one comment
* @ param string $css_class The CSS class to use for comments
* @ param string $none The string to display when comments have been turned off
* @ return null Returns null on single posts and pages .
*/
2007-12-10 21:49:46 +01:00
function comments_popup_link ( $zero = 'No Comments' , $one = '1 Comment' , $more = '% Comments' , $css_class = '' , $none = 'Comments Off' ) {
2007-12-06 20:49:33 +01:00
global $id , $wpcommentspopupfile , $wpcommentsjavascript , $post ;
2006-04-19 12:13:28 +02:00
if ( is_single () || is_page () )
return ;
2007-12-10 21:49:46 +01:00
$number = get_comments_number ( $id );
2006-04-19 12:13:28 +02:00
if ( 0 == $number && 'closed' == $post -> comment_status && 'closed' == $post -> ping_status ) {
2007-12-10 21:49:46 +01:00
echo '<span' . (( ! empty ( $css_class )) ? ' class="' . $css_class . '"' : '' ) . '>' . $none . '</span>' ;
2006-04-19 12:13:28 +02:00
return ;
}
2008-09-03 21:54:14 +02:00
if ( post_password_required () ) {
echo __ ( 'Enter your password to view comments' );
return ;
2006-04-19 12:13:28 +02:00
}
2007-12-10 21:49:46 +01:00
echo '<a href="' ;
if ( $wpcommentsjavascript ) {
if ( empty ( $wpcommentspopupfile ) )
2006-08-30 23:46:31 +02:00
$home = get_option ( 'home' );
2006-04-19 12:13:28 +02:00
else
2006-08-30 23:46:31 +02:00
$home = get_option ( 'siteurl' );
2007-12-10 21:49:46 +01:00
echo $home . '/' . $wpcommentspopupfile . '?comments_popup=' . $id ;
echo '" onclick="wpopen(this.href); return false"' ;
2006-04-19 12:13:28 +02:00
} else { // if comments_popup_script() is not in the template, display simple comment link
if ( 0 == $number )
2007-12-10 21:49:46 +01:00
echo get_permalink () . '#respond' ;
2006-04-19 12:13:28 +02:00
else
2007-12-10 21:49:46 +01:00
comments_link ();
echo '"' ;
2006-04-19 12:13:28 +02:00
}
2007-12-10 21:49:46 +01:00
if ( ! empty ( $css_class ) ) {
echo ' class="' . $css_class . '" ' ;
2006-04-19 12:13:28 +02:00
}
2007-12-10 21:49:46 +01:00
$title = attribute_escape ( get_the_title () );
2008-02-05 07:47:27 +01:00
2007-12-10 21:49:46 +01:00
echo apply_filters ( 'comments_popup_link_attributes' , '' );
echo ' title="' . sprintf ( __ ( 'Comment on %s' ), $title ) . '">' ;
comments_number ( $zero , $one , $more , $number );
echo '</a>' ;
2006-04-19 12:13:28 +02:00
}
2008-09-11 21:25:50 +02:00
function comment_reply_link ( $args = array (), $comment = null , $post = null ) {
global $user_ID ;
$defaults = array ( 'add_below' => 'comment' , 'respond_id' => 'respond' , 'reply_text' => __ ( 'Reply' ),
'login_text' => __ ( 'Log in to Reply' ));
$args = wp_parse_args ( $args , $defaults );
extract ( $args , EXTR_SKIP );
$comment = get_comment ( $comment );
$post = get_post ( $post );
if ( 'open' != $post -> comment_status )
return false ;
$link = '' ;
if ( get_option ( 'comment_registration' ) && ! $user_ID )
$link = '<a href="' . site_url ( 'wp-login.php?redirect_to=' . get_permalink ()) . '">' . $login_text . '</a>' ;
else
$link = " <a href='#' onclick='moveAddCommentForm( \" $add_below - $comment->comment_ID\ " , $comment -> comment_ID , \ " $respond_id\ " ); return false ; ' > $reply_text </ a > " ;
return $link ;
}
2008-09-12 23:19:40 +02:00
function cancel_comment_reply_link ( $text = '' , $respond_id = 'respond' , $respond_root = 'content' ) {
2008-09-11 21:25:50 +02:00
if ( empty ( $text ) )
$text = __ ( 'Click here to cancel reply.' );
2008-09-12 23:19:40 +02:00
echo '<a href="#" onclick="cancelCommentReply(\'' . $respond_id . '\', \'' . $respond_root . '\'); return false;">' . $text . '</a>' ;
2008-09-11 21:25:50 +02:00
}
class Walker_Comment extends Walker {
var $tree_type = 'comment' ;
var $db_fields = array ( 'parent' => 'comment_parent' , 'id' => 'comment_ID' );
function start_lvl ( & $output , $depth , $args ) {
2008-09-12 21:18:39 +02:00
switch ( $args [ 'style' ] ) {
case 'div' :
break ;
case 'ol' :
echo " <ol class='children'> \n " ;
break ;
default :
case 'ul' :
echo " <ul class='children'> \n " ;
break ;
}
2008-09-11 21:25:50 +02:00
}
function end_lvl ( & $output , $depth , $args ) {
2008-09-12 21:18:39 +02:00
switch ( $args [ 'style' ] ) {
case 'div' :
break ;
case 'ol' :
echo " </ol> \n " ;
break ;
default :
case 'ul' :
echo " </ul> \n " ;
break ;
}
2008-09-11 21:25:50 +02:00
}
function start_el ( & $output , $comment , $depth , $args ) {
$depth ++ ;
if ( ! empty ( $args [ 'callback' ]) ) {
call_user_func ( $args [ 'callback' ], $comment , $args , $depth );
return ;
}
$GLOBALS [ 'comment' ] = $comment ;
extract ( $args , EXTR_SKIP );
if ( 'div' == $args [ 'style' ] )
$tag = 'div' ;
else
$tag = 'li' ;
?>
2008-09-12 21:18:39 +02:00
<< ? php echo $tag ?> <?php comment_class() ?> id="comment-<?php comment_ID() ?>">
2008-09-11 21:25:50 +02:00
< ? php if ( 'list' == $args [ 'style' ] ) : ?>
< div id = " div-comment-<?php comment_ID() ?> " >
< ? php endif ; ?>
< div class = " comment-author vcard " >
< ? php echo get_avatar ( $comment , 32 ) ?>
< ? php printf ( __ ( '<cite>%s</cite> Says:' ), get_comment_author_link ()) ?>
</ div >
< ? php if ( $comment -> comment_approved == '0' ) : ?>
< em >< ? php _e ( 'Your comment is awaiting moderation.' ) ?> </em>
< br />
< ? php endif ; ?>
< div class = " comment-meta commentmetadata " >< a href = " #comment-<?php comment_ID() ?> " title = " " >< ? php printf ( __ ( '%1$s at %2$s' ), get_comment_date ( 'F jS, Y' ), get_comment_time ()) ?> </a><?php edit_comment_link('edit',' ','') ?></div>
< ? php echo apply_filters ( 'comment_text' , get_comment_text ()) ?>
< div class = 'reply' >
2008-09-12 21:18:39 +02:00
< ? php if ( 0 == $args [ 'depth' ] || $depth < $args [ 'depth' ] ) echo comment_reply_link ( array ( 'add_below' => 'div-comment' )) ?>
2008-09-11 21:25:50 +02:00
< ? php if ( 'list' == $args [ 'style' ] ) : ?>
</ div >
< ? php endif ; ?>
</ div >
< ? php
}
function end_el ( & $output , $comment , $depth , $args ) {
2008-09-12 21:18:39 +02:00
if ( ! empty ( $args [ 'end-callback' ]) ) {
call_user_func ( $args [ 'end-callback' ], $comment , $args , $depth );
return ;
}
2008-09-11 21:25:50 +02:00
if ( 'div' == $args [ 'style' ] )
echo " </div> \n " ;
else
echo " </li> \n " ;
}
}
/**
* List comments
*
* Used in the comments . php template to list comments for a particular post
*
* @ since 2.7
* @ uses Walker_Comment
*
* @ param $comments array Array of comment object to list
* @ param $args string | array Additional arguments
*/
function wp_list_comments ( & $comments , $args = array () ) {
2008-09-12 21:18:39 +02:00
$defaults = array ( 'walker' => null , 'depth' => 3 , 'style' => 'ul' , 'callback' => null , 'end-callback' => null );
2008-09-11 21:25:50 +02:00
$r = wp_parse_args ( $args , $defaults );
extract ( $r , EXTR_SKIP );
if ( empty ( $walker ) )
$walker = new Walker_Comment ;
$walker -> walk ( $comments , $depth , $r );
}
2007-12-26 18:18:13 +01:00
?>