OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "athena/activity/activity_manager_impl.h" | 5 #include "athena/activity/activity_manager_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "athena/activity/activity_widget_delegate.h" | 9 #include "athena/activity/activity_widget_delegate.h" |
10 #include "athena/activity/public/activity.h" | 10 #include "athena/activity/public/activity.h" |
11 #include "athena/activity/public/activity_manager_observer.h" | 11 #include "athena/activity/public/activity_manager_observer.h" |
12 #include "athena/activity/public/activity_view_model.h" | 12 #include "athena/activity/public/activity_view_model.h" |
13 #include "base/logging.h" | 13 #include "base/logging.h" |
14 #include "base/observer_list.h" | 14 #include "base/observer_list.h" |
15 #include "ui/views/widget/widget.h" | 15 #include "ui/views/widget/widget.h" |
16 | 16 |
17 namespace athena { | 17 namespace athena { |
18 | 18 |
19 namespace { | 19 namespace { |
20 | 20 |
21 ActivityManager* instance = nullptr; | 21 ActivityManager* instance = nullptr; |
22 | 22 |
23 views::Widget* CreateWidget(Activity* activity) { | 23 views::Widget* CreateWidget(Activity* activity) { |
24 ActivityViewModel* view_model = activity->GetActivityViewModel(); | 24 aura::Window* window = activity->GetWindow(); |
25 views::Widget* widget = view_model->CreateWidget(); | 25 views::Widget* widget = |
| 26 window ? views::Widget::GetWidgetForNativeView(window) : nullptr; |
26 if (widget) | 27 if (widget) |
27 return widget; | 28 return widget; |
28 widget = new views::Widget; | 29 widget = new views::Widget; |
29 views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); | 30 views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); |
30 params.delegate = new ActivityWidgetDelegate(view_model); | 31 params.delegate = |
| 32 new ActivityWidgetDelegate(activity->GetActivityViewModel()); |
31 widget->Init(params); | 33 widget->Init(params); |
32 activity->GetActivityViewModel()->Init(); | 34 activity->GetActivityViewModel()->Init(); |
33 return widget; | 35 return widget; |
34 } | 36 } |
35 | 37 |
36 views::Widget* GetWidget(Activity* activity) { | 38 views::Widget* GetWidget(Activity* activity) { |
37 CHECK(activity); | 39 CHECK(activity); |
38 CHECK(activity->GetWindow()); | 40 CHECK(activity->GetWindow()); |
39 return views::Widget::GetWidgetForNativeWindow(activity->GetWindow()); | 41 return views::Widget::GetWidgetForNativeWindow(activity->GetWindow()); |
40 } | 42 } |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 return instance; | 127 return instance; |
126 } | 128 } |
127 | 129 |
128 void ActivityManager::Shutdown() { | 130 void ActivityManager::Shutdown() { |
129 CHECK(instance); | 131 CHECK(instance); |
130 delete instance; | 132 delete instance; |
131 } | 133 } |
132 | 134 |
133 | 135 |
134 } // namespace athena | 136 } // namespace athena |
OLD | NEW |