From 3434d2db0ebbe4e861a6bbacb6bfe184073ed4c1 Mon Sep 17 00:00:00 2001 From: "patrick.pdb" Date: Wed, 5 Jun 2024 07:17:35 -0400 Subject: [PATCH] '#2163 Creates a map to store the correspondence between a query escaped name of the field and its original name, that needs to be recovered when restoring defined filters. --- .../main/java/iped/app/ui/TableHeaderFilterManager.java | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/iped-app/src/main/java/iped/app/ui/TableHeaderFilterManager.java b/iped-app/src/main/java/iped/app/ui/TableHeaderFilterManager.java index 338ccb900e..ddadc5fe72 100644 --- a/iped-app/src/main/java/iped/app/ui/TableHeaderFilterManager.java +++ b/iped-app/src/main/java/iped/app/ui/TableHeaderFilterManager.java @@ -40,6 +40,7 @@ public class TableHeaderFilterManager implements IResultSetFilterer, IQueryFilte // store the filters defined by the FieldValuePopupMenu private HashMap otherFilters = new HashMap(); + private HashMap escapedFields = new HashMap(); static public TableHeaderFilterManager get() { return singleton; @@ -189,7 +190,9 @@ public MetadataSearch getMetadataSearch(String field) { MetadataSearch result = panels.get(field); if (result == null) { result = new MetadataSearch(); - panels.put(field, result); + String escapedField = escape(field); + panels.put(escapedField, result); + escapedFields.put(escapedField, field); } return result; } @@ -271,12 +274,12 @@ public IMultiSearchResult filterResult(IMultiSearchResult src) throws ParseExcep for (String filterField : panels.keySet()) { MetadataSearch internalMetadataSearch = panels.get(filterField); Set ords = new HashSet<>(); - Set values = selectedValues.get(escape(filterField)); + Set values = selectedValues.get(filterField); if (values != null && values.size() > 0) { for (ValueCount value : values) { ords.add(value.getOrd()); } - result = internalMetadataSearch.getIdsWithOrd(result, filterField, ords); + result = internalMetadataSearch.getIdsWithOrd(result, escapedFields.get(filterField), ords); if (result.getLength() <= 0) { return result; }