I am trying to save an object in the database and trying to save it from this error Target Unreachable, 'Movimentacao' returned null, but I am initializing the Movimentacao object in MangedBean.
ManagedBean
@Named
@ViewScoped
public class PesquisaBemBean implements Serializable {
private static final long serialVersionUID = 1L;
private Movimentacao movimentacao;
@PostConstruct
public void inicializar(){
this.novo();
}
public void novo(){
this.movimentacao = new Movimentacao();
}
/*remaining code with your get and set*/
}
XHTML code to save
<p:dialog id="movimentacaoDialogo" widgetVar="movimentacaoDialogo" closable="true" header="Movimentação"
draggable="false" resizable="false" responsive="true" >
<h:form id="frmMovimentacao">
<div class="row">
<div class="col-md-4 form-group">
<p:outputLabel value="N° tombamento"/>
<p:inputText value="#{pesquisaBemBean.movimentacao.numeroTombamento}"/>
</div>
<div class="col-md-8 form-group">
<p:outputLabel value="Setor:" />
<p:selectOneMenu value="#{pesquisaBemBean.movimentacao.setor}" style="width: 100%">
<f:selectItem itemLabel="Selecione" noSelectionOption="true" />
<f:selectItems var="setor" value="#{pesquisaBemBean.setores}"
itemValue="#{setor}" itemLabel="#{setor.descricao}"/>
</p:selectOneMenu>
</div>
</div>
<div class="row">
<div class="col-md-4 form-group">
<p:outputLabel value="Estado de Concervação"/>
<p:selectOneMenu style="width: 100%" value="#{pesquisaBemBean.movimentacao.estadoConservacao}">
<f:selectItem itemLabel="Selecione" noSelectionOption="true" />
<f:selectItems var="ec" value="#{pesquisaBemBean.estadoConcervacoes}"
itemValue="#{ec}" itemLabel="#{ec.descricao}"/>
</p:selectOneMenu>
</div>
<div class="col-md-4 form-group">
<p:outputLabel value="Data"/>
<p:inputText value="#{pesquisaBemBean.movimentacao.data}"/>
</div>
<div class="col-md-12 form-group">
<p:outputLabel value="Histórico"/>
<p:inputText value="#{pesquisaBemBean.movimentacao.historico}"/>
</div>
</div>
<p:commandButton value="Salvar" oncomplete="PF('movimentacaoDialogo').hide()"
action="#{pesquisaBemBean.salvarMovimentacao}"
update=":frmMovimentacao"/>
</h:form>
</p:dialog>
I saw that the error is generated by enabling row selection from a dataTable, because I call the same Movimentacao object in the dataTable selection attribute.
DataTable
<p:dataTable id="movimentacaoTable" var="movimentacao" rows="3" value="#{pesquisaBemBean.listaMovimentacao}"
emptyMessage="Selecione um bem" paginator="true" paginatorPosition="bottom"
selectionMode="single" selection="#{pesquisaBemBean.movimentacao}" rowKey="#{movimentacao.id}">
<p:column headerText="N° tombamento">
<h:outputText value="#{movimentacao.numeroTombamento}"/>
</p:column>
<p:column headerText="Operacao">
<h:outputText value="#{movimentacao.operacao}"/>
</p:column>
</p:dataTable>
One solution I found was to create a new variable of type Movimentacao and call it in the DataTable selection. I was wondering if this is the solution or if I can use only the same variable.
error generated
INFORMAÇÕES: javax.el.PropertyNotFoundException: /bem/PesquisaBem.xhtml @128,91 value="#{pesquisaBemBean.movimentacao.setor}": Target Unreachable, 'movimentacao' returned null
javax.el.PropertyNotFoundException: /bem/PesquisaBem.xhtml @128,91 value="#{pesquisaBemBean.movimentacao.setor}": Target Unreachable, 'movimentacao' returned null
at com.sun.faces.facelets.el.TagValueExpression.getType(TagValueExpression.java:100)
at org.primefaces.renderkit.SelectRenderer.findImplicitConverter(SelectRenderer.java:199)
at org.primefaces.renderkit.SelectRenderer.getOptionAsString(SelectRenderer.java:185)
at org.primefaces.renderkit.SelectRenderer.doValidateSubmittedValues(SelectRenderer.java:341)
at org.primefaces.renderkit.SelectRenderer.validateSubmittedValues(SelectRenderer.java:310)
at org.primefaces.renderkit.SelectOneRenderer.decode(SelectOneRenderer.java:44)
at org.primefaces.component.selectonemenu.SelectOneMenuRenderer.decode(SelectOneMenuRenderer.java:78)
at javax.faces.component.UIComponentBase.decode(UIComponentBase.java:832)
at javax.faces.component.UIInput.decode(UIInput.java:771)
at javax.faces.component.UIComponentBase.processDecodes(UIComponentBase.java:1227)
at javax.faces.component.UIInput.processDecodes(UIInput.java:676)
at javax.faces.component.UIForm.processDecodes(UIForm.java:225)
at com.sun.faces.context.PartialViewContextImpl$PhaseAwareVisitCallback.visit(PartialViewContextImpl.java:573)
at com.sun.faces.component.visit.PartialVisitContext.invokeVisitCallback(PartialVisitContext.java:183)
at javax.faces.component.UIForm.visitTree(UIForm.java:381)
at javax.faces.component.UIComponent.visitTree(UIComponent.java:1700)
at javax.faces.component.UIComponent.visitTree(UIComponent.java:1700)
at javax.faces.component.UIComponent.visitTree(UIComponent.java:1700)
at com.sun.faces.context.PartialViewContextImpl.processComponents(PartialViewContextImpl.java:403)
at com.sun.faces.context.PartialViewContextImpl.processPartial(PartialViewContextImpl.java:266)
at org.primefaces.context.PrimePartialViewContext.processPartial(PrimePartialViewContext.java:63)
at javax.faces.context.PartialViewContextWrapper.processPartial(PartialViewContextWrapper.java:219)
at javax.faces.component.UIViewRoot.processDecodes(UIViewRoot.java:927)
at com.sun.faces.lifecycle.ApplyRequestValuesPhase.execute(ApplyRequestValuesPhase.java:78)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:658)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:292)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:240)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:212)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:94)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:504)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:141)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:620)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:502)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1132)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:684)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1533)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1489)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
Caused by: javax.el.PropertyNotFoundException: Target Unreachable, 'movimentacao' returned null
at org.apache.el.parser.AstValue.getTarget(AstValue.java:124)
at org.apache.el.parser.AstValue.getType(AstValue.java:58)
at org.apache.el.ValueExpressionImpl.getType(ValueExpressionImpl.java:168)
at org.jboss.weld.el.WeldValueExpression.getType(WeldValueExpression.java:93)
at com.sun.faces.facelets.el.TagValueExpression.getType(TagValueExpression.java:98)
... 47 more
library versions
Primefaces: 7.0 Jsf: 2.2.13