Index: chrome/browser/android/download_overwrite_infobar_delegate.h |
diff --git a/chrome/browser/android/download_overwrite_infobar_delegate.h b/chrome/browser/android/download_overwrite_infobar_delegate.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8da252f734e8d2346cb10bb9ff57141d9eaf53d2 |
--- /dev/null |
+++ b/chrome/browser/android/download_overwrite_infobar_delegate.h |
@@ -0,0 +1,80 @@ |
+// Copyright 2015 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_ANDROID_DOWNLOAD_OVERWRITE_INFOBAR_DELEGATE_H_ |
+#define CHROME_BROWSER_ANDROID_DOWNLOAD_OVERWRITE_INFOBAR_DELEGATE_H_ |
+ |
+#include "base/callback.h" |
+#include "base/files/file_path.h" |
+#include "chrome/browser/download/download_target_determiner_delegate.h" |
+#include "components/infobars/core/infobar_delegate.h" |
+ |
+namespace content { |
+class DownloadItem; |
+} |
+ |
+namespace chrome { |
+namespace android { |
+ |
+// A class to implement an infobar that asks if it is ok to overwrite an |
Peter Kasting
2015/02/18 00:51:31
Nit: Remove "A class to implement"
Changwan Ryu
2015/02/18 07:15:02
Done.
|
+// existing file. Due to limited disk space on Android, two options are |
+// presented to the user when downloading a file whose name conflicts with an |
+// already present file: |
+// |
+// 1. Overwrite the file. |
+// 2. Create a new file. |
+// |
+// Also, you can dismiss the infobar. |
Peter Kasting
2015/02/18 00:51:31
Nit: "The user can dismiss the infobar to abort th
Changwan Ryu
2015/02/18 07:15:02
Done.
|
+// |
+// Note that this infobar does not expire when the user navigates away. |
Peter Kasting
2015/02/18 00:51:31
Nit: "when the user navigates away" -> "if the use
Changwan Ryu
2015/02/18 07:15:03
Done.
|
+class DownloadOverwriteInfoBarDelegate : public infobars::InfoBarDelegate { |
+ public: |
+ ~DownloadOverwriteInfoBarDelegate() override; |
+ |
+ static infobars::InfoBar* Create( |
Peter Kasting
2015/02/18 00:51:31
Looks like you don't use the return value, so retu
Changwan Ryu
2015/02/18 07:15:02
Done.
|
+ content::DownloadItem* download, |
+ const base::FilePath& suggested_download_path, |
+ const DownloadTargetDeterminerDelegate::FileSelectedCallback& |
+ file_selected_callback); |
+ |
+ // This is called when the user accepts overwriting. |
+ bool AcceptOverwrite(); |
Peter Kasting
2015/02/18 00:51:31
Nit: Consider calling this OverwriteExistingFile()
Changwan Ryu
2015/02/18 07:15:03
Done.
|
+ |
+ static void CreateNewFileInternal( |
Peter Kasting
2015/02/18 00:51:31
Nit: Add a comment explaining what this does, and
Changwan Ryu
2015/02/18 07:15:02
Done.
|
+ const base::FilePath& suggested_download_path, |
+ const DownloadTargetDeterminerDelegate::FileSelectedCallback& callback); |
+ |
+ // This is called when the user chooses to create a new file. |
+ bool CreateNewFile(); |
+ |
+ std::string GetFileName() const; |
+ std::string GetDirName() const; |
+ std::string GetDirFullPath() const; |
+ |
+ // Implements InfoBarDelegate |
Peter Kasting
2015/02/18 00:51:31
Nit: "infobars::InfoBarDelegate:"
Changwan Ryu
2015/02/18 07:15:02
Done.
|
+ void InfoBarDismissed() override; |
Peter Kasting
2015/02/18 00:51:31
Nit: Swap the order of these two functions (to mat
Changwan Ryu
2015/02/18 07:15:03
Done.
|
+ bool ShouldExpire(const NavigationDetails& details) const override; |
+ |
+ private: |
+ DownloadOverwriteInfoBarDelegate( |
+ content::DownloadItem* download, |
+ const base::FilePath& suggested_path, |
+ const DownloadTargetDeterminerDelegate::FileSelectedCallback& callback); |
+ |
+ // The suggested download path from download target determiner. This is used |
+ // to show users the file name and the directory that will be used. |
+ base::FilePath suggested_download_path_; |
+ |
+ // A callback to download target determiner to notify that file selection |
+ // is made (or cancelled). |
+ DownloadTargetDeterminerDelegate::FileSelectedCallback |
+ file_selected_callback_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(DownloadOverwriteInfoBarDelegate); |
+}; |
+ |
+} // namespace android |
+} // namespace chrome |
+ |
+#endif // CHROME_BROWSER_ANDROID_DOWNLOAD_OVERWRITE_INFOBAR_DELEGATE_H_ |