/** * Copyright (C) 2001-2017 by RapidMiner and the contributors * * Complete list of developers available at our web site: * * http://rapidminer.com * * This program is free software: you can redistribute it and/or modify it under the terms of the * GNU Affero 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 * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License along with this program. * If not, see http://www.gnu.org/licenses/. */ package com.rapidminer.gui.tools.dialogs.wizards; import java.util.Collection; import java.util.Collections; import java.util.LinkedList; import javax.swing.AbstractButton; import javax.swing.JComponent; import javax.swing.event.ChangeEvent; import javax.swing.event.ChangeListener; import com.rapidminer.gui.tools.dialogs.wizards.AbstractWizard.WizardStepDirection; import com.rapidminer.tools.I18N; /** * * @author Tobias Malbrecht */ public abstract class WizardStep { private LinkedList<ChangeListener> listeners = new LinkedList<ChangeListener>(); private String i18nKey; public WizardStep(String i18nKey) { this.i18nKey = i18nKey; } private String getKey() { return "gui.dialog.step." + i18nKey; } protected String getTitle() { return I18N.getMessage(I18N.getGUIBundle(), getKey() + ".title"); } protected String getInfoText() { return I18N.getMessage(I18N.getGUIBundle(), getKey() + ".message"); } protected abstract JComponent getComponent(); protected Collection<AbstractButton> getButtons() { return Collections.<AbstractButton> emptyList(); } /** * should be called whenever a field was updated */ public void fireStateChanged() { ChangeEvent e = new ChangeEvent(this); for (ChangeListener listener : listeners) { listener.stateChanged(e); } } protected void addChangeListener(ChangeListener listener) { listeners.add(listener); } protected void removeChangeListener(ChangeListener listener) { listeners.remove(listener); } /** * is called whenever a field is updated * * @return proceed possible (settings complete?) */ protected abstract boolean canProceed(); /** * is called whenever a field is updated * * @return can go back to previous view? */ protected abstract boolean canGoBack(); /** * This method is called when the step is entered. */ protected boolean performEnteringAction(WizardStepDirection direction) { return performEnteringAction(); } /** * This method is called when the step is left. */ protected boolean performLeavingAction(WizardStepDirection direction) { return performLeavingAction(); } /** * This method is called when the step is entered. This method is deprecated since it does not * give information about the direction from where the step came. * * @param direction * TODO */ @Deprecated protected boolean performEnteringAction() { return true; } /** * This method is called when the step is left. This method is deprecated since it does not give * information about the direction in which the step goes. * * @param direction * TODO */ @Deprecated protected boolean performLeavingAction() { return true; } }