]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt2/QDocumentDialog.C
Use PanelStack for the document dialog too
[lyx.git] / src / frontends / qt2 / QDocumentDialog.C
index 323c703b0702895a7765d54ae74508d0fb7993da..481a15091b849d0a851cdf99a27c8a8375f77ae6 100644 (file)
@@ -9,14 +9,11 @@
  */
 
 #include <config.h>
-#include "gettext.h"
+#include "qt_helpers.h"
 
 #include "ControlDocument.h"
 #include "QDocument.h"
 
-#ifdef __GNUG__
-#pragma implementation
-#endif
 
 #include "QDocumentDialog.h"
 
@@ -30,6 +27,7 @@
 #include "ui/NumberingModuleBase.h"
 #include "ui/MarginsModuleBase.h"
 #include "ui/PreambleModuleBase.h"
+#include "panelstack.h"
 
 #include "Spacing.h"
 #include "support/lstrings.h"
@@ -62,187 +60,102 @@ QDocumentDialog::QDocumentDialog(QDocument * form)
        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->setCurrentItem(LAYOUT);
-       moduleLB->setMinimumSize(moduleLB->sizeHint());
-
        layoutModule = new ClassModuleBase(this);
        paperModule = new PaperModuleBase(this);
        marginsModule = new MarginsModuleBase(this);
-       packagesModule = new PackagesModuleBase(this);
        langModule = new LanguageModuleBase(this);
        bulletsModule = new BulletsModule(this);
        numberingModule = new NumberingModuleBase(this);
        biblioModule = new BiblioModuleBase(this);
+       packagesModule = new PackagesModuleBase(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->raiseWidget(LAYOUT);
-
-
-       // take care of title
-       QFont f = titleL->font();
-       f.setWeight(QFont::Bold);
-       titleL->setFont(f);
-       setTitle(LAYOUT);
+       docPS->addPanel(layoutModule, _("Layout"));
+       docPS->addPanel(paperModule, _("Paper"));
+       docPS->addPanel(marginsModule, _("Margins"));
+       docPS->addPanel(langModule, _("Language"));
+       docPS->addPanel(numberingModule, _("Table of Contents"));
+       docPS->addPanel(biblioModule, _("Bibliography"));
+       docPS->addPanel(packagesModule, _("LaTeX packages"));
+       docPS->addPanel(bulletsModule, _("Bullets"));
+       docPS->addPanel(preambleModule, _("LaTeX Preamble"));
+       docPS->setCurrentPanel(_("Layout"));
 
        // preamble
-       connect(preambleModule->preambleMLE, SIGNAL(textChanged()),
-                this , SLOT(change_adaptor()));
+       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()));
+       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()));
+       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->defaultencodingCB, SIGNAL(toggled(bool)), this, SLOT(change_adaptor()));
+       connect(langModule->encodingCO, 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()));
+       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()));
+       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)));
+       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->lspacingCO, SIGNAL(activated(int)), this, SLOT(change_adaptor()));
+       connect(layoutModule->lspacingCO, SIGNAL(activated(int)), this, SLOT(setLSpacing(int)));
+       connect(layoutModule->lspacingLE, SIGNAL(textChanged(const QString&)), 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()));
+       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->bulletsizeCO, SIGNAL(activated(int)),
-                this , SLOT(change_adaptor()));
-       connect(bulletsModule->bulletsLV, SIGNAL(selectionChanged()),
-                this , SLOT(change_adaptor()));
+       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->portraitRB, SIGNAL(toggled(bool)), this, SLOT(portraitChanged()));
+
+       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->bulletsizeCO, SIGNAL(activated(int)), this, SLOT(change_adaptor()));
+       connect(bulletsModule->bulletsLV, SIGNAL(selectionChanged()), this, SLOT(change_adaptor()));
 }
 
 
@@ -251,37 +164,9 @@ QDocumentDialog::~QDocumentDialog()
 }
 
 
-void QDocumentDialog::setTitle(int item)
+void QDocumentDialog::showPreamble()
 {
-       switch(item) {
-       case LAYOUT:
-               titleL->setText(_("Document Style"));
-               break;
-       case PACKAGES:
-               titleL->setText(_("LaTeX Packages"));
-               break;
-       case PAPER:
-               titleL->setText(_("Papersize and Orientation"));
-               break;
-       case MARGINS:
-               titleL->setText(_("Margins"));
-               break;
-       case LANGUAGE:
-               titleL->setText(_("Language Settings and Quote Style"));
-               break;
-       case BULLETS:
-               titleL->setText(_("Bullet Types"));
-               break;
-       case NUMBERING:
-               titleL->setText(_("Numbering"));
-               break;
-       case BIBLIOGRAPHY:
-               titleL->setText(_("Bibliography Settings"));
-               break;
-       case PREAMBLE:
-               titleL->setText(_("LaTeX Preamble"));
-               break;
-       }
+       docPS->setCurrentPanel(_("LaTeX Preamble"));
 }
 
 
@@ -312,7 +197,7 @@ void QDocumentDialog::closeEvent(QCloseEvent * e)
 
 void QDocumentDialog::setLSpacing(int item)
 {
-       packagesModule->lspacingLE->setEnabled(item == 3);
+       layoutModule->lspacingLE->setEnabled(item == 3);
 }
 
 
@@ -333,20 +218,25 @@ void QDocumentDialog::enableSkip(bool skip)
                setSkip(layoutModule->skipCO->currentItem());
 }
 
+void QDocumentDialog::portraitChanged()
+{
+       setMargins(paperModule->papersizeCO->currentItem());
+}
 
 void QDocumentDialog::setMargins(int papersize)
 {
-       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->insertStrList(normal);
-       if (papersize==6) {
-               marginsModule->marginCO->insertStrList(a4only);
+       marginsModule->marginCO->insertItem(qt_("Default"));
+       marginsModule->marginCO->insertItem(qt_("Custom"));
+       bool a4size = (papersize == 6 || papersize == 0
+                       && lyxrc.default_papersize == BufferParams::PAPER_A4PAPER);
+       if (a4size && paperModule->portraitRB->isChecked()) {
+               marginsModule->marginCO->insertItem(qt_("Small margins"));
+               marginsModule->marginCO->insertItem(qt_("Very small margins"));
+               marginsModule->marginCO->insertItem(qt_("Very wide margins"));
+       } else if (olditem > 1) {
+               olditem = 0;
        }
        marginsModule->marginCO->setCurrentItem(olditem);
        setCustomMargins(olditem);
@@ -409,10 +299,10 @@ void QDocumentDialog::updateFontsize(string const & items, string const & sel)
 
        for (int n=0; !token(items,'|',n).empty(); ++n)
                layoutModule->fontsizeCO->
-                       insertItem(token(items,'|',n).c_str());
+                       insertItem(toqstr(token(items,'|',n)));
 
        for (int n = 0; n<layoutModule->fontsizeCO->count(); ++n) {
-               if (layoutModule->fontsizeCO->text(n).latin1()==sel) {
+               if (fromqstr(layoutModule->fontsizeCO->text(n)) == sel) {
                        layoutModule->fontsizeCO->setCurrentItem(n);
                        break;
                }
@@ -427,10 +317,10 @@ void QDocumentDialog::updatePagestyle(string const & items, string const & sel)
 
        for (int n=0; !token(items,'|',n).empty(); ++n)
                layoutModule->pagestyleCO->
-                       insertItem(token(items,'|',n).c_str());
+                       insertItem(toqstr(token(items,'|',n)));
 
        for (int n = 0; n<layoutModule->pagestyleCO->count(); ++n) {
-               if (layoutModule->pagestyleCO->text(n).latin1()==sel) {
+               if (fromqstr(layoutModule->pagestyleCO->text(n))==sel) {
                        layoutModule->pagestyleCO->setCurrentItem(n);
                        break;
                }
@@ -461,7 +351,7 @@ void QDocumentDialog::classChanged()
        } else {
                for (int n = 0; n<layoutModule->classCO->count(); ++n) {
                        if (layoutModule->classCO->text(n) ==
-                           cntrl.textClass().description().c_str()) {
+                           toqstr(cntrl.textClass().description())) {
                                layoutModule->classCO->setCurrentItem(n);
                                break;
                        }