summaryrefslogtreecommitdiffstats
path: root/chrome/browser/gtk/toolbar_star_toggle_gtk.cc
diff options
context:
space:
mode:
authorestade@chromium.org <estade@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-09-01 18:56:35 +0000
committerestade@chromium.org <estade@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-09-01 18:56:35 +0000
commit84c88aa65b45234668caa6b4a7205e534a7b8973 (patch)
tree23d54dea38749e169a832a29a52845faf4ecfadc /chrome/browser/gtk/toolbar_star_toggle_gtk.cc
parent0f215e0c0e92474342c3003414d1e0f7ee5e8eba (diff)
downloadchromium_src-84c88aa65b45234668caa6b4a7205e534a7b8973.zip
chromium_src-84c88aa65b45234668caa6b4a7205e534a7b8973.tar.gz
chromium_src-84c88aa65b45234668caa6b4a7205e534a7b8973.tar.bz2
GTK: Make the toolbar star button a drag source.
Also refactor URI list/named url packing code. BUG=19008 Review URL: http://codereview.chromium.org/175036 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@25067 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/gtk/toolbar_star_toggle_gtk.cc')
-rw-r--r--chrome/browser/gtk/toolbar_star_toggle_gtk.cc24
1 files changed, 23 insertions, 1 deletions
diff --git a/chrome/browser/gtk/toolbar_star_toggle_gtk.cc b/chrome/browser/gtk/toolbar_star_toggle_gtk.cc
index ed4f524c..8723a48 100644
--- a/chrome/browser/gtk/toolbar_star_toggle_gtk.cc
+++ b/chrome/browser/gtk/toolbar_star_toggle_gtk.cc
@@ -4,13 +4,16 @@
#include "chrome/browser/gtk/toolbar_star_toggle_gtk.h"
+#include "app/gtk_dnd_util.h"
#include "app/resource_bundle.h"
#include "base/gfx/rect.h"
+#include "chrome/browser/browser.h"
#include "chrome/browser/gtk/bookmark_bubble_gtk.h"
#include "chrome/browser/gtk/browser_toolbar_gtk.h"
#include "chrome/browser/gtk/gtk_chrome_button.h"
#include "chrome/browser/gtk/gtk_theme_provider.h"
#include "chrome/browser/profile.h"
+#include "chrome/browser/tab_contents/tab_contents.h"
#include "chrome/common/notification_service.h"
#include "grit/theme_resources.h"
@@ -29,10 +32,18 @@ ToolbarStarToggleGtk::ToolbarStarToggleGtk(BrowserToolbarGtk* host)
// We effectively double-buffer by virtue of having only one image...
gtk_widget_set_double_buffered(widget_.get(), FALSE);
- g_signal_connect(G_OBJECT(widget_.get()), "expose-event",
+ g_signal_connect(widget(), "expose-event",
G_CALLBACK(OnExpose), this);
GTK_WIDGET_UNSET_FLAGS(widget_.get(), GTK_CAN_FOCUS);
+ gtk_drag_source_set(widget(), GDK_BUTTON1_MASK,
+ NULL, 0, GDK_ACTION_COPY);
+ GtkDndUtil::SetSourceTargetListFromCodeMask(widget(),
+ GtkDndUtil::TEXT_PLAIN |
+ GtkDndUtil::TEXT_URI_LIST |
+ GtkDndUtil::CHROME_NAMED_URL);
+ g_signal_connect(widget(), "drag-data-get", G_CALLBACK(OnDragDataGet), this);
+
theme_provider_->InitThemesFor(this);
registrar_.Add(this,
NotificationType::BROWSER_THEME_CHANGED,
@@ -90,6 +101,17 @@ gboolean ToolbarStarToggleGtk::OnExpose(GtkWidget* widget, GdkEventExpose* e,
}
}
+// static
+void ToolbarStarToggleGtk::OnDragDataGet(GtkWidget* widget,
+ GdkDragContext* drag_context, GtkSelectionData* data, guint info,
+ guint time, ToolbarStarToggleGtk* star) {
+ const TabContents* tab = star->host_->browser()->tabstrip_model()->
+ GetSelectedTabContents();
+ if (!tab)
+ return;
+ GtkDndUtil::WriteURLWithName(data, tab->GetURL(), tab->GetTitle(), info);
+}
+
void ToolbarStarToggleGtk::UpdateGTKButton() {
bool use_gtk = theme_provider_ && theme_provider_->UseGtkTheme();