From 799a53be094e99b4285d6e5ce947e915b1f19750 Mon Sep 17 00:00:00 2001 From: Simon Rettberg Date: Mon, 12 Sep 2022 10:02:29 +0200 Subject: [eventlog] Improve sample data displaying when editing a filter rule --- .../eventlog/templates/page-filters-edit-rule.html | 43 +++++++++++++++------- 1 file changed, 29 insertions(+), 14 deletions(-) (limited to 'modules-available/eventlog/templates') diff --git a/modules-available/eventlog/templates/page-filters-edit-rule.html b/modules-available/eventlog/templates/page-filters-edit-rule.html index 2c8c9b29..a7886397 100644 --- a/modules-available/eventlog/templates/page-filters-edit-rule.html +++ b/modules-available/eventlog/templates/page-filters-edit-rule.html @@ -30,7 +30,7 @@ {{#filter}} -
+
{{index}} @@ -60,12 +60,10 @@
-
+
+ +
-
{{/filter}} @@ -123,12 +121,10 @@ var $type = $('#i-type'); var $list = $('#filter-keys'); var $fkInputs = $('.filter-key'); - // Flag if type changed - $type.change(function () { - typeChanged = true; - }); + var $filterRows = $('.filter-rule-row'); + // If type changed, fetch sample data, or use cached, and populate autocomplete - $fkInputs.focus(function () { + var typeFieldChangeUpdate = function () { if (!typeChanged) return; typeChanged = false; @@ -145,7 +141,12 @@ typeSamples[typeVal] = data; setAutocomplete(typeVal); }); - }); + }; + + // Flag if type changed + $type.change(function () { + typeChanged = true; + }).blur(typeFieldChangeUpdate); // Population function function setAutocomplete(type) { @@ -162,8 +163,9 @@ if (k === 'machineuuid') m = true; } if (m) { - $list.append($('#machine-filter-keys').clone()); + //$list.append($('#machine-filter-keys').clone()); } + $fkInputs.change(); } // Display sample data @@ -180,7 +182,20 @@ } var index = $this.data('index'); $('#sample-' + index).text(wat); + var empties = 0; + $filterRows.each(function() { + var $this = $(this); + if ($this.find('.filter-key').val().length === 0) { + empties++; + if (empties > 2) { + $this.hide(); + } else { + $this.show(); + } + } + }); }; - $fkInputs.on('input', chFn).change(chFn).change(); + $fkInputs.on('input', chFn).change(chFn); + typeFieldChangeUpdate(); }); -- cgit v1.2.3-55-g7522