Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 // | 4 // |
| 5 // A view that implements one download on the Download shelf. | 5 // A view that implements one download on the Download shelf. |
| 6 // Each DownloadItemView contains an application icon, a text label | 6 // Each DownloadItemView contains an application icon, a text label |
| 7 // indicating the download's file name, a text label indicating the | 7 // indicating the download's file name, a text label indicating the |
| 8 // download's status (such as the number of bytes downloaded so far) | 8 // download's status (such as the number of bytes downloaded so far) |
| 9 // and a button for canceling an in progress download, or opening | 9 // and a button for canceling an in progress download, or opening |
| 10 // the completed download. | 10 // the completed download. |
| 11 // | 11 // |
| 12 // The DownloadItemView lives in the Browser, and has a corresponding | 12 // The DownloadItemView lives in the Browser, and has a corresponding |
| 13 // DownloadController that receives / writes data which lives in the | 13 // DownloadController that receives / writes data which lives in the |
| 14 // Renderer. | 14 // Renderer. |
| 15 | 15 |
| 16 #ifndef CHROME_BROWSER_UI_VIEWS_DOWNLOAD_DOWNLOAD_ITEM_VIEW_H_ | 16 #ifndef CHROME_BROWSER_UI_VIEWS_DOWNLOAD_DOWNLOAD_ITEM_VIEW_H_ |
| 17 #define CHROME_BROWSER_UI_VIEWS_DOWNLOAD_DOWNLOAD_ITEM_VIEW_H_ | 17 #define CHROME_BROWSER_UI_VIEWS_DOWNLOAD_DOWNLOAD_ITEM_VIEW_H_ |
| 18 | 18 |
| 19 #include <memory> | 19 #include <memory> |
| 20 #include <string> | 20 #include <string> |
| 21 | 21 |
| 22 #include "base/macros.h" | 22 #include "base/macros.h" |
| 23 #include "base/memory/weak_ptr.h" | 23 #include "base/memory/weak_ptr.h" |
| 24 #include "base/strings/string_util.h" | 24 #include "base/strings/string_util.h" |
| 25 #include "base/task/cancelable_task_tracker.h" | 25 #include "base/task/cancelable_task_tracker.h" |
| 26 #include "base/time/time.h" | 26 #include "base/time/time.h" |
| 27 #include "base/timer/timer.h" | 27 #include "base/timer/timer.h" |
| 28 #include "chrome/browser/download/download_commands.h" | |
| 28 #include "chrome/browser/download/download_item_model.h" | 29 #include "chrome/browser/download/download_item_model.h" |
| 29 #include "chrome/browser/icon_manager.h" | 30 #include "chrome/browser/icon_manager.h" |
| 30 #include "content/public/browser/download_item.h" | 31 #include "content/public/browser/download_item.h" |
| 31 #include "content/public/browser/download_manager.h" | 32 #include "content/public/browser/download_manager.h" |
| 32 #include "ui/gfx/animation/animation_delegate.h" | 33 #include "ui/gfx/animation/animation_delegate.h" |
| 33 #include "ui/gfx/font_list.h" | 34 #include "ui/gfx/font_list.h" |
| 34 #include "ui/views/animation/ink_drop_host_view.h" | 35 #include "ui/views/animation/ink_drop_host_view.h" |
| 35 #include "ui/views/context_menu_controller.h" | 36 #include "ui/views/context_menu_controller.h" |
| 36 #include "ui/views/controls/button/vector_icon_button_delegate.h" | 37 #include "ui/views/controls/button/vector_icon_button_delegate.h" |
| 37 | 38 |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 77 | 78 |
| 78 // Returns the base color for text on this download item, based on |theme|. | 79 // Returns the base color for text on this download item, based on |theme|. |
| 79 static SkColor GetTextColorForThemeProvider(const ui::ThemeProvider* theme); | 80 static SkColor GetTextColorForThemeProvider(const ui::ThemeProvider* theme); |
| 80 | 81 |
| 81 // IconManager::Client interface. | 82 // IconManager::Client interface. |
| 82 void OnExtractIconComplete(gfx::Image* icon); | 83 void OnExtractIconComplete(gfx::Image* icon); |
| 83 | 84 |
| 84 // Returns the DownloadItem model object belonging to this item. | 85 // Returns the DownloadItem model object belonging to this item. |
| 85 content::DownloadItem* download() { return model_.download(); } | 86 content::DownloadItem* download() { return model_.download(); } |
| 86 | 87 |
| 88 // If download is bad && download feedback feature is available && | |
| 89 // not incognito. | |
| 90 bool ShouldAllowDownloadFeedback(); | |
|
Peter Kasting
2016/10/24 21:39:07
Nit: I suggest a comment that states the purpose o
Jialiu Lin
2016/10/25 21:07:09
Function merged into MaybeSubmitDownloadToFeedback
| |
| 91 | |
| 92 // Submit download to download feedback service if user opts in safe browsing | |
| 93 // extended reporting (SBER) service, then perform the specified | |
| 94 // |download_command|. If user hasn't seen SBER opt-in text before, | |
| 95 // show SBER opt-in dialog first. | |
| 96 void MaybeSubmitDownloadToFeedbackService( | |
|
Peter Kasting
2016/10/24 21:39:07
It's very confusing that you have both MaybeSubmit
Jialiu Lin
2016/10/25 21:07:09
Good suggestion! I have renamed the second functio
| |
| 97 DownloadCommands::Command download_command); | |
| 98 | |
| 87 // DownloadItem::Observer methods | 99 // DownloadItem::Observer methods |
| 88 void OnDownloadUpdated(content::DownloadItem* download) override; | 100 void OnDownloadUpdated(content::DownloadItem* download) override; |
| 89 void OnDownloadOpened(content::DownloadItem* download) override; | 101 void OnDownloadOpened(content::DownloadItem* download) override; |
| 90 void OnDownloadDestroyed(content::DownloadItem* download) override; | 102 void OnDownloadDestroyed(content::DownloadItem* download) override; |
| 91 | 103 |
| 92 // Overridden from views::View: | 104 // Overridden from views::View: |
| 93 void Layout() override; | 105 void Layout() override; |
| 94 gfx::Size GetPreferredSize() const override; | 106 gfx::Size GetPreferredSize() const override; |
| 95 bool OnMousePressed(const ui::MouseEvent& event) override; | 107 bool OnMousePressed(const ui::MouseEvent& event) override; |
| 96 bool OnMouseDragged(const ui::MouseEvent& event) override; | 108 bool OnMouseDragged(const ui::MouseEvent& event) override; |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 140 }; | 152 }; |
| 141 | 153 |
| 142 void OpenDownload(); | 154 void OpenDownload(); |
| 143 | 155 |
| 144 // Submits the downloaded file to the safebrowsing download feedback service. | 156 // Submits the downloaded file to the safebrowsing download feedback service. |
| 145 // Returns whether submission was successful. On successful submission, | 157 // Returns whether submission was successful. On successful submission, |
| 146 // |this| and the DownloadItem will have been deleted. | 158 // |this| and the DownloadItem will have been deleted. |
| 147 bool SubmitDownloadToFeedbackService(); | 159 bool SubmitDownloadToFeedbackService(); |
| 148 | 160 |
| 149 // If the user has |enabled| uploading, calls SubmitDownloadToFeedbackService. | 161 // If the user has |enabled| uploading, calls SubmitDownloadToFeedbackService. |
| 150 // Otherwise, it simply removes the DownloadItem without uploading. | 162 // Otherwise, apply the download command (DISCARD or KEEP) without uploading. |
| 151 void PossiblySubmitDownloadToFeedbackService(bool enabled); | 163 void PossiblySubmitDownloadToFeedbackService( |
|
Peter Kasting
2016/10/24 21:39:07
Nit: Call this function something more precise. I
Jialiu Lin
2016/10/25 21:07:09
Done.
| |
| 164 DownloadCommands::Command download_command_id, | |
| 165 bool enabled); | |
|
Peter Kasting
2016/10/24 21:39:07
Nit: I would rename this |feedback_enabled| and pu
Jialiu Lin
2016/10/25 21:07:09
Renamed |enabled| to |feedback_enabled|, though I
| |
| 152 | 166 |
| 153 // This function calculates the vertical coordinate to draw the file name text | 167 // This function calculates the vertical coordinate to draw the file name text |
| 154 // relative to local bounds. | 168 // relative to local bounds. |
| 155 int GetYForFilenameText() const; | 169 int GetYForFilenameText() const; |
| 156 | 170 |
| 157 // Painting of various download item bits. | 171 // Painting of various download item bits. |
| 158 void DrawStatusText(gfx::Canvas* canvas); | 172 void DrawStatusText(gfx::Canvas* canvas); |
| 159 void DrawFilename(gfx::Canvas* canvas); | 173 void DrawFilename(gfx::Canvas* canvas); |
| 160 void DrawIcon(gfx::Canvas* canvas); | 174 void DrawIcon(gfx::Canvas* canvas); |
| 161 | 175 |
| (...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 320 std::unique_ptr<extensions::ExperienceSamplingEvent> sampling_event_; | 334 std::unique_ptr<extensions::ExperienceSamplingEvent> sampling_event_; |
| 321 | 335 |
| 322 // Method factory used to delay reenabling of the item when opening the | 336 // Method factory used to delay reenabling of the item when opening the |
| 323 // downloaded file. | 337 // downloaded file. |
| 324 base::WeakPtrFactory<DownloadItemView> weak_ptr_factory_; | 338 base::WeakPtrFactory<DownloadItemView> weak_ptr_factory_; |
| 325 | 339 |
| 326 DISALLOW_COPY_AND_ASSIGN(DownloadItemView); | 340 DISALLOW_COPY_AND_ASSIGN(DownloadItemView); |
| 327 }; | 341 }; |
| 328 | 342 |
| 329 #endif // CHROME_BROWSER_UI_VIEWS_DOWNLOAD_DOWNLOAD_ITEM_VIEW_H_ | 343 #endif // CHROME_BROWSER_UI_VIEWS_DOWNLOAD_DOWNLOAD_ITEM_VIEW_H_ |
| OLD | NEW |