Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(279)

Unified Diff: ui/app_list/search_result_list_view.cc

Issue 10386224: app_list: Add search box and search result view for v2. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix win_aura Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ui/app_list/search_result_list_view.cc
diff --git a/ui/app_list/search_result_list_view.cc b/ui/app_list/search_result_list_view.cc
new file mode 100644
index 0000000000000000000000000000000000000000..2892224d2ef70504d2ce6e5af96eb75043c9f523
--- /dev/null
+++ b/ui/app_list/search_result_list_view.cc
@@ -0,0 +1,154 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/app_list/search_result_list_view.h"
+
+#include <algorithm>
+
+#include "base/bind.h"
+#include "base/message_loop.h"
+#include "ui/app_list/search_result_view.h"
+#include "ui/app_list/search_result_list_view_delegate.h"
+#include "ui/views/layout/box_layout.h"
+
+namespace {
+
+const int kMaxResults = 6;
+
+} // namespace
+
+namespace app_list {
+
+SearchResultListView::SearchResultListView(
+ SearchResultListViewDelegate* delegate)
+ : delegate_(delegate),
+ results_(NULL),
+ last_visible_index_(0),
+ selected_index_(-1),
+ ALLOW_THIS_IN_INITIALIZER_LIST(update_factory_(this)) {
+ SetLayoutManager(
+ new views::BoxLayout(views::BoxLayout::kVertical, 0, 0, 0));
+
+ for (int i = 0; i < kMaxResults; ++i)
+ AddChildView(new SearchResultView(this, this));
+}
+
+SearchResultListView::~SearchResultListView() {
+ if (results_)
+ results_->RemoveObserver(this);
+}
+
+void SearchResultListView::SetResults(AppListModel::SearchResults* results) {
+ if (results_)
+ results_->RemoveObserver(this);
+
+ results_ = results;
+ if (results_)
+ results_->AddObserver(this);
+
+ Update();
+}
+
+void SearchResultListView::SetSelectedIndex(int selected_index) {
+ if (selected_index_ == selected_index)
+ return;
+
+ if (selected_index_ >= 0)
+ GetResultViewAt(selected_index_)->SchedulePaint();
+
+ selected_index_ = selected_index;
+
+ if (selected_index_ >= 0)
+ GetResultViewAt(selected_index_)->SchedulePaint();
+}
+
+bool SearchResultListView::IsResultViewSelected(
+ const SearchResultView* result_view) const {
+ if (selected_index_ < 0)
+ return false;
+
+ return static_cast<const SearchResultView*>(child_at(selected_index_)) ==
+ result_view;
+}
+
+SearchResultView* SearchResultListView::GetResultViewAt(int index) {
+ DCHECK(index >= 0 && index < child_count());
+ return static_cast<SearchResultView*>(child_at(index));
+}
+
+void SearchResultListView::Update() {
+ last_visible_index_ = 0;
+ for (size_t i = 0; i < static_cast<size_t>(child_count()); ++i) {
+ SearchResultView* result_view = GetResultViewAt(i);
+ if (i < results_->item_count()) {
+ result_view->SetResult(results_->GetItemAt(i));
+ result_view->SetVisible(true);
+ last_visible_index_ = i;
+ } else {
+ result_view->SetResult(NULL);
+ result_view->SetVisible(false);
+ }
+ }
+ if (selected_index_ > last_visible_index_)
+ SetSelectedIndex(last_visible_index_);
+
+ Layout();
+ update_factory_.InvalidateWeakPtrs();
+}
+
+void SearchResultListView::ScheduleUpdate() {
+ // When search results are added one by one, each addition generates an update
+ // request. Consolidates those update requests into one Update call.
+ if (!update_factory_.HasWeakPtrs()) {
+ MessageLoop::current()->PostTask(
+ FROM_HERE,
+ base::Bind(&SearchResultListView::Update,
+ update_factory_.GetWeakPtr()));
+ }
+}
+
+bool SearchResultListView::OnKeyPressed(const views::KeyEvent& event) {
+ switch (event.key_code()) {
+ case ui::VKEY_UP:
+ SetSelectedIndex(std::max(selected_index_ - 1, 0));
+ return true;
+ case ui::VKEY_DOWN:
+ SetSelectedIndex(std::min(selected_index_ + 1, last_visible_index_));
+ return true;
+ case ui::VKEY_RETURN:
+ if (selected_index_ >= 0)
+ ButtonPressed(GetResultViewAt(selected_index_), event);
+ return true;
+ default:
+ break;
+ }
+ return false;
+}
+
+void SearchResultListView::ButtonPressed(views::Button* sender,
+ const views::Event& event) {
+ if (sender->GetClassName() != SearchResultView::kViewClassName)
+ return;
+
+ if (delegate_) {
+ const SearchResult* result =
+ static_cast<SearchResultView*>(sender)->result();
+ DCHECK(result);
+ delegate_->OpenResult(*result, event.flags());
+ }
+}
+
+void SearchResultListView::ListItemsAdded(size_t start, size_t count) {
+ ScheduleUpdate();
+}
+
+void SearchResultListView::ListItemsRemoved(size_t start, size_t count) {
+ ScheduleUpdate();
+}
+
+void SearchResultListView::ListItemsChanged(size_t start, size_t count) {
+ ScheduleUpdate();
+}
+
+} // namespace app_list

Powered by Google App Engine
This is Rietveld 408576698