Fix display of disabled page margins (#12887)

while preserving input values on geometry toggle
This commit is contained in:
Juergen Spitzmueller 2023-09-16 11:00:10 +02:00
parent 9110759ec4
commit c8d4b99559
2 changed files with 92 additions and 19 deletions

View File

@ -2187,10 +2187,8 @@ void GuiDocument::setMargins()
if (extern_geometry) { if (extern_geometry) {
marginsModule->marginCB->setChecked(false); marginsModule->marginCB->setChecked(false);
setCustomMargins(true); setCustomMargins(true);
} else { } else
marginsModule->marginCB->setChecked(!bp_.use_geometry); marginsModule->marginCB->setChecked(!bp_.use_geometry);
setCustomMargins(!bp_.use_geometry);
}
} }
@ -2220,6 +2218,61 @@ void GuiDocument::setColSep()
void GuiDocument::setCustomMargins(bool custom) void GuiDocument::setCustomMargins(bool custom)
{ {
if (custom) {
// Cache current settings
tmp_leftmargin_ = widgetsToLength(marginsModule->innerLE,
marginsModule->innerUnit);
tmp_topmargin_ = widgetsToLength(marginsModule->topLE,
marginsModule->topUnit);
tmp_rightmargin_ = widgetsToLength(marginsModule->outerLE,
marginsModule->outerUnit);
tmp_bottommargin_ = widgetsToLength(marginsModule->bottomLE,
marginsModule->bottomUnit);
tmp_headheight_ = widgetsToLength(marginsModule->headheightLE,
marginsModule->headheightUnit);
tmp_headsep_ = widgetsToLength(marginsModule->headsepLE,
marginsModule->headsepUnit);
tmp_footskip_ = widgetsToLength(marginsModule->footskipLE,
marginsModule->footskipUnit);
tmp_columnsep_ = widgetsToLength(marginsModule->columnsepLE,
marginsModule->columnsepUnit);
// clear widgets
marginsModule->topLE->clear();
marginsModule->bottomLE->clear();
marginsModule->innerLE->clear();
marginsModule->outerLE->clear();
marginsModule->headheightLE->clear();
marginsModule->headsepLE->clear();
marginsModule->footskipLE->clear();
marginsModule->columnsepLE->clear();
} else {
Length::UNIT const default_unit = Length::defaultUnit();
// re-fill chached values
lengthToWidgets(marginsModule->topLE,
marginsModule->topUnit,
tmp_topmargin_, default_unit);
lengthToWidgets(marginsModule->bottomLE,
marginsModule->bottomUnit,
tmp_bottommargin_, default_unit);
lengthToWidgets(marginsModule->innerLE,
marginsModule->innerUnit,
tmp_leftmargin_, default_unit);
lengthToWidgets(marginsModule->outerLE,
marginsModule->outerUnit,
tmp_rightmargin_, default_unit);
lengthToWidgets(marginsModule->headheightLE,
marginsModule->headheightUnit,
tmp_headheight_, default_unit);
lengthToWidgets(marginsModule->headsepLE,
marginsModule->headsepUnit,
tmp_headsep_, default_unit);
lengthToWidgets(marginsModule->footskipLE,
marginsModule->footskipUnit,
tmp_footskip_, default_unit);
lengthToWidgets(marginsModule->columnsepLE,
marginsModule->columnsepUnit,
tmp_columnsep_, default_unit);
}
marginsModule->topL->setEnabled(!custom); marginsModule->topL->setEnabled(!custom);
marginsModule->topLE->setEnabled(!custom); marginsModule->topLE->setEnabled(!custom);
marginsModule->topUnit->setEnabled(!custom); marginsModule->topUnit->setEnabled(!custom);
@ -3989,6 +4042,7 @@ void GuiDocument::applyView()
Ui::MarginsUi const * m = marginsModule; Ui::MarginsUi const * m = marginsModule;
if (bp_.use_geometry) {
bp_.leftmargin = widgetsToLength(m->innerLE, m->innerUnit); bp_.leftmargin = widgetsToLength(m->innerLE, m->innerUnit);
bp_.topmargin = widgetsToLength(m->topLE, m->topUnit); bp_.topmargin = widgetsToLength(m->topLE, m->topUnit);
bp_.rightmargin = widgetsToLength(m->outerLE, m->outerUnit); bp_.rightmargin = widgetsToLength(m->outerLE, m->outerUnit);
@ -3997,6 +4051,7 @@ void GuiDocument::applyView()
bp_.headsep = widgetsToLength(m->headsepLE, m->headsepUnit); bp_.headsep = widgetsToLength(m->headsepLE, m->headsepUnit);
bp_.footskip = widgetsToLength(m->footskipLE, m->footskipUnit); bp_.footskip = widgetsToLength(m->footskipLE, m->footskipUnit);
bp_.columnsep = widgetsToLength(m->columnsepLE, m->columnsepUnit); bp_.columnsep = widgetsToLength(m->columnsepLE, m->columnsepUnit);
}
// branches // branches
branchesModule->apply(bp_); branchesModule->apply(bp_);
@ -4586,32 +4641,34 @@ void GuiDocument::paramsToDialog()
// margins // margins
Ui::MarginsUi * m = marginsModule; Ui::MarginsUi * m = marginsModule;
setMargins(); tmp_leftmargin_ = bp_.leftmargin;
tmp_topmargin_ = bp_.topmargin;
tmp_rightmargin_ = bp_.rightmargin;
tmp_bottommargin_ = bp_.bottommargin;
tmp_headheight_ = bp_.headheight;
tmp_headsep_ = bp_.headsep;
tmp_footskip_ = bp_.footskip;
tmp_columnsep_ = bp_.columnsep;
lengthToWidgets(m->topLE, m->topUnit, lengthToWidgets(m->topLE, m->topUnit,
bp_.topmargin, default_unit); bp_.topmargin, default_unit);
lengthToWidgets(m->bottomLE, m->bottomUnit, lengthToWidgets(m->bottomLE, m->bottomUnit,
bp_.bottommargin, default_unit); bp_.bottommargin, default_unit);
lengthToWidgets(m->innerLE, m->innerUnit, lengthToWidgets(m->innerLE, m->innerUnit,
bp_.leftmargin, default_unit); bp_.leftmargin, default_unit);
lengthToWidgets(m->outerLE, m->outerUnit, lengthToWidgets(m->outerLE, m->outerUnit,
bp_.rightmargin, default_unit); bp_.rightmargin, default_unit);
lengthToWidgets(m->headheightLE, m->headheightUnit, lengthToWidgets(m->headheightLE, m->headheightUnit,
bp_.headheight, default_unit); bp_.headheight, default_unit);
lengthToWidgets(m->headsepLE, m->headsepUnit, lengthToWidgets(m->headsepLE, m->headsepUnit,
bp_.headsep, default_unit); bp_.headsep, default_unit);
lengthToWidgets(m->footskipLE, m->footskipUnit, lengthToWidgets(m->footskipLE, m->footskipUnit,
bp_.footskip, default_unit); bp_.footskip, default_unit);
lengthToWidgets(m->columnsepLE, m->columnsepUnit, lengthToWidgets(m->columnsepLE, m->columnsepUnit,
bp_.columnsep, default_unit); bp_.columnsep, default_unit);
setMargins();
// branches // branches
updateUnknownBranches(); updateUnknownBranches();
branchesModule->update(bp_); branchesModule->update(bp_);

View File

@ -360,6 +360,22 @@ private:
/// Track whether we prompted the user about unapplied /// Track whether we prompted the user about unapplied
/// changes /// changes
bool prompted_; bool prompted_;
/// Cache margin values
std::string tmp_leftmargin_;
///
std::string tmp_topmargin_;
///
std::string tmp_rightmargin_;
///
std::string tmp_bottommargin_;
///
std::string tmp_headheight_;
///
std::string tmp_headsep_;
///
std::string tmp_footskip_;
///
std::string tmp_columnsep_;
/// LaTeX syntax highlighter /// LaTeX syntax highlighter
LaTeXHighlighter * pdf_options_highlighter_; LaTeXHighlighter * pdf_options_highlighter_;