001 /** 002 * Copyright 2005-2012 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.uif.field; 017 018 import org.kuali.rice.krad.uif.component.Component; 019 import org.kuali.rice.krad.uif.view.View; 020 021 /** 022 * Field that contains a header element and optionally a <code>Group</code> to 023 * present along with the header text 024 * 025 * <p> 026 * Generally the group is used to display content to the right of the header, 027 * such as links for the group or other information 028 * </p> 029 * 030 * @author Kuali Rice Team (rice.collab@kuali.org) 031 */ 032 public class HeaderField extends FieldGroup { 033 private static final long serialVersionUID = -6950408292923393244L; 034 035 private String headerText; 036 private String headerLevel; 037 private String headerStyleClasses; 038 private String headerStyle; 039 private String headerDivStyleClasses; 040 private String headerDivStyle; 041 042 public HeaderField() { 043 super(); 044 } 045 046 /** 047 * The following finalization is performed: 048 * 049 * <ul> 050 * <li>Set render on group to false if no items are configured</li> 051 * </ul> 052 * 053 * @see org.kuali.rice.krad.uif.component.ComponentBase#performFinalize(org.kuali.rice.krad.uif.view.View, 054 * java.lang.Object, org.kuali.rice.krad.uif.component.Component) 055 */ 056 @Override 057 public void performFinalize(View view, Object model, Component parent) { 058 super.performFinalize(view, model, parent); 059 060 // don't render header group if no items were configured 061 if ((getGroup() != null) && (getGroup().getItems().isEmpty())) { 062 getGroup().setRender(false); 063 } 064 } 065 066 /** 067 * Text that should be displayed on the header 068 * 069 * @return String header text 070 */ 071 public String getHeaderText() { 072 return this.headerText; 073 } 074 075 /** 076 * Setter for the header text 077 * 078 * @param headerText 079 */ 080 public void setHeaderText(String headerText) { 081 this.headerText = headerText; 082 } 083 084 /** 085 * HTML header level (h1 ... h6) that should be applied to the header text 086 * 087 * @return String header level 088 */ 089 public String getHeaderLevel() { 090 return this.headerLevel; 091 } 092 093 /** 094 * Setter for the header level 095 * 096 * @param headerLevel 097 */ 098 public void setHeaderLevel(String headerLevel) { 099 this.headerLevel = headerLevel; 100 } 101 102 /** 103 * Style class that should be applied to the header text (h tag) 104 * 105 * <p> 106 * Note the style class given here applies to only the header text. The 107 * style class property inherited from the <code>Component</code> interface 108 * can be used to set the class for the whole field div (which could 109 * include a nested <code>Group</code>) 110 * </p> 111 * 112 * @return String style class 113 * @see org.kuali.rice.krad.uif.Component.getStyleClasses() 114 */ 115 public String getHeaderStyleClasses() { 116 return this.headerStyleClasses; 117 } 118 119 /** 120 * Setter for the header style class 121 * 122 * @param headerStyleClasses 123 */ 124 public void setHeaderStyleClasses(String headerStyleClasses) { 125 this.headerStyleClasses = headerStyleClasses; 126 } 127 128 /** 129 * Style that should be applied to the header text 130 * 131 * <p> 132 * Note the style given here applies to only the header text. The style 133 * property inherited from the <code>Component</code> interface can be used 134 * to set the style for the whole field div (which could include a nested 135 * <code>Group</code>) 136 * </p> 137 * 138 * @return String header style 139 * @see org.kuali.rice.krad.uif.Component.getStyle() 140 */ 141 public String getHeaderStyle() { 142 return this.headerStyle; 143 } 144 145 /** 146 * Setter for the header style 147 * 148 * @param headerStyle 149 */ 150 public void setHeaderStyle(String headerStyle) { 151 this.headerStyle = headerStyle; 152 } 153 154 /** 155 * Style class that should be applied to the header div 156 * 157 * <p> 158 * Note the style class given here applies to the div surrounding the header tag only 159 * </p> 160 * 161 * @return String style class 162 * @see org.kuali.rice.krad.uif.Component.getStyleClasses() 163 */ 164 public String getHeaderDivStyleClasses() { 165 return headerDivStyleClasses; 166 } 167 168 /** 169 * Setter for the header div class 170 * 171 * @param headerStyleClasses 172 */ 173 public void setHeaderDivStyleClasses(String headerDivStyleClasses) { 174 this.headerDivStyleClasses = headerDivStyleClasses; 175 } 176 177 /** 178 * Style that should be applied to the header div 179 * 180 * <p> 181 * Note the style given here applies to the div surrounding the header tag only 182 * </p> 183 * 184 * @return String header style 185 * @see org.kuali.rice.krad.uif.Component.getStyle() 186 */ 187 public String getHeaderDivStyle() { 188 return headerDivStyle; 189 } 190 191 /** 192 * Setter for the header div 193 * 194 * @param headerStyle 195 */ 196 public void setHeaderDivStyle(String headerDivStyle) { 197 this.headerDivStyle = headerDivStyle; 198 } 199 }