X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/084cf94a31e7bccbcc9c25d31e6e9893db38d696..b3ac8d783bd2df15014b848657fbe601e7575f38:/src/dolphinmainwindow.cpp diff --git a/src/dolphinmainwindow.cpp b/src/dolphinmainwindow.cpp index ccd80151b..47a74742b 100644 --- a/src/dolphinmainwindow.cpp +++ b/src/dolphinmainwindow.cpp @@ -115,11 +115,11 @@ DolphinMainWindow::DolphinMainWindow() , m_tearDownFromPlacesRequested(false) , m_backAction(nullptr) , m_forwardAction(nullptr) + , m_splitViewAction(nullptr) + , m_splitViewMenuAction(nullptr) , m_sessionSaveTimer(nullptr) , m_sessionSaveWatcher(nullptr) , m_sessionSaveScheduled(false) - , m_splitViewAction(nullptr) - , m_splitViewMenuAction(nullptr) { Q_INIT_RESOURCE(dolphin); @@ -1208,8 +1208,9 @@ QPointer DolphinMainWindow::preferredSearchTool() auto *action = new QAction(QIcon::fromTheme(kfind->icon()), kfind->name(), this); - connect(action, &QAction::triggered, this, [kfind] { + connect(action, &QAction::triggered, this, [this, kfind] { auto *job = new KIO::ApplicationLauncherJob(kfind); + job->setUrls({m_activeViewContainer->url()}); job->start(); }); @@ -1845,7 +1846,6 @@ void DolphinMainWindow::setupActions() // only set it for the menu version actionCollection()->setDefaultShortcut(m_splitViewMenuAction, Qt::Key_F3); - m_splitViewAction->setPopupMode(QToolButton::MenuButtonPopup); connect(m_splitViewAction, &QAction::triggered, this, &DolphinMainWindow::toggleSplitView); connect(m_splitViewMenuAction, &QAction::triggered, this, &DolphinMainWindow::toggleSplitView); @@ -2162,6 +2162,7 @@ void DolphinMainWindow::setupDockWidgets() connect(this, &DolphinMainWindow::selectionChanged, infoPanel, &InformationPanel::setSelection); connect(this, &DolphinMainWindow::requestItemInfo, infoPanel, &InformationPanel::requestDelayedItemInfo); connect(this, &DolphinMainWindow::fileItemsChanged, infoPanel, &InformationPanel::slotFilesItemChanged); + connect(this, &DolphinMainWindow::settingsChanged, infoPanel, &InformationPanel::readSettings); #endif // i18n: This is the last paragraph for the "What's This"-texts of all four panels. @@ -2536,6 +2537,14 @@ void DolphinMainWindow::connectViewSignals(DolphinViewContainer *container) void DolphinMainWindow::updateSplitActions() { QAction *popoutSplitAction = actionCollection()->action(QStringLiteral("popout_split_view")); + + auto setActionPopupMode = [this](KActionMenu *action, QToolButton::ToolButtonPopupMode popupMode) { + action->setPopupMode(popupMode); + if (auto *buttonForAction = qobject_cast(toolBar()->widgetForAction(action))) { + buttonForAction->setPopupMode(popupMode); + } + }; + const DolphinTabPage *tabPage = m_tabWidget->currentTabPage(); if (tabPage->splitViewEnabled()) { if (GeneralSettings::closeActiveSplitView() ? tabPage->primaryViewActive() : !tabPage->primaryViewActive()) { @@ -2553,6 +2562,7 @@ void DolphinMainWindow::updateSplitActions() } popoutSplitAction->setEnabled(true); if (!m_splitViewAction->menu()) { + setActionPopupMode(m_splitViewAction, QToolButton::MenuButtonPopup); m_splitViewAction->setMenu(new QMenu); m_splitViewAction->addAction(popoutSplitAction); } @@ -2564,7 +2574,9 @@ void DolphinMainWindow::updateSplitActions() popoutSplitAction->setEnabled(false); if (m_splitViewAction->menu()) { m_splitViewAction->removeAction(popoutSplitAction); + m_splitViewAction->menu()->deleteLater(); m_splitViewAction->setMenu(nullptr); + setActionPopupMode(m_splitViewAction, QToolButton::DelayedPopup); } } @@ -2608,8 +2620,6 @@ void DolphinMainWindow::createPanelAction(const QIcon &icon, const QKeySequence QAction *panelAction = actionCollection()->addAction(actionName, dockAction); actionCollection()->setDefaultShortcut(panelAction, shortcut); - - connect(panelAction, &QAction::toggled, dockWidget, &QWidget::setVisible); } // clang-format off void DolphinMainWindow::setupWhatsThis()