jidefx.scene.control.field.verifier.IntegerTemporalPatternVerifier Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jidefx-fields Show documentation
Show all versions of jidefx-fields Show documentation
JideFX Common Layer is a collection of several extend feature for JavaFX
The newest version!
/*
* @(#)IntegerTemporalPatternVerifier.java 5/19/2013
*
* Copyright 2002 - 2013 JIDE Software Inc. All rights reserved.
*/
package jidefx.scene.control.field.verifier;
import jidefx.utils.CommonUtils;
import java.time.format.DateTimeFormatter;
import java.time.format.DateTimeParseException;
import java.time.format.ResolverStyle;
import java.time.temporal.Temporal;
import java.time.temporal.TemporalField;
import java.time.temporal.TemporalUnit;
/**
* A special verifier for the Calendar field that has an integer type. It knows how to verify the value for a Calendar
* field based on its actual maximum and minimum values.
*/
public class IntegerTemporalPatternVerifier extends TemporalPatternVerifier implements PatternVerifier.Length,
PatternVerifier.Formatter, PatternVerifier.Parser, PatternVerifier.Value,
PatternVerifier.Adjustable {
private boolean _fixedLength = false;
private final DateTimeFormatter _formatter;
public IntegerTemporalPatternVerifier(TemporalField field, TemporalUnit unit, String pattern) {
this(field, unit, pattern, Integer.MIN_VALUE, Integer.MAX_VALUE, false);
}
public IntegerTemporalPatternVerifier(TemporalField field, TemporalUnit unit, String pattern, boolean fixedLength) {
this(field, unit, pattern, Integer.MIN_VALUE, Integer.MAX_VALUE, fixedLength);
}
public IntegerTemporalPatternVerifier(TemporalField field, TemporalUnit unit, String pattern, long min, long max) {
this(field, unit, pattern, min, max, false);
}
public IntegerTemporalPatternVerifier(TemporalField field, TemporalUnit unit, String pattern, long min, long max, boolean fixedLength) {
super(field, unit, min, max);
_fixedLength = fixedLength;
_formatter = DateTimeFormatter.ofPattern(pattern).withResolverStyle(ResolverStyle.SMART);
}
@Override
public Integer getEnd(Integer current) {
if (_value != null) {
_value = _value.with(_temporalField, getMax());
}
return null;
}
@Override
public Integer getHome(Integer current) {
if (_value != null) {
_value = _value.with(_temporalField, getMin());
}
return null;
}
@Override
public Integer getPreviousPage(Integer current, boolean restart) {
if (_value != null) {
try {
_value = _value.minus(10, _temporalUnit);
}
catch (Exception ignored) {
}
}
return null;
}
@Override
public Integer getNextPage(Integer current, boolean restart) {
if (_value != null) {
try {
_value = _value.plus(10, _temporalUnit);
}
catch (Exception ignored) {
}
}
return null;
}
@Override
public Integer getNextValue(Integer current, boolean restart) {
if (_value != null) {
try {
_value = _value.plus(1, _temporalUnit);
}
catch (Exception ignored) {
}
}
return null;
}
@Override
public Integer getPreviousValue(Integer current, boolean restart) {
if (_value != null) {
try {
_value = _value.minus(1, _temporalUnit);
}
catch (Exception ignored) {
}
}
return null;
}
@Override
public void setFieldValue(Temporal fieldValue) {
if (fieldValue != null) {
_value = fieldValue;
}
}
@Override
public Temporal getFieldValue() {
return _value;
}
@Override
public Integer toTargetValue(Temporal fieldValue) {
return fieldValue.get(_temporalField);
}
@Override
public Temporal fromTargetValue(Temporal existingValue, Integer value) {
existingValue.with(_temporalField, value);
return existingValue;
}
@Override
public int getMinLength() {
return _fixedLength ? getMaxLength() : 0;
}
@Override
public int getMaxLength() {
return format(getMax().intValue()).length();
}
@Override
public String format(Integer value) {
if (value == null) return null;
return _formatter.format(getFieldValue().with(getTemporalField(), value));
}
@Override
public Integer parse(String text) {
if (text == null || text.trim().isEmpty()) return null;
return _formatter.parse(text).get(getTemporalField());
}
@Override
public Boolean call(String text) {
if (text.length() > getMaxLength()) return false;
try {
long i = parse(text);
if (i >= getMin() && i <= getMax()) return true;
}
catch (DateTimeParseException e) {
CommonUtils.ignoreException(e);
}
return false;
}
}