#include "wx/dialog.h"
#include "wx/listctrl.h"
+#include "wx/datetime.h"
//-----------------------------------------------------------------------------
// classes
//-----------------------------------------------------------------------------
-class wxCheckBox;
-class wxChoice;
-class wxFileData;
-class wxFileCtrl;
-class wxGenericFileDialog;
-class wxListEvent;
-class wxListItem;
-class wxStaticText;
-class wxTextCtrl;
-
-#if defined(__WXUNIVERSAL__)||defined(__WXGTK__)||defined(__WXX11__)||defined(__WXMGL__)
+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
-
-//-----------------------------------------------------------------------------
-// data
-//-----------------------------------------------------------------------------
-
-WXDLLEXPORT_DATA(extern const wxChar *)wxFileSelectorPromptStr;
-WXDLLEXPORT_DATA(extern const wxChar *)wxFileSelectorDefaultWildcardStr;
-
-#endif // USE_GENERIC_FILEDIALOG
-
//-------------------------------------------------------------------------
-// File selector
+// wxGenericFileDialog
//-------------------------------------------------------------------------
class WXDLLEXPORT wxGenericFileDialog: public wxDialog
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
wxFileCtrl *m_list;
wxCheckBox *m_check;
wxStaticText *m_static;
+ wxBitmapButton *m_upDirButton;
+ wxBitmapButton *m_newDirButton;
private:
DECLARE_DYNAMIC_CLASS(wxGenericFileDialog)
}
};
-// File selector - backward compatibility
-WXDLLEXPORT wxString
-wxFileSelector(const wxChar *message = wxFileSelectorPromptStr,
- const wxChar *default_path = NULL,
- const wxChar *default_filename = NULL,
- const wxChar *default_extension = NULL,
- const wxChar *wildcard = wxFileSelectorDefaultWildcardStr,
- int flags = 0,
- wxWindow *parent = NULL,
- int x = -1, int y = -1);
-
-// An extended version of wxFileSelector
-WXDLLEXPORT wxString
-wxFileSelectorEx(const wxChar *message = wxFileSelectorPromptStr,
- const wxChar *default_path = NULL,
- const wxChar *default_filename = NULL,
- int *indexDefaultExtension = NULL,
- const wxChar *wildcard = wxFileSelectorDefaultWildcardStr,
- int flags = 0,
- wxWindow *parent = NULL,
- int x = -1, int y = -1);
-
-// Ask for filename to load
-WXDLLEXPORT wxString
-wxLoadFileSelector(const wxChar *what,
- const wxChar *extension,
- const wxChar *default_name = (const wxChar *)NULL,
- wxWindow *parent = (wxWindow *) NULL);
-
-// Ask for filename to save
-WXDLLEXPORT wxString
-wxSaveFileSelector(const wxChar *what,
- const wxChar *extension,
- const wxChar *default_name = (const wxChar *) NULL,
- wxWindow *parent = (wxWindow *) NULL);
-
#endif // USE_GENERIC_FILEDIALOG
//-----------------------------------------------------------------------------
-// wxFileData
+// wxFileData - a class to hold the file info for the wxFileCtrl
//-----------------------------------------------------------------------------
class WXDLLEXPORT wxFileData
public:
enum fileType
{
- is_file = 0,
+ is_file = 0x0000,
is_dir = 0x0001,
is_link = 0x0002,
is_exe = 0x0004,
is_drive = 0x0008
};
- wxFileData( const wxString &name, const wxString &fname, fileType type );
- wxString GetName() const;
- wxString GetFullName() const;
- wxString GetHint() const;
+ // Full copy constructor
+ wxFileData( const wxFileData& fileData );
+ // Create a filedata from this information
+ wxFileData( const wxString &filePath, const wxString &fileName,
+ fileType type, int image_id );
+
+ // (re)read the extra data about the file from the system
+ void ReadData();
+
+ // 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; }
+ // Set the path + name and name of the item
+ void SetNewName( const wxString &filePath, const wxString &fileName );
+
+ // Get the size of the file in bytes
+ long GetSize() const { return m_size; }
+ // Get the type of file, either file extension or <DIR>, <LINK>, <DRIVE>
+ wxString GetFileType() const;
+ // get the last modification time
+ wxDateTime GetDateTime() const { return m_dateTime; }
+ // Get the time as a formatted string
+ wxString GetModificationTime() const;
+ // in UNIX get rwx for file, in MSW get attributes ARHS
+ wxString GetPermissions() const { return m_permissions; }
+ // Get the id of the image used in a wxImageList
+ int GetImageId() const { return m_image; }
+
+ bool IsFile() const { return !IsDir() && !IsLink() && !IsDrive(); }
+ bool IsDir() const { return (m_type & is_dir ) != 0; }
+ bool IsLink() const { return (m_type & is_link ) != 0; }
+ bool IsExe() const { return (m_type & is_exe ) != 0; }
+ bool IsDrive() const { return (m_type & is_drive) != 0; }
+
+ // Get/Set the type of file, file/dir/drive/link
+ int GetType() const { return m_type; }
// the wxFileCtrl fields in report view
enum fileListFieldType
{
FileList_Name,
+ FileList_Size,
FileList_Type,
- FileList_Date,
FileList_Time,
-#ifdef __UNIX__
+#if defined(__UNIX__) || defined(__WIN32__)
FileList_Perm,
-#endif // __UNIX__
+#endif // defined(__UNIX__) || defined(__WIN32__)
FileList_Max
};
+ // Get the entry for report view of wxFileCtrl
wxString GetEntry( fileListFieldType num ) const;
- bool IsDir() const;
- bool IsLink() const;
- bool IsExe() const;
- bool IsDrive() const;
- long GetSize() const { return m_size; }
- int GetHour() const { return m_hour; }
- int GetMinute() const { return m_minute; }
- int GetYear() const { return m_year; }
- int GetMonth() const { return m_month; }
- int GetDay() const { return m_day; }
-
+ // Get a string representation of the file info
+ wxString GetHint() const;
+ // initialize a wxListItem attributes
void MakeItem( wxListItem &item );
- void SetNewName( const wxString &name, const wxString &fname );
private:
- wxString m_name;
wxString m_fileName;
+ wxString m_filePath;
long m_size;
- int m_hour;
- int m_minute;
- int m_year;
- int m_month;
- int m_day;
+ wxDateTime m_dateTime;
wxString m_permissions;
int m_type;
+ int m_image;
};
//-----------------------------------------------------------------------------
const wxString &name = wxT("filelist") );
virtual ~wxFileCtrl();
- void ChangeToListMode();
- void ChangeToReportMode();
- void ChangeToIconMode();
- void ShowHidden( bool show = TRUE );
+ virtual void ChangeToListMode();
+ virtual void ChangeToReportMode();
+ virtual void ChangeToSmallIconMode();
+ virtual void ShowHidden( bool show = TRUE );
bool GetShowHidden() const { return m_showHidden; }
- long Add( wxFileData *fd, wxListItem &item );
- void UpdateFiles();
- virtual void StatusbarText( wxChar *WXUNUSED(text) ) {};
- void MakeDir();
- void GoToParentDir();
- void GoToHomeDir();
- void GoToDir( const wxString &dir );
- void SetWild( const wxString &wild );
+ virtual long Add( wxFileData *fd, wxListItem &item );
+ virtual void UpdateItem(const wxListItem &item);
+ virtual void UpdateFiles();
+ virtual void MakeDir();
+ virtual void GoToParentDir();
+ virtual void GoToHomeDir();
+ virtual void GoToDir( const wxString &dir );
+ virtual void SetWild( const wxString &wild );
wxString GetWild() const { return m_wild; }
- void GetDir( wxString &dir );
wxString GetDir() const { return m_dirName; }
void OnListDeleteItem( wxListEvent &event );
void OnListEndLabelEdit( wxListEvent &event );
void OnListColClick( wxListEvent &event );
- // Associate commonly used UI controls with wxFileCtrl so that they can be
- // disabled when they cannot be used (e.g. can't go to parent directory
- // if wxFileCtrl already is in the root dir):
- void SetGoToParentControl(wxWindow *ctrl) { m_goToParentControl = ctrl; }
- void SetNewDirControl(wxWindow *ctrl) { m_newDirControl = ctrl; }
-
- void SortItems(wxFileData::fileListFieldType field, bool foward);
- bool GetSortDirection() const { return m_sort_foward > 0; }
+ virtual void SortItems(wxFileData::fileListFieldType field, bool foward);
+ bool GetSortDirection() const { return m_sort_foward; }
wxFileData::fileListFieldType GetSortField() const { return m_sort_field; }
-private:
+protected:
void FreeItemData(const wxListItem& item);
void FreeAllItemsData();
bool m_showHidden;
wxString m_wild;
- wxWindow *m_goToParentControl;
- wxWindow *m_newDirControl;
-
- int m_sort_foward;
+ bool m_sort_foward;
wxFileData::fileListFieldType m_sort_field;
+private:
DECLARE_DYNAMIC_CLASS(wxFileCtrl);
DECLARE_EVENT_TABLE()
};
-#endif
- // _WX_FILEDLGG_H_
-
+#endif // _WX_FILEDLGG_H_