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
3 // found in the LICENSE file.
5 #include "mandoline/ui/aura/native_widget_view_manager.h"
7 #include "mandoline/ui/aura/input_method_mandoline.h"
8 #include "mandoline/ui/aura/window_tree_host_mojo.h"
9 #include "mojo/converters/geometry/geometry_type_converters.h"
10 #include "mojo/converters/input_events/input_events_type_converters.h"
11 #include "ui/aura/client/default_capture_client.h"
12 #include "ui/aura/window.h"
13 #include "ui/aura/window_event_dispatcher.h"
14 #include "ui/base/ime/input_method_delegate.h"
15 #include "ui/wm/core/base_focus_rules.h"
16 #include "ui/wm/core/capture_controller.h"
17 #include "ui/wm/core/focus_controller.h"
22 // TODO: figure out what this should be.
23 class FocusRulesImpl
: public wm::BaseFocusRules
{
26 ~FocusRulesImpl() override
{}
28 bool SupportsChildActivation(aura::Window
* window
) const override
{
33 DISALLOW_COPY_AND_ASSIGN(FocusRulesImpl
);
38 NativeWidgetViewManager::NativeWidgetViewManager(
39 views::internal::NativeWidgetDelegate
* delegate
,
42 : NativeWidgetAura(delegate
), view_(view
) {
43 view_
->AddObserver(this);
44 window_tree_host_
.reset(new WindowTreeHostMojo(shell
, view_
));
45 window_tree_host_
->InitHost();
47 focus_client_
.reset(new wm::FocusController(new FocusRulesImpl
));
49 aura::client::SetFocusClient(window_tree_host_
->window(),
51 aura::client::SetActivationClient(window_tree_host_
->window(),
53 window_tree_host_
->window()->AddPreTargetHandler(focus_client_
.get());
55 capture_client_
.reset(
56 new aura::client::DefaultCaptureClient(window_tree_host_
->window()));
59 NativeWidgetViewManager::~NativeWidgetViewManager() {
61 view_
->RemoveObserver(this);
64 void NativeWidgetViewManager::InitNativeWidget(
65 const views::Widget::InitParams
& in_params
) {
66 views::Widget::InitParams
params(in_params
);
67 params
.parent
= window_tree_host_
->window();
68 NativeWidgetAura::InitNativeWidget(params
);
71 void NativeWidgetViewManager::OnWindowVisibilityChanged(aura::Window
* window
,
73 view_
->SetVisible(visible
);
74 // NOTE: We could also update aura::Window's visibility when the View's
75 // visibility changes, but this code isn't going to be around for very long so
79 void NativeWidgetViewManager::OnViewDestroyed(mus::View
* view
) {
80 DCHECK_EQ(view
, view_
);
81 view
->RemoveObserver(this);
83 // TODO(sky): WindowTreeHostMojo assumes the View outlives it.
84 // NativeWidgetViewManager needs to deal, likely by deleting this.
87 void NativeWidgetViewManager::OnViewBoundsChanged(
89 const mojo::Rect
& old_bounds
,
90 const mojo::Rect
& new_bounds
) {
91 gfx::Rect view_rect
= view
->bounds().To
<gfx::Rect
>();
92 GetWidget()->SetBounds(gfx::Rect(view_rect
.size()));
95 void NativeWidgetViewManager::OnViewFocusChanged(mus::View
* gained_focus
,
96 mus::View
* lost_focus
) {
97 if (gained_focus
== view_
)
98 window_tree_host_
->GetInputMethod()->OnFocus();
99 else if (lost_focus
== view_
)
100 window_tree_host_
->GetInputMethod()->OnBlur();
103 void NativeWidgetViewManager::OnViewInputEvent(mus::View
* view
,
104 const mojo::EventPtr
& event
) {
105 scoped_ptr
<ui::Event
> ui_event(event
.To
<scoped_ptr
<ui::Event
>>());
109 if (ui_event
->IsKeyEvent()) {
110 window_tree_host_
->GetInputMethod()->DispatchKeyEvent(
111 static_cast<ui::KeyEvent
*>(ui_event
.get()));
113 window_tree_host_
->SendEventToProcessor(ui_event
.get());
117 } // namespace mandoline