annotate src/main/java/javax/faces/model/SelectItem.java @ 179:c9dec00f0f17

add "show private" to browse all function.
author Robert Casties <casties@mpiwg-berlin.mpg.de>
date Fri, 08 Jun 2018 18:59:49 +0200
parents 2e911857a759
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
jurzua
parents:
diff changeset
1 /*
jurzua
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
jurzua
parents:
diff changeset
3 *
jurzua
parents:
diff changeset
4 * Copyright (c) 1997-2010 Oracle and/or its affiliates. All rights reserved.
jurzua
parents:
diff changeset
5 *
jurzua
parents:
diff changeset
6 * The contents of this file are subject to the terms of either the GNU
jurzua
parents:
diff changeset
7 * General Public License Version 2 only ("GPL") or the Common Development
jurzua
parents:
diff changeset
8 * and Distribution License("CDDL") (collectively, the "License"). You
jurzua
parents:
diff changeset
9 * may not use this file except in compliance with the License. You can
jurzua
parents:
diff changeset
10 * obtain a copy of the License at
jurzua
parents:
diff changeset
11 * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
jurzua
parents:
diff changeset
12 * or packager/legal/LICENSE.txt. See the License for the specific
jurzua
parents:
diff changeset
13 * language governing permissions and limitations under the License.
jurzua
parents:
diff changeset
14 *
jurzua
parents:
diff changeset
15 * When distributing the software, include this License Header Notice in each
jurzua
parents:
diff changeset
16 * file and include the License file at packager/legal/LICENSE.txt.
jurzua
parents:
diff changeset
17 *
jurzua
parents:
diff changeset
18 * GPL Classpath Exception:
jurzua
parents:
diff changeset
19 * Oracle designates this particular file as subject to the "Classpath"
jurzua
parents:
diff changeset
20 * exception as provided by Oracle in the GPL Version 2 section of the License
jurzua
parents:
diff changeset
21 * file that accompanied this code.
jurzua
parents:
diff changeset
22 *
jurzua
parents:
diff changeset
23 * Modifications:
jurzua
parents:
diff changeset
24 * If applicable, add the following below the License Header, with the fields
jurzua
parents:
diff changeset
25 * enclosed by brackets [] replaced by your own identifying information:
jurzua
parents:
diff changeset
26 * "Portions Copyright [year] [name of copyright owner]"
jurzua
parents:
diff changeset
27 *
jurzua
parents:
diff changeset
28 * Contributor(s):
jurzua
parents:
diff changeset
29 * If you wish your version of this file to be governed by only the CDDL or
jurzua
parents:
diff changeset
30 * only the GPL Version 2, indicate your decision by adding "[Contributor]
jurzua
parents:
diff changeset
31 * elects to include this software in this distribution under the [CDDL or GPL
jurzua
parents:
diff changeset
32 * Version 2] license." If you don't indicate a single choice of license, a
jurzua
parents:
diff changeset
33 * recipient has the option to distribute your version of this file under
jurzua
parents:
diff changeset
34 * either the CDDL, the GPL Version 2 or to extend the choice of license to
jurzua
parents:
diff changeset
35 * its licensees as provided above. However, if you add GPL Version 2 code
jurzua
parents:
diff changeset
36 * and therefore, elected the GPL Version 2 license, then the option applies
jurzua
parents:
diff changeset
37 * only if the new code is made subject to such option by the copyright
jurzua
parents:
diff changeset
38 * holder.
jurzua
parents:
diff changeset
39 */
jurzua
parents:
diff changeset
40
jurzua
parents:
diff changeset
41 package javax.faces.model;
jurzua
parents:
diff changeset
42
jurzua
parents:
diff changeset
43
jurzua
parents:
diff changeset
44 import java.io.Serializable;
jurzua
parents:
diff changeset
45 import javax.faces.component.UISelectMany;
jurzua
parents:
diff changeset
46 import javax.faces.component.UISelectOne;
jurzua
parents:
diff changeset
47
jurzua
parents:
diff changeset
48
jurzua
parents:
diff changeset
49 /**
jurzua
parents:
diff changeset
50 * <p><strong class="changed_modified_2_0
jurzua
parents:
diff changeset
51 * changed_modified_2_0_rev_a">SelectItem</strong> represents a single
jurzua
parents:
diff changeset
52 * <em>item</em> in the list of supported <em>items</em> associated with
jurzua
parents:
diff changeset
53 * a {@link UISelectMany} or {@link UISelectOne} component.</p>
jurzua
parents:
diff changeset
54 */
jurzua
parents:
diff changeset
55
jurzua
parents:
diff changeset
56 public class SelectItem implements Serializable {
jurzua
parents:
diff changeset
57
jurzua
parents:
diff changeset
58 private static final long serialVersionUID = 876782311414654999L;
jurzua
parents:
diff changeset
59
jurzua
parents:
diff changeset
60
jurzua
parents:
diff changeset
61 // ------------------------------------------------------------ Constructors
jurzua
parents:
diff changeset
62
jurzua
parents:
diff changeset
63
jurzua
parents:
diff changeset
64 /**
jurzua
parents:
diff changeset
65 * <p>Construct a <code>SelectItem</code> with no initialized property
jurzua
parents:
diff changeset
66 * values.</p>
jurzua
parents:
diff changeset
67 */
jurzua
parents:
diff changeset
68 public SelectItem() {
jurzua
parents:
diff changeset
69
jurzua
parents:
diff changeset
70 super();
jurzua
parents:
diff changeset
71
jurzua
parents:
diff changeset
72 }
jurzua
parents:
diff changeset
73
jurzua
parents:
diff changeset
74
jurzua
parents:
diff changeset
75 /**
jurzua
parents:
diff changeset
76 * <p>Construct a <code>SelectItem</code> with the specified value. The
jurzua
parents:
diff changeset
77 * <code>label</code> property will be set to the value (converted to a
jurzua
parents:
diff changeset
78 * String, if necessary), the <code>description</code> property will be
jurzua
parents:
diff changeset
79 * set to <code>null</code>, the <code>disabled</code> property will be set to
jurzua
parents:
diff changeset
80 * <code>false</code>, and the <code>escape</code> property will be set to
jurzua
parents:
diff changeset
81 ( <code>true</code>.</p>
jurzua
parents:
diff changeset
82 *
jurzua
parents:
diff changeset
83 * @param value Value to be delivered to the model if this
jurzua
parents:
diff changeset
84 * item is selected by the user
jurzua
parents:
diff changeset
85 */
jurzua
parents:
diff changeset
86 public SelectItem(Object value) {
jurzua
parents:
diff changeset
87
jurzua
parents:
diff changeset
88 this(value, value == null ? null : value.toString(), null, false, true, false);
jurzua
parents:
diff changeset
89
jurzua
parents:
diff changeset
90 }
jurzua
parents:
diff changeset
91
jurzua
parents:
diff changeset
92
jurzua
parents:
diff changeset
93 /**
jurzua
parents:
diff changeset
94 * <p>Construct a <code>SelectItem</code> with the specified value and
jurzua
parents:
diff changeset
95 * label. The <code>description</code> property will be set to
jurzua
parents:
diff changeset
96 * <code>null</code>, the <code>disabled</code> property will be
jurzua
parents:
diff changeset
97 * set to <code>false</code>, and the <code>escape</code> property will
jurzua
parents:
diff changeset
98 * be set to <code>true</code>.</p>
jurzua
parents:
diff changeset
99 *
jurzua
parents:
diff changeset
100 * @param value Value to be delivered to the model if this
jurzua
parents:
diff changeset
101 * item is selected by the user
jurzua
parents:
diff changeset
102 * @param label Label to be rendered for this item in the response
jurzua
parents:
diff changeset
103 */
jurzua
parents:
diff changeset
104 public SelectItem(Object value, String label) {
jurzua
parents:
diff changeset
105
jurzua
parents:
diff changeset
106 this(value, label, null, false, true, false);
jurzua
parents:
diff changeset
107
jurzua
parents:
diff changeset
108 }
jurzua
parents:
diff changeset
109
jurzua
parents:
diff changeset
110
jurzua
parents:
diff changeset
111 /**
jurzua
parents:
diff changeset
112 * <p>Construct a <code>SelectItem</code> instance with the specified
jurzua
parents:
diff changeset
113 * value, label and description. This <code>disabled</code> property
jurzua
parents:
diff changeset
114 * will be set to <code>false</code>, and the <code>escape</code>
jurzua
parents:
diff changeset
115 * property will be set to <code>true</code>.</p>
jurzua
parents:
diff changeset
116 *
jurzua
parents:
diff changeset
117 * @param value Value to be delivered to the model if this
jurzua
parents:
diff changeset
118 * item is selected by the user
jurzua
parents:
diff changeset
119 * @param label Label to be rendered for this item in the response
jurzua
parents:
diff changeset
120 * @param description Description of this item, for use in tools
jurzua
parents:
diff changeset
121 */
jurzua
parents:
diff changeset
122 public SelectItem(Object value, String label, String description) {
jurzua
parents:
diff changeset
123
jurzua
parents:
diff changeset
124 this(value, label, description, false, true, false);
jurzua
parents:
diff changeset
125
jurzua
parents:
diff changeset
126 }
jurzua
parents:
diff changeset
127
jurzua
parents:
diff changeset
128
jurzua
parents:
diff changeset
129 /**
jurzua
parents:
diff changeset
130 * <p>Construct a <code>SelectItem</code> instance with the specified
jurzua
parents:
diff changeset
131 * property values. The <code>escape</code> property will be set
jurzua
parents:
diff changeset
132 * to <code>true</code>.</p>
jurzua
parents:
diff changeset
133 *
jurzua
parents:
diff changeset
134 * @param value Value to be delivered to the model if this
jurzua
parents:
diff changeset
135 * item is selected by the user
jurzua
parents:
diff changeset
136 * @param label Label to be rendered for this item in the response
jurzua
parents:
diff changeset
137 * @param description Description of this item, for use in tools
jurzua
parents:
diff changeset
138 * @param disabled Flag indicating that this option is disabled
jurzua
parents:
diff changeset
139 */
jurzua
parents:
diff changeset
140 public SelectItem(Object value, String label, String description,
jurzua
parents:
diff changeset
141 boolean disabled) {
jurzua
parents:
diff changeset
142
jurzua
parents:
diff changeset
143 this(value, label, description, disabled, true, false);
jurzua
parents:
diff changeset
144
jurzua
parents:
diff changeset
145 }
jurzua
parents:
diff changeset
146
jurzua
parents:
diff changeset
147 /**
jurzua
parents:
diff changeset
148 * <p>Construct a <code>SelectItem</code> instance with the specified
jurzua
parents:
diff changeset
149 * property values.</p>
jurzua
parents:
diff changeset
150 *
jurzua
parents:
diff changeset
151 * @param value Value to be delivered to the model if this
jurzua
parents:
diff changeset
152 * item is selected by the user
jurzua
parents:
diff changeset
153 * @param label Label to be rendered for this item in the response
jurzua
parents:
diff changeset
154 * @param description Description of this item, for use in tools
jurzua
parents:
diff changeset
155 * @param disabled Flag indicating that this option is disabled
jurzua
parents:
diff changeset
156 * @param escape Flag indicating that the text of this option should be
jurzua
parents:
diff changeset
157 * escaped when rendered.
jurzua
parents:
diff changeset
158 * @since 1.2
jurzua
parents:
diff changeset
159 */
jurzua
parents:
diff changeset
160 public SelectItem(Object value, String label, String description,
jurzua
parents:
diff changeset
161 boolean disabled, boolean escape) {
jurzua
parents:
diff changeset
162
jurzua
parents:
diff changeset
163 this(value, label, description, disabled, escape, false);
jurzua
parents:
diff changeset
164
jurzua
parents:
diff changeset
165 }
jurzua
parents:
diff changeset
166
jurzua
parents:
diff changeset
167
jurzua
parents:
diff changeset
168 /**
jurzua
parents:
diff changeset
169 * <p>Construct a <code>SelectItem</code> instance with the specified
jurzua
parents:
diff changeset
170 * property values.</p>
jurzua
parents:
diff changeset
171 *
jurzua
parents:
diff changeset
172 * @param value Value to be delivered to the model if this
jurzua
parents:
diff changeset
173 * item is selected by the user
jurzua
parents:
diff changeset
174 * @param label Label to be rendered for this item in the response
jurzua
parents:
diff changeset
175 * @param description Description of this item, for use in tools
jurzua
parents:
diff changeset
176 * @param disabled Flag indicating that this option is disabled
jurzua
parents:
diff changeset
177 * @param escape Flag indicating that the text of this option should be
jurzua
parents:
diff changeset
178 * escaped when rendered.
jurzua
parents:
diff changeset
179 * @param noSelectionOption Flag indicating that the current option is a "no selection" option
jurzua
parents:
diff changeset
180 * @since 1.2
jurzua
parents:
diff changeset
181 */
jurzua
parents:
diff changeset
182 public SelectItem(Object value, String label, String description,
jurzua
parents:
diff changeset
183 boolean disabled, boolean escape, boolean noSelectionOption) {
jurzua
parents:
diff changeset
184
jurzua
parents:
diff changeset
185 super();
jurzua
parents:
diff changeset
186 setValue(value);
jurzua
parents:
diff changeset
187 setLabel(label);
jurzua
parents:
diff changeset
188 setDescription(description);
jurzua
parents:
diff changeset
189 setDisabled(disabled);
jurzua
parents:
diff changeset
190 setEscape(escape);
jurzua
parents:
diff changeset
191 setNoSelectionOption(noSelectionOption);
jurzua
parents:
diff changeset
192
jurzua
parents:
diff changeset
193 }
jurzua
parents:
diff changeset
194
jurzua
parents:
diff changeset
195
jurzua
parents:
diff changeset
196
jurzua
parents:
diff changeset
197
jurzua
parents:
diff changeset
198 // ------------------------------------------------------ Instance Variables
jurzua
parents:
diff changeset
199
jurzua
parents:
diff changeset
200
jurzua
parents:
diff changeset
201 private String description = null;
jurzua
parents:
diff changeset
202 private boolean disabled = false;
jurzua
parents:
diff changeset
203 private String label = null;
jurzua
parents:
diff changeset
204 //@author jurzua
jurzua
parents:
diff changeset
205 private String style = null;
jurzua
parents:
diff changeset
206 @SuppressWarnings({"NonSerializableFieldInSerializableClass"})
jurzua
parents:
diff changeset
207 private Object value = null;
jurzua
parents:
diff changeset
208
jurzua
parents:
diff changeset
209
jurzua
parents:
diff changeset
210 // -------------------------------------------------------------- Properties
jurzua
parents:
diff changeset
211
jurzua
parents:
diff changeset
212
jurzua
parents:
diff changeset
213 /**
jurzua
parents:
diff changeset
214 * <p>Return a description of this item, for use in development tools.
jurzua
parents:
diff changeset
215 */
jurzua
parents:
diff changeset
216 public String getDescription() {
jurzua
parents:
diff changeset
217
jurzua
parents:
diff changeset
218 return (this.description);
jurzua
parents:
diff changeset
219
jurzua
parents:
diff changeset
220 }
jurzua
parents:
diff changeset
221
jurzua
parents:
diff changeset
222
jurzua
parents:
diff changeset
223 /**
jurzua
parents:
diff changeset
224 * <p>Set the description of this item, for use in development tools.</p>
jurzua
parents:
diff changeset
225 *
jurzua
parents:
diff changeset
226 * @param description The new description
jurzua
parents:
diff changeset
227 */
jurzua
parents:
diff changeset
228 public void setDescription(String description) {
jurzua
parents:
diff changeset
229
jurzua
parents:
diff changeset
230 this.description = description;
jurzua
parents:
diff changeset
231
jurzua
parents:
diff changeset
232 }
jurzua
parents:
diff changeset
233
jurzua
parents:
diff changeset
234
jurzua
parents:
diff changeset
235 /**
jurzua
parents:
diff changeset
236 * <p>Return the disabled flag for this item, which should modify the
jurzua
parents:
diff changeset
237 * rendered output to make this item unavailable for selection by the user
jurzua
parents:
diff changeset
238 * if set to <code>true</code>.</p>
jurzua
parents:
diff changeset
239 */
jurzua
parents:
diff changeset
240 public boolean isDisabled() {
jurzua
parents:
diff changeset
241
jurzua
parents:
diff changeset
242 return (this.disabled);
jurzua
parents:
diff changeset
243
jurzua
parents:
diff changeset
244 }
jurzua
parents:
diff changeset
245
jurzua
parents:
diff changeset
246
jurzua
parents:
diff changeset
247 /**
jurzua
parents:
diff changeset
248 * <p>Set the disabled flag for this item, which should modify the
jurzua
parents:
diff changeset
249 * rendered output to make this item unavailable for selection by the user
jurzua
parents:
diff changeset
250 * if set to <code>true</code>.</p>
jurzua
parents:
diff changeset
251 *
jurzua
parents:
diff changeset
252 * @param disabled The new disabled flag
jurzua
parents:
diff changeset
253 */
jurzua
parents:
diff changeset
254 public void setDisabled(boolean disabled) {
jurzua
parents:
diff changeset
255
jurzua
parents:
diff changeset
256 this.disabled = disabled;
jurzua
parents:
diff changeset
257
jurzua
parents:
diff changeset
258 }
jurzua
parents:
diff changeset
259
jurzua
parents:
diff changeset
260
jurzua
parents:
diff changeset
261 /**
jurzua
parents:
diff changeset
262 * <p>Return the label of this item, to be rendered visibly for the user.
jurzua
parents:
diff changeset
263 */
jurzua
parents:
diff changeset
264 public String getLabel() {
jurzua
parents:
diff changeset
265
jurzua
parents:
diff changeset
266 return (this.label);
jurzua
parents:
diff changeset
267
jurzua
parents:
diff changeset
268 }
jurzua
parents:
diff changeset
269
jurzua
parents:
diff changeset
270
jurzua
parents:
diff changeset
271 /**
jurzua
parents:
diff changeset
272 * <p>Set the label of this item, to be rendered visibly for the user.
jurzua
parents:
diff changeset
273 *
jurzua
parents:
diff changeset
274 * @param label The new label
jurzua
parents:
diff changeset
275 */
jurzua
parents:
diff changeset
276 public void setLabel(String label) {
jurzua
parents:
diff changeset
277
jurzua
parents:
diff changeset
278 this.label = label;
jurzua
parents:
diff changeset
279
jurzua
parents:
diff changeset
280 }
jurzua
parents:
diff changeset
281
jurzua
parents:
diff changeset
282
jurzua
parents:
diff changeset
283 /**
jurzua
parents:
diff changeset
284 * <p>Return the value of this item, to be delivered to the model
jurzua
parents:
diff changeset
285 * if this item is selected by the user.
jurzua
parents:
diff changeset
286 */
jurzua
parents:
diff changeset
287 public Object getValue() {
jurzua
parents:
diff changeset
288
jurzua
parents:
diff changeset
289 return (this.value);
jurzua
parents:
diff changeset
290
jurzua
parents:
diff changeset
291 }
jurzua
parents:
diff changeset
292
jurzua
parents:
diff changeset
293
jurzua
parents:
diff changeset
294 /**
jurzua
parents:
diff changeset
295 * <p>Set the value of this item, to be delivered to the model
jurzua
parents:
diff changeset
296 * if this item is selected by this user.
jurzua
parents:
diff changeset
297 *
jurzua
parents:
diff changeset
298 * @param value The new value
jurzua
parents:
diff changeset
299 *
jurzua
parents:
diff changeset
300 */
jurzua
parents:
diff changeset
301 public void setValue(Object value) {
jurzua
parents:
diff changeset
302
jurzua
parents:
diff changeset
303 this.value = value;
jurzua
parents:
diff changeset
304
jurzua
parents:
diff changeset
305 }
jurzua
parents:
diff changeset
306
jurzua
parents:
diff changeset
307 private boolean escape;
jurzua
parents:
diff changeset
308
jurzua
parents:
diff changeset
309 /**
jurzua
parents:
diff changeset
310 * <p class="changed_added_2_0_rev_a">If and only if this returns
jurzua
parents:
diff changeset
311 * <code>true</code>, the code that renders this select item must
jurzua
parents:
diff changeset
312 * escape the label using escaping syntax appropriate to the content
jurzua
parents:
diff changeset
313 * type being rendered. </p>
jurzua
parents:
diff changeset
314 *
jurzua
parents:
diff changeset
315 * @since 2.0
jurzua
parents:
diff changeset
316 */
jurzua
parents:
diff changeset
317 public boolean isEscape() {
jurzua
parents:
diff changeset
318 return this.escape;
jurzua
parents:
diff changeset
319 }
jurzua
parents:
diff changeset
320
jurzua
parents:
diff changeset
321 /**
jurzua
parents:
diff changeset
322 * <p class="changed_added_2_0_rev_a">Set the value of the escape
jurzua
parents:
diff changeset
323 * property. See {@link #isEscape}.</p>
jurzua
parents:
diff changeset
324 *
jurzua
parents:
diff changeset
325 * @since 2.0
jurzua
parents:
diff changeset
326 */
jurzua
parents:
diff changeset
327 public void setEscape(boolean escape) {
jurzua
parents:
diff changeset
328 this.escape = escape;
jurzua
parents:
diff changeset
329 }
jurzua
parents:
diff changeset
330
jurzua
parents:
diff changeset
331 private boolean noSelectionOption = false;
jurzua
parents:
diff changeset
332
jurzua
parents:
diff changeset
333 /** <p class="changed_added_2_0">Return the value of the
jurzua
parents:
diff changeset
334 * <code>noSelectionOption</code> property. If the value of this
jurzua
parents:
diff changeset
335 * property is <code>true</code>, the system interprets the option
jurzua
parents:
diff changeset
336 * represented by this <code>SelectItem</code> instance as
jurzua
parents:
diff changeset
337 * representing a "no selection" option. See {@link
jurzua
parents:
diff changeset
338 * UISelectOne#validateValue} and {@link UISelectMany#validateValue}
jurzua
parents:
diff changeset
339 * for usage.</p>
jurzua
parents:
diff changeset
340 *
jurzua
parents:
diff changeset
341 * @since 2.0
jurzua
parents:
diff changeset
342 */
jurzua
parents:
diff changeset
343
jurzua
parents:
diff changeset
344 public boolean isNoSelectionOption() {
jurzua
parents:
diff changeset
345 return noSelectionOption;
jurzua
parents:
diff changeset
346 }
jurzua
parents:
diff changeset
347
jurzua
parents:
diff changeset
348 /**
jurzua
parents:
diff changeset
349 * <p class="changed_added_2_0">Set the value of the
jurzua
parents:
diff changeset
350 * <code>noSelectionOption</code> property.</p>
jurzua
parents:
diff changeset
351 *
jurzua
parents:
diff changeset
352 * @since 2.0
jurzua
parents:
diff changeset
353 */
jurzua
parents:
diff changeset
354
jurzua
parents:
diff changeset
355 public void setNoSelectionOption(boolean noSelectionOption) {
jurzua
parents:
diff changeset
356 this.noSelectionOption = noSelectionOption;
jurzua
parents:
diff changeset
357 }
jurzua
parents:
diff changeset
358
jurzua
parents:
diff changeset
359 /**
jurzua
parents:
diff changeset
360 * @author jurzua
jurzua
parents:
diff changeset
361 */
jurzua
parents:
diff changeset
362 public void setStyle(String style){
jurzua
parents:
diff changeset
363 this.style = style;
jurzua
parents:
diff changeset
364 }
jurzua
parents:
diff changeset
365
jurzua
parents:
diff changeset
366 /**
jurzua
parents:
diff changeset
367 * @author jurzua
jurzua
parents:
diff changeset
368 */
jurzua
parents:
diff changeset
369 public String getStyle(){
jurzua
parents:
diff changeset
370 return (this.style);
jurzua
parents:
diff changeset
371 }
jurzua
parents:
diff changeset
372
jurzua
parents:
diff changeset
373 }