mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-16 13:02:49 +00:00
214 lines
5.3 KiB
C++
214 lines
5.3 KiB
C++
/**
|
|
* \file GuiWrap.cpp
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author Jürgen Spitzmüller
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include "GuiWrap.h"
|
|
|
|
#include "LengthCombo.h"
|
|
#include "qt_helpers.h"
|
|
#include "Validator.h"
|
|
#include "FuncRequest.h"
|
|
|
|
#include "support/gettext.h"
|
|
#include "support/lstrings.h"
|
|
|
|
#include <QLineEdit>
|
|
#include <QPushButton>
|
|
|
|
using namespace std;
|
|
|
|
namespace lyx {
|
|
namespace frontend {
|
|
|
|
GuiWrap::GuiWrap(GuiView & lv)
|
|
: GuiDialog(lv, "wrap", qt_("Wrap Float Settings"))
|
|
{
|
|
setupUi(this);
|
|
|
|
connect(buttonBox, SIGNAL(clicked(QAbstractButton *)),
|
|
this, SLOT(slotButtonBox(QAbstractButton *)));
|
|
|
|
connect(valignCO, SIGNAL(highlighted(QString)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(floatCB, SIGNAL(stateChanged(int)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(widthED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(widthUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(overhangCB, SIGNAL(stateChanged(int)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(overhangED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(overhangUnitLC, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(linesCB, SIGNAL(stateChanged(int)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(linesSB, SIGNAL(valueChanged(int)),
|
|
this, SLOT(change_adaptor()));
|
|
|
|
widthED->setValidator(unsignedLengthValidator(widthED));
|
|
// FIXME:
|
|
// overhang can be negative, but the unsignedLengthValidator allows this
|
|
overhangED->setValidator(unsignedLengthValidator(overhangED));
|
|
|
|
bc().setPolicy(ButtonPolicy::NoRepeatedApplyReadOnlyPolicy);
|
|
bc().setOK(buttonBox->button(QDialogButtonBox::Ok));
|
|
bc().setApply(buttonBox->button(QDialogButtonBox::Apply));
|
|
bc().setCancel(buttonBox->button(QDialogButtonBox::Cancel));
|
|
bc().setRestore(buttonBox->button(QDialogButtonBox::Reset));
|
|
|
|
bc().addReadOnly(valignCO);
|
|
bc().addReadOnly(floatCB);
|
|
bc().addReadOnly(widthED);
|
|
bc().addReadOnly(widthUnitLC);
|
|
bc().addReadOnly(overhangCB);
|
|
bc().addReadOnly(overhangED);
|
|
bc().addReadOnly(overhangUnitLC);
|
|
bc().addReadOnly(linesCB);
|
|
bc().addReadOnly(linesSB);
|
|
|
|
// initialize the length validator
|
|
bc().addCheckedLineEdit(widthED, widthLA);
|
|
bc().addCheckedLineEdit(overhangED, overhangCB);
|
|
}
|
|
|
|
|
|
void GuiWrap::change_adaptor()
|
|
{
|
|
changed();
|
|
}
|
|
|
|
|
|
void GuiWrap::applyView()
|
|
{
|
|
double const width_value = widthED->text().toDouble();
|
|
Length::UNIT widthUnit = widthUnitLC->currentLengthItem();
|
|
if (widthED->text().isEmpty())
|
|
widthUnit = Length::UNIT_NONE;
|
|
double const overhang_value = overhangED->text().toDouble();
|
|
Length::UNIT overhangUnit = overhangUnitLC->currentLengthItem();
|
|
if (overhangED->text().isEmpty())
|
|
overhangUnit = Length::UNIT_NONE;
|
|
|
|
params_.width = Length(width_value, widthUnit);
|
|
|
|
if (overhangCB->checkState() == Qt::Checked)
|
|
params_.overhang = Length(overhang_value, overhangUnit);
|
|
else
|
|
// when value is "0" the option is not set in the LaTeX-output
|
|
// in InsetWrap.cpp
|
|
params_.overhang = Length("0in");
|
|
|
|
if (linesCB->checkState() == Qt::Checked)
|
|
params_.lines = linesSB->value();
|
|
else
|
|
// when value is "0" the option is not set in the LaTeX-output
|
|
// in InsetWrap.cpp
|
|
params_.lines = 0;
|
|
|
|
bool floatOn = false;
|
|
if (floatCB->checkState() == Qt::Checked)
|
|
floatOn = true;
|
|
switch (valignCO->currentIndex()) {
|
|
case 0:
|
|
if (floatOn)
|
|
params_.placement = "O";
|
|
else
|
|
params_.placement = "o";
|
|
break;
|
|
case 1:
|
|
if (floatOn)
|
|
params_.placement = "I";
|
|
else
|
|
params_.placement = "i";
|
|
break;
|
|
case 2:
|
|
if (floatOn)
|
|
params_.placement = "L";
|
|
else
|
|
params_.placement = "l";
|
|
break;
|
|
case 3:
|
|
if (floatOn)
|
|
params_.placement = "R";
|
|
else
|
|
params_.placement = "r";
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
void GuiWrap::paramsToDialog(InsetWrapParams const & params)
|
|
{
|
|
// 0pt is a legal width now, it yields a
|
|
// wrapfloat just wide enough for the contents.
|
|
Length len_w = params.width;
|
|
widthED->setText(QString::number(len_w.value()));
|
|
widthUnitLC->setCurrentItem(len_w.unit());
|
|
|
|
Length len_o(params.overhang);
|
|
overhangED->setText(QString::number(len_o.value()));
|
|
overhangUnitLC->setCurrentItem(len_o.unit());
|
|
if (len_o.value() == 0)
|
|
overhangCB->setCheckState(Qt::Unchecked);
|
|
else
|
|
overhangCB->setCheckState(Qt::Checked);
|
|
|
|
linesSB->setValue(params.lines);
|
|
if (params.lines == 0)
|
|
linesCB->setCheckState(Qt::Unchecked);
|
|
else
|
|
linesCB->setCheckState(Qt::Checked);
|
|
|
|
int item = 0;
|
|
if (params.placement == "i" || params.placement == "I")
|
|
item = 1;
|
|
else if (params.placement == "l" || params.placement == "L")
|
|
item = 2;
|
|
else if (params.placement == "r" || params.placement == "R")
|
|
item = 3;
|
|
|
|
valignCO->setCurrentIndex(item);
|
|
|
|
if (params.placement == "O" || params.placement == "I"
|
|
|| params.placement == "L" || params.placement == "R")
|
|
floatCB->setCheckState(Qt::Checked);
|
|
}
|
|
|
|
|
|
bool GuiWrap::initialiseParams(string const & sdata)
|
|
{
|
|
InsetWrap::string2params(sdata, params_);
|
|
paramsToDialog(params_);
|
|
return true;
|
|
}
|
|
|
|
|
|
void GuiWrap::clearParams()
|
|
{
|
|
params_ = InsetWrapParams();
|
|
}
|
|
|
|
|
|
void GuiWrap::dispatchParams()
|
|
{
|
|
string const lfun = InsetWrap::params2string(params_);
|
|
dispatch(FuncRequest(getLfun(), lfun));
|
|
}
|
|
|
|
|
|
} // namespace frontend
|
|
} // namespace lyx
|
|
|
|
|
|
#include "moc_GuiWrap.cpp"
|