From 91f6ff43847e3f68d5b4602522158923e6ec0575 Mon Sep 17 00:00:00 2001 From: Nathan Gray Date: Tue, 20 Mar 2012 17:47:00 +0000 Subject: [PATCH] Override nm header input widgets' onChange to update nm filters, and if original change returned true, refresh inm data --- etemplate/js/et2_extension_nextmatch.js | 31 ++++++++++++++++++------- 1 file changed, 23 insertions(+), 8 deletions(-) diff --git a/etemplate/js/et2_extension_nextmatch.js b/etemplate/js/et2_extension_nextmatch.js index 449310ebb0..06f62b58e3 100644 --- a/etemplate/js/et2_extension_nextmatch.js +++ b/etemplate/js/et2_extension_nextmatch.js @@ -888,8 +888,26 @@ var et2_nextmatch_header_bar = et2_DOMWidget.extend(et2_INextmatchHeader, { var header = et2_createWidget("template", {"id": headers[i]}, this); jQuery(header.getDOMNode()).addClass(i == 0 ? "et2_hbox_left":"et2_hbox_right").addClass("nm_header"); this.headers.push(header); + + // Bind onChange to update filter, and refresh if needed + header.iterateOver(function(_widget) { + // Previously set change function + var widget_change = _widget.change; + _widget.change = function(_node) { + // Call previously set change function + var result = widget_change.call(_widget,_node); + + // Update filters + var old = self.nextmatch.activeFilters[_widget.id]; + self.nextmatch.activeFilters[_widget.id] = _widget.getValue(); + + if(result && old != _widget.getValue()) { + // Filter now + self.nextmatch.applyFilters(); + } + } + }, this, et2_inputWidget); } - // TODO: Bind onChange to update filter, and refresh if needed } } @@ -1020,13 +1038,10 @@ var et2_nextmatch_header_bar = et2_DOMWidget.extend(et2_INextmatchHeader, { // Connect it to the onchange event of the input element input.change(this.nextmatch, et2_compileLegacyJS(onchange, this.nextmatch, input)); } - else - { - input.change(this.nextmatch, function(event) { - event.data.activeFilters[name] = input.val() - event.data.applyFilters(); - }); - } + input.change(this.nextmatch, function(event) { + event.data.activeFilters[name] = input.val() + event.data.applyFilters(); + }); return select; },