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 "chrome/browser/ui/views/autofill/autofill_popup_base_view.h" | 5 #include "chrome/browser/ui/views/autofill/autofill_popup_base_view.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "chrome/browser/ui/autofill/popup_constants.h" | 10 #include "chrome/browser/ui/autofill/popup_constants.h" |
11 #include "ui/views/border.h" | 11 #include "ui/views/border.h" |
| 12 #include "ui/views/focus/focus_manager.h" |
12 #include "ui/views/widget/widget.h" | 13 #include "ui/views/widget/widget.h" |
13 | 14 |
14 namespace autofill { | 15 namespace autofill { |
15 | 16 |
16 const SkColor AutofillPopupBaseView::kBorderColor = | 17 const SkColor AutofillPopupBaseView::kBorderColor = |
17 SkColorSetARGB(0xFF, 0xC7, 0xCA, 0xCE); | 18 SkColorSetARGB(0xFF, 0xC7, 0xCA, 0xCE); |
18 const SkColor AutofillPopupBaseView::kHoveredBackgroundColor = | 19 const SkColor AutofillPopupBaseView::kHoveredBackgroundColor = |
19 SkColorSetARGB(0xFF, 0xCD, 0xCD, 0xCD); | 20 SkColorSetARGB(0xFF, 0xCD, 0xCD, 0xCD); |
20 const SkColor AutofillPopupBaseView::kItemTextColor = | 21 const SkColor AutofillPopupBaseView::kItemTextColor = |
21 SkColorSetARGB(0xFF, 0x7F, 0x7F, 0x7F); | 22 SkColorSetARGB(0xFF, 0x7F, 0x7F, 0x7F); |
22 const SkColor AutofillPopupBaseView::kPopupBackground = | 23 const SkColor AutofillPopupBaseView::kPopupBackground = |
23 SkColorSetARGB(0xFF, 0xFF, 0xFF, 0xFF); | 24 SkColorSetARGB(0xFF, 0xFF, 0xFF, 0xFF); |
24 const SkColor AutofillPopupBaseView::kValueTextColor = | 25 const SkColor AutofillPopupBaseView::kValueTextColor = |
25 SkColorSetARGB(0xFF, 0x00, 0x00, 0x00); | 26 SkColorSetARGB(0xFF, 0x00, 0x00, 0x00); |
26 const SkColor AutofillPopupBaseView::kWarningTextColor = | 27 const SkColor AutofillPopupBaseView::kWarningTextColor = |
27 SkColorSetARGB(0xFF, 0x7F, 0x7F, 0x7F); | 28 SkColorSetARGB(0xFF, 0x7F, 0x7F, 0x7F); |
28 | 29 |
29 AutofillPopupBaseView::AutofillPopupBaseView( | 30 AutofillPopupBaseView::AutofillPopupBaseView( |
30 AutofillPopupViewDelegate* delegate, | 31 AutofillPopupViewDelegate* delegate, |
31 views::Widget* observing_widget) | 32 views::FocusManager* focus_manager) |
32 : delegate_(delegate), | 33 : delegate_(delegate), |
33 observing_widget_(observing_widget), | 34 focus_manager_(focus_manager), |
34 weak_ptr_factory_(this) {} | 35 weak_ptr_factory_(this) {} |
35 | 36 |
36 AutofillPopupBaseView::~AutofillPopupBaseView() { | 37 AutofillPopupBaseView::~AutofillPopupBaseView() { |
37 if (delegate_) { | 38 if (delegate_) { |
38 delegate_->ViewDestroyed(); | 39 delegate_->ViewDestroyed(); |
39 | 40 |
40 RemoveObserver(); | 41 RemoveObserver(); |
41 } | 42 } |
42 } | 43 } |
43 | 44 |
44 void AutofillPopupBaseView::DoShow() { | 45 void AutofillPopupBaseView::DoShow() { |
45 const bool initialize_widget = !GetWidget(); | 46 const bool initialize_widget = !GetWidget(); |
46 if (initialize_widget) { | 47 if (initialize_widget) { |
47 observing_widget_->AddObserver(this); | 48 focus_manager_->RegisterAccelerator( |
48 | |
49 views::FocusManager* focus_manager = observing_widget_->GetFocusManager(); | |
50 focus_manager->RegisterAccelerator( | |
51 ui::Accelerator(ui::VKEY_RETURN, ui::EF_NONE), | 49 ui::Accelerator(ui::VKEY_RETURN, ui::EF_NONE), |
52 ui::AcceleratorManager::kNormalPriority, | 50 ui::AcceleratorManager::kNormalPriority, |
53 this); | 51 this); |
54 focus_manager->RegisterAccelerator( | 52 focus_manager_->RegisterAccelerator( |
55 ui::Accelerator(ui::VKEY_ESCAPE, ui::EF_NONE), | 53 ui::Accelerator(ui::VKEY_ESCAPE, ui::EF_NONE), |
56 ui::AcceleratorManager::kNormalPriority, | 54 ui::AcceleratorManager::kNormalPriority, |
57 this); | 55 this); |
58 | 56 |
59 // The widget is destroyed by the corresponding NativeWidget, so we use | 57 // The widget is destroyed by the corresponding NativeWidget, so we use |
60 // a weak pointer to hold the reference and don't have to worry about | 58 // a weak pointer to hold the reference and don't have to worry about |
61 // deletion. | 59 // deletion. |
62 views::Widget* widget = new views::Widget; | 60 views::Widget* widget = new views::Widget; |
63 views::Widget::InitParams params(views::Widget::InitParams::TYPE_POPUP); | 61 views::Widget::InitParams params(views::Widget::InitParams::TYPE_POPUP); |
64 params.delegate = this; | 62 params.delegate = this; |
(...skipping 28 matching lines...) Expand all Loading... |
93 // assume the the widget is still valid after this point. | 91 // assume the the widget is still valid after this point. |
94 // http://crbug.com/229224 | 92 // http://crbug.com/229224 |
95 // NOTE: This deletes |this|. | 93 // NOTE: This deletes |this|. |
96 GetWidget()->Close(); | 94 GetWidget()->Close(); |
97 } else { | 95 } else { |
98 delete this; | 96 delete this; |
99 } | 97 } |
100 } | 98 } |
101 | 99 |
102 void AutofillPopupBaseView::RemoveObserver() { | 100 void AutofillPopupBaseView::RemoveObserver() { |
103 observing_widget_->GetFocusManager()->UnregisterAccelerators(this); | 101 focus_manager_->UnregisterAccelerators(this); |
104 observing_widget_->RemoveObserver(this); | |
105 views::WidgetFocusManager::GetInstance()->RemoveFocusChangeListener(this); | 102 views::WidgetFocusManager::GetInstance()->RemoveFocusChangeListener(this); |
106 } | 103 } |
107 | 104 |
108 void AutofillPopupBaseView::DoUpdateBoundsAndRedrawPopup() { | 105 void AutofillPopupBaseView::DoUpdateBoundsAndRedrawPopup() { |
109 GetWidget()->SetBounds(delegate_->popup_bounds()); | 106 GetWidget()->SetBounds(delegate_->popup_bounds()); |
110 SchedulePaint(); | 107 SchedulePaint(); |
111 } | 108 } |
112 | 109 |
113 void AutofillPopupBaseView::OnNativeFocusChange( | 110 void AutofillPopupBaseView::OnNativeFocusChange( |
114 gfx::NativeView focused_before, | 111 gfx::NativeView focused_before, |
115 gfx::NativeView focused_now) { | 112 gfx::NativeView focused_now) { |
116 if (GetWidget() && GetWidget()->GetNativeView() != focused_now) | 113 if (GetWidget() && GetWidget()->GetNativeView() != focused_now) |
117 HideController(); | 114 HideController(); |
118 } | 115 } |
119 | 116 |
120 void AutofillPopupBaseView::OnWidgetBoundsChanged(views::Widget* widget, | |
121 const gfx::Rect& new_bounds) { | |
122 DCHECK_EQ(widget, observing_widget_); | |
123 HideController(); | |
124 } | |
125 | |
126 void AutofillPopupBaseView::OnMouseCaptureLost() { | 117 void AutofillPopupBaseView::OnMouseCaptureLost() { |
127 ClearSelection(); | 118 ClearSelection(); |
128 } | 119 } |
129 | 120 |
130 bool AutofillPopupBaseView::OnMouseDragged(const ui::MouseEvent& event) { | 121 bool AutofillPopupBaseView::OnMouseDragged(const ui::MouseEvent& event) { |
131 if (HitTestPoint(event.location())) { | 122 if (HitTestPoint(event.location())) { |
132 SetSelection(event.location()); | 123 SetSelection(event.location()); |
133 | 124 |
134 // We must return true in order to get future OnMouseDragged and | 125 // We must return true in order to get future OnMouseDragged and |
135 // OnMouseReleased events. | 126 // OnMouseReleased events. |
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
232 void AutofillPopupBaseView::HideController() { | 223 void AutofillPopupBaseView::HideController() { |
233 if (delegate_) | 224 if (delegate_) |
234 delegate_->Hide(); | 225 delegate_->Hide(); |
235 } | 226 } |
236 | 227 |
237 gfx::NativeView AutofillPopupBaseView::container_view() { | 228 gfx::NativeView AutofillPopupBaseView::container_view() { |
238 return delegate_->container_view(); | 229 return delegate_->container_view(); |
239 } | 230 } |
240 | 231 |
241 } // namespace autofill | 232 } // namespace autofill |
OLD | NEW |