From 5a53d2bf91dd9861b6b36e398566f8705b1d714a Mon Sep 17 00:00:00 2001 From: Andrea Diamantini Date: Fri, 8 Apr 2011 00:30:12 +0200 Subject: Add bookmarks by dropping inside the bk toolbar. This patch, based on Furkan's work on this, is quite different from the original for the following reasons: first, the "need" to not modify a lot actual code in the urlbar (disabling dragging and reenabling by code. What are the implications? Who really knows this?) Second, the problem of showing "as urls" (showing their icon) TEXT mimeData: not a good choice, IMHO. Actual code is cleaner and works with every drop inside the bk toolbar (In case of text, checking if the derivated url is valid) --- src/bookmarks/bookmarkstoolbar.cpp | 77 +++++++++++++++++++++++++++++--------- 1 file changed, 59 insertions(+), 18 deletions(-) (limited to 'src') diff --git a/src/bookmarks/bookmarkstoolbar.cpp b/src/bookmarks/bookmarkstoolbar.cpp index 8da30c62..3667503b 100644 --- a/src/bookmarks/bookmarkstoolbar.cpp +++ b/src/bookmarks/bookmarkstoolbar.cpp @@ -36,6 +36,7 @@ #include "application.h" #include "bookmarkprovider.h" #include "bookmarkowner.h" +#include "webtab.h" // Qt Includes #include @@ -232,10 +233,16 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) QPoint pos = toolBar()->mapToGlobal(toolBar()->widgetForAction(act)->pos()); act->menu()->popup(QPoint(pos.x(), pos.y() + toolBar()->widgetForAction(act)->height())); } + + return QObject::eventFilter(watched, event); } - else if (watched == toolBar()) + + if (watched != toolBar()) + return QObject::eventFilter(watched, event); + + switch (event->type()) { - if (event->type() == QEvent::Show) + case QEvent::Show: { if (!m_filled) { @@ -243,7 +250,9 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) m_filled = true; } } - if (event->type() == QEvent::ActionRemoved) + break; + + case QEvent::ActionRemoved: { QActionEvent *actionEvent = static_cast(event); if (actionEvent && actionEvent->action() != m_dropAction) @@ -255,7 +264,9 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) } } } - else if (event->type() == QEvent::ParentChange) + break; + + case QEvent::ParentChange: { QActionEvent *actionEvent = static_cast(event); if (actionEvent && actionEvent->action() != m_dropAction) @@ -267,10 +278,12 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) } } } - else if (event->type() == QEvent::DragEnter) + break; + + case QEvent::DragEnter: { QDragEnterEvent *dragEvent = static_cast(event); - if (dragEvent->mimeData()->hasFormat("application/rekonq-bookmark") || dragEvent->mimeData()->hasFormat("text/uri-list")) + if (dragEvent->mimeData()->hasFormat("application/rekonq-bookmark") || dragEvent->mimeData()->hasFormat("text/uri-list") || dragEvent->mimeData()->hasFormat("text/plain")) { QFrame* dropIndicatorWidget = new QFrame(toolBar()); dropIndicatorWidget->setFrameShape(QFrame::VLine); @@ -279,10 +292,12 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) dragEvent->accept(); } } - else if (event->type() == QEvent::DragMove) + break; + + case QEvent::DragMove: { QDragMoveEvent *dragEvent = static_cast(event); - if (dragEvent->mimeData()->hasFormat("application/rekonq-bookmark") || dragEvent->mimeData()->hasFormat("text/uri-list")) + if (dragEvent->mimeData()->hasFormat("application/rekonq-bookmark") || dragEvent->mimeData()->hasFormat("text/uri-list") || dragEvent->mimeData()->hasFormat("text/plain")) { QAction *overAction = toolBar()->actionAt(dragEvent->pos()); KBookmarkActionInterface *overActionBK = dynamic_cast(overAction); @@ -312,14 +327,18 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) } } } - else if (event->type() == QEvent::DragLeave) + break; + + case QEvent::DragLeave: { QDragLeaveEvent *dragEvent = static_cast(event); delete m_dropAction; m_dropAction = 0; dragEvent->accept(); } - else if (event->type() == QEvent::Drop) + break; + + case QEvent::Drop: { QDropEvent *dropEvent = static_cast(event); KBookmark bookmark; @@ -334,10 +353,26 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) } else if (dropEvent->mimeData()->hasFormat("text/uri-list")) { - QString title = dropEvent->mimeData()->text(); + kDebug() << "DROP is URL"; QString url = dropEvent->mimeData()->urls().at(0).toString(); + QString title = url.contains( rApp->mainWindow()->currentTab()->url().url() ) + ? rApp->mainWindow()->currentTab()->view()->title() + : url; bookmark = root.addBookmark(title, url); } + else if (dropEvent->mimeData()->hasFormat("text/plain")) + { + kDebug() << "DROP is TEXT"; + QString url = dropEvent->mimeData()->text(); + KUrl u(url); + if (u.isValid()) + { + QString title = url.contains( rApp->mainWindow()->currentTab()->url().url() ) + ? rApp->mainWindow()->currentTab()->view()->title() + : url; + bookmark = root.addBookmark(title, url); + } + } else { return false; @@ -391,11 +426,9 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) } dropEvent->accept(); } - } - else - { - // Drag handling - if (event->type() == QEvent::MouseButtonPress) + break; + + case QEvent::MouseButtonPress: // drag handling { QPoint pos = toolBar()->mapFromGlobal(QCursor::pos()); KBookmarkActionInterface *action = dynamic_cast(toolBar()->actionAt(pos)); @@ -410,7 +443,9 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) return true; } } - else if (event->type() == QEvent::MouseMove) + break; + + case QEvent::MouseMove: { int distance = (toolBar()->mapFromGlobal(QCursor::pos()) - m_startDragPos).manhattanLength(); if (!m_currentMenu && distance >= QApplication::startDragDistance()) @@ -418,7 +453,9 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) startDrag(); } } - else if (event->type() == QEvent::MouseButtonRelease) + break; + + case QEvent::MouseButtonRelease: { int distance = (toolBar()->mapFromGlobal(QCursor::pos()) - m_startDragPos).manhattanLength(); KBookmarkActionInterface *action = dynamic_cast(toolBar()->actionAt(m_startDragPos)); @@ -430,6 +467,10 @@ bool BookmarkToolBar::eventFilter(QObject *watched, QEvent *event) menu->menu()->popup(QPoint(actionPos.x(), actionPos.y() + toolBar()->widgetForAction(menu)->height())); } } + break; + + default: + break; } return QObject::eventFilter(watched, event); -- cgit v1.2.1