All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.zkoss.bind.Binder Maven / Gradle / Ivy

/* Binder.java

	Purpose:
		
	Description:
		
	History:
		Jun 22, 2011 9:54:23 AM, Created by henrichen

Copyright (C) 2011 Potix Corporation. All Rights Reserved.
*/
package org.zkoss.bind;

import java.util.Map;
import java.util.Set;

import org.zkoss.bind.sys.BindEvaluatorX;
import org.zkoss.zk.ui.Component;

/**
 * The Binder that do the data binding things.
 * @author henrichen
 * @author dennischen
 * @since 6.0.0
 */
public interface Binder {

	/**
	 * Component annotation of ZKBind
	 */
	public static final String ZKBIND = "ZKBIND"; //system binding annotation name

	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the special renderer for binding 
	 */
	public static final String RENDERER = "RENDERER"; //system renderer for binding

	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the load trigger event; meaningful only when ACCESS is "both" or "load" or not found(default to "load").
	 */
	public static final String LOAD_EVENT = "LOAD_EVENT"; //load trigger event
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the save trigger event; meaningful only when ACCESS is "both" or "save".
	 */
	public static final String SAVE_EVENT = "SAVE_EVENT"; //save trigger event
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the access direction: can be "both", "save", "load"; default to "load" if not found
	 */
	public static final String ACCESS = "ACCESS"; //access type (load|save|both), load is default
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the system converter for special properties. e.g. SelectedItem in listbox. see SelectedListitemConverter.java
	 */
	public static final String CONVERTER = "CONVERTER"; //system converter for binding
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the system validator for special properties.
	 */
	public static final String VALIDATOR = "VALIDATOR"; //system validator for binding
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the load replacement ; e.g. value of textbox, it loads to rawValue
	 */
	public static final String LOAD_REPLACEMENT = "LOAD_REPLACEMENT"; //loadreplacement of attribute
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the type of attribute for loading; e.g. rawValue of textbox is java.lang.String
	 */
	public static final String LOAD_TYPE = "LOAD_TYPE"; //expected type of attribute
	/**
	 * Attribute of {@link Binder#ZKBIND} annotation, the save replacement ; e.g. selectedItem of selectbox, it save the value selectedIndex (via converter) to bean
	 */
	public static final String SAVE_REPLACEMENT = "SAVE_REPLACEMENT"; //loadreplacement of attribute

	/**
	 * Indicates the doing command is successful.
	 * @since 8.0.1
	 */
	public static final int COMMAND_SUCCESS = 0;

	/**
	 * Indicates the doing command is failure with some validation errors.
	 * @since 8.0.1
	 */
	public static final int COMMAND_FAIL_VALIDATE = 1;

	/**
	 * Initializes the binder with a root component and viewModel object. 
	 * You should never call this if you use {@link AnnotateBinder} and zk annotation
	 * @param root root component of binder
	 * @param viewModel viewModel object
	 * @param initArgs args key-value pairs for initial, nullable
	 * @since 6.0.1
	 */
	public void init(Component root, Object viewModel, Map initArgs);

	/**
	 * Destroys the binder with a root component and viewModel object.
	 * You should never call this if you use {@link AnnotateBinder} and zk annotation
	 * @param root root component of binder
	 * @param viewModel viewModel object
	 * @since 8.5.2
	 */
	public void destroy(Component root, Object viewModel);

	/**
	 * Load the load-binding of the component. 
* By calling this method, all load-bindings in the component (including load-bindings in its descendant) will reload the value to components. * * @param comp the component to reload * @param loadinit true if should also load the init-binding */ public void loadComponent(Component comp, boolean loadinit); /** * Returns the {@link BindEvaluatorX} used by this Binder. * @return the EvaluatorX. */ public BindEvaluatorX getEvaluatorX(); /** * Add a new command binding. * @param comp the associated component * @param evtnm the associated component event name * @param commandExpr the command expression * @param commandArgs other key-value pairs pairs for command */ public void addCommandBinding(Component comp, String evtnm, String commandExpr, Map commandArgs); /** * Add a new global-command binding. * @param comp the associated component * @param evtnm the associated component event name * @param commandExpr the command expression * @param commandArgs other key-value pairs pairs for command */ public void addGlobalCommandBinding(Component comp, String evtnm, String commandExpr, Map commandArgs); /** * set template to a component property by an expression * * @param comp the associated component, must not null * @param attr the associated attribute of the component; ex label, style, must not null * @param templateExpr template expression, must not null * @param templateArgs args key-value pairs for template, nullable */ public void setTemplate(Component comp, String attr, String templateExpr, Map templateArgs); /** * init a component property by a expression, it only execute once * * @param comp the associated component, must not null * @param attr the associated attribute of the component; ex label, style, must not null * @param initExpr init expression, must not null * @param initArgs args key-value pairs for initial, nullable * @param converterExpr the converter expression, nullable * @param converterArgs args key-value pairs for converter, nullable */ public void addPropertyInitBinding(Component comp, String attr, String initExpr, Map initArgs, String converterExpr, Map converterArgs); /** * Add new property-load-bindings. * It creates a prompt|conditional property-load-binding depends on beforeCmds and afterCmds. * If both beforeCmds and afterCmds are null or empty, it create a prompt binding. * * @param comp the associated component, must not null * @param attr the associated attribute of the component; ex label, style, must not null * @param loadExpr load expression, must not null * @param beforeCmds load before these commands, the command here is not a EL expression. nullable * @param afterCmds load after these commands, the command here is not a EL expression. nullable * @param bindingArgs args key-value pairs for this binding, nullable * @param converterExpr the converter expression, nullable * @param converterArgs args key-value pairs for converter, nullable */ public void addPropertyLoadBindings(Component comp, String attr, String loadExpr, String[] beforeCmds, String[] afterCmds, Map bindingArgs, String converterExpr, Map converterArgs); /** * Add new property-save-bindings. * It creates a prompt|conditional property-save-binding depends on beforeCmds and afterCmds. * If both beforeCmds and afterCmds are null or empty, it create a prompt binding. * * @param comp the associated component, must not null * @param attr the associated attribute of the component; ex value, check, must not null * @param saveExpr save expression, nullable * @param beforeCmds save before these commands, the command here is not a EL expression. nullable * @param afterCmds save after these commands, the command here is not a EL expression. nullable * @param bindingArgs args key-value pairs for this binding, nullable * @param converterExpr the converter expression, nullable * @param converterArgs args key-value pairs for converter, nullable * @param validatorExpr the converter expression, nullable * @param validatorArgs args key-value pairs for validator, nullable */ public void addPropertySaveBindings(Component comp, String attr, String saveExpr, String[] beforeCmds, String[] afterCmds, Map bindingArgs, String converterExpr, Map converterArgs, String validatorExpr, Map validatorArgs); /** * init a component form by expression, it only execute once * * @param comp the associated component, must not null * @param id the form id, must not null * @param initExpr init expression, nullable * @param initArgs args key-value pairs for this init, nullable */ public void addFormInitBinding(Component comp, String id, String initExpr, Map initArgs); /** * Add new form-load-bindings. * It create a prompt|conditional form-load-binding depends on beforeCmds and afterCmds. * If both beforeCmds and afterCmds are null or empty, it create a prompt binding. * * @param comp the associated component, must not null * @param id the form id, must not null * @param loadExpr load expression, nullable * @param beforeCmds load before these commands, the command here is not a EL expression. nullable * @param afterCmds load after these commands, the command here is not a EL expression. nullable * @param bindingArgs args key-value pairs for this binding, nullable */ public void addFormLoadBindings(Component comp, String id, String loadExpr, String[] beforeCmds, String[] afterCmds, Map bindingArgs); /** * Add new form-save-bindings. * It create a conditional form-save-binding depends on beforeCmds and afterCmds. * Since form-save-binding is always triggered by command, if both beforeCmds and afterCmds are null or empty, it throws an exception. * * @param comp the associated component, must not null * @param id the form id, must not null * @param saveExpr save expression, nullable * @param beforeCmds save before these commands, the command here is not a EL expression. nullable * @param afterCmds save after these commands, the command here is not a EL expression. nullable * @param bindingArgs args key-value pairs for this binding, nullable * @param validatorExpr the converter expression, nullable * @param validatorArgs args key-value pairs for validator, nullable * @throws IllegalArgumentException if beforeCmds or afterCmds are both null or empty */ public void addFormSaveBindings(Component comp, String id, String saveExpr, String[] beforeCmds, String[] afterCmds, Map bindingArgs, String validatorExpr, Map validatorArgs); /** * init children of a component by an expression, it only execute once * * @param comp the associated component, must not null * @param initExpr init expression, must not null * @param initArgs args key-value pairs for initial, nullable * @param converterExpr the converter expression, nullable * @param converterArgs args key-value pairs for converter, nullable * @since 6.0.1 */ public void addChildrenInitBinding(Component comp, String initExpr, Map initArgs, String converterExpr, Map converterArgs); /** * Add new children-load-bindings. * It creates a prompt|conditional children-load-binding depends on beforeCmds and afterCmds. * If both beforeCmds and afterCmds are null or empty, it create a prompt binding. * * @param comp the associated component, must not null * @param loadExpr load expression, must not null * @param beforeCmds load before these commands, the command here is not a EL expression. nullable * @param afterCmds load after these commands, the command here is not a EL expression. nullable * @param bindingArgs args key-value pairs for this binding, nullable * @param converterExpr the converter expression, nullable * @param converterArgs args key-value pairs for converter, nullable * @since 6.0.1 */ public void addChildrenLoadBindings(Component comp, String loadExpr, String[] beforeCmds, String[] afterCmds, Map bindingArgs, String converterExpr, Map converterArgs); /** * Add a new reference-binding. * It creates an attribute as the reference of the expression in the component. * * @param comp the associated component, must not null * @param attr the name of reference that stored in the component; ex myval, must not null * @param loadExpr load expression, must not null * @param bindingArgs args key-value pairs for this binding, nullable * @since 6.0.1 */ public void addReferenceBinding(Component comp, String attr, String loadExpr, Map bindingArgs); /** * Remove all managed bindings that associated with the specified component. * @param comp */ public void removeBindings(Component comp); /** * Remove all managed bindings that associated with the specified components. * @param comps * @since 7.0.2 */ public void removeBindings(Set comps); /** * Remove all managed Binding that associated with the specified * component and attribute name, event name, or form id. * @param comp the associated component * @param key the associated attribute name, event name, or form id */ public void removeBindings(Component comp, String key); /** * Returns the _converter of the given _converter name. * @param name _converter name * @return the _converter of the given _converter name. */ public Converter getConverter(String name); /** * Returns the _validator of the given _validator name. * @param name _validator name * @return the _validator of the given _validator name. */ public Validator getValidator(String name); /** * Notify change of the property. * @param bean the backing bean object. * @param property the property of the bean that change the value */ public void notifyChange(Object bean, String property); /** * send command fired to this binder and process the command immediately * @param command command name * @param args , arguments when notifying this command, it will be passed as a arguments of execution method of vm * @return the result of the doCommand, COMMAND_SUCCESS or COMMAND_FAIL_VALIDATE (since 8.0.1) */ public int sendCommand(String command, Map args); /** * post command this binder, binder will queue the command, and fired later. * @param command command name * @param args , arguments when notifying this command, it will be passed as a arguments of execution method of vm */ public void postCommand(String command, Map args); /** * Returns associated ViewModel of this binder. * @return associated ViewModel of this binder. */ public Object getViewModel(); /** * Sets associated ViewModel of this binder. * @param viewModel the associated view model of this binder. */ public void setViewModel(Object viewModel); /** * Sets the associated phase listener to intervene the binding life cycle. * @param listener the associated phase listener. */ public void setPhaseListener(PhaseListener listener); /** * Returns associated root component of this binder. * @return associated root component of this binder. */ public Component getView(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy