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

Unified Diff: ash/display/display_error_dialog.cc

Issue 10986087: Adds DisplayErrorDialog to show the error message of the failure of mirroring to the users. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 3 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
« no previous file with comments | « ash/display/display_error_dialog.h ('k') | ash/display/output_configurator_animation.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ash/display/display_error_dialog.cc
diff --git a/ash/display/display_error_dialog.cc b/ash/display/display_error_dialog.cc
new file mode 100644
index 0000000000000000000000000000000000000000..08749a0509b374a30215816eb7d93f09f311a9b2
--- /dev/null
+++ b/ash/display/display_error_dialog.cc
@@ -0,0 +1,94 @@
+// 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 "ash/display/display_error_dialog.h"
+
+#include "ash/screen_ash.h"
+#include "grit/ash_strings.h"
+#include "ui/aura/window.h"
+#include "ui/base/l10n/l10n_util.h"
+#include "ui/base/ui_base_types.h"
+#include "ui/gfx/rect.h"
+#include "ui/views/border.h"
+#include "ui/views/controls/label.h"
+#include "ui/views/widget/widget.h"
+
+namespace ash {
+namespace internal {
+namespace {
+
+// The width of the area to show the error message.
+const int kDialogMessageWidthPixel = 300;
+
+// The margin width from the error message to the edge of the dialog.
+const int kDialogMessageMarginWidthPixel = 5;
+
+DisplayErrorDialog* g_instance = NULL;
+
+} // namespace
+
+// static
+void DisplayErrorDialog::ShowDialog() {
+ if (g_instance) {
+ DCHECK(g_instance->GetWidget());
+ g_instance->GetWidget()->StackAtTop();
+ g_instance->GetWidget()->GetNativeWindow()->Focus();
+ return;
oshima 2012/10/02 18:18:42 We probably should close this when external displa
Jun Mukai 2012/10/02 21:43:05 Changed the code to close the dialog, but I'm aski
+ }
+
+ const gfx::Display& secondary_display = ash::ScreenAsh::GetSecondaryDisplay();
+
+ g_instance = new DisplayErrorDialog();
+ views::Widget* widget = new views::Widget;
+ views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW);
+ params.delegate = g_instance;
+ // Makes |widget| belong to the secondary display. Size and location are
+ // fixed by CenterWindow() below.
+ params.bounds = gfx::Rect(secondary_display.bounds());
oshima 2012/10/02 18:18:42 do you need gfx::Rect ?
Jun Mukai 2012/10/02 21:43:05 removed. Thanks.
+ params.keep_on_top = true;
+ widget->Init(params);
+
+ widget->GetNativeView()->SetName("DisplayErrorDialog");
+ widget->CenterWindow(widget->GetRootView()->GetPreferredSize());
+ widget->Show();
+}
+
+DisplayErrorDialog::DisplayErrorDialog() {
+ views::View* container = GetContentsView();
+ label_ = new views::Label(
+ l10n_util::GetStringUTF16(IDS_ASH_DISPLAY_FAILURE_ON_MIRRORING));
+ container->AddChildView(label_);
+
+ label_->SetMultiLine(true);
+ label_->SetHorizontalAlignment(views::Label::ALIGN_LEFT);
+ label_->set_border(views::Border::CreateEmptyBorder(
+ kDialogMessageMarginWidthPixel,
+ kDialogMessageMarginWidthPixel,
+ kDialogMessageMarginWidthPixel,
+ kDialogMessageMarginWidthPixel));
+ label_->SizeToFit(kDialogMessageWidthPixel);
+}
+
+DisplayErrorDialog::~DisplayErrorDialog() {
+ g_instance = NULL;
+}
+
+int DisplayErrorDialog::GetDialogButtons() const {
+ return ui::DIALOG_BUTTON_OK;
+}
+
+ui::ModalType DisplayErrorDialog::GetModalType() const {
+ return ui::MODAL_TYPE_NONE;
+}
+
+views::View* DisplayErrorDialog::GetContentsView() {
+ return this;
+}
+
+gfx::Size DisplayErrorDialog::GetPreferredSize() {
+ return label_->GetPreferredSize();
+}
+
+} // namespace internal
+} // namespace ash
« no previous file with comments | « ash/display/display_error_dialog.h ('k') | ash/display/output_configurator_animation.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698