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 #include "chrome/browser/ui/webui/media_router/media_router_ui.h" | 5 #include "chrome/browser/ui/webui/media_router/media_router_ui.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <unordered_map> | 9 #include <unordered_map> |
10 #include <utility> | 10 #include <utility> |
(...skipping 13 matching lines...) Expand all Loading... | |
24 #include "chrome/browser/media/router/media_router_metrics.h" | 24 #include "chrome/browser/media/router/media_router_metrics.h" |
25 #include "chrome/browser/media/router/media_routes_observer.h" | 25 #include "chrome/browser/media/router/media_routes_observer.h" |
26 #include "chrome/browser/media/router/media_sinks_observer.h" | 26 #include "chrome/browser/media/router/media_sinks_observer.h" |
27 #include "chrome/browser/media/router/mojo/media_router_mojo_impl.h" | 27 #include "chrome/browser/media/router/mojo/media_router_mojo_impl.h" |
28 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" | 28 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" |
29 #include "chrome/browser/profiles/profile.h" | 29 #include "chrome/browser/profiles/profile.h" |
30 #include "chrome/browser/sessions/session_tab_helper.h" | 30 #include "chrome/browser/sessions/session_tab_helper.h" |
31 #include "chrome/browser/ui/webui/media_router/media_router_localized_strings_pr ovider.h" | 31 #include "chrome/browser/ui/webui/media_router/media_router_localized_strings_pr ovider.h" |
32 #include "chrome/browser/ui/webui/media_router/media_router_resources_provider.h " | 32 #include "chrome/browser/ui/webui/media_router/media_router_resources_provider.h " |
33 #include "chrome/browser/ui/webui/media_router/media_router_webui_message_handle r.h" | 33 #include "chrome/browser/ui/webui/media_router/media_router_webui_message_handle r.h" |
34 #include "chrome/common/chrome_features.h" | |
34 #include "chrome/common/media_router/issue.h" | 35 #include "chrome/common/media_router/issue.h" |
35 #include "chrome/common/media_router/media_route.h" | 36 #include "chrome/common/media_router/media_route.h" |
36 #include "chrome/common/media_router/media_sink.h" | 37 #include "chrome/common/media_router/media_sink.h" |
37 #include "chrome/common/media_router/media_source.h" | 38 #include "chrome/common/media_router/media_source.h" |
38 #include "chrome/common/media_router/media_source_helper.h" | 39 #include "chrome/common/media_router/media_source_helper.h" |
39 #include "chrome/common/media_router/route_request_result.h" | 40 #include "chrome/common/media_router/route_request_result.h" |
40 #include "chrome/common/pref_names.h" | 41 #include "chrome/common/pref_names.h" |
41 #include "chrome/common/url_constants.h" | 42 #include "chrome/common/url_constants.h" |
42 #include "chrome/grit/generated_resources.h" | 43 #include "chrome/grit/generated_resources.h" |
43 #include "components/prefs/pref_service.h" | 44 #include "components/prefs/pref_service.h" |
(...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
146 } | 147 } |
147 | 148 |
148 MediaRouterUI::UIMediaRoutesObserver::~UIMediaRoutesObserver() {} | 149 MediaRouterUI::UIMediaRoutesObserver::~UIMediaRoutesObserver() {} |
149 | 150 |
150 void MediaRouterUI::UIMediaRoutesObserver::OnRoutesUpdated( | 151 void MediaRouterUI::UIMediaRoutesObserver::OnRoutesUpdated( |
151 const std::vector<MediaRoute>& routes, | 152 const std::vector<MediaRoute>& routes, |
152 const std::vector<MediaRoute::Id>& joinable_route_ids) { | 153 const std::vector<MediaRoute::Id>& joinable_route_ids) { |
153 callback_.Run(routes, joinable_route_ids); | 154 callback_.Run(routes, joinable_route_ids); |
154 } | 155 } |
155 | 156 |
157 MediaRouterUI::UIMediaRouteControllerObserver::UIMediaRouteControllerObserver( | |
158 MediaRouterUI* ui, | |
159 scoped_refptr<MediaRouteController> controller) | |
160 : MediaRouteController::Observer(std::move(controller)), ui_(ui) {} | |
161 MediaRouterUI::UIMediaRouteControllerObserver:: | |
162 ~UIMediaRouteControllerObserver() {} | |
163 | |
164 void MediaRouterUI::UIMediaRouteControllerObserver::OnMediaStatusUpdated( | |
165 const MediaStatus& status) { | |
166 ui_->handler_->UpdateMediaRouteStatus(status); | |
mark a. foltz
2017/05/01 21:28:42
Can you make this a method on MediaRouterUI as is
takumif
2017/05/02 21:37:37
Done.
| |
167 } | |
168 | |
169 void MediaRouterUI::UIMediaRouteControllerObserver::OnControllerInvalidated() { | |
170 ui_->OnRouteControllerInvalidated(); | |
171 } | |
172 | |
156 MediaRouterUI::MediaRouterUI(content::WebUI* web_ui) | 173 MediaRouterUI::MediaRouterUI(content::WebUI* web_ui) |
157 : ConstrainedWebDialogUI(web_ui), | 174 : ConstrainedWebDialogUI(web_ui), |
158 ui_initialized_(false), | 175 ui_initialized_(false), |
159 current_route_request_id_(-1), | 176 current_route_request_id_(-1), |
160 route_request_counter_(0), | 177 route_request_counter_(0), |
161 initiator_(nullptr), | 178 initiator_(nullptr), |
162 router_(nullptr), | 179 router_(nullptr), |
163 weak_factory_(this) { | 180 weak_factory_(this) { |
164 auto handler = base::MakeUnique<MediaRouterWebUIMessageHandler>(this); | 181 auto handler = base::MakeUnique<MediaRouterWebUIMessageHandler>(this); |
165 handler_ = handler.get(); | 182 handler_ = handler.get(); |
(...skipping 587 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
753 MediaRouterMetrics::RecordMediaRouterDialogLoaded( | 770 MediaRouterMetrics::RecordMediaRouterDialogLoaded( |
754 base::Time::Now() - start_time_); | 771 base::Time::Now() - start_time_); |
755 start_time_ = base::Time(); | 772 start_time_ = base::Time(); |
756 } | 773 } |
757 } | 774 } |
758 | 775 |
759 void MediaRouterUI::UpdateMaxDialogHeight(int height) { | 776 void MediaRouterUI::UpdateMaxDialogHeight(int height) { |
760 handler_->UpdateMaxDialogHeight(height); | 777 handler_->UpdateMaxDialogHeight(height); |
761 } | 778 } |
762 | 779 |
780 const MediaRouteController* MediaRouterUI::GetMediaRouteController() const { | |
781 return route_controller_observer_ | |
782 ? route_controller_observer_->controller().get() | |
783 : nullptr; | |
784 } | |
785 | |
786 void MediaRouterUI::OnMediaControllerUIAvailable( | |
787 const MediaRoute::Id& route_id) { | |
788 scoped_refptr<MediaRouteController> controller = | |
789 router_->GetRouteController(route_id); | |
790 if (!controller) { | |
791 DVLOG(1) << "Requested a route controller with an invalid route ID."; | |
792 return; | |
793 } | |
794 DVLOG_IF(1, route_controller_observer_) | |
795 << "Route controller observer unexpectedly exists."; | |
796 route_controller_observer_ = | |
797 base::MakeUnique<UIMediaRouteControllerObserver>(this, controller); | |
798 } | |
799 | |
800 void MediaRouterUI::OnMediaControllerUIClosed() { | |
801 route_controller_observer_.reset(); | |
802 } | |
803 | |
804 void MediaRouterUI::OnRouteControllerInvalidated() { | |
805 route_controller_observer_.reset(); | |
806 handler_->OnRouteControllerInvalidated(); | |
807 } | |
808 | |
763 std::string MediaRouterUI::GetSerializedInitiatorOrigin() const { | 809 std::string MediaRouterUI::GetSerializedInitiatorOrigin() const { |
764 url::Origin origin = initiator_ | 810 url::Origin origin = initiator_ |
765 ? url::Origin(initiator_->GetLastCommittedURL()) | 811 ? url::Origin(initiator_->GetLastCommittedURL()) |
766 : url::Origin(); | 812 : url::Origin(); |
767 return origin.Serialize(); | 813 return origin.Serialize(); |
768 } | 814 } |
769 | 815 |
770 } // namespace media_router | 816 } // namespace media_router |
OLD | NEW |