View Javadoc

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.component.Component;
20  import org.kuali.rice.krad.uif.util.ComponentFactory;
21  import org.kuali.rice.krad.uif.view.View;
22  import org.kuali.rice.krad.uif.widget.Help;
23  
24  import java.util.List;
25  
26  /**
27   * Content element that renders a HTML <code>&lt;IMG&gt;</code> tag
28   *
29   * @author Kuali Rice Team (rice.collab@kuali.org)
30   */
31  public class Image extends ContentElementBase {
32      private static final long serialVersionUID = -3911849875276940507L;
33  
34      private String source;
35      private String altText;
36      private String height;
37      private String width;
38  
39      private boolean captionHeaderPlacementAboveImage;
40  
41      private String captionHeaderText;
42      private Header captionHeader;
43  
44      private String cutlineText;
45      private Message cutlineMessage;
46  
47      public Image() {
48          super();
49  
50          altText = "";
51      }
52      
53      /**
54       * The following initialization is performed:
55       *
56       * <ul>
57       * <li>Initializes the cutline message and caption header components if necessary</li>
58       * </ul>
59       *
60       * @see org.kuali.rice.krad.uif.component.ComponentBase#performInitialization(org.kuali.rice.krad.uif.view.View,
61       *      java.lang.Object)
62       */
63      @Override
64      public void performInitialization(View view, Object model) {
65          super.performInitialization(view, model);
66  
67          if ((StringUtils.isNotBlank(captionHeaderText) || (getPropertyExpression("captionHeaderText") != null)) && (
68                  captionHeader == null)) {
69              captionHeader = ComponentFactory.getImageCaptionHeader();
70              view.assignComponentIds(captionHeader);
71          }
72  
73          if ((StringUtils.isNotBlank(cutlineText) || (getPropertyExpression("cutlineText") != null)) && (cutlineMessage
74                  == null)) {
75              cutlineMessage = ComponentFactory.getImageCutlineMessage();
76              view.assignComponentIds(cutlineMessage);
77          }
78      }
79  
80      /**
81       * Performs the final lifecycle phase for this element.
82       *
83       * <p>
84       * Performs the following steps
85       * <ul>
86       * <li>Set the caption header text on the caption header</li>
87       * <li>Set the cutline text on the cutline message</li>
88       * </ul>
89       * </p>
90       *
91       * @see Component#performFinalize(org.kuali.rice.krad.uif.view.View, java.lang.Object, org.kuali.rice.krad.uif.component.Component)
92       */
93      @Override
94      public void performFinalize(View view, Object model, Component parent) {
95          super.performFinalize(view, model, parent);
96  
97          if (StringUtils.isNotBlank(captionHeaderText)) {
98              captionHeader.setHeaderText(captionHeaderText);
99          }
100 
101         if (StringUtils.isNotBlank(cutlineText)) {
102             cutlineMessage.setMessageText(cutlineText);
103         }
104     }
105 
106     /**
107      * @see org.kuali.rice.krad.uif.component.ComponentBase#getComponentsForLifecycle()
108      */
109     @Override
110     public List<Component> getComponentsForLifecycle() {
111         List<Component> components = super.getComponentsForLifecycle();
112 
113         components.add(captionHeader);
114         components.add(cutlineMessage);
115 
116         return components;
117     }
118 
119     /**
120      * returns the URL of this image
121      *
122      * @return String containing the URL of this image.
123      */
124     public String getSource() {
125         return this.source;
126     }
127 
128     /**
129      * Sets the URL of this image
130      *
131      * @param source - String representing the URL of this image
132      */
133     public void setSource(String source) {
134         this.source = source;
135     }
136 
137     /**
138      * Provides alternate information for the image element
139      *
140      * <p>The altText property specifies an alternate text for an image. It is displayed by the browser
141      * if the image cannot be displayed.  This is especially important for accessibility, because screen
142      * readers can't understand images, but rather will read aloud the alternative text assigned to them.
143      * <br>
144      * Some best practices:
145      * <ul>
146      * <li>spacer images, bullets, and icons should have the altText set to null or the empty string. This
147      * will prevent screen readers from announcing it.</li>
148      * <li>Make the altText message as short and succinct as possible</li>
149      * <li>Describe the content of the image and nothing more</li>
150      * </ul>
151      * </p>
152      *
153      * @return a String representing alternative information about this image
154      */
155     public String getAltText() {
156         return this.altText;
157     }
158 
159     /**
160      * Sets the alternate text property for this image
161      *
162      * @param altText - a String containing the alternative information about the image
163      */
164     public void setAltText(String altText) {
165         this.altText = altText;
166     }
167 
168     /**
169      * Returns the height style attribute of this image
170      *
171      * <p>
172      * The default unit of measure is pixels.<br>
173      * It is good practice to specify both the height and width attributes for an image.
174      * If these attributes are set, the space required for the image is reserved when the page is loaded.
175      * However, without these attributes, the browser does not know the size of the image. The effect will
176      * be that the page layout will change while the images load.
177      * </p>
178      *
179      * @return String containing of the height style attribute of this image
180      */
181     public String getHeight() {
182         return this.height;
183     }
184 
185     /**
186      * Sets the height style attribute of the image.
187      *
188      * @param height - String containing the height of the image
189      */
190     public void setHeight(String height) {
191         this.height = height;
192     }
193 
194     /**
195      * Returns the width style attribute of the image
196      *
197      * <p>
198      * The default unit of measure is pixels.<br>
199      * It is good practice to specify both the height and width attributes for an image.
200      * If these attributes are set, the space required for the image is reserved when the page is loaded.
201      * However, without these attributes, the browser does not know the size of the image. The effect will
202      * be that the page layout will change while the images load.
203      * <p>
204      *
205      * @return String containing the width of this image
206      */
207     public String getWidth() {
208         return width;
209     }
210 
211     /**
212      * Sets the width style attribute of the image
213      *
214      * @param width - a String containing the width of this image
215      */
216     public void setWidth(String width) {
217         this.width = width;
218     }
219 
220     /**
221      * Retrieves the caption text for this image
222      *
223      * <p>
224      * The caption text is a headline for the picture. It may be displayed either above or below the picture.
225      * </p>
226      *
227      * @return String containing the caption
228      */
229     public String getCaptionHeaderText() {
230         return captionHeaderText;
231     }
232 
233     /**
234      * Sets the text displayed as of the caption for the picture
235      *
236      * @param captionHeaderText - String containing the caption text.
237      */
238     public void setCaptionHeaderText(String captionHeaderText) {
239         this.captionHeaderText = captionHeaderText;
240     }
241 
242     /**
243      * Retrieves the {@link Header} component used to display the caption for this image
244      *
245      * @return Header component which wraps the caption text.
246      */
247     public Header getCaptionHeader() {
248         return captionHeader;
249     }
250 
251     /**
252      * Sets the Header used to display the caption for this image
253      *
254      * @param captionHeader - Header component which wraps the caption text.
255      */
256     public void setCaptionHeader(Header captionHeader) {
257         this.captionHeader = captionHeader;
258     }
259 
260     /**
261      * Retrieves the cutline text for this image
262      *
263      * <p>
264      * The cutline text give more detailed information about the picture. Generally it describes
265      * the who, what, where, when of this image.
266      * </p>
267      *
268      * @return String containing the cutline text.
269      */
270     public String getCutlineText() {
271         return cutlineText;
272     }
273 
274     /**
275      * Sets the cutline text that describes this image
276      *
277      * @param cutlineText - String describing this image
278      */
279     public void setCutlineText(String cutlineText) {
280         this.cutlineText = cutlineText;
281     }
282 
283     /**
284      * Gets the {@link Message} component used to display the cutline.
285      *
286      * <p>
287      * Wrapping the cutline text with a Message component allows styling of the cutline text.
288      * </p>
289      *
290      * @return Message component wrapping the cutline.
291      */
292     public Message getCutlineMessage() {
293         return cutlineMessage;
294     }
295 
296     /**
297      * Sets the Message component used to display the cutline for this image
298      *
299      * @param cutlineMessage - Message
300      */
301     public void setCutlineMessage(Message cutlineMessage) {
302         this.cutlineMessage = cutlineMessage;
303     }
304 
305     /**
306      * Specifies whether the image caption is to be displayed above or below the image
307      *
308      * @return true if the caption is to be displayed above the image. false if displayed below the image.
309      */
310     public boolean isCaptionHeaderPlacementAboveImage() {
311         return captionHeaderPlacementAboveImage;
312     }
313 
314     /**
315      * Sets whether the image caption is to be displayed above or below the image
316      *
317      * @param captionHeaderPlacementAboveImage - true displays above image, false displays below image
318      */
319     public void setCaptionHeaderPlacementAboveImage(boolean captionHeaderPlacementAboveImage) {
320         this.captionHeaderPlacementAboveImage = captionHeaderPlacementAboveImage;
321     }
322 
323 }