org.tentackle.fx.component.config.ChoiceBoxConfigurator Maven / Gradle / Ivy
/*
* Tentackle - https://tentackle.org.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*/
package org.tentackle.fx.component.config;
import javafx.scene.control.ChoiceBox;
import org.tentackle.fx.ConfiguratorService;
import org.tentackle.fx.FxControl;
/**
* Configures a ChoiceBox.
*
* @author harald
* @param the choicebox type
*/
@ConfiguratorService(ChoiceBox.class)
public class ChoiceBoxConfigurator> extends ComponentConfigurator {
@Override
public void configure(T control) {
super.configure(control);
// make change visible immediately (not only after focus lost)
control.setOnAction(e -> updateModelAndView((FxControl) control));
control.getProperties().put(PrefixSelectionFeature.ENABLED, "");
new PrefixSelectionFeature<>(control,
() -> true,
control::getItems,
control.getConverter(),
index -> control.getSelectionModel().select(index))
.configure();
}
/**
* Updates the model and the view.
* The view update will also trigger dynamic rendering such as mandatory/changeable.
*
* @param control the choicebox
*/
protected void updateModelAndView(FxControl control) {
control.updateModel();
control.updateView();
}
}