com.dua3.utility.fx.controls.InputBuilder Maven / Gradle / Ivy
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
);
}