mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-17 13:26:58 +00:00
c293be56bd
In particular, the directory frontends/qt4 is renamed to frontends/qt. Many configurations file have to be updated. All mentions of qt4 in the source have been audited, and changed to qt if necessary. The only part that has not been updated is the CMake build system.
691 lines
19 KiB
C++
691 lines
19 KiB
C++
/**
|
|
* \file GuiExternal.cpp
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author John Levon
|
|
* \author Angus Leeming
|
|
* \author Asger Alstrup
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include "GuiExternal.h"
|
|
|
|
#include "Buffer.h"
|
|
#include "FuncRequest.h"
|
|
#include "support/gettext.h"
|
|
#include "Length.h"
|
|
#include "LyXRC.h"
|
|
|
|
#include "insets/ExternalSupport.h"
|
|
#include "insets/ExternalTemplate.h"
|
|
#include "insets/InsetExternal.h"
|
|
|
|
#include "graphics/epstools.h"
|
|
#include "graphics/GraphicsCache.h"
|
|
#include "graphics/GraphicsCacheItem.h"
|
|
#include "graphics/GraphicsImage.h"
|
|
|
|
#include "support/convert.h"
|
|
#include "support/filetools.h"
|
|
#include "support/lstrings.h"
|
|
#include "support/lyxlib.h"
|
|
#include "support/os.h"
|
|
|
|
#include "LengthCombo.h"
|
|
#include "qt_helpers.h"
|
|
#include "Validator.h"
|
|
|
|
#include <QCheckBox>
|
|
#include <QGroupBox>
|
|
#include <QLineEdit>
|
|
#include <QPushButton>
|
|
#include <QTabWidget>
|
|
#include <QTextBrowser>
|
|
|
|
using namespace std;
|
|
using namespace lyx::support;
|
|
|
|
namespace lyx {
|
|
namespace frontend {
|
|
|
|
using namespace external;
|
|
|
|
namespace {
|
|
|
|
RotationDataType origins[] = {
|
|
RotationData::DEFAULT,
|
|
RotationData::TOPLEFT,
|
|
RotationData::BOTTOMLEFT,
|
|
RotationData::BASELINELEFT,
|
|
RotationData::CENTER,
|
|
RotationData::TOPCENTER,
|
|
RotationData::BOTTOMCENTER,
|
|
RotationData::BASELINECENTER,
|
|
RotationData::TOPRIGHT,
|
|
RotationData::BOTTOMRIGHT,
|
|
RotationData::BASELINERIGHT
|
|
};
|
|
|
|
|
|
// These are the strings, corresponding to the above, that the GUI should
|
|
// use. Note that they can/should be translated.
|
|
char const * const origin_gui_strs[] = {
|
|
N_("Default"),
|
|
N_("Top left"), N_("Bottom left"), N_("Baseline left"),
|
|
N_("Center"), N_("Top center"), N_("Bottom center"), N_("Baseline center"),
|
|
N_("Top right"), N_("Bottom right"), N_("Baseline right")
|
|
};
|
|
|
|
} // namespace
|
|
|
|
|
|
GuiExternal::GuiExternal(GuiView & lv)
|
|
: GuiDialog(lv, "external", qt_("External Material")), bbChanged_(false)
|
|
{
|
|
setupUi(this);
|
|
|
|
connect(buttonBox, SIGNAL(clicked(QAbstractButton *)),
|
|
this, SLOT(slotButtonBox(QAbstractButton *)));
|
|
|
|
/*
|
|
connect(displayGB, SIGNAL(toggled(bool)),
|
|
displayscaleED, SLOT(setEnabled(bool)));
|
|
*/
|
|
connect(originCO, SIGNAL(activated(int)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(aspectratioCB, SIGNAL(stateChanged(int)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(browsePB, SIGNAL(clicked()),
|
|
this, SLOT(browseClicked()));
|
|
connect(externalCO, SIGNAL(activated(QString)),
|
|
this, SLOT(templateChanged()));
|
|
connect(extraED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(extraChanged(QString)));
|
|
connect(extraFormatCO, SIGNAL(activated(QString)),
|
|
this, SLOT(formatChanged(QString)));
|
|
connect(widthUnitCO, SIGNAL(activated(int)),
|
|
this, SLOT(widthUnitChanged()));
|
|
connect(heightUnitCO, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(displayGB, SIGNAL(toggled(bool)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(displayscaleED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(angleED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(widthED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(sizeChanged()));
|
|
connect(heightED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(sizeChanged()));
|
|
connect(fileED, SIGNAL(textChanged(QString)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(clipCB, SIGNAL(stateChanged(int)),
|
|
this, SLOT(change_adaptor()));
|
|
connect(getbbPB, SIGNAL(clicked()), this, SLOT(getbbClicked()));
|
|
connect(xrED, SIGNAL(textChanged(QString)), this, SLOT(bbChanged()));
|
|
connect(ytED, SIGNAL(textChanged(QString)), this, SLOT(bbChanged()));
|
|
connect(xlED, SIGNAL(textChanged(QString)), this, SLOT(bbChanged()));
|
|
connect(ybED, SIGNAL(textChanged(QString)), this, SLOT(bbChanged()));
|
|
connect(xrUnitCO, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(bbChanged()));
|
|
connect(ytUnitCO, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(bbChanged()));
|
|
connect(xlUnitCO, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(bbChanged()));
|
|
connect(ybUnitCO, SIGNAL(selectionChanged(lyx::Length::UNIT)),
|
|
this, SLOT(bbChanged()));
|
|
connect(draftCB, SIGNAL(clicked()), this, SLOT(change_adaptor()));
|
|
|
|
QIntValidator * validator = new QIntValidator(displayscaleED);
|
|
validator->setBottom(1);
|
|
displayscaleED->setValidator(validator);
|
|
|
|
angleED->setValidator(new QDoubleValidator(-360, 360, 2, angleED));
|
|
|
|
xlED->setValidator(unsignedLengthValidator(xlED));
|
|
ybED->setValidator(unsignedLengthValidator(ybED));
|
|
xrED->setValidator(unsignedLengthValidator(xrED));
|
|
ytED->setValidator(unsignedLengthValidator(ytED));
|
|
|
|
widthED->setValidator(unsignedLengthValidator(widthED));
|
|
heightED->setValidator(unsignedLengthValidator(heightED));
|
|
|
|
setFocusProxy(fileED);
|
|
|
|
bc().setPolicy(ButtonPolicy::NoRepeatedApplyReadOnlyPolicy);
|
|
|
|
bc().setOK(buttonBox->button(QDialogButtonBox::Ok));
|
|
bc().setApply(buttonBox->button(QDialogButtonBox::Apply));
|
|
bc().setCancel(buttonBox->button(QDialogButtonBox::Cancel));
|
|
|
|
bc().addReadOnly(fileED);
|
|
bc().addReadOnly(browsePB);
|
|
bc().addReadOnly(externalCO);
|
|
bc().addReadOnly(draftCB);
|
|
bc().addReadOnly(displayscaleED);
|
|
bc().addReadOnly(displayGB);
|
|
bc().addReadOnly(angleED);
|
|
bc().addReadOnly(originCO);
|
|
bc().addReadOnly(heightUnitCO);
|
|
bc().addReadOnly(heightED);
|
|
bc().addReadOnly(aspectratioCB);
|
|
bc().addReadOnly(widthUnitCO);
|
|
bc().addReadOnly(widthED);
|
|
bc().addReadOnly(clipCB);
|
|
bc().addReadOnly(getbbPB);
|
|
bc().addReadOnly(ytED);
|
|
bc().addReadOnly(xlED);
|
|
bc().addReadOnly(xrED);
|
|
bc().addReadOnly(ybED);
|
|
bc().addReadOnly(ytUnitCO);
|
|
bc().addReadOnly(xlUnitCO);
|
|
bc().addReadOnly(xrUnitCO);
|
|
bc().addReadOnly(ybUnitCO);
|
|
bc().addReadOnly(extraFormatCO);
|
|
bc().addReadOnly(extraED);
|
|
|
|
bc().addCheckedLineEdit(angleED, angleLA);
|
|
bc().addCheckedLineEdit(displayscaleED, scaleLA);
|
|
bc().addCheckedLineEdit(heightED, heightLA);
|
|
bc().addCheckedLineEdit(widthED, widthLA);
|
|
bc().addCheckedLineEdit(xlED, lbLA);
|
|
bc().addCheckedLineEdit(ybED, lbLA);
|
|
bc().addCheckedLineEdit(xrED, rtLA);
|
|
bc().addCheckedLineEdit(ytED, rtLA);
|
|
bc().addCheckedLineEdit(fileED, fileLA);
|
|
|
|
external::TemplateManager::Templates::const_iterator i1, i2;
|
|
i1 = external::TemplateManager::get().getTemplates().begin();
|
|
i2 = external::TemplateManager::get().getTemplates().end();
|
|
QMap<QString, QString> localizedTemplates;
|
|
for (; i1 != i2; ++i1)
|
|
localizedTemplates.insert(qt_(i1->second.guiName), toqstr(i1->second.lyxName));
|
|
// Sort alphabetically by (localized) GUI name
|
|
QStringList keys = localizedTemplates.keys();
|
|
qSort(keys.begin(), keys.end(), SortLocaleAware);
|
|
for (QString & key : keys) {
|
|
QString const value = localizedTemplates[key];
|
|
externalCO->addItem(key, value);
|
|
}
|
|
|
|
// Fill the origins combo
|
|
for (size_t i = 0; i != sizeof(origins) / sizeof(origins[0]); ++i)
|
|
originCO->addItem(qt_(origin_gui_strs[i]));
|
|
|
|
// add scale item
|
|
widthUnitCO->insertItem(0, qt_("Scale%"), "scale");
|
|
|
|
// remove all units from bb that depend on font or other dimensions
|
|
// we cannot use these, since we need to compare against absolute
|
|
// values from the image file.
|
|
xlUnitCO->noPercents();
|
|
xlUnitCO->removeFontDependent();
|
|
xrUnitCO->noPercents();
|
|
xrUnitCO->removeFontDependent();
|
|
ytUnitCO->noPercents();
|
|
ytUnitCO->removeFontDependent();
|
|
ybUnitCO->noPercents();
|
|
ybUnitCO->removeFontDependent();
|
|
}
|
|
|
|
|
|
bool GuiExternal::activateAspectratio() const
|
|
{
|
|
if (usingScale())
|
|
return false;
|
|
|
|
QString const wstr = widthED->text();
|
|
if (wstr.isEmpty())
|
|
return false;
|
|
bool wIsDbl;
|
|
double val = wstr.trimmed().toDouble(&wIsDbl);
|
|
if (wIsDbl && float_equal(val, 0.0, 0.05))
|
|
return false;
|
|
Length l;
|
|
if (!wIsDbl && (!isValidLength(fromqstr(wstr), &l) || l.zero()))
|
|
return false;
|
|
|
|
QString const hstr = heightED->text();
|
|
if (hstr.isEmpty())
|
|
return false;
|
|
bool hIsDbl;
|
|
val = hstr.trimmed().toDouble(&hIsDbl);
|
|
if (hIsDbl && float_equal(val, 0.0, 0.05))
|
|
return false;
|
|
if (!hIsDbl && (!isValidLength(fromqstr(hstr), &l) || l.zero()))
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
bool GuiExternal::usingScale() const
|
|
{
|
|
return (widthUnitCO->itemData(
|
|
widthUnitCO->currentIndex()).toString() == "scale");
|
|
}
|
|
|
|
|
|
void GuiExternal::bbChanged()
|
|
{
|
|
bbChanged_ = true;
|
|
changed();
|
|
}
|
|
|
|
|
|
void GuiExternal::browseClicked()
|
|
{
|
|
QString const template_name =
|
|
externalCO->itemData(externalCO->currentIndex()).toString();
|
|
QString const str = browse(fileED->text(), template_name);
|
|
if (!str.isEmpty()) {
|
|
fileED->setText(str);
|
|
changed();
|
|
}
|
|
}
|
|
|
|
|
|
void GuiExternal::change_adaptor()
|
|
{
|
|
changed();
|
|
}
|
|
|
|
|
|
void GuiExternal::extraChanged(const QString & text)
|
|
{
|
|
extra_[extraFormatCO->currentText()] = text;
|
|
changed();
|
|
}
|
|
|
|
|
|
void GuiExternal::formatChanged(const QString & format)
|
|
{
|
|
extraED->setText(extra_[format]);
|
|
}
|
|
|
|
|
|
void GuiExternal::getbbClicked()
|
|
{
|
|
xlED->setText("0");
|
|
ybED->setText("0");
|
|
xrED->setText("0");
|
|
ytED->setText("0");
|
|
|
|
string const filename = fromqstr(fileED->text());
|
|
if (filename.empty())
|
|
return;
|
|
|
|
FileName const abs_file(support::makeAbsPath(filename, fromqstr(bufferFilePath())));
|
|
|
|
// try to get it from the file, if possible
|
|
string bb = graphics::readBB_from_PSFile(abs_file);
|
|
if (bb.empty()) {
|
|
// we don't, so ask the Graphics Cache if it has loaded the file
|
|
int width = 0;
|
|
int height = 0;
|
|
|
|
graphics::Cache & gc = graphics::Cache::get();
|
|
if (gc.inCache(abs_file)) {
|
|
graphics::Image const * image = gc.item(abs_file)->image();
|
|
|
|
if (image) {
|
|
width = image->width();
|
|
height = image->height();
|
|
}
|
|
}
|
|
bb = "0 0 " + convert<string>(width) + ' ' + convert<string>(height);
|
|
}
|
|
|
|
doubleToWidget(xlED, token(bb, ' ', 0));
|
|
doubleToWidget(ybED, token(bb, ' ', 1));
|
|
doubleToWidget(xrED, token(bb, ' ', 2));
|
|
doubleToWidget(ytED, token(bb, ' ', 3));
|
|
// the values from the file always have the bigpoint-unit bp
|
|
xlUnitCO->setCurrentIndex(0);
|
|
ybUnitCO->setCurrentIndex(0);
|
|
xrUnitCO->setCurrentIndex(0);
|
|
ytUnitCO->setCurrentIndex(0);
|
|
|
|
bbChanged_ = false;
|
|
}
|
|
|
|
|
|
void GuiExternal::sizeChanged()
|
|
{
|
|
aspectratioCB->setEnabled(activateAspectratio());
|
|
changed();
|
|
}
|
|
|
|
|
|
void GuiExternal::templateChanged()
|
|
{
|
|
updateTemplate();
|
|
changed();
|
|
}
|
|
|
|
|
|
void GuiExternal::widthUnitChanged()
|
|
{
|
|
if (usingScale())
|
|
widthED->setValidator(new QDoubleValidator(0, 1000, 2, widthED));
|
|
else
|
|
widthED->setValidator(unsignedLengthValidator(widthED));
|
|
|
|
heightED->setEnabled(!usingScale());
|
|
heightUnitCO->setEnabled(!usingScale());
|
|
changed();
|
|
}
|
|
|
|
|
|
static void setRotation(QLineEdit & angleED, QComboBox & originCO,
|
|
external::RotationData const & data)
|
|
{
|
|
originCO.setCurrentIndex(int(data.origin()));
|
|
doubleToWidget(&angleED, data.angle);
|
|
}
|
|
|
|
|
|
static void getRotation(external::RotationData & data,
|
|
QLineEdit const & angleED, QComboBox const & originCO)
|
|
{
|
|
typedef external::RotationData::OriginType OriginType;
|
|
|
|
data.origin(static_cast<OriginType>(originCO.currentIndex()));
|
|
data.angle = widgetToDoubleStr(&angleED);
|
|
}
|
|
|
|
|
|
static void setSize(QLineEdit & widthED, LengthCombo & widthUnitCO,
|
|
QLineEdit & heightED, LengthCombo & heightUnitCO,
|
|
QCheckBox & aspectratioCB,
|
|
external::ResizeData const & data)
|
|
{
|
|
bool using_scale = data.usingScale();
|
|
string scale = data.scale;
|
|
if (data.no_resize()) {
|
|
// Everything is zero, so default to this!
|
|
using_scale = true;
|
|
scale = "100";
|
|
}
|
|
|
|
if (using_scale) {
|
|
doubleToWidget(&widthED, scale);
|
|
widthUnitCO.setCurrentItem("scale");
|
|
} else
|
|
lengthToWidgets(&widthED, &widthUnitCO,
|
|
data.width.asString(), Length::defaultUnit());
|
|
|
|
string const h = data.height.zero() ? string() : data.height.asString();
|
|
Length::UNIT const default_unit = data.width.zero() ?
|
|
Length::defaultUnit() : data.width.unit();
|
|
lengthToWidgets(&heightED, &heightUnitCO, h, default_unit);
|
|
|
|
heightED.setEnabled(!using_scale);
|
|
heightUnitCO.setEnabled(!using_scale);
|
|
|
|
aspectratioCB.setChecked(data.keepAspectRatio);
|
|
|
|
bool const disable_aspectRatio = using_scale ||
|
|
data.width.zero() || data.height.zero();
|
|
aspectratioCB.setEnabled(!disable_aspectRatio);
|
|
}
|
|
|
|
|
|
static void getSize(external::ResizeData & data,
|
|
QLineEdit const & widthED, QComboBox const & widthUnitCO,
|
|
QLineEdit const & heightED, LengthCombo const & heightUnitCO,
|
|
QCheckBox const & aspectratioCB, bool const scaling)
|
|
{
|
|
if (scaling) {
|
|
// scaling instead of a width
|
|
data.scale = widgetToDoubleStr(&widthED);
|
|
data.width = Length();
|
|
} else {
|
|
data.width = Length(widgetsToLength(&widthED, &widthUnitCO));
|
|
data.scale = string();
|
|
}
|
|
data.height = Length(widgetsToLength(&heightED, &heightUnitCO));
|
|
data.keepAspectRatio = aspectratioCB.isChecked();
|
|
}
|
|
|
|
|
|
void setCrop(QCheckBox & clipCB,
|
|
QLineEdit & xlED, QLineEdit & ybED,
|
|
QLineEdit & xrED, QLineEdit & ytED,
|
|
LengthCombo & xlUnitCO, LengthCombo & ybUnitCO,
|
|
LengthCombo & xrUnitCO, LengthCombo & ytUnitCO,
|
|
external::ClipData const & data)
|
|
{
|
|
clipCB.setChecked(data.clip);
|
|
Length::UNIT const default_unit = data.bbox.xl.zero() ?
|
|
Length::defaultUnit() : data.bbox.xl.unit();
|
|
lengthToWidgets(&xlED, &xlUnitCO, data.bbox.xl, default_unit);
|
|
lengthToWidgets(&ybED, &ybUnitCO, data.bbox.yb, default_unit);
|
|
lengthToWidgets(&xrED, &xrUnitCO, data.bbox.xr, default_unit);
|
|
lengthToWidgets(&ytED, &ytUnitCO, data.bbox.yt, default_unit);
|
|
}
|
|
|
|
|
|
static void getCrop(external::ClipData & data,
|
|
QCheckBox const & clipCB,
|
|
QLineEdit const & xlED, QLineEdit const & ybED,
|
|
QLineEdit const & xrED, QLineEdit const & ytED,
|
|
LengthCombo const & xlUnitCO, LengthCombo const & ybUnitCO,
|
|
LengthCombo const & xrUnitCO, LengthCombo const & ytUnitCO,
|
|
bool bb_changed)
|
|
{
|
|
data.clip = clipCB.isChecked();
|
|
|
|
if (!bb_changed)
|
|
return;
|
|
|
|
data.bbox.xl = Length(widgetsToLength(&xlED, &xlUnitCO));
|
|
data.bbox.yb = Length(widgetsToLength(&ybED, &ybUnitCO));
|
|
data.bbox.xr = Length(widgetsToLength(&xrED, &xrUnitCO));
|
|
data.bbox.yt = Length(widgetsToLength(&ytED, &ytUnitCO));
|
|
}
|
|
|
|
|
|
void GuiExternal::updateContents()
|
|
{
|
|
if (params_.filename.empty())
|
|
tab->setCurrentIndex(0);
|
|
|
|
string const name =
|
|
params_.filename.outputFileName(fromqstr(bufferFilePath()));
|
|
fileED->setText(toqstr(name));
|
|
|
|
externalCO->setCurrentIndex(
|
|
externalCO->findData(toqstr(params_.templatename())));
|
|
updateTemplate();
|
|
|
|
draftCB->setChecked(params_.draft);
|
|
|
|
displayGB->setChecked(params_.display);
|
|
displayscaleED->setText(QString::number(params_.lyxscale));
|
|
bool scaled = params_.display && !isBufferReadonly() &&
|
|
(params_.preview_mode != PREVIEW_INSTANT);
|
|
displayscaleED->setEnabled(scaled);
|
|
scaleLA->setEnabled(scaled);
|
|
displayGB->setEnabled(lyxrc.display_graphics);
|
|
|
|
|
|
setRotation(*angleED, *originCO, params_.rotationdata);
|
|
|
|
setSize(*widthED, *widthUnitCO, *heightED, *heightUnitCO,
|
|
*aspectratioCB, params_.resizedata);
|
|
|
|
setCrop(*clipCB, *xlED, *ybED, *xrED, *ytED,
|
|
*xlUnitCO, *ybUnitCO, *xrUnitCO, *ytUnitCO, params_.clipdata);
|
|
bbChanged_ = !params_.clipdata.bbox.empty();
|
|
|
|
isValid();
|
|
}
|
|
|
|
|
|
void GuiExternal::updateTemplate()
|
|
{
|
|
external::TemplateManager const & etm =
|
|
external::TemplateManager::get();
|
|
external::Template const * const templ = etm.getTemplateByName(
|
|
fromqstr(externalCO->itemData(externalCO->currentIndex()).toString()));
|
|
externalTB->setPlainText(toqstr(translateIfPossible(
|
|
templ ? templ->helpText : docstring())));
|
|
if (!templ)
|
|
return;
|
|
|
|
// Ascertain which (if any) transformations the template supports
|
|
// and disable tabs and Group Boxes hosting unsupported transforms.
|
|
typedef vector<external::TransformID> TransformIDs;
|
|
TransformIDs const transformIds = templ->transformIds;
|
|
TransformIDs::const_iterator tr_begin = transformIds.begin();
|
|
TransformIDs::const_iterator const tr_end = transformIds.end();
|
|
|
|
bool rotate = std::find(tr_begin, tr_end, external::Rotate) != tr_end;
|
|
rotationGB->setEnabled(rotate);
|
|
|
|
bool resize = std::find(tr_begin, tr_end, external::Resize) != tr_end;
|
|
scaleGB->setEnabled(resize);
|
|
|
|
bool clip = std::find(tr_begin, tr_end, external::Clip) != tr_end;
|
|
cropGB->setEnabled(clip);
|
|
|
|
sizetab->setEnabled(rotate || resize || clip);
|
|
tab->setTabEnabled(tab->indexOf(sizetab), rotate || resize || clip);
|
|
|
|
bool found = std::find(tr_begin, tr_end, external::Extra) != tr_end;
|
|
optionsGB->setEnabled(found);
|
|
|
|
bool scaled = displayGB->isChecked() && displayGB->isEnabled() &&
|
|
!isBufferReadonly() && (templ->preview_mode != PREVIEW_INSTANT);
|
|
displayscaleED->setEnabled(scaled);
|
|
scaleLA->setEnabled(scaled);
|
|
|
|
if (!found)
|
|
return;
|
|
|
|
// Ascertain whether the template has any formats supporting
|
|
// the 'Extra' option
|
|
extra_.clear();
|
|
extraED->clear();
|
|
extraFormatCO->clear();
|
|
|
|
external::Template::Formats::const_iterator it = templ->formats.begin();
|
|
external::Template::Formats::const_iterator end = templ->formats.end();
|
|
for (; it != end; ++it) {
|
|
if (it->second.option_transformers.find(external::Extra) ==
|
|
it->second.option_transformers.end())
|
|
continue;
|
|
string const format = it->first;
|
|
string const opt = params_.extradata.get(format);
|
|
extraFormatCO->addItem(toqstr(format));
|
|
extra_[toqstr(format)] = toqstr(opt);
|
|
}
|
|
|
|
bool const enabled = extraFormatCO->count() > 0;
|
|
|
|
optionsGB->setEnabled(enabled);
|
|
extraED->setEnabled(enabled && !isBufferReadonly());
|
|
extraFormatCO->setEnabled(enabled);
|
|
|
|
if (enabled) {
|
|
extraFormatCO->setCurrentIndex(0);
|
|
extraED->setText(extra_[extraFormatCO->currentText()]);
|
|
}
|
|
}
|
|
|
|
|
|
void GuiExternal::applyView()
|
|
{
|
|
params_.filename.set(fromqstr(fileED->text()), fromqstr(bufferFilePath()));
|
|
params_.settemplate(fromqstr(externalCO->itemData(externalCO->currentIndex()).toString()));
|
|
|
|
params_.draft = draftCB->isChecked();
|
|
params_.lyxscale = displayscaleED->text().toInt();
|
|
params_.display = displayGB->isChecked();
|
|
|
|
if (rotationGB->isEnabled())
|
|
getRotation(params_.rotationdata, *angleED, *originCO);
|
|
|
|
if (scaleGB->isEnabled())
|
|
getSize(params_.resizedata, *widthED, *widthUnitCO,
|
|
*heightED, *heightUnitCO, *aspectratioCB, usingScale());
|
|
|
|
if (cropGB->isEnabled())
|
|
getCrop(params_.clipdata, *clipCB, *xlED, *ybED, *xrED, *ytED,
|
|
*xlUnitCO, *ybUnitCO, *xrUnitCO, *ytUnitCO, bbChanged_);
|
|
|
|
if (optionsGB->isEnabled()) {
|
|
MapType::const_iterator it = extra_.begin();
|
|
MapType::const_iterator const end = extra_.end();
|
|
for (; it != end; ++it)
|
|
params_.extradata.set(fromqstr(it.key()), fromqstr(it.value().trimmed()));
|
|
}
|
|
}
|
|
|
|
|
|
bool GuiExternal::initialiseParams(string const & sdata)
|
|
{
|
|
InsetExternal::string2params(sdata, buffer(), params_);
|
|
return true;
|
|
}
|
|
|
|
|
|
void GuiExternal::clearParams()
|
|
{
|
|
params_ = InsetExternalParams();
|
|
}
|
|
|
|
|
|
void GuiExternal::dispatchParams()
|
|
{
|
|
string const lfun = InsetExternal::params2string(params_, buffer());
|
|
dispatch(FuncRequest(getLfun(), lfun));
|
|
}
|
|
|
|
|
|
static QStringList templateFilters(QString const & template_name)
|
|
{
|
|
/// Determine the template file extension
|
|
external::TemplateManager const & etm =
|
|
external::TemplateManager::get();
|
|
external::Template const * const et_ptr =
|
|
etm.getTemplateByName(fromqstr(template_name));
|
|
|
|
string filter;
|
|
if (et_ptr && et_ptr->fileRegExp != "" && et_ptr->fileRegExp != "*") {
|
|
filter += to_utf8(_(et_ptr->guiName));
|
|
filter += " (";
|
|
filter += et_ptr->fileRegExp;
|
|
filter += ")";
|
|
}
|
|
return fileFilters(toqstr(filter));
|
|
}
|
|
|
|
|
|
QString GuiExternal::browse(QString const & input,
|
|
QString const & template_name) const
|
|
{
|
|
QString const title = qt_("Select external file");
|
|
QString const bufpath = bufferFilePath();
|
|
QStringList const filter = templateFilters(template_name);
|
|
|
|
QString const label1 = qt_("D&ocuments");
|
|
QString const dir1 = toqstr(lyxrc.document_path);
|
|
|
|
return browseRelToParent(input, bufpath, title, filter, false, label1, dir1);
|
|
}
|
|
|
|
|
|
Dialog * createGuiExternal(GuiView & lv) { return new GuiExternal(lv); }
|
|
|
|
|
|
} // namespace frontend
|
|
} // namespace lyx
|
|
|
|
#include "moc_GuiExternal.cpp"
|