|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.kuali.rice.krad.uif.service.impl.ExpressionEvaluatorServiceImpl
public class ExpressionEvaluatorServiceImpl
Evaluates expression language statements using the Spring EL engine
Field Summary |
---|
Fields inherited from interface org.kuali.rice.krad.uif.service.ExpressionEvaluatorService |
---|
EMBEDDED_PROPERTY_NAME_ADD_INDICATOR |
Constructor Summary | |
---|---|
ExpressionEvaluatorServiceImpl()
|
Method Summary | |
---|---|
protected void |
addCustomFunctions(org.springframework.expression.spel.support.StandardEvaluationContext context)
Registers custom functions for el expressions with the given context |
boolean |
containsElPlaceholder(String value)
Indicates whether or not the given string contains the el placholder (begin and end delimiters) |
Object |
evaluateExpression(Object contextObject,
Map<String,Object> evaluationParameters,
String expressionStr)
Evaluates the given el expression against the content object and parameters, and returns the result of the evaluation |
void |
evaluateExpressionsOnConfigurable(View view,
UifDictionaryBean expressionConfigurable,
Object contextObject,
Map<String,Object> evaluationParameters)
Evaluates any el expressions that are found as a string property value for the object |
String |
evaluateExpressionTemplate(Object contextObject,
Map<String,Object> evaluationParameters,
String expressionTemplate)
Evaluates the given expression template string against the context object and map of parameters |
void |
evaluatePropertyExpression(View view,
Object contextObject,
Map<String,Object> evaluationParameters,
UifDictionaryBean expressionConfigurable,
String propertyName,
boolean removeExpression)
Evaluates the configured expression for the given property name (if not exists) on the given configurable |
protected void |
evaluatePropertyExpressions(View view,
UifDictionaryBean expressionConfigurable,
Object contextObject,
Map<String,Object> evaluationParameters)
Iterates through the keys of the property expressions map and invokes evaluatePropertyExpression(org.kuali.rice.krad.uif.view.View, Object, java.util.Map,
org.kuali.rice.krad.datadictionary.uif.UifDictionaryBean, String, boolean) |
protected void |
evaluatePropertyReplacers(View view,
UifDictionaryBean expressionConfigurable,
Object contextObject,
Map<String,Object> evaluationParameters)
Iterates through any configured PropertyReplacer instances for the component and
evaluates the given condition. |
protected static String |
getLinePathPrefixValue(Component component)
Determines the value for the UifConstants.LINE_PATH_BIND_ADJUST_PREFIX binding
prefix
based on collection group found in the component context |
String |
replaceBindingPrefixes(View view,
Object object,
String expression)
Adjusts the property expressions for a given object |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public ExpressionEvaluatorServiceImpl()
Method Detail |
---|
public void evaluateExpressionsOnConfigurable(View view, UifDictionaryBean expressionConfigurable, Object contextObject, Map<String,Object> evaluationParameters)
ExpressionEvaluatorService
Using reflection the properties for the object are retrieved and if of
String
type the corresponding value is retrieved. If the
value is not empty and contains the el placeholder see
ExpressionEvaluatorService.containsElPlaceholder(String)
then the expression is evaluated
using the given context object and parameters. The evaluated string is
then set as the new property value, or in the case of a template
(expression contained within a literal string), the expression part is
replaced in the property value.
In addition to evaluating any property expressions, any configured
PropertyReplacer
for the object are also evaluated and if a
match occurs those property replacements are made
evaluateExpressionsOnConfigurable
in interface ExpressionEvaluatorService
view
- - view instance being renderedexpressionConfigurable
- - object whose properties should be checked for expressions
and evaluatedcontextObject
- - context object for the expression evaluationsevaluationParameters
- - map of parameters that may appear in expressions, the map
key gives the parameter name that may appear in the
expression, and the map value is the object that expression
should evaluate against when that name is foundorg.kuali.rice.krad.uif.service.ExpressionEvaluatorService#evaluateExpressionsOnConfigurable(org.kuali.rice.krad.uif.view.View,
org.kuali.rice.krad.datadictionary.uif.UifDictionaryBean, java.lang.Object,
java.util.Map)
public String evaluateExpressionTemplate(Object contextObject, Map<String,Object> evaluationParameters, String expressionTemplate)
ExpressionEvaluatorService
If the template string contains one or more el placeholders (see
ExpressionEvaluatorService.containsElPlaceholder(String)
), the expression contained within
the placeholder will be evaluated and the corresponding value will be
substituted back into the property value where the placeholder occurred.
If no placeholders are found, the string will be returned unchanged
evaluateExpressionTemplate
in interface ExpressionEvaluatorService
contextObject
- - context object for the expression evaluationsevaluationParameters
- - map of parameters that may appear in expressions, the map
key gives the parameter name that may appear in the
expression, and the map value is the object that expression
should evaluate against when that name is foundexpressionTemplate
- - string that should be evaluated for el expressions
ExpressionEvaluatorService.evaluateExpressionTemplate(java.lang.Object,
java.util.Map, java.lang.String)
public void evaluatePropertyExpression(View view, Object contextObject, Map<String,Object> evaluationParameters, UifDictionaryBean expressionConfigurable, String propertyName, boolean removeExpression)
ExpressionEvaluatorService
evaluatePropertyExpression
in interface ExpressionEvaluatorService
view
- view instance the configurable is associated with, used to adjust binding prefixescontextObject
- model object containing dataevaluationParameters
- map that will be exposed as EL parametersexpressionConfigurable
- configurable object to pull and evaluate the expression onpropertyName
- name of the property whose expression should be evaluatedremoveExpression
- boolean that indicates whether the expression should be removed after evaluationorg.kuali.rice.krad.uif.service.ExpressionEvaluatorService#evaluatePropertyExpression(
org.kuali.rice.krad.uif.view.View, Object, java.util.Map,
org.kuali.rice.krad.datadictionary.uif.UifDictionaryBean, String, boolean)
public boolean containsElPlaceholder(String value)
ExpressionEvaluatorService
containsElPlaceholder
in interface ExpressionEvaluatorService
value
- - String to check for contained placeholders
ExpressionEvaluatorService.containsElPlaceholder(String)
public String replaceBindingPrefixes(View view, Object object, String expression)
ExpressionEvaluatorService
The UifConstants.NO_BIND_ADJUST_PREFIX
prefix will be removed
as this is a placeholder indicating that the property is directly on the form.
The UifConstants.FIELD_PATH_BIND_ADJUST_PREFIX
prefix will be replaced by
the object's field path - this is only applicable to DataFields. The
UifConstants.DEFAULT_PATH_BIND_ADJUST_PREFIX
prefix will be replaced
by the view's default path if it is set.
replaceBindingPrefixes
in interface ExpressionEvaluatorService
view
- - the parent view of the objectobject
- - Object to adjust property expressions onexpression
- - The expression to adjust
ExpressionEvaluatorService.replaceBindingPrefixes(org.kuali.rice.krad.uif.view.View,
Object, String)
public Object evaluateExpression(Object contextObject, Map<String,Object> evaluationParameters, String expressionStr)
ExpressionEvaluatorService
The given expression string is assumed to be one el expression and should not contain the el placeholders. The returned result depends on the evaluation and what type is returns, for instance a boolean will be return for a boolean expression, or a string for string expression
evaluateExpression
in interface ExpressionEvaluatorService
contextObject
- - context object for the expression evaluationsevaluationParameters
- - map of parameters that may appear in expressions, the map
key gives the parameter name that may appear in the
expression, and the map value is the object that expression
should evaluate against when that name is foundexpressionStr
- - el expression to evaluate
ExpressionEvaluatorService.evaluateExpression(java.lang.Object,
java.util.Map, java.lang.String)
protected void addCustomFunctions(org.springframework.expression.spel.support.StandardEvaluationContext context)
context
- - context instance to register functions toprotected void evaluatePropertyReplacers(View view, UifDictionaryBean expressionConfigurable, Object contextObject, Map<String,Object> evaluationParameters)
PropertyReplacer
instances for the component and
evaluates the given condition. If the condition is met, the replacement value is set on the
corresponding property
view
- - view instance being renderedexpressionConfigurable
- - expressionConfigurable instance with property replacers list, should be either a
component or layout
managercontextObject
- - context for el evaluationevaluationParameters
- - parameters for el evaluationprotected void evaluatePropertyExpressions(View view, UifDictionaryBean expressionConfigurable, Object contextObject, Map<String,Object> evaluationParameters)
evaluatePropertyExpression(org.kuali.rice.krad.uif.view.View, Object, java.util.Map,
org.kuali.rice.krad.datadictionary.uif.UifDictionaryBean, String, boolean)
If the expression is an el template (part static text and part expression), only the expression part will be replaced with the result. More than one expressions may be contained within the template
view
- - view instance that is being renderedexpressionConfigurable
- - object instance to evaluate expressions forcontextObject
- - object providing the default context for expressionsevaluationParameters
- - map of additional parameters that may be used within the expressionsprotected static String getLinePathPrefixValue(Component component)
UifConstants.LINE_PATH_BIND_ADJUST_PREFIX
binding
prefix
based on collection group found in the component context
component
- - component instance for which the prefix is configured on
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |