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.uif.element; 17 18 import org.apache.commons.lang.StringUtils; 19 import org.kuali.rice.krad.uif.UifConstants.Position; 20 import org.kuali.rice.krad.uif.component.Component; 21 import org.kuali.rice.krad.uif.view.View; 22 23 import java.util.List; 24 25 /** 26 * Content element that renders a label 27 * 28 * <p> 29 * Contains options for adding a colon to the label along with a required message 30 * </p> 31 * 32 * @author Kuali Rice Team (rice.collab@kuali.org) 33 */ 34 public class Label extends ContentElementBase { 35 private static final long serialVersionUID = -6491546893195180114L; 36 37 private String labelText; 38 private String labelForComponentId; 39 40 private boolean renderColon; 41 42 private Position requiredMessagePlacement; 43 private Message requiredMessage; 44 45 public Label() { 46 renderColon = true; 47 48 requiredMessagePlacement = Position.LEFT; 49 } 50 51 /** 52 * The following finalization is performed: 53 * 54 * <ul> 55 * <li>If label text is blank, set render to false for field</li> 56 * 57 * @see org.kuali.rice.krad.uif.component.ComponentBase#performFinalize(org.kuali.rice.krad.uif.view.View, 58 * java.lang.Object, org.kuali.rice.krad.uif.component.Component) 59 */ 60 @Override 61 public void performFinalize(View view, Object model, Component parent) { 62 super.performFinalize(view, model, parent); 63 64 if (StringUtils.isBlank(getLabelText())) { 65 setRender(false); 66 } 67 } 68 69 /** 70 * @see org.kuali.rice.krad.uif.component.ComponentBase#getComponentsForLifecycle() 71 */ 72 @Override 73 public List<Component> getComponentsForLifecycle() { 74 List<Component> components = super.getComponentsForLifecycle(); 75 76 components.add(requiredMessage); 77 78 return components; 79 } 80 81 /** 82 * Indicates the id for the component the label applies to 83 * <p> 84 * Used for setting the labelFor attribute of the corresponding HTML 85 * element. Note this gets set automatically by the framework during the 86 * initialize phase 87 * </p> 88 * 89 * @return String component id 90 */ 91 public String getLabelForComponentId() { 92 return this.labelForComponentId; 93 } 94 95 /** 96 * Setter for the component id the label applies to 97 * 98 * @param labelForComponentId 99 */ 100 public void setLabelForComponentId(String labelForComponentId) { 101 this.labelForComponentId = labelForComponentId; 102 } 103 104 /** 105 * Text that will display as the label 106 * 107 * @return String label text 108 */ 109 public String getLabelText() { 110 return this.labelText; 111 } 112 113 /** 114 * Setter for the label text 115 * 116 * @param labelText 117 */ 118 public void setLabelText(String labelText) { 119 this.labelText = labelText; 120 } 121 122 /** 123 * Indicates whether a colon should be rendered after the label text, 124 * generally used when the label appears to the left of the field's control 125 * or value 126 * 127 * @return boolean true if a colon should be rendered, false if it should 128 * not be 129 */ 130 public boolean isRenderColon() { 131 return this.renderColon; 132 } 133 134 /** 135 * Setter for the render colon indicator 136 * 137 * @param renderColon 138 */ 139 public void setRenderColon(boolean renderColon) { 140 this.renderColon = renderColon; 141 } 142 143 /** 144 * <code>Message</code> instance that will display a required indicator 145 * 146 * <p> 147 * To indicate a field must have a value (required input) the required 148 * message field can be set to display an indicator or message along with 149 * the label. The message field also dictates the styling of the required 150 * message 151 * </p> 152 * 153 * @return Message instance 154 */ 155 public Message getRequiredMessage() { 156 return this.requiredMessage; 157 } 158 159 /** 160 * Setter for the required message field 161 * 162 * @param requiredMessage 163 */ 164 public void setRequiredMessage(Message requiredMessage) { 165 this.requiredMessage = requiredMessage; 166 } 167 168 /** 169 * Indicates where the required message field should be placed in relation 170 * to the label field, valid options are 'LEFT' and 'RIGHT' 171 * 172 * @return Position the requiredMessage placement 173 */ 174 public Position getRequiredMessagePlacement() { 175 return this.requiredMessagePlacement; 176 } 177 178 /** 179 * Setter for the required message field placement 180 * 181 * @param requiredMessagePlacement 182 */ 183 public void setRequiredMessagePlacement(Position requiredMessagePlacement) { 184 this.requiredMessagePlacement = requiredMessagePlacement; 185 } 186 187 }