Skip to content

Commit

Permalink
Search Filter supports match regex, match case and remembers these se…
Browse files Browse the repository at this point in the history
…ttings
  • Loading branch information
Phillipus committed Jan 17, 2025
1 parent bff2fd8 commit 81c370e
Show file tree
Hide file tree
Showing 6 changed files with 115 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -175,4 +175,9 @@ public interface IPreferenceConstants {

// Single column layout in Properties View
String PROPERTIES_SINGLE_COLUMN = "propertiesSingleColumn";

// Search Filter
String SEARCHFILTER_SHOW_ALL_FOLDERS = "searchFilterShowAllFolders";
String SEARCHFILTER_MATCH_CASE = "searchFilterMatchCase";
String SEARCHFILTER_USE_REGEX = "searchFilterUseRegex";
}
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,10 @@ public class Messages extends NLS {

public static String SearchWidget_17;

public static String SearchWidget_18;

public static String SearchWidget_19;

public static String SearchWidget_2;

public static String SearchWidget_3;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@

import java.util.HashSet;
import java.util.Set;
import java.util.regex.Pattern;

import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.EObject;
Expand Down Expand Up @@ -41,15 +42,20 @@ public class SearchFilter extends ViewerFilter {
private Set<EClass> fConceptsFilter = new HashSet<>();
private Set<String> fPropertiesFilter = new HashSet<>();
private Set<IProfile> fSpecializationsFilter = new HashSet<>();
private boolean fFilterViews = false;

private boolean fShowAllFolders = false;

private boolean fFilterViews;
private boolean fShowAllFolders;
private boolean fMatchCase;
private boolean fUseRegex;

private Pattern fRegexPattern;

SearchFilter() {
}

void setSearchText(String text) {
fSearchText = text;
createRegexPattern();
}

void reset() {
Expand Down Expand Up @@ -136,7 +142,7 @@ private boolean shouldShowObjectWithName(Object element) {
// Normalise in case of multi-line text
name = StringUtils.normaliseNewLineCharacters(name);

return name.toLowerCase().contains(fSearchText.toLowerCase());
return matchesString(name);
}

return false;
Expand All @@ -145,7 +151,7 @@ private boolean shouldShowObjectWithName(Object element) {
private boolean shouldShowObjectWithDocumentation(Object element) {
if(element instanceof IDocumentable documentable) {
String text = StringUtils.safeString(documentable.getDocumentation());
return text.toLowerCase().contains(fSearchText.toLowerCase());
return matchesString(text);
}

return false;
Expand All @@ -170,13 +176,45 @@ private boolean shouldShowProperty(Object element) {
if(element instanceof IProperties properties) {
for(IProperty property : properties.getProperties()) {
if(fPropertiesFilter.contains(property.getKey())) {
return hasSearchText() ? property.getValue().toLowerCase().contains(fSearchText.toLowerCase()) : true;
return hasSearchText() ? matchesString(property.getValue()) : true;
}
}
}

return false;
}

private boolean matchesString(String str) {
if(str == null || str.length() == 0) {
return false;
}

if(isUseRegex()) {
return matchesRegexString(str);
}

if(isMatchCase()) {
return str.contains(fSearchText);
}

return str.toLowerCase().contains(fSearchText.toLowerCase());
}

private boolean matchesRegexString(String searchString) {
return fRegexPattern != null ? fRegexPattern.matcher(searchString).find() : false;
}

private void createRegexPattern() {
fRegexPattern = null;

if(isUseRegex() && hasSearchText()) {
try {
fRegexPattern = Pattern.compile(fSearchText, isMatchCase() ? 0 : Pattern.CASE_INSENSITIVE);
}
catch(Exception ex) {
}
}
}

public boolean isFiltering() {
return isFilteringName() || isFilteringDocumentation() || isFilteringConcepts() || isFilteringPropertyKeys() || isFilteringSpecializations() || isFilteringViews();
Expand Down Expand Up @@ -206,7 +244,25 @@ private boolean hasSearchText() {
return fSearchText.length() > 0;
}

void setFilterOnName(boolean set) {
void setMatchCase(boolean set) {
fMatchCase = set;
createRegexPattern();
}

boolean isMatchCase() {
return fMatchCase;
}

void setUseRegex(boolean set) {
fUseRegex = set;
createRegexPattern();
}

boolean isUseRegex() {
return fUseRegex;
}

void setFilterOnName(boolean set) {
fFilterName = set;
}

Expand Down Expand Up @@ -269,5 +325,4 @@ void setFilterViews(boolean set) {
boolean isFilteringViews() {
return fFilterViews;
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -331,13 +331,41 @@ public void run() {
IAction actionFolders = new Action(Messages.SearchWidget_12, IAction.AS_CHECK_BOX) {
@Override
public void run() {
ArchiPlugin.PREFERENCES.setValue(IPreferenceConstants.SEARCHFILTER_SHOW_ALL_FOLDERS, isChecked());
fSearchFilter.setShowAllFolders(isChecked());
refreshTree();
}
};
actionFolders.setChecked(fSearchFilter.isShowAllFolders());
actionFolders.setChecked(ArchiPlugin.PREFERENCES.getBoolean(IPreferenceConstants.SEARCHFILTER_SHOW_ALL_FOLDERS));
fSearchFilter.setShowAllFolders(actionFolders.isChecked());
dropDownAction.add(actionFolders);

// Match Case
IAction actionMatchCase = new Action(Messages.SearchWidget_18, IAction.AS_CHECK_BOX) {
@Override
public void run() {
ArchiPlugin.PREFERENCES.setValue(IPreferenceConstants.SEARCHFILTER_MATCH_CASE, isChecked());
fSearchFilter.setMatchCase(isChecked());
refreshTree();
}
};
actionMatchCase.setChecked(ArchiPlugin.PREFERENCES.getBoolean(IPreferenceConstants.SEARCHFILTER_MATCH_CASE));
fSearchFilter.setMatchCase(actionMatchCase.isChecked());
dropDownAction.add(actionMatchCase);

// Regex
IAction actionUseRegex = new Action(Messages.SearchWidget_19, IAction.AS_CHECK_BOX) {
@Override
public void run() {
ArchiPlugin.PREFERENCES.setValue(IPreferenceConstants.SEARCHFILTER_USE_REGEX, isChecked());
fSearchFilter.setUseRegex(isChecked());
refreshTree();
}
};
actionUseRegex.setChecked(ArchiPlugin.PREFERENCES.getBoolean(IPreferenceConstants.SEARCHFILTER_USE_REGEX));
fSearchFilter.setUseRegex(actionUseRegex.isChecked());
dropDownAction.add(actionUseRegex);

dropDownAction.add(new Separator());

// Reset
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ SearchWidget_14=Other
SearchWidget_15=Strategy
SearchWidget_16=Specializations
SearchWidget_17=Views
SearchWidget_18=Match Case
SearchWidget_19=Match Regular Expression
SearchWidget_2=Documentation
SearchWidget_3=Search in Documentation
SearchWidget_4=Filter Options
Expand Down
12 changes: 12 additions & 0 deletions com.archimatetool.help/help/Text/model_tree_search.html
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,18 @@ <h3>Show All Folders</h3>

<br/>

<h3>Match Case</h3>

<p>Select this option to match case on the search text.</p>

<br/>

<h3>Match Regular Expression</h3>

<p>Select this option to match using regular expressions. Note that the syntax is Java based.</p>

<br/>

<h3>Reset Filters</h3>

<p>Selecting this menu item will clear all selections for Documentation, Properties, Specializations, Elements, Relations, and Views.</p>
Expand Down

0 comments on commit 81c370e

Please sign in to comment.