blob: 69bd696e66b67357097405fa03002d183b1018ad [file] [log] [blame]
// 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.
// Draws the view for the balloons.
#ifndef CHROME_BROWSER_GTK_NOTIFICATIONS_BALLOON_VIEW_GTK_H_
#define CHROME_BROWSER_GTK_NOTIFICATIONS_BALLOON_VIEW_GTK_H_
#include "app/animation.h"
#include "base/basictypes.h"
#include "base/scoped_ptr.h"
#include "chrome/browser/gtk/menu_gtk.h"
#include "chrome/browser/notifications/balloon.h"
#include "chrome/common/notification_observer.h"
#include "chrome/common/notification_registrar.h"
#include "gfx/point.h"
#include "gfx/rect.h"
#include "gfx/size.h"
class BalloonCollection;
class BalloonViewHost;
class MenuGtk;
class NineBox;
class NotificationDetails;
class NotificationOptionsMenuModel;
class NotificationSource;
class SlideAnimation;
// A balloon view is the UI component for desktop notification toasts.
// It draws a border, and within the border an HTML renderer.
class BalloonViewImpl : public BalloonView,
public MenuGtk::Delegate,
public NotificationObserver,
public AnimationDelegate {
public:
explicit BalloonViewImpl(BalloonCollection* collection);
~BalloonViewImpl();
// BalloonView interface.
virtual void Show(Balloon* balloon);
virtual void Update() {}
virtual void RepositionToBalloon();
virtual void Close(bool by_user);
virtual gfx::Size GetSize() const;
private:
// MenuGtk::Delegate interface. These methods shouldn't actually be
// called because we are using a MenuModel which handles these callbacks.
virtual bool IsCommandEnabled(int command_id) const {
NOTIMPLEMENTED();
return true;
}
virtual void ExecuteCommand(int command_id) {
NOTIMPLEMENTED();
}
// Initializes the toolbar style with GTK.
void InitToolbarStyle();
// NotificationObserver interface.
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
// AnimationDelegate interface.
virtual void AnimationProgressed(const Animation* animation);
// Launches the options menu.
void RunOptionsMenu();
// Adjust the contents window size to be appropriate for the frame.
void SizeContentsWindow();
// Do the delayed close work.
void DelayedClose(bool by_user);
// The height of the balloon's shelf.
// The shelf is where is close button is located.
int GetShelfHeight() const;
// The height of the part of the frame around the balloon.
int GetBalloonFrameHeight() const;
// The width and height that the frame should be. If the balloon inside
// changes size, this will not be the same as the actual frame size until
// RepositionToBalloon() has been called and the animation completes.
int GetDesiredTotalWidth() const;
int GetDesiredTotalHeight() const;
// Where the balloon contents should be placed with respect to the top left
// of the frame.
gfx::Point GetContentsOffset() const;
// Where the balloon contents should be in screen coordinates.
gfx::Rect GetContentsRectangle() const;
static gboolean HandleExposeThunk(GtkWidget* widget,
GdkEventExpose* event,
gpointer user_data) {
return reinterpret_cast<BalloonViewImpl*>(user_data)->HandleExpose();
}
gboolean HandleExpose();
static void HandleCloseButtonThunk(GtkWidget* widget, gpointer user_data) {
reinterpret_cast<BalloonViewImpl*>(user_data)->Close(true);
}
static void HandleOptionsMenuButtonThunk(GtkWidget* widget,
gpointer user_data) {
reinterpret_cast<BalloonViewImpl*>(user_data)->RunOptionsMenu();
}
// Non-owned pointer to the balloon which owns this object.
Balloon* balloon_;
// The window that contains the frame of the notification.
GtkWidget* frame_container_;
// The widget that contains the shelf.
GtkWidget* shelf_;
// The toolbar widget within the shelf that contains the buttons.
GtkWidget* toolbar_;
// The window that contains the contents of the notification.
GtkWidget* html_container_;
// The renderer of the HTML contents. Pointer owned by the views hierarchy.
BalloonViewHost* html_contents_;
// The following factory is used to call methods at a later time.
ScopedRunnableMethodFactory<BalloonViewImpl> method_factory_;
// Image painters for the frame of the toast.
scoped_ptr<NineBox> shelf_background_;
scoped_ptr<NineBox> balloon_background_;
// Pointer to sub-view is owned by the View sub-class.
GtkWidget* close_button_;
// An animation to move the balloon on the screen as its position changes.
scoped_ptr<SlideAnimation> animation_;
gfx::Rect anim_frame_start_;
gfx::Rect anim_frame_end_;
// The options menu.
scoped_ptr<MenuGtk> options_menu_;
scoped_ptr<NotificationOptionsMenuModel> options_menu_model_;
GtkWidget* options_menu_button_;
NotificationRegistrar notification_registrar_;
DISALLOW_COPY_AND_ASSIGN(BalloonViewImpl);
};
#endif // CHROME_BROWSER_GTK_NOTIFICATIONS_BALLOON_VIEW_GTK_H_