QGCFileDialogController.h 1.82 KB
Newer Older
1 2
/****************************************************************************
 *
3
 * (c) 2009-2020 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
4 5 6 7 8 9 10
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/


11 12
#ifndef QGCFileDialogController_H
#define QGCFileDialogController_H
13 14 15 16 17 18

#include <QObject>
#include <QUrl>

#include "QGCLoggingCategory.h"

19
Q_DECLARE_LOGGING_CATEGORY(QGCFileDialogControllerLog)
20

21
class QGCFileDialogController : public QObject
22 23 24 25 26
{
    Q_OBJECT

public:
    /// Return all file in the specified path which match the specified extension
27
    Q_INVOKABLE QStringList getFiles(const QString& directoryPath, const QStringList& nameFilters);
28

29 30 31
    /// Returns the fully qualified file name from the specified parts.
    /// If filename has no file extension the first file extension is nameFilters is added to the filename.
    Q_INVOKABLE QString fullyQualifiedFilename(const QString& directoryPath, const QString& filename, const QStringList& nameFilters = QStringList());
32 33 34 35

    /// Check for file existence of specified fully qualified file name
    Q_INVOKABLE bool fileExists(const QString& filename);
    
36 37 38
    /// Deletes the file specified by the fully qualified file name
    Q_INVOKABLE void deleteFile(const QString& filename);

39
    Q_INVOKABLE QString urlToLocalFile(QUrl url) { return url.toLocalFile(); }
40 41 42 43 44

    /// Important: Should only be used in mobile builds where default save location cannot be changed.
    /// Returns the standard QGC location portion of a fully qualified folder path.
    /// Example: "/Users/Don/Document/QGroundControl/Missions" returns "QGroundControl/Missions"
    Q_INVOKABLE QString fullFolderPathToShortMobilePath(const QString& fullFolderPath);
45 46 47
};

#endif