I put a like and dislike system for comments so that each comment can be liked and disliked, But there are 2 problems :
- For example, if I have 10 comments, the like and dislike buttons will display correctly in all of them, but if there is no like or dislike comment, it will show the value 0000000000 (10 to zero) instead of 0.
- When I click on the Like or Dislike button, the information is saved in
wp_commentmetatable, but not correctly, In the Reza section, instead of registering the ID of the comment, it registers the ID of the post
enter image description here
type here
This is my php codes :
function ldcPostLikeDislikeDetailTable() {
global $wpdb;
$db_table_name = $wpdb->prefix . 'like_dislike_btn_details'; // table name
$charset_collate = $wpdb->get_charset_collate();
$sql = "CREATE TABLE $db_table_name (
id int(11) NOT NULL auto_increment,
btn_container varchar(1000),
likeDislikeType varchar(20),
show_one_home varchar(5),
on_pages varchar(5),
on_product_page varchar(5),
onshowShare varchar(5),
UNIQUE KEY id (id)
) $charset_collate;";
require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
dbDelta( $sql );
add_option( 'test_db_version', $test_db_version );
// Adding default values
$wpdb->insert( $db_table_name, array( 'btn_container' => '<div class="button-container-likes-dislike">
<button class="btn-start-1" id="post-like-btn"><i class="fa fa-thumbs-up"></i><span>Like</span><b>224</b></button>
<button class="btn-start-1" id="post-dislike-btn"><i class="fa fa-thumbs-down"></i><span>Dislike</span><b>28</b></button>
<label class="switch-on-off" style="display: none;"><input type="checkbox" class="input-on-off"><span class="slider-on-off round"></span></label></div>', 'likeDislikeType' => 'cookie-check', 'show_one_home' => 'no', 'on_pages' =>'no', 'on_product_page' =>'yes', 'onshowShare' =>'yes' ) );
} add_action( 'init', 'ldcPostLikeDislikeDetailTable' );
function ldcPostLikeDislikeCounter() {
if (isset($_POST['counter_type'], $_POST['comment_id'])) {
$counter_type = sanitize_key($_POST['counter_type']);
$comment_id = sanitize_key($_POST['comment_id']);
}
if ($counter_type == "post-like-btn") {
//First check dislike exist in user meta
ldcDislikeAlreadyExist($comment_id);
$user_result_like = ldcUserLikeIncrement($counter_type, $comment_id);
if ($user_result_like == "1") {
//Like added successfuly in user meta
$post_result_like = ldcPostLikeIncrement($comment_id);
if ($post_result_like == "1") {
echo esc_html( "1" );
}
} else {
//Likst does not posted
echo esc_html( $user_result_like );
}
} else {
ldcLikeAlreadyExist($comment_id);
$user_result_dislike = ldcUserDislikeIncrement($counter_type, $comment_id);
if ($user_result_dislike == "1") {
//Like added successfuly in user meta
$post_result_dislike = ldcPostDislikeIncrement($comment_id);
if ($post_result_dislike == "1") {
echo esc_html( "1" );
}
} else {
//Likst does not posted
echo esc_html( $user_result_dislike );
}
}
die();
} add_action('wp_ajax_nopriv_ldcPostLikeDislikeCounter', 'ldcPostLikeDislikeCounter'); add_action('wp_ajax_ldcPostLikeDislikeCounter', 'ldcPostLikeDislikeCounter');
function ldcAjaxPostLikeDislikeEnqueueScripts() {
wp_enqueue_style( 'like', get_stylesheet_directory_uri() . '/assets/css/style.css' );
wp_enqueue_script( 'like', get_stylesheet_directory_uri() . '/assets/js/logic.js', array( 'jquery' ), null, true );
wp_localize_script('like', 'counterURL', array(
'ajax_url' => admin_url('admin-ajax.php')
));
wp_localize_script('like', 'cookieURL', array(
'cookie_ajax_url' => admin_url('admin-ajax.php')
));
} add_action('wp_enqueue_scripts', 'ldcAjaxPostLikeDislikeEnqueueScripts');
function shortcode_like_dislike( $comment_text ) {
global $post, $wpdb;
$table_name = $wpdb->prefix . 'like_dislike_btn_details';
$c = ldcLikeDislikeSourceBtns();
$comment_text = $comment_text . $c;
return $comment_text;
} add_filter( 'comment_text', 'shortcode_like_dislike');
function ldcLikeDislikeSourceBtns(){
#global $wp_query;
#$postid = $wp_query->post->ID;
$commentid = get_comment_ID();
//Post meta
#$post_like_counter = get_post_meta($postid, 'post_likes_plusCounter', true);
$post_like_counter = get_comment_meta($commentid, 'post_likes_plusCounter', true);
#$post_dislike_counter = get_post_meta($postid, 'post_dislikes_plusCounter', true);
$post_dislike_counter = get_comment_meta($commentid, 'post_dislikes_plusCounter', true);
if ($post_like_counter == "") {
$post_like_counter = "0";
}
if ($post_dislike_counter == "") {
$post_dislike_counter = "0";
}
global $wpdb;
$table_name = $wpdb->prefix . 'like_dislike_btn_details';
$button_db_details = $wpdb->get_row("SELECT * FROM $table_name WHERE id = '1' ");
$c = "<div class='post-like-dislike-plusCounter-container'>".$button_db_details->btn_container."</div><span class='hidden-id' id='like-dislike-post-id'>".get_the_ID()."</span><span class='hidden-id ldc-post-total-likes'>".$post_like_counter."</span><span class='hidden-id ldc-post-total-dislikes'>".$post_dislike_counter."</span><span class='hidden-id ldc-lk-dk-type'>".$button_db_details->likeDislikeType."</span><span class='hidden-id ldc-page-title'>".get_the_title()."</span><span class='hidden-id ldc-share-it'>".$button_db_details->onshowShare."</span>";
return $c;
}
function ldcUserLikeIncrement($counter_type, $comment_id) {
$sendBack = "";
if (is_user_logged_in()) {
$user_id = get_current_user_id();
$user_like_posts = get_user_meta($user_id, 'post_likes_plusCounter', true);
if ($user_like_posts == "") {
$comment_id = $comment_id . ",";
add_user_meta($user_id, 'post_likes_plusCounter', $comment_id);
// Like added successuflly
$sendBack = "1";
} else {
$comma_seperate_post_ids = explode(',', $user_like_posts);
if (in_array($comment_id, $comma_seperate_post_ids)) {
//like aready exist of current user.
$sendBack = "0";
} else {
//update user meta with new post id
$user_like_posts = $user_like_posts . "" . $comment_id . ",";
update_user_meta($user_id, 'post_likes_plusCounter', $user_like_posts);
// Like added successuflly
$sendBack = "1";
}
}
} else {
//User not login
$sendBack = "2";
}
return $sendBack;
}
function ldcUserDislikeIncrement($counter_type, $comment_id) {
$sendBack = "";
if (is_user_logged_in()) {
$user_id = get_current_user_id();
$user_like_posts = get_user_meta($user_id, 'post_dislikes_plusCounter', true);
if ($user_like_posts == "") {
$comment_id = $comment_id . ",";
add_user_meta($user_id, 'post_dislikes_plusCounter', $comment_id);
// Like added successuflly
$sendBack = "1";
} else {
$comma_seperate_post_ids = explode(',', $user_like_posts);
if (in_array($comment_id, $comma_seperate_post_ids)) {
//like aready exist of current user.
$sendBack = "0";
} else {
//update user meta with new post id
$user_like_posts = $user_like_posts . "" . $comment_id . ",";
update_user_meta($user_id, 'post_dislikes_plusCounter', $user_like_posts);
// Like added successuflly
$sendBack = "1";
}
}
} else {
//User not login
$sendBack = "2";
}
return $sendBack;
}
function ldcPostLikeIncrement($comment_id) {
#$post_like_posts = get_post_meta($post_id, 'post_likes_plusCounter', true);
$post_like_posts = get_comment_meta($comment_id, 'post_likes_plusCounter', true);
if ($post_like_posts == "") {
#add_post_meta($post_id, 'post_likes_plusCounter', '1');
add_comment_meta($comment_id, 'post_likes_plusCounter', '1');
} else {
$post_like_posts = $post_like_posts + 1;
#update_post_meta($post_id, 'post_likes_plusCounter', $post_like_posts);
update_comment_meta($comment_id, 'post_likes_plusCounter', $post_like_posts);
}
return "1";
}
function ldcPostDislikeIncrement($comment_id) {
#$post_like_posts = get_post_meta($post_id, 'post_dislikes_plusCounter', true);
$post_like_posts = get_comment_meta($comment_id, 'post_dislikes_plusCounter', true);
if ($post_like_posts == "") {
#add_post_meta($post_id, 'post_dislikes_plusCounter', '1');
add_comment_meta($comment_id, 'post_dislikes_plusCounter', '1');
} else {
$post_like_posts = $post_like_posts + 1;
#update_post_meta($post_id, 'post_dislikes_plusCounter', $post_like_posts);
update_comment_meta($comment_id, 'post_dislikes_plusCounter', $post_like_posts);
}
return "1";
}
function ldcDislikeAlreadyExist($comment_id) {
$user_id = get_current_user_id();
$user_like_posts = get_user_meta($user_id, 'post_dislikes_plusCounter', true);
if ($user_like_posts == "") {
return "Not exist";
} else {
$comma_seperate_post_ids = explode(',', $user_like_posts);
if (in_array($comment_id, $comma_seperate_post_ids)) {
//dislike aready exist of the current user.
$key = array_search($comment_id, $comma_seperate_post_ids);
if (false !== $key) {
unset($comma_seperate_post_ids[$key]);
$updated_counter = implode(',', $comma_seperate_post_ids);
if($updated_counter==""){
$updated_counter = ",";
}
update_user_meta($user_id, 'post_dislikes_plusCounter', $updated_counter);
ldcDislikeDecrease($comment_id);
}
}
}
}
function ldcDislikeDecrease($comment_id){
if (is_user_logged_in()) {
#$user_dislike_posts = get_post_meta( $post_id, 'post_dislikes_plusCounter', true );
$user_dislike_posts = get_comment_meta( $comment_id, 'post_dislikes_plusCounter', true );
$user_dislike_posts = $user_dislike_posts - 1;
#update_post_meta( $post_id, 'post_dislikes_plusCounter', $user_dislike_posts );
update_comment_meta( $comment_id, 'post_dislikes_plusCounter', $user_dislike_posts );
echo esc_html( "1" );
}
}
function ldcLikeAlreadyExist($comment_id) {
$user_id = get_current_user_id();
$user_like_posts = get_user_meta($user_id, 'post_likes_plusCounter', true);
if ($user_like_posts == "") {
return "Not exist";
} else {
$comma_seperate_post_ids = explode(',', $user_like_posts);
if (in_array($comment_id, $comma_seperate_post_ids)) {
//dislike aready exist of the current user.
$key = array_search($comment_id, $comma_seperate_post_ids);
if (false !== $key) {
unset($comma_seperate_post_ids[$key]);
$updated_counter = implode(',', $comma_seperate_post_ids);
if($updated_counter==""){
$updated_counter = ",";
}
update_user_meta($user_id, 'post_likes_plusCounter', $updated_counter);
ldcLikeDecrease($comment_id);
}
}
}
}
function ldcLikeDecrease($comment_id){
if (is_user_logged_in()) {
#$user_dislike_posts = get_post_meta( $post_id, 'post_likes_plusCounter', true );
$user_dislike_posts = get_comment_meta( $comment_id, 'post_likes_plusCounter', true );
$user_dislike_posts = $user_dislike_posts - 1;
#update_post_meta( $post_id, 'post_likes_plusCounter', $user_dislike_posts );
update_comment_meta( $comment_id, 'post_likes_plusCounter', $user_dislike_posts );
echo esc_html( "1" );
}
}
This is my javascript code :
jQuery(document).ready(function( $ ) {
// Show like and dislike buttons
$('#post-like-btn b').text($('.ldc-post-total-likes').text()); //show text
$('#post-dislike-btn b').text($('.ldc-post-total-dislikes').text()); //show text
$('.post-like-dislike-plusCounter-container').css("display", "block"); //show buttons
});
var btnOpacityId = "";
jQuery( document ).on( 'click', '.button-container-likes-dislike button', function() {
btnOpacityId = jQuery(this).attr('id');
jQuery(this).css("opacity", "0.4");
var counter_type = jQuery(this).attr('id').trim();
var post_id = jQuery("#like-dislike-post-id").text().trim();
jQuery.ajax({
url : counterURL.ajax_url,
type : 'post',
data : {
action : 'ldcPostLikeDislikeCounter',
counter_type : counter_type,
post_id : post_id
},
success : function( response ) {
jQuery("#"+counter_type).css("opacity", "1");
response = response.trim();
console.log(response);
if (counter_type == "post-like-btn") {
if (response=="1") {
//increment like
var inc = parseInt(jQuery('#post-like-btn b').text());
jQuery('#post-like-btn b').text(inc+1);
jQuery('.social-share-back').fadeIn();
}
else if (response=="11") {
//increment like
var inc = parseInt(jQuery('#post-like-btn b').text());
jQuery('#post-like-btn b').text(inc+1);
//dislike decrement
var desc = parseInt(jQuery('#post-dislike-btn b').text());
jQuery('#post-dislike-btn b').text(desc-1);
jQuery('.social-share-back').fadeIn();
}
else if(response == "0"){
alert("Like already exist for this post");
}
else if(response == "2"){
alert("Please, first you need to login if you want to vote!");
}
}
else{
if (response=="1") {
var inc = parseInt(jQuery('#post-dislike-btn b').text());
jQuery('#post-dislike-btn b').text(inc+1);
}
else if (response=="11") {
var inc = parseInt(jQuery('#post-dislike-btn b').text());
jQuery('#post-dislike-btn b').text(inc+1);
// Dislike decrement
var inc = parseInt(jQuery('#post-like-btn b').text());
jQuery('#post-like-btn b').text(inc-1);
}
else if(response == "0"){
alert("Dislike already exist for this post");
}
else if(response == "2"){
alert("Please, first you need to login if you want to vote!");
}
}
}
});
})
This is my css codes :
#likes-dislikes{
display: flex;
justify-content: space-around;
flex:1;
list-style: none;
}
#likes-dislikes :first-child span{
background-color: #00D100;
border: 2px solid #b0b7da;
color: white;
font-weight: 900;
margin-top:5px;
padding: 5px 10px;
align-items: center;
justify-content: center;
box-shadow: inset 0 0 0 0 #fff;
-webkit-transition: ease-out 0.4s;
-moz-transition: ease-out 0.4s;
transition: ease-out 0.4s;
}
#likes-dislikes :last-child span{
background-color: #E22C05;
border: 2px solid #b0b7da;
color: white;
font-weight: 900;
margin-top:5px;
padding: 5px 10px;
align-items: center;
justify-content: center;
box-shadow: inset 0 0 0 0 #fff;
-webkit-transition: ease-out 0.4s;
-moz-transition: ease-out 0.4s;
transition: ease-out 0.4s;
}
#likes-dislikes a{
background-color: #372c3f;
border: 2px solid #b0b7da;
border-right: 0px;
color: white;
margin-top:5px;
cursor: pointer;
padding: 5px 30px;
align-items: center;
justify-content: center;
box-shadow: inset 0 0 0 0 #fff;
-webkit-transition: ease-out 0.4s;
-moz-transition: ease-out 0.4s;
transition: ease-out 0.4s;
}
#likes-dislikes :first-child a:hover {
border:2px solid #00D100;
position: relative;
box-shadow: inset 400px 0 0 0 #fff;
}
#likes-dislikes :first-child a:hover:after {
content:url() ;
display: block;
position: absolute;
width: 30%;
height: 30%;
margin: -26px 33px 0px 33px;;
padding: 0;
align-items: center;
justify-content: center;
transition: all .35s ease-Out;
color:#fff;
}
#likes-dislikes :last-child a:hover {
border:2px solid #E22C05;
position: relative;
box-shadow: inset 400px 0 0 0 #fff;
}
#likes-dislikes :last-child a:hover:after {
content: url();
display: block;
position: absolute;
width: 30%;
height: 30%;
margin: -29px 33px 0px 33px;;
padding: 2px;
align-items: center;
justify-content: center;
transition: all .35s ease-Out;
color:#fff;
}
My knowledge about programming is very little, I have been dealing with this issue for a few days, I am really confused, friends, if you can help me, please do not hesitate.