diff --git a/src/widgets/dtitlebar.cpp b/src/widgets/dtitlebar.cpp index 19b150992..f07954ab4 100644 --- a/src/widgets/dtitlebar.cpp +++ b/src/widgets/dtitlebar.cpp @@ -322,9 +322,6 @@ void DTitlebarPrivate::updateButtonsState(Qt::WindowFlags type) bool showClose = (type.testFlag(Qt::WindowCloseButtonHint) || forceShow) && !forceHide; closeButton->setVisible(showClose); - bool showOption = (type.testFlag(Qt::WindowSystemMenuHint) || forceShow) && !isFullscreen; - optionButton->setVisible(showOption); - buttonArea->adjustSize(); buttonArea->resize(buttonArea->size()); @@ -335,8 +332,6 @@ void DTitlebarPrivate::updateButtonsState(Qt::WindowFlags type) void DTitlebarPrivate::updateButtonsFunc() { - optionButton->setDisabled(disableFlags.testFlag(Qt::WindowSystemMenuHint)); - if (!targetWindowHandle) { return; } @@ -1014,6 +1009,30 @@ void DTitlebar::resize(const QSize &sz) DTitlebar::resize(sz.width(), sz.height()); } +bool DTitlebar::menuIsVisible() const +{ + D_DC(DTitlebar); + return !d->optionButton->isVisible(); +} + +void DTitlebar::setMenuVisible(bool visible) +{ + D_D(DTitlebar); + d->optionButton->setVisible(visible); +} + +bool DTitlebar::menuIsDisabled() const +{ + D_DC(DTitlebar); + return !d->optionButton->isEnabled(); +} + +void DTitlebar::setMenuDisabled(bool disabled) +{ + D_D(DTitlebar); + d->optionButton->setDisabled(disabled); +} + /*! * \~english \brief DTitlebar::setDisableFlags will disable button match flags. diff --git a/src/widgets/dtitlebar.h b/src/widgets/dtitlebar.h index 4edfcff60..7abd28763 100644 --- a/src/widgets/dtitlebar.h +++ b/src/widgets/dtitlebar.h @@ -54,6 +54,12 @@ class LIBDTKWIDGETSHARED_EXPORT DTitlebar : public QFrame, public DTK_CORE_NAMES void resize(int width, int height); void resize(const QSize &); + bool menuIsVisible() const; + void setMenuVisible(bool visible); + + bool menuIsDisabled() const; + void setMenuDisabled(bool disabled); + void setDisableFlags(Qt::WindowFlags flags); Qt::WindowFlags disableFlags() const; Q_SIGNALS: