All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.dua3.utility.fx.controls.InputBuilder Maven / Gradle / Ivy

There is a newer version: 15.0.2
Show newest version
package com.dua3.utility.fx.controls;

import org.jspecify.annotations.Nullable;
import com.dua3.utility.options.Arguments;
import com.dua3.utility.options.Option;
import javafx.scene.Node;
import javafx.stage.FileChooser;

import java.nio.file.Path;
import java.util.Collection;
import java.util.Optional;
import java.util.function.BiPredicate;
import java.util.function.Function;
import java.util.function.Supplier;
import java.util.function.UnaryOperator;

/**
 * A builder class for creating input controls.
 * 

* The InputBuilder class provides methods to add various types of labeled * and unlabeled input controls such as text fields, checkboxes, and combo boxes * to a UI form. It allows customization of the control's ID, label text, default * value, and validation rules. The builder pattern allows chaining of method calls * to create complex input forms with ease. * * @param the generic type of the {@link InputBuilder} */ public interface InputBuilder> { /** * Add labeled input control. * * @param the result type * @param id the control's ID * @param label the label text * @param type the result type * @param dflt supplier of default value * @param control the control * @return {@code this} */ B add( String id, String label, Class type, Supplier dflt, InputControl control ); /** * Add unlabeled input control. * * @param the result type * @param id the control's ID * @param type the result type * @param dflt supplier of default value * @param control the control * @return {@code this} */ B add( String id, Class type, Supplier dflt, InputControl control ); /** * Add labeled input control. * * @param id the node's ID * @param label the label text * @param node the node * @return {@code this} */ B addNode(String id, String label, Node node); /** * Add unlabeled input control. * * @param id the node's ID * @param node the node * @return {@code this} */ B addNode(String id, Node node); /** * Set number of columns for layout (default is 1). * * @param columns the number of columns for laying out the input controls * @return {@code this} */ B columns(int columns); /** * Add labeled string input. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @return {@code this} */ default B string( String id, String label, Supplier dflt ) { return string(id, label, dflt, s -> Optional.empty()); } /** * Add labeled string input. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @param validate validation callback, return error message if invalid, empty optional if valid * @return {@code this} */ B string( String id, String label, Supplier dflt, Function> validate ); /** * Add labeled integer input. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @return {@code this} */ default B integer( String id, String label, Supplier dflt ) { return integer(id, label, dflt, i -> Optional.empty()); } /** * Add labeled integer input. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @param validate validation callback, return error message if invalid, empty optional if valid * @return {@code this} */ B integer( String id, String label, Supplier dflt, Function> validate ); /** * Add labeled decimal input. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @return {@code this} */ default B decimal( String id, String label, Supplier dflt ) { return decimal(id, label, dflt, d -> Optional.empty()); } /** * Add labeled decimal input. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @param validate validation callback, return error message if invalid, empty optional if valid * @return {@code this} */ B decimal( String id, String label, Supplier dflt, Function> validate ); /** * Add labeled checkbox. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @param text the checkbox text * @return {@code this} */ default B checkBox( String id, String label, Supplier dflt, String text ) { return checkBox(id, label, dflt, text, b -> Optional.empty()); } /** * Creates a checkbox with the given parameters. * * @param id the ID of the checkbox * @param label the label for the checkbox * @param dflt the default value of the checkbox * @param text the text to display next to the checkbox * @param validate a function that takes a Boolean value and returns an optional validation message * @return the created checkbox */ B checkBox( String id, String label, Supplier dflt, String text, Function> validate ); /** * Add labeled combobox. * * @param the item type * @param id the ID * @param label the label text * @param dflt supplier of default value * @param cls the result class * @param items the items to choose from * @return {@code this} */ default B comboBox( String id, String label, Supplier dflt, Class cls, Collection items ) { return comboBox(id, label, dflt, cls, items, t -> Optional.empty()); } /** * Creates a comboBox widget with the given parameters. * * @param id the unique identifier for the comboBox * @param label the label to display with the comboBox * @param dflt the supplier function to provide the default value for the comboBox * @param cls the class type of the comboBox items * @param items the collection of items to populate the comboBox * @param validate the function to validate the selected item in the comboBox * @param the type of the comboBox items * @return the comboBox widget */ B comboBox( String id, String label, Supplier dflt, Class cls, Collection items, Function> validate ); /** * Adds a labeled combo box control with extended functionality. * * @param the item type * @param id the control's ID * @param label the label text * @param edit the action to be performed when an item is edited (optional) * @param add the action to be performed when a new item is added (optional) * @param remove the action to be performed when an item is removed (optional) * @param format the function to format the items in the combo box * @param dflt the supplier of the default value * @param cls the result class of the combo box items * @param items the collection of items to choose from * @return the InputBuilder instance */ default B comboBoxEx( String id, String label, @Nullable UnaryOperator<@Nullable T> edit, @Nullable Supplier<@Nullable T> add, @Nullable BiPredicate, T> remove, Function format, Supplier<@Nullable T> dflt, Class cls, Collection items ) { return comboBoxEx(id, label, edit, add, remove, format, dflt, cls, items, t -> Optional.empty()); } /** * Returns a custom combo box with the specified parameters. * * @param the type of objects in the combo box * @param id the ID of the combo box * @param label the label of the combo box * @param edit a function to modify the selected item in the combo box, or null if editing is not allowed * @param add a supplier to add a new item to the combo box, or null if adding is not allowed * @param remove a predicate to remove an item from the combo box, or null if removing is not allowed * @param format a function to format the items of the combo box as strings * @param dflt a supplier to provide a default item for the combo box * @param cls the class of objects in the combo box * @param items the collection of items to populate the combo box * @param validate a function to validate the items in the combo box and return an optional error message * @return a custom combo box with the specified parameters */ B comboBoxEx( String id, String label, @Nullable UnaryOperator edit, @Nullable Supplier add, @Nullable BiPredicate, T> remove, Function format, Supplier dflt, Class cls, Collection items, Function> validate ); /** * Add labeled list of radiobuttons. * * @param the item type * @param id the ID * @param label the label text * @param dflt supplier of default value * @param cls the result class * @param items the items to choose from * @return {@code this} */ default B radioList( String id, String label, Supplier<@Nullable T> dflt, Class cls, Collection items ) { return radioList(id, label, dflt, cls, items, (@Nullable T t) -> t != null ? Optional.empty() : Optional.of("No option selected")); } /** * Creates a radio list component. * * @param id the ID of the radio list * @param label the label text for the radio list * @param dflt a supplier that provides the default value for the radio list * @param cls the class of the items in the radio list * @param items a collection of items for the radio list * @param validate a function to validate the selected item, returning an optional error message * @param the type of items in the radio list * @return a radio list component */ B radioList( String id, String label, Supplier dflt, Class cls, Collection items, Function> validate ); /** * Add labeled pane with options. * * @param id the ID * @param label the label text * @param dflt supplier of default values * @param options supplier of options * @return {@code this} */ B options( String id, String label, Supplier dflt, Supplier>> options ); /** * Add unlabeled pane with options. *

* Note to implementers: Labels of the options should be aligned properly with labels of the input dialog. *

* * @param id the ID * @param dflt supplier of default values * @param options supplier of options * @return {@code this} */ B options( String id, Supplier dflt, Supplier>> options ); /** * Add File chooser. * * @param id the ID * @param label the label text * @param dflt supplier of default value * @param mode the mode, either {@link FileDialogMode#OPEN} or {@link FileDialogMode#SAVE} * @param existingOnly only let the user choose existing files; i.e., no new files can be created * @param filter the extension filter to use * @return {@code this} */ default B chooseFile( String id, String label, Supplier<@Nullable Path> dflt, FileDialogMode mode, boolean existingOnly, Collection filter ) { return chooseFile(id, label, dflt, mode, existingOnly, filter, FileInput.defaultValidate(mode, existingOnly)); } /** * Opens a file chooser dialog to allow the user to select a file. * * @param id The identifier for the file chooser dialog. * @param label The label to display in the file chooser dialog. * @param dflt A function that provides the default path to preselect in the file chooser dialog. * @param mode The mode of the file dialog, such as OPEN or SAVE. * @param existingOnly Whether to only allow selection of existing files. * @param filter The file filters to apply in the file chooser dialog. * @param validate A function to perform additional validation on the selected file path. * It returns an optional error message if the validation fails. * @return The selected file path wrapped in an instance of {@code B}. */ B chooseFile( String id, String label, Supplier dflt, FileDialogMode mode, boolean existingOnly, Collection filter, Function> validate ); }