com.netgrif.application.engine.validation.models.DateFieldValidation.groovy Maven / Gradle / Ivy
package com.netgrif.application.engine.validation.models
import com.netgrif.application.engine.validation.domain.ValidationDataInput
import groovy.util.logging.Slf4j
import java.time.DayOfWeek
import java.time.LocalDate
import java.time.format.DateTimeFormatter
import java.time.format.DateTimeParseException
import java.time.temporal.ChronoField
@Slf4j
class DateFieldValidation extends AbstractFieldValidation {
// BETWEEN = 'between'
// WORKDAY = 'workday'
// WEEKEND = 'weekend'
// REQUIRED = 'required',
// VALID_BETWEEN = 'validBetween',
// VALID_WORKDAY = 'validWorkday',
// VALID_WEEKEND = 'validWeekend'
// between today,future
// between past,today
// between 2020-03-03,today
public static final String FUTURE = "future"
public static final String TODAY = "today"
public static final String PAST = "past"
public static final String NOW = "now"
void between(ValidationDataInput validationData) {
LocalDate updateDate_TODAY = validationData.getData().getLastModified().toLocalDate()
List regex = validationData.getValidationRegex().trim().split(",")
LocalDate setDate;
try {
setDate = validationData.getData().getValue() as LocalDate
} catch (Exception e){
try {
setDate = (validationData.getData().getValue() as Date).toLocalDate()
}catch (Exception e2){
log.error(e2.message)
}
}
if (regex.size() == 2) {
def fromDate = parseStringToLocalDate(regex.get(0)) != null ? parseStringToLocalDate(regex.get(0)) : regex.get(0)
def toDate = parseStringToLocalDate(regex.get(1)) != null ? parseStringToLocalDate(regex.get(1)) : regex.get(1)
if ((fromDate == TODAY || fromDate == NOW) && toDate == FUTURE) {
if (setDate < updateDate_TODAY) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
} else if (fromDate == PAST && (toDate == TODAY || toDate == NOW)) {
if (setDate > updateDate_TODAY) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
} else if (fromDate == PAST && (toDate instanceof LocalDate)) {
if (setDate > toDate) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
} else if (fromDate == TODAY && (toDate instanceof LocalDate)) {
if (setDate < toDate || setDate > updateDate_TODAY) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
} else if ((fromDate instanceof LocalDate) && toDate == TODAY) {
if (setDate < fromDate || setDate > updateDate_TODAY) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
} else if (toDate == FUTURE && (fromDate instanceof LocalDate)) {
if (setDate < fromDate) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
} else if ((fromDate instanceof LocalDate) && (toDate instanceof LocalDate)) {
if (setDate > toDate || setDate < fromDate) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
}
}
}
void workday(ValidationDataInput validationData) {
LocalDate setDate;
try {
setDate = validationData.getData().getValue() as LocalDate
} catch (Exception e){
try {
setDate = (validationData.getData().getValue() as Date).toLocalDate()
}catch (Exception e2){
log.error(e2.message)
}
}
if (isWeekend(setDate)) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
}
void weekend(ValidationDataInput validationData) {
LocalDate setDate;
try {
setDate = validationData.getData().getValue() as LocalDate
} catch (Exception e){
try {
setDate = (validationData.getData().getValue() as Date).toLocalDate()
}catch (Exception e2){
log.error(e2.message)
}
}
if (!isWeekend(setDate)) {
throw new IllegalArgumentException(validationData.getValidationMessage().getTranslation(validationData.getLocale()))
}
}
protected static boolean isWeekend(LocalDate day) {
DayOfWeek dayOfWeek = DayOfWeek.of(day.get(ChronoField.DAY_OF_WEEK));
return dayOfWeek == DayOfWeek.SUNDAY || dayOfWeek == DayOfWeek.SATURDAY;
}
protected LocalDate parseStringToLocalDate(String stringDate) {
if (stringDate == null)
return null
List patterns = Arrays.asList("dd.MM.yyyy")
try {
return LocalDate.parse(stringDate, DateTimeFormatter.BASIC_ISO_DATE)
} catch (DateTimeParseException e) {
try {
return LocalDate.parse(stringDate, DateTimeFormatter.ISO_DATE)
} catch (DateTimeParseException ex) {
for (String pattern : patterns) {
try {
return LocalDate.parse(stringDate, DateTimeFormatter.ofPattern(pattern))
} catch (DateTimeParseException | IllegalArgumentException exc) {
continue
}
}
}
}
return null
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy