blob: 3a4962edabc9be66ece3a0791e89c6c01d98f7c9 (
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
|
// 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.
#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/compiler_specific.h"
#include "base/memory/weak_ptr.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;
class ChromeWebContentsViewDelegateGtk;
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:
typedef ChromeWebContentsViewDelegateGtk TabContentsViewType;
ConstrainedWindowGtk(TabContentsWrapper* wrapper,
ConstrainedWindowGtkDelegate* delegate);
virtual ~ConstrainedWindowGtk();
// Overridden from ConstrainedWindow:
virtual void ShowConstrainedWindow() OVERRIDE;
virtual void CloseConstrainedWindow() OVERRIDE;
virtual void FocusConstrainedWindow() OVERRIDE;
// 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 WebContentsView.
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_
|