*/
#include <config.h>
-#include "gettext.h"
+#include "qt_helpers.h"
#include "ControlDocument.h"
#include "QDocument.h"
-#ifdef __GNUG__
-#pragma implementation
-#endif
#include "QDocumentDialog.h"
#include "ui/NumberingModuleBase.h"
#include "ui/MarginsModuleBase.h"
#include "ui/PreambleModuleBase.h"
+#include "panelstack.h"
#include "Spacing.h"
#include "support/lstrings.h"
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()));
}
}
-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"));
}
void QDocumentDialog::setLSpacing(int item)
{
- packagesModule->lspacingLE->setEnabled(item == 3);
+ layoutModule->lspacingLE->setEnabled(item == 3);
}
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);
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;
}
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;
}
} 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;
}