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.custom.document;
20  
21  import javax.faces.component.UIComponentBase;
22  
23  import org.apache.myfaces.buildtools.maven2.plugin.builder.annotation.JSFComponent;
24  import org.apache.myfaces.buildtools.maven2.plugin.builder.annotation.JSFProperty;
25  
26  /**
27   * Base class to handle the document family
28   * 
29   * @JSFComponent
30   *   tagClass = "org.apache.myfaces.custom.document.AbstractDocumentTag"
31   *   configExcluded = "true"
32   *   
33   * @author Mario Ivankovits (latest modification by $Author: skitching $)
34   * @version $Revision: 673833 $ $Date: 2008-07-03 16:58:05 -0500 (jue, 03 jul 2008) $
35   */
36  @JSFComponent(
37     tagClass = "org.apache.myfaces.custom.document.AbstractDocumentTag",
38     configExcluded = true)
39  public class AbstractDocument extends UIComponentBase
40  {
41      public static final String COMPONENT_FAMILY = "javax.faces.Data";
42  
43      public AbstractDocument(String renderType)
44      {
45          setRendererType(renderType);
46      }
47  
48      public String getFamily()
49      {
50          return COMPONENT_FAMILY;
51      }
52  
53      public void setState(String state)
54      {
55          getStateHelper().put(PropertyKeys.state, state );
56      }
57  
58      /**
59       * state="start|end". Used to demarkate the document boundaries
60       * 
61       */
62      @JSFProperty(literalOnly = true)
63      public String getState()
64      {
65          return (String)getStateHelper().get(PropertyKeys.state);
66      }
67  
68      public boolean hasState()
69      {
70          return isStartState() || isEndState();
71      }
72  
73      public boolean isStartState()
74      {
75          return "start".equals(getState());
76      }
77  
78      public boolean isEndState()
79      {
80          return "end".equals(getState());
81      }
82      
83      protected enum PropertyKeys
84      {
85          state
86      }
87  }