25#ifndef TGUI_FILE_DIALOG_HPP
26#define TGUI_FILE_DIALOG_HPP
28#include <TGUI/Widgets/Label.hpp>
29#include <TGUI/Widgets/Button.hpp>
30#include <TGUI/Widgets/EditBox.hpp>
31#include <TGUI/Widgets/ComboBox.hpp>
32#include <TGUI/Widgets/ListView.hpp>
33#include <TGUI/Widgets/ChildWindow.hpp>
34#include <TGUI/Widgets/Panel.hpp>
35#include <TGUI/Renderers/FileDialogRenderer.hpp>
36#include <TGUI/Filesystem.hpp>
38#if !TGUI_EXPERIMENTAL_USE_STD_MODULE
44TGUI_MODULE_EXPORT
namespace tgui
46 class FileDialogIconLoader;
66 using Ptr = std::shared_ptr<FileDialog>;
67 using ConstPtr = std::shared_ptr<const FileDialog>;
69 static constexpr const char StaticWidgetType[] =
"FileDialog";
78 FileDialog(
const char* typeName = StaticWidgetType,
bool initRenderer =
true);
228 TGUI_NODISCARD
const std::vector<std::pair<String, std::vector<String>>>&
getFileTypeFilters()
const;
411 void textEntered(
char32_t key)
override;
437 TGUI_NODISCARD std::unique_ptr<DataIO::Node>
save(SavingRenderersMap& renderers)
const override;
442 void load(
const std::unique_ptr<DataIO::Node>& node,
const LoadingRenderersMap& renderers)
override;
447 bool updateTime(
Duration elapsedTime)
override;
465 void historyChanged();
470 void sortFilesInListView();
475 void filesSelected(std::vector<Filesystem::Path> filenames);
480 void updateConfirmButtonEnabled();
485 void confirmButtonPressed();
490 void addCreateFolderButton();
495 void createFolder(
const String& name);
500 void createCreateFolderDialog();
505 void destroyCreateFolderDialog();
510 bool isValidFolderName(
const String& name);
515 void identifyChildWidgets();
520 void connectSignals();
547 bool m_allowCreateFolder =
false;
549 bool m_createFolderDialogOpen =
false;
552 std::vector<Filesystem::FileInfo> m_filesInDirectory;
553 std::vector<Texture> m_fileIcons;
554 std::size_t m_sortColumnIndex = 0;
555 bool m_sortInversed =
false;
557 std::vector<Filesystem::Path> m_pathHistory;
558 std::size_t m_pathHistoryIndex = 0;
560 bool m_fileMustExist =
true;
561 bool m_selectingDirectory =
false;
562 bool m_multiSelect =
false;
564 std::vector<std::pair<String, std::vector<String>>> m_fileTypeFilters;
565 std::size_t m_selectedFileTypeFilter = 0;
567 std::shared_ptr<FileDialogIconLoader> m_iconLoader;
569 std::vector<Filesystem::Path> m_selectedFiles;
Child window widget.
Definition ChildWindow.hpp:45
std::shared_ptr< ComboBox > Ptr
Shared widget pointer.
Definition ComboBox.hpp:52
Wrapper for durations.
Definition Duration.hpp:55
std::shared_ptr< EditBox > Ptr
Shared widget pointer.
Definition EditBox.hpp:51
Definition FileDialogRenderer.hpp:35
File dialog widget.
Definition FileDialog.hpp:63
void setCancelButtonText(const String &text="Cancel")
Changes the text of the cancel button (e.g. to display it in a different language)
void setMultiSelect(bool multiSelect)
Changes whether multiple files can be selected.
void setFileTypeFilters(const std::vector< std::pair< String, std::vector< String > > > &filters, std::size_t defaultFilterIndex=0)
Changes the file filters which the user can select to only show files of a certain type.
void setFileMustExist(bool enforceExistence)
Changes whether the file should exist or whether the filename can be a non-existent file.
std::size_t getFileTypeFiltersIndex() const
Returns the index of the currently selected file filter.
void setAllowCreateFolder(bool allowCreateFolder)
Adds or removes the create folder button.
void setConfirmButtonText(const String &text="Open")
Changes the text of the open/save button.
static FileDialog::Ptr create(const String &title="Open file", const String &confirmButtonText="Open", bool allowCreateFolder=false)
Creates a new file dialog widget.
std::unique_ptr< DataIO::Node > save(SavingRenderersMap &renderers) const override
Saves the widget as a tree node in order to save it to a file.
void load(const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override
Loads the widget from a tree of nodes.
const String & getCreateFolderButtonText() const
Return the text of the create folder button.
const String & getConfirmButtonText() const
Return the text of the open/save button.
FileDialogRenderer * getSharedRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
bool getFileMustExist() const
Returns whether the file should exist or whether the filename can be a non-existent file.
void setPath(const String &path)
Changes the directory for which the files are to be displayed.
std::shared_ptr< const FileDialog > ConstPtr
Shared constant widget pointer.
Definition FileDialog.hpp:67
std::shared_ptr< FileDialog > Ptr
Shared widget pointer.
Definition FileDialog.hpp:66
const String & getCancelButtonText() const
Return the text of the cancel button.
std::shared_ptr< FileDialogIconLoader > getIconLoader() const
Gets the icon loader that is currently being used.
const String & getFilenameLabelText() const
Return the text of the filename label.
const std::vector< std::pair< String, std::vector< String > > > & getFileTypeFilters() const
Returns the file filters which the user can select to only show files of a certain type.
bool getAllowCreateFolder() const
Return whether the file dialog allows the user to create a folder.
void setPath(const Filesystem::Path &path)
Changes the directory for which the files are to be displayed.
void setCreateFolderButtonText(const String &text="Create Folder")
Changes the text of the create folder button.
std::tuple< String, String, String > getListViewColumnCaptions() const
Returns the names of the list view columns.
const String & getFilename() const
Returns the filename that is entered in the filename edit box.
bool getMultiSelect() const
Returns whether multiple files can be selected.
FileDialogRenderer * getRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
void setIconLoader(std::shared_ptr< FileDialogIconLoader > iconLoader)
Sets a custom icon loader.
bool canHandleKeyPress(const Event::KeyEvent &event) override
Called by the parent of the widget to check if keyPressed would process the event.
static FileDialog::Ptr copy(const FileDialog::ConstPtr &dialog)
Makes a copy of another file dialog.
void setSelectingDirectory(bool selectDirectories)
Changes whether the file dialog is used for selecting a file or for selecting a directory.
void rendererChanged(const String &property) override
Function called when one of the properties of the renderer is changed.
Widget::Ptr clone() const override
Makes a copy of the widget if you don't know its exact type.
bool getSelectingDirectory() const
Returns whether the file dialog is used for selecting a file or for selecting a directory.
void setFilenameLabelText(const String &labelText="Filename:")
Changes the text of the filename label (e.g. to display it in a different language)
void setFilename(const String &filename)
Sets the filename that is shown at the bottom of the file dialog.
FileDialog(FileDialog &©) noexcept
Move constructor.
const std::vector< Filesystem::Path > & getSelectedPaths() const
Returns the selected files/directories.
void setListViewColumnCaptions(const String &nameColumnText="Name", const String &sizeColumnText="Size", const String &modifiedColumnText="Modified")
Changes the names of the list view columns (e.g. to display them in a different language)
Signal & getSignal(String signalName) override
Retrieves a signal based on its name.
FileDialog(const FileDialog ©)
Copy constructor.
const Filesystem::Path & getPath() const
Returns the directory that is currently being shown in the file dialog.
Object to represent paths on a filesystem.
Definition Filesystem.hpp:58
std::shared_ptr< Label > Ptr
Shared widget pointer.
Definition Label.hpp:44
std::shared_ptr< ListView > Ptr
Shared widget pointer.
Definition ListView.hpp:50
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:783
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:61
Wrapper class to store strings.
Definition String.hpp:96
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:38
KeyPressed event parameters.
Definition Event.hpp:168