/* $Id: GUISettingsTabInterface.java 17749 2010-01-11 18:49:17Z linus $
*******************************************************************************
* Copyright (c) 2009 Contributors - see below
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* mvw
*******************************************************************************
*
* Some portions of this file was previously release using the BSD License:
*/
// Copyright (c) 1996-2009 The Regents of the University of California. All
// Rights Reserved. Permission to use, copy, modify, and distribute this
// software and its documentation without fee, and without a written
// agreement is hereby granted, provided that the above copyright notice
// and this paragraph appear in all copies. This software program and
// documentation are copyrighted by The Regents of the University of
// California. The software program and documentation are supplied "AS
// IS", without any accompanying services from The Regents. The Regents
// does not warrant that the operation of the program will be
// uninterrupted or error-free. The end-user understands that the program
// was developed for research purposes and is advised not to rely
// exclusively on the program for any reason. IN NO EVENT SHALL THE
// UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,
// SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS,
// ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
// THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF
// SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE
// PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF
// CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
// UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
package org.argouml.application.api;
import javax.swing.JPanel;
/**
* An interface which must be implemented as the UI for
* tabs used on the settings panel.<p>
*
* Tabs will only need to load data during {@link #handleSettingsTabRefresh}
* and should only save data during {@link #handleSettingsTabSave}.
* Changes can be made during editing of the tabs, but the tab must
* be able to undo any change if requested
* through {@link #handleSettingsTabCancel}.<p>
*
* Warning: Do not access the ProjectManager in the constructor
* of classes that implement this interface! This because the
* SettingsTabs are created before an initial Project is created.
*
* @author Thierry Lach
* @since 0.9.4
* @author Linus Tolke (moved this into the GUI subsystem)
* @since 0.21.3 (it is part of the GUI subsystem)
*/
public interface GUISettingsTabInterface {
/**
* Save any fields changed.
*/
void handleSettingsTabSave();
/**
* Cancel any changes.
*/
void handleSettingsTabCancel();
/**
* Load or reload field settings.
*/
void handleSettingsTabRefresh();
/**
* Reset the settings shown to the same settings with a broader scope.
* I.e. copy settings from wider scope to narrow scope. <p>
*
* Remark:
* This shall only adapt the displayed value!
* You need a save to make the actual change.
*/
void handleResetToDefault();
/**
* Gets the unlocalized settings tab name.
*
* @return the unlocalized settings tab name
*/
String getTabKey();
/**
* Gets the JPanel which implements the tab.
*
* @return the JPanel which implements the tab
*/
JPanel getTabPanel();
} /* End interface GUISettingsTabInterface */