Chromium Code Reviews| 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/public/activity_view_manager.h" | 5 #include "athena/activity/public/activity_view_manager.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <map> | 8 #include <map> |
| 9 | 9 |
| 10 #include "athena/activity/activity_widget_delegate.h" | 10 #include "athena/activity/activity_widget_delegate.h" |
| 11 #include "athena/activity/public/activity.h" | 11 #include "athena/activity/public/activity.h" |
| 12 #include "athena/activity/public/activity_manager.h" | 12 #include "athena/activity/public/activity_manager.h" |
| 13 #include "athena/activity/public/activity_view_model.h" | 13 #include "athena/activity/public/activity_view_model.h" |
| 14 #include "athena/screen/public/screen_manager.h" | 14 #include "athena/screen/public/screen_manager.h" |
| 15 #include "ui/aura/window.h" | 15 #include "ui/aura/window.h" |
| 16 #include "ui/views/view.h" | 16 #include "ui/views/view.h" |
| 17 #include "ui/views/widget/widget.h" | 17 #include "ui/views/widget/widget.h" |
| 18 #include "ui/views/widget/widget_observer.h" | 18 #include "ui/views/widget/widget_observer.h" |
| 19 | 19 |
| 20 namespace athena { | 20 namespace athena { |
| 21 namespace { | 21 namespace { |
| 22 | 22 |
| 23 typedef std::map<Activity*, views::Widget*> ActivityWidgetMap; | 23 typedef std::map<Activity*, views::Widget*> ActivityWidgetMap; |
| 24 | 24 |
| 25 views::Widget* CreateWidget(Activity* activity) { | 25 views::Widget* CreateWidget(Activity* activity) { |
| 26 ActivityViewModel* view_model = activity->GetActivityViewModel(); | 26 ActivityViewModel* view_model = activity->GetActivityViewModel(); |
| 27 views::Widget* widget = new views::Widget; | 27 views::Widget* widget = view_model->CreateWidget(); |
| 28 if (widget) | |
| 29 return widget; | |
| 30 widget = new views::Widget; | |
| 28 views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); | 31 views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); |
| 29 params.delegate = new ActivityWidgetDelegate(view_model); | 32 params.delegate = new ActivityWidgetDelegate(view_model); |
| 30 params.activatable = views::Widget::InitParams::ACTIVATABLE_YES; | |
|
Jun Mukai
2014/09/10 23:35:38
why this removed? is it a default value?
oshima
2014/09/11 00:12:34
This was necessary when window type was TYPE_WINDO
| |
| 31 widget->Init(params); | 33 widget->Init(params); |
| 32 return widget; | 34 return widget; |
| 33 } | 35 } |
| 34 | 36 |
| 35 ActivityViewManager* instance = NULL; | 37 ActivityViewManager* instance = NULL; |
| 36 | 38 |
| 37 class ActivityViewManagerImpl : public ActivityViewManager, | 39 class ActivityViewManagerImpl : public ActivityViewManager, |
| 38 public views::WidgetObserver { | 40 public views::WidgetObserver { |
| 39 public: | 41 public: |
| 40 ActivityViewManagerImpl() { | 42 ActivityViewManagerImpl() { |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 110 ActivityViewManager* ActivityViewManager::Get() { | 112 ActivityViewManager* ActivityViewManager::Get() { |
| 111 return instance; | 113 return instance; |
| 112 } | 114 } |
| 113 | 115 |
| 114 void ActivityViewManager::Shutdown() { | 116 void ActivityViewManager::Shutdown() { |
| 115 CHECK(instance); | 117 CHECK(instance); |
| 116 delete instance; | 118 delete instance; |
| 117 } | 119 } |
| 118 | 120 |
| 119 } // namespace athena | 121 } // namespace athena |
| OLD | NEW |