#include <config.h>
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
#include "qt_helpers.h"
#include "ControlDocument.h"
#include "frnt_lang.h"
#include "lyxrc.h" // defaultUnit
#include "tex-strings.h" // tex_graphics
-#include "support/lstrings.h" // tostr()
+#include "support/tostr.h"
#include "support/filetools.h" // LibFileSearch()
+#include "support/BoostFormat.h"
#include "lyxtextclasslist.h"
#include "vspace.h"
#include "bufferparams.h"
#include "qt_helpers.h"
+#include "floatplacement.h"
#include <qpushbutton.h>
#include <qmultilineedit.h>
#include <qradiobutton.h>
#include <qcombobox.h>
#include <qcheckbox.h>
-#include <qspinbox.h>
+#include <qslider.h>
#include <qlineedit.h>
#include <qstringlist.h>
#include "lengthcombo.h"
QDocument::QDocument()
- : base_class(qt_("Document Settings"))
+ : base_class(_("LyX: Document Settings"))
{
vector<frnt::LanguagePair> const langs = frnt::getLanguageData(false);
lang_ = getSecond(langs);
}
+namespace {
+
+char const * encodings[] = { "LaTeX default", "latin1", "latin2",
+ "latin3", "latin4", "latin5", "latin9",
+ "koi8-r", "koi8-u", "cp866", "cp1251",
+ "iso88595", "pt154", 0
+};
+
+}
+
void QDocument::build_dialog()
{
toqstr(lit->first));
}
- char const * items[] = {"default", "auto", "latin1", "latin2",
- "latin3", "latin4", "latin5", "latin9",
- "koi8-r", "koi8-u", "cp866", "cp1251",
- "iso88595", "pt154", 0};
- dialog_->langModule->encodingCO->insertStrList(items);
+ int i = 0;
+ while (encodings[i]) {
+ dialog_->langModule->encodingCO->insertItem(qt_(encodings[i++]));
+ }
dialog_->langModule->quoteStyleCO->insertItem(qt_("``text''"));
dialog_->langModule->quoteStyleCO->insertItem(qt_("''text''"));
// packages
for (int n = 0; tex_graphics[n][0]; ++n) {
QString enc = tex_graphics[n];
- dialog_->packagesModule->psdriverCO->insertItem(enc);
+ dialog_->latexModule->psdriverCO->insertItem(enc);
}
// paper
- QComboBox * cb = dialog_->paperModule->papersizeCO;
+ QComboBox * cb = dialog_->pageLayoutModule->papersizeCO;
cb->insertItem(qt_("Default"));
cb->insertItem(qt_("Custom"));
cb->insertItem(qt_("US letter"));
// layout
for (LyXTextClassList::const_iterator cit = textclasslist.begin();
cit != textclasslist.end(); ++cit) {
- dialog_->layoutModule->classCO->insertItem(toqstr(cit->description()));
+ if (cit->isTeXClassAvailable()) {
+ dialog_->latexModule->classCO->insertItem(toqstr(cit->description()));
+ } else {
+ string item =
+#if USE_BOOST_FORMAT
+ boost::io::str(boost::format(_("Unavailable: %1$s")) % cit->description());
+#else
+ _("Unavailable: ") + cit->description();
+#endif
+ dialog_->latexModule->classCO->insertItem(toqstr(item));
+ }
}
for (int n = 0; tex_fonts[n][0]; ++n) {
QString font = tex_fonts[n];
- dialog_->layoutModule->fontsCO->insertItem(font);
+ dialog_->textLayoutModule->fontsCO->insertItem(font);
}
- dialog_->layoutModule->fontsizeCO->insertItem(qt_("default"));
- dialog_->layoutModule->fontsizeCO->insertItem(qt_("10"));
- dialog_->layoutModule->fontsizeCO->insertItem(qt_("11"));
- dialog_->layoutModule->fontsizeCO->insertItem(qt_("12"));
-
- dialog_->layoutModule->skipCO->insertItem(qt_("SmallSkip"));
- dialog_->layoutModule->skipCO->insertItem(qt_("MedSkip"));
- dialog_->layoutModule->skipCO->insertItem(qt_("BigSkip"));
- dialog_->layoutModule->skipCO->insertItem(qt_("Length"));
-
- dialog_->layoutModule->pagestyleCO->insertItem(qt_("default"));
- dialog_->layoutModule->pagestyleCO->insertItem(qt_("empty"));
- dialog_->layoutModule->pagestyleCO->insertItem(qt_("plain"));
- dialog_->layoutModule->pagestyleCO->insertItem(qt_("headings"));
- dialog_->layoutModule->pagestyleCO->insertItem(qt_("fancy"));
-
- dialog_->layoutModule->lspacingCO->insertItem(
+ dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("default"));
+ dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("10"));
+ dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("11"));
+ dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("12"));
+
+ dialog_->textLayoutModule->skipCO->insertItem(qt_("SmallSkip"));
+ dialog_->textLayoutModule->skipCO->insertItem(qt_("MedSkip"));
+ dialog_->textLayoutModule->skipCO->insertItem(qt_("BigSkip"));
+ dialog_->textLayoutModule->skipCO->insertItem(qt_("Length"));
+
+ dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("default"));
+ dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("empty"));
+ dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("plain"));
+ dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("headings"));
+ dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("fancy"));
+
+ dialog_->textLayoutModule->lspacingCO->insertItem(
qt_("Single"), Spacing::Single);
- dialog_->layoutModule->lspacingCO->insertItem(
+ dialog_->textLayoutModule->lspacingCO->insertItem(
qt_("OneHalf"), Spacing::Onehalf);
- dialog_->layoutModule->lspacingCO->insertItem(
+ dialog_->textLayoutModule->lspacingCO->insertItem(
qt_("Double"), Spacing::Double);
- dialog_->layoutModule->lspacingCO->insertItem(
+ dialog_->textLayoutModule->lspacingCO->insertItem(
qt_("Custom"), Spacing::Other);
// margins
dialog_->setMargins(0);
// Manage the restore, ok, apply, restore and cancel/close buttons
- bc().setOK(dialog_->okPB);
- bc().setApply(dialog_->applyPB);
- bc().setCancel(dialog_->closePB);
- bc().setRestore(dialog_->restorePB);
+ bcview().setOK(dialog_->okPB);
+ bcview().setApply(dialog_->applyPB);
+ bcview().setCancel(dialog_->closePB);
+ bcview().setRestore(dialog_->restorePB);
+}
+
+
+void QDocument::showPreamble()
+{
+ dialog_->showPreamble();
}
else
params.quotes_times = InsetQuotes::DoubleQ;
- params.inputenc =
- fromqstr(dialog_->langModule->encodingCO->currentText());
+ if (dialog_->langModule->defaultencodingCB->isChecked()) {
+ params.inputenc = "auto";
+ } else {
+ int i = dialog_->langModule->encodingCO->currentItem();
+ if (i == 0) {
+ params.inputenc = "default";
+ } else {
+ params.inputenc = encodings[i];
+ }
+ }
InsetQuotes::quote_language lga = InsetQuotes::EnglishQ;
switch (dialog_->langModule->quoteStyleCO->currentItem()) {
params.language = languages.getLanguage(lang_[pos]);
// numbering
- params.secnumdepth =
- dialog_->numberingModule->tocDepthSB->value();
- params.tocdepth =
- dialog_->numberingModule->sectionnrDepthSB->value();
+ params.tocdepth = dialog_->numberingModule->tocSL->value();
+ params.secnumdepth = dialog_->numberingModule->depthSL->value();
// bullets
params.user_defined_bullets[0] = dialog_->bulletsModule->getBullet(0);
// packages
params.graphicsDriver =
- fromqstr(dialog_->packagesModule->psdriverCO->currentText());
+ fromqstr(dialog_->latexModule->psdriverCO->currentText());
- params.use_amsmath =
- dialog_->packagesModule->amsCB->isChecked();
+ if (dialog_->mathsModule->amsautoCB->isChecked()) {
+ params.use_amsmath = BufferParams::AMS_AUTO;
+ } else {
+ if (dialog_->mathsModule->amsCB->isChecked())
+ params.use_amsmath = BufferParams::AMS_ON;
+ else
+ params.use_amsmath = BufferParams::AMS_OFF;
+ }
// layout
params.textclass =
- dialog_->layoutModule->classCO->currentItem();
-
+ dialog_->latexModule->classCO->currentItem();
+
params.fonts =
- fromqstr(dialog_->layoutModule->fontsCO->currentText());
+ fromqstr(dialog_->textLayoutModule->fontsCO->currentText());
params.fontsize =
- fromqstr(dialog_->layoutModule->fontsizeCO->currentText());
+ fromqstr(dialog_->textLayoutModule->fontsizeCO->currentText());
params.pagestyle =
- fromqstr(dialog_->layoutModule->pagestyleCO->currentText());
-
- switch (dialog_->layoutModule->lspacingCO->currentItem()) {
+ fromqstr(dialog_->pageLayoutModule->pagestyleCO->currentText());
+
+ switch (dialog_->textLayoutModule->lspacingCO->currentItem()) {
case 0:
params.spacing.set(Spacing::Single);
break;
break;
case 3:
params.spacing.set(Spacing::Other,
- dialog_->layoutModule->
+ dialog_->textLayoutModule->
lspacingLE->text().toFloat()
);
break;
}
- if (dialog_->layoutModule->indentRB->isChecked())
+ if (dialog_->textLayoutModule->twoColumnCB->isChecked())
+ params.columns = 2;
+ else
+ params.columns = 1;
+
+ if (dialog_->textLayoutModule->indentRB->isChecked())
params.paragraph_separation = BufferParams::PARSEP_INDENT;
else
params.paragraph_separation = BufferParams::PARSEP_SKIP;
- switch (dialog_->layoutModule->skipCO->currentItem()) {
+ switch (dialog_->textLayoutModule->skipCO->currentItem()) {
case 0:
params.setDefSkip(VSpace(VSpace::SMALLSKIP));
break;
case 3:
{
LyXLength::UNIT unit =
- dialog_->layoutModule->skipLengthCO->
+ dialog_->textLayoutModule->skipLengthCO->
currentLengthItem();
double length =
- dialog_->layoutModule->skipLE->text().toDouble();
+ dialog_->textLayoutModule->skipLE->text().toDouble();
VSpace vs = VSpace(LyXGlueLength(LyXLength(length,unit)));
params.setDefSkip(vs);
break;
}
params.options =
- fromqstr(dialog_->layoutModule->optionsLE->text());
+ fromqstr(dialog_->latexModule->optionsLE->text());
- params.float_placement =
- fromqstr(dialog_->layoutModule->floatPlacementLE->text());
+ params.float_placement = dialog_->floatModule->get();
// paper
- params.papersize2 =
- dialog_->paperModule->papersizeCO->currentItem();
-
- params.paperwidth = widgetsToLength(dialog_->paperModule->paperwidthLE,
- dialog_->paperModule->paperwidthUnitCO);
+ params.papersize2 = BufferParams::VMARGIN_PAPER_TYPE(
+ dialog_->pageLayoutModule->papersizeCO->currentItem());
- params.paperheight = widgetsToLength(dialog_->paperModule->paperheightLE,
- dialog_->paperModule->paperheightUnitCO);
+ params.paperwidth = widgetsToLength(dialog_->pageLayoutModule->paperwidthLE,
+ dialog_->pageLayoutModule->paperwidthUnitCO);
- if (dialog_->paperModule->twoColumnCB->isChecked())
- params.columns = 2;
- else
- params.columns = 1;
+ params.paperheight = widgetsToLength(dialog_->pageLayoutModule->paperheightLE,
+ dialog_->pageLayoutModule->paperheightUnitCO);
- if (dialog_->paperModule->facingPagesCB->isChecked())
+ if (dialog_->pageLayoutModule->facingPagesCB->isChecked())
params.sides = LyXTextClass::TwoSides;
else
params.sides = LyXTextClass::OneSide;
- if (dialog_->paperModule->landscapeRB->isChecked())
+ if (dialog_->pageLayoutModule->landscapeRB->isChecked())
params.orientation = BufferParams::ORIENTATION_LANDSCAPE;
else
params.orientation = BufferParams::ORIENTATION_PORTRAIT;
if (margin > 0) {
margin = margin - 1;
}
- params.paperpackage = char(margin);
+ params.paperpackage = BufferParams::PAPER_PACKAGES(margin);
+
+ // set params.papersize from params.papersize2
+ // and params.paperpackage
+ params.setPaperStuff();
MarginsModuleBase const * m(dialog_->marginsModule);
dialog_->langModule->quoteStyleCO->setCurrentItem(
params.quotes_language);
-
- char const * enc[] = {
- "default" , "auto" , "latin1" , "latin2" , "latin3" ,
- "latin4" , "latin5" , "latin9" , "koi8-r" , "koi8-u" ,
- "cp866" , "cp1251" , "iso88595" , "pt154" };
- for (size_t i = 0; i < sizeof(enc)/sizeof(char *); ++i) {
- if (params.inputenc == enc[i])
- dialog_->langModule->encodingCO->setCurrentItem(i);
+
+ dialog_->langModule->defaultencodingCB->setChecked(true);
+
+ if (params.inputenc != "auto") {
+ dialog_->langModule->defaultencodingCB->setChecked(false);
+ if (params.inputenc == "default") {
+ dialog_->langModule->encodingCO->setCurrentItem(0);
+ } else {
+ int i = 0;
+ while (encodings[i]) {
+ if (encodings[i] == params.inputenc)
+ dialog_->langModule->encodingCO->setCurrentItem(i);
+ ++i;
+ }
+ }
}
// numbering
- dialog_->numberingModule->tocDepthSB->setValue(
- params.secnumdepth);
- dialog_->numberingModule->sectionnrDepthSB->setValue(
- params.tocdepth);
+ dialog_->numberingModule->tocSL->setValue(params.tocdepth);
+ dialog_->numberingModule->depthSL->setValue(params.secnumdepth);
+ dialog_->updateNumbering();
// bullets
dialog_->bulletsModule->setBullet(0,params.user_defined_bullets[0]);
// packages
QString text = toqstr(params.graphicsDriver);
- int nitem = dialog_->packagesModule->psdriverCO->count();
+ int nitem = dialog_->latexModule->psdriverCO->count();
for (int n = 0; n < nitem ; ++n) {
QString enc = tex_graphics[n];
if (enc == text) {
- dialog_->packagesModule->psdriverCO->setCurrentItem(n);
+ dialog_->latexModule->psdriverCO->setCurrentItem(n);
}
}
- dialog_->packagesModule->amsCB->setChecked(
- params.use_amsmath);
+ dialog_->mathsModule->amsCB->setChecked(
+ params.use_amsmath == BufferParams::AMS_ON);
+ dialog_->mathsModule->amsautoCB->setChecked(
+ params.use_amsmath == BufferParams::AMS_AUTO);
switch (params.spacing.getSpace()) {
case Spacing::Other: nitem = 3; break;
// layout
- for (int n = 0; n<dialog_->layoutModule->classCO->count(); ++n) {
- if (dialog_->layoutModule->classCO->text(n) ==
- toqstr(controller().textClass().description())) {
- dialog_->layoutModule->classCO->setCurrentItem(n);
- break;
- }
- }
+ dialog_->latexModule->classCO->setCurrentItem(params.textclass);
dialog_->updateFontsize(controller().textClass().opt_fontsize(),
params.fontsize);
for (int n = 0; tex_fonts[n][0]; ++n) {
if (tex_fonts[n] == params.fonts) {
- dialog_->layoutModule->fontsCO->setCurrentItem(n);
+ dialog_->textLayoutModule->fontsCO->setCurrentItem(n);
break;
}
}
- dialog_->layoutModule->lspacingCO->setCurrentItem(nitem);
+ dialog_->textLayoutModule->lspacingCO->setCurrentItem(nitem);
if (params.spacing.getSpace() == Spacing::Other) {
- dialog_->layoutModule->lspacingLE->setText(
+ dialog_->textLayoutModule->lspacingLE->setText(
toqstr(tostr(params.spacing.getValue())));
dialog_->setLSpacing(3);
}
if (params.paragraph_separation
== BufferParams::PARSEP_INDENT) {
- dialog_->layoutModule->indentRB->setChecked(true);
+ dialog_->textLayoutModule->indentRB->setChecked(true);
} else {
- dialog_->layoutModule->skipRB->setChecked(true);
+ dialog_->textLayoutModule->skipRB->setChecked(true);
}
int skip = 0;
{
skip = 3;
string const length = params.getDefSkip().asLyXCommand();
- dialog_->layoutModule->skipLengthCO->setCurrentItem(LyXLength(length).unit());
- dialog_->layoutModule->skipLE->setText(toqstr(tostr(LyXLength(length).value())));
+ dialog_->textLayoutModule->skipLengthCO->setCurrentItem(LyXLength(length).unit());
+ dialog_->textLayoutModule->skipLE->setText(toqstr(tostr(LyXLength(length).value())));
break;
}
default:
skip = 0;
break;
}
- dialog_->layoutModule->skipCO->setCurrentItem(skip);
+ dialog_->textLayoutModule->skipCO->setCurrentItem(skip);
dialog_->setSkip(skip);
+ dialog_->textLayoutModule->twoColumnCB->setChecked(
+ params.columns == 2);
+
if (!params.options.empty()) {
- dialog_->layoutModule->optionsLE->setText(
+ dialog_->latexModule->optionsLE->setText(
toqstr(params.options));
} else {
- dialog_->layoutModule->optionsLE->setText("");
+ dialog_->latexModule->optionsLE->setText("");
}
+ dialog_->floatModule->set(params.float_placement);
+
// paper
int const psize = params.papersize2;
- dialog_->paperModule->papersizeCO->setCurrentItem(psize);
+ dialog_->pageLayoutModule->papersizeCO->setCurrentItem(psize);
dialog_->setMargins(psize);
dialog_->setCustomPapersize(psize);
bool const landscape =
params.orientation == BufferParams::ORIENTATION_LANDSCAPE;
- dialog_->paperModule->landscapeRB->setChecked(landscape);
- dialog_->paperModule->portraitRB->setChecked(!landscape);
+ dialog_->pageLayoutModule->landscapeRB->setChecked(landscape);
+ dialog_->pageLayoutModule->portraitRB->setChecked(!landscape);
- dialog_->paperModule->facingPagesCB->setChecked(
+ dialog_->pageLayoutModule->facingPagesCB->setChecked(
params.sides == LyXTextClass::TwoSides);
- dialog_->paperModule->twoColumnCB->setChecked(
- params.columns == 2);
- lengthToWidgets(dialog_->paperModule->paperwidthLE,
- dialog_->paperModule->paperwidthUnitCO, params.paperwidth, defaultUnit);
+ lengthToWidgets(dialog_->pageLayoutModule->paperwidthLE,
+ dialog_->pageLayoutModule->paperwidthUnitCO, params.paperwidth, defaultUnit);
- lengthToWidgets(dialog_->paperModule->paperheightLE,
- dialog_->paperModule->paperheightUnitCO, params.paperheight, defaultUnit);
+ lengthToWidgets(dialog_->pageLayoutModule->paperheightLE,
+ dialog_->pageLayoutModule->paperheightUnitCO, params.paperheight, defaultUnit);
// margins
{
BufferParams & params = controller().params();
- params.textclass = dialog_->layoutModule->classCO->currentItem();
+ params.textclass = dialog_->latexModule->classCO->currentItem();
params.useClassDefaults();
update_contents();
}