All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.mpxj.explorer.FileSaverModel Maven / Gradle / Ivy

Go to download

Library that provides facilities to allow project information to be manipulated in Java and .Net. Supports a range of data formats: Microsoft Project Exchange (MPX), Microsoft Project (MPP,MPT), Microsoft Project Data Interchange (MSPDI XML), Microsoft Project Database (MPD), Planner (XML), Primavera (PM XML, XER, and database), Asta Powerproject (PP, MDB), Asta Easyplan (PP), Phoenix Project Manager (PPX), FastTrack Schedule (FTS), and the Standard Data Exchange Format (SDEF).

There is a newer version: 13.8.0
Show newest version
/*
 * file:       FileSaverModel.java
 * author:     Jon Iles
 * copyright:  (c) Packwood Software 2017
 * date:       2017-11-23
 */

/*
 * This library is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published by the
 * Free Software Foundation; either version 2.1 of the License, or (at your
 * option) any later version.
 *
 * This library 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 Lesser General Public
 * License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this library; if not, write to the Free Software Foundation, Inc.,
 * 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
 */

package net.sf.mpxj.explorer;

import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport;
import java.io.File;

/**
 * Implements the model component of the FileChooser MVC.
 */
public class FileSaverModel
{
   private final PropertyChangeSupport m_changeSupport = new PropertyChangeSupport(this);
   private boolean m_showDialog;
   private File m_file;
   private String m_type;
   private String[] m_extensions;

   /**
    * Retrieves the show dialog flag.
    *
    * @return show dialog flag
    */
   public boolean getShowDialog()
   {
      return m_showDialog;
   }

   /**
    * Sets the show dialog flag.
    *
    * @param showDialog show dialog flag
    */
   public void setShowDialog(boolean showDialog)
   {
      m_changeSupport.firePropertyChange("showDialog", m_showDialog, m_showDialog = showDialog);
   }

   /**
    * Retrieves the file selected by the user.
    *
    * @return file selected by the user
    */
   public File getFile()
   {
      return m_file;
   }

   /**
    * Retrieves the file type selected by the user.
    *
    * @return file type selected by the user
    */
   public String getType()
   {
      return m_type;
   }

   /**
    * Sets the file selected by the user.
    *
    * @param file file selected by the user.
    */
   public void setFile(File file)
   {
      m_changeSupport.firePropertyChange("file", m_file, m_file = file);
   }

   /**
    * Sets the file type selected by the user.
    *
    * @param type file type selected by the user.
    */
   public void setType(String type)
   {
      m_changeSupport.firePropertyChange("type", m_type, m_type = type);
   }

   /**
    * Retrieves the file extensions used by the file chooser.
    *
    * @return file extensions
    */
   public String[] getExtensions()
   {
      return m_extensions;
   }

   /**
    * Sets the file extensions used by the file chooser.
    *
    * @param extensions file extensions
    */
   public void setExtensions(String... extensions)
   {
      m_changeSupport.firePropertyChange("extensions", m_extensions, m_extensions = extensions);
   }

   /**
    * Add a property change listener.
    *
    * @param listener property change listener
    */
   public void addPropertyChangeListener(PropertyChangeListener listener)
   {
      m_changeSupport.addPropertyChangeListener(listener);
   }

   /**
    * Add a property change listener for a named property.
    *
    * @param propertyName property name
    * @param listener listener
    */
   public void addPropertyChangeListener(String propertyName, PropertyChangeListener listener)
   {
      m_changeSupport.addPropertyChangeListener(propertyName, listener);
   }

   /**
    * Remove a property change listener.
    *
    * @param listener property change listener
    */
   public void removePropertyChangeListener(PropertyChangeListener listener)
   {
      m_changeSupport.removePropertyChangeListener(listener);
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy