From db77376422d25546246faddec45108194aaf2803 Mon Sep 17 00:00:00 2001 From: Oliver Gorwits Date: Sun, 19 Feb 2012 18:03:06 +0000 Subject: [PATCH] github issue #9 - strikethrough remains on tab change --- Netdisco/public/javascripts/netdisco.js | 2 +- Netdisco/views/js/search.js | 48 +++++++++++++++---------- 2 files changed, 30 insertions(+), 20 deletions(-) diff --git a/Netdisco/public/javascripts/netdisco.js b/Netdisco/public/javascripts/netdisco.js index 76cffdeb..a81648ae 100644 --- a/Netdisco/public/javascripts/netdisco.js +++ b/Netdisco/public/javascripts/netdisco.js @@ -64,7 +64,7 @@ function do_search (event, tab) { ); } - inner_view_processing(); + inner_view_processing(tab); } ); } diff --git a/Netdisco/views/js/search.js b/Netdisco/views/js/search.js index 73777f06..a37697dc 100644 --- a/Netdisco/views/js/search.js +++ b/Netdisco/views/js/search.js @@ -1,30 +1,40 @@ - // this is called by do_search to support local code - function inner_view_processing() {} - // used by the tabbing interface to make sure the correct // ajax content is loaded var path = 'search'; - $(document).ready(function() { - // highlight active search filters in green. - // strikethrough the navbar search if using device_form instead. + // fields in the Device Search Options form (Device tab) + var d_inputs = $("#device_form .clearfix input").not('[type="checkbox"]') + .add("#device_form .clearfix select"); - var d_inputs = $("#device_form .clearfix input").not('[type="checkbox"]') - .add("#device_form .clearfix select"); - - function device_form_state(e) { - if (e.is('[value!=""]')) { - e.parent(".clearfix").addClass('success'); - $('#nq').css('text-decoration', 'line-through'); - } - else { - e.parent(".clearfix").removeClass('success'); - if (! d_inputs.is('[value!=""]') ) { - $('#nq').css('text-decoration', 'none'); - } + // if any field in Device Search Options has content, highlight in green + // and strikethrough the navbar search + function device_form_state(e) { + if (e.is('[value!=""]')) { + e.parent(".clearfix").addClass('success'); + $('#nq').css('text-decoration', 'line-through'); + } + else { + e.parent(".clearfix").removeClass('success'); + if (! d_inputs.is('[value!=""]') ) { + $('#nq').css('text-decoration', 'none'); } } + } + // this is called by do_search to support local code + // here, when tab changes need to strike/unstrike the navbar search + function inner_view_processing(tab) { + if (tab == 'device') { + d_inputs.each(function() {device_form_state($(this))}); + } + else { + $('#nq').css('text-decoration', 'none'); + } + } + + // on load, check initial Device Search Options form state, + // and on each change to the form fields + $(document).ready(function() { d_inputs.each(function() {device_form_state($(this))}); d_inputs.change(function() {device_form_state($(this))}); });