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.swing;
017
018 import java.util.Map;
019
020 import javax.swing.ComboBoxEditor;
021 import javax.swing.JComboBox;
022 import javax.swing.JComponent;
023 import javax.swing.ListCellRenderer;
024
025 import org.springframework.binding.form.FormModel;
026 import org.springframework.rules.closure.Closure;
027 import org.springframework.util.Assert;
028
029 /**
030 * @author Oliver Hutchison
031 */
032 public class ComboBoxBinder extends AbstractListBinder {
033 public static final String RENDERER_KEY = "renderer";
034
035 public static final String EDITOR_KEY = "editor";
036
037 /**
038 * context key for a value which is used to mark an empty Selection. If this value is selected null will be assigned
039 * to the fields value
040 */
041 public static final String EMPTY_SELECTION_VALUE = "emptySelectionValue";
042
043 private Object renderer;
044
045 private Object editor;
046
047 private Object emptySelectionValue;
048
049 public ComboBoxBinder() {
050 this(null, new String[] { SELECTABLE_ITEMS_KEY, COMPARATOR_KEY, RENDERER_KEY, EDITOR_KEY, FILTER_KEY,
051 EMPTY_SELECTION_VALUE });
052 }
053
054 public ComboBoxBinder(String[] supportedContextKeys) {
055 this(null, supportedContextKeys);
056 }
057
058 public ComboBoxBinder(Class requiredSourceClass, String[] supportedContextKeys) {
059 super(requiredSourceClass, supportedContextKeys);
060 }
061
062 protected AbstractListBinding createListBinding(JComponent control, FormModel formModel, String formPropertyPath) {
063 Assert.isInstanceOf(JComboBox.class, control, formPropertyPath);
064 return new ComboBoxBinding((JComboBox) control, formModel, formPropertyPath, getRequiredSourceClass());
065 }
066
067 protected void applyContext(AbstractListBinding binding, Map context) {
068 super.applyContext(binding, context);
069 ComboBoxBinding comboBoxBinding = (ComboBoxBinding) binding;
070 if (context.containsKey(RENDERER_KEY)) {
071 comboBoxBinding.setRenderer((ListCellRenderer) decorate(context.get(RENDERER_KEY), comboBoxBinding
072 .getRenderer()));
073 } else if (renderer != null) {
074 comboBoxBinding.setRenderer((ListCellRenderer) decorate(renderer, comboBoxBinding.getRenderer()));
075 }
076 if (context.containsKey(EDITOR_KEY)) {
077 comboBoxBinding.setEditor((ComboBoxEditor) decorate(context.get(EDITOR_KEY), comboBoxBinding.getEditor()));
078 } else if (editor != null) {
079 comboBoxBinding.setEditor((ComboBoxEditor) decorate(editor, comboBoxBinding.getEditor()));
080 }
081 if (context.containsKey(EMPTY_SELECTION_VALUE)) {
082 comboBoxBinding.setEmptySelectionValue(context.get(EMPTY_SELECTION_VALUE));
083 } else if (emptySelectionValue != null) {
084 comboBoxBinding.setEmptySelectionValue(emptySelectionValue);
085 }
086 }
087
088 protected JComponent createControl(Map context) {
089 return getComponentFactory().createComboBox();
090 }
091
092 public void setRenderer(ListCellRenderer renderer) {
093 this.renderer = renderer;
094 }
095
096 /**
097 * Defines a closure which is called to create the renderer. The argument for the closure will be the default
098 * renderer (see {@link JComboBox#getRenderer()} of the combobox. The closure must create an instance of
099 * {@link ListCellRenderer}
100 *
101 * @param rendererClosure
102 * the closure which is used to create the renderer
103 */
104 public void setRendererClosure(Closure rendererClosure) {
105 this.renderer = rendererClosure;
106 }
107
108 public void setEditor(ComboBoxEditor editor) {
109 this.editor = editor;
110 }
111
112 /**
113 * Defines a closure which is called to create the editor. The argument for the closure will be the default editor
114 * (see {@link JComboBox#getEditor()} of the combobox. The closure must create an instance of {@link ComboBoxEditor}
115 *
116 * @param editorClosure
117 * the closure which is used to create the editor
118 */
119 public void setEditorClosure(Closure editorClosure) {
120 this.editor = editorClosure;
121 }
122
123 public Object getEmptySelectionValue() {
124 return emptySelectionValue;
125 }
126
127 public void setEmptySelectionValue(Object emptySelectionValue) {
128 this.emptySelectionValue = emptySelectionValue;
129 }
130 }