#include "frontends/alert.h"
#include <QAbstractItemModel>
+#include <QHeaderView>
#include <QColor>
#include <QColorDialog>
#include <QCloseEvent>
// 2. Description (lexicographic)
LayoutFile const & tc1 = LayoutFileList::get()[lhs];
LayoutFile const & tc2 = LayoutFileList::get()[rhs];
- int const rel = compare_no_case(
+ int const order = compare_no_case(
translateIfPossible(from_utf8(tc1.description())),
translateIfPossible(from_utf8(tc2.description())));
return (tc1.isTeXClassAvailable() && !tc2.isTeXClassAvailable()) ||
- (tc1.isTeXClassAvailable() == tc2.isTeXClassAvailable() && rel < 0);
+ (tc1.isTeXClassAvailable() == tc2.isTeXClassAvailable() && order < 0);
}
};
vector<string> getRequiredList(string const & modName)
{
- LyXModule const * const mod = moduleList[modName];
+ LyXModule const * const mod = theModuleList[modName];
if (!mod)
return vector<string>(); //empty such thing
return mod->getRequiredModules();
vector<string> getExcludedList(string const & modName)
{
- LyXModule const * const mod = moduleList[modName];
+ LyXModule const * const mod = theModuleList[modName];
if (!mod)
return vector<string>(); //empty such thing
return mod->getExcludedModules();
docstring getModuleDescription(string const & modName)
{
- LyXModule const * const mod = moduleList[modName];
+ LyXModule const * const mod = theModuleList[modName];
if (!mod)
return _("Module not found!");
// FIXME Unicode
vector<string> getPackageList(string const & modName)
{
- LyXModule const * const mod = moduleList[modName];
+ LyXModule const * const mod = theModuleList[modName];
if (!mod)
return vector<string>(); //empty such thing
return mod->getPackageList();
bool isModuleAvailable(string const & modName)
{
- LyXModule * mod = moduleList[modName];
+ LyXModule const * const mod = theModuleList[modName];
if (!mod)
return false;
return mod->isAvailable();
public:
///
ModuleSelectionManager(
- QListView * availableLV,
+ QTreeView * availableLV,
QListView * selectedLV,
QPushButton * addPB,
QPushButton * delPB,
this, SLOT(change_adaptor()));
connect(textLayoutModule->twoColumnCB, SIGNAL(clicked()),
this, SLOT(setColSep()));
- connect(textLayoutModule->listingsED, SIGNAL(textChanged()),
- this, SLOT(change_adaptor()));
- connect(textLayoutModule->bypassCB, SIGNAL(clicked()),
- this, SLOT(change_adaptor()));
- connect(textLayoutModule->bypassCB, SIGNAL(clicked()),
- this, SLOT(setListingsMessage()));
- connect(textLayoutModule->listingsED, SIGNAL(textChanged()),
- this, SLOT(setListingsMessage()));
- textLayoutModule->listingsTB->setPlainText(
- qt_("Input listings parameters on the right. Enter ? for a list of parameters."));
+
textLayoutModule->lspacingLE->setValidator(new QDoubleValidator(
textLayoutModule->lspacingLE));
textLayoutModule->indentLE->setValidator(unsignedLengthValidator(
textLayoutModule->indentLE));
- textLayoutModule->skipLE->setValidator(unsignedLengthValidator(
+ textLayoutModule->skipLE->setValidator(unsignedGlueLengthValidator(
textLayoutModule->skipLE));
textLayoutModule->indentCO->addItem(qt_("Default"));
textLayoutModule->skipCO->addItem(qt_("SmallSkip"));
textLayoutModule->skipCO->addItem(qt_("MedSkip"));
textLayoutModule->skipCO->addItem(qt_("BigSkip"));
- textLayoutModule->skipCO->addItem(qt_("Length"));
+ textLayoutModule->skipCO->addItem(qt_("Custom"));
textLayoutModule->lspacingCO->insertItem(
Spacing::Single, qt_("Single"));
textLayoutModule->lspacingCO->insertItem(
this, SLOT(change_adaptor()));
connect(latexModule->childDocPB, SIGNAL(clicked()),
this, SLOT(browseMaster()));
+ connect(latexModule->suppressDateCB, SIGNAL(clicked()),
+ this, SLOT(change_adaptor()));
// postscript drivers
for (int n = 0; tex_graphics[n][0]; ++n) {
// Modules
modulesModule = new UiWidget<Ui::ModulesUi>;
-
+ modulesModule->availableLV->header()->setVisible(false);
selectionManager =
new ModuleSelectionManager(modulesModule->availableLV,
modulesModule->selectedLV,
connect(floatModule, SIGNAL(changed()),
this, SLOT(change_adaptor()));
+ // listings
+ listingsModule = new UiWidget<Ui::ListingsSettingsUi>;
+ connect(listingsModule->listingsED, SIGNAL(textChanged()),
+ this, SLOT(change_adaptor()));
+ connect(listingsModule->bypassCB, SIGNAL(clicked()),
+ this, SLOT(change_adaptor()));
+ connect(listingsModule->bypassCB, SIGNAL(clicked()),
+ this, SLOT(setListingsMessage()));
+ connect(listingsModule->listingsED, SIGNAL(textChanged()),
+ this, SLOT(setListingsMessage()));
+ listingsModule->listingsTB->setPlainText(
+ qt_("Input listings parameters below. Enter ? for a list of parameters."));
+
docPS->addPanel(latexModule, qt_("Document Class"));
docPS->addPanel(modulesModule, qt_("Modules"));
docPS->addPanel(fontModule, qt_("Fonts"));
docPS->addPanel(pdfSupportModule, qt_("PDF Properties"));
docPS->addPanel(mathsModule, qt_("Math Options"));
docPS->addPanel(floatModule, qt_("Float Placement"));
+ docPS->addPanel(listingsModule, qt_("Listings"));
docPS->addPanel(bulletsModule, qt_("Bullets"));
docPS->addPanel(branchesModule, qt_("Branches"));
docPS->addPanel(outputModule, qt_("Output"));
static string param_cache;
static QString msg_cache;
- if (textLayoutModule->bypassCB->isChecked())
+ if (listingsModule->bypassCB->isChecked())
return QString();
- string params = fromqstr(textLayoutModule->listingsED->toPlainText());
+ string params = fromqstr(listingsModule->listingsED->toPlainText());
if (params != param_cache) {
param_cache = params;
msg_cache = toqstr(InsetListingsParams(params).validate());
return;
isOK = true;
// listingsTB->setTextColor("black");
- textLayoutModule->listingsTB->setPlainText(
- qt_("Input listings parameters on the right. "
+ listingsModule->listingsTB->setPlainText(
+ qt_("Input listings parameters below. "
"Enter ? for a list of parameters."));
} else {
isOK = false;
// listingsTB->setTextColor("red");
- textLayoutModule->listingsTB->setPlainText(msg);
+ listingsModule->listingsTB->setPlainText(msg);
}
}
vector<string>::const_iterator it = idList.begin();
vector<string>::const_iterator end = idList.end();
for (; it != end; ++it) {
- LyXModule const * const mod = moduleList[*it];
+ LyXModule const * const mod = theModuleList[*it];
if (!mod)
retval.push_back(*it + " (Unavailable)");
else
//Module description
bool const focus_on_selected = selectionManager->selectedFocused();
- QListView const * const lv =
- focus_on_selected ? modulesModule->selectedLV : modulesModule->availableLV;
+ QAbstractItemView * lv;
+ if (focus_on_selected)
+ lv = modulesModule->selectedLV;
+ else
+ lv= modulesModule->availableLV;
if (lv->selectionModel()->selectedIndexes().isEmpty()) {
modulesModule->infoML->document()->clear();
return;
// preamble
preambleModule->apply(bp_);
+ // date
+ bp_.suppress_date = latexModule->suppressDateCB->isChecked();
+
// biblio
bp_.setCiteEngine(ENGINE_BASIC);
// Modules
modulesToParams(bp_);
+ // Math
if (mathsModule->amsautoCB->isChecked()) {
bp_.use_amsmath = BufferParams::package_auto;
} else {
bp_.use_esint = BufferParams::package_off;
}
+ // Page Layout
if (pageLayoutModule->pagestyleCO->currentIndex() == 0)
bp_.pagestyle = "default";
else {
bp_.pagestyle = pagestyles[i].first;
}
+ // Text Layout
switch (textLayoutModule->lspacingCO->currentIndex()) {
case 0:
bp_.spacing().set(Spacing::Single);
else
bp_.columns = 1;
- // text should have passed validation
- bp_.listings_params =
- InsetListingsParams(fromqstr(textLayoutModule->listingsED->toPlainText())).params();
-
if (textLayoutModule->indentRB->isChecked()) {
// if paragraphs are separated by an indentation
bp_.paragraph_separation = BufferParams::ParagraphIndentSeparation;
else
bp_.master = string();
+ // Float Placement
bp_.float_placement = floatModule->get();
+ // Listings
+ // text should have passed validation
+ bp_.listings_params =
+ InsetListingsParams(fromqstr(listingsModule->listingsED->toPlainText())).params();
+
// output
bp_.defaultOutputFormat = fromqstr(outputModule->defaultFormatCO->itemData(
outputModule->defaultFormatCO->currentIndex()).toString());
// preamble
preambleModule->update(bp_, id());
+ // date
+ latexModule->suppressDateCB->setChecked(bp_.suppress_date);
+
// biblio
biblioModule->citeDefaultRB->setChecked(
bp_.citeEngine() == ENGINE_BASIC);
textLayoutModule->indentRB->setChecked(true);
string indentation = bp_.getIndentation().asLyXCommand();
int indent = 0;
- if (indentation == "default")
- indent = 0;
- else {
+ if (indentation != "default") {
lengthToWidgets(textLayoutModule->indentLE,
textLayoutModule->indentLengthCO,
indentation, defaultUnit);
textLayoutModule->twoColumnCB->setChecked(
bp_.columns == 2);
- // break listings_params to multiple lines
- string lstparams =
- InsetListingsParams(bp_.listings_params).separatedParams();
- textLayoutModule->listingsED->setPlainText(toqstr(lstparams));
-
if (!bp_.options.empty()) {
latexModule->optionsLE->setText(
toqstr(bp_.options));
latexModule->childDocGB->setChecked(false);
}
+ // Float Settings
floatModule->set(bp_.float_placement);
+ // ListingsSettings
+ // break listings_params to multiple lines
+ string lstparams =
+ InsetListingsParams(bp_.listings_params).separatedParams();
+ listingsModule->listingsED->setPlainText(toqstr(lstparams));
+
// Output
// update combobox with formats
updateDefaultFormat();
for (; it != end; ++it) {
modInfoStruct m;
m.id = *it;
- LyXModule * mod = moduleList[*it];
+ LyXModule const * const mod = theModuleList[*it];
if (mod)
// FIXME Unicode
m.name = toqstr(translateIfPossible(from_utf8(mod->getName())));
void GuiDocument::loadModuleInfo()
{
moduleNames_.clear();
- LyXModuleList::const_iterator it = moduleList.begin();
- LyXModuleList::const_iterator end = moduleList.end();
+ LyXModuleList::const_iterator it = theModuleList.begin();
+ LyXModuleList::const_iterator end = theModuleList.end();
for (; it != end; ++it) {
modInfoStruct m;
m.id = it->getID();