summaryrefslogtreecommitdiffstats
path: root/chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc
diff options
context:
space:
mode:
authorrogerta@chromium.org <rogerta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-17 18:44:01 +0000
committerrogerta@chromium.org <rogerta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-17 18:44:01 +0000
commit557205cef10e483f2953299d241e21e0a96c007e (patch)
treebe8df5f77cc8267405c9d799bd8631ec9b1e612c /chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc
parent531b5d55c4ce29b7c84e3b6be201b5bfb5ac3df5 (diff)
downloadchromium_src-557205cef10e483f2953299d241e21e0a96c007e.zip
chromium_src-557205cef10e483f2953299d241e21e0a96c007e.tar.gz
chromium_src-557205cef10e483f2953299d241e21e0a96c007e.tar.bz2
Allow dragging and dropping of URLs to any portion of the toolbar view.
BUG=9181 TEST=Drag a URL or ay text to the toolbar area, including back/forward/reload buttons, and the browser action/menu area. This should not interfere with dragging and dropping of browser actions. Test that browser actions behave as they should (i.e. should be able to change their order in the toolbar). Review URL: http://codereview.chromium.org/6462009 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@75288 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc')
-rw-r--r--chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc45
1 files changed, 43 insertions, 2 deletions
diff --git a/chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc b/chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc
index fd04090..192a40e 100644
--- a/chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc
+++ b/chrome/browser/autocomplete/autocomplete_edit_view_gtk.cc
@@ -31,6 +31,7 @@
#include "net/base/escape.h"
#include "third_party/undoview/undo_view.h"
#include "ui/base/animation/multi_animation.h"
+#include "ui/base/dragdrop/drag_drop_types.h"
#include "ui/base/l10n/l10n_util.h"
#include "ui/base/resource/resource_bundle.h"
#include "ui/gfx/color_utils.h"
@@ -44,6 +45,7 @@
#include "chrome/browser/ui/views/autocomplete/autocomplete_popup_contents_view.h"
#include "chrome/browser/ui/views/location_bar/location_bar_view.h"
#include "views/controls/textfield/native_textfield_views.h"
+#include "views/events/event.h"
#else
#include "chrome/browser/autocomplete/autocomplete_popup_view_gtk.h"
#include "chrome/browser/ui/gtk/gtk_theme_provider.h"
@@ -65,6 +67,16 @@ size_t GetUTF8Offset(const string16& text, size_t text_offset) {
return UTF16ToUTF8(text.substr(0, text_offset)).size();
}
+// A helper method for determining a valid drag operation given the allowed
+// operation. We prefer copy over link.
+int CopyOrLinkDragOperation(int drag_operation) {
+ if (drag_operation & ui::DragDropTypes::DRAG_COPY)
+ return ui::DragDropTypes::DRAG_COPY;
+ if (drag_operation & ui::DragDropTypes::DRAG_LINK)
+ return ui::DragDropTypes::DRAG_LINK;
+ return ui::DragDropTypes::DRAG_NONE;
+}
+
// Stores GTK+-specific state so it can be restored after switching tabs.
struct ViewState {
explicit ViewState(const AutocompleteEditViewGtk::CharRange& selection_range)
@@ -843,6 +855,27 @@ views::View* AutocompleteEditViewGtk::AddToView(views::View* parent) {
return host;
}
+int AutocompleteEditViewGtk::OnPerformDrop(
+ const views::DropTargetEvent& event) {
+ std::wstring text;
+ const ui::OSExchangeData& data = event.data();
+ if (data.HasURL()) {
+ GURL url;
+ std::wstring title;
+ if (data.GetURLAndTitle(&url, &title))
+ text = UTF8ToWide(url.spec());
+ } else {
+ std::wstring data_string;
+ if (data.GetString(&data_string))
+ text = CollapseWhitespace(data_string, true);
+ }
+
+ if (!text.empty() && OnPerformDropImpl(WideToUTF16(text)))
+ return CopyOrLinkDragOperation(event.source_operations());
+
+ return ui::DragDropTypes::DRAG_NONE;
+}
+
void AutocompleteEditViewGtk::EnableAccessibility() {
accessible_widget_helper_.reset(
new AccessibleWidgetHelper(text_view(), model_->profile()));
@@ -1545,8 +1578,7 @@ void AutocompleteEditViewGtk::HandleDragDataReceived(
string16 possible_url = UTF8ToUTF16(reinterpret_cast<char*>(text));
g_free(text);
- if (model_->CanPasteAndGo(CollapseWhitespace(possible_url, true))) {
- model_->PasteAndGo();
+ if (OnPerformDropImpl(possible_url)) {
gtk_drag_finish(context, TRUE, TRUE, time);
static guint signal_id =
@@ -1737,6 +1769,15 @@ void AutocompleteEditViewGtk::HandleCopyOrCutClipboard(bool copy) {
OwnPrimarySelection(UTF16ToUTF8(text));
}
+bool AutocompleteEditViewGtk::OnPerformDropImpl(const string16& text) {
+ if (model_->CanPasteAndGo(CollapseWhitespace(text, true))) {
+ model_->PasteAndGo();
+ return true;
+ }
+
+ return false;
+}
+
gfx::Font AutocompleteEditViewGtk::GetFont() {
#if defined(TOOLKIT_VIEWS)
bool use_gtk = false;