]> git.lyx.org Git - features.git/commitdiff
Fix loop when opening TOC widget in an empty document, basically by Richard Heck.
authorJürgen Spitzmüller <spitz@lyx.org>
Tue, 17 Apr 2007 10:27:53 +0000 (10:27 +0000)
committerJürgen Spitzmüller <spitz@lyx.org>
Tue, 17 Apr 2007 10:27:53 +0000 (10:27 +0000)
* src/frontends/qt4/TocWidget.[Ch]:
- rename enableButtons to enableControls and include slider enabling/disabling
- only set slider if there is some content

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@17835 a592a061-630c-0410-9148-cb99ea01b6c8

src/frontends/qt4/TocWidget.C
src/frontends/qt4/TocWidget.h

index 0ff2763766502d48670b780f8238d16430c0c231..b1cde0eb52b38ce28719ddd142ab8d1fc074ad2e 100644 (file)
@@ -129,39 +129,39 @@ void TocWidget::on_typeCO_activated(int value)
 
 void TocWidget::on_moveUpPB_clicked()
 {
-       enableButtons(false);
+       enableControls(false);
        QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
        if (!list.isEmpty()) {
-               enableButtons(false);
+               enableControls(false);
                form_->goTo(typeCO->currentIndex(), list[0]);
                form_->outlineUp();
-               enableButtons(true);
+               enableControls(true);
        }
 }
 
 
 void TocWidget::on_moveDownPB_clicked()
 {
-       enableButtons(false);
+       enableControls(false);
        QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
        if (!list.isEmpty()) {
-               enableButtons(false);
+               enableControls(false);
                form_->goTo(typeCO->currentIndex(), list[0]);
                form_->outlineDown();
-               enableButtons(true);
+               enableControls(true);
        }
 }
 
 
 void TocWidget::on_moveInPB_clicked()
 {
-       enableButtons(false);
+       enableControls(false);
        QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
        if (!list.isEmpty()) {
-               enableButtons(false);
+               enableControls(false);
                form_->goTo(typeCO->currentIndex(), list[0]);
                form_->outlineIn();
-               enableButtons(true);
+               enableControls(true);
        }
 }
 
@@ -170,10 +170,10 @@ void TocWidget::on_moveOutPB_clicked()
 {
        QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
        if (!list.isEmpty()) {
-               enableButtons(false);
+               enableControls(false);
                form_->goTo(typeCO->currentIndex(), list[0]);
                form_->outlineOut();
-               enableButtons(true);
+               enableControls(true);
        }
 }
 
@@ -194,7 +194,7 @@ void TocWidget::select(QModelIndex const & index)
 }
 
 
-void TocWidget::enableButtons(bool enable)
+void TocWidget::enableControls(bool enable)
 {
        updatePB->setEnabled(enable);
 
@@ -205,6 +205,8 @@ void TocWidget::enableButtons(bool enable)
        moveDownPB->setEnabled(enable);
        moveInPB->setEnabled(enable);
        moveOutPB->setEnabled(enable);
+
+       depthSL->setEnabled(enable);
 }
 
 
@@ -220,11 +222,10 @@ void TocWidget::updateGui()
 {
        QStringListModel * type_model = form_->typeModel();
        if (type_model->stringList().isEmpty()) {
-               enableButtons(false);
+               enableControls(false);
                typeCO->setModel(type_model);
                tocTV->setModel(new QStandardItemModel);
                tocTV->setEditTriggers(QAbstractItemView::NoEditTriggers);
-               depthSL->setEnabled(false);
                return;
        }
 
@@ -242,20 +243,22 @@ void TocWidget::updateGui()
 
 void TocWidget::setTocModel(size_t type)
 {
-       bool buttons_enabled = false;
+       bool controls_enabled = false;
        QStandardItemModel * toc_model = form_->tocModel(type);
        if (toc_model) {
-               buttons_enabled = toc_model->rowCount() > 0;
+               controls_enabled = toc_model->rowCount() > 0;
                tocTV->setModel(toc_model);
                tocTV->setEditTriggers(QAbstractItemView::NoEditTriggers);
        }
 
-       enableButtons(buttons_enabled);
+       enableControls(controls_enabled);
 
        reconnectSelectionModel();
-       depthSL->setEnabled(true);
-       depthSL->setMaximum(form_->getTocDepth(type));
-       depthSL->setValue(depth_);
+
+       if (controls_enabled) {
+               depthSL->setMaximum(form_->getTocDepth(type));
+               depthSL->setValue(depth_);
+       }
 
        LYXERR(Debug::GUI) << "In TocWidget::updateGui()" << endl;
 
index c04989fd04b2f25ff93eac5613d273c7a090f605..14897cfaaff0d790d32d333b7529360749e81692 100644 (file)
@@ -51,7 +51,7 @@ protected Q_SLOTS:
 
 protected:
        ///
-       void enableButtons(bool enable = true);
+       void enableControls(bool enable = true);
        ///
        int getIndexDepth(QModelIndex const & index, int depth = -1);
        ///