X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetFileSelector.h;h=0d048d0c20a925ea65358d2e8655fe0cc54258d0;hb=2cb4458b35ae6c9561a35b3b18dbdb673d0c12c9;hp=3b183d7031a83f71c86059d3143d45d99fd09382;hpb=abab0a0689765a60fcec0d7861a3ef7893a685fa;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_WidgetFileSelector.h b/src/ModuleBase/ModuleBase_WidgetFileSelector.h index 3b183d703..0d048d0c2 100644 --- a/src/ModuleBase/ModuleBase_WidgetFileSelector.h +++ b/src/ModuleBase/ModuleBase_WidgetFileSelector.h @@ -1,11 +1,21 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D - -/* - * ModuleBase_WidgetFileSelector.h - * - * Created on: Aug 28, 2014 - * Author: sbh - */ +// Copyright (C) 2014-2019 CEA/DEN, EDF R&D +// +// 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 +// +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// #ifndef MODULEBASE_WIDGETFILESELECTOR_H_ #define MODULEBASE_WIDGETFILESELECTOR_H_ @@ -17,8 +27,9 @@ #include #include -class QWidget; +class QFileDialog; class QLineEdit; +class QWidget; /** * \ingroup GUI @@ -27,11 +38,15 @@ class QLineEdit; * \code * * * * \endcode +* It can use following parameters: +* - id - name of object attribute +* - type - type of dialog. Possible values: open, save. */ class MODULEBASE_EXPORT ModuleBase_WidgetFileSelector : public ModuleBase_ModelWidget { @@ -39,51 +54,72 @@ class MODULEBASE_EXPORT ModuleBase_WidgetFileSelector : public ModuleBase_ModelW public: /// Constructor /// \param theParent the parent object - /// \param theData the widget configuation. The attribute of the model widget is obtained from - /// \param theParentId is Id of a parent of the current attribute + /// \param theData the widget configuration. The attribute of the model widget is obtained from ModuleBase_WidgetFileSelector(QWidget* theParent, - const Config_WidgetAPI* theData, - const std::string& theParentId); + const Config_WidgetAPI* theData); virtual ~ModuleBase_WidgetFileSelector(); - virtual bool storeValue() const; - - virtual bool restoreValue(); - - QWidget* getControl() const; - virtual QList getControls() const; /// Returns true if a file on the current path in the line edit /// exists and has supported format bool isCurrentPathValid(); - public slots: +public slots: /// Processing of path selection button press void onPathSelectionBtn(); /// Processing of path changing void onPathChanged(); - protected: - /// Returns string containing formats - QString formatsString() const; +protected: + /// Reject the current editor dialog if it is shown and returns true. + virtual bool processEscape(); + + /// Saves the internal parameters to the given feature + /// \return True in success + virtual bool storeValueCustom(); + + virtual bool restoreValueCustom(); - /// Return list of validator formats +protected: + /// Converts format to filter string + static QString formatToFilter(const QString & theFormat); + + /// Returns a short format string of theFilter string + static QString filterToShortFormat(const QString & theFilter); + + /// Returns a list of extensions from theFilter + static QStringList filterToExtensions(const QString & theFilter); + + /// Returns list of validator formats QStringList getValidatorFormats() const; - private: + /// Returns string containing formats + QString filterString() const; + + /// Add an extension to file name if the extension is not defined + /// \param theFileName a file name + /// \param theFilter a file filter + /// \return the file name with extension + static QString applyExtension(const QString& theFileName, const QString& theFilter); + +protected: /// A control for path input QLineEdit* myPathField; - - /// Container - QWidget* myMainWidget; + QFileDialog* myFileDialog; ///< started dialog /// A title of open file dialog box QString myTitle; - /// Default path - QString myDefaultPath; + /// A current format + QString mySelectedFilter; + + /// A title of open file dialog box + enum { + WFS_OPEN, ///< open file + WFS_SAVE ///< save file + } myType; ///< type of dialog }; #endif /* MODULEBASE_WIDGETFILESELECTOR_H_ */