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

Unified Diff: chrome/browser/ui/views/chooser_content_view.cc

Issue 2029863002: Refactor ChooserBubbleUiViewDelegate (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: updated test code Created 4 years, 6 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: chrome/browser/ui/views/chooser_content_view.cc
diff --git a/chrome/browser/ui/views/chooser_content_view.cc b/chrome/browser/ui/views/chooser_content_view.cc
new file mode 100644
index 0000000000000000000000000000000000000000..50b0d7a65a96aea1be74b1acd955042081e3b6a6
--- /dev/null
+++ b/chrome/browser/ui/views/chooser_content_view.cc
@@ -0,0 +1,139 @@
+// Copyright 2016 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 "chrome/browser/ui/views/chooser_content_view.h"
+
+#include "chrome/grit/generated_resources.h"
+#include "components/chooser_controller/chooser_controller.h"
+#include "ui/base/l10n/l10n_util.h"
+#include "ui/base/models/table_model.h"
+#include "ui/views/controls/styled_label.h"
+#include "ui/views/controls/table/table_view.h"
+#include "ui/views/controls/table/table_view_observer.h"
+
+class ChooserTableModel : public ui::TableModel,
+ public ChooserController::Observer {
+ public:
+ explicit ChooserTableModel(ChooserController* chooser_controller);
+ ~ChooserTableModel() override {}
msw 2016/06/08 00:58:45 optional nit: "= default;"?
juncai 2016/06/09 01:59:21 Got compile error "Overriding method must be marke
+
+ // ui::TableModel:
+ int RowCount() override;
+ base::string16 GetText(int row, int column_id) override;
+ void SetObserver(ui::TableModelObserver* observer) override;
+
+ // ChooserController::Observer:
+ void OnOptionsInitialized() override;
+ void OnOptionAdded(size_t index) override;
+ void OnOptionRemoved(size_t index) override;
+
+ void Update();
+
+ private:
+ ui::TableModelObserver* observer_;
+ ChooserController* chooser_controller_;
+
+ DISALLOW_COPY_AND_ASSIGN(ChooserTableModel);
+};
+
+ChooserTableModel::ChooserTableModel(ChooserController* chooser_controller)
+ : observer_(nullptr), chooser_controller_(chooser_controller) {
+ chooser_controller_->set_observer(this);
+}
+
+int ChooserTableModel::RowCount() {
+ // When there are no devices, the table contains a message saying there
+ // are no devices, so the number of rows is always at least 1.
+ return std::max(static_cast<int>(chooser_controller_->NumOptions()), 1);
+}
+
+base::string16 ChooserTableModel::GetText(int row, int column_id) {
+ int num_options = static_cast<int>(chooser_controller_->NumOptions());
+ if (num_options == 0) {
+ DCHECK_EQ(0, row);
+ return l10n_util::GetStringUTF16(
+ IDS_CHOOSER_BUBBLE_NO_DEVICES_FOUND_PROMPT);
+ }
+
+ DCHECK_GE(row, 0);
+ DCHECK_LT(row, num_options);
+ return chooser_controller_->GetOption(static_cast<size_t>(row));
+}
+
+void ChooserTableModel::SetObserver(ui::TableModelObserver* observer) {
+ observer_ = observer;
+}
+
+void ChooserTableModel::OnOptionsInitialized() {
+ if (observer_) {
+ observer_->OnModelChanged();
+ Update();
+ }
+}
+
+void ChooserTableModel::OnOptionAdded(size_t index) {
+ if (observer_) {
+ observer_->OnItemsAdded(static_cast<int>(index), 1);
+ Update();
+ }
+}
+
+void ChooserTableModel::OnOptionRemoved(size_t index) {
+ if (observer_) {
+ observer_->OnItemsRemoved(static_cast<int>(index), 1);
+ Update();
+ }
+}
+
+void ChooserTableModel::Update() {
+ views::TableView* table_view = static_cast<views::TableView*>(observer_);
+
+ if (chooser_controller_->NumOptions() == 0) {
+ observer_->OnModelChanged();
+ table_view->SetEnabled(false);
+ } else {
+ table_view->SetEnabled(true);
+ }
+}
+
+ChooserContentView::ChooserContentView(views::TableViewObserver* observer,
+ ChooserController* chooser_controller) {
msw 2016/06/08 00:58:45 Init |: table_view_(nullptr)| here or with |= null
juncai 2016/06/09 01:59:21 Done.
+ std::vector<ui::TableColumn> table_columns;
+ table_columns.push_back(ui::TableColumn());
+ chooser_table_model_.reset(new ChooserTableModel(chooser_controller));
+ table_view_ = new views::TableView(chooser_table_model_.get(), table_columns,
+ views::TEXT_ONLY, true);
+ table_view_->set_select_on_remove(false);
+ chooser_table_model_->SetObserver(table_view_);
+ table_view_->SetObserver(observer);
+ table_view_->SetEnabled(chooser_controller->NumOptions() > 0);
+}
+
+ChooserContentView::~ChooserContentView() {}
+
+base::string16 ChooserContentView::GetDialogButtonLabel(
+ ui::DialogButton button) const {
+ return l10n_util::GetStringUTF16(button == ui::DIALOG_BUTTON_OK
+ ? IDS_CHOOSER_BUBBLE_CONNECT_BUTTON_TEXT
+ : IDS_CHOOSER_BUBBLE_CANCEL_BUTTON_TEXT);
+}
+
+bool ChooserContentView::IsDialogButtonEnabled(ui::DialogButton button) const {
+ return button != ui::DIALOG_BUTTON_OK ||
+ !table_view_->selection_model().empty();
+}
+
+views::StyledLabel* ChooserContentView::CreateFootnoteView(
+ views::StyledLabelListener* listener) const {
+ base::string16 link =
+ l10n_util::GetStringUTF16(IDS_CHOOSER_BUBBLE_GET_HELP_LINK_TEXT);
+ size_t offset = 0;
+ base::string16 text = l10n_util::GetStringFUTF16(
+ IDS_CHOOSER_BUBBLE_FOOTNOTE_TEXT, link, &offset);
+ views::StyledLabel* styled_label = new views::StyledLabel(text, listener);
+ styled_label->AddStyleRange(
+ gfx::Range(offset, offset + link.length()),
+ views::StyledLabel::RangeStyleInfo::CreateForLink());
+ return styled_label;
+}

Powered by Google App Engine
This is Rietveld 408576698