1 /** 2 * Copyright 2005-2012 The Kuali Foundation 3 * 4 * Licensed under the Educational Community License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.opensource.org/licenses/ecl2.php 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 package org.kuali.rice.krad.datadictionary; 17 18 import org.kuali.rice.krad.document.Document; 19 import org.kuali.rice.krad.util.KRADConstants; 20 21 import java.io.Serializable; 22 import java.util.ArrayList; 23 import java.util.List; 24 25 /** 26 * Allows for grouping of related {@link WorkflowProperty} objects 27 * 28 * <p> 29 * This element is used to define a set of workflowProperty tags, which are used to 30 * specify which document properties should be serialized during the document serialization 31 * process. This element allows for all the nested workflowProperty tags to be relative 32 * to some base path. This base path itself is relative to the object being serialized 33 * during the document serialization process (which is not necessarily the document itself, 34 * but a wrapper around the document).If blank/missing, the base path will be assumed to be 35 * the property path to the document. 36 * </p> 37 * 38 * @author Kuali Rice Team (rice.collab@kuali.org) 39 */ 40 public class WorkflowPropertyGroup implements Serializable { 41 private static final long serialVersionUID = 1L; 42 43 protected String basePath = KRADConstants.EMPTY_STRING; 44 protected List<WorkflowProperty> workflowProperties = new ArrayList<WorkflowProperty>(); 45 46 /** 47 * The list of {@link WorkflowProperty} objects 48 * 49 * @return List<WorkflowProperty> 50 */ 51 public List<WorkflowProperty> getWorkflowProperties() { 52 return workflowProperties; 53 } 54 55 /** 56 * The base path of the group which all {@link WorkflowProperty} objects are relative to 57 * 58 * <p> 59 * The base path itself should be relative from the object being serialized, which may not necessarily be the 60 * document, see {@link Document#wrapDocumentWithMetadataForXmlSerialization()} 61 * and {@link Document#getBasePathToDocumentDuringSerialization()}. If blank/missing, the base path will be 62 * assumed to be the property path to the document. 63 * </p> 64 * 65 * @return String 66 */ 67 public String getBasePath() { 68 return this.basePath; 69 } 70 71 /** 72 * Setter for the base path 73 * 74 * @param basePath - the base path 75 */ 76 public void setBasePath(String basePath) { 77 this.basePath = basePath; 78 } 79 80 /** 81 * Setter for workflow properties list 82 * 83 * @param workflowProperties - the list of workflow properties 84 */ 85 public void setWorkflowProperties(List<WorkflowProperty> workflowProperties) { 86 this.workflowProperties = workflowProperties; 87 } 88 89 }