View Javadoc

1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements.  See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership.  The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License.  You may obtain a copy of the License at
9    *
10   *   http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing,
13   * software distributed under the License is distributed on an
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   * KIND, either express or implied.  See the License for the
16   * specific language governing permissions and limitations
17   * under the License.
18   */
19  package org.apache.myfaces.component.html.ext;
20  
21  import javax.faces.context.FacesContext;
22  
23  import org.apache.myfaces.buildtools.maven2.plugin.builder.annotation.JSFComponent;
24  import org.apache.myfaces.buildtools.maven2.plugin.builder.annotation.JSFProperty;
25  import org.apache.myfaces.component.DataProperties;
26  import org.apache.myfaces.component.DisplayValueOnlyAware;
27  import org.apache.myfaces.component.EscapeAware;
28  import org.apache.myfaces.component.ForceIdAware;
29  import org.apache.myfaces.component.UserRoleAware;
30  import org.apache.myfaces.component.UserRoleUtils;
31  import org.apache.myfaces.component.html.util.HtmlComponentUtils;
32  import org.apache.myfaces.shared_tomahawk.component.DisplayValueOnlyCapable;
33  import org.apache.myfaces.shared_tomahawk.component.EscapeCapable;
34  
35  /**
36   * Extends standard selectManyListbox with user role support and
37   * a valueType attribute.
38   * 
39   * Unless otherwise specified, all attributes accept static values or EL expressions.
40   * 
41   * @since 1.1.7
42   * @author Martin Marinschek (latest modification by $Author: jakobk $)
43   * @version $Revision: 955214 $ $Date: 2010-06-16 07:16:02 -0500 (Wed, 16 Jun 2010) $
44   */
45  @JSFComponent(
46      name = "t:selectManyListbox",
47      clazz = "org.apache.myfaces.component.html.ext.HtmlSelectManyListbox",
48      tagClass = "org.apache.myfaces.generated.taglib.html.ext.HtmlSelectManyListboxTag")
49  public abstract class AbstractHtmlSelectManyListbox
50          extends javax.faces.component.html.HtmlSelectManyListbox
51          implements UserRoleAware, DisplayValueOnlyCapable, EscapeCapable,
52          EscapeAware, DisplayValueOnlyAware, ForceIdAware, DataProperties
53  {
54      public static final String COMPONENT_TYPE = "org.apache.myfaces.HtmlSelectManyListbox";
55      public static final String DEFAULT_RENDERER_TYPE = "org.apache.myfaces.Listbox";
56  
57      public String getClientId(FacesContext context)
58      {
59          String clientId = HtmlComponentUtils.getClientId(this, getRenderer(context), context);
60          if (clientId == null)
61          {
62              clientId = super.getClientId(context);
63          }
64  
65          return clientId;
66      }
67      
68      public boolean isRendered()
69      {
70          if (!UserRoleUtils.isVisibleOnUserRole(this)) return false;
71          return super.isRendered();
72      }
73  
74      public boolean isSetDisplayValueOnly(){
75          return getDisplayValueOnly() != null ? true : false;  
76      }
77      
78      public boolean isDisplayValueOnly(){
79          return getDisplayValueOnly() != null ? getDisplayValueOnly().booleanValue() : false;
80      }
81      
82      public void setDisplayValueOnly(boolean displayValueOnly){
83          this.setDisplayValueOnly((Boolean) Boolean.valueOf(displayValueOnly));
84      }
85      
86      /**
87       * Specifies the value type of the selectable items. This attribute is
88       * similar to the collectionType attribute introduced in JSF 2.0. 
89       * It can be used to declare the type of the selectable items when using
90       * a Collection to store the values in the managed bean, because it is 
91       * not possible in Java to get the value type of a type-safe Collection
92       * (in contrast to arrays where this is possible). 
93       * 
94       * @since 2.0
95       */
96      @JSFProperty
97      public abstract String getValueType(); 
98  
99  }