blob: 29efde14340817c3ab2ebb5b99f853f6f436c5d2 [file] [log] [blame]
/*
* $Id$
* $Revision$
* $Date$
*
* ====================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package wicket.extensions.markup.html.repeater.data.table.filter;
import wicket.Component;
import wicket.behavior.AbstractBehavior;
import wicket.markup.ComponentTag;
import wicket.markup.html.form.Form;
import wicket.markup.html.form.FormComponent;
import wicket.markup.html.form.HiddenField;
import wicket.model.AbstractModel;
import wicket.model.IModel;
import wicket.model.Model;
/**
* A form with filter-related special functionality for its form components.
*
* @author igor
*
*/
public class FilterForm extends Form
{
private static final long serialVersionUID = 1L;
private final HiddenField hidden;
private final IFilterStateLocator locator;
/**
* @param id
* component id
* @param locator
* filter state locator
*/
public FilterForm(String id, IFilterStateLocator locator)
{
super(id, new FilterStateModel(locator));
this.locator = locator;
hidden = new HiddenField("focus-tracker", new Model());
hidden.add(new AbstractBehavior()
{
private static final long serialVersionUID = 1L;
public void onComponentTag(Component component, ComponentTag tag)
{
tag.put("id", getFocusTrackerFieldCssId());
super.onComponentTag(component, tag);
}
});
add(hidden);
}
/**
* @return css id of the hidden form input that keeps track of the focused
* input field
*/
public final String getFocusTrackerFieldCssId()
{
return hidden.getPageRelativePath();
}
/**
* @return IFilterStateLocator passed to this form
*/
public final IFilterStateLocator getStateLocator()
{
return locator;
}
/**
* Adds behaviour to the form component to allow this form to keep track of
* the component's focus which will be restored after a form submit.
*
* @param fc
* form component
*/
public final void enableFocusTracking(FormComponent fc)
{
fc.add(new AbstractBehavior()
{
private static final long serialVersionUID = 1L;
public void onComponentTag(Component component, ComponentTag tag)
{
tag.put("id", component.getPageRelativePath());
tag.put("onfocus", getFocusTrackingHandler(component));
super.onComponentTag(component, tag);
}
});
}
/**
* Returns the javascript focus handler necessary to notify the form of
* focus tracking changes on the component
*
* Useful when components want to participate in focus tracking but want to
* add the handler their own way.
*
* A unique css id is required on the form component for focus tracking to
* work.
*
* @param component
* component to
* @return the javascript focus handler necessary to notify the form of
* focus tracking changes on the component
*/
public final String getFocusTrackingHandler(Component component)
{
return ("_filter_focus(this, '" + getFocusTrackerFieldCssId() + "');");
}
/**
* Model that uses filter state locator as a passthrough for model objects
*
* @author Igor Vaynberg (ivaynberg)
*
*/
private static class FilterStateModel extends AbstractModel
{
private static final long serialVersionUID = 1L;
private IFilterStateLocator locator;
/**
* Constructor
*
* @param locator
* IFilterStateLocator implementation used to provide model
* object for this model
*/
public FilterStateModel(IFilterStateLocator locator)
{
if (locator == null)
{
throw new IllegalArgumentException("argument [locator] cannot be null");
}
this.locator = locator;
}
/**
* @see wicket.model.IModel#getNestedModel()
*/
public IModel getNestedModel()
{
return null;
}
/**
* @see wicket.model.IModel#getObject(wicket.Component)
*/
public Object getObject(Component component)
{
return locator.getFilterState();
}
/**
* @see wicket.model.IModel#setObject(wicket.Component,
* java.lang.Object)
*/
public void setObject(Component component, Object object)
{
locator.setFilterState(object);
}
}
}