X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2b5f62a0b2db198609b45dec622a018dae37008e..4a6e4a46a356e9abf0760e2d481bbec321cc3adf:/include/wx/generic/filedlgg.h diff --git a/include/wx/generic/filedlgg.h b/include/wx/generic/filedlgg.h index 41e4ba171a..95e196c06c 100644 --- a/include/wx/generic/filedlgg.h +++ b/include/wx/generic/filedlgg.h @@ -1,6 +1,6 @@ ///////////////////////////////////////////////////////////////////////////// // Name: filedlgg.h -// Purpose: wxFileDialog +// Purpose: wxGenericFileDialog // Author: Robert Roebling // Modified by: // Created: 8/17/99 @@ -17,44 +17,56 @@ #endif #include "wx/dialog.h" +#include "wx/listctrl.h" +#include "wx/datetime.h" //----------------------------------------------------------------------------- -// data +// classes //----------------------------------------------------------------------------- -WXDLLEXPORT_DATA(extern const wxChar *)wxFileSelectorPromptStr; -WXDLLEXPORT_DATA(extern const wxChar *)wxFileSelectorDefaultWildcardStr; +class WXDLLEXPORT wxBitmapButton; +class WXDLLEXPORT wxCheckBox; +class WXDLLEXPORT wxChoice; +class WXDLLEXPORT wxFileData; +class WXDLLEXPORT wxFileCtrl; +class WXDLLEXPORT wxGenericFileDialog; +class WXDLLEXPORT wxListEvent; +class WXDLLEXPORT wxListItem; +class WXDLLEXPORT wxStaticText; +class WXDLLEXPORT wxTextCtrl; + +#if defined(__WXUNIVERSAL__)||defined(__WXGTK__)||defined(__WXX11__)||defined(__WXMGL__)||defined(__WXCOCOA__) + #define USE_GENERIC_FILEDIALOG +#endif + +#ifdef USE_GENERIC_FILEDIALOG //----------------------------------------------------------------------------- -// classes +// data //----------------------------------------------------------------------------- -class wxCheckBox; -class wxChoice; -class wxFileData; -class wxFileCtrl; -class wxFileDialog; -class wxListEvent; -class wxStaticText; -class wxTextCtrl; +WXDLLEXPORT_DATA(extern const wxChar *)wxFileSelectorPromptStr; +WXDLLEXPORT_DATA(extern const wxChar *)wxFileSelectorDefaultWildcardStr; + +#endif // USE_GENERIC_FILEDIALOG //------------------------------------------------------------------------- // File selector //------------------------------------------------------------------------- -class wxFileDialog: public wxDialog +class WXDLLEXPORT wxGenericFileDialog: public wxDialog { public: - wxFileDialog() { } + wxGenericFileDialog() { } - wxFileDialog(wxWindow *parent, + wxGenericFileDialog(wxWindow *parent, const wxString& message = wxFileSelectorPromptStr, const wxString& defaultDir = _T(""), const wxString& defaultFile = _T(""), const wxString& wildCard = wxFileSelectorDefaultWildcardStr, long style = 0, const wxPoint& pos = wxDefaultPosition); - virtual ~wxFileDialog(); + virtual ~wxGenericFileDialog(); void SetMessage(const wxString& message) { SetTitle(message); } void SetPath(const wxString& path); @@ -91,9 +103,12 @@ public: void OnNew( wxCommandEvent &event ); void OnChoiceFilter( wxCommandEvent &event ); void OnTextEnter( wxCommandEvent &event ); + void OnTextChange( wxCommandEvent &event ); void OnCheck( wxCommandEvent &event ); - void HandleAction( const wxString &fn ); + virtual void HandleAction( const wxString &fn ); + + virtual void UpdateControls(); protected: // use the filter with the given index @@ -112,16 +127,39 @@ protected: wxFileCtrl *m_list; wxCheckBox *m_check; wxStaticText *m_static; + wxBitmapButton *m_upDirButton; + wxBitmapButton *m_newDirButton; private: - DECLARE_DYNAMIC_CLASS(wxFileDialog) + DECLARE_DYNAMIC_CLASS(wxGenericFileDialog) DECLARE_EVENT_TABLE() - // these variables are preserved between wxFileDialog calls + // these variables are preserved between wxGenericFileDialog calls static long ms_lastViewStyle; // list or report? static bool ms_lastShowHidden; // did we show hidden files? }; +#ifdef USE_GENERIC_FILEDIALOG + +class WXDLLEXPORT wxFileDialog: public wxGenericFileDialog +{ + DECLARE_DYNAMIC_CLASS(wxFileDialog) + +public: + wxFileDialog() {} + + wxFileDialog(wxWindow *parent, + const wxString& message = wxFileSelectorPromptStr, + const wxString& defaultDir = _T(""), + const wxString& defaultFile = _T(""), + const wxString& wildCard = wxFileSelectorDefaultWildcardStr, + long style = 0, + const wxPoint& pos = wxDefaultPosition) + :wxGenericFileDialog(parent, message, defaultDir, defaultFile, wildCard, style, pos) + { + } +}; + // File selector - backward compatibility WXDLLEXPORT wxString wxFileSelector(const wxChar *message = wxFileSelectorPromptStr, @@ -158,9 +196,138 @@ wxSaveFileSelector(const wxChar *what, const wxChar *default_name = (const wxChar *) NULL, wxWindow *parent = (wxWindow *) NULL); +#endif // USE_GENERIC_FILEDIALOG + +//----------------------------------------------------------------------------- +// wxFileData +//----------------------------------------------------------------------------- + +class WXDLLEXPORT wxFileData +{ +public: + enum fileType + { + is_file = 0x0000, + is_dir = 0x0001, + is_link = 0x0002, + is_exe = 0x0004, + is_drive = 0x0008 + }; + + wxFileData( const wxString &filePath, const wxString &fileName, + fileType type, int image_id ); + + // get the name of the file, dir, drive + wxString GetFileName() const { return m_fileName; } + // get the full path + name of the file, dir, path + wxString GetFilePath() const { return m_filePath; } + long GetSize() const { return m_size; } + // Get the type of file, either file extension or