Class FormComponentUpdatingBehavior
- java.lang.Object
-
- org.apache.wicket.behavior.Behavior
-
- org.apache.wicket.markup.html.form.FormComponentUpdatingBehavior
-
- All Implemented Interfaces:
Serializable
,IComponentAwareEventSink
,IRequestListener
,IComponentAwareHeaderContributor
,IClusterable
public class FormComponentUpdatingBehavior extends Behavior implements IRequestListener
A behavior to get notifications when aFormComponent
changes its value.Contrary to
AjaxFormComponentUpdatingBehavior
all notification are sent via standard HTTP requests and the full page is rendered as a response.Notification is triggered by a
change
JavaScript event - if neededgetEvent()
can be overridden to deviate from this default.Note: This behavior has limited support for
FormComponent
s outside of a form, i.e. multiple choice components (ListMultipleChoice
andRadioGroup
) will send their last selected choice only.- See Also:
onUpdate()
, Serialized Form
-
-
Constructor Summary
Constructors Constructor Description FormComponentUpdatingBehavior()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
bind(Component component)
Bind this handler to the given component.protected String
getEvent()
Which JavaScript event triggers notification.FormComponent<?>
getFormComponent()
Get the hosting component.boolean
getStatelessHint(Component component)
This method returns false if the behavior generates a callback url (for example ajax behaviors)protected boolean
getUpdateModel()
Gives the control to the application to decide whether the form component model should be updated automatically or not.protected void
onBind()
Called when the component was bound to it's host component.protected void
onError(RuntimeException e)
Hook method invoked when updating of the component resulted in an error.void
onRequest()
Called when a request is received.protected void
onUpdate()
Hook method invoked when the component is updated.void
renderHead(Component component, IHeaderResponse response)
Render to the web response whatever the component wants to contribute to the head section.-
Methods inherited from class org.apache.wicket.behavior.Behavior
afterRender, beforeRender, canCallListener, detach, isEnabled, isTemporary, onAttribute, onComponentTag, onConfigure, onEvent, onException, onRemove, onTag, unbind
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.apache.wicket.IRequestListener
rendersPage
-
-
-
-
Constructor Detail
-
FormComponentUpdatingBehavior
public FormComponentUpdatingBehavior()
-
-
Method Detail
-
getStatelessHint
public boolean getStatelessHint(Component component)
Description copied from class:Behavior
This method returns false if the behavior generates a callback url (for example ajax behaviors)- Overrides:
getStatelessHint
in classBehavior
- Parameters:
component
- the component that has this behavior coupled.- Returns:
- boolean true or false.
-
bind
public final void bind(Component component)
Description copied from class:Behavior
Bind this handler to the given component. This method is called by the host component immediately after this behavior is added to it. This method is useful if you need to do initialization based on the component it is attached and you can't wait to do it at render time. Keep in mind that if you decide to keep a reference to the host component, it is not thread safe anymore, and should thus only be used in situations where you do not reuse the behavior for multiple components.
-
onBind
protected void onBind()
Called when the component was bound to it's host component. You can get the bound host component by callinggetFormComponent()
.
-
getFormComponent
public final FormComponent<?> getFormComponent()
Get the hosting component.- Returns:
- hosting component
-
renderHead
public void renderHead(Component component, IHeaderResponse response)
Description copied from class:Behavior
Render to the web response whatever the component wants to contribute to the head section.- Specified by:
renderHead
in interfaceIComponentAwareHeaderContributor
- Overrides:
renderHead
in classBehavior
- Parameters:
component
- component which is contributing to the response. This parameter is here to give the component as the context for component-awares implementing this interfaceresponse
- Response object
-
getEvent
protected String getEvent()
Which JavaScript event triggers notification.- Returns:
change
by default
-
getUpdateModel
protected boolean getUpdateModel()
Gives the control to the application to decide whether the form component model should be updated automatically or not. Make sure to callFormComponent.valid()
additionally in case the application want to update the model manually.- Returns:
- true if the model of form component should be updated, false otherwise
-
onUpdate
protected void onUpdate()
Hook method invoked when the component is updated.Note:
onError(RuntimeException)
is called instead when processing of theFormComponent
failed with conversion or validation errors!
-
onError
protected void onError(RuntimeException e)
Hook method invoked when updating of the component resulted in an error.The
RuntimeException
will be null if it was just a validation or conversion error of the FormComponent.- Parameters:
e
- optional runtime exception
-
onRequest
public final void onRequest()
Description copied from interface:IRequestListener
Called when a request is received.- Specified by:
onRequest
in interfaceIRequestListener
-
-