changeset 1460:69b7fdd6394f

Add option to suppress close button on first pane
author Chris Cannam
date Fri, 17 May 2019 14:37:02 +0100 (2019-05-17)
parents 42c87368287c
children e561f0a8d75b
files view/PaneStack.cpp view/PaneStack.h
diffstat 2 files changed, 32 insertions(+), 5 deletions(-) [+]
line wrap: on
line diff
--- a/view/PaneStack.cpp	Fri May 17 10:02:52 2019 +0100
+++ b/view/PaneStack.cpp	Fri May 17 14:37:02 2019 +0100
@@ -41,6 +41,7 @@
     QFrame(parent),
     m_currentPane(nullptr),
     m_showAccessories(true),
+    m_showCloseButtonOnFirstPane(true),
     m_showAlignmentViews(false),
     m_splitter(new QSplitter),
     m_autoResizeStack(new QWidget),
@@ -81,6 +82,12 @@
 }
 
 void
+PaneStack::setShowCloseButtonOnFirstPane(bool show)
+{
+    m_showCloseButtonOnFirstPane = show;
+}
+
+void
 PaneStack::setShowAlignmentViews(bool show)
 {
     m_showAlignmentViews = show;
@@ -116,6 +123,9 @@
     xButton->setFixedSize(QSize(16, 16));
     xButton->setFlat(true);
     xButton->setVisible(m_showAccessories);
+    if (m_panes.empty() && !m_showCloseButtonOnFirstPane) {
+        xButton->setVisible(false);
+    }
     layout->addWidget(xButton, 1, 0);
     connect(xButton, SIGNAL(clicked()), this, SLOT(paneDeleteButtonClicked()));
 
@@ -123,7 +133,8 @@
     connect(currentIndicator, SIGNAL(clicked()), this, SLOT(indicatorClicked()));
     layout->addWidget(currentIndicator, 2, 0);
     layout->setRowStretch(1, 20);
-    currentIndicator->setMinimumWidth(8);
+    currentIndicator->setMinimumWidth(16);
+    currentIndicator->setMinimumHeight(16);
     currentIndicator->setScaledContents(true);
     currentIndicator->setVisible(m_showAccessories);
 
@@ -381,8 +392,15 @@
     bool multi = (getPaneCount() > 1);
     for (std::vector<PaneRec>::iterator i = m_panes.begin();
          i != m_panes.end(); ++i) {
-        i->xButton->setVisible(multi && m_showAccessories);
-        i->currentIndicator->setVisible(multi && m_showAccessories);
+        bool visible = (multi && m_showAccessories);
+        bool xvisible = visible;
+        if (i == m_panes.begin()) {
+            if (!m_showCloseButtonOnFirstPane) {
+                xvisible = false;
+            }
+        }
+        i->xButton->setVisible(xvisible);
+        i->currentIndicator->setVisible(visible);
     }
 }
 
--- a/view/PaneStack.h	Fri May 17 10:02:52 2019 +0100
+++ b/view/PaneStack.h	Fri May 17 14:37:02 2019 +0100
@@ -79,9 +79,17 @@
     ResizeMode getResizeMode() const { return m_resizeMode; }
     void setResizeMode(ResizeMode);
 
+    // Set whether the current-pane indicators and close buttons are
+    // shown. The default is true.
+    void setShowPaneAccessories(bool show);
+
+    // Set whether a close button is shown on the first pane as well
+    // as others. (It may be reasonable to omit the close button from
+    // what is presumably the main pane in some applications.)  The
+    // default is true.
+    void setShowCloseButtonOnFirstPane(bool);
+
     void setPropertyStackMinWidth(int mw);
-    
-    void setShowPaneAccessories(bool show); // current indicator, close button
 
     void setShowAlignmentViews(bool show);
 
@@ -139,6 +147,7 @@
     std::vector<PaneRec> m_hiddenPanes;
 
     bool m_showAccessories;
+    bool m_showCloseButtonOnFirstPane;
     bool m_showAlignmentViews;
 
     QSplitter *m_splitter; // constitutes the stack in UserResizeable mode