/* 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(); } }