X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/793ad44cb82c69de89a128f2bd41dd9bede5130f..20dafcb1018ca8690288bbd857f58bcc3e0aa040:/src/dolphintabbar.cpp diff --git a/src/dolphintabbar.cpp b/src/dolphintabbar.cpp index 4c1d9e44a..c70089223 100644 --- a/src/dolphintabbar.cpp +++ b/src/dolphintabbar.cpp @@ -13,10 +13,10 @@ #include #include -DolphinTabBar::DolphinTabBar(QWidget* parent) : - QTabBar(parent), - m_autoActivationIndex(-1), - m_tabToBeClosedOnMiddleMouseButtonRelease(-1) +DolphinTabBar::DolphinTabBar(QWidget *parent) + : QTabBar(parent) + , m_autoActivationIndex(-1) + , m_tabToBeClosedOnMiddleMouseButtonRelease(-1) { setAcceptDrops(true); setSelectionBehaviorOnRemove(QTabBar::SelectPreviousTab); @@ -26,69 +26,57 @@ DolphinTabBar::DolphinTabBar(QWidget* parent) : m_autoActivationTimer = new QTimer(this); m_autoActivationTimer->setSingleShot(true); m_autoActivationTimer->setInterval(800); - connect(m_autoActivationTimer, &QTimer::timeout, - this, &DolphinTabBar::slotAutoActivationTimeout); + connect(m_autoActivationTimer, &QTimer::timeout, this, &DolphinTabBar::slotAutoActivationTimeout); } -void DolphinTabBar::dragEnterEvent(QDragEnterEvent* event) +void DolphinTabBar::dragEnterEvent(QDragEnterEvent *event) { - const QMimeData* mimeData = event->mimeData(); - const int index = tabAt(event->pos()); + const QMimeData *mimeData = event->mimeData(); + const int index = tabAt(event->position().toPoint()); if (mimeData->hasUrls()) { - if (index >= 0) { - event->acceptProposedAction(); - } else { - event->setDropAction(Qt::IgnoreAction); - // Still need to accept it to receive dragMoveEvent - event->accept(); - } + event->acceptProposedAction(); updateAutoActivationTimer(index); } QTabBar::dragEnterEvent(event); } -void DolphinTabBar::dragLeaveEvent(QDragLeaveEvent* event) +void DolphinTabBar::dragLeaveEvent(QDragLeaveEvent *event) { updateAutoActivationTimer(-1); QTabBar::dragLeaveEvent(event); } -void DolphinTabBar::dragMoveEvent(QDragMoveEvent* event) +void DolphinTabBar::dragMoveEvent(QDragMoveEvent *event) { - const QMimeData* mimeData = event->mimeData(); - const int index = tabAt(event->pos()); + const QMimeData *mimeData = event->mimeData(); + const int index = tabAt(event->position().toPoint()); if (mimeData->hasUrls()) { - if (index >= 0) { - event->acceptProposedAction(); - } else { - event->setDropAction(Qt::IgnoreAction); - } updateAutoActivationTimer(index); } QTabBar::dragMoveEvent(event); } -void DolphinTabBar::dropEvent(QDropEvent* event) +void DolphinTabBar::dropEvent(QDropEvent *event) { // Disable the auto activation timer updateAutoActivationTimer(-1); - const QMimeData* mimeData = event->mimeData(); - const int index = tabAt(event->pos()); + const QMimeData *mimeData = event->mimeData(); + const int index = tabAt(event->position().toPoint()); - if (index >= 0 && mimeData->hasUrls()) { + if (mimeData->hasUrls()) { Q_EMIT tabDropEvent(index, event); } QTabBar::dropEvent(event); } -void DolphinTabBar::mousePressEvent(QMouseEvent* event) +void DolphinTabBar::mousePressEvent(QMouseEvent *event) { const int index = tabAt(event->pos()); @@ -104,8 +92,7 @@ void DolphinTabBar::mouseReleaseEvent(QMouseEvent *event) { const int index = tabAt(event->pos()); - if (index >= 0 && index == m_tabToBeClosedOnMiddleMouseButtonRelease - && event->button() == Qt::MiddleButton) { + if (index >= 0 && index == m_tabToBeClosedOnMiddleMouseButtonRelease && event->button() == Qt::MiddleButton) { // Mouse middle click on a tab closes this tab. Q_EMIT tabCloseRequested(index); return; @@ -114,21 +101,22 @@ void DolphinTabBar::mouseReleaseEvent(QMouseEvent *event) QTabBar::mouseReleaseEvent(event); } -void DolphinTabBar::mouseDoubleClickEvent(QMouseEvent* event) +void DolphinTabBar::mouseDoubleClickEvent(QMouseEvent *event) { - const int index = tabAt(event->pos()); + int index = tabAt(event->pos()); if (index < 0) { - // Double click on the empty tabbar area opens a new activated tab - // with the url from the current tab. - Q_EMIT openNewActivatedTab(currentIndex()); - return; + // empty tabbar area case + index = currentIndex(); } + // Double click on the tabbar opens a new activated tab + // with the url from the doubleclicked tab or currentTab otherwise. + Q_EMIT openNewActivatedTab(index); QTabBar::mouseDoubleClickEvent(event); } -void DolphinTabBar::contextMenuEvent(QContextMenuEvent* event) +void DolphinTabBar::contextMenuEvent(QContextMenuEvent *event) { const int index = tabAt(event->pos()); @@ -136,12 +124,12 @@ void DolphinTabBar::contextMenuEvent(QContextMenuEvent* event) // Tab context menu QMenu menu(this); - QAction* newTabAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-new")), i18nc("@action:inmenu", "New Tab")); - QAction* detachTabAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-detach")), i18nc("@action:inmenu", "Detach Tab")); - QAction* closeOtherTabsAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-close-other")), i18nc("@action:inmenu", "Close Other Tabs")); - QAction* closeTabAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-close")), i18nc("@action:inmenu", "Close Tab")); + QAction *newTabAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-new")), i18nc("@action:inmenu", "New Tab")); + QAction *detachTabAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-detach")), i18nc("@action:inmenu", "Detach Tab")); + QAction *closeOtherTabsAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-close-other")), i18nc("@action:inmenu", "Close Other Tabs")); + QAction *closeTabAction = menu.addAction(QIcon::fromTheme(QStringLiteral("tab-close")), i18nc("@action:inmenu", "Close Tab")); - QAction* selectedAction = menu.exec(event->globalPos()); + QAction *selectedAction = menu.exec(event->globalPos()); if (selectedAction == newTabAction) { Q_EMIT openNewActivatedTab(index); } else if (selectedAction == detachTabAction) { @@ -184,3 +172,5 @@ void DolphinTabBar::updateAutoActivationTimer(const int index) } } } + +#include "moc_dolphintabbar.cpp"