Commit 37badd20 authored by Vadim's avatar Vadim

Version 2.6.4

Оптимизирована подгрузка новых счетчиков
parent 0e8c96ab
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
Plugin Name: Bg Az-Counter Plugin Name: Bg Az-Counter
Plugin URI: https://bogaiskov.ru Plugin URI: https://bogaiskov.ru
Description: Подсчет количества посещений страниц на базе stat.azbyka.ru Description: Подсчет количества посещений страниц на базе stat.azbyka.ru
Version: 2.6.2 Version: 2.6.4
Author: VBog Author: VBog
Author URI: https://bogaiskov.ru Author URI: https://bogaiskov.ru
License: GPL2 License: GPL2
...@@ -38,7 +38,7 @@ ...@@ -38,7 +38,7 @@
if ( !defined('ABSPATH') ) { if ( !defined('ABSPATH') ) {
die( 'Sorry, you are not allowed to access this page directly.' ); die( 'Sorry, you are not allowed to access this page directly.' );
} }
define('BG_COUNTER_VERSION', '2.6.2'); define('BG_COUNTER_VERSION', '2.6.4');
define('BG_COUNTER_LOG', dirname(__FILE__ ).'/bg_counter.log'); define('BG_COUNTER_LOG', dirname(__FILE__ ).'/bg_counter.log');
define('BG_COUNTER_STAT_COUNTERS','https://stat.azbyka.ru/counters'); define('BG_COUNTER_STAT_COUNTERS','https://stat.azbyka.ru/counters');
......
...@@ -13,7 +13,11 @@ jQuery( document ).ready(function() { ...@@ -13,7 +13,11 @@ jQuery( document ).ready(function() {
var socket = new ReconnectingWebSocket(request, null, { timeoutInterval: 10000 }); var socket = new ReconnectingWebSocket(request, null, { timeoutInterval: 10000 });
socket.onopen = function() { socket.onopen = function() {
if (bg_counter.debug) console.log(" Соединение установлено: "+request); if (bg_counter.debug) console.log(" Соединение установлено: "+request);
GetAllCounters(); // Обновляет счетчики каждые 3 сек, если добавлены элементы.
let timerAllCountersId = setTimeout(function tickAllCounters() {
GetAllCounters();
timerAllCountersId = setTimeout(tickAllCounters, bg_counter.updatetime?bg_counter.updatetime:3000);
}, bg_counter.updatetime?bg_counter.updatetime:3000);
}; };
// Обработка ошибок // Обработка ошибок
if (bg_counter.debug) { if (bg_counter.debug) {
...@@ -29,9 +33,17 @@ jQuery( document ).ready(function() { ...@@ -29,9 +33,17 @@ jQuery( document ).ready(function() {
console.log('Код: ' + event.code + ' причина: ' + event.reason); console.log('Код: ' + event.code + ' причина: ' + event.reason);
}; };
} }
} else GetAllCounters(); } else {
// Обновляет счетчики каждые 3 сек, если добавлены элементы.
bg_counter_elements_reloaded_on_scroll(); let timerAllCountersId = setTimeout(function tickAllCounters() {
GetAllCounters();
timerAllCountersId = setTimeout(tickAllCounters, bg_counter.updatetime?bg_counter.updatetime:3000);
}, bg_counter.updatetime?bg_counter.updatetime:3000);
}
// Обновляет счетчики после прокрутки страницы, если добавлены элементы.
// jQuery(window).on('scroll', function() {
// GetAllCounters();
// });
/********************************************************************************* /*********************************************************************************
Просомтр счетчиков читающих в реальном времени. Просомтр счетчиков читающих в реальном времени.
...@@ -190,51 +202,66 @@ GET /counters/project/test/author/1/book/3 ...@@ -190,51 +202,66 @@ GET /counters/project/test/author/1/book/3
**********************************************************************************/ **********************************************************************************/
function GetAllCounters() { function GetAllCounters() {
jQuery('span.bg-az-counter').each (function () { var elem = jQuery('span.bg-az-counter');
var el = jQuery(this); if( typeof elem == 'undefined' ) {
// bg_counter_elements = el.length; return;
var type = el.attr('data-type'); }
var id = el.attr('data-ID'); var elem_num = 0;
var project = el.attr('data-project'); if (elem.length > bg_counter_elements) {
if (project == "") request = bg_counter.counterurl; elem.each (function () {
else { if (elem_num >= bg_counter_elements) {
if (project) project = '/project/'+project; var el = jQuery(this);
else project = bg_counter.project; var type = el.attr('data-type');
var id = el.attr('data-ID');
if (!type || !id) var request = bg_counter.counterurl+project; var project = el.attr('data-project');
else var request = bg_counter.counterurl+project+"/"+type+"/"+id; if (project == "") request = bg_counter.counterurl;
else {
} if (project) project = '/project/'+project;
var xhr = new XMLHttpRequest(); else project = bg_counter.project;
xhr.open("GET", request, true);
xhr.onreadystatechange = function() { if (!type || !id) var request = bg_counter.counterurl+project;
if (xhr.readyState == 4 && xhr.status == 200) { else var request = bg_counter.counterurl+project+"/"+type+"/"+id;
if (xhr.responseText) {
var response = JSON.parse(xhr.responseText); }
if (response.success) { var xhr = new XMLHttpRequest();
if (bg_counter.debug) console.log('GET REQUEST: '+request); xhr.open("GET", request, true);
if (bg_counter.debug) console.log(JSON.stringify(response.data)); xhr.onreadystatechange = function() {
el.find('span.bg-az-counter-views').text(bg_counter_number_format(response.data.total)); if (xhr.readyState != 4) return;
el.find('span.bg-az-counter-now').text(addDelimiter(response.data.now)); if (xhr.status == 200) {
if (xhr.responseText) {
var response = JSON.parse(xhr.responseText);
if (response.success) {
if (bg_counter.debug) console.log('GET REQUEST: '+request);
if (bg_counter.debug) console.log(JSON.stringify(response.data));
el.find('span.bg-az-counter-views').text(bg_counter_number_format(response.data.total));
el.find('span.bg-az-counter-now').text(addDelimiter(response.data.now));
} else {
if (bg_counter.debug) console.log('GET REQUEST: '+request+' ERROR '+xhr.status+': '+response.error);
el.find('span.bg-az-counter-views').text('0');
el.find('span.bg-az-counter-now').text('0');
}
} else {
if (bg_counter.debug) console.warn('GET REQUEST: '+request+' Warning: responseText is empty!');
el.find('span.bg-az-counter-views').text(' - ');
el.find('span.bg-az-counter-now').text(' - ');
}
} else { } else {
if (bg_counter.debug) console.log('GET REQUEST: '+request+' ERROR '+xhr.status+': '+response.error); if (bg_counter.debug) console.warn('ERROR '+xhr.status+': '+xhr.statusText);
el.find('span.bg-az-counter-views').text('0'); el.find('span.bg-az-counter-views').text('-');
el.find('span.bg-az-counter-now').text('0'); el.find('span.bg-az-counter-now').text('-');
} }
} else { }
if (bg_counter.debug) console.warn('GET REQUEST: '+request+' Warning: responseText is empty!'); xhr.onerror = function(err) {
console.warn(err.type +" "+ err.target.status + ". Check if the server is running!");
el.find('span.bg-az-counter-views').text(' - '); el.find('span.bg-az-counter-views').text(' - ');
el.find('span.bg-az-counter-now').text(' - '); el.find('span.bg-az-counter-now').text(' - ');
} }
xhr.send();
} }
} elem_num++;
xhr.onerror = function(err) { });
console.warn(err.type +" "+ err.target.status + ". Check if the server is running!"); bg_counter_elements = elem.length;
el.find('span.bg-az-counter-views').text(' - '); }
el.find('span.bg-az-counter-now').text(' - ');
}
xhr.send();
});
} }
/********************************************************************************* /*********************************************************************************
Отображает значения счетчика на странице Отображает значения счетчика на странице
...@@ -280,22 +307,3 @@ function bg_counter_number_format (num) { ...@@ -280,22 +307,3 @@ function bg_counter_number_format (num) {
return num; return num;
} }
/*********************************************************************************
Обновляет счетчики после прокрутки страницы,
если добавлены элементы.
**********************************************************************************/
function bg_counter_elements_reloaded_on_scroll() {
jQuery(window).on('scroll', function() {
var elem = jQuery('span.bg-az-counter');
if( typeof elem == 'undefined' ) {
return;
}
if (elem.length > bg_counter_elements) {
bg_counter_elements = elem.length;
GetAllCounters();
// getAllRates();
}
});
}
...@@ -6,43 +6,51 @@ var bg_counter_ratings = 0; ...@@ -6,43 +6,51 @@ var bg_counter_ratings = 0;
jQuery( document ).ready(function() { jQuery( document ).ready(function() {
// Обновлять рейтинги каждые 3 сек, если добавлены элементы.
let timerAllRatesId = setTimeout(function tickAllRates() {
getAllRates();
timerAllRatesId = setTimeout(tickAllRates, bg_counter.updatetime?bg_counter.updatetime:3000);
}, bg_counter.updatetime?bg_counter.updatetime:3000);
// Обновлять рейтинги после прокрутки страницы, если добавлены элементы.
// jQuery(window).on('scroll', function() {
// getAllRates(); // getAllRates();
bg_counter_ratings_reloaded_on_scroll(); // });
if (!bg_counter.ID) return; // У объекта нет ID
if (jQuery("div").is(".bg_counter_rating") == false) return; // На странице нет счетчика if (!bg_counter.ID) return; // У объекта нет ID
if (jQuery("div").is(".bg_counter_rating") == false) return; // На странице нет счетчика
start_rate_index = parseFloat(jQuery( "#bg_counter_score" ).html());
rating_voted = (jQuery( "#bg_counter_score" ).attr("data-voted")=='true')?true:false; start_rate_index = parseFloat(jQuery( "#bg_counter_score" ).html());
iniRatingState(start_rate_index, rating_voted); rating_voted = (jQuery( "#bg_counter_score" ).attr("data-voted")=='true')?true:false;
iniRatingState(start_rate_index, rating_voted);
getRate(bg_counter.type, bg_counter.ID);
getRate(bg_counter.type, bg_counter.ID);
jQuery( "#bg_counter_rate_box li" ).mouseover(function() {
if(!rating_voted){ jQuery( "#bg_counter_rate_box li" ).mouseover(function() {
var index = jQuery( this ).index(); if(!rating_voted){
iniRatingState(index+1, rating_voted); var index = jQuery( this ).index();
jQuery('#bg_counter_popup_help').text(bg_counter.price[index]); iniRatingState(index+1, rating_voted);
} else { jQuery('#bg_counter_popup_help').text(bg_counter.price[index]);
jQuery('#bg_counter_popup_help').text(bg_counter.voted); } else {
} jQuery('#bg_counter_popup_help').text(bg_counter.voted);
jQuery('#bg_counter_popup_help').show(); }
}); jQuery('#bg_counter_popup_help').show();
});
jQuery( "#bg_counter_rate_box" ).mouseout(function() { jQuery( "#bg_counter_rate_box" ).mouseout(function() {
if(!rating_voted){ if(!rating_voted){
iniRatingState(start_rate_index, rating_voted); iniRatingState(start_rate_index, rating_voted);
} }
jQuery('#bg_counter_popup_help').hide(); jQuery('#bg_counter_popup_help').hide();
}); });
jQuery( "#bg_counter_rate_box li" ).click(function() { jQuery( "#bg_counter_rate_box li" ).click(function() {
if(!rating_voted){ if(!rating_voted){
rating_voted = true; rating_voted = true;
jQuery( "#bg_counter_rate_box li" ).css('cursor', 'default'); jQuery( "#bg_counter_rate_box li" ).css('cursor', 'default');
var sindex = jQuery( this ).index()+1; var sindex = jQuery( this ).index()+1;
sendRate(bg_counter.type, bg_counter.ID, sindex); sendRate(bg_counter.type, bg_counter.ID, sindex);
} }
}); });
}); });
function iniRatingState(sindex, voted){ function iniRatingState(sindex, voted){
if(!voted) jQuery( "#bg_counter_rate_box li" ).css('cursor', 'pointer'); if(!voted) jQuery( "#bg_counter_rate_box li" ).css('cursor', 'pointer');
...@@ -130,41 +138,51 @@ function getRate(type, id) { ...@@ -130,41 +138,51 @@ function getRate(type, id) {
function getAllRates() { function getAllRates() {
jQuery('span.bg-az-counter').each (function () { var elem = jQuery('span.bg-az-counter');
var el = jQuery(this);
// bg_counter_ratings = el.length; if( typeof elem == 'undefined' ) {
var type = el.attr('data-type'); return;
var id = el.attr('data-ID'); }
var project = el.attr('data-project'); if (elem.length > bg_counter_ratings) {
if (project) project = '/project/'+project; bg_counter_ratings = elem.length;
else project = bg_counter.project; jQuery('span.bg-az-counter').each (function () {
var el = jQuery(this);
if (!type || !id) return; var type = el.attr('data-type');
var request = bg_counter.scoreurl+bg_counter.project+"/"+type+"/"+id; var id = el.attr('data-ID');
var xhr = new XMLHttpRequest(); var project = el.attr('data-project');
xhr.open("GET", request, true); if (project) project = '/project/'+project;
if (bg_counter.debug) console.log('GET REQUEST: '+request); else project = bg_counter.project;
xhr.onreadystatechange = function() {
if (xhr.readyState == 4 && xhr.status == 200) { if (!type || !id) return;
if (xhr.responseText) { var request = bg_counter.scoreurl+bg_counter.project+"/"+type+"/"+id;
var response = JSON.parse(xhr.responseText); var xhr = new XMLHttpRequest();
if (response.success) { xhr.open("GET", request, true);
// Вывод данных на экран if (bg_counter.debug) console.log('GET REQUEST: '+request);
if (bg_counter.debug) console.log(JSON.stringify(response.data)); xhr.onreadystatechange = function() {
el.find('span.bg-az-counter-score').text(parseFloat(response.data.score).toFixed(1)); if (xhr.readyState != 4) return;
if (xhr.status == 200) {
if (xhr.responseText) {
var response = JSON.parse(xhr.responseText);
if (response.success) {
// Вывод данных на экран
if (bg_counter.debug) console.log(JSON.stringify(response.data));
el.find('span.bg-az-counter-score').text(parseFloat(response.data.score).toFixed(1));
} else {
if (bg_counter.debug) console.log('GET REQUEST: '+request+' ERROR: '+response.error);
el.find('span.bg-az-counter-score').text('0');
}
} else { } else {
if (bg_counter.debug) console.log('GET REQUEST: '+request+' ERROR: '+response.error); if (bg_counter.debug) console.warn('GET REQUEST: '+request+' Warning: responseText is empty!');
el.find('span.bg-az-counter-score').text('0'); el.find('span.bg-az-counter-score').text(' - ');
} }
} else { } else {
if (bg_counter.debug) console.warn('GET REQUEST: '+request+' Warning: responseText is empty!'); if (bg_counter.debug) console.warn('ERROR '+xhr.status+': '+xhr.statusText);
el.find('span.bg-az-counter-score').text(' - '); el.find('span.bg-az-counter-score').text('-');
} }
} }
} xhr.send();
xhr.send(); });
}); }
} }
...@@ -226,21 +244,3 @@ function sendRate(type, id, number) { ...@@ -226,21 +244,3 @@ function sendRate(type, id, number) {
xhr.send('{"rating": '+number+'}'); xhr.send('{"rating": '+number+'}');
} }
/*********************************************************************************
Обновляет рейтинги после прокрутки страницы,
если добавлены элементы.
**********************************************************************************/
function bg_counter_ratings_reloaded_on_scroll() {
jQuery(window).on('scroll', function() {
var elem = jQuery('span.bg-az-counter');
if( typeof elem == 'undefined' ) {
return;
}
if (elem.length > bg_counter_ratings) {
bg_counter_ratings = elem.length;
getAllRates();
}
});
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment