// $Id: ActionSaveProject.java 127 2010-09-25 22:23:13Z marcusvnac $
// Copyright (c) 1996-2007 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.uml.ui;
import java.awt.event.ActionEvent;
import javax.swing.AbstractAction;
import javax.swing.Action;
import javax.swing.Icon;
//#if defined(LOGGING)
//@#$LPS-LOGGING:GranularityType:Import
import org.apache.log4j.Logger;
//#endif
import org.argouml.application.helpers.ResourceLoaderWrapper;
import org.argouml.i18n.Translator;
import org.argouml.kernel.ProjectManager;
import org.argouml.ui.ProjectBrowser;
/**
* Action that saves the project.
*
* @see ActionOpenProject
*/
public class ActionSaveProject extends AbstractAction {
private static final long serialVersionUID = -5579548202585774293L;
//#if defined(LOGGING)
//@#$LPS-LOGGING:GranularityType:Field
/**
* Logger.
*/
private static final Logger LOG = Logger.getLogger(ActionSaveProject.class);
//#endif
/**
* The constructor.
*/
public ActionSaveProject() {
super(Translator.localize("action.save-project"),
ResourceLoaderWrapper.lookupIcon("action.save-project"));
// Set the tooltip string:
putValue(Action.SHORT_DESCRIPTION,
Translator.localize("action.save-project"));
super.setEnabled(false);
}
/**
* The constructor.
* @param name the name of the action.
* @param icon the icon to represent this action graphically.
*/
protected ActionSaveProject(String name, Icon icon) {
super(name, icon);
}
/*
* @see java.awt.event.ActionListener#actionPerformed(java.awt.event.ActionEvent)
*/
public void actionPerformed(ActionEvent e) {
//#if defined(LOGGING)
//@#$LPS-LOGGING:GranularityType:Statement
//@#$LPS-LOGGING:Localization:StartMethod
LOG.info("Performing save action");
//#endif
ProjectBrowser.getInstance().trySave(
ProjectManager.getManager().getCurrentProject() != null
&& ProjectManager.getManager().getCurrentProject()
.getURI() != null);
}
/**
* Set the enabled state of the save action. When we become enabled inform
* the user by highlighting the title bar with an asterisk. This method is
* undoable. This method is synchronized so that it can be used from any
* thread without external synchronization.
*
* @param isEnabled new state for save command
*/
@Override
public synchronized void setEnabled(final boolean isEnabled) {
if (isEnabled == this.enabled) {
return;
}
//#if defined(LOGGING)
//@#$LPS-LOGGING:GranularityType:Statement
if (LOG.isDebugEnabled()) {
if (!enabled && isEnabled) {
Throwable throwable = new Throwable();
throwable.fillInStackTrace();
LOG.debug("Save action enabled by ", throwable);
} else {
LOG.debug("Save state changed from " + enabled + " to "
+ isEnabled);
}
}
//#endif
internalSetEnabled(isEnabled);
}
/**
* Set the enabled state of this action and displays the save indicator
* @param isEnabled true to enable the action
*/
private void internalSetEnabled(boolean isEnabled) {
super.setEnabled(isEnabled);
ProjectBrowser.getInstance().showSaveIndicator();
}
}