autohide frame stats when out of pixels
parent
1ea4ee6ef1
commit
08d640a06c
|
@ -1,4 +1,6 @@
|
||||||
|
var table = $j('#frameStatsTable');
|
||||||
var backBtn = $j('#backBtn');
|
var backBtn = $j('#backBtn');
|
||||||
|
var statsBtn = $j('#statsBtn');
|
||||||
|
|
||||||
function changeScale() {
|
function changeScale() {
|
||||||
var scale = $j('#scale').val();
|
var scale = $j('#scale').val();
|
||||||
|
@ -32,6 +34,20 @@ function changeScale() {
|
||||||
anchor.prop('href', anchor.prop('href').replace(/scale=.*&/, 'scale=' + scale + '&'));
|
anchor.prop('href', anchor.prop('href').replace(/scale=.*&/, 'scale=' + scale + '&'));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// After a resize, check if we still have room to display the event stats table
|
||||||
|
onStatsResize(newWidth);
|
||||||
|
}
|
||||||
|
|
||||||
|
function getFrmStatsCookie() {
|
||||||
|
var cookie = 'zmFrameStats';
|
||||||
|
var stats = getCookie(cookie);
|
||||||
|
|
||||||
|
if ( !stats ) {
|
||||||
|
stats = 'on';
|
||||||
|
setCookie(cookie, stats, 10*365);
|
||||||
|
}
|
||||||
|
return stats;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getStat(params) {
|
function getStat(params) {
|
||||||
|
@ -42,8 +58,20 @@ function getStat(params) {
|
||||||
$j('#frameStatsTable').empty().append('<tbody>');
|
$j('#frameStatsTable').empty().append('<tbody>');
|
||||||
$j.each( statHeaderStrings, function( key ) {
|
$j.each( statHeaderStrings, function( key ) {
|
||||||
var th = $j('<th>').addClass('text-right').text(statHeaderStrings[key]);
|
var th = $j('<th>').addClass('text-right').text(statHeaderStrings[key]);
|
||||||
var tdString = ( stat ) ? stat[key] : 'n/a';
|
var tdString;
|
||||||
var td = $j('<td>').text(tdString);
|
|
||||||
|
switch (stat ? key : 'n/a') {
|
||||||
|
case 'FrameId':
|
||||||
|
tdString = '<a href="?view=stats&eid=' + params.eid + '&fid=' + params.fid + '">' + stat[key] + '</a>';
|
||||||
|
break;
|
||||||
|
case 'n/a':
|
||||||
|
tdString = 'n/a';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
tdString = stat[key];
|
||||||
|
}
|
||||||
|
|
||||||
|
var td = $j('<td>').html(tdString);
|
||||||
var row = $j('<tr>').append(th, td);
|
var row = $j('<tr>').append(th, td);
|
||||||
|
|
||||||
$j('#frameStatsTable tbody').append(row);
|
$j('#frameStatsTable tbody').append(row);
|
||||||
|
@ -52,6 +80,27 @@ function getStat(params) {
|
||||||
.fail(logAjaxFail);
|
.fail(logAjaxFail);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function onStatsResize(vidwidth) {
|
||||||
|
var minWidth = 300; // An arbitrary value in pixels used to hide the stats table
|
||||||
|
var width = $j(window).width() - vidwidth;
|
||||||
|
|
||||||
|
// Hide the stats table if we have run out of room to show it properly
|
||||||
|
if ( width < minWidth ) {
|
||||||
|
statsBtn.prop('disabled', true);
|
||||||
|
if ( table.is(':visible') ) {
|
||||||
|
table.toggle(false);
|
||||||
|
wasHidden = true;
|
||||||
|
}
|
||||||
|
// Show the stats table if we hid it previously and sufficient room becomes available
|
||||||
|
} else if ( width >= minWidth ) {
|
||||||
|
statsBtn.prop('disabled', false);
|
||||||
|
if ( !table.is(':visible') && wasHidden ) {
|
||||||
|
table.toggle(true);
|
||||||
|
wasHidden = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function initPage() {
|
function initPage() {
|
||||||
if ( scale == '0' || scale == 'auto' ) changeScale();
|
if ( scale == '0' || scale == 'auto' ) changeScale();
|
||||||
|
|
||||||
|
@ -70,14 +119,29 @@ function initPage() {
|
||||||
window.location.reload(true);
|
window.location.reload(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Manage the STATS button
|
// Manage the Frame STATISTICS Button
|
||||||
document.getElementById("statsBtn").addEventListener("click", function onViewClick(evt) {
|
document.getElementById("statsBtn").addEventListener("click", function onStatsClick(evt) {
|
||||||
evt.preventDefault();
|
evt.preventDefault();
|
||||||
window.location.href = thisUrl+'?view=stats&eid='+eid+'&fid='+fid;
|
var cookie = 'zmFrameStats';
|
||||||
|
|
||||||
|
// Toggle the visiblity of the stats table and write an appropriate cookie
|
||||||
|
if ( table.is(':visible') ) {
|
||||||
|
setCookie(cookie, 'off', 10*365);
|
||||||
|
table.toggle(false);
|
||||||
|
} else {
|
||||||
|
setCookie(cookie, 'on', 10*365);
|
||||||
|
table.toggle(true);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Load the frame stats
|
// Load the frame stats
|
||||||
getStat({eid: eid, fid: fid});
|
getStat({eid: eid, fid: fid});
|
||||||
|
|
||||||
|
if ( getFrmStatsCookie() != 'on' ) {
|
||||||
|
table.toggle(false);
|
||||||
|
} else {
|
||||||
|
onStatsResize($j('#base_width').val() * scale / SCALE_BASE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Kick everything off
|
// Kick everything off
|
||||||
|
|
|
@ -14,14 +14,16 @@ var fid = <?php echo $fid ?>;
|
||||||
var record_event_stats = <?php echo ZM_RECORD_EVENT_STATS ?>;
|
var record_event_stats = <?php echo ZM_RECORD_EVENT_STATS ?>;
|
||||||
var alarmFrame = <?php echo $alarmFrame ?>;
|
var alarmFrame = <?php echo $alarmFrame ?>;
|
||||||
|
|
||||||
var statHeaderStrings = {};
|
var statHeaderStrings = {
|
||||||
statHeaderStrings.ZoneName = "<?php echo translate('Zone') ?>";
|
Id: '<?php echo translate('EventId') ?>',
|
||||||
statHeaderStrings.PixelDiff = "<?php echo translate('PixelDiff') ?>";
|
FrameId: '<?php echo translate('FrameId') ?>',
|
||||||
statHeaderStrings.AlarmPixels = "<?php echo translate('AlarmPx') ?>";
|
ZoneName: '<?php echo translate('Zone') ?>',
|
||||||
statHeaderStrings.FilterPixels = "<?php echo translate('FilterPx') ?>";
|
PixelDiff: '<?php echo translate('PixelDiff') ?>',
|
||||||
statHeaderStrings.BlobPixels = "<?php echo translate('BlobPx') ?>";
|
AlarmPixels: '<?php echo translate('AlarmPx') ?>',
|
||||||
statHeaderStrings.Blobs = "<?php echo translate('Blobs') ?>";
|
FilterPixels: '<?php echo translate('FilterPx') ?>',
|
||||||
statHeaderStrings.BlobSizes = "<?php echo translate('BlobSizes') ?>";
|
BlobPixels: '<?php echo translate('BlobPx') ?>',
|
||||||
statHeaderStrings.AlarmLimits = "<?php echo translate('AlarmLimits') ?>";
|
Blobs: '<?php echo translate('Blobs') ?>',
|
||||||
statHeaderStrings.Score = "<?php echo translate('Score') ?>";
|
BlobSizes: '<?php echo translate('BlobSizes') ?>',
|
||||||
|
AlarmLimits: '<?php echo translate('AlarmLimits') ?>',
|
||||||
|
Score: '<?php echo translate('Score') ?>'
|
||||||
|
};
|
||||||
|
|
Loading…
Reference in New Issue