]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt2/QDocumentDialog.C
better selection and scrolling behaviour
[lyx.git] / src / frontends / qt2 / QDocumentDialog.C
index 8147388bffa97411f309929ce4214fc9290762f6..37c09d4d948c168f258dcb645a07e77dca8fe696 100644 (file)
 #include "ui/MarginsModuleBase.h"
 #include "ui/PreambleModuleBase.h"
 
-#include "QBrowseBox.h"
 #include "Spacing.h"
-#include "support/filetools.h"
 #include "support/lstrings.h"
-#include "Alert.h"
 #include "lyxrc.h"
 #include "buffer.h"
-#include "lyx_main.h" // for user_lyxdir
 
 #include <qwidgetstack.h>
 #include <qlistbox.h>
 #include "lengthcombo.h"
 
 
-/*
- *  Constructs a DocumentDialog which is a child of 'parent', with the
- *  name 'name' and widget flags set to 'f'
- *
- *  The dialog will by default be modeless, unless you set 'modal' to
- *  TRUE to construct a modal dialog.
- */
-QDocumentDialog::QDocumentDialog( QDocument * form)
-       : QDocumentDialogBase( 0, 0, false, 0 ), form_(form)
+QDocumentDialog::QDocumentDialog(QDocument * form)
+       : QDocumentDialogBase(0, 0, false, 0), form_(form)
 {
        connect(okPB, SIGNAL(clicked()),
                form, SLOT(slotOK()));
        connect(applyPB, SIGNAL(clicked()),
                form, SLOT(slotApply()));
-       connect(cancelPB, SIGNAL(clicked()),
+       connect(closePB, SIGNAL(clicked()),
                form, SLOT(slotClose()));
        connect(restorePB, SIGNAL(clicked()),
                form, SLOT(slotRestore()));
 
        moduleLB->clear();
-       moduleLB->insertItem( _("Layout"), LAYOUT );
-       moduleLB->insertItem( _("Packages"), PACKAGES );
-       moduleLB->insertItem( _("Paper"), PAPER );
-       moduleLB->insertItem( _("Margins"), MARGINS );
-       moduleLB->insertItem( _("Language"), LANGUAGE );
-       moduleLB->insertItem( _("Bullets"), BULLETS );
-       moduleLB->insertItem( _("Numbering"), NUMBERING );
-       moduleLB->insertItem( _("Bibliography"), BIBLIOGRAPHY );
-       moduleLB->insertItem( _("Preamble"), PREAMBLE );
+       moduleLB->insertItem(_("Layout"), LAYOUT);
+       moduleLB->insertItem(_("Packages"), PACKAGES);
+       moduleLB->insertItem(_("Paper"), PAPER);
+       moduleLB->insertItem(_("Margins"), MARGINS);
+       moduleLB->insertItem(_("Language"), LANGUAGE);
+       moduleLB->insertItem(_("Bullets"), BULLETS);
+       moduleLB->insertItem(_("Numbering"), NUMBERING);
+       moduleLB->insertItem(_("Bibliography"), BIBLIOGRAPHY);
+       moduleLB->insertItem(_("Preamble"), PREAMBLE);
        moduleLB->setCurrentItem(LAYOUT);
+       moduleLB->setMinimumSize(moduleLB->sizeHint());
 
        layoutModule = new ClassModuleBase(this);
        paperModule = new PaperModuleBase(this);
@@ -94,185 +84,185 @@ QDocumentDialog::QDocumentDialog( QDocument * form)
        biblioModule = new BiblioModuleBase(this);
        preambleModule = new PreambleModuleBase(this);
 
-       moduleStack->addWidget(layoutModule,LAYOUT);
-       moduleStack->addWidget(paperModule,PAPER);
-       moduleStack->addWidget(marginsModule,MARGINS);
-       moduleStack->addWidget(packagesModule,PACKAGES);
-       moduleStack->addWidget(langModule,LANGUAGE);
-       moduleStack->addWidget(bulletsModule,BULLETS);
-       moduleStack->addWidget(numberingModule,NUMBERING);
-       moduleStack->addWidget(biblioModule,BIBLIOGRAPHY);
-       moduleStack->addWidget(preambleModule,PREAMBLE);
+       moduleStack->addWidget(layoutModule, LAYOUT);
+       moduleStack->addWidget(paperModule, PAPER);
+       moduleStack->addWidget(marginsModule, MARGINS);
+       moduleStack->addWidget(packagesModule, PACKAGES);
+       moduleStack->addWidget(langModule, LANGUAGE);
+       moduleStack->addWidget(bulletsModule, BULLETS);
+       moduleStack->addWidget(numberingModule, NUMBERING);
+       moduleStack->addWidget(biblioModule, BIBLIOGRAPHY);
+       moduleStack->addWidget(preambleModule, PREAMBLE);
 
        moduleStack->raiseWidget(LAYOUT);
 
-       //QPixmap image("standard.xpm");
-       //bulletsModule->bulletsBB->insertItem(image);
-       //bulletsModule->bulletsBB->resize(image.width(),image.height());
+
        // take care of title
        QFont f = titleL->font();
-       f.setWeight( QFont::Bold );
-       titleL->setFont( f );
+       f.setWeight(QFont::Bold);
+       titleL->setFont(f);
        setTitle(LAYOUT);
 
-       /* preamble */
-       connect( preambleModule->preambleMLE, SIGNAL( textChanged() ),
-                this , SLOT( change_adaptor() ) );
-       /* biblio */
-       connect( biblioModule->natbibCB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( biblioModule->citeStyleCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       /* language & quote */
-       connect( langModule->singleQuoteRB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( langModule->doubleQuoteRB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( langModule->languageCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( langModule->quoteStyleCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       /* numbering */
-       connect( numberingModule->sectionnrDepthSB,
-                SIGNAL( valueChanged(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( numberingModule->tocDepthSB,
-                SIGNAL( valueChanged(int) ),
-                this , SLOT( change_adaptor() ) );
-       /* packages */
-       connect( packagesModule->lspacingCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( packagesModule->lspacingCO, SIGNAL( activated(int) ),
-                this , SLOT( setLSpacing(int) ) );
-       connect( packagesModule->lspacingLE,
-                SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( packagesModule->encodingCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( packagesModule->amsCB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( packagesModule->psdriverCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       /* layout */
-       connect( layoutModule->classCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->optionsLE,
-                SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->pagestyleCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->fontsCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->fontsizeCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->floatPlacementLE,
-                SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->skipRB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->indentRB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->skipCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->skipLE,
-                SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( layoutModule->skipLengthCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-
-       connect( layoutModule->classCO, SIGNAL( activated(int) ),
-                this , SLOT( classChanged() ) );
-       connect( layoutModule->skipCO, SIGNAL( activated(int) ),
-                this , SLOT( setSkip(int) ) );
-       connect( layoutModule->skipRB, SIGNAL( toggled(bool) ),
-                this , SLOT( enableSkip(bool) ) );
-
-       /* margins */
-       connect( marginsModule->marginCO, SIGNAL( activated(int) ),
-                this , SLOT( setCustomMargins(int) ) );
-
-       connect( marginsModule->marginCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->topLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->topUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->bottomLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->bottomUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->innerLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->innerUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->outerLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->outerUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->headheightLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->headheightUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->headsepLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->headsepUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->footskipLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( marginsModule->footskipUnit, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-
-       /* paper */
-       connect( paperModule->papersizeCO, SIGNAL( activated(int) ),
-                this , SLOT( setMargins(int) ) );
-       connect( paperModule->papersizeCO, SIGNAL( activated(int) ),
-                this , SLOT( setCustomPapersize(int) ) );
-       connect( paperModule->papersizeCO, SIGNAL( activated(int) ),
-                this , SLOT( setCustomPapersize(int) ) );
-
-       connect( paperModule->papersizeCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->paperheightLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->paperwidthLE, SIGNAL( textChanged(const QString&) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->paperwidthUnitCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->paperheightUnitCO, SIGNAL( activated(int) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->portraitRB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->landscapeRB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->twoColumnCB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-       connect( paperModule->facingPagesCB, SIGNAL( toggled(bool) ),
-                this , SLOT( change_adaptor() ) );
-
-}
-
+       // preamble
+       connect(preambleModule->preambleMLE, SIGNAL(textChanged()),
+                this , SLOT(change_adaptor()));
+       // biblio
+       connect(biblioModule->natbibCB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(biblioModule->citeStyleCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       // language & quote
+       connect(langModule->singleQuoteRB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(langModule->doubleQuoteRB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(langModule->languageCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(langModule->quoteStyleCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       // numbering
+       connect(numberingModule->sectionnrDepthSB,
+                SIGNAL(valueChanged(int)),
+                this , SLOT(change_adaptor()));
+       connect(numberingModule->tocDepthSB,
+                SIGNAL(valueChanged(int)),
+                this , SLOT(change_adaptor()));
+       // packages
+       connect(packagesModule->lspacingCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(packagesModule->lspacingCO, SIGNAL(activated(int)),
+                this , SLOT(setLSpacing(int)));
+       connect(packagesModule->lspacingLE,
+                SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(packagesModule->encodingCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(packagesModule->amsCB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(packagesModule->psdriverCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       // layout
+       connect(layoutModule->classCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->optionsLE,
+                SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->pagestyleCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->fontsCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->fontsizeCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->floatPlacementLE,
+                SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->skipRB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->indentRB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->skipCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->skipLE,
+                SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(layoutModule->skipLengthCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+
+       connect(layoutModule->classCO, SIGNAL(activated(int)),
+                this , SLOT(classChanged()));
+       connect(layoutModule->skipCO, SIGNAL(activated(int)),
+                this , SLOT(setSkip(int)));
+       connect(layoutModule->skipRB, SIGNAL(toggled(bool)),
+                this , SLOT(enableSkip(bool)));
+
+       // margins
+       connect(marginsModule->marginCO, SIGNAL(activated(int)),
+                this , SLOT(setCustomMargins(int)));
+
+       connect(marginsModule->marginCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->topLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->topUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->bottomLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->bottomUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->innerLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->innerUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->outerLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->outerUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->headheightLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->headheightUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->headsepLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->headsepUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->footskipLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(marginsModule->footskipUnit, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+
+       // paper
+       connect(paperModule->papersizeCO, SIGNAL(activated(int)),
+                this , SLOT(setMargins(int)));
+       connect(paperModule->papersizeCO, SIGNAL(activated(int)),
+                this , SLOT(setCustomPapersize(int)));
+       connect(paperModule->papersizeCO, SIGNAL(activated(int)),
+                this , SLOT(setCustomPapersize(int)));
+
+       connect(paperModule->papersizeCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->paperheightLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->paperwidthLE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->paperwidthUnitCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->paperheightUnitCO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->portraitRB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->landscapeRB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->twoColumnCB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+       connect(paperModule->facingPagesCB, SIGNAL(toggled(bool)),
+                this , SLOT(change_adaptor()));
+
+       // bullets
+       connect(bulletsModule->bullet1LE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bulletsize1CO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bullet2LE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bulletsize2CO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bullet3LE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bulletsize3CO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bullet4LE, SIGNAL(textChanged(const QString&)),
+                this , SLOT(change_adaptor()));
+       connect(bulletsModule->bulletsize4CO, SIGNAL(activated(int)),
+                this , SLOT(change_adaptor()));
 
-void QDocumentDialog::showPreamble()
-{
-       moduleStack->raiseWidget(PREAMBLE);
-       setTitle(PREAMBLE);
-       QDocumentDialogBase::show();
 }
 
 
-/*
- *  Destroys the object and frees any allocated resources
- */
 QDocumentDialog::~QDocumentDialog()
 {
-    // no need to delete child widgets, Qt does it all for us
 }
 
 
-/*
- * public slot
- */
-
 void QDocumentDialog::setTitle(int item)
 {
        switch(item) {
@@ -307,28 +297,15 @@ void QDocumentDialog::setTitle(int item)
 }
 
 
-/*
- * public slot
- */
-void QDocumentDialog::saveDocDefault()
-{}
-
-
-/*
- * public slot
- */
-void QDocumentDialog::restore()
+void QDocumentDialog::saveDefaultClicked()
 {
-    qWarning( "DocumentDialog::restore() not yet implemented!" );
+       form_->saveDocDefault();
 }
 
 
-/*
- * public slot
- */
-void QDocumentDialog::useClassDefaults()
+void QDocumentDialog::useDefaultsClicked()
 {
-    qWarning( "DocumentDialog::useClassDefaults() not yet implemented!" );
+    form_->useClassDefaults();
 }
 
 
@@ -353,7 +330,7 @@ void QDocumentDialog::setLSpacing(int item)
 
 void QDocumentDialog::setSkip(int item)
 {
-       bool enable = (item == 3);
+       bool const enable = (item == 3);
        layoutModule->skipLE->setEnabled(enable);
        layoutModule->skipLengthCO->setEnabled(enable);
 }
@@ -371,17 +348,17 @@ void QDocumentDialog::enableSkip(bool skip)
 
 void QDocumentDialog::setMargins(int papersize)
 {
-       QStringList a4only;
-       QStringList normal;
-       a4only << _("Small Margins") << _( "Very small Margins")
-              << _("Very wide Margins ");
-       normal << _("Default") << _("Custom");
+       char const * a4only[] = {
+               _("Small Margins"), _("Very small Margins"),
+               _("Very wide Margins "), 0 };
+       char const * normal[] = {
+               _("Default"), _("Custom"), 0 };
 
        int olditem = marginsModule->marginCO->currentItem();
        marginsModule->marginCO->clear();
-       marginsModule->marginCO->insertStringList(normal);
+       marginsModule->marginCO->insertStrList(normal);
        if (papersize==6) {
-               marginsModule->marginCO->insertStringList(a4only);
+               marginsModule->marginCO->insertStrList(a4only);
        }
        marginsModule->marginCO->setCurrentItem(olditem);
        setCustomMargins(olditem);
@@ -475,10 +452,31 @@ void QDocumentDialog::updatePagestyle(string const & items, string const & sel)
 
 void QDocumentDialog::classChanged()
 {
-       updateFontsize(form_->controller().textClass().opt_fontsize(),
-                      form_->controller().params().fontsize);
+       ControlDocument & cntrl = form_->controller();
+       BufferParams & params = cntrl.params();
 
-       updatePagestyle(form_->controller().textClass().opt_pagestyle(),
-                       form_->controller().params().pagestyle);
+       lyx::textclass_type const tc = layoutModule->classCO->currentItem();
 
+       if (form_->controller().loadTextclass(tc)) {
+               params.textclass = tc;
+
+               if (lyxrc.auto_reset_options) {
+                       params.useClassDefaults();
+                       form_->update_contents();
+               } else {
+                       updateFontsize(cntrl.textClass().opt_fontsize(),
+                                      params.fontsize);
+
+                       updatePagestyle(cntrl.textClass().opt_pagestyle(),
+                                       params.pagestyle);
+               }
+       } else {
+               for (int n = 0; n<layoutModule->classCO->count(); ++n) {
+                       if (layoutModule->classCO->text(n) ==
+                           cntrl.textClass().description().c_str()) {
+                               layoutModule->classCO->setCurrentItem(n);
+                               break;
+                       }
+               }
+       }
 }