/******************************************************************************* * Copyright (c) 2015, 2015 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Bruno Medeiros - initial API and implementation *******************************************************************************/ package melnorme.util.swt.components.fields; import org.eclipse.swt.SWT; import org.eclipse.swt.events.SelectionAdapter; import org.eclipse.swt.events.SelectionEvent; import org.eclipse.swt.widgets.Combo; import org.eclipse.swt.widgets.Composite; import melnorme.util.swt.SWTFactoryUtil; import melnorme.util.swt.SWTLayoutUtil; import melnorme.util.swt.SWTUtil; import melnorme.util.swt.components.LabelledFieldWidget; import melnorme.utilbox.collections.ArrayList2; import melnorme.utilbox.collections.Indexable; import melnorme.utilbox.misc.StringUtil; /** * Field for a read_only combo with a set of options. * The user can only choose from the list of options in the combo, * but the available list of options can be changed during the lifetime of the component. * * Canonicity: The field value can only be one of the values of the Combo options, or null. */ public class ComboOptionsField extends LabelledFieldWidget<String> { protected Indexable<String> fieldOptions = ArrayList2.create(); protected int comboStyle = SWT.DROP_DOWN; protected Combo combo; public ComboOptionsField(String labelText) { super(labelText, Option_AllowNull.YES, null); } public Indexable<String> getComboOptions() { return fieldOptions; } public void setFieldOptions(String... fieldOptions) { setFieldOptions(ArrayList2.create(fieldOptions)); } public void setFieldOptions(Indexable<String> fieldOptions) { this.fieldOptions = fieldOptions; //This will force the value to only the possible options String fieldValue = getEffectiveValue(getFieldValue()); setComboItems(); if(fieldValue == null && !fieldOptions.isEmpty()) { fieldValue = fieldOptions.get(0); } setFieldValue(fieldValue); } @Override protected void doSetFieldValue(String newValue) { super.doSetFieldValue(getEffectiveValue(newValue)); } public String getEffectiveValue(String newValue) { if(newValue != null) { for(String comboOption : fieldOptions) { if(newValue.equals(comboOption)) { return newValue; } } } // If newValue is not valid, try to set a valid value from possible options: if(!fieldOptions.isEmpty()) { return fieldOptions.get(0); } return null; } /* ----------------- ----------------- */ @Override public int getPreferredLayoutColumns() { return 2; } @Override protected void createContents_all(Composite topControl) { createContents_Label(topControl); createContents_Combo(topControl); } @Override protected void createContents_layout() { SWTLayoutUtil.layout2Controls(label, combo); } protected void createContents_Combo(Composite topControl) { combo = createComboControl(topControl); combo.addSelectionListener(new SelectionAdapter() { @Override public void widgetSelected(SelectionEvent e) { setFieldValueFromControl(combo.getText()); } }); setComboItems(); } protected Combo createComboControl(Composite topControl) { return SWTFactoryUtil.createCombo(topControl, comboStyle | SWT.READ_ONLY); } protected void setComboItems() { if(SWTUtil.isOkToUse(combo)) { combo.setItems(fieldOptions.toArray(String.class)); } } @Override public Combo getFieldControl() { return combo; } @Override protected void doUpdateWidgetFromValue() { String stringValue = StringUtil.asString(getFieldValue()); if(stringValue != null) { combo.setText(stringValue); } else { if(combo.getSelectionIndex() != -1) { combo.deselect(combo.getSelectionIndex()); } } } @Override protected void doSetEnabled(boolean enabled) { SWTUtil.setEnabledIfOk(getFieldControl(), enabled); } }