/* Copyright (C) 2014 konik.io
*
* This file is part of the Konik library.
*
* The Konik library is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* The Konik library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with the Konik library. If not, see <http://www.gnu.org/licenses/>.
*/
package io.konik.zugferd.unqualified;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* The ZUGFeRD Date with year and month.
*/
public class ZfDateMonth extends ZfDate {
private static final long serialVersionUID = 2756814691171025048L;
/** The format code for year and month. */
public static final String CODE = "610";
private static final String DATE_PATTERN = "yyyyMM";
private static final ThreadLocal<SimpleDateFormat> formatter = new ThreadLocal<SimpleDateFormat>() {
@Override
protected SimpleDateFormat initialValue() {
return new SimpleDateFormat(DATE_PATTERN);
}
};
/**
* Instantiates a new zf date with current year and month
*/
public ZfDateMonth() {
super();
}
/**
* Instantiates a new zf date with current year and month
*
* @param date the date
*/
public ZfDateMonth(Date date) {
super(date);
}
/**
* Instantiates a new zf date month.
*
* @param date the date
*/
public ZfDateMonth(long date) {
super(date);
}
/**
* Instantiates a new zf date month.
*
* @param formattedDate the formatted date
*/
public ZfDateMonth(String formattedDate) {
super(formattedDate);
}
/**
* Gets the format code.
*
* @return the format code
*/
@Override
public String getFormatCode() {
return CODE;
}
@Override
SimpleDateFormat getFormatter() {
return formatter.get();
}
}