Составление списка всех представленных обзоров WooCommerce - PullRequest
0 голосов
/ 18 октября 2018

Я пытаюсь создать список всех утвержденных обзоров WooCommerce с помощью запроса, и я пытаюсь отобразить этот список на странице с помощью шорткода.

Главное с этим - показатьимя клиента, адрес электронной почты и дата отправки отзыва.Вот код и то, что я пробовал до сих пор:

function list_reviews() {  
    $customer_details_from_reviews = $wpdb->get_results("SELECT wpc.comment_author,wpc.comment_author_email,wpc.comment_date,wpc.comment_content,wpcm.meta_value AS rating FROM `" . $wpdb->prefix . "comments` AS wpc INNER JOIN  `" . $wpdb->prefix . "commentmeta` AS wpcm ON wpcm.comment_id = wpc.comment_id AND wpcm.meta_key = 'rating' WHERE wpc.comment_post_id = '" . $p_id . "' ");
}
add_shortcode('allreviews', 'list_reviews');

Ничего не отображается на паштете при использовании [allreviews].Если кто-то может помочь с этим, я был бы очень признателен.

Ответы [ 2 ]

0 голосов
/ 14 ноября 2018

Я застрял с той же самой проблемой в течение недели, я думаю, и сумел найти решение, которое будет выводить все обзоры продуктов на одной странице.

//Display all reviews
if (!function_exists('display_all_reviews')) {
function display_all_reviews(){
    $args = array(
       'status' => 'approve',
       'type' => 'review'
    );

    // The Query
    $comments_query = new WP_Comment_Query;
    $comments = $comments_query->query( $args );

    // Comment Loop
    if ( $comments ) {
        echo "<ol>";
        foreach ( $comments as $comment ): ?>
        <?php if ( $comment->comment_approved == '0' ) : ?>
            <p class="meta waiting-approval-info">
                <em><?php _e( 'Thanks, your review is awaiting approval', 'woocommerce' ); ?></em>
            </p>
            <?php endif;  ?>
            <li itemprop="reviews" itemscope itemtype="http://schema.org/Review" <?php comment_class(); ?> id="li-review-<?php echo $comment->comment_ID; ?>">
                <div id="review-<?php echo $comment->comment_ID; ?>" class="review_container">
                    <div class="review-avatar">
                        <?php echo get_avatar( $comment->comment_author_email, $size = '50' ); ?>
                    </div>
                    <div class="review-author">
                        <div class="review-author-name" itemprop="author"><?php echo $comment->comment_author; ?></div>
                        <div class='star-rating-container'>
                            <div itemprop="reviewRating" itemscope itemtype="http://schema.org/Rating" class="star-rating" title="<?php echo esc_attr( get_comment_meta( $comment->comment_ID, 'rating', true ) ); ?>">
                                <span style="width:<?php echo get_comment_meta( $comment->comment_ID, 'rating', true )*22; ?>px"><span itemprop="ratingValue"><?php echo get_comment_meta( $comment->comment_ID, 'rating', true ); ?></span> <?php _e('out of 5', 'woocommerce'); ?></span>

                                    <?php
                                        $timestamp = strtotime( $comment->comment_date ); //Changing comment time to timestamp
                                        $date = date('F d, Y', $timestamp);
                                    ?>
                            </div>
                            <em class="review-date">
                                <time itemprop="datePublished" datetime="<?php echo $comment->comment_date; ?>"><?php echo $date; ?></time>
                            </em>
                        </div>
                    </div>
                    <div class="clear"></div>
                    <div class="review-text">
                        <div itemprop="description" class="description">
                            <?php echo $comment->comment_content; ?>
                        </div>
                        <div class="clear"></div>
                    </div>
                <div class="clear"></div>           
            </div>
        </li>

        <?php 
        endforeach;
        echo "</ol>";
    } else {
        echo "This product hasn't been rated yet.";
    }
}
}

add_shortcode('allreviews', 'display_all_reviews');

Вышеприведенная функция также включает выводсамих отзывов.Мне также удалось создать несколько дополнительных функций, таких как получение и отображение среднего рейтинга отзывов по всем продуктам, а также отображение гистограммы всех оценок продуктов.Я написал учебное пособие с демонстрационной ссылкой здесь: Как получить отзывы клиентов WooCommerce по всем продуктам, отображать среднее и все рейтинги в гистограмме без плагина

0 голосов
/ 18 октября 2018

Во-первых, в своей функции вы просто запрашиваете базу данных, не просматривая результаты и не распечатывая их, во-вторых, в Wordpress уже есть встроенная функция, которая поможет вам получить комментарий из базы данных без написания пользовательского запроса, который всегда целесообразен.выбор следовать стандарту WordPress, если это возможно.

чтобы получить комментарии с помощью функции get_comments(), ваш код должен выглядеть следующим образом:

function list_reviews()
{
    $args = array(
        'post_type' => 'product', //Post type 
        'status' => "approve", // Status you can also use 'hold', 'spam', 'trash', 


    );
    $comments = get_comments($args);

    foreach ($comments as $comment) {
        echo "Customer Name " . $comment->comment_author . " Email: " . $comment->comment_author_email . " Date " . $comment->comment_date . "<br>";
    }


}
add_shortcode('allreviews', 'list_reviews');

. Для получения дополнительной информации о функции get_comments() вы можете прочитать следующую WordPressКодекс

Отредактировано:

, чтобы напечатать информацию в таблице, ваш код должен выглядеть следующим образом:

function list_reviews()
{
    $args = array(
        'post_type' => 'product', //Post type 
        'status' => "approve", // Status you can also use 'hold', 'spam', 'trash', 
    );
    $comments = get_comments($args);
    ?>
<table>
    <tr>
        <th>Customer Name</th>
        <th>Email</th>
        <th>Date</th>
    </tr>
    <?php
foreach ($comments as $comment) {

    ?>
    <tr>
        <td>
            <?php echo $comment->comment_author ?>
        </td>
        <td>
            <?php echo $comment->comment_author_email ?>
        </td>
        <td>
            <?php echo $comment->comment_date ?>
        </td>
    </tr>
    <?php

}
?>
</table>
<?php

}
add_shortcode('allreviews', 'list_reviews');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...