Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 #include "components/offline_pages/downloads/download_notifying_observer.h" | 5 #include "components/offline_pages/downloads/download_notifying_observer.h" |
| 6 | 6 |
| 7 #include "components/offline_pages/background/request_coordinator.h" | 7 #include "components/offline_pages/background/request_coordinator.h" |
| 8 #include "components/offline_pages/background/save_page_request.h" | 8 #include "components/offline_pages/background/save_page_request.h" |
| 9 #include "components/offline_pages/client_policy_controller.h" | 9 #include "components/offline_pages/client_policy_controller.h" |
| 10 #include "components/offline_pages/downloads/download_ui_adapter.h" | 10 #include "components/offline_pages/downloads/download_ui_adapter.h" |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 37 DCHECK(request_coordinator); | 37 DCHECK(request_coordinator); |
| 38 DCHECK(notifier.get()); | 38 DCHECK(notifier.get()); |
| 39 DownloadNotifyingObserver* observer = new DownloadNotifyingObserver( | 39 DownloadNotifyingObserver* observer = new DownloadNotifyingObserver( |
| 40 std::move(notifier), request_coordinator->GetPolicyController()); | 40 std::move(notifier), request_coordinator->GetPolicyController()); |
| 41 request_coordinator->AddObserver(observer); | 41 request_coordinator->AddObserver(observer); |
| 42 // |request_coordinator| takes ownership of observer here. | 42 // |request_coordinator| takes ownership of observer here. |
| 43 request_coordinator->SetUserData(&kUserDataKey, observer); | 43 request_coordinator->SetUserData(&kUserDataKey, observer); |
| 44 } | 44 } |
| 45 | 45 |
| 46 void DownloadNotifyingObserver::OnAdded(const SavePageRequest& request) { | 46 void DownloadNotifyingObserver::OnAdded(const SavePageRequest& request) { |
| 47 DCHECK(notifier_.get()); | 47 // Same notifier update as for OnChanged. |
| 48 if (!IsVisibleInUI(request.client_id())) | 48 OnChanged(request); |
|
dougarnett
2016/11/28 21:33:26
Hmm, actually this didn't work. Seems that we need
dougarnett
2016/11/28 22:18:49
Here is one approach at this level to affect the c
| |
| 49 return; | |
| 50 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); | |
| 51 } | 49 } |
| 52 | 50 |
| 53 void DownloadNotifyingObserver::OnChanged(const SavePageRequest& request) { | 51 void DownloadNotifyingObserver::OnChanged(const SavePageRequest& request) { |
| 54 DCHECK(notifier_.get()); | 52 DCHECK(notifier_.get()); |
| 55 if (!IsVisibleInUI(request.client_id())) | 53 if (!IsVisibleInUI(request.client_id())) |
| 56 return; | 54 return; |
| 57 if (request.request_state() == SavePageRequest::RequestState::PAUSED) | 55 if (request.request_state() == SavePageRequest::RequestState::PAUSED) |
| 58 notifier_->NotifyDownloadPaused(DownloadUIItem(request)); | 56 notifier_->NotifyDownloadPaused(DownloadUIItem(request)); |
| 57 else if (request.request_state() == SavePageRequest::RequestState::AVAILABLE) | |
| 58 notifier_->NotifyDownloadInterrupted(DownloadUIItem(request)); | |
| 59 else | 59 else |
| 60 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); | 60 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); |
| 61 } | 61 } |
| 62 | 62 |
| 63 void DownloadNotifyingObserver::OnCompleted( | 63 void DownloadNotifyingObserver::OnCompleted( |
| 64 const SavePageRequest& request, | 64 const SavePageRequest& request, |
| 65 RequestCoordinator::BackgroundSavePageResult status) { | 65 RequestCoordinator::BackgroundSavePageResult status) { |
| 66 DCHECK(notifier_.get()); | 66 DCHECK(notifier_.get()); |
| 67 if (!IsVisibleInUI(request.client_id())) | 67 if (!IsVisibleInUI(request.client_id())) |
| 68 return; | 68 return; |
| 69 if (status == RequestCoordinator::BackgroundSavePageResult::SUCCESS) | 69 if (status == RequestCoordinator::BackgroundSavePageResult::SUCCESS) |
| 70 notifier_->NotifyDownloadSuccessful(DownloadUIItem(request)); | 70 notifier_->NotifyDownloadSuccessful(DownloadUIItem(request)); |
| 71 else if (status == RequestCoordinator::BackgroundSavePageResult::REMOVED) | 71 else if (status == RequestCoordinator::BackgroundSavePageResult::REMOVED) |
| 72 notifier_->NotifyDownloadCanceled(DownloadUIItem(request)); | 72 notifier_->NotifyDownloadCanceled(DownloadUIItem(request)); |
| 73 else | 73 else |
| 74 notifier_->NotifyDownloadFailed(DownloadUIItem(request)); | 74 notifier_->NotifyDownloadFailed(DownloadUIItem(request)); |
| 75 } | 75 } |
| 76 | 76 |
| 77 bool DownloadNotifyingObserver::IsVisibleInUI(const ClientId& page) { | 77 bool DownloadNotifyingObserver::IsVisibleInUI(const ClientId& page) { |
| 78 return policy_controller_->IsSupportedByDownload(page.name_space) && | 78 return policy_controller_->IsSupportedByDownload(page.name_space) && |
| 79 base::IsValidGUID(page.id); | 79 base::IsValidGUID(page.id); |
| 80 } | 80 } |
| 81 | 81 |
| 82 } // namespace offline_pages | 82 } // namespace offline_pages |
| OLD | NEW |