/* * Copyright 2008-2017 the original author or authors. * * 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 griffon.core.formatters; import javax.annotation.Nonnull; import javax.annotation.Nullable; import java.text.SimpleDateFormat; import java.util.Date; import static griffon.util.GriffonNameUtils.isBlank; /** * @author Andres Almiray * @since 2.0.0 */ public class DateFormatter extends AbstractFormatter<Date> { private final SimpleDateFormat dateFormat; public DateFormatter() { this(null); } public DateFormatter(@Nullable String pattern) { if (isBlank(pattern)) { dateFormat = new SimpleDateFormat(); } else { dateFormat = new SimpleDateFormat(pattern); } } @Nonnull public String getPattern() { return dateFormat.toPattern(); } @Nullable public String format(@Nullable Date date) { return date == null ? null : dateFormat.format(date); } @Nullable @Override public Date parse(@Nullable String str) throws ParseException { if (isBlank(str)) return null; try { return dateFormat.parse(str); } catch (java.text.ParseException e) { throw new ParseException(e); } } }