commitb054119d9cAuthor: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 17 14:29:58 2013 +0000 hide Reports menu if there are no reports commitd86e670600Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 17 14:23:59 2013 +0000 add Report docs for developers commitee8351eb30Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 17 14:06:39 2013 +0000 split Plugin docs into user and developer pages commit5e4b8f3063Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 17 12:59:47 2013 +0000 add duplex report into default config commit8fd622f50cAuthor: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 17 12:56:51 2013 +0000 update query for duplex mismatch to check left and right are both not DOWN commit6d9170598cAuthor: Oliver Gorwits <oliver@cpan.org> Date: Mon Mar 11 23:10:38 2013 +0000 use the new duplex mismatch query in a template commit786977354bAuthor: Oliver Gorwits <oliver@cpan.org> Date: Mon Mar 11 22:54:21 2013 +0000 add VIEW for duplex mismatches commitf37ae8568eAuthor: Oliver Gorwits <oliver@cpan.org> Date: Mon Mar 11 22:54:01 2013 +0000 remove unecessary assign commit13af853582Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 23:40:53 2013 +0000 fixes to main app to support reports commit55a0f3d8dcAuthor: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 22:18:48 2013 +0000 also update fontawesome to match bootstrap version commit83a2c74242Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 22:07:23 2013 +0000 update bootstrap again, to include glyphicons with correct path commit25be8bfa92Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 19:27:37 2013 +0000 implement first report - duplex mismatch - as a placeholder only commit00265a9323Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 18:41:40 2013 +0000 report error on failure to load a plugin commitaf8f124bb2Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 18:37:19 2013 +0000 change id for tag in device and search tab plugins commitb818d4156fAuthor: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 18:29:57 2013 +0000 change id for tag in navbar plugins commitf513000f08Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 17:21:23 2013 +0000 implement register_report() and replace More menu with Reports menu commit4a16e3fde3Author: Oliver Gorwits <oliver@cpan.org> Date: Sun Mar 10 17:00:44 2013 +0000 Upgraded to Twitter Bootstrap 2.3.1 - customized for 13px font 18px line
		
			
				
	
	
		
			221 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			221 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // parameterised for the active tab - submits search form and injects
 | |
| // HTML response into the tab pane, or an error/empty-results message
 | |
| function do_search (event, tab) {
 | |
|   var form = '#' + tab + '_form';
 | |
|   var target = '#' + tab + '_pane';
 | |
| 
 | |
|   // stop form from submitting normally
 | |
|   event.preventDefault();
 | |
| 
 | |
|   // page title
 | |
|   var pgtitle = 'Netdisco';
 | |
|   if ($('#nd_device_name').text().length) {
 | |
|     var pgtitle = $('#nd_device_name').text() +' - '+ $('#'+ tab + '_link').text();
 | |
|   }
 | |
| 
 | |
|   // each sidebar search form has a hidden copy of the main navbar search
 | |
|   // query. when the tab query takes place, copy the navbar locally, then
 | |
|   // replicate to all other tabs.
 | |
|   if ($('#nq').val()) {
 | |
|     $(form).find("input[name=q]").val( $('#nq').val() );
 | |
|   }
 | |
|   $('form').find("input[name=q]").each( function() {
 | |
|     $(this).val( $(form).find("input[name=q]").val() );
 | |
|   });
 | |
| 
 | |
|   // hide or show sidebars depending on previous state,
 | |
|   // and whether the sidebar contains any content (detected by TT)
 | |
|   if (has_sidebar[tab] == 0) {
 | |
|     $('.sidebar, #sidebar_toggle_img_out').hide();
 | |
|     $('.content').css('margin-right', '10px');
 | |
|   }
 | |
|   else {
 | |
|     if (sidebar_hidden) {
 | |
|       $('#sidebar_toggle_img_out').show();
 | |
|     }
 | |
|     else {
 | |
|       $('.content').css('margin-right', '215px');
 | |
|       $('.sidebar').show();
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   // get the form params
 | |
|   var query = $(form).serialize();
 | |
| 
 | |
|   // update browser search history with the new query.
 | |
|   // however if it's the same tab, this is a *replace* of the query url.
 | |
|   // and just skip this bit if it's the reports display.
 | |
|   if (path != 'report' && window.History && window.History.enabled) {
 | |
|     is_from_history_plugin = 1;
 | |
|     window.History.replaceState(
 | |
|       {name: tab, fields: $(form).serializeArray()},
 | |
|       pgtitle, uri_base + '/' + path + '?' + query
 | |
|     );
 | |
|     is_from_history_plugin = 0;
 | |
|   }
 | |
| 
 | |
|   // in case of slow data load, let the user know
 | |
|   $(target).html(
 | |
|     '<div class="span2 alert">Waiting for results...</div>'
 | |
|   );
 | |
| 
 | |
|   // submit the query and put results into the tab pane
 | |
|   $(target).load( uri_base + '/ajax/content/' + path + '/' + tab + '?' + query,
 | |
|     function(response, status, xhr) {
 | |
|       if (status !== "success") {
 | |
|         $(target).html(
 | |
|           '<div class="span5 alert alert-error">' +
 | |
|           'Search failed! Please contact your site administrator.</div>'
 | |
|         );
 | |
|         return;
 | |
|       }
 | |
|       if (response === "") {
 | |
|         $(target).html(
 | |
|           '<div class="span2 alert alert-info">No matching records.</div>'
 | |
|         );
 | |
|       }
 | |
| 
 | |
|       // delegate to any [device|search] specific JS code
 | |
|       inner_view_processing(tab);
 | |
|     }
 | |
|   );
 | |
| }
 | |
| 
 | |
| // keep track of which tabs have a sidebar, for when switching tab
 | |
| var has_sidebar = {};
 | |
| var sidebar_hidden = 0;
 | |
| 
 | |
| // the history.js plugin is great, but fires statechange at pushState
 | |
| // so we have these semaphpores to help avoid messing the History.
 | |
| 
 | |
| // set true when faking a user click on a tab
 | |
| var is_from_state_event = 0;
 | |
| // set true when the history plugin does pushState - to prevent loop
 | |
| var is_from_history_plugin = 0;
 | |
| 
 | |
| // on tab change, hide previous tab's search form and show new tab's
 | |
| // search form. also trigger to load the content for the newly active tab.
 | |
| function update_content(from, to) {
 | |
|   $('#' + from + '_search').toggleClass('active');
 | |
|   $('#' + to + '_search').toggleClass('active');
 | |
| 
 | |
|   var to_form = '#' + to + '_form';
 | |
|   var from_form = '#' + from + '_form';
 | |
| 
 | |
|   // page title
 | |
|   var pgtitle = 'Netdisco';
 | |
|   if ($('#nd_device_name').text().length) {
 | |
|     var pgtitle = $('#nd_device_name').text() +' - '+ $('#'+ to + '_link').text();
 | |
|   }
 | |
| 
 | |
|   if (window.History && window.History.enabled && is_from_state_event == 0) {
 | |
|     is_from_history_plugin = 1;
 | |
|     window.History.pushState(
 | |
|       {name: to, fields: $(to_form).serializeArray()},
 | |
|       pgtitle, uri_base + '/' + path + '?' + $(to_form).serialize()
 | |
|     );
 | |
|     is_from_history_plugin = 0;
 | |
|   }
 | |
| 
 | |
|   $(to_form).trigger("submit");
 | |
| }
 | |
| 
 | |
| // handler for ajax navigation
 | |
| if (window.History && window.History.enabled) {
 | |
|   var History = window.History;
 | |
|   History.Adapter.bind(window, "statechange", function() {
 | |
|     if (is_from_history_plugin == 0) {
 | |
|       is_from_state_event = 1;
 | |
|       var State = History.getState();
 | |
|       // History.log(State.data.name, State.title, State.url);
 | |
|       $('#'+ State.data.name + '_form').deserialize(State.data.fields);
 | |
|       $('#'+ State.data.name + '_link').click();
 | |
|       is_from_state_event = 0;
 | |
|     }
 | |
|   });
 | |
| }
 | |
| 
 | |
| $(document).ready(function() {
 | |
|   // activate typeahead on the main search box, for device names only
 | |
|   $('#nq').typeahead({
 | |
|     source: function (query, process) {
 | |
|       return $.get('/ajax/data/device/typeahead', { query: query }, function (data) {
 | |
|         return process(data);
 | |
|       });
 | |
|     }
 | |
|     ,matcher: function () { return true; } // trust backend
 | |
|     ,minLength: 3
 | |
|   });
 | |
| 
 | |
|   // activate tooltips
 | |
|   $("[rel=tooltip]").tooltip({live: true});
 | |
| 
 | |
|   // bind submission to the navbar go icon
 | |
|   $('#navsearchgo').click(function() {
 | |
|     $('#navsearchgo').parents('form').submit();
 | |
|   });
 | |
| 
 | |
|   // fix green background on search checkboxes
 | |
|   // https://github.com/twitter/bootstrap/issues/742
 | |
|   syncCheckBox = function() {
 | |
|     $(this).parents('.add-on').toggleClass('active', $(this).is(':checked'));
 | |
|   };
 | |
|   $('.add-on :checkbox').each(syncCheckBox).click(syncCheckBox);
 | |
| 
 | |
|   // sidebar toggle - pinning
 | |
|   $('.sidebar_pin').click(function() {
 | |
|     $('.sidebar').toggleClass('sidebar_pinned');
 | |
|     $('.sidebar_pin').toggleClass('sidebar_pin_clicked');
 | |
|     // update tooltip note for current state
 | |
|     if ($('.sidebar_pin').hasClass('sidebar_pin_clicked')) {
 | |
|       $('.sidebar_pin').first().data('tooltip').options.title = 'Unpin Sidebar';
 | |
|     }
 | |
|     else {
 | |
|       $('.sidebar_pin').first().data('tooltip').options.title = 'Pin Sidebar';
 | |
|     }
 | |
|   });
 | |
| 
 | |
|   // sidebar toggle - trigger in/out on image click()
 | |
|   $('#sidebar_toggle_img_in').click(function() {
 | |
|     $('.sidebar').toggle(250);
 | |
|     $('#sidebar_toggle_img_out').toggle();
 | |
|     $('.content').css('margin-right', '10px');
 | |
|     sidebar_hidden = 1;
 | |
|   });
 | |
|   $('#sidebar_toggle_img_out').click(function() {
 | |
|     $('#sidebar_toggle_img_out').toggle();
 | |
|     $('.content').css('margin-right', '215px');
 | |
|     $('.sidebar').toggle(250);
 | |
|     if (! $('.sidebar').hasClass('sidebar_pinned')) {
 | |
|         $(window).scrollTop(0);
 | |
|     }
 | |
|     sidebar_hidden = 0;
 | |
|   });
 | |
| 
 | |
|   // could not get twitter bootstrap tabs to behave, so implemented this
 | |
|   // but warning! will probably not work for dropdowns in tabs
 | |
|   $('#search_results li').delegate('a', 'click', function(event) {
 | |
|     event.preventDefault();
 | |
|     var from_li = $('.nav-tabs').find('> .active').first();
 | |
|     var to_li = $(this).parent('li')
 | |
| 
 | |
|     from_li.toggleClass('active');
 | |
|     to_li.toggleClass('active');
 | |
| 
 | |
|     var from_id = from_li.find('a').attr('href');
 | |
|     var to_id = $(this).attr('href');
 | |
| 
 | |
|     if (from_id == to_id) {
 | |
|       return;
 | |
|     }
 | |
| 
 | |
|     $(from_id).toggleClass('active');
 | |
|     $(to_id).toggleClass('active');
 | |
| 
 | |
|     update_content(
 | |
|       from_id.replace(/^#/,"").replace(/_pane$/,""),
 | |
|       to_id.replace(/^#/,"").replace(/_pane$/,"")
 | |
|     );
 | |
|   });
 | |
| });
 |