org.apache.struts2.components
Class Component

java.lang.Object
  extended by org.apache.struts2.components.Component
Direct Known Subclasses:
ActionComponent, AppendIterator, Bean, Date, Else, ElseIf, I18n, If, Include, IteratorComponent, MergeIterator, OptGroup, Param, Property, Push, Set, Text, UIBean, URL

public class Component
extends java.lang.Object

Base class to extend for UI components.

This class is a good extension point when building reuseable UI components.


Field Summary
static java.lang.String COMPONENT_STACK
           
protected  java.lang.String id
           
protected  java.util.Map parameters
           
protected  com.opensymphony.xwork2.util.OgnlValueStack stack
           
 
Constructor Summary
Component(com.opensymphony.xwork2.util.OgnlValueStack stack)
          Constructor.
 
Method Summary
 void addAllParameters(java.util.Map params)
          Add's all the given parameters to this componenets own parameters.
 void addParameter(java.lang.String key, java.lang.Object value)
          Add's the given key and value to this components own parameter.
 boolean altSyntax()
          Is the altSyntax enabled? [TRUE]

See struts.properties where the altSyntax flag is defined.

 void copyParams(java.util.Map params)
          Pushes this component's parameter Map as well as the component itself on to the stack and then copies the supplied parameters over.
protected  java.lang.String determineActionURL(java.lang.String action, java.lang.String namespace, java.lang.String method, javax.servlet.http.HttpServletRequest req, javax.servlet.http.HttpServletResponse res, java.util.Map parameters, java.lang.String scheme, boolean includeContext, boolean encodeResult)
          Renders an action URL by consulting the ActionMapper.
protected  java.lang.String determineNamespace(java.lang.String namespace, com.opensymphony.xwork2.util.OgnlValueStack stack, javax.servlet.http.HttpServletRequest req)
          Determines the namespace of the current page being renderdd.
 boolean end(java.io.Writer writer, java.lang.String body)
          Callback for the end tag of this component.
protected  boolean end(java.io.Writer writer, java.lang.String body, boolean popComponentStack)
          Callback for the start tag of this component.
protected  StrutsException fieldError(java.lang.String field, java.lang.String errorMsg, java.lang.Exception e)
          Constructs?a RuntimeException based on the given information.
protected  Component findAncestor(java.lang.Class clazz)
          Finds the nearest ancestor of this component stack.
protected  java.lang.String findString(java.lang.String expr)
          Evaluates the OGNL stack to find a String value.
protected  java.lang.String findString(java.lang.String expr, java.lang.String field, java.lang.String errorMsg)
          Evaluates the OGNL stack to find a String value.
protected  java.lang.Object findValue(java.lang.String expr)
          Finds a value from the OGNL stack based on the given expression.
protected  java.lang.Object findValue(java.lang.String expr, java.lang.Class toType)
          Evaluates the OGNL stack to find an Object of the given type.
protected  java.lang.Object findValue(java.lang.String expr, java.lang.String field, java.lang.String errorMsg)
          Evaluates the OGNL stack to find an Object value.
 java.util.Stack getComponentStack()
          Get's the component stack of this component.
 java.lang.String getId()
          Get's the id for referencing element.
 java.util.Map getParameters()
          Get's the parameters.
 com.opensymphony.xwork2.util.OgnlValueStack getStack()
          Get's the OGNL value stack assoicated with this component.
protected  void popComponentStack()
          Pops the component stack.
 void setId(java.lang.String id)
          id for referencing element.
 boolean start(java.io.Writer writer)
          Callback for the start tag of this component.
protected  java.lang.String toString(java.lang.Throwable t)
          Constructs a string representation of the given exception.
 boolean usesBody()
          Overwrite to set if body shold be used.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

COMPONENT_STACK

public static final java.lang.String COMPONENT_STACK
See Also:
Constant Field Values

stack

protected com.opensymphony.xwork2.util.OgnlValueStack stack

parameters

protected java.util.Map parameters

id

protected java.lang.String id
Constructor Detail

Component

public Component(com.opensymphony.xwork2.util.OgnlValueStack stack)
Constructor.

Parameters:
stack - OGNL value stack.
Method Detail

getStack

public com.opensymphony.xwork2.util.OgnlValueStack getStack()
Get's the OGNL value stack assoicated with this component.

Returns:
the OGNL value stack assoicated with this component.

getComponentStack

public java.util.Stack getComponentStack()
Get's the component stack of this component.

Returns:
the component stack of this component, never null.

start

public boolean start(java.io.Writer writer)
Callback for the start tag of this component. Should the body be evaluated?

Parameters:
writer - the output writer.
Returns:
true if the body should be evaluated

end

public boolean end(java.io.Writer writer,
                   java.lang.String body)
Callback for the end tag of this component. Should the body be evaluated again?

NOTE: will pop component stack.

Parameters:
writer - the output writer.
body - the rendered body.
Returns:
true if the body should be evaluated again

end

protected boolean end(java.io.Writer writer,
                      java.lang.String body,
                      boolean popComponentStack)
Callback for the start tag of this component. Should the body be evaluated again?

NOTE: has a parameter to determine to pop the component stack.

Parameters:
writer - the output writer.
body - the rendered body.
popComponentStack - should the component stack be popped?
Returns:
true if the body should be evaluated again

popComponentStack

protected void popComponentStack()
Pops the component stack.


findAncestor

protected Component findAncestor(java.lang.Class clazz)
Finds the nearest ancestor of this component stack.

Parameters:
clazz - the class to look for, or if assignable from.
Returns:
the component if found, null if not.

findString

protected java.lang.String findString(java.lang.String expr)
Evaluates the OGNL stack to find a String value.

Parameters:
expr - OGNL expression.
Returns:
the String value found.

findString

protected java.lang.String findString(java.lang.String expr,
                                      java.lang.String field,
                                      java.lang.String errorMsg)
Evaluates the OGNL stack to find a String value.

If the given expression is null a error is logged and a RuntimeException is thrown constructed with a messaged based on the given field and errorMsg paramter.

Parameters:
expr - OGNL expression.
field - field name used when throwing RuntimeException.
errorMsg - error message used when throwing RuntimeException.
Returns:
the String value found.
Throws:
StrutsException - is thrown in case of expression is null.

fieldError

protected StrutsException fieldError(java.lang.String field,
                                     java.lang.String errorMsg,
                                     java.lang.Exception e)
Constructs?a RuntimeException based on the given information.

A message is constructed and logged at ERROR level before being returned as a RuntimeException.

Parameters:
field - field name used when throwing RuntimeException.
errorMsg - error message used when throwing RuntimeException.
e - the caused exception, can be null.
Returns:
the constructed StrutsException.

findValue

protected java.lang.Object findValue(java.lang.String expr)
Finds a value from the OGNL stack based on the given expression. Will always evaluate expr against stack except when expr is null. If altsyntax (%{...}) is applied, simply strip it off.

Parameters:
expr - the expression. Returns null if expr is null.
Returns:
the value, null if not found.

altSyntax

public boolean altSyntax()
Is the altSyntax enabled? [TRUE]

See struts.properties where the altSyntax flag is defined.


findValue

protected java.lang.Object findValue(java.lang.String expr,
                                     java.lang.String field,
                                     java.lang.String errorMsg)
Evaluates the OGNL stack to find an Object value.

Function just like findValue(String) except that if the given expression is null a error is logged and a RuntimeException is thrown constructed with a messaged based on the given field and errorMsg paramter.

Parameters:
expr - OGNL expression.
field - field name used when throwing RuntimeException.
errorMsg - error message used when throwing RuntimeException.
Returns:
the Object found, is never null.
Throws:
StrutsException - is thrown in case of not found in the OGNL stack, or expression is null.

findValue

protected java.lang.Object findValue(java.lang.String expr,
                                     java.lang.Class toType)
Evaluates the OGNL stack to find an Object of the given type. Will evaluate expr the portion wrapped with altSyntax (%{...}) against stack when altSyntax is on, else the whole expr is evaluated against the stack.

This method only supports the altSyntax. So this should be set to true.

Parameters:
expr - OGNL expression.
toType - the type expected to find.
Returns:
the Object found, or null if not found.

determineActionURL

protected java.lang.String determineActionURL(java.lang.String action,
                                              java.lang.String namespace,
                                              java.lang.String method,
                                              javax.servlet.http.HttpServletRequest req,
                                              javax.servlet.http.HttpServletResponse res,
                                              java.util.Map parameters,
                                              java.lang.String scheme,
                                              boolean includeContext,
                                              boolean encodeResult)
Renders an action URL by consulting the ActionMapper.

Parameters:
action - the action
namespace - the namespace
method - the method
req - HTTP request
res - HTTP response
parameters - parameters
scheme - http or https
includeContext - should the context path be included or not
encodeResult - should the url be encoded
Returns:
the action url.

determineNamespace

protected java.lang.String determineNamespace(java.lang.String namespace,
                                              com.opensymphony.xwork2.util.OgnlValueStack stack,
                                              javax.servlet.http.HttpServletRequest req)
Determines the namespace of the current page being renderdd. Useful for Form, URL, and href generations.

Parameters:
namespace - the namespace
stack - OGNL value stack
req - HTTP request
Returns:
the namepsace of the current page being rendered, is never null.

copyParams

public void copyParams(java.util.Map params)
Pushes this component's parameter Map as well as the component itself on to the stack and then copies the supplied parameters over. Because the component's parameter Map is pushed before the component itself, any key-value pair that can't be assigned to componet will be set in the parameters Map.

Parameters:
params - the parameters to copy.

toString

protected java.lang.String toString(java.lang.Throwable t)
Constructs a string representation of the given exception.

Parameters:
t - the exception
Returns:
the exception as a string.

getParameters

public java.util.Map getParameters()
Get's the parameters.

Returns:
the parameters. Is never null.

addAllParameters

public void addAllParameters(java.util.Map params)
Add's all the given parameters to this componenets own parameters.

Parameters:
params - the parameters to add.

addParameter

public void addParameter(java.lang.String key,
                         java.lang.Object value)
Add's the given key and value to this components own parameter.

If the provided key is null nothing happends. If the provided value is null any existing parameter with the given key name is removed.

Parameters:
key - the key of the new parameter to add.
value - the value assoicated with the key.

getId

public java.lang.String getId()
Get's the id for referencing element.

Returns:
the id for referencing element.

setId

public void setId(java.lang.String id)
id for referencing element. For UI and form tags it will be used as HTML id attribute


usesBody

public boolean usesBody()
Overwrite to set if body shold be used.

Returns:
always false for this component.


Copyright © 2000-2006 Apache Software Foundation. All Rights Reserved.