I have a form with 2 required input fields and a command button which shows a dialog:
The PrimeFaces ajax response puts an args
object in the JS scope which has a validationFailed
property. You could just check for that in the oncomplete
.
<p:commandButton ... oncomplete="if (args && !args.validationFailed) dialogaboutDEQ.show()" />
If you're performing validation in action method instead of in a normal validator, and you can't rework that, then you need to manually call FacesContext#validationFailed().
A different alternative is to use RequestContext#execute() inside action method to programmatically instruct PrimeFaces to execute the given piece of JS code. So, instead of the oncomplete
, you could also do this in action method:
RequestContext.getCurrentInstance().execute("dialogaboutDEQ.show()");
If the validation fails, then the action method is not invoked and then this would also not be executed.
Again a different alternative is to use the dialog's visible
attribute. Your command button is apparently updating the whole form including the dialog (even though the dialog is at its own badly declared with appendToBody="true"
which would cause it to not be inside the parent form anymore; i.e. it must have appendToBody="false"
or have its own form, but ala). You could check e.g. on FacesContext#isPostback() and FacesContext#isValidationFailed() if a successful postback is performed:
<p:dialog ... visible="#{facesContext.postback and not facesContext.validationFailed}">