001 /**
002 * Copyright 2005-2011 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016 package org.kuali.rice.krad.datadictionary;
017
018 import org.apache.commons.lang.StringUtils;
019
020 import java.io.Serializable;
021
022 /**
023 The help element provides the keys to obtain a
024 help description from the database.
025
026 On document JSP pages, a help icon may be rendered. If this tag is specified, then
027 the filename of this page will be located in the value of the parameter specified by the namespace, detail type, and name.
028
029 The value of the parameter is relative to the value of the "externalizable.help.url" property in ConfigurationService (see KualiHelpAction).
030 parameterNamespace: namespace of the parameter that has the path to the help page
031 parameterName: name of the parameter that has the path to the help page
032 parameterDetailType: detail type of the parameter that has the path to the help page
033 */
034 public class HelpDefinition extends DataDictionaryDefinitionBase implements Serializable {
035 private static final long serialVersionUID = -6869646654597012863L;
036
037 protected String parameterNamespace;
038 protected String parameterDetailType;
039 protected String parameterName;
040
041 /**
042 * Constructs a HelpDefinition.
043 */
044 public HelpDefinition() {}
045
046 /**
047 * @see org.kuali.rice.krad.datadictionary.DataDictionaryDefinition#completeValidation(java.lang.Class, java.lang.Class)
048 */
049 public void completeValidation(Class rootBusinessObjectClass, Class otherBusinessObjectClass) {
050 // No real validation to be done here other than perhaps checking to be
051 // sure that the security workgroup is a valid workgroup.
052 }
053
054 /**
055 * @return
056 */
057 public String getParameterName() {
058 return parameterName;
059 }
060
061 /**
062 * parameterName: name of the parameter that has the path to the help page
063 */
064 public void setParameterName(String parameterName) {
065 if (StringUtils.isBlank(parameterName)) {
066 throw new IllegalArgumentException("invalid (blank) parameterName");
067 }
068 this.parameterName = parameterName;
069 }
070
071 /**
072 * @return
073 */
074 public String getParameterNamespace() {
075 return parameterNamespace;
076 }
077
078 /**
079 * parameterNamespace: namespace of the parameter that has the path to the help page
080 */
081 public void setParameterNamespace(String parameterNamespace) {
082 if (StringUtils.isBlank(parameterNamespace)) {
083 throw new IllegalArgumentException("invalid (blank) parameterNamespace");
084 }
085 this.parameterNamespace = parameterNamespace;
086 }
087
088 public String getParameterDetailType() {
089 return this.parameterDetailType;
090 }
091
092 /**
093 * parameterDetailType: detail type of the parameter that has the path to the help page
094 */
095 public void setParameterDetailType(String parameterDetailType) {
096 if (StringUtils.isBlank(parameterDetailType)) {
097 throw new IllegalArgumentException("invalid (blank) parameterDetailType");
098 }
099 this.parameterDetailType = parameterDetailType;
100 }
101
102 }