┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/dolphintabpage.cpp
diff options
context:
space:
mode:
authorFelix Ernst <[email protected]>2020-10-28 17:52:29 +0100
committerElvis Angelaccio <[email protected]>2020-11-09 23:49:07 +0100
commita418d6229e31dac254660da2a417b4306f066ae3 (patch)
tree2ee8cdcfbc3c4e92a480f82fdb3afee89af8a1ea /src/dolphintabpage.cpp
parent37327c9b0aae112c5890703cba1f0157043007e0 (diff)
Fix a crash and extract unrelated changes
The secondary UrlNavigator is now created when and only when: - split view mode is activated for the active tab OR - switching to a tab that has split view already enabled. This fixes a crash that occurs when the setting to always start in split view mode is enabled. An animation for activating split view is also removed from this and moved into a separate MR. Another unrelated name change left over from a previous commit (viewContainers() -> activeViewContainers()) is dropped.
Diffstat (limited to 'src/dolphintabpage.cpp')
-rw-r--r--src/dolphintabpage.cpp41
1 files changed, 1 insertions, 40 deletions
diff --git a/src/dolphintabpage.cpp b/src/dolphintabpage.cpp
index d2fd1d143..d196508a8 100644
--- a/src/dolphintabpage.cpp
+++ b/src/dolphintabpage.cpp
@@ -9,7 +9,6 @@
#include "dolphin_generalsettings.h"
#include "dolphinviewcontainer.h"
-#include <QPropertyAnimation>
#include <QSplitter>
#include <QVBoxLayout>
@@ -70,7 +69,6 @@ void DolphinTabPage::setSplitViewEnabled(bool enabled, const QUrl &secondaryUrl)
m_splitViewEnabled = enabled;
if (enabled) {
- int splitterTotalWidth = m_splitter->width();
const QUrl& url = (secondaryUrl.isEmpty()) ? m_primaryViewContainer->url() : secondaryUrl;
m_secondaryViewContainer = createViewContainer(url);
@@ -84,33 +82,8 @@ void DolphinTabPage::setSplitViewEnabled(bool enabled, const QUrl &secondaryUrl)
m_splitter->addWidget(m_secondaryViewContainer);
m_secondaryViewContainer->installEventFilter(this);
- m_secondaryViewContainer->setActive(true);
-
- // opening animation
- m_splitter->widget(1)->setMinimumWidth(1);
- const QList<int> splitterSizes = {m_splitter->width(), 0};
- m_splitter->setSizes(splitterSizes);
-
- // TODO: This is only here to test the robustness of DolphinNavigatorsWidgetAction! I still have to move it to another merge request!
- m_splitViewAnimation = new QVariantAnimation(m_splitter);
- m_splitViewAnimation->setDuration(200); // TODO: where do I get the animation times from again?
- m_splitViewAnimation->setStartValue(splitterTotalWidth);
- m_splitViewAnimation->setEndValue(splitterTotalWidth / 2);
- m_splitViewAnimation->setEasingCurve(QEasingCurve::OutCubic);
-
- connect(m_splitViewAnimation, &QVariantAnimation::valueChanged, [=]() {
- if (m_splitter->count() != 2) {
- return;
- }
- int value = m_splitViewAnimation->currentValue().toInt();
- const QList<int> splitterSizes = {value, m_splitter->width() - value};
- m_splitter->setSizes(splitterSizes);
- if (value == m_splitViewAnimation->endValue().toInt()) {
- m_splitter->widget(1)->setMinimumWidth(m_splitter->widget(1)->minimumSizeHint().width());
- }
- });
- m_splitViewAnimation->start(QAbstractAnimation::DeleteWhenStopped);
m_secondaryViewContainer->show();
+ m_secondaryViewContainer->setActive(true);
} else {
m_navigatorsWidget->setSecondaryNavigatorVisible(false);
m_secondaryViewContainer->disconnectUrlNavigator();
@@ -144,10 +117,6 @@ void DolphinTabPage::setSplitViewEnabled(bool enabled, const QUrl &secondaryUrl)
m_primaryViewContainer->setActive(true);
view->close();
view->deleteLater();
- if (m_splitViewAnimation) {
- delete m_splitViewAnimation;
- m_splitter->widget(0)->setMinimumWidth(m_splitter->widget(0)->minimumSizeHint().width());
- }
}
}
}
@@ -194,10 +163,6 @@ void DolphinTabPage::connectNavigators(DolphinNavigatorsWidgetAction *navigators
m_primaryViewContainer->connectUrlNavigator(primaryNavigator);
if (m_splitViewEnabled) {
auto secondaryNavigator = navigatorsWidget->secondaryUrlNavigator();
- if (!secondaryNavigator) {
- navigatorsWidget->createSecondaryUrlNavigator();
- secondaryNavigator = navigatorsWidget->secondaryUrlNavigator();
- }
secondaryNavigator->setActive(!m_primaryViewActive);
m_secondaryViewContainer->connectUrlNavigator(secondaryNavigator);
}
@@ -334,10 +299,6 @@ void DolphinTabPage::restoreState(const QByteArray& state)
m_navigatorsWidget->primaryUrlNavigator()->setActive(false);
}
- if (m_splitViewAnimation) {
- delete m_splitViewAnimation;
- m_splitter->widget(0)->setMinimumWidth(m_splitter->widget(0)->minimumSizeHint().width());
- }
QByteArray splitterState;
stream >> splitterState;
m_splitter->restoreState(splitterState);