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 29 matching lines...) Expand all Loading... | |
| 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 DCHECK(notifier_.get()); |
| 48 if (!IsVisibleInUI(request.client_id())) | 48 if (!IsVisibleInUI(request.client_id())) |
| 49 return; | 49 return; |
| 50 | |
| 51 // There is no Added call for the notifier so we perform a Progress call | |
| 52 // to cause the notification to be created. | |
| 50 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); | 53 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); |
| 54 | |
| 55 // Now if the request state is available, we need to send Interrupted call. | |
| 56 // TODO(dougarnett): Handle request state in notifier impl so this call | |
| 57 // is not needed. | |
| 58 if (request.request_state() == SavePageRequest::RequestState::AVAILABLE) | |
|
fgorski
2016/11/28 22:30:24
Here is the response to your previous comment that
dougarnett
2016/11/28 22:52:15
Done.
Btw, chatted with Min and he does suggest g
| |
| 59 notifier_->NotifyDownloadInterrupted(DownloadUIItem(request)); | |
| 51 } | 60 } |
| 52 | 61 |
| 53 void DownloadNotifyingObserver::OnChanged(const SavePageRequest& request) { | 62 void DownloadNotifyingObserver::OnChanged(const SavePageRequest& request) { |
| 54 DCHECK(notifier_.get()); | 63 DCHECK(notifier_.get()); |
| 55 if (!IsVisibleInUI(request.client_id())) | 64 if (!IsVisibleInUI(request.client_id())) |
| 56 return; | 65 return; |
| 57 if (request.request_state() == SavePageRequest::RequestState::PAUSED) | 66 if (request.request_state() == SavePageRequest::RequestState::PAUSED) |
| 58 notifier_->NotifyDownloadPaused(DownloadUIItem(request)); | 67 notifier_->NotifyDownloadPaused(DownloadUIItem(request)); |
| 68 else if (request.request_state() == SavePageRequest::RequestState::AVAILABLE) | |
| 69 notifier_->NotifyDownloadInterrupted(DownloadUIItem(request)); | |
| 59 else | 70 else |
| 60 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); | 71 notifier_->NotifyDownloadProgress(DownloadUIItem(request)); |
| 61 } | 72 } |
| 62 | 73 |
| 63 void DownloadNotifyingObserver::OnCompleted( | 74 void DownloadNotifyingObserver::OnCompleted( |
| 64 const SavePageRequest& request, | 75 const SavePageRequest& request, |
| 65 RequestCoordinator::BackgroundSavePageResult status) { | 76 RequestCoordinator::BackgroundSavePageResult status) { |
| 66 DCHECK(notifier_.get()); | 77 DCHECK(notifier_.get()); |
| 67 if (!IsVisibleInUI(request.client_id())) | 78 if (!IsVisibleInUI(request.client_id())) |
| 68 return; | 79 return; |
| 69 if (status == RequestCoordinator::BackgroundSavePageResult::SUCCESS) | 80 if (status == RequestCoordinator::BackgroundSavePageResult::SUCCESS) |
| 70 notifier_->NotifyDownloadSuccessful(DownloadUIItem(request)); | 81 notifier_->NotifyDownloadSuccessful(DownloadUIItem(request)); |
| 71 else if (status == RequestCoordinator::BackgroundSavePageResult::REMOVED) | 82 else if (status == RequestCoordinator::BackgroundSavePageResult::REMOVED) |
| 72 notifier_->NotifyDownloadCanceled(DownloadUIItem(request)); | 83 notifier_->NotifyDownloadCanceled(DownloadUIItem(request)); |
| 73 else | 84 else |
| 74 notifier_->NotifyDownloadFailed(DownloadUIItem(request)); | 85 notifier_->NotifyDownloadFailed(DownloadUIItem(request)); |
| 75 } | 86 } |
| 76 | 87 |
| 77 bool DownloadNotifyingObserver::IsVisibleInUI(const ClientId& page) { | 88 bool DownloadNotifyingObserver::IsVisibleInUI(const ClientId& page) { |
| 78 return policy_controller_->IsSupportedByDownload(page.name_space) && | 89 return policy_controller_->IsSupportedByDownload(page.name_space) && |
| 79 base::IsValidGUID(page.id); | 90 base::IsValidGUID(page.id); |
| 80 } | 91 } |
| 81 | 92 |
| 82 } // namespace offline_pages | 93 } // namespace offline_pages |
| OLD | NEW |