/* 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 a Year and week of the year.
*/
public class ZfDateWeek extends ZfDate {
private static final long serialVersionUID = 8855185120284648974L;
/** The date format code. */
public static final String CODE = "616";
private static final String DATE_PATTERN = "yyyyww";
private static final ThreadLocal<SimpleDateFormat> formatter = new ThreadLocal<SimpleDateFormat>() {
@Override
protected SimpleDateFormat initialValue() {
return new SimpleDateFormat(DATE_PATTERN);
}
};
/**
* Instantiates a new zf date week.
*/
public ZfDateWeek() {
super();
}
/**
* Instantiates a new zf date week.
*
* @param date the date
*/
public ZfDateWeek(Date date) {
super(date);
}
/**
* Instantiates a new zf date week.
*
* @param date the date
*/
public ZfDateWeek(long date) {
super(date);
}
/**
* Instantiates a new zf date week.
*
* @param formattedDate the formatted date
*/
public ZfDateWeek(String formattedDate) {
super(formattedDate);
}
/**
* Gets the format code.
*
* @return the format code
*/
@Override
public String getFormatCode() {
return CODE;
}
@Override
SimpleDateFormat getFormatter() {
return formatter.get();
}
}