001/* Copyright (C) 2014 konik.io 002 * 003 * This file is part of the Konik library. 004 * 005 * The Konik library is free software: you can redistribute it and/or modify 006 * it under the terms of the GNU Affero General Public License as 007 * published by the Free Software Foundation, either version 3 of the 008 * License, or (at your option) any later version. 009 * 010 * The Konik library is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 013 * GNU Affero General Public License for more details. 014 * 015 * You should have received a copy of the GNU Affero General Public License 016 * along with the Konik library. If not, see <http://www.gnu.org/licenses/>. 017 */ 018package io.konik.zugferd.entity; 019 020import io.konik.zugferd.unqualified.Amount; 021 022import java.util.ArrayList; 023import java.util.Collections; 024import java.util.List; 025 026/** 027 * 028 * The Item GrossPrice. 029 */ 030public class GrossPrice extends Price { 031 032 GrossPrice() { 033 super(); 034 } 035 036 /** 037 * Instantiates a new gross price. 038 * 039 * @param chargeAmount the charge amount 040 */ 041 public GrossPrice(Amount chargeAmount) { 042 super(chargeAmount); 043 } 044 045 /** 046 * Gets the applied trade allowance charge. 047 * 048 * @return the applied trade allowance charge 049 */ 050 public List<AllowanceCharge> getAllowanceCharges() { 051 if (allowanceCharges == null) { 052 allowanceCharges = new ArrayList<AllowanceCharge>(); 053 } 054 return this.allowanceCharges; 055 } 056 057 /** 058 * Adds additional allowance charges. 059 * 060 * @param additionalAllowanceCharges the additional allowance charges 061 * @return the price 062 */ 063 public Price addAllowanceCharge(AllowanceCharge... additionalAllowanceCharges) { 064 Collections.addAll(getAllowanceCharges(), additionalAllowanceCharges); 065 return this; 066 } 067}