diff options
author | ananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-01-16 23:08:27 +0000 |
---|---|---|
committer | ananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-01-16 23:08:27 +0000 |
commit | e8c62b968fba790e682b0d77416131a2e916f475 (patch) | |
tree | e4755e37cf6208c182aa8c5290923e16b5f53cf3 /ui/shell_dialogs/select_file_dialog.h | |
parent | fdc9eec417bb1eaf98485ab7e1285fcb432bcbcd (diff) | |
download | chromium_src-e8c62b968fba790e682b0d77416131a2e916f475.zip chromium_src-e8c62b968fba790e682b0d77416131a2e916f475.tar.gz chromium_src-e8c62b968fba790e682b0d77416131a2e916f475.tar.bz2 |
Bring back the file dialogs for chrome AURA.
This CL copies the ui\base\dialogs sources to a new directory ui\shell_folders. This is
done due to problems with gcl not working correctly in conjunction with svn mv and local edits leading
to tryjob issues.
The code in ui\shell_folders is not compiled at the moment.
This will be compiled when CL https://codereview.chromium.org/11878031 lands.
BUG=170483
TBR=ben
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@177251 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ui/shell_dialogs/select_file_dialog.h')
-rw-r--r-- | ui/shell_dialogs/select_file_dialog.h | 201 |
1 files changed, 201 insertions, 0 deletions
diff --git a/ui/shell_dialogs/select_file_dialog.h b/ui/shell_dialogs/select_file_dialog.h new file mode 100644 index 0000000..b5922d9 --- /dev/null +++ b/ui/shell_dialogs/select_file_dialog.h @@ -0,0 +1,201 @@ +// Copyright (c) 2012 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef UI_BASE_DIALOGS_SELECT_FILE_DIALOG_H_ +#define UI_BASE_DIALOGS_SELECT_FILE_DIALOG_H_ + +#include <string> +#include <vector> + +#include "base/basictypes.h" +#include "base/callback_forward.h" +#include "base/file_path.h" +#include "base/memory/ref_counted.h" +#include "base/memory/scoped_ptr.h" +#include "base/string16.h" +#include "ui/base/dialogs/base_shell_dialog.h" +#include "ui/base/ui_export.h" +#include "ui/gfx/native_widget_types.h" + +namespace ui { +class SelectFileDialogFactory; +class SelectFilePolicy; +struct SelectedFileInfo; + +// Shows a dialog box for selecting a file or a folder. +class UI_EXPORT SelectFileDialog + : public base::RefCountedThreadSafe<SelectFileDialog>, + public ui::BaseShellDialog { + public: + enum Type { + SELECT_NONE, + SELECT_FOLDER, + SELECT_SAVEAS_FILE, + SELECT_OPEN_FILE, + SELECT_OPEN_MULTI_FILE + }; + + // An interface implemented by a Listener object wishing to know about the + // the result of the Select File/Folder action. These callbacks must be + // re-entrant. + class UI_EXPORT Listener { + public: + // Notifies the Listener that a file/folder selection has been made. The + // file/folder path is in |path|. |params| is contextual passed to + // SelectFile. |index| specifies the index of the filter passed to the + // the initial call to SelectFile. + virtual void FileSelected(const FilePath& path, + int index, void* params) = 0; + + // Similar to FileSelected() but takes SelectedFileInfo instead of + // FilePath. Used for passing extra information (ex. display name). + // + // If not overridden, calls FileSelected() with path from |file|. + virtual void FileSelectedWithExtraInfo( + const ui::SelectedFileInfo& file, + int index, + void* params); + + // Notifies the Listener that many files have been selected. The + // files are in |files|. |params| is contextual passed to SelectFile. + virtual void MultiFilesSelected( + const std::vector<FilePath>& files, void* params) {} + + // Similar to MultiFilesSelected() but takes SelectedFileInfo instead of + // FilePath. Used for passing extra information (ex. display name). + // + // If not overridden, calls MultiFilesSelected() with paths from |files|. + virtual void MultiFilesSelectedWithExtraInfo( + const std::vector<ui::SelectedFileInfo>& files, + void* params); + + // Notifies the Listener that the file/folder selection was aborted (via + // the user canceling or closing the selection dialog box, for example). + // |params| is contextual passed to SelectFile. + virtual void FileSelectionCanceled(void* params) {} + + protected: + virtual ~Listener() {} + }; + + // Sets the factory that creates SelectFileDialog objects, overriding default + // behaviour. + // + // This is optional and should only be used by components that have to live + // elsewhere in the tree due to layering violations. (For example, because of + // a dependency on chrome's extension system.) + static void SetFactory(ui::SelectFileDialogFactory* factory); + + // Creates a dialog box helper. This object is ref-counted, but the returned + // object will have no reference (refcount is 0). |policy| is an optional + // class that can prevent showing a dialog. + static SelectFileDialog* Create(Listener* listener, + ui::SelectFilePolicy* policy); + + // Holds information about allowed extensions on a file save dialog. + struct UI_EXPORT FileTypeInfo { + FileTypeInfo(); + ~FileTypeInfo(); + + // A list of allowed extensions. For example, it might be + // + // { { "htm", "html" }, { "txt" } } + // + // Only pass more than one extension in the inner vector if the extensions + // are equivalent. Do NOT include leading periods. + std::vector<std::vector<FilePath::StringType> > extensions; + + // Overrides the system descriptions of the specified extensions. Entries + // correspond to |extensions|; if left blank the system descriptions will + // be used. + std::vector<string16> extension_description_overrides; + + // Specifies whether there will be a filter added for all files (i.e. *.*). + bool include_all_files; + + // Specifies whether the caller can support files/folders that are on + // GDrive. + bool support_gdata; + }; + + // Selects a File. + // Before doing anything this function checks if FileBrowsing is forbidden + // by Policy. If so, it tries to show an InfoBar and behaves as though no File + // was selected (the user clicked `Cancel` immediately). + // Otherwise it will start displaying the dialog box. This will also + // block the calling window until the dialog box is complete. The listener + // associated with this object will be notified when the selection is + // complete. + // |type| is the type of file dialog to be shown, see Type enumeration above. + // |title| is the title to be displayed in the dialog. If this string is + // empty, the default title is used. + // |default_path| is the default path and suggested file name to be shown in + // the dialog. This only works for SELECT_SAVEAS_FILE and SELECT_OPEN_FILE. + // Can be an empty string to indicate the platform default. + // |file_types| holds the information about the file types allowed. Pass NULL + // to get no special behavior + // |file_type_index| is the 1-based index into the file type list in + // |file_types|. Specify 0 if you don't need to specify extension behavior. + // |default_extension| is the default extension to add to the file if the + // user doesn't type one. This should NOT include the '.'. On Windows, if + // you specify this you must also specify |file_types|. + // |owning_window| is the window the dialog is modal to, or NULL for a + // modeless dialog. + // |params| is data from the calling context which will be passed through to + // the listener. Can be NULL. + // NOTE: only one instance of any shell dialog can be shown per owning_window + // at a time (for obvious reasons). + void SelectFile(Type type, + const string16& title, + const FilePath& default_path, + const FileTypeInfo* file_types, + int file_type_index, + const FilePath::StringType& default_extension, + gfx::NativeWindow owning_window, + void* params); + bool HasMultipleFileTypeChoices(); + + protected: + friend class base::RefCountedThreadSafe<SelectFileDialog>; + explicit SelectFileDialog(Listener* listener, + ui::SelectFilePolicy* policy); + virtual ~SelectFileDialog(); + + // Displays the actual file-selection dialog. + // This is overridden in the platform-specific descendants of FileSelectDialog + // and gets called from SelectFile after testing the + // AllowFileSelectionDialogs-Policy. + virtual void SelectFileImpl(Type type, + const string16& title, + const FilePath& default_path, + const FileTypeInfo* file_types, + int file_type_index, + const FilePath::StringType& default_extension, + gfx::NativeWindow owning_window, + void* params) = 0; + + // The listener to be notified of selection completion. + Listener* listener_; + + private: + // Tests if the file selection dialog can be displayed by + // testing if the AllowFileSelectionDialogs-Policy is + // either unset or set to true. + bool CanOpenSelectFileDialog(); + + // Informs the |listener_| that the file selection dialog was canceled. Moved + // to a function for being able to post it to the message loop. + void CancelFileSelection(void* params); + + // Returns true if the dialog has multiple file type choices. + virtual bool HasMultipleFileTypeChoicesImpl() = 0; + + scoped_ptr<ui::SelectFilePolicy> select_file_policy_; + + DISALLOW_COPY_AND_ASSIGN(SelectFileDialog); +}; + +} // namespace ui + +#endif // UI_BASE_DIALOGS_SELECT_FILE_DIALOG_H_ |