mirror of
https://github.com/KDE/latte-dock.git
synced 2025-01-26 02:04:12 +03:00
improve View config windows focusOut codepath
This commit is contained in:
parent
1740c0be91
commit
334a40fff1
@ -78,6 +78,8 @@ void CanvasConfigView::initParentView(Latte::View *view)
|
||||
{
|
||||
SubConfigView::initParentView(view);
|
||||
|
||||
rootContext()->setContextProperty(QStringLiteral("primaryConfigView"), m_parent);
|
||||
|
||||
updateEnabledBorders();
|
||||
syncGeometry();
|
||||
}
|
||||
@ -117,6 +119,8 @@ void CanvasConfigView::syncGeometry()
|
||||
|
||||
bool CanvasConfigView::event(QEvent *e)
|
||||
{
|
||||
bool result = SubConfigView::event(e);
|
||||
|
||||
switch (e->type()) {
|
||||
case QEvent::Enter:
|
||||
case QEvent::MouseButtonPress:
|
||||
@ -129,7 +133,7 @@ bool CanvasConfigView::event(QEvent *e)
|
||||
break;
|
||||
}
|
||||
|
||||
return SubConfigView::event(e);
|
||||
return result;
|
||||
}
|
||||
|
||||
void CanvasConfigView::showEvent(QShowEvent *ev)
|
||||
@ -169,15 +173,14 @@ void CanvasConfigView::focusOutEvent(QFocusEvent *ev)
|
||||
|
||||
const auto *focusWindow = qGuiApp->focusWindow();
|
||||
|
||||
if ((focusWindow && (focusWindow->flags().testFlag(Qt::Popup)
|
||||
|| focusWindow->flags().testFlag(Qt::ToolTip)))
|
||||
|| m_latteView->alternativesIsShown()) {
|
||||
if (focusWindow && (focusWindow->flags().testFlag(Qt::Popup)
|
||||
|| focusWindow->flags().testFlag(Qt::ToolTip))) {
|
||||
return;
|
||||
}
|
||||
|
||||
const auto parent = qobject_cast<PrimaryConfigView *>(m_parent);
|
||||
|
||||
if (!m_latteView->containsMouse() && parent && !parent->sticker() && !parent->isActive()) {
|
||||
if (!parent->hasFocus()) {
|
||||
parent->hideConfigWindow();
|
||||
}
|
||||
}
|
||||
|
@ -70,9 +70,10 @@ public:
|
||||
|
||||
QRect geometryWhenVisible() const;
|
||||
|
||||
void hideConfigWindow();
|
||||
|
||||
public slots:
|
||||
Q_INVOKABLE void syncGeometry() override;
|
||||
Q_INVOKABLE void hideConfigWindow();
|
||||
|
||||
signals:
|
||||
void showSignal();
|
||||
|
@ -143,7 +143,7 @@ void PrimaryConfigView::requestActivate()
|
||||
SubConfigView::requestActivate();
|
||||
}
|
||||
|
||||
void PrimaryConfigView::showPrimaryWindow()
|
||||
void PrimaryConfigView::showConfigWindow()
|
||||
{
|
||||
if (isVisible()) {
|
||||
return;
|
||||
@ -154,9 +154,17 @@ void PrimaryConfigView::showPrimaryWindow()
|
||||
showSecondaryWindow();
|
||||
}
|
||||
|
||||
void PrimaryConfigView::hidePrimaryWindow()
|
||||
void PrimaryConfigView::hideConfigWindow()
|
||||
{
|
||||
if (m_shellSurface) {
|
||||
//!NOTE: Avoid crash in wayland environment with qt5.9
|
||||
close();
|
||||
} else {
|
||||
hide();
|
||||
}
|
||||
|
||||
hideCanvasWindow();
|
||||
hideSecondaryWindow();
|
||||
}
|
||||
|
||||
void PrimaryConfigView::showCanvasWindow()
|
||||
@ -213,11 +221,11 @@ void PrimaryConfigView::setParentView(Latte::View *view)
|
||||
//!slide-out delay
|
||||
QTimer::singleShot(SLIDEOUTINTERVAL, [this, view]() {
|
||||
initParentView(view);
|
||||
showPrimaryWindow();
|
||||
showConfigWindow();
|
||||
});
|
||||
} else {
|
||||
initParentView(view);
|
||||
showPrimaryWindow();
|
||||
showConfigWindow();
|
||||
}
|
||||
}
|
||||
|
||||
@ -430,6 +438,16 @@ void PrimaryConfigView::hideEvent(QHideEvent *ev)
|
||||
setVisible(false);
|
||||
}
|
||||
|
||||
bool PrimaryConfigView::hasFocus() const
|
||||
{
|
||||
bool primaryHasHocus{isActive()};
|
||||
bool secHasFocus{m_secConfigView && m_secConfigView->isActive()};
|
||||
bool canvasHasFocus{m_canvasConfigView && m_canvasConfigView->isActive()};
|
||||
bool viewHasFocus{m_latteView && (m_latteView->containsMouse() || m_latteView->alternativesIsShown())};
|
||||
|
||||
return (m_blockFocusLost || viewHasFocus || primaryHasHocus || secHasFocus || canvasHasFocus);
|
||||
}
|
||||
|
||||
void PrimaryConfigView::focusOutEvent(QFocusEvent *ev)
|
||||
{
|
||||
Q_UNUSED(ev);
|
||||
@ -440,15 +458,12 @@ void PrimaryConfigView::focusOutEvent(QFocusEvent *ev)
|
||||
|
||||
const auto *focusWindow = qGuiApp->focusWindow();
|
||||
|
||||
if (!m_latteView
|
||||
|| (focusWindow && (focusWindow->flags().testFlag(Qt::Popup)
|
||||
|| focusWindow->flags().testFlag(Qt::ToolTip)))
|
||||
|| m_latteView->alternativesIsShown()) {
|
||||
if (focusWindow && (focusWindow->flags().testFlag(Qt::Popup)
|
||||
|| focusWindow->flags().testFlag(Qt::ToolTip))) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!m_blockFocusLost && !m_latteView->containsMouse()
|
||||
&& (!m_secConfigView || (m_secConfigView && !m_secConfigView->isActive()))) {
|
||||
if (!hasFocus()) {
|
||||
hideConfigWindow();
|
||||
}
|
||||
}
|
||||
@ -554,19 +569,6 @@ void PrimaryConfigView::setInAdvancedMode(bool advanced)
|
||||
emit inAdvancedModeChanged();
|
||||
}
|
||||
|
||||
void PrimaryConfigView::hideConfigWindow()
|
||||
{
|
||||
if (m_shellSurface) {
|
||||
//!NOTE: Avoid crash in wayland environment with qt5.9
|
||||
close();
|
||||
} else {
|
||||
hide();
|
||||
}
|
||||
|
||||
hideCanvasWindow();
|
||||
hideSecondaryWindow();
|
||||
}
|
||||
|
||||
//!BEGIN borders
|
||||
void PrimaryConfigView::updateEnabledBorders()
|
||||
{
|
||||
|
@ -88,6 +88,8 @@ public:
|
||||
bool inAdvancedMode() const;
|
||||
void setInAdvancedMode(bool advanced);
|
||||
|
||||
bool hasFocus() const;
|
||||
|
||||
bool isReady() const;
|
||||
|
||||
bool showInlineProperties() const;
|
||||
@ -99,8 +101,7 @@ public:
|
||||
void setParentView(Latte::View *view) override;
|
||||
void setOnActivities(QStringList activities);
|
||||
|
||||
void showPrimaryWindow();
|
||||
void hidePrimaryWindow();
|
||||
void showConfigWindow();
|
||||
|
||||
void requestActivate() override;
|
||||
|
||||
|
@ -92,6 +92,8 @@ void SecondaryConfigView::initParentView(Latte::View *view)
|
||||
{
|
||||
SubConfigView::initParentView(view);
|
||||
|
||||
rootContext()->setContextProperty(QStringLiteral("primaryConfigView"), m_parent);
|
||||
|
||||
updateEnabledBorders();
|
||||
syncGeometry();
|
||||
}
|
||||
@ -207,15 +209,14 @@ void SecondaryConfigView::focusOutEvent(QFocusEvent *ev)
|
||||
|
||||
const auto *focusWindow = qGuiApp->focusWindow();
|
||||
|
||||
if ((focusWindow && (focusWindow->flags().testFlag(Qt::Popup)
|
||||
|| focusWindow->flags().testFlag(Qt::ToolTip)))
|
||||
|| m_latteView->alternativesIsShown()) {
|
||||
if (focusWindow && (focusWindow->flags().testFlag(Qt::Popup)
|
||||
|| focusWindow->flags().testFlag(Qt::ToolTip))) {
|
||||
return;
|
||||
}
|
||||
|
||||
const auto parent = qobject_cast<PrimaryConfigView *>(m_parent);
|
||||
|
||||
if (!m_latteView->containsMouse() && parent && !parent->sticker() && !parent->isActive()) {
|
||||
if (!parent->hasFocus()) {
|
||||
parent->hideConfigWindow();
|
||||
}
|
||||
}
|
||||
|
@ -72,9 +72,10 @@ public:
|
||||
|
||||
QRect geometryWhenVisible() const;
|
||||
|
||||
void hideConfigWindow();
|
||||
|
||||
public slots:
|
||||
Q_INVOKABLE void syncGeometry() override;
|
||||
Q_INVOKABLE void hideConfigWindow();
|
||||
Q_INVOKABLE void updateEffects();
|
||||
|
||||
signals:
|
||||
|
@ -457,9 +457,9 @@ void View::showConfigurationInterface(Plasma::Applet *applet)
|
||||
|
||||
if (m_primaryConfigView && c && c->isContainment() && c == this->containment()) {
|
||||
if (m_primaryConfigView->isVisible()) {
|
||||
m_primaryConfigView->hidePrimaryWindow();
|
||||
m_primaryConfigView->hideConfigWindow();
|
||||
} else {
|
||||
m_primaryConfigView->showPrimaryWindow();
|
||||
m_primaryConfigView->showConfigWindow();
|
||||
applyActivitiesToWindows();
|
||||
}
|
||||
|
||||
|
@ -66,7 +66,7 @@ FocusScope {
|
||||
|
||||
Keys.onPressed: {
|
||||
if (event.key === Qt.Key_Escape) {
|
||||
viewConfig.hideConfigWindow();
|
||||
primaryConfigView.hideConfigWindow();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user