blob: 34abb8b85fe4e5f51f596c3fceee95f1cda78fb5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
// Copyright (c) 2011 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.
#ifndef CHROME_BROWSER_UI_GTK_CONSTRAINED_WINDOW_GTK_H_
#define CHROME_BROWSER_UI_GTK_CONSTRAINED_WINDOW_GTK_H_
#pragma once
#include <gtk/gtk.h>
#include "base/basictypes.h"
#include "base/memory/weak_ptr.h"
#include "base/task.h"
#include "chrome/browser/ui/constrained_window.h"
#include "ui/base/gtk/gtk_signal.h"
#include "ui/base/gtk/owned_widget_gtk.h"
class TabContentsWrapper;
typedef struct _GdkColor GdkColor;
#if defined(TOOLKIT_VIEWS)
class NativeTabContentsViewGtk;
#else
class ChromeTabContentsViewWrapperGtk;
#endif
class ConstrainedWindowGtkDelegate {
public:
// Returns the widget that will be put in the constrained window's container.
virtual GtkWidget* GetWidgetRoot() = 0;
// Returns the widget that should get focus when ConstrainedWindow is focused.
virtual GtkWidget* GetFocusWidget() = 0;
// Tells the delegate to either delete itself or set up a task to delete
// itself later.
virtual void DeleteDelegate() = 0;
virtual bool GetBackgroundColor(GdkColor* color);
// Returns true if hosting ConstrainedWindowGtk should apply default padding.
virtual bool ShouldHaveBorderPadding() const;
protected:
virtual ~ConstrainedWindowGtkDelegate();
};
// Constrained window implementation for the GTK port. Unlike the Win32 system,
// ConstrainedWindowGtk doesn't draw draggable fake windows and instead just
// centers the dialog. It is thus an order of magnitude simpler.
class ConstrainedWindowGtk : public ConstrainedWindow {
public:
#if defined(TOOLKIT_VIEWS)
typedef NativeTabContentsViewGtk TabContentsViewType;
#else
typedef ChromeTabContentsViewWrapperGtk TabContentsViewType;
#endif
ConstrainedWindowGtk(TabContentsWrapper* wrapper,
ConstrainedWindowGtkDelegate* delegate);
virtual ~ConstrainedWindowGtk();
// Overridden from ConstrainedWindow:
virtual void ShowConstrainedWindow();
virtual void CloseConstrainedWindow();
virtual void FocusConstrainedWindow();
// Returns the TabContentsWrapper that constrains this Constrained Window.
TabContentsWrapper* owner() const { return wrapper_; }
// Returns the toplevel widget that displays this "window".
GtkWidget* widget() { return border_.get(); }
// Returns the View that we collaborate with to position ourselves.
TabContentsViewType* ContainingView();
private:
friend class ConstrainedWindow;
// Signal callbacks.
CHROMEGTK_CALLBACK_1(ConstrainedWindowGtk, gboolean, OnKeyPress,
GdkEventKey*);
CHROMEGTK_CALLBACK_1(ConstrainedWindowGtk, void, OnHierarchyChanged,
GtkWidget*);
// The TabContentsWrapper that owns and constrains this ConstrainedWindow.
TabContentsWrapper* wrapper_;
// The top level widget container that exports to our TabContentsView.
ui::OwnedWidgetGtk border_;
// Delegate that provides the contents of this constrained window.
ConstrainedWindowGtkDelegate* delegate_;
// Stores if |ShowConstrainedWindow()| has been called.
bool visible_;
base::WeakPtrFactory<ConstrainedWindowGtk> weak_factory_;
DISALLOW_COPY_AND_ASSIGN(ConstrainedWindowGtk);
};
#endif // CHROME_BROWSER_UI_GTK_CONSTRAINED_WINDOW_GTK_H_
|