Skip to content

Commit

Permalink
put changes behing the feature flag
Browse files Browse the repository at this point in the history
  • Loading branch information
vursen committed Aug 15, 2022
1 parent 871a756 commit 64f077a
Showing 1 changed file with 42 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@
import java.util.stream.Collectors;
import java.util.stream.Stream;

import com.vaadin.experimental.Feature;
import com.vaadin.experimental.FeatureFlags;
import com.vaadin.flow.component.AttachEvent;
import com.vaadin.flow.component.ComponentEventListener;
import com.vaadin.flow.component.shared.ClientValidationUtil;
Expand Down Expand Up @@ -119,7 +121,9 @@ private TimePicker(LocalTime time, boolean isInitialValueOptional) {

addValueChangeListener(e -> validate());

addClientValidatedEventListener(event -> validate());
if (getFeatureFlags().isEnabled(FeatureFlags.ENFORCE_FIELD_VALIDATION)) {
addClientValidatedEventListener(event -> validate());
}
}

/**
Expand Down Expand Up @@ -276,24 +280,34 @@ public boolean isInvalid() {

@Override
public Validator<LocalTime> getDefaultValidator() {
return (value, context) -> checkValidity(value);
if (getFeatureFlags().isEnabled(FeatureFlags.ENFORCE_FIELD_VALIDATION)) {
return (value, context) -> checkValidity(value);
}

return Validator.alwaysPass();
}

@Override
public Registration addValidationStatusChangeListener(
ValidationStatusChangeListener<LocalTime> listener) {
return addClientValidatedEventListener(event -> {
listener.validationStatusChanged(
new ValidationStatusChangeEvent<LocalTime>(this,
!isInvalid()));
});
if (getFeatureFlags().isEnabled(FeatureFlags.ENFORCE_FIELD_VALIDATION)) {
return addClientValidatedEventListener(event -> {
listener.validationStatusChanged(
new ValidationStatusChangeEvent<LocalTime>(this,
!isInvalid()));
});
}

return null;
}

private ValidationResult checkValidity(LocalTime value) {
var hasNonParsableValue = value == getEmptyValue()
&& isInputValuePresent();
if (hasNonParsableValue) {
return ValidationResult.error("");
if (getFeatureFlags().isEnabled(FeatureFlags.ENFORCE_FIELD_VALIDATION)) {
var hasNonParsableValue = value == getEmptyValue()
&& isInputValuePresent();
if (hasNonParsableValue) {
return ValidationResult.error("");
}
}

var greaterThanMaxValidation = ValidationUtil.checkGreaterThanMax(value,
Expand Down Expand Up @@ -469,7 +483,23 @@ protected void onAttach(AttachEvent attachEvent) {
super.onAttach(attachEvent);
initConnector();
requestLocaleUpdate();
ClientValidationUtil.preventWebComponentFromSettingItselfToValid(this);
if (getFeatureFlags().isEnabled(FeatureFlags.ENFORCE_FIELD_VALIDATION)) {
ClientValidationUtil.preventWebComponentFromSettingItselfToValid(this);
} else {
FieldValidationUtil.disableClientValidation(this);
}
}

/**
* Gets the feature flags for the current UI.
* <p>
* Extracted with protected visibility to support mocking
*
* @return the current set of feature flags
*/
private FeatureFlags getFeatureFlags() {
return FeatureFlags
.get(UI.getCurrent().getSession().getService().getContext());
}

private void initConnector() {
Expand Down

0 comments on commit 64f077a

Please sign in to comment.