io.github.interacto.jfx.binding.api.InteractionCmdBinder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of interacto-javafx Show documentation
Show all versions of interacto-javafx Show documentation
The JavaFX implementation of the Interacto library
The newest version!
/*
* Interacto
* Copyright (C) 2020 Arnaud Blouin
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
* This program 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 General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package io.github.interacto.jfx.binding.api;
import io.github.interacto.command.Command;
import io.github.interacto.interaction.InteractionData;
import io.github.interacto.jfx.binding.JfxWidgetBinding;
import io.github.interacto.jfx.interaction.JfxInteraction;
import io.github.interacto.jfx.interaction.help.HelpAnimation;
import java.util.function.BiConsumer;
import java.util.function.BooleanSupplier;
import java.util.function.Consumer;
import java.util.function.Predicate;
import javafx.beans.property.DoubleProperty;
import javafx.beans.property.StringProperty;
import javafx.collections.ObservableList;
import javafx.scene.control.Button;
import javafx.scene.layout.Pane;
public interface InteractionCmdBinder, D extends InteractionData>
extends CmdBinderBuilder, InteractionBinderBuilder {
/**
* Specifies the initialisation of the command when the interaction starts.
* Each time the interaction starts, an instance of the command is created and configured by the given callback.
* @param initCmdFct The callback method that initialises the command.
* This callback takes as arguments both the command and interaction involved in the binding.
* @return The builder to chain the building configuration.
*/
InteractionCmdBinder first(final BiConsumer initCmdFct);
InteractionCmdBinder ifHadEffects(final BiConsumer hadEffectFct);
InteractionCmdBinder ifHadNoEffect(final BiConsumer noEffectFct);
/**
* Specifies what to do end when an interaction ends (when the last event of the interaction has occured, but just after
* the interaction is reinitialised and the command finally executed and discarded / saved).
* @param onEnd The callback method to specify what to do when an interaction ends.
* @return The builder to chain the building configuration.
*/
InteractionCmdBinder end(final BiConsumer onEnd);
@Override
InteractionCmdBinder first(final Consumer initCmdFct);
@Override
InteractionCmdBinder on(final W... widgets);
@Override
InteractionCmdBinder end(final Runnable endFct);
@Override
InteractionCmdBinder consume();
@Override
InteractionCmdBinder on(final ObservableList widgets);
@Override
InteractionCmdBinder when(final BooleanSupplier whenPredicate);
@Override
InteractionCmdBinder log(final LogLevel... level);
@Override
InteractionCmdBinder async(final Button cancel, final DoubleProperty progressProp, final StringProperty msgProp);
@Override
InteractionCmdBinder help(final HelpAnimation animation);
@Override
InteractionCmdBinder help(final Pane helpPane);
@Override
InteractionCmdBinder when(final Predicate whenPredicate);
@Override
InteractionCmdBinder end(final Consumer onEnd);
/**
* Executes the builder to create and install the binding on the instrument.
* @throws IllegalArgumentException On issues while creating the binding.
*/
JfxWidgetBinding bind();
}