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.trade.item;
019
020import javax.validation.Valid;
021import javax.validation.constraints.NotNull;
022import javax.xml.bind.annotation.XmlElement;
023import javax.xml.bind.annotation.XmlType;
024
025import io.konik.validator.annotation.Comfort;
026import io.konik.validator.annotation.Extended;
027import io.konik.zugferd.entity.CommonMonetarySummation;
028import io.konik.zugferd.unqualified.Amount;
029
030/**
031 * 
032 * The specified per monetary summation on item basis.
033 */
034@XmlType(propOrder = { "lineTotal", "totalAllowanceCharge" })
035public class SpecifiedMonetarySummation implements CommonMonetarySummation {
036
037   @XmlElement(name = "LineTotalAmount")
038   private Amount lineTotal;
039
040   @XmlElement(name = "TotalAllowanceChargeAmount")
041   private Amount totalAllowanceCharge;
042
043   @Comfort
044   @Override
045   @Valid
046   @NotNull(groups = Comfort.class)
047   public Amount getLineTotal() {
048      return lineTotal;
049   }
050
051   @Override
052   public SpecifiedMonetarySummation setLineTotal(Amount lineTotal) {
053      this.lineTotal = lineTotal;
054      return this;
055   }
056
057   /**
058    * Gets the total allowance charge.
059    *
060    * @return the total allowance charge
061    */
062   @Extended
063   @Valid
064   public Amount getTotalAllowanceCharge() {
065      return totalAllowanceCharge;
066   }
067
068   /**
069    * Sets the total allowance charge.
070    *
071    * @param totalAllowanceCharge the new total allowance charge
072    * @return the specified monetary summation
073    */
074   public SpecifiedMonetarySummation setTotalAllowanceCharge(Amount totalAllowanceCharge) {
075      this.totalAllowanceCharge = totalAllowanceCharge;
076      return this;
077   }
078}