/** * * Copyright (c) 2006-2017, Speedment, Inc. All Rights Reserved. * * 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 com.speedment.tool.propertyeditor.item; import javafx.beans.property.Property; import javafx.collections.FXCollections; import javafx.collections.ObservableList; import javafx.scene.Node; import javafx.scene.control.ChoiceBox; import java.util.function.UnaryOperator; /** * An editor for editing a property via a ChoiceBox. * The property will bind to the ChoiceBox.valueProperty(). * * @param <T> the type of the property to edit * * @author Simon Jonasson * @since 3.0.0 */ public class ChoiceBoxItem<T> extends AbstractLabelTooltipItem { private final Property<T> currentValue; private final ObservableList<T> alternatives; /** * Creates a new ChoiceBoxItem. * <p> * The default choice will either be the first choice alternative, or the * alternative matching the current value of the property (if such as * alternative exists). Alternatives will get their name by calling toString() * on the objects in the list of alternatives * <p> * The property will bind to the ChoiceBox.valueProperty(). * * @param label the label text * @param value the property * @param alternatives list of alternatives in the choice box * @param tooltip the tooltip */ public ChoiceBoxItem( String label, Property<T> value, ObservableList<T> alternatives, String tooltip) { this(label, value, alternatives, tooltip, NO_DECORATOR); } /** * Creates a new ChoiceBoxItem. * <p> * The default choice will either be the first choice alternative, or the * alternative matching the current value of the property (if such as * alternative exists). Alternatives will get their name by calling toString() * on the objects in the list of alternatives * <p> * The property will bind to the ChoiceBox.valueProperty(). * * @param label the label text * @param value the property * @param alternatives list of alternatives in the choice box * @param tooltip the tooltip * @param decorator the editor decorator */ public ChoiceBoxItem( String label, Property<T> value, ObservableList<T> alternatives, String tooltip, UnaryOperator<Node> decorator) { super(label, tooltip, decorator); this.currentValue = value; this.alternatives = FXCollections.unmodifiableObservableList(alternatives); } @Override protected Node createUndecoratedEditor() { final ChoiceBox<T> box = new ChoiceBox<>(alternatives); final T val = currentValue.getValue(); if (alternatives.contains(val)) { box.setValue(val); } else { box.setValue(alternatives.get(0)); } currentValue.bindBidirectional(box.valueProperty()); return box; } }