I am not sure about the "correct" way to deal with method expressions in composite components.
My composite uses a backing class with action methods. Theses perform some default actions or delegate to an action method passed by the composite user as an attribute:
In using page:
<my:component action="#{myBean.actionMethod}" />
Composite:
<cc:interface componentType="mycomponentType">
<cc:attribute name="action" method-signature="java.lang.String action()" required="false" />
</cc:interface>
<cc:implementation>
<h:commandButton value="submit" action="#{cc.componentAction}" />
</cc:implementation>
Backing class:
@FacesComponent("mycomponentType")
public class UIMyComponent extends UINamingContainer {
public String action() {
String outcome = "";
ValueExpression ve = getValueExpression("action");
String expression = ve.getExpressionString();
FacesContext facesContext = FacesContext.getCurrentInstance();
Application application = facesContext.getApplication();
ELContext elContext = facesContext.getELContext();
ExpressionFactory expressionFactory = application .getExpressionFactory();
MethodExpression methodExpression = expressionFactory.createMethodExpression(elContext, expression, String.class, new Class[0]);
outcome = (String) methodExpression.invoke(elContext, new Object[0]);
if (outcome.equals("whatever")) {
// set another outcome
}
return outcome;
}
}
The code above is working as expected, but I find it rather bulky and it creates a ValueExpression to retrieve the method-expression from the declared "action" attribute.
UIComponentBase offers getValueExpression("attributeName")
but there is nothing similar for MethodExpressions.
So my Question is if there is a better way to evaluate MethodExpressions
declared as attributes in composite components than the code above.
Thx
Get it as attribute instead of as value expression.
So, instead of
do