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 selectManyMenu 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:selectManyMenu",
47      clazz = "org.apache.myfaces.component.html.ext.HtmlSelectManyMenu",
48      tagClass = "org.apache.myfaces.generated.taglib.html.ext.HtmlSelectManyMenuTag")
49  public abstract class AbstractHtmlSelectManyMenu
50          extends javax.faces.component.html.HtmlSelectManyMenu
51          implements UserRoleAware, DisplayValueOnlyCapable,
52          EscapeCapable, DisplayValueOnlyAware, EscapeAware,
53          ForceIdAware, DataProperties
54  {
55      public static final String COMPONENT_TYPE = "org.apache.myfaces.HtmlSelectManyMenu";
56      public static final String DEFAULT_RENDERER_TYPE = "org.apache.myfaces.Menu";
57      
58      public String getClientId(FacesContext context)
59      {
60          String clientId = HtmlComponentUtils.getClientId(this, getRenderer(context), context);
61          if (clientId == null)
62          {
63              clientId = super.getClientId(context);
64          }
65  
66          return clientId;
67      }
68  
69      public boolean isRendered()
70      {
71          if (!UserRoleUtils.isVisibleOnUserRole(this)) return false;
72          return super.isRendered();
73      }
74  
75      public boolean isSetDisplayValueOnly(){
76          return getDisplayValueOnly() != null ? true : false;  
77      }
78      
79      public boolean isDisplayValueOnly(){
80          return getDisplayValueOnly() != null ? getDisplayValueOnly().booleanValue() : false;
81      }
82      
83      public void setDisplayValueOnly(boolean displayValueOnly){
84          this.setDisplayValueOnly((Boolean) Boolean.valueOf(displayValueOnly));
85      }
86      
87      /**
88       * Specifies the value type of the selectable items. This attribute is
89       * similar to the collectionType attribute introduced in JSF 2.0. 
90       * It can be used to declare the type of the selectable items when using
91       * a Collection to store the values in the managed bean, because it is 
92       * not possible in Java to get the value type of a type-safe Collection
93       * (in contrast to arrays where this is possible). 
94       * 
95       * @since 2.0
96       */
97      @JSFProperty
98      public abstract String getValueType(); 
99  
100 }