/* * The Kuali Financial System, a comprehensive financial management system for higher education. * * Copyright 2005-2014 The Kuali Foundation * * This program 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. * * This program 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 this program. If not, see <http://www.gnu.org/licenses/>. */ package org.kuali.kfs.sys.document.datadictionary; import java.util.ArrayList; import java.util.List; import org.kuali.kfs.sys.businessobject.AccountingLine; import org.kuali.kfs.sys.document.web.AccountingLineViewLineFillingElement; import org.kuali.kfs.sys.document.web.AccountingLineViewLines; import org.kuali.kfs.sys.document.web.TableJoining; import org.kuali.rice.krad.datadictionary.DataDictionaryDefinitionBase; import org.kuali.rice.krad.datadictionary.exception.AttributeValidationException; /** * Data dictionary definition for a group of multiple lines to render. This also renders blocks - though each block will be rendered as a line with an embedded table */ public class AccountingLineViewLinesDefinition extends DataDictionaryDefinitionBase implements AccountingLineViewRenderableElementDefinition { private List<AccountingLineViewLineFillingDefinition> lines; private String elementName; /** * Validates that: * 1) there is at least one child line * @see org.kuali.rice.krad.datadictionary.DataDictionaryDefinition#completeValidation(java.lang.Class, java.lang.Class) */ public void completeValidation(Class rootBusinessObjectClass, Class otherBusinessObjectClass) { if (lines == null || lines.size() == 0) { throw new AttributeValidationException("Please specify at least one child line for the lines definition"); } } /** * Gets the lines attribute. * @return Returns the lines. */ public List<AccountingLineViewLineFillingDefinition> getLines() { return lines; } /** * Sets the lines attribute value. * @param lines The lines to set. */ public void setLines(List<AccountingLineViewLineFillingDefinition> lines) { this.lines = lines; } /** * Gets the elementName attribute. * @return Returns the elementName. */ public String getElementName() { return elementName; } /** * Sets the elementName attribute value. * @param elementName The elementName to set. */ public void setElementName(String elementName) { this.elementName = elementName; } /** * @see org.kuali.kfs.sys.document.datadictionary.AccountingLineViewRenderableElementDefinition#createLayoutElement() */ public TableJoining createLayoutElement(Class<? extends AccountingLine> accountingLineClass) { AccountingLineViewLines layoutElement = new AccountingLineViewLines(); layoutElement.setDefinition(this); layoutElement.setElements(getLayoutElementsForLines(accountingLineClass)); return layoutElement; } /** * Generates layout elements for all the child lines of this lines definition * @return a List with the line elements for all child lines of this element definition */ protected List<AccountingLineViewLineFillingElement> getLayoutElementsForLines(Class<? extends AccountingLine> accountingLineClass) { List<AccountingLineViewLineFillingElement> elements = new ArrayList<AccountingLineViewLineFillingElement>(); for (AccountingLineViewLineFillingDefinition line : lines) { elements.add(line.createLineFillingLayoutElement(accountingLineClass)); } return elements; } }