blob: ee28b0f1f67bfcd2628e57e1bf9b7eadbeb82380 (
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
|
// Copyright (c) 2009 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_GTK_TAB_CONTENTS_CONTAINER_GTK_H_
#define CHROME_BROWSER_GTK_TAB_CONTENTS_CONTAINER_GTK_H_
#pragma once
#include <gtk/gtk.h>
#include "base/basictypes.h"
#include "chrome/browser/gtk/owned_widget_gtk.h"
#include "chrome/browser/gtk/view_id_util.h"
#include "chrome/common/notification_observer.h"
#include "chrome/common/notification_registrar.h"
class RenderViewHost;
class StatusBubbleGtk;
class TabContents;
typedef struct _GtkFloatingContainer GtkFloatingContainer;
class TabContentsContainerGtk : public NotificationObserver,
public ViewIDUtil::Delegate {
public:
explicit TabContentsContainerGtk(StatusBubbleGtk* status_bubble);
~TabContentsContainerGtk();
void Init();
// Make the specified tab visible.
void SetTabContents(TabContents* tab_contents);
TabContents* GetTabContents() const { return tab_contents_; }
void SetPreviewContents(TabContents* preview);
void PopPreviewContents();
// Remove the tab from the hierarchy.
void DetachTabContents(TabContents* tab_contents);
// NotificationObserver implementation.
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
GtkWidget* widget() { return floating_.get(); }
// ViewIDUtil::Delegate implementation ---------------------------------------
virtual GtkWidget* GetWidgetForViewID(ViewID id);
private:
// Called when a TabContents is destroyed. This gives us a chance to clean
// up our internal state if the TabContents is somehow destroyed before we
// get notified.
void TabContentsDestroyed(TabContents* contents);
// Handler for |floating_|'s "set-floating-position" signal. During this
// callback, we manually set the position of the status bubble.
static void OnSetFloatingPosition(
GtkFloatingContainer* container, GtkAllocation* allocation,
TabContentsContainerGtk* tab_contents_container);
// Add |contents| to the container and start showing it.
void PackTabContents(TabContents* contents);
// Stop showing |contents|.
void HideTabContents(TabContents* contents);
// Removes |preview_contents_|.
void RemovePreviewContents();
NotificationRegistrar registrar_;
// The TabContents for the currently selected tab. This will be showing unless
// there is a preview contents.
TabContents* tab_contents_;
// The current preview contents (for instant). If non-NULL, it will be
// visible.
TabContents* preview_contents_;
// The status bubble manager. Always non-NULL.
StatusBubbleGtk* status_bubble_;
// Top of the TabContentsContainerGtk widget hierarchy. A cross between a
// GtkBin and a GtkFixed, |floating_| has |expanded_| as its one "real" child,
// and the various things that hang off the bottom (status bubble, etc) have
// their positions manually set in OnSetFloatingPosition.
OwnedWidgetGtk floating_;
// We insert and remove TabContents GtkWidgets into this expanded_. This
// should not be a GtkVBox since there were errors with timing where the vbox
// was horizontally split with the top half displaying the current TabContents
// and bottom half displaying the loading page.
GtkWidget* expanded_;
DISALLOW_COPY_AND_ASSIGN(TabContentsContainerGtk);
};
#endif // CHROME_BROWSER_GTK_TAB_CONTENTS_CONTAINER_GTK_H_
|