1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef UI_VIEWS_WINDOW_DIALOG_CLIENT_VIEW_H_
6 #define UI_VIEWS_WINDOW_DIALOG_CLIENT_VIEW_H_
8 #include "ui/base/ui_base_types.h"
9 #include "ui/views/controls/button/button.h"
10 #include "ui/views/focus/focus_manager.h"
11 #include "ui/views/window/client_view.h"
19 // DialogClientView provides adornments for a dialog's content view, including
20 // custom-labeled [OK] and [Cancel] buttons with [Enter] and [Esc] accelerators.
21 // The view also displays the delegate's extra view alongside the buttons and
22 // the delegate's footnote view below the buttons. The view appears like below.
23 // NOTE: The contents view is not inset on the top or side client view edges.
24 // +------------------------------+
26 // +------------------------------+
27 // | [Extra View] [OK] [Cancel] |
28 // | [ Footnote View ] |
29 // +------------------------------+
30 class VIEWS_EXPORT DialogClientView
: public ClientView
,
31 public ButtonListener
,
32 public FocusChangeListener
{
34 DialogClientView(Widget
* widget
, View
* contents_view
);
35 virtual ~DialogClientView();
37 // Accept or Cancel the dialog.
41 // Accessors in case the user wishes to adjust these buttons.
42 LabelButton
* ok_button() const { return ok_button_
; }
43 LabelButton
* cancel_button() const { return cancel_button_
; }
45 // Update the dialog buttons to match the dialog's delegate.
46 void UpdateDialogButtons();
48 // ClientView implementation:
49 virtual bool CanClose() OVERRIDE
;
50 virtual DialogClientView
* AsDialogClientView() OVERRIDE
;
51 virtual const DialogClientView
* AsDialogClientView() const OVERRIDE
;
53 // FocusChangeListener implementation:
54 virtual void OnWillChangeFocus(View
* focused_before
,
55 View
* focused_now
) OVERRIDE
;
56 virtual void OnDidChangeFocus(View
* focused_before
,
57 View
* focused_now
) OVERRIDE
;
59 // View implementation:
60 virtual gfx::Size
GetPreferredSize() OVERRIDE
;
61 virtual void Layout() OVERRIDE
;
62 virtual bool AcceleratorPressed(const ui::Accelerator
& accelerator
) OVERRIDE
;
63 virtual void ViewHierarchyChanged(
64 const ViewHierarchyChangedDetails
& details
) OVERRIDE
;
65 virtual void NativeViewHierarchyChanged() OVERRIDE
;
67 // ButtonListener implementation:
68 virtual void ButtonPressed(Button
* sender
, const ui::Event
& event
) OVERRIDE
;
72 DialogClientView(View
* contents_view
);
74 // Returns the DialogDelegate for the window. Virtual for testing.
75 virtual DialogDelegate
* GetDialogDelegate() const;
77 // Create and add the extra view, if supplied by the delegate.
78 void CreateExtraView();
80 // Creates and adds the footnote view, if supplied by the delegate.
81 void CreateFootnoteView();
83 // View implementation.
84 virtual void ChildPreferredSizeChanged(View
* child
) OVERRIDE
;
85 virtual void ChildVisibilityChanged(View
* child
) OVERRIDE
;
88 FRIEND_TEST_ALL_PREFIXES(DialogClientViewTest
, FocusManager
);
90 bool has_dialog_buttons() const { return ok_button_
|| cancel_button_
; }
92 // Create a dialog button of the appropriate type.
93 LabelButton
* CreateDialogButton(ui::DialogButton type
);
95 // Update |button|'s text and enabled state according to the delegate's state.
96 void UpdateButton(LabelButton
* button
, ui::DialogButton type
);
98 // Returns the height of the row containing the buttons and the extra view.
99 int GetButtonsAndExtraViewRowHeight() const;
101 // Returns the insets for the buttons and extra view.
102 gfx::Insets
GetButtonRowInsets() const;
104 // Closes the widget.
107 // The dialog buttons.
108 LabelButton
* ok_button_
;
109 LabelButton
* cancel_button_
;
111 // The button that is currently default; may be NULL.
112 LabelButton
* default_button_
;
114 // Observe |focus_manager_| to update the default button with focus changes.
115 FocusManager
* focus_manager_
;
117 // The extra view shown in the row of buttons; may be NULL.
120 // The footnote view shown below the buttons; may be NULL.
121 View
* footnote_view_
;
123 // True if we've notified the delegate the window is closing and the delegate
124 // allosed the close. In some situations it's possible to get two closes (see
125 // http://crbug.com/71940). This is used to avoid notifying the delegate
126 // twice, which can have bad consequences.
127 bool notified_delegate_
;
129 DISALLOW_COPY_AND_ASSIGN(DialogClientView
);
134 #endif // UI_VIEWS_WINDOW_DIALOG_CLIENT_VIEW_H_