001 /*
002 * Copyright 2002-2004 the original author or authors.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016 package org.springframework.richclient.form.binding;
017
018 import java.util.Map;
019
020 import javax.swing.JComponent;
021
022 import org.springframework.binding.form.FormModel;
023
024 /**
025 * A Binder is responsible for creating a binding between a form model's property and
026 * a control that may be used to visualize and/or edit that property.
027 *
028 * @author Oliver Hutchison
029 */
030 public interface Binder {
031
032 /**
033 * Returns a binding between a form model's property and a control that will be
034 * created by this Binder.
035 * @param formModel the form model that this binding is for
036 * @param formModel the property that this binding is for
037 * @param context additional context that may be used by this binder.
038 * @return a Binding (never null).
039 * @throws UnsupportedOperationException if this binder is unable to create its
040 * own control
041 */
042 Binding bind(FormModel formModel, String formPropertyPath, Map context);
043
044 /**
045 * Returns a binding between a form model's property and the provided control.
046 * @param control the visual control that will be bound to the form model's property.
047 * @param formModel the form model that this binding is for
048 * @param formModel the property that this binding is for
049 * @param context additional context that may be used by this binder
050 * @return a Binding (never null).
051 * @throws UnsupportedOperationException if this binder is unable to bind the
052 * provided control or if this binder is unable to bind a provided control
053 */
054 Binding bind(JComponent control, FormModel formModel, String formPropertyPath, Map context);
055 }