Blob Blame Raw
#pragma once

#ifndef FILEFIELD_H
#define FILEFIELD_H

#include "tcommon.h"
#include <QWidget>
#include <QFileDialog>
#include "tfilepath.h"
#include "toonzqt/lineedit.h"

#undef DVAPI
#undef DVVAR
#ifdef TOONZQT_EXPORTS
#define DVAPI DV_EXPORT_API
#define DVVAR DV_EXPORT_VAR
#else
#define DVAPI DV_IMPORT_API
#define DVVAR DV_IMPORT_VAR
#endif

// forward declaration
class QPushButton;

//=============================================================================

namespace DVGui {

//=============================================================================
/*! \class DVGui::FileField
                \brief The FileField class provides an object to manage file
   browser.

                Inherits \b QWidget.

                The object FileField is composed of two part, a field \b
   LineEdit and a
                button \b QPushButton. Click button to open a directory browser
   popup
                that is used to choose a directory.
                You can set in constructor default path.
                Maximum height object is fixed to \b DVGui::WidgetHeight.
                By default dialog permit user to select only folder, but using
   setFileMode()
                you can indicate what the user may select in the file dialog,
   folder or file;
                you can also set file type using setFilters().
*/
class DVAPI FileField : public QWidget {
  Q_OBJECT

  LineEdit *m_field;
  QStringList m_filters;
  QFileDialog::FileMode m_fileMode;
  QString m_windowTitle;
  QString m_descriptionText;  // if the initial text is not path, set the string
                              // here and prevent browsing
  bool m_codePath;

protected:  // used in the child class for CleanupSettings
  QPushButton *m_fileBrowseButton;
  QString m_lastSelectedPath;

public:
  /* N.B. Vedi il commento della classe BrowserPopupController in
   * filebrowserpopup.cpp*/
  class BrowserPopupController {
  public:
    BrowserPopupController() {}
    virtual ~BrowserPopupController() {}
    virtual bool isExecute() { return true; };
    virtual QString getPath(bool codePath = true) { return QString(); };
    virtual void openPopup(QStringList, bool, QString,
                           const QWidget * = NULL){};
  };

  static BrowserPopupController *m_browserPopupController;

  FileField(QWidget *parent = 0, QString path = QString(),
            bool readOnly = false, bool doNotBrowseInitialPath = false,
            bool codePath = true);
  ~FileField() {}

  /*! Set what the user may select in the file dialog:
                  \li QFileDialog::DirectoryOnly show only directory.
                  \li QFileDialog::AnyFile, QFileDialog::ExistingFile,
     QFileDialog::Directory, QFileDialog::ExistingFiles
                                  show directory and file. */
  void setFileMode(const QFileDialog::FileMode &fileMode);
  /*! Set file type in dialog popup. */
  void setFilters(const QStringList &filters);
  void setValidator(const QValidator *v) { m_field->setValidator(v); }
  QString getPath();
  void setPath(const QString &path);
  LineEdit *getField() { return m_field; }

  static void setBrowserPopupController(BrowserPopupController *controller);
  static BrowserPopupController *getBrowserPopupController();

protected slots:
  /*! Open a static file dialog popup to browse and choose directories. If a
                  directory is seleceted and choose, set field to this
     directory. */
  // reimplemented in the "save in" filefield in CleanupSettings
  virtual void browseDirectory();

signals:
  /*!	This signal is emitted when path in field change, or by field edit or by
                  browse popup. */
  void pathChanged();
};

//-----------------------------------------------------------------------------
}  // namespace DVGui
//-----------------------------------------------------------------------------

#endif  // FILEFIELD_H