The reason for this is that DataTables keys local data on the page path, so each tab should have its own path. We're already doing this for reports and admin tasks, so it also makes sense to have consistency with search and device tabs. Squashed commit of the following: commit 4ad33a23a81122496adfe561ad14f039e6255eff Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:46:17 2014 +0100 fix search preference selection commit 363e094935d386961e8773f787af41c46b83129a Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:36:45 2014 +0100 fix css selector to match begins with /search commit 43c972ee0d9401f74dcc3bd30052dba130b0d068 Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:18:24 2014 +0100 fix history push commit 84f83eb46874b0222c0484014389713e4f027c8a Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:06:44 2014 +0100 update sidebar form for tab-path, remove hidden tab name field commit 344d4679a83f714c998cd475c041f8effab0c696 Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:05:49 2014 +0100 update template links for tab path commit 9cf370d7eb4413aac6fc19c2c13a9bf670600965 Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:04:57 2014 +0100 move tab-specific JS from common into specific includes files commit c2d8592a18e389535368d1e74fed29fe5a0eabd8 Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:02:46 2014 +0100 fix mode commit 52487cea47eaaea7f5c74536ad6d4bb2a8d6ba4c Author: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 14:01:15 2014 +0100 move from tab param to tabname template var commit b5a2424631a0050d5de3bc658746a40cd822e869 Merge:531782bd8102bfAuthor: Oliver Gorwits <oliver@cpan.org> Date: Sat Oct 25 10:50:00 2014 +0100 Merge branch 'master' into em-device-ports-json
190 lines
5.8 KiB
JavaScript
190 lines
5.8 KiB
JavaScript
// used by the tabbing interface to make sure the correct
|
|
// ajax content is loaded
|
|
var path = 'admin';
|
|
|
|
// keep track of timers so we can kill them
|
|
var nd_timers = new Array();
|
|
var timermax = [% settings.jobqueue_refresh || 5 | html_entity %];
|
|
var timercache = timermax - 1;
|
|
|
|
// this is called by do_search to support local code
|
|
// which might need to act on the newly inserted content
|
|
// but which cannot use jQuery delegation via .on()
|
|
function inner_view_processing(tab) {
|
|
|
|
// reload this table every 5 seconds
|
|
if (tab == 'jobqueue'
|
|
&& $('#nd_countdown-control-icon').hasClass('icon-play')) {
|
|
|
|
$('#nd_countdown').text(timermax);
|
|
|
|
// add new timers
|
|
for (var i = timercache; i > 0; i--) {
|
|
nd_timers.push(setTimeout(function() {
|
|
$('#nd_countdown').text(timercache);
|
|
timercache = timercache - 1;
|
|
}, ((timermax * 1000) - (i * 1000)) ));
|
|
}
|
|
|
|
nd_timers.push(setTimeout(function() {
|
|
// clear any running timers
|
|
for (var i = 0; i < nd_timers.length; i++) {
|
|
clearTimeout(nd_timers[i]);
|
|
}
|
|
|
|
// reset the timer cache
|
|
timercache = timermax - 1;
|
|
|
|
// reload the tab content in...
|
|
$('#' + tab + '_form').trigger('submit');
|
|
}, (timermax * 1000)));
|
|
}
|
|
|
|
// activate typeahead on the topo boxes
|
|
$('.nd_topo_dev').autocomplete({
|
|
source: uri_base + '/ajax/data/deviceip/typeahead'
|
|
,delay: 150
|
|
,minLength: 0
|
|
});
|
|
|
|
// activate typeahead on the topo boxes
|
|
$('.nd_topo_port.nd_topo_dev1').autocomplete({
|
|
source: function (request, response) {
|
|
var query = $('.nd_topo_dev1').serialize();
|
|
return $.get( uri_base + '/ajax/data/port/typeahead', query, function (data) {
|
|
return response(data);
|
|
});
|
|
}
|
|
,delay: 150
|
|
,minLength: 0
|
|
});
|
|
|
|
// activate typeahead on the topo boxes
|
|
$('.nd_topo_port.nd_topo_dev2').autocomplete({
|
|
source: function (request, response) {
|
|
var query = $('.nd_topo_dev2').serialize();
|
|
return $.get( uri_base + '/ajax/data/port/typeahead', query, function (data) {
|
|
return response(data);
|
|
});
|
|
}
|
|
,delay: 150
|
|
,minLength: 0
|
|
});
|
|
|
|
// activate modals
|
|
$('.nd_modal').modal({show: false});
|
|
}
|
|
|
|
// on load, establish global delegations for now and future
|
|
$(document).ready(function() {
|
|
var tab = '[% task.tag %]'
|
|
var target = '#' + tab + '_pane';
|
|
|
|
// get all devices on device input focus
|
|
$(target).on('focus', '.nd_topo_dev', function(e) {
|
|
$(this).autocomplete('search', '%') });
|
|
$(target).on('click', '.nd_topo_dev_caret', function(e) {
|
|
$(this).siblings('.nd_topo_dev').autocomplete('search', '%') });
|
|
|
|
// get all ports on port input focus
|
|
$(target).on('focus', '.nd_topo_port', function(e) {
|
|
$(this).autocomplete('search') });
|
|
$(target).on('click', '.nd_topo_port_caret', function(e) {
|
|
$(this).siblings('.nd_topo_port').val('');
|
|
$(this).siblings('.nd_topo_port').autocomplete('search');
|
|
});
|
|
|
|
// job control refresh icon should reload the page
|
|
$('#nd_countdown-refresh').click(function(event) {
|
|
event.preventDefault();
|
|
for (var i = 0; i < nd_timers.length; i++) {
|
|
clearTimeout(nd_timers[i]);
|
|
}
|
|
$('#' + tab + '_form').trigger('submit');
|
|
});
|
|
|
|
// job control pause/play icon switcheroo
|
|
$('#nd_countdown-control').click(function(event) {
|
|
event.preventDefault();
|
|
var icon = $('#nd_countdown-control-icon');
|
|
icon.toggleClass('icon-pause icon-play text-error text-success');
|
|
|
|
if (icon.hasClass('icon-pause')) {
|
|
for (var i = 0; i < nd_timers.length; i++) {
|
|
clearTimeout(nd_timers[i]);
|
|
}
|
|
$('#nd_countdown').text('0');
|
|
}
|
|
else {
|
|
$('#' + tab + '_form').trigger('submit');
|
|
}
|
|
});
|
|
|
|
// activity for admin task tables
|
|
// dynamically bind to all forms in the table
|
|
$('.content').on('click', '.nd_adminbutton', function(event) {
|
|
// stop form from submitting normally
|
|
event.preventDefault();
|
|
|
|
// clear any running timers
|
|
for (var i = 0; i < nd_timers.length; i++) {
|
|
clearTimeout(nd_timers[i]);
|
|
}
|
|
|
|
// what purpose - add/update/del
|
|
var mode = $(this).attr('name');
|
|
|
|
// submit the query and put results into the tab pane
|
|
$.ajax({
|
|
type: 'POST'
|
|
,async: true
|
|
,dataType: 'html'
|
|
,url: uri_base + '/ajax/control/admin/' + tab + '/' + mode
|
|
,data: $(this).closest('tr').find('input[data-form="' + mode + '"]').serializeArray()
|
|
,beforeSend: function() {
|
|
$(target).html(
|
|
'<div class="span2 alert">Request submitted...</div>'
|
|
);
|
|
}
|
|
,success: function() {
|
|
$('#' + tab + '_form').trigger('submit');
|
|
}
|
|
// skip any error reporting for now
|
|
// TODO: fix sanity_ok in Netdisco Web
|
|
,error: function() {
|
|
$('#' + tab + '_form').trigger('submit');
|
|
}
|
|
});
|
|
});
|
|
|
|
// bind qtip2 to show the event log output
|
|
$(target).on('mouseover', '.nd_jobqueueitem', function(event) {
|
|
$(this).qtip({
|
|
overwrite: false,
|
|
content: {
|
|
attr: 'data-content'
|
|
},
|
|
show: {
|
|
event: event.type,
|
|
ready: true,
|
|
delay: 100
|
|
},
|
|
position: {
|
|
my: 'top center',
|
|
at: 'bottom center',
|
|
target: false
|
|
},
|
|
style: {
|
|
classes: 'qtip-cluetip qtip-rounded nd_qtip-unconstrained'
|
|
}
|
|
});
|
|
});
|
|
|
|
// for the admin pages
|
|
$('[% "#${task.tag}_form" %]').submit(function (event) {
|
|
update_page_title('[% task.tag %]');
|
|
update_csv_download_link('admin', '[% task.tag %]', '1');
|
|
do_search(event, '[% task.tag %]');
|
|
});
|
|
});
|