Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(10)

Unified Diff: chrome/browser/extensions/api/file_system/file_entry_picker.h

Issue 2967223002: Move fileSystem API FilePicker class to own file (Closed)
Patch Set: no comment Created 3 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/file_system/file_entry_picker.h
diff --git a/chrome/browser/extensions/api/file_system/file_entry_picker.h b/chrome/browser/extensions/api/file_system/file_entry_picker.h
new file mode 100644
index 0000000000000000000000000000000000000000..25e12b7718d0755a206437b7215eff8c530a0294
--- /dev/null
+++ b/chrome/browser/extensions/api/file_system/file_entry_picker.h
@@ -0,0 +1,66 @@
+// Copyright 2017 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 CHROME_BROWSER_EXTENSIONS_API_FILE_SYSTEM_FILE_ENTRY_PICKER_H_
+#define CHROME_BROWSER_EXTENSIONS_API_FILE_SYSTEM_FILE_ENTRY_PICKER_H_
+
+#include <vector>
+
+#include "base/callback.h"
+#include "base/memory/ref_counted.h"
+#include "ui/shell_dialogs/select_file_dialog.h"
+
+namespace base {
+class FilePath;
+} // namespace base
+
+namespace content {
+class WebContents;
+} // namespace content
+
+namespace extensions {
+
+// Shows a dialog to the user to ask for the filename for a file to save or
+// open. Deletes itself once the dialog is closed.
+class FileEntryPicker : public ui::SelectFileDialog::Listener {
+ public:
+ using FilesSelectedCallback =
+ base::OnceCallback<void(const std::vector<base::FilePath>& paths)>;
Devlin 2017/07/05 19:08:05 nit: \n
michaelpg 2017/07/05 19:52:53 Done.
+ FileEntryPicker(content::WebContents* web_contents,
Devlin 2017/07/05 19:08:05 Document, either here or above the member variable
michaelpg 2017/07/05 19:52:53 Done.
+ const base::FilePath& suggested_name,
+ const ui::SelectFileDialog::FileTypeInfo& file_type_info,
+ ui::SelectFileDialog::Type picker_type,
+ FilesSelectedCallback&& files_selected_callback,
Devlin 2017/07/05 19:08:05 nit: maybe just pass by value here, and std::move
michaelpg 2017/07/05 19:52:53 Thanks for catching this. Yeah, what I had goes ag
+ base::OnceClosure&& file_selection_canceled_callback);
+ ~FileEntryPicker() override;
Devlin 2017/07/05 19:08:05 Can we make this private?
michaelpg 2017/07/05 19:52:53 Done (was copied code).
+
+ private:
+ // ui::SelectFileDialog::Listener implementation.
+ void FileSelected(const base::FilePath& path,
+ int index,
+ void* params) override;
+
Devlin 2017/07/05 19:08:05 no \n between overridden methods from the same cla
michaelpg 2017/07/05 19:52:53 Done (was copied code)
+ void FileSelectedWithExtraInfo(const ui::SelectedFileInfo& file,
+ int index,
+ void* params) override;
+
+ void MultiFilesSelected(const std::vector<base::FilePath>& files,
+ void* params) override;
+
+ void MultiFilesSelectedWithExtraInfo(
+ const std::vector<ui::SelectedFileInfo>& files,
+ void* params) override;
+
+ void FileSelectionCanceled(void* params) override;
+
+ FilesSelectedCallback files_selected_callback_;
+ base::OnceClosure file_selection_canceled_callback_;
+ scoped_refptr<ui::SelectFileDialog> select_file_dialog_;
+
+ DISALLOW_COPY_AND_ASSIGN(FileEntryPicker);
+};
+
+} // namespace extensions
+
+#endif // CHROME_BROWSER_EXTENSIONS_API_FILE_SYSTEM_FILE_ENTRY_PICKER_H_

Powered by Google App Engine
This is Rietveld 408576698