Как отфильтровать пользовательский пост по звездному рейтингу

Вопрос или проблема

Сначала пользователь заполняет эту пользовательскую форму комментария.

first step

Это мой meta_key, который я хочу получить. для каждого комментария есть 10 оценок.

meta_key

Я хочу сделать ниже фильтр оценок. Но не знаю, с чего начать.

final output

Вот что я пробовал до сих пор.

add_action( 'comment_post', 'show_message_function', 10, 2 );

function show_message_function( $comment_ID, $comment_approved  ) {

    $comment = get_comment( $comment_ID );

    if( empty($comment) ) {
      return;
    }

    $post = get_post( $comment->comment_post_ID );

    $post_comments = get_comments( ['post_ID' => $post->ID ] ); 

    $meta_value = get_comment_meta($comment->comment_ID);

    d($post);

    // d($post_comments);
    d($meta_value);

    die;
}

function d($data) {
  echo '<pre>', print_r($data), '</pre>';
}

ОБНОВЛЕНИЕ: Я создал мета пост и сохраняю его в обновленной средней оценке каждый раз, когда добавляется комментарий.

Теперь хочу сделать фильтр, как показано на изображении выше, когда любой пользователь щелкает по флажку напротив количества звезд, данные должны быть отфильтрованы и показывать те пользовательские посты, которые имеют среднее = выбранное количество звезд.

Я создал пользовательский код для оценки, возможно, этот код поможет вам.

Шаг первый:- Файл шаблона

    <!-- начало контента -->
    <div id="content-wrap" class="top_pad review-planner" >         
        <div class="review-block">
            <div class="container">
            <h2><?php echo get_field('sub_title'); ?></h2>
            <div class="all-list" style="display:none;">
            <?php if(get_field('list_title')) { ?>
                <span class="title"><?php echo get_field('list_title'); ?></span>
            <?php } ?>  
            <ul class="list-item">
                <li class="service"><span>Service:<i></i></span></li>
                <li class="service2"><span>Uitsraling:<i></i></span></li>
                <li class="service3"><span>Ligging:<i></i></span></li>
                <li class="service4"><span>Eten&drinken:<i></i></span></li>
                <li class="service5"><span>Parkeren:<i></i></span></li>
                <li class="service6"><span>Prijs/kwaliteit:<i></i></span></li>
            </ul>
                <a class="reservBtn"><span>Schrijf een review</span></a>
            </div>

            </div>
        </div>  

        <div class="user-reviews">
        <div id="ajaxData">

        <?php query_posts('post_type=reviews&showposts=-1');
                    if (have_posts()) : $i =1; while (have_posts()) : the_post();
                    $url = wp_get_attachment_url( get_post_thumbnail_id($post->ID) );           
                ?>
            <div class="publish-review">
            <div class="icon" style="background:url(<?php if($url) { ?><?php echo $url; ?><?php } else { ?><?php bloginfo('template_url'); ?>/images/ic.png<?php } ?>) no-repeat center center; background-size:cover;" >

            </div>              
            <div class="text-right">
            <h2><span><?php the_title(); ?></span> <cite class="rating"></cite> <i>9,7</i><small><?php the_time('j F Y') ?></small></h2>                
            <div class="desc">
                <p><?php echo get_field('description'); ?></p>
            </div>
            <ul>
                <?php if(get_field('service_rating')) { ?>
                    <li class="service">Service: <i><?php echo get_field('service_rating'); ?></i></li>
                <?php } ?>  
                <?php if(get_field('uitsraling_rating')) { ?>
                    <li class="service2">Uitsraling: <i><?php echo get_field('uitsraling_rating'); ?></i></li>
                <?php } ?>  

                <?php if(get_field('ligging_rating')) { ?>
                    <li class="service3">Ligging: <i><?php echo get_field('ligging_rating'); ?></i></li>
                <?php } ?>  

                <?php if(get_field('eten&drinken_rating')) { ?>
                    <li class="service4">Eten&drinken: <i><?php echo get_field('eten&drinken_rating'); ?></i></li>
                <?php } ?>  
                <?php if(get_field('parkeren_rating')) { ?>
                    <li class="service5">Parkeren: <i><?php echo get_field('parkeren_rating'); ?></i></li>
                <?php } ?>  
                <?php if(get_field('prijskwaliteit_rating')) { ?>
                    <li class="service6"> Prijs/kwaliteit: <i><?php echo get_field('prijskwaliteit_rating'); ?></i></li>
                <?php } ?>  

            </ul>

            </div>
            </div>
        <?php endwhile; wp_reset_query(); endif; ?> 

    </div>
        </div>

    </div>

<?php include 'reviewform.php'; ?>      

<!-- конец контента -->

jQuery(document).ready(function() {

jQuery('.header-wrap').click(function(event) {
    event.stopPropagation();
});
setTimeout(function() {
    jQuery('.all-list').fadeIn();
    jQuery('#content-wrap').trigger('click');
}, 1000);

jQuery('.review-block .all-list ul.list-item li').each(function() {
    var ffc = jQuery(this).find('span i').text();

    if (jQuery(this).find('span i').text() == "NaN") {

        jQuery(this).hide();
    }
});

jQuery('#content-wrap').click(function() {
    var url = "<?php bloginfo('template_url'); ?>/loadData.php";
    jQuery.ajax({
        type: "POST",
        url: url,
        data: "",
        my_option: 'sucomp',
        success: function(data) {
            jQuery('#ajaxData').html(data);
            var szs = jQuery('.user-reviews .publish-review').size();
            var szs2 = szs * 10
            serv = [];
            serv2 = [];
            serv3 = [];
            serv4 = [];
            serv5 = [];
            serv6 = [];
            var a1 = 0;
            var a2 = 0;
            var a3 = 0;
            var a4 = 0;
            var a5 = 0;
            var a6 = 0;
            jQuery('.user-reviews .publish-review').each(function(m) {
                var comvar = 0;
                var common = [];
                jQuery(this).find('.text-right ul li').each(function() {
                    if (jQuery(this).hasClass('service')) {
                        var ths = jQuery(this).find('i').text();
                        serv.push(ths);
                    }
                    if (jQuery(this).hasClass('service2')) {
                        var ths = jQuery(this).find('i').text();
                        serv2.push(ths);
                    }
                    if (jQuery(this).hasClass('service3')) {
                        var ths = jQuery(this).find('i').text();
                        serv3.push(ths);
                    }
                    if (jQuery(this).hasClass('service4')) {
                        var ths = jQuery(this).find('i').text();
                        serv4.push(ths);
                    }
                    if (jQuery(this).hasClass('service5')) {
                        var ths = jQuery(this).find('i').text();
                        serv5.push(ths);
                    }
                    if (jQuery(this).hasClass('service6')) {
                        var ths = jQuery(this).find('i').text();
                        serv6.push(ths);
                    }

                    var ths2 = jQuery(this).find('i').text();
                    common.push(ths2);

                });
                common.forEach(function(ele, key) {
                    comvar += parseInt(ele);
                });
                comvar2 = comvar / 60;
                coml2 = comvar2 / 100 * 1000;
                console.log(coml2);

                jQuery(this).find('.text-right h2').find('i').text(coml2.toFixed(1).replace(".", ','));

                var pars = parseFloat(coml2);
                var divd = pars / 100;
                var runds = divd * 1000;
                var pieces = runds.toFixed(0);

                rund = pieces;
                //alert(rund);  
                function addScore(score, $domElement) {
                    jQuery("<span class="stars-container">")
                        .addClass("stars-" + score.toString())
                        .text("★★★★★")
                        .appendTo($domElement);
                    jQuery("head").append(jQuery('<style>.stars-' + rund + ':after { width:' + rund + '%; }</style>'));

                }

                addScore(rund, jQuery("#fixture-" + m));

            });
            serv.forEach(function(ele, key) {
                a1 += parseInt(ele);
            });
            sp1 = a1 / szs2;
            tot1 = sp1 / 100 * 1000;

            serv2.forEach(function(ele, key) {
                a2 += parseInt(ele);
            });
            sp2 = a2 / szs2;
            tot2 = sp2 / 100 * 1000;

            serv3.forEach(function(ele, key) {
                a3 += parseInt(ele);
            });
            sp3 = a3 / szs2;
            tot3 = sp3 / 100 * 1000;

            serv4.forEach(function(ele, key) {
                a4 += parseInt(ele);
            });
            sp4 = a4 / szs2;
            tot4 = sp4 / 100 * 1000;

            serv5.forEach(function(ele, key) {
                a5 += parseInt(ele);
            });
            sp5 = a5 / szs2;
            tot5 = sp5 / 100 * 1000;

            serv6.forEach(function(ele, key) {
                a6 += parseInt(ele);
            });
            sp6 = a6 / szs2;
            tot6 = sp6 / 100 * 1000;

            jQuery('.review-block .all-list ul.list-item li').each(function() {
                if (jQuery(this).hasClass('service')) {
                    jQuery(this).find('i').text(tot1.toFixed(1).replace(".", ','));
                }

                if (jQuery(this).hasClass('service2')) {
                    jQuery(this).find('i').text(tot2.toFixed(1).replace(".", ','));
                }

                if (jQuery(this).hasClass('service3')) {
                    jQuery(this).find('i').text(tot3.toFixed(1).replace(".", ','));
                }

                if (jQuery(this).hasClass('service4')) {
                    jQuery(this).find('i').text(tot4.toFixed(1).replace(".", ','));
                }

                if (jQuery(this).hasClass('service5')) {
                    jQuery(this).find('i').text(tot5.toFixed(1).replace(".", ','));
                }

                if (jQuery(this).hasClass('service6')) {
                    jQuery(this).find('i').text(tot6.toFixed(1).replace(".", ','));
                }

            })

        },
        complete: function() {
            jQuery('.review-block .all-list ul.list-item li').each(function() {
                var ffc = jQuery(this).find('span i').text();

                if (jQuery(this).find('span i').text() == "NaN") {

                    jQuery(this).hide();
                }
            });

        }
    });
    return false;

});

})

Ответ или решение

Теория

Фильтрация пользовательских постов по звездному рейтингу — это задача, которая включает в себя получение и обработку метаданных комментариев для оценки средней оценки и отображения постов в соответствии с выбранными критериями. Это может быть полезно, например, для сайтов обзоров или магазинов, где у каждого товара есть рейтинг, и пользователи могут хотеть видеть только те товары, которые соответствуют определенным критериям.

Для внедрения такого функционала в WordPress необходимо работать с комментариями и их мета-данными, которые могут хранить информацию о рейтинге. Кроме того, нужно объединить эту функциональность с пользовательским интерфейсом — фильтром, который позволяет пользователю выбрать интересующую его оценку.

Пример

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

Применение

  1. Создание пользовательского интерфейса и хука для обработки фильтрации:

    Создайте HTML-форму с чекбоксами, представляющими различные звездные рейтинги, которые пользователи могут выбрать для фильтрации. Например:

    <form id="rating-filter-form">
       <label><input type="checkbox" name="rating" value="1"> 1 звезда</label>
       <label><input type="checkbox" name="rating" value="2"> 2 звезды</label>
       <label><input type="checkbox" name="rating" value="3"> 3 звезды</label>
       <label><input type="checkbox" name="rating" value="4"> 4 звезды</label>
       <label><input type="checkbox" name="rating" value="5"> 5 звезд</label>
       <button type="submit">Фильтровать</button>
    </form>
  2. Обработка AJAX-запроса:

    При отправке формы используйте jQuery для отправки AJAX-запроса на сервер:

    jQuery(document).ready(function($) {
       $('#rating-filter-form').on('submit', function(e) {
           e.preventDefault();
           var selectedRatings = $(this).serialize();
           $.ajax({
               url: ajaxurl,
               type: 'POST',
               data: {
                   action: 'filter_posts_by_rating',
                   ratings: selectedRatings
               },
               success: function(response) {
                   $('#filtered-posts-container').html(response); // Отображение отфильтрованных постов
               }
           });
       });
    });
  3. Обработка данных на серверной стороне:

    Добавьте обработчик на PHP для обработки данных фильтрации и вычисления средней оценки:

    add_action('wp_ajax_filter_posts_by_rating', 'filter_posts_by_rating');
    add_action('wp_ajax_nopriv_filter_posts_by_rating', 'filter_posts_by_rating');
    
    function filter_posts_by_rating() {
       // Получите выбранные рейтинги из запроса
       $selected_ratings = $_POST['ratings'];
       $selected_rating_values = array_map('intval', explode('&', $selected_ratings));
    
       // Получите посты
       $query_args = [
           'post_type' => 'custom_post_type', // укажите ваш тип поста
           'meta_query' => []
       ];
    
       foreach ($selected_rating_values as $rating) {
           $query_args['meta_query'][] = [
               'key' => 'average_rating',
               'value' => $rating,
               'compare' => '='
           ];
       }
    
       $posts = new WP_Query($query_args);
    
       // Форматирование вывода
       if ($posts->have_posts()) {
           while ($posts->have_posts()) : $posts->the_post();
               echo '<div>' . get_the_title() . ' - Средний рейтинг: ' . get_post_meta(get_the_ID(), 'average_rating', true) . '</div>';
           endwhile;
           wp_reset_postdata();
       } else {
           echo 'Нет постов с выбранным рейтингом.';
       }
    
       die();
    }

Эта структура помогает минимизировать нагрузку на сервер и обеспечить быстрое взаимодействие с пользовательским интерфейсом. Вы должны обеспечить корректное сохранение и обновление метаданных комментариев при их создании или изменении для корректной работы фильтра.

Оцените материал
Добавить комментарий

Капча загружается...