// Copyright (c) 2010 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. // This is the GTK implementation of the First Run bubble, the dialog box // presented on first run of Chromium. There can only ever be a single // bubble open, so the class presents only static methods. #ifndef CHROME_BROWSER_GTK_FIRST_RUN_BUBBLE_H_ #define CHROME_BROWSER_GTK_FIRST_RUN_BUBBLE_H_ #include #include #include "base/basictypes.h" #include "chrome/browser/first_run.h" #include "chrome/browser/gtk/info_bubble_gtk.h" #include "chrome/browser/profile.h" #include "chrome/common/notification_observer.h" #include "chrome/common/notification_registrar.h" class FirstRunBubble : public InfoBubbleGtkDelegate, public NotificationObserver { public: // Shows the first run bubble, pointing at |rect|. static void Show(Profile* profile, GtkWidget* anchor, const gfx::Rect& rect, FirstRun::BubbleType bubble_type); // Implements the InfoBubbleGtkDelegate. We are notified when the bubble // is about to be closed. virtual void InfoBubbleClosing(InfoBubbleGtk* info_bubble, bool closed_by_escape); virtual bool CloseOnEscape() { return true; } // Overridden from NotificationObserver: virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); private: FirstRunBubble(Profile* profile, GtkWidget* anchor, const gfx::Rect& rect); ~FirstRunBubble() { } static void HandleChangeButtonThunk(GtkWidget* widget, gpointer user_data) { reinterpret_cast(user_data)->HandleChangeButton(); } void HandleChangeButton(); static void HandleDestroyThunk(GtkWidget* widget, gpointer userdata) { reinterpret_cast(userdata)->HandleDestroy(); } void HandleDestroy(); static void HandleKeepButtonThunk(GtkWidget* widget, gpointer user_data) { reinterpret_cast(user_data)->HandleKeepButton(); } void HandleKeepButton(); // Our current profile. Profile* profile_; // Provides colors and stuff. GtkThemeProvider* theme_provider_; // The widget we anchor to, and a descendant of the toplevel window we // are transient for. GtkWidget* anchor_; // We let the InfoBubble own our content, and then we delete ourself // when the widget is destroyed (when the InfoBubble is destroyed). GtkWidget* content_; // The various labels in the interface. We keep track of them for theme // changes. std::vector labels_; InfoBubbleGtk* bubble_; NotificationRegistrar registrar_; DISALLOW_COPY_AND_ASSIGN(FirstRunBubble); }; #endif // CHROME_BROWSER_GTK_FIRST_RUN_BUBBLE_H_