zoneminder/web/skins/classic/views/js/console.js

221 lines
5.9 KiB
JavaScript
Raw Normal View History

2020-08-22 09:44:20 +08:00
function thumbnail_onmouseover(event) {
var img = event.target;
img.src = '';
img.src = img.getAttribute('stream_src');
}
function thumbnail_onmouseout(event) {
var img = event.target;
img.src = '';
img.src = img.getAttribute('still_src');
}
function initThumbAnimation() {
$j('.colThumbnail img').each(function() {
this.addEventListener('mouseover', thumbnail_onmouseover, false);
this.addEventListener('mouseout', thumbnail_onmouseout, false);
});
}
2016-04-15 01:53:10 +08:00
2017-05-19 01:50:56 +08:00
function setButtonStates( element ) {
var form = element.form;
var checked = 0;
for ( var i=0; i < form.elements.length; i++ ) {
if (
2020-09-04 22:02:43 +08:00
form.elements[i].type=="checkbox" &&
form.elements[i].name=="markMids[]"
) {
var tr = $j(form.elements[i]).closest("tr");
if ( form.elements[i].checked ) {
checked ++;
tr.addClass("danger");
} else {
tr.removeClass("danger");
}
}
2017-05-19 01:50:56 +08:00
}
if ( checked ) {
form.editBtn.disabled = false;
form.deleteBtn.disabled = false;
2018-04-04 01:36:58 +08:00
form.selectBtn.disabled = false;
if ( checked == 1 ) {
$j(form.cloneBtn).css('display', 'inline');
} else {
form.cloneBtn.hide();
}
} else {
form.cloneBtn.hide();
form.editBtn.disabled = true;
form.deleteBtn.disabled = true;
2018-04-04 01:36:58 +08:00
form.selectBtn.disabled = true;
}
}
2017-10-27 09:56:10 +08:00
function addMonitor(element) {
window.location.assign('?view=monitor');
}
function cloneMonitor(element) {
2017-05-19 01:50:56 +08:00
var form = element.form;
var monitorId=-1;
// get the value of the first checkbox
for ( var i = 0; i < form.elements.length; i++ ) {
if (
2020-09-04 22:02:43 +08:00
form.elements[i].type == "checkbox" &&
form.elements[i].name == "markMids[]" &&
form.elements[i].checked
) {
monitorId = form.elements[i].value;
break;
}
} // end foreach element
if ( monitorId != -1 ) {
window.location.assign('?view=monitor&dupId='+monitorId);
}
2016-04-15 01:53:10 +08:00
}
2017-05-19 01:50:56 +08:00
function editMonitor( element ) {
var form = element.form;
var monitorIds = Array();
2017-05-19 01:50:56 +08:00
for ( var i = 0; i < form.elements.length; i++ ) {
if (
2020-09-04 22:02:43 +08:00
form.elements[i].type == "checkbox" &&
form.elements[i].name == "markMids[]" &&
form.elements[i].checked
) {
monitorIds.push( form.elements[i].value );
//form.elements[i].checked = false;
//setButtonStates( form.elements[i] );
//$(form.elements[i]).getParent( 'tr' ).removeClass( 'highlight' );
//break;
}
} // end foreach checkboxes
if ( monitorIds.length == 1 ) {
window.location.assign('?view=monitor&mid='+monitorIds[0]);
} else if ( monitorIds.length > 1 ) {
window.location.assign( '?view=monitors&'+(monitorIds.map(function(mid) {
return 'mids[]='+mid;
}).join('&')));
}
}
2017-05-19 01:50:56 +08:00
function deleteMonitor( element ) {
if ( confirm( 'Warning, deleting a monitor also deletes all events and database entries associated with it.\nAre you sure you wish to delete?' ) ) {
var form = element.form;
form.elements['action'].value = 'delete';
form.submit();
}
}
2018-04-04 01:36:58 +08:00
function selectMonitor(element) {
var form = element.form;
var url = thisUrl+'?view=console';
for ( var i = 0; i < form.elements.length; i++ ) {
if (
2020-09-04 22:02:43 +08:00
form.elements[i].type == 'checkbox' &&
form.elements[i].name == 'markMids[]' &&
2019-12-03 03:18:27 +08:00
form.elements[i].checked
) {
url += '&MonitorId[]='+form.elements[i].value;
2018-04-04 01:36:58 +08:00
}
}
window.location.replace(url);
}
2017-05-19 01:50:56 +08:00
function reloadWindow() {
window.location.replace( thisUrl );
}
2020-09-19 23:18:59 +08:00
// Manage the the Function modal and its buttons
function manageFunctionModal() {
$j('.functionLnk').click(function(evt) {
evt.preventDefault();
if ( !canEditEvents ) {
enoperm();
return;
}
var mid = evt.currentTarget.getAttribute('data-mid');
monitor = monitors[mid];
if ( !monitor ) {
console.error("No monitor found for mid " + mid);
return;
}
var function_form = document.getElementById('function_form');
if ( !function_form ) {
console.error("Unable to find form with id function_form");
return;
}
function_form.elements['newFunction'].value = monitor.Function;
function_form.elements['newEnabled'].checked = monitor.Enabled == '1';
function_form.elements['mid'].value = mid;
2020-09-04 22:02:43 +08:00
document.getElementById('function_monitor_name').innerHTML = monitor.Name;
$j('#modalFunction').modal('show');
});
2020-09-19 23:18:59 +08:00
2020-08-27 00:39:48 +08:00
// Manage the CANCEL modal buttons
$j('.funcCancelBtn').click(function(evt) {
evt.preventDefault();
$j('#modalFunction').modal('hide');
2020-08-27 00:39:48 +08:00
});
// Manage the SAVE modal buttons
$j('.funcSaveBtn').click(function(evt) {
evt.preventDefault();
2020-09-19 23:18:59 +08:00
$j('#function_form').submit();
});
}
function initPage() {
reloadWindow.periodical(consoleRefreshTimeout);
if ( showDonatePopup ) {
$j.getJSON(thisUrl + '?request=modal&modal=donate')
.done(function(data) {
2020-10-15 04:58:39 +08:00
insertModalHtml('donate', data.html);
2020-09-19 23:18:59 +08:00
$j('#donate').modal('show');
// Manage the Apply button
$j('#donateApplyBtn').click(function(evt) {
evt.preventDefault();
$j('#donateForm').submit();
});
})
.fail(logAjaxFail);
2020-09-19 23:18:59 +08:00
}
// Makes table sortable
$j( function() {
$j( "#consoleTableBody" ).sortable({
handle: ".sort",
update: applySort,
axis: 'Y'} );
$j( "#consoleTableBody" ).disableSelection();
} );
// Setup the thumbnail video animation
initThumbAnimation();
// Load the Function modal on page load
$j.getJSON(thisUrl + '?request=modal&modal=function')
.done(function(data) {
2020-10-15 04:58:39 +08:00
insertModalHtml('modalFunction', data.html);
2020-09-19 23:18:59 +08:00
// Manage the Function modal
manageFunctionModal();
})
.fail(logAjaxFail);
}
2017-01-23 23:12:57 +08:00
function applySort(event, ui) {
var monitor_ids = $j(this).sortable('toArray');
var ajax = new Request.JSON( {
url: 'index.php?request=console',
data: {monitor_ids: monitor_ids, action: 'sort'},
method: 'post',
timeout: AJAX_TIMEOUT
} );
2017-01-23 23:12:57 +08:00
ajax.send();
} // end function applySort(event,ui)
$j(document).ready(initPage );