diff --git a/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/FilterComponent.java b/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/FilterComponent.java index 58a46d4..04a30b9 100644 --- a/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/FilterComponent.java +++ b/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/FilterComponent.java @@ -82,6 +82,7 @@ import software.xdev.vaadin.model.FilterField; import software.xdev.vaadin.model.FilterFieldEnumExtension; import software.xdev.vaadin.model.SimpleFilterField; +import software.xdev.vaadin.utl.FilterComponentUtl; import software.xdev.vaadin.utl.QueryParameterUtil; @@ -519,8 +520,23 @@ private void deactivateDeleteButtonFromChipComponents( this.addQueryParameter(badge); } - // Activate the reset button - this.btnResetFilter.setEnabled(true); + // When no initial filter is existing + if(this.initialChipBadges.isEmpty() && this.chipBadges.isEmpty()) + { + this.btnResetFilter.setEnabled(false); + } + else + { + final List>> initialChipBadgesCopy + = new ArrayList<>(this.initialChipBadges); + final List>> chipBadgesCopy + = new ArrayList<>(this.chipBadges); + + // Check if just the initial filter are currently applied. Then enable/disable the reset button as + // appropriate. + this.btnResetFilter.setEnabled( + !new FilterComponentUtl().equalLists(initialChipBadgesCopy, chipBadgesCopy)); + } }); } } @@ -1293,7 +1309,7 @@ private String createMultipleQueryParameterString() /** * Method for adding a specific filter condition as query parameter. * - * @param filterCondition The condition which should be converted to query parameter. + * @param chipBadge The condition which should be converted to query parameter. */ private void addQueryParameter(final ChipBadgeExtension> chipBadge) { diff --git a/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/utl/FilterComponentUtl.java b/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/utl/FilterComponentUtl.java new file mode 100644 index 0000000..40e3341 --- /dev/null +++ b/vaadin-simple-grid-filter/src/main/java/software/xdev/vaadin/utl/FilterComponentUtl.java @@ -0,0 +1,50 @@ +/* + * Copyright © 2024 XDEV Software (https://xdev.software) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package software.xdev.vaadin.utl; + +import java.util.List; +import java.util.stream.Collectors; + +import software.xdev.vaadin.model.ChipBadge; +import software.xdev.vaadin.model.ChipBadgeExtension; +import software.xdev.vaadin.model.FilterCondition; + + +public final class FilterComponentUtl +{ + public FilterComponentUtl() + { + } + + /** + * Check if the lists contains the same chip badges objects + * + * @param one List one + * @param two List two + * @return True if the lists contains the same objects + */ + public boolean equalLists( + final List>> one, + final List>> two) + { + return one.stream() + .map(ChipBadge::getBadgeId) + .collect(Collectors.toSet()) + .equals(two.stream() + .map(ChipBadge::getBadgeId) + .collect(Collectors.toSet())); + } +}