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 "ui/app_list/views/start_page_view.h" | 5 #include "ui/app_list/views/start_page_view.h" |
6 | 6 |
7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
8 #include "ui/app_list/app_list_constants.h" | 8 #include "ui/app_list/app_list_constants.h" |
9 #include "ui/app_list/app_list_item.h" | 9 #include "ui/app_list/app_list_item.h" |
10 #include "ui/app_list/app_list_model.h" | 10 #include "ui/app_list/app_list_model.h" |
11 #include "ui/app_list/app_list_view_delegate.h" | 11 #include "ui/app_list/app_list_view_delegate.h" |
12 #include "ui/app_list/views/app_list_main_view.h" | 12 #include "ui/app_list/views/app_list_main_view.h" |
13 #include "ui/app_list/views/search_box_view.h" | |
13 #include "ui/app_list/views/search_result_list_view.h" | 14 #include "ui/app_list/views/search_result_list_view.h" |
14 #include "ui/app_list/views/tile_item_view.h" | 15 #include "ui/app_list/views/tile_item_view.h" |
15 #include "ui/gfx/canvas.h" | 16 #include "ui/gfx/canvas.h" |
16 #include "ui/views/controls/button/custom_button.h" | 17 #include "ui/views/background.h" |
17 #include "ui/views/controls/image_view.h" | 18 #include "ui/views/controls/image_view.h" |
18 #include "ui/views/controls/label.h" | 19 #include "ui/views/controls/label.h" |
20 #include "ui/views/controls/textfield/textfield.h" | |
19 #include "ui/views/layout/box_layout.h" | 21 #include "ui/views/layout/box_layout.h" |
20 | 22 |
21 namespace app_list { | 23 namespace app_list { |
22 | 24 |
23 namespace { | 25 namespace { |
24 | 26 |
27 // Layout constants | |
tapted
2014/06/18 02:46:05
nit: full-stop at the end of comments. More below.
calamity
2014/06/18 06:49:40
Done.
| |
25 const int kTopMargin = 30; | 28 const int kTopMargin = 30; |
29 const int kInstantContainerSpacing = 20; | |
26 | 30 |
31 // WebView constants | |
27 const int kWebViewWidth = 200; | 32 const int kWebViewWidth = 200; |
28 const int kWebViewHeight = 105; | 33 const int kWebViewHeight = 105; |
29 | 34 |
30 const int kInstantContainerSpacing = 20; | 35 // DummySearchBoxView constants |
31 const int kBarPlaceholderWidth = 490; | 36 const int kDummySearchBoxWidth = 490; |
32 const int kBarPlaceholderHeight = 30; | 37 const int kDummySearchBoxHeight = 40; |
38 const SkColor kDummySearchBoxBorderColor = | |
39 SkColorSetARGB(0x30, 0xD0, 0xD0, 0xD0); | |
tapted
2014/06/18 02:46:06
If the thing behind the color is always solid, I t
calamity
2014/06/18 06:49:40
Done. Moved this to app_list_constants.h
| |
40 const int kDummySearchBoxBorderWidth = 1; | |
41 const int kDummySearchBoxBorderBottomWidth = 2; | |
42 const int kDummySearchBoxBorderCornerRadius = 2; | |
33 | 43 |
44 // Tile container constants | |
34 const size_t kNumStartPageTiles = 5; | 45 const size_t kNumStartPageTiles = 5; |
35 const int kTileSpacing = 10; | 46 const int kTileSpacing = 10; |
36 | 47 |
37 // A button that is the placeholder for the search bar in the start page view. | 48 // A placeholder search box which is sized to fit within the start page view. |
38 class BarPlaceholderButton : public views::CustomButton { | 49 class DummySearchBoxView : public SearchBoxView { |
39 public: | 50 public: |
40 explicit BarPlaceholderButton(views::ButtonListener* listener) | 51 explicit DummySearchBoxView(SearchBoxViewDelegate* delegate, |
tapted
2014/06/18 02:46:05
nit: explicit not required
calamity
2014/06/18 06:49:40
Done.
| |
41 : views::CustomButton(listener) {} | 52 AppListViewDelegate* view_delegate) |
53 : SearchBoxView(delegate, view_delegate) {} | |
42 | 54 |
43 virtual ~BarPlaceholderButton() {} | 55 virtual ~DummySearchBoxView() {} |
44 | 56 |
45 // Overridden from views::View: | 57 // Overridden from views::View: |
46 virtual gfx::Size GetPreferredSize() const OVERRIDE { | 58 virtual gfx::Size GetPreferredSize() const OVERRIDE { |
47 return gfx::Size(kBarPlaceholderWidth, kBarPlaceholderHeight); | 59 return gfx::Size(kDummySearchBoxWidth, kDummySearchBoxHeight); |
48 } | |
49 | |
50 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE { | |
51 PaintButton( | |
52 canvas, | |
53 state() == STATE_HOVERED ? kPagerHoverColor : kPagerNormalColor); | |
54 } | 60 } |
55 | 61 |
56 private: | 62 private: |
57 // Paints a rectangular button. | 63 DISALLOW_COPY_AND_ASSIGN(DummySearchBoxView); |
58 void PaintButton(gfx::Canvas* canvas, SkColor base_color) { | 64 }; |
59 gfx::Rect rect(GetContentsBounds()); | 65 |
60 rect.ClampToCenteredSize( | 66 class DummySearchBoxBackground : public views::Background { |
tapted
2014/06/18 02:46:06
this class needs a brief comment describing what P
calamity
2014/06/18 06:49:40
Done.
| |
61 gfx::Size(kBarPlaceholderWidth, kBarPlaceholderHeight)); | 67 public: |
68 DummySearchBoxBackground() {} | |
69 virtual ~DummySearchBoxBackground() {} | |
70 | |
71 private: | |
72 // views::Background overrides: | |
73 virtual void Paint(gfx::Canvas* canvas, views::View* view) const OVERRIDE { | |
74 gfx::Rect bounds = view->GetContentsBounds(); | |
62 | 75 |
63 SkPaint paint; | 76 SkPaint paint; |
64 paint.setAntiAlias(true); | 77 paint.setFlags(SkPaint::kAntiAlias_Flag); |
65 paint.setStyle(SkPaint::kFill_Style); | 78 paint.setColor(kDummySearchBoxBorderColor); |
66 paint.setColor(base_color); | 79 canvas->DrawRoundRect(bounds, kDummySearchBoxBorderCornerRadius, paint); |
67 canvas->DrawRect(rect, paint); | 80 bounds.Inset(kDummySearchBoxBorderWidth, |
81 kDummySearchBoxBorderWidth, | |
82 kDummySearchBoxBorderWidth, | |
83 kDummySearchBoxBorderBottomWidth); | |
84 paint.setColor(SK_ColorWHITE); | |
85 canvas->DrawRoundRect(bounds, kDummySearchBoxBorderCornerRadius, paint); | |
68 } | 86 } |
69 | 87 |
70 DISALLOW_COPY_AND_ASSIGN(BarPlaceholderButton); | 88 DISALLOW_COPY_AND_ASSIGN(DummySearchBoxBackground); |
71 }; | 89 }; |
72 | 90 |
73 } // namespace | 91 } // namespace |
74 | 92 |
75 StartPageView::StartPageView(AppListMainView* app_list_main_view, | 93 StartPageView::StartPageView(AppListMainView* app_list_main_view, |
76 AppListViewDelegate* view_delegate) | 94 AppListViewDelegate* view_delegate) |
77 : app_list_main_view_(app_list_main_view), | 95 : app_list_main_view_(app_list_main_view), |
78 model_(NULL), | 96 model_(NULL), |
79 view_delegate_(view_delegate), | 97 view_delegate_(view_delegate), |
98 search_box_view_(new DummySearchBoxView(this, view_delegate_)), | |
80 results_view_( | 99 results_view_( |
81 new SearchResultListView(app_list_main_view, view_delegate)), | 100 new SearchResultListView(app_list_main_view, view_delegate)), |
82 instant_container_(new views::View), | 101 instant_container_(new views::View), |
83 tiles_container_(new views::View), | 102 tiles_container_(new views::View), |
84 show_state_(SHOW_START_PAGE) { | 103 show_state_(SHOW_START_PAGE) { |
85 // The view containing the start page WebContents and the BarPlaceholder. | 104 // The view containing the start page WebContents and DummySearchBoxView. |
105 InitInstantContainer(); | |
86 AddChildView(instant_container_); | 106 AddChildView(instant_container_); |
107 | |
108 // The view containing the search results. | |
109 AddChildView(results_view_); | |
110 | |
111 // The view containing the start page tiles. | |
112 InitTilesContainer(); | |
113 AddChildView(tiles_container_); | |
114 | |
115 SetModel(view_delegate_->GetModel()); | |
116 view_delegate_->AddObserver(this); | |
117 } | |
118 | |
119 StartPageView::~StartPageView() { | |
120 view_delegate_->RemoveObserver(this); | |
121 if (model_) | |
122 model_->RemoveObserver(this); | |
123 } | |
124 | |
125 void StartPageView::InitInstantContainer() { | |
87 views::BoxLayout* instant_layout_manager = new views::BoxLayout( | 126 views::BoxLayout* instant_layout_manager = new views::BoxLayout( |
88 views::BoxLayout::kVertical, 0, 0, kInstantContainerSpacing); | 127 views::BoxLayout::kVertical, 0, 0, kInstantContainerSpacing); |
89 instant_layout_manager->set_inside_border_insets( | 128 instant_layout_manager->set_inside_border_insets( |
90 gfx::Insets(kTopMargin, 0, kInstantContainerSpacing, 0)); | 129 gfx::Insets(kTopMargin, 0, kInstantContainerSpacing, 0)); |
91 instant_layout_manager->set_main_axis_alignment( | 130 instant_layout_manager->set_main_axis_alignment( |
92 views::BoxLayout::MAIN_AXIS_ALIGNMENT_END); | 131 views::BoxLayout::MAIN_AXIS_ALIGNMENT_END); |
93 instant_container_->SetLayoutManager(instant_layout_manager); | 132 instant_container_->SetLayoutManager(instant_layout_manager); |
94 | 133 |
95 views::View* web_view = view_delegate->CreateStartPageWebView( | 134 views::View* web_view = view_delegate_->CreateStartPageWebView( |
96 gfx::Size(kWebViewWidth, kWebViewHeight)); | 135 gfx::Size(kWebViewWidth, kWebViewHeight)); |
97 if (web_view) | 136 if (web_view) |
98 instant_container_->AddChildView(web_view); | 137 instant_container_->AddChildView(web_view); |
99 instant_container_->AddChildView(new BarPlaceholderButton(this)); | |
100 | 138 |
101 // The view containing the search results. | 139 // TODO(calamity): This container is needed to horizontally center the search |
102 AddChildView(results_view_); | 140 // box view. Remove this container once BoxLayout supports CrossAxisAlignment. |
141 views::View* search_box_container = new views::View(); | |
142 views::BoxLayout* layout_manager = | |
143 new views::BoxLayout(views::BoxLayout::kHorizontal, 0, 0, 0); | |
144 layout_manager->set_main_axis_alignment( | |
145 views::BoxLayout::MAIN_AXIS_ALIGNMENT_CENTER); | |
146 search_box_container->SetLayoutManager(layout_manager); | |
103 | 147 |
104 // The view containing the start page tiles. | 148 search_box_container->AddChildView(search_box_view_); |
105 AddChildView(tiles_container_); | 149 search_box_view_->set_background(new DummySearchBoxBackground()); |
tapted
2014/06/18 02:46:06
maybe do this in the DummySearchBoxView constructo
calamity
2014/06/18 06:49:40
Done.
| |
150 | |
151 instant_container_->AddChildView(search_box_container); | |
152 } | |
153 | |
154 void StartPageView::InitTilesContainer() { | |
106 views::BoxLayout* tiles_layout_manager = | 155 views::BoxLayout* tiles_layout_manager = |
107 new views::BoxLayout(views::BoxLayout::kHorizontal, 0, 0, kTileSpacing); | 156 new views::BoxLayout(views::BoxLayout::kHorizontal, 0, 0, kTileSpacing); |
108 tiles_layout_manager->set_main_axis_alignment( | 157 tiles_layout_manager->set_main_axis_alignment( |
109 views::BoxLayout::MAIN_AXIS_ALIGNMENT_CENTER); | 158 views::BoxLayout::MAIN_AXIS_ALIGNMENT_CENTER); |
110 tiles_container_->SetLayoutManager(tiles_layout_manager); | 159 tiles_container_->SetLayoutManager(tiles_layout_manager); |
111 for (size_t i = 0; i < kNumStartPageTiles; ++i) { | 160 for (size_t i = 0; i < kNumStartPageTiles; ++i) { |
112 TileItemView* tile_item = new TileItemView(); | 161 TileItemView* tile_item = new TileItemView(); |
113 tiles_container_->AddChildView(tile_item); | 162 tiles_container_->AddChildView(tile_item); |
114 tile_views_.push_back(tile_item); | 163 tile_views_.push_back(tile_item); |
115 } | 164 } |
116 | |
117 SetModel(view_delegate_->GetModel()); | |
118 view_delegate_->AddObserver(this); | |
119 } | |
120 | |
121 StartPageView::~StartPageView() { | |
122 view_delegate_->RemoveObserver(this); | |
123 if (model_) | |
124 model_->RemoveObserver(this); | |
125 } | 165 } |
126 | 166 |
127 void StartPageView::SetModel(AppListModel* model) { | 167 void StartPageView::SetModel(AppListModel* model) { |
128 DCHECK(model); | 168 DCHECK(model); |
129 if (model_) | 169 if (model_) |
130 model_->RemoveObserver(this); | 170 model_->RemoveObserver(this); |
131 model_ = model; | 171 model_ = model; |
132 model_->AddObserver(this); | 172 model_->AddObserver(this); |
133 results_view_->SetResults(model_->results()); | 173 results_view_->SetResults(model_->results()); |
134 Reset(); | 174 Reset(); |
(...skipping 13 matching lines...) Expand all Loading... | |
148 } | 188 } |
149 | 189 |
150 void StartPageView::ShowSearchResults() { | 190 void StartPageView::ShowSearchResults() { |
151 SetShowState(SHOW_SEARCH_RESULTS); | 191 SetShowState(SHOW_SEARCH_RESULTS); |
152 } | 192 } |
153 | 193 |
154 void StartPageView::SetShowState(ShowState show_state) { | 194 void StartPageView::SetShowState(ShowState show_state) { |
155 instant_container_->SetVisible(show_state == SHOW_START_PAGE); | 195 instant_container_->SetVisible(show_state == SHOW_START_PAGE); |
156 results_view_->SetVisible(show_state == SHOW_SEARCH_RESULTS); | 196 results_view_->SetVisible(show_state == SHOW_SEARCH_RESULTS); |
157 | 197 |
198 if (show_state == SHOW_START_PAGE) | |
199 search_box_view_->search_box()->RequestFocus(); | |
200 | |
158 if (show_state_ == show_state) | 201 if (show_state_ == show_state) |
159 return; | 202 return; |
160 | 203 |
161 show_state_ = show_state; | 204 show_state_ = show_state; |
162 | 205 |
163 results_view_->UpdateAutoLaunchState(); | 206 results_view_->UpdateAutoLaunchState(); |
164 if (show_state == SHOW_SEARCH_RESULTS) | 207 if (show_state == SHOW_SEARCH_RESULTS) |
165 results_view_->SetSelectedIndex(0); | 208 results_view_->SetSelectedIndex(0); |
166 } | 209 } |
167 | 210 |
(...skipping 14 matching lines...) Expand all Loading... | |
182 bounds.set_height(instant_container_->GetHeightForWidth(bounds.width())); | 225 bounds.set_height(instant_container_->GetHeightForWidth(bounds.width())); |
183 instant_container_->SetBoundsRect(bounds); | 226 instant_container_->SetBoundsRect(bounds); |
184 results_view_->SetBoundsRect(bounds); | 227 results_view_->SetBoundsRect(bounds); |
185 | 228 |
186 // Tiles begin where the instant container ends. | 229 // Tiles begin where the instant container ends. |
187 bounds.set_y(bounds.bottom()); | 230 bounds.set_y(bounds.bottom()); |
188 bounds.set_height(tiles_container_->GetHeightForWidth(bounds.width())); | 231 bounds.set_height(tiles_container_->GetHeightForWidth(bounds.width())); |
189 tiles_container_->SetBoundsRect(bounds); | 232 tiles_container_->SetBoundsRect(bounds); |
190 } | 233 } |
191 | 234 |
192 void StartPageView::ButtonPressed(views::Button* sender, | 235 void StartPageView::QueryChanged(SearchBoxView* sender) { |
193 const ui::Event& event) { | 236 // Forward the search terms on to the real search box and clear the dummy |
194 app_list_main_view_->OnStartPageSearchButtonPressed(); | 237 // search box. |
238 app_list_main_view_->OnStartPageSearchTextfieldChanged( | |
239 sender->search_box()->text()); | |
240 sender->search_box()->SetText(base::string16()); | |
tapted
2014/06/18 02:46:06
each SearchBoxView has a reference to the the same
calamity
2014/06/18 06:49:40
Hmm. This doesn't _actually_ affect anything due t
calamity
2014/06/18 07:08:30
Actually, it looks like this isn't exactly easy. T
| |
195 } | 241 } |
196 | 242 |
197 void StartPageView::OnProfilesChanged() { | 243 void StartPageView::OnProfilesChanged() { |
198 SetModel(view_delegate_->GetModel()); | 244 SetModel(view_delegate_->GetModel()); |
199 } | 245 } |
200 | 246 |
201 void StartPageView::OnAppListModelStatusChanged() { | 247 void StartPageView::OnAppListModelStatusChanged() { |
202 Reset(); | 248 Reset(); |
203 } | 249 } |
204 | 250 |
205 void StartPageView::OnAppListItemAdded(AppListItem* item) { | 251 void StartPageView::OnAppListItemAdded(AppListItem* item) { |
206 Reset(); | 252 Reset(); |
207 } | 253 } |
208 | 254 |
209 void StartPageView::OnAppListItemDeleted() { | 255 void StartPageView::OnAppListItemDeleted() { |
210 Reset(); | 256 Reset(); |
211 } | 257 } |
212 | 258 |
213 void StartPageView::OnAppListItemUpdated(AppListItem* item) { | 259 void StartPageView::OnAppListItemUpdated(AppListItem* item) { |
214 Reset(); | 260 Reset(); |
215 } | 261 } |
216 | 262 |
217 } // namespace app_list | 263 } // namespace app_list |
OLD | NEW |