QGCFileDialog.h 6.52 KB
Newer Older
Don Gagne's avatar
Don Gagne committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*=====================================================================
 
 QGroundControl Open Source Ground Control Station
 
 (c) 2009 - 2014 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 
 This file is part of the QGROUNDCONTROL project
 
 QGROUNDCONTROL 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.
 
 QGROUNDCONTROL 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 QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
 
 ======================================================================*/

#ifndef QGCFILEDIALOG_H
#define QGCFILEDIALOG_H

#include <QFileDialog>

/// @file
30
///     @brief Subclass of <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html">QFileDialog</a>
Don Gagne's avatar
Don Gagne committed
31 32
///     @author Don Gagne <don@thegagnes.com>

33 34 35 36 37 38 39
/*!
     Subclass of <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html">QFileDialog</a> which re-implements the static public functions. The reason for this
     is that the <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html">QFileDialog</a> implementations of these use the native os dialogs. On OSX these
     these can intermittently hang. So instead here we use the native dialogs. It also allows
     use to catch these dialogs for unit testing.
*/

Don Gagne's avatar
Don Gagne committed
40 41 42
class QGCFileDialog : public QFileDialog {
    
public:
43 44 45 46 47 48 49 50 51 52

    //! Static helper that will return an existing directory selected by the user.
    /*!
      \param parent The parent QWidget.
      \param caption The caption displayed at the top of the dialog.
      \param dir The initial directory shown to the user.
      \param options Set the various options that affect the look and feel of the dialog.
      \return The chosen path or QString("") if none.
      \sa <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html#getExistingDirectory">QFileDialog::getExistingDirectory()</a>
    */
53 54 55 56
    static QString getExistingDirectory(QWidget* parent = 0,
                                        const QString& caption = QString(),
                                        const QString& dir = QString(),
                                        Options options = ShowDirsOnly);
Don Gagne's avatar
Don Gagne committed
57
    
58 59 60 61 62 63
    //! Static helper that invokes a File Open dialog where the user can select a file to be opened.
    /*!
      \param parent The parent QWidget.
      \param caption The caption displayed at the top of the dialog.
      \param dir The initial directory shown to the user.
      \param filter The filter used for selecting the file type.
64
      \param selectedFilter **NOT IMPLEMENTED - Set to NULL** Returns the filter that the user selected in the file dialog.
65 66 67 68
      \param options Set the various options that affect the look and feel of the dialog.
      \return The full path and filename to be opened or QString("") if none.
      \sa <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html#getOpenFileName">QFileDialog::getOpenFileName()</a>
    */
69 70 71 72 73 74
    static QString getOpenFileName(QWidget* parent = 0,
                                   const QString& caption = QString(),
                                   const QString& dir = QString(),
                                   const QString& filter = QString(),
                                   QString* selectedFilter = 0,
                                   Options options = 0);
Don Gagne's avatar
Don Gagne committed
75
    
76 77 78 79 80 81
    //! Static helper that invokes a File Open dialog where the user can select one or more files to be opened.
    /*!
      \param parent The parent QWidget.
      \param caption The caption displayed at the top of the dialog.
      \param dir The initial directory shown to the user.
      \param filter The filter used for selecting the file type.
82
      \param selectedFilter **NOT IMPLEMENTED - Set to NULL** Returns the filter that the user selected in the file dialog.
83 84 85 86
      \param options Set the various options that affect the look and feel of the dialog.
      \return A QStringList object containing zero or more files to be opened.
      \sa <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html#getOpenFileNames">QFileDialog::getOpenFileNames()</a>
    */
87 88 89 90 91 92
    static QStringList getOpenFileNames(QWidget* parent = 0,
                                        const QString& caption = QString(),
                                        const QString& dir = QString(),
                                        const QString& filter = QString(),
                                        QString* selectedFilter = 0,
                                        Options options = 0);
Don Gagne's avatar
Don Gagne committed
93
    
94 95 96 97 98 99
    //! Static helper that invokes a File Save dialog where the user can select a directory and enter a filename to be saved.
    /*!
      \param parent The parent QWidget.
      \param caption The caption displayed at the top of the dialog.
      \param dir The initial directory shown to the user.
      \param filter The filter used for selecting the file type.
100
      \param selectedFilter **NOT IMPLEMENTED - Set to NULL** Returns the filter that the user selected in the file dialog.
101 102 103 104 105
      \param options Set the various options that affect the look and feel of the dialog.
      \param defaultSuffix Specifies a string that will be added to the filename if it has no suffix already. The suffix is typically used to indicate the file type (e.g. "txt" indicates a text file).
      \return The full path and filename to be used to save the file or QString("") if none.
      \sa <a href="http://qt-project.org/doc/qt-4.8/qfiledialog.html#getSaveFileName">QFileDialog::getSaveFileName()</a>
    */
106 107 108 109 110
    static QString getSaveFileName(QWidget* parent = 0,
                                   const QString& caption = QString(),
                                   const QString& dir = QString(),
                                   const QString& filter = QString(),
                                   QString* selectedFilter = 0,
111 112
                                   Options options = 0,
                                   QString* defaultSuffix = 0);
113 114 115 116 117 118 119 120
    
private slots:
    /// @brief The exec slot is private becasue when only want QGCFileDialog users to use the static methods. Otherwise it will break
    ///         unit testing.
    int exec(void) { return QGCFileDialog::exec(); }
    
private:
    static void _validate(QString* selectedFilter, Options& options);
Don Gagne's avatar
Don Gagne committed
121 122 123 124
};


#endif