2006-03-05 17:24:44 +00:00
|
|
|
/**
|
2007-08-31 05:53:55 +00:00
|
|
|
* \file GuiDocument.cpp
|
2006-03-05 17:24:44 +00:00
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
*
|
|
|
|
* \author Edwin Leuven
|
2020-12-05 17:17:02 -05:00
|
|
|
* \author Richard Kimberly Heck (modules)
|
2006-03-05 17:24:44 +00:00
|
|
|
*
|
|
|
|
* Full author contact details are available in file CREDITS.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
2007-08-31 05:53:55 +00:00
|
|
|
#include "GuiDocument.h"
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2020-10-19 17:15:45 +03:00
|
|
|
#include "BulletsModule.h"
|
2012-10-09 07:22:48 +02:00
|
|
|
#include "CategorizedCombo.h"
|
2020-10-19 17:15:45 +03:00
|
|
|
#include "FancyLineEdit.h"
|
2008-05-08 09:18:45 +00:00
|
|
|
#include "GuiApplication.h"
|
|
|
|
#include "GuiBranches.h"
|
2009-04-16 07:29:01 +00:00
|
|
|
#include "GuiIndices.h"
|
2008-09-20 13:44:51 +00:00
|
|
|
#include "GuiSelectionManager.h"
|
2008-05-08 09:18:45 +00:00
|
|
|
#include "LaTeXHighlighter.h"
|
|
|
|
#include "Validator.h"
|
|
|
|
|
2008-03-07 03:53:21 +00:00
|
|
|
#include "LayoutFile.h"
|
2007-10-06 22:43:21 +00:00
|
|
|
#include "BranchList.h"
|
|
|
|
#include "buffer_funcs.h"
|
|
|
|
#include "Buffer.h"
|
|
|
|
#include "BufferView.h"
|
2016-12-31 09:28:51 +01:00
|
|
|
#include "CiteEnginesList.h"
|
2007-11-02 23:42:27 +00:00
|
|
|
#include "Color.h"
|
2009-04-11 21:40:11 +00:00
|
|
|
#include "ColorCache.h"
|
2016-10-19 18:11:58 -04:00
|
|
|
#include "Converter.h"
|
2015-06-03 12:14:30 +02:00
|
|
|
#include "Cursor.h"
|
2007-10-06 22:43:21 +00:00
|
|
|
#include "Encoding.h"
|
2006-08-25 13:40:01 +00:00
|
|
|
#include "FloatPlacement.h"
|
2009-04-10 11:06:53 +00:00
|
|
|
#include "Format.h"
|
2007-10-06 22:43:21 +00:00
|
|
|
#include "FuncRequest.h"
|
2009-04-16 07:29:01 +00:00
|
|
|
#include "IndicesList.h"
|
2007-10-06 22:43:21 +00:00
|
|
|
#include "Language.h"
|
|
|
|
#include "LaTeXFeatures.h"
|
2012-08-16 13:23:39 +02:00
|
|
|
#include "LaTeXFonts.h"
|
2007-09-29 20:02:32 +00:00
|
|
|
#include "Layout.h"
|
2012-10-09 07:22:48 +02:00
|
|
|
#include "LayoutEnums.h"
|
2009-02-12 15:07:22 +00:00
|
|
|
#include "LayoutModuleList.h"
|
2009-02-06 21:24:13 +00:00
|
|
|
#include "LyXRC.h"
|
2007-10-06 22:43:21 +00:00
|
|
|
#include "ModuleList.h"
|
|
|
|
#include "PDFOptions.h"
|
2007-05-14 12:09:14 +00:00
|
|
|
#include "qt_helpers.h"
|
2017-08-03 13:07:41 +02:00
|
|
|
#include "Session.h"
|
2007-10-06 22:43:21 +00:00
|
|
|
#include "Spacing.h"
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
#include "TextClass.h"
|
2014-03-03 18:24:51 +01:00
|
|
|
#include "Undo.h"
|
2015-07-18 16:29:04 +02:00
|
|
|
#include "VSpace.h"
|
2007-05-14 12:09:14 +00:00
|
|
|
|
Add support for listings package. Two listings command \lstinline, \lstinputlisting and an environment \lstlisting are supported, along with preamble \lstset. \lstinputlisting is implemented through Include dialog, and the other two are implemented with a new inset listings, along with its dialog.
* src/LyXAction.cpp: listing-insert action
* src/insets/Inset.h,cpp: LISTINGS_CODE
* src/insets/InsetInclude.cpp: handle \lstinputlisting
* src/insets/InsetListings.h,cpp: new listings inset
* src/insets/InsetListingsParams.h,cpp: parameters from listings package
* src/insets/InsetCommandParams.h,cpp: handle lstinputlisting option
* src/Bidi.cpp: handle LISTINGS_CODE
* src/frontends/qt4/ui/TextLayoutUi.ui: update UI
* src/frontends/qt4/ui/ListingsUi.ui: new dialog
* src/frontends/qt4/ui/IncludeUi.ui: update UI
* src/frontends/qt4/QInclude.h,cpp: add lstinputlisting
* src/frontends/qt4/QDocument.h,cpp: add textedit for preamble listings_params
* src/frontends/qt4/QListings.h,cpp: new listings inset
* src/frontends/qt4/Dialogs.cpp: new listings dialog
* src/frontends/controllers/ControlInclude.h,cpp: add lstinputlisting
* src/frontends/controllers/ControlListings.h,cpp: new listings inset
* src/LyXFunc.cpp: handle LISTING_CODE
* src/Paragraph.cpp: handle LISTING_CODE
* src/factory.cpp: new listings inset
* src/CutAndPaste.cpp: handle LISTINGS_CODE
* src/LaTeXFeatures.cpp: require listings
* src/Text3.cpp: Handle LISTINGS_CODE
* src/lfuns.h: add LFUN_LISTING_INSERT
* src/Buffer.cpp: change lyx file format to 269
* src/BufferParams.h,cpp: add listings_params to preamble
* lib/lyx2lyx/LyX.py: lyx2lyx
* lib/lyx2lyx/lyx_1_5.py: lyx2lyx
* lib/ui/stdmenus.inc: new menu item (no shortcut!)
* src/insets/Makefile.am: update autotools
* src/frontends/controllers/Makefile.am
* src/frontends/qt4/Makefile.dialogs
* src/frontends/qt4/Makefile.am
* po/POTFILES.in: a few more translatable files.
* development/scons/scons_manifest.py: scons build system
* development/FORMAT: document format changes
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18243 a592a061-630c-0410-9148-cb99ea01b6c8
2007-05-09 19:11:42 +00:00
|
|
|
#include "insets/InsetListingsParams.h"
|
2020-11-30 22:34:16 +02:00
|
|
|
#include "insets/InsetQuotes.h"
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2008-02-28 21:04:55 +00:00
|
|
|
#include "support/debug.h"
|
2018-04-19 23:33:40 -04:00
|
|
|
#include "support/docstream.h"
|
2007-12-05 09:23:19 +00:00
|
|
|
#include "support/FileName.h"
|
|
|
|
#include "support/filetools.h"
|
2008-05-08 09:18:45 +00:00
|
|
|
#include "support/gettext.h"
|
2012-01-03 20:51:07 +00:00
|
|
|
#include "support/lassert.h"
|
2006-03-05 17:24:44 +00:00
|
|
|
#include "support/lstrings.h"
|
2019-03-26 16:23:34 +01:00
|
|
|
#include "support/Package.h"
|
2018-04-19 23:33:40 -04:00
|
|
|
#include "support/TempFile.h"
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2008-01-15 10:38:19 +00:00
|
|
|
#include "frontends/alert.h"
|
|
|
|
|
2008-05-14 10:34:19 +00:00
|
|
|
#include <QAbstractItemModel>
|
2018-04-02 15:39:56 +02:00
|
|
|
#include <QButtonGroup>
|
2009-04-11 21:40:11 +00:00
|
|
|
#include <QColor>
|
|
|
|
#include <QColorDialog>
|
2007-05-14 12:09:14 +00:00
|
|
|
#include <QCloseEvent>
|
2019-03-26 16:23:34 +01:00
|
|
|
#include <QDirIterator>
|
2009-04-06 06:58:30 +00:00
|
|
|
#include <QFontDatabase>
|
2018-04-02 15:39:56 +02:00
|
|
|
#include <QHeaderView>
|
2019-04-20 09:28:46 +02:00
|
|
|
#include <QPixmap>
|
2007-05-14 14:23:55 +00:00
|
|
|
#include <QScrollBar>
|
2016-05-31 18:47:29 +01:00
|
|
|
#include <QTextBoundaryFinder>
|
2007-05-14 12:09:14 +00:00
|
|
|
#include <QTextCursor>
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
#include <sstream>
|
2008-10-14 14:04:21 +00:00
|
|
|
#include <vector>
|
2006-03-05 17:24:44 +00:00
|
|
|
|
2008-04-16 16:48:12 +00:00
|
|
|
|
2009-04-11 21:40:11 +00:00
|
|
|
// a style sheet for buttons
|
|
|
|
// this is for example used for the background color setting button
|
2009-04-12 09:13:46 +00:00
|
|
|
static inline QString colorButtonStyleSheet(QColor const & bgColor)
|
2009-04-11 21:40:11 +00:00
|
|
|
{
|
2009-04-12 09:13:46 +00:00
|
|
|
if (bgColor.isValid()) {
|
2010-04-02 23:50:39 +00:00
|
|
|
QString rc = QLatin1String("background-color:");
|
2009-04-12 09:13:46 +00:00
|
|
|
rc += bgColor.name();
|
|
|
|
return rc;
|
|
|
|
}
|
2009-04-12 10:11:54 +00:00
|
|
|
return QString();
|
2009-04-11 21:40:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-12-12 10:16:00 +00:00
|
|
|
using namespace std;
|
2007-12-12 19:57:42 +00:00
|
|
|
using namespace lyx::support;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-01-14 19:52:16 +00:00
|
|
|
|
2008-02-28 21:04:55 +00:00
|
|
|
namespace {
|
2008-01-14 19:52:16 +00:00
|
|
|
|
2007-09-05 20:33:29 +00:00
|
|
|
char const * const tex_graphics[] =
|
|
|
|
{
|
2008-09-29 19:33:37 +00:00
|
|
|
"default", "dvialw", "dvilaser", "dvipdf", "dvipdfm", "dvipdfmx",
|
|
|
|
"dvips", "dvipsone", "dvitops", "dviwin", "dviwindo", "dvi2ps", "emtex",
|
|
|
|
"ln", "oztex", "pctexhp", "pctexps", "pctexwin", "pctex32", "pdftex",
|
|
|
|
"psprint", "pubps", "tcidvi", "textures", "truetex", "vtex", "xdvi",
|
|
|
|
"xetex", "none", ""
|
2007-04-30 21:01:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2007-09-05 20:33:29 +00:00
|
|
|
char const * const tex_graphics_gui[] =
|
|
|
|
{
|
2008-09-29 19:33:37 +00:00
|
|
|
N_("Default"), "dvialw", "DviLaser", "dvipdf", "DVIPDFM", "DVIPDFMx",
|
|
|
|
"Dvips", "DVIPSONE", "DVItoPS", "DVIWIN", "DVIWindo", "dvi2ps", "EmTeX",
|
|
|
|
"LN", "OzTeX", "pctexhp", "pctexps", "pctexwin", "PCTeX32", "pdfTeX",
|
|
|
|
"psprint", "pubps", "tcidvi", "Textures", "TrueTeX", "VTeX", "xdvi",
|
|
|
|
"XeTeX", N_("None"), ""
|
2007-06-01 17:44:04 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-10-13 16:01:02 +00:00
|
|
|
char const * backref_opts[] =
|
|
|
|
{
|
|
|
|
"false", "section", "slide", "page", ""
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
char const * backref_opts_gui[] =
|
|
|
|
{
|
|
|
|
N_("Off"), N_("Section"), N_("Slide"), N_("Page"), ""
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-06-12 17:24:26 +02:00
|
|
|
char const * lst_packages[] =
|
|
|
|
{
|
|
|
|
"Listings", "Minted", ""
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2012-03-01 00:41:30 +00:00
|
|
|
vector<string> engine_types_;
|
2008-09-20 12:57:12 +00:00
|
|
|
vector<pair<string, QString> > pagestyles;
|
2007-06-01 17:44:04 +00:00
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
QMap<QString, QString> rmfonts_;
|
|
|
|
QMap<QString, QString> sffonts_;
|
|
|
|
QMap<QString, QString> ttfonts_;
|
2012-09-22 17:44:00 +02:00
|
|
|
QMap<QString, QString> mathfonts_;
|
2012-08-16 13:23:39 +02:00
|
|
|
|
2019-06-12 11:48:47 +02:00
|
|
|
enum EncodingSets {
|
|
|
|
unicode = 0,
|
|
|
|
legacy = 1,
|
|
|
|
custom = 2
|
|
|
|
};
|
2007-06-01 17:44:04 +00:00
|
|
|
|
2020-02-26 22:29:40 -05:00
|
|
|
lyx::RGBColor set_backgroundcolor;
|
2010-04-05 20:31:10 +00:00
|
|
|
bool is_backgroundcolor;
|
2020-02-26 22:29:40 -05:00
|
|
|
lyx::RGBColor set_fontcolor;
|
2010-04-02 23:39:36 +00:00
|
|
|
bool is_fontcolor;
|
2020-02-26 22:29:40 -05:00
|
|
|
lyx::RGBColor set_notefontcolor;
|
|
|
|
lyx::RGBColor set_boxbgcolor;
|
2013-07-20 16:15:47 +02:00
|
|
|
bool forced_fontspec_activation;
|
2009-04-11 21:40:11 +00:00
|
|
|
|
2020-02-26 22:29:40 -05:00
|
|
|
} // anonymous namespace
|
|
|
|
|
|
|
|
namespace lyx {
|
|
|
|
|
2008-02-28 21:04:55 +00:00
|
|
|
namespace {
|
|
|
|
// used when sorting the textclass list.
|
|
|
|
class less_textclass_avail_desc
|
|
|
|
{
|
|
|
|
public:
|
2008-09-20 13:44:51 +00:00
|
|
|
bool operator()(string const & lhs, string const & rhs) const
|
2008-02-28 21:04:55 +00:00
|
|
|
{
|
|
|
|
// Ordering criteria:
|
|
|
|
// 1. Availability of text class
|
|
|
|
// 2. Description (lexicographic)
|
2008-03-07 03:53:21 +00:00
|
|
|
LayoutFile const & tc1 = LayoutFileList::get()[lhs];
|
|
|
|
LayoutFile const & tc2 = LayoutFileList::get()[rhs];
|
2009-08-06 12:44:06 +00:00
|
|
|
int const order = compare_no_case(
|
2009-03-18 18:47:42 +00:00
|
|
|
translateIfPossible(from_utf8(tc1.description())),
|
|
|
|
translateIfPossible(from_utf8(tc2.description())));
|
2008-02-28 21:04:55 +00:00
|
|
|
return (tc1.isTeXClassAvailable() && !tc2.isTeXClassAvailable()) ||
|
2009-08-06 12:44:06 +00:00
|
|
|
(tc1.isTeXClassAvailable() == tc2.isTeXClassAvailable() && order < 0);
|
2008-02-28 21:04:55 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-07-23 13:11:54 +02:00
|
|
|
} // namespace
|
2008-02-28 21:04:55 +00:00
|
|
|
|
2007-04-25 10:25:37 +00:00
|
|
|
namespace frontend {
|
2008-01-09 18:51:02 +00:00
|
|
|
namespace {
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
vector<string> getRequiredList(string const & modName)
|
2008-09-20 12:17:15 +00:00
|
|
|
{
|
2009-08-14 15:37:34 +00:00
|
|
|
LyXModule const * const mod = theModuleList[modName];
|
2008-09-20 12:17:15 +00:00
|
|
|
if (!mod)
|
|
|
|
return vector<string>(); //empty such thing
|
|
|
|
return mod->getRequiredModules();
|
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
|
|
|
|
2008-09-20 12:17:15 +00:00
|
|
|
vector<string> getExcludedList(string const & modName)
|
|
|
|
{
|
2009-08-14 15:37:34 +00:00
|
|
|
LyXModule const * const mod = theModuleList[modName];
|
2008-09-20 12:17:15 +00:00
|
|
|
if (!mod)
|
|
|
|
return vector<string>(); //empty such thing
|
|
|
|
return mod->getExcludedModules();
|
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
|
|
|
|
2012-03-08 16:43:04 +00:00
|
|
|
docstring getModuleCategory(string const & modName)
|
|
|
|
{
|
|
|
|
LyXModule const * const mod = theModuleList[modName];
|
|
|
|
if (!mod)
|
|
|
|
return docstring();
|
|
|
|
return from_utf8(mod->category());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-09-20 12:17:15 +00:00
|
|
|
docstring getModuleDescription(string const & modName)
|
|
|
|
{
|
2009-08-14 15:37:34 +00:00
|
|
|
LyXModule const * const mod = theModuleList[modName];
|
2008-09-20 12:17:15 +00:00
|
|
|
if (!mod)
|
|
|
|
return _("Module not found!");
|
2008-11-04 15:44:02 +00:00
|
|
|
// FIXME Unicode
|
2008-11-04 15:38:37 +00:00
|
|
|
return translateIfPossible(from_utf8(mod->getDescription()));
|
2008-09-20 12:17:15 +00:00
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
|
|
|
|
2008-09-20 12:17:15 +00:00
|
|
|
vector<string> getPackageList(string const & modName)
|
|
|
|
{
|
2009-08-14 15:37:34 +00:00
|
|
|
LyXModule const * const mod = theModuleList[modName];
|
2008-09-20 12:17:15 +00:00
|
|
|
if (!mod)
|
|
|
|
return vector<string>(); //empty such thing
|
|
|
|
return mod->getPackageList();
|
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
|
|
|
|
2008-09-20 12:17:15 +00:00
|
|
|
bool isModuleAvailable(string const & modName)
|
|
|
|
{
|
2009-08-14 15:46:10 +00:00
|
|
|
LyXModule const * const mod = theModuleList[modName];
|
2008-09-20 12:17:15 +00:00
|
|
|
if (!mod)
|
|
|
|
return false;
|
|
|
|
return mod->isAvailable();
|
|
|
|
}
|
|
|
|
|
|
|
|
} // anonymous namespace
|
|
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// ModuleSelectionManager
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
2008-01-09 18:51:02 +00:00
|
|
|
|
2008-09-20 13:44:51 +00:00
|
|
|
/// SelectionManager for use with modules
|
2011-12-03 22:15:11 +00:00
|
|
|
class ModuleSelectionManager : public GuiSelectionManager
|
2008-09-20 13:44:51 +00:00
|
|
|
{
|
|
|
|
public:
|
2008-10-16 13:41:25 +00:00
|
|
|
///
|
2017-02-26 22:15:49 +01:00
|
|
|
ModuleSelectionManager(QObject * parent,
|
2020-02-26 22:29:40 -05:00
|
|
|
QTreeView * availableLVarg,
|
|
|
|
QTreeView * selectedLVarg,
|
|
|
|
QPushButton * addPBarg,
|
|
|
|
QPushButton * delPBarg,
|
|
|
|
QPushButton * upPBarg,
|
|
|
|
QPushButton * downPBarg,
|
|
|
|
QStandardItemModel * availableModelarg,
|
|
|
|
GuiIdListModel * selectedModelarg,
|
2017-02-26 22:15:49 +01:00
|
|
|
GuiDocument const * container)
|
2020-02-26 22:29:40 -05:00
|
|
|
: GuiSelectionManager(parent, availableLVarg, selectedLVarg, addPBarg, delPBarg,
|
|
|
|
upPBarg, downPBarg, availableModelarg, selectedModelarg),
|
2017-02-26 22:15:49 +01:00
|
|
|
container_(container)
|
2008-09-20 13:44:51 +00:00
|
|
|
{}
|
2008-10-23 00:27:03 +00:00
|
|
|
///
|
2011-12-03 22:15:11 +00:00
|
|
|
void updateProvidedModules(LayoutModuleList const & pm)
|
2009-02-12 15:07:22 +00:00
|
|
|
{ provided_modules_ = pm.list(); }
|
2008-10-23 00:27:03 +00:00
|
|
|
///
|
2011-12-03 22:15:11 +00:00
|
|
|
void updateExcludedModules(LayoutModuleList const & em)
|
2009-02-12 15:07:22 +00:00
|
|
|
{ excluded_modules_ = em.list(); }
|
2008-09-20 13:44:51 +00:00
|
|
|
private:
|
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void updateAddPB() override;
|
2008-09-20 13:44:51 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void updateUpPB() override;
|
2008-09-20 13:44:51 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void updateDownPB() override;
|
2008-09-20 13:44:51 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void updateDelPB() override;
|
2008-09-20 13:44:51 +00:00
|
|
|
/// returns availableModel as a GuiIdListModel
|
2019-04-07 11:23:19 +02:00
|
|
|
QStandardItemModel * getAvailableModel()
|
2008-09-20 13:44:51 +00:00
|
|
|
{
|
2019-04-07 11:23:19 +02:00
|
|
|
return dynamic_cast<QStandardItemModel *>(availableModel);
|
2008-09-20 13:44:51 +00:00
|
|
|
}
|
|
|
|
/// returns selectedModel as a GuiIdListModel
|
2011-12-03 22:15:11 +00:00
|
|
|
GuiIdListModel * getSelectedModel()
|
2008-09-20 13:44:51 +00:00
|
|
|
{
|
|
|
|
return dynamic_cast<GuiIdListModel *>(selectedModel);
|
|
|
|
}
|
2008-10-23 00:27:03 +00:00
|
|
|
/// keeps a list of the modules the text class provides
|
2010-01-01 02:43:44 +00:00
|
|
|
list<string> provided_modules_;
|
2008-10-23 00:27:03 +00:00
|
|
|
/// similarly...
|
2010-01-01 02:43:44 +00:00
|
|
|
list<string> excluded_modules_;
|
2011-12-03 22:15:11 +00:00
|
|
|
///
|
2008-10-20 19:53:15 +00:00
|
|
|
GuiDocument const * container_;
|
2008-09-20 13:44:51 +00:00
|
|
|
};
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
void ModuleSelectionManager::updateAddPB()
|
2008-01-09 18:51:02 +00:00
|
|
|
{
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
int const arows = availableModel->rowCount();
|
2011-12-03 22:15:11 +00:00
|
|
|
QModelIndexList const avail_sels =
|
2019-04-07 11:23:19 +02:00
|
|
|
availableLV->selectionModel()->selectedRows(0);
|
2008-10-16 15:04:48 +00:00
|
|
|
|
|
|
|
// disable if there aren't any modules (?), if none of them is chosen
|
|
|
|
// in the dialog, or if the chosen one is already selected for use.
|
2008-10-20 20:31:33 +00:00
|
|
|
if (arows == 0 || avail_sels.isEmpty() || isSelected(avail_sels.first())) {
|
2008-01-09 18:51:02 +00:00
|
|
|
addPB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2008-10-16 15:04:48 +00:00
|
|
|
|
2008-01-09 18:51:02 +00:00
|
|
|
QModelIndex const & idx = availableLV->selectionModel()->currentIndex();
|
2019-04-07 11:23:19 +02:00
|
|
|
|
|
|
|
if (getAvailableModel()->itemFromIndex(idx)->hasChildren()) {
|
|
|
|
// This is a category header
|
|
|
|
addPB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
string const modname = fromqstr(getAvailableModel()->data(idx, Qt::UserRole).toString());
|
2008-01-09 18:51:02 +00:00
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
bool const enable =
|
2012-12-05 11:16:21 -05:00
|
|
|
container_->params().layoutModuleCanBeAdded(modname);
|
2008-10-20 19:53:15 +00:00
|
|
|
addPB->setEnabled(enable);
|
2008-01-09 18:51:02 +00:00
|
|
|
}
|
|
|
|
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
|
2008-09-20 12:17:15 +00:00
|
|
|
void ModuleSelectionManager::updateDownPB()
|
2008-01-10 01:33:24 +00:00
|
|
|
{
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
int const srows = selectedModel->rowCount();
|
2008-01-10 01:33:24 +00:00
|
|
|
if (srows == 0) {
|
|
|
|
downPB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2008-10-20 20:31:33 +00:00
|
|
|
QModelIndex const & curidx = selectedLV->selectionModel()->currentIndex();
|
|
|
|
int const curRow = curidx.row();
|
2008-10-14 17:14:25 +00:00
|
|
|
if (curRow < 0 || curRow >= srows - 1) { // invalid or last item
|
2008-01-10 01:33:24 +00:00
|
|
|
downPB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2008-10-14 17:14:25 +00:00
|
|
|
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
// determine whether immediately succeeding element requires this one
|
2008-10-20 20:31:33 +00:00
|
|
|
string const curmodname = getSelectedModel()->getIDString(curRow);
|
|
|
|
string const nextmodname = getSelectedModel()->getIDString(curRow + 1);
|
2008-01-10 01:33:24 +00:00
|
|
|
|
2008-10-20 20:31:33 +00:00
|
|
|
vector<string> reqs = getRequiredList(nextmodname);
|
2008-01-10 01:33:24 +00:00
|
|
|
|
2008-10-12 22:21:56 +00:00
|
|
|
// if it doesn't require anything....
|
2008-01-10 01:33:24 +00:00
|
|
|
if (reqs.empty()) {
|
|
|
|
downPB->setEnabled(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2008-10-12 22:21:56 +00:00
|
|
|
// Enable it if this module isn't required.
|
2011-12-03 22:15:11 +00:00
|
|
|
// FIXME This should perhaps be more flexible and check whether, even
|
2008-10-14 17:35:49 +00:00
|
|
|
// if the next one is required, there is also an earlier one that will do.
|
2008-01-10 01:33:24 +00:00
|
|
|
downPB->setEnabled(
|
2008-10-20 20:31:33 +00:00
|
|
|
find(reqs.begin(), reqs.end(), curmodname) == reqs.end());
|
2008-01-10 01:33:24 +00:00
|
|
|
}
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
void ModuleSelectionManager::updateUpPB()
|
2008-01-10 01:33:24 +00:00
|
|
|
{
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
int const srows = selectedModel->rowCount();
|
2008-01-10 01:33:24 +00:00
|
|
|
if (srows == 0) {
|
|
|
|
upPB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
|
|
|
|
QModelIndex const & curIdx = selectedLV->selectionModel()->currentIndex();
|
|
|
|
int curRow = curIdx.row();
|
2008-10-14 17:14:25 +00:00
|
|
|
if (curRow <= 0 || curRow > srows - 1) { // first item or invalid
|
|
|
|
upPB->setEnabled(false);
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
return;
|
|
|
|
}
|
2008-10-20 20:31:33 +00:00
|
|
|
string const curmodname = getSelectedModel()->getIDString(curRow);
|
2008-10-14 17:35:49 +00:00
|
|
|
|
|
|
|
// determine whether immediately preceding element is required by this one
|
2008-10-20 20:31:33 +00:00
|
|
|
vector<string> reqs = getRequiredList(curmodname);
|
2008-10-16 13:41:25 +00:00
|
|
|
|
2008-10-12 22:21:56 +00:00
|
|
|
// if this one doesn't require anything....
|
2008-01-10 01:33:24 +00:00
|
|
|
if (reqs.empty()) {
|
|
|
|
upPB->setEnabled(true);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-12 22:21:56 +00:00
|
|
|
// Enable it if the preceding module isn't required.
|
2011-12-03 22:15:11 +00:00
|
|
|
// NOTE This is less flexible than it might be. We could check whether, even
|
2008-10-14 17:35:49 +00:00
|
|
|
// if the previous one is required, there is an earlier one that would do.
|
2008-10-20 20:31:33 +00:00
|
|
|
string const premod = getSelectedModel()->getIDString(curRow - 1);
|
|
|
|
upPB->setEnabled(find(reqs.begin(), reqs.end(), premod) == reqs.end());
|
2008-01-10 01:33:24 +00:00
|
|
|
}
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
void ModuleSelectionManager::updateDelPB()
|
2008-01-10 01:33:24 +00:00
|
|
|
{
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
int const srows = selectedModel->rowCount();
|
2008-01-10 01:33:24 +00:00
|
|
|
if (srows == 0) {
|
|
|
|
deletePB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2008-10-20 19:53:15 +00:00
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
QModelIndex const & curidx =
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
selectedLV->selectionModel()->currentIndex();
|
2008-10-20 20:31:33 +00:00
|
|
|
int const curRow = curidx.row();
|
2008-10-14 17:14:25 +00:00
|
|
|
if (curRow < 0 || curRow >= srows) { // invalid index?
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
deletePB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2008-10-16 13:41:25 +00:00
|
|
|
|
2008-10-20 20:31:33 +00:00
|
|
|
string const curmodname = getSelectedModel()->getIDString(curRow);
|
2008-10-16 13:41:25 +00:00
|
|
|
|
2008-10-12 22:21:56 +00:00
|
|
|
// We're looking here for a reason NOT to enable the button. If we
|
|
|
|
// find one, we disable it and return. If we don't, we'll end up at
|
|
|
|
// the end of the function, and then we enable it.
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
for (int i = curRow + 1; i < srows; ++i) {
|
|
|
|
string const thisMod = getSelectedModel()->getIDString(i);
|
|
|
|
vector<string> reqs = getRequiredList(thisMod);
|
2008-01-10 01:33:24 +00:00
|
|
|
//does this one require us?
|
2008-10-20 20:31:33 +00:00
|
|
|
if (find(reqs.begin(), reqs.end(), curmodname) == reqs.end())
|
2008-01-10 01:33:24 +00:00
|
|
|
//no...
|
|
|
|
continue;
|
|
|
|
|
2008-10-12 22:21:56 +00:00
|
|
|
// OK, so this module requires us
|
|
|
|
// is there an EARLIER module that also satisfies the require?
|
|
|
|
// NOTE We demand that it be earlier to keep the list of modules
|
|
|
|
// consistent with the rule that a module must be proceeded by a
|
|
|
|
// required module. There would be more flexible ways to proceed,
|
|
|
|
// but that would be a lot more complicated, and the logic here is
|
|
|
|
// already complicated. (That's why I've left the debugging code.)
|
2010-01-01 02:43:44 +00:00
|
|
|
// lyxerr << "Testing " << thisMod << endl;
|
2008-10-20 20:31:33 +00:00
|
|
|
bool foundone = false;
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
for (int j = 0; j < curRow; ++j) {
|
|
|
|
string const mod = getSelectedModel()->getIDString(j);
|
2010-01-01 02:43:44 +00:00
|
|
|
// lyxerr << "In loop: Testing " << mod << endl;
|
2011-12-03 22:15:11 +00:00
|
|
|
// do we satisfy the require?
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (find(reqs.begin(), reqs.end(), mod) != reqs.end()) {
|
2010-01-01 02:43:44 +00:00
|
|
|
// lyxerr << mod << " does the trick." << endl;
|
2008-10-20 20:31:33 +00:00
|
|
|
foundone = true;
|
2008-01-10 01:33:24 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2008-10-12 22:21:56 +00:00
|
|
|
// did we find a module to satisfy the require?
|
2008-10-20 20:31:33 +00:00
|
|
|
if (!foundone) {
|
2010-01-01 02:43:44 +00:00
|
|
|
// lyxerr << "No matching module found." << endl;
|
2008-01-10 01:33:24 +00:00
|
|
|
deletePB->setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2010-01-01 02:43:44 +00:00
|
|
|
// lyxerr << "All's well that ends well." << endl;
|
2008-01-10 01:33:24 +00:00
|
|
|
deletePB->setEnabled(true);
|
|
|
|
}
|
|
|
|
|
2008-01-09 18:51:02 +00:00
|
|
|
|
2007-05-14 12:09:14 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// PreambleModule
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
|
2017-02-26 22:15:49 +01:00
|
|
|
PreambleModule::PreambleModule(QWidget * parent)
|
2020-02-26 22:29:40 -05:00
|
|
|
: UiWidget<Ui::PreambleUi>(parent), current_id_(nullptr)
|
2007-05-14 12:09:14 +00:00
|
|
|
{
|
|
|
|
// This is not a memory leak. The object will be destroyed
|
|
|
|
// with this.
|
2016-07-15 17:45:47 +01:00
|
|
|
// @ is letter in the LyX user preamble
|
|
|
|
(void) new LaTeXHighlighter(preambleTE->document(), true);
|
2016-04-15 11:49:04 +02:00
|
|
|
preambleTE->setFont(guiApp->typewriterSystemFont());
|
2016-02-17 21:45:44 +00:00
|
|
|
preambleTE->setWordWrapMode(QTextOption::NoWrap);
|
2007-05-14 12:09:14 +00:00
|
|
|
setFocusProxy(preambleTE);
|
2007-05-14 16:54:27 +00:00
|
|
|
connect(preambleTE, SIGNAL(textChanged()), this, SIGNAL(changed()));
|
2018-04-01 22:00:41 -04:00
|
|
|
connect(findLE, SIGNAL(textEdited(const QString &)), this, SLOT(checkFindButton()));
|
|
|
|
connect(findButtonPB, SIGNAL(clicked()), this, SLOT(findText()));
|
2018-04-19 23:33:40 -04:00
|
|
|
connect(editPB, SIGNAL(clicked()), this, SLOT(editExternal()));
|
2018-04-01 22:00:41 -04:00
|
|
|
connect(findLE, SIGNAL(returnPressed()), this, SLOT(findText()));
|
|
|
|
checkFindButton();
|
2018-04-01 22:07:21 -04:00
|
|
|
// https://stackoverflow.com/questions/13027091/how-to-override-tab-width-in-qt
|
|
|
|
const int tabStop = 4;
|
|
|
|
QFontMetrics metrics(preambleTE->currentFont());
|
2020-03-08 11:16:28 -04:00
|
|
|
#if (QT_VERSION >= QT_VERSION_CHECK(5, 11, 0))
|
|
|
|
// horizontalAdvance() is available starting in 5.11.0
|
|
|
|
// setTabStopDistance() is available starting in 5.10.0
|
|
|
|
preambleTE->setTabStopDistance(tabStop * metrics.horizontalAdvance(' '));
|
|
|
|
#else
|
2018-04-01 22:07:21 -04:00
|
|
|
preambleTE->setTabStopWidth(tabStop * metrics.width(' '));
|
2020-03-08 11:16:28 -04:00
|
|
|
#endif
|
2018-04-01 22:00:41 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void PreambleModule::checkFindButton()
|
|
|
|
{
|
|
|
|
findButtonPB->setEnabled(!findLE->text().isEmpty());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void PreambleModule::findText()
|
|
|
|
{
|
|
|
|
bool const found = preambleTE->find(findLE->text());
|
|
|
|
if (!found) {
|
|
|
|
// wrap
|
|
|
|
QTextCursor qtcur = preambleTE->textCursor();
|
|
|
|
qtcur.movePosition(QTextCursor::Start);
|
|
|
|
preambleTE->setTextCursor(qtcur);
|
|
|
|
preambleTE->find(findLE->text());
|
|
|
|
}
|
2007-05-14 12:09:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-05-14 16:41:50 +00:00
|
|
|
void PreambleModule::update(BufferParams const & params, BufferId id)
|
2007-05-14 12:09:14 +00:00
|
|
|
{
|
|
|
|
QString preamble = toqstr(params.preamble);
|
|
|
|
// Nothing to do if the params and preamble are unchanged.
|
2007-05-28 22:27:45 +00:00
|
|
|
if (id == current_id_
|
2007-05-14 12:09:14 +00:00
|
|
|
&& preamble == preambleTE->document()->toPlainText())
|
|
|
|
return;
|
|
|
|
|
|
|
|
QTextCursor cur = preambleTE->textCursor();
|
|
|
|
// Save the coords before switching to the new one.
|
2007-05-28 22:27:45 +00:00
|
|
|
preamble_coords_[current_id_] =
|
2007-05-14 12:09:14 +00:00
|
|
|
make_pair(cur.position(), preambleTE->verticalScrollBar()->value());
|
|
|
|
|
|
|
|
// Save the params address for further use.
|
|
|
|
current_id_ = id;
|
|
|
|
preambleTE->document()->setPlainText(preamble);
|
|
|
|
Coords::const_iterator it = preamble_coords_.find(current_id_);
|
|
|
|
if (it == preamble_coords_.end())
|
|
|
|
// First time we open this one.
|
2008-09-08 01:18:33 +00:00
|
|
|
preamble_coords_[current_id_] = make_pair(0, 0);
|
2007-05-14 12:09:14 +00:00
|
|
|
else {
|
|
|
|
// Restore saved coords.
|
2017-12-16 09:55:25 -05:00
|
|
|
cur = preambleTE->textCursor();
|
2007-05-14 12:09:14 +00:00
|
|
|
cur.setPosition(it->second.first);
|
|
|
|
preambleTE->setTextCursor(cur);
|
|
|
|
preambleTE->verticalScrollBar()->setValue(it->second.second);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void PreambleModule::apply(BufferParams & params)
|
|
|
|
{
|
2016-09-25 12:37:40 +02:00
|
|
|
params.preamble = qstring_to_ucs4(preambleTE->document()->toPlainText());
|
2007-05-14 12:09:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void PreambleModule::closeEvent(QCloseEvent * e)
|
|
|
|
{
|
|
|
|
// Save the coords before closing.
|
|
|
|
QTextCursor cur = preambleTE->textCursor();
|
2007-05-28 22:27:45 +00:00
|
|
|
preamble_coords_[current_id_] =
|
2007-05-14 12:09:14 +00:00
|
|
|
make_pair(cur.position(), preambleTE->verticalScrollBar()->value());
|
|
|
|
e->accept();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-04-19 23:33:40 -04:00
|
|
|
void PreambleModule::editExternal() {
|
|
|
|
if (!current_id_)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (tempfile_) {
|
|
|
|
preambleTE->setReadOnly(false);
|
|
|
|
FileName const tempfilename = tempfile_->name();
|
|
|
|
docstring const s = tempfilename.fileContents("UTF-8");
|
|
|
|
preambleTE->document()->setPlainText(toqstr(s));
|
|
|
|
tempfile_.reset();
|
2019-03-22 22:14:21 +01:00
|
|
|
editPB->setText(qt_("&Edit"));
|
2018-04-19 23:33:40 -04:00
|
|
|
changed();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
string const format =
|
|
|
|
current_id_->params().documentClass().outputFormat();
|
|
|
|
string const ext = theFormats().extension(format);
|
2018-06-06 13:55:59 -04:00
|
|
|
tempfile_.reset(new TempFile("preamble_editXXXXXX." + ext));
|
2018-04-19 23:33:40 -04:00
|
|
|
FileName const tempfilename = tempfile_->name();
|
|
|
|
string const name = tempfilename.toFilesystemEncoding();
|
|
|
|
ofdocstream os(name.c_str());
|
|
|
|
os << qstring_to_ucs4(preambleTE->document()->toPlainText());
|
|
|
|
os.close();
|
|
|
|
preambleTE->setReadOnly(true);
|
|
|
|
theFormats().edit(*current_id_, tempfilename, format);
|
2019-03-22 22:14:21 +01:00
|
|
|
editPB->setText(qt_("&End Edit"));
|
2018-04-19 23:33:40 -04:00
|
|
|
changed();
|
|
|
|
}
|
|
|
|
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// LocalLayout
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
2017-02-26 22:15:49 +01:00
|
|
|
LocalLayout::LocalLayout(QWidget * parent)
|
2020-02-26 22:29:40 -05:00
|
|
|
: UiWidget<Ui::LocalLayoutUi>(parent), current_id_(nullptr), validated_(false)
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
{
|
2018-01-24 23:09:46 -07:00
|
|
|
locallayoutTE->setFont(guiApp->typewriterSystemFont());
|
|
|
|
locallayoutTE->setWordWrapMode(QTextOption::NoWrap);
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
connect(locallayoutTE, SIGNAL(textChanged()), this, SLOT(textChanged()));
|
|
|
|
connect(validatePB, SIGNAL(clicked()), this, SLOT(validatePressed()));
|
2011-05-08 00:54:17 +00:00
|
|
|
connect(convertPB, SIGNAL(clicked()), this, SLOT(convertPressed()));
|
2018-04-19 23:33:40 -04:00
|
|
|
connect(editPB, SIGNAL(clicked()), this, SLOT(editExternal()));
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LocalLayout::update(BufferParams const & params, BufferId id)
|
|
|
|
{
|
2013-05-15 07:19:49 +02:00
|
|
|
QString layout = toqstr(params.getLocalLayout(false));
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
// Nothing to do if the params and preamble are unchanged.
|
|
|
|
if (id == current_id_
|
|
|
|
&& layout == locallayoutTE->document()->toPlainText())
|
|
|
|
return;
|
|
|
|
|
|
|
|
// Save the params address for further use.
|
|
|
|
current_id_ = id;
|
|
|
|
locallayoutTE->document()->setPlainText(layout);
|
|
|
|
validate();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LocalLayout::apply(BufferParams & params)
|
|
|
|
{
|
2016-09-25 12:37:40 +02:00
|
|
|
docstring const layout =
|
|
|
|
qstring_to_ucs4(locallayoutTE->document()->toPlainText());
|
2013-05-15 07:19:49 +02:00
|
|
|
params.setLocalLayout(layout, false);
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-07-23 15:29:40 +01:00
|
|
|
void LocalLayout::hideConvert()
|
|
|
|
{
|
|
|
|
convertPB->setEnabled(false);
|
|
|
|
convertLB->setText("");
|
|
|
|
convertPB->hide();
|
|
|
|
convertLB->hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
void LocalLayout::textChanged()
|
|
|
|
{
|
2018-12-29 11:47:37 +01:00
|
|
|
// Flashy red bold text
|
|
|
|
static const QString ivpar("<p style=\"color: #c00000; font-weight: bold; text-align:left\">"
|
|
|
|
"%1</p>");
|
|
|
|
static const QString message = ivpar.arg(qt_("Validation required!"));
|
2012-04-21 16:22:28 -04:00
|
|
|
string const layout =
|
|
|
|
fromqstr(locallayoutTE->document()->toPlainText().trimmed());
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
|
2012-04-21 16:22:28 -04:00
|
|
|
if (layout.empty()) {
|
2012-04-21 16:25:38 -04:00
|
|
|
validated_ = true;
|
2012-04-21 16:22:28 -04:00
|
|
|
validatePB->setEnabled(false);
|
|
|
|
validLB->setText("");
|
2016-07-23 15:29:40 +01:00
|
|
|
hideConvert();
|
2012-04-21 16:22:28 -04:00
|
|
|
changed();
|
|
|
|
} else if (!validatePB->isEnabled()) {
|
|
|
|
// if that's already enabled, we shouldn't need to do anything.
|
2012-04-21 16:25:38 -04:00
|
|
|
validated_ = false;
|
2012-04-21 16:22:28 -04:00
|
|
|
validLB->setText(message);
|
|
|
|
validatePB->setEnabled(true);
|
2016-07-23 15:29:40 +01:00
|
|
|
hideConvert();
|
2012-04-21 16:22:28 -04:00
|
|
|
changed();
|
|
|
|
}
|
2011-05-08 00:54:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LocalLayout::convert() {
|
|
|
|
string const layout =
|
|
|
|
fromqstr(locallayoutTE->document()->toPlainText().trimmed());
|
|
|
|
string const newlayout = TextClass::convert(layout);
|
2016-07-23 15:29:40 +01:00
|
|
|
if (!newlayout.empty())
|
2011-05-08 00:54:17 +00:00
|
|
|
locallayoutTE->setPlainText(toqstr(newlayout));
|
|
|
|
validate();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LocalLayout::convertPressed() {
|
|
|
|
convert();
|
2016-07-23 15:29:40 +01:00
|
|
|
hideConvert();
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
changed();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LocalLayout::validate() {
|
2016-07-23 15:29:40 +01:00
|
|
|
// Bold text
|
2018-12-29 11:47:37 +01:00
|
|
|
static const QString vpar("<p style=\"font-weight: bold; text-align:left\">%1</p>");
|
2016-07-23 15:29:40 +01:00
|
|
|
// Flashy red bold text
|
2018-12-29 11:47:37 +01:00
|
|
|
static const QString ivpar("<p style=\"color: #c00000; font-weight: bold; text-align:left\">"
|
2016-07-23 15:29:40 +01:00
|
|
|
"%1</p>");
|
2011-12-03 22:15:11 +00:00
|
|
|
string const layout =
|
2010-09-03 13:33:05 +00:00
|
|
|
fromqstr(locallayoutTE->document()->toPlainText().trimmed());
|
2012-04-21 16:22:28 -04:00
|
|
|
if (!layout.empty()) {
|
2011-05-08 00:54:17 +00:00
|
|
|
TextClass::ReturnValues const ret = TextClass::validate(layout);
|
2012-04-21 16:25:38 -04:00
|
|
|
validated_ = (ret == TextClass::OK) || (ret == TextClass::OK_OLDFORMAT);
|
2011-05-08 00:54:17 +00:00
|
|
|
validatePB->setEnabled(false);
|
2016-07-23 15:29:40 +01:00
|
|
|
validLB->setText(validated_ ? vpar.arg(qt_("Layout is valid!"))
|
|
|
|
: ivpar.arg(qt_("Layout is invalid!")));
|
2011-05-08 00:54:17 +00:00
|
|
|
if (ret == TextClass::OK_OLDFORMAT) {
|
|
|
|
convertPB->show();
|
2016-07-23 15:29:40 +01:00
|
|
|
// Testing conversion to LYXFILE_LAYOUT_FORMAT at this point
|
|
|
|
// already.
|
|
|
|
if (TextClass::convert(layout).empty()) {
|
|
|
|
// Conversion failed. If LAYOUT_FORMAT > LYXFILE_LAYOUT_FORMAT,
|
|
|
|
// then maybe the layout is still valid, but its format is more
|
|
|
|
// recent than LYXFILE_LAYOUT_FORMAT. However, if LAYOUT_FORMAT
|
|
|
|
// == LYXFILE_LAYOUT_FORMAT then something is definitely wrong.
|
|
|
|
convertPB->setEnabled(false);
|
|
|
|
const QString text = (LAYOUT_FORMAT == LYXFILE_LAYOUT_FORMAT)
|
|
|
|
? ivpar.arg(qt_("Conversion to current format impossible!"))
|
|
|
|
: vpar.arg(qt_("Conversion to current stable format "
|
|
|
|
"impossible."));
|
|
|
|
convertLB->setText(text);
|
|
|
|
} else {
|
|
|
|
convertPB->setEnabled(true);
|
|
|
|
convertLB->setText(qt_("Convert to current format"));
|
|
|
|
}
|
2011-05-08 00:54:17 +00:00
|
|
|
convertLB->show();
|
|
|
|
} else {
|
|
|
|
convertPB->hide();
|
|
|
|
convertLB->hide();
|
|
|
|
}
|
2010-09-03 13:33:05 +00:00
|
|
|
}
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void LocalLayout::validatePressed() {
|
|
|
|
validate();
|
|
|
|
changed();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-04-19 23:33:40 -04:00
|
|
|
void LocalLayout::editExternal() {
|
|
|
|
if (!current_id_)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (tempfile_) {
|
|
|
|
locallayoutTE->setReadOnly(false);
|
|
|
|
FileName const tempfilename = tempfile_->name();
|
|
|
|
docstring const s = tempfilename.fileContents("UTF-8");
|
|
|
|
locallayoutTE->document()->setPlainText(toqstr(s));
|
|
|
|
tempfile_.reset();
|
2019-03-22 22:14:21 +01:00
|
|
|
editPB->setText(qt_("&Edit"));
|
2018-04-19 23:33:40 -04:00
|
|
|
changed();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
string const format =
|
|
|
|
current_id_->params().documentClass().outputFormat();
|
|
|
|
string const ext = theFormats().extension(format);
|
2018-06-06 13:55:59 -04:00
|
|
|
tempfile_.reset(new TempFile("preamble_editXXXXXX." + ext));
|
2018-04-19 23:33:40 -04:00
|
|
|
FileName const tempfilename = tempfile_->name();
|
|
|
|
string const name = tempfilename.toFilesystemEncoding();
|
|
|
|
ofdocstream os(name.c_str());
|
|
|
|
os << qstring_to_ucs4(locallayoutTE->document()->toPlainText());
|
|
|
|
os.close();
|
|
|
|
locallayoutTE->setReadOnly(true);
|
|
|
|
theFormats().edit(*current_id_, tempfilename, format);
|
2019-03-22 22:14:21 +01:00
|
|
|
editPB->setText(qt_("&End Edit"));
|
2018-04-19 23:33:40 -04:00
|
|
|
validatePB->setEnabled(false);
|
|
|
|
hideConvert();
|
|
|
|
changed();
|
|
|
|
}
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// DocumentDialog
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
|
2007-09-03 05:59:32 +00:00
|
|
|
|
2007-11-23 09:44:02 +00:00
|
|
|
GuiDocument::GuiDocument(GuiView & lv)
|
2014-12-21 19:08:41 +01:00
|
|
|
: GuiDialog(lv, "document", qt_("Document Settings")),
|
2017-08-10 01:32:23 +02:00
|
|
|
biblioChanged_(false), nonModuleChanged_(false),
|
|
|
|
modulesChanged_(false), shellescapeChanged_(false)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
|
|
|
setupUi(this);
|
2008-03-08 07:59:47 +00:00
|
|
|
|
2018-07-09 09:46:39 +02:00
|
|
|
connect(buttonBox, SIGNAL(clicked(QAbstractButton *)),
|
|
|
|
this, SLOT(slotButtonBox(QAbstractButton *)));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(savePB, SIGNAL(clicked()), this, SLOT(saveDefaultClicked()));
|
|
|
|
connect(defaultPB, SIGNAL(clicked()), this, SLOT(useDefaultsClicked()));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// Manage the restore, ok, apply, restore and cancel/close buttons
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().setPolicy(ButtonPolicy::NoRepeatedApplyReadOnlyPolicy);
|
2018-07-09 09:46:39 +02:00
|
|
|
bc().setOK(buttonBox->button(QDialogButtonBox::Ok));
|
|
|
|
bc().setApply(buttonBox->button(QDialogButtonBox::Apply));
|
|
|
|
bc().setCancel(buttonBox->button(QDialogButtonBox::Cancel));
|
|
|
|
bc().setRestore(buttonBox->button(QDialogButtonBox::Reset));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// text layout
|
2017-02-26 22:15:49 +01:00
|
|
|
textLayoutModule = new UiWidget<Ui::TextLayoutUi>(this);
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(textLayoutModule->lspacingCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(textLayoutModule->lspacingCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(setLSpacing(int)));
|
2008-02-23 16:45:38 +00:00
|
|
|
connect(textLayoutModule->lspacingLE, SIGNAL(textChanged(const QString &)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2009-07-19 21:13:27 +00:00
|
|
|
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(textLayoutModule->indentRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-07-19 21:13:27 +00:00
|
|
|
connect(textLayoutModule->indentRB, SIGNAL(toggled(bool)),
|
|
|
|
textLayoutModule->indentCO, SLOT(setEnabled(bool)));
|
|
|
|
connect(textLayoutModule->indentCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(textLayoutModule->indentCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(setIndent(int)));
|
|
|
|
connect(textLayoutModule->indentLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(textLayoutModule->indentLengthCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
|
|
|
connect(textLayoutModule->skipRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(textLayoutModule->skipRB, SIGNAL(toggled(bool)),
|
|
|
|
textLayoutModule->skipCO, SLOT(setEnabled(bool)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(textLayoutModule->skipCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-07-19 21:13:27 +00:00
|
|
|
connect(textLayoutModule->skipCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(setSkip(int)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(textLayoutModule->skipLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(textLayoutModule->skipLengthCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-07-19 21:13:27 +00:00
|
|
|
|
|
|
|
connect(textLayoutModule->indentRB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(enableIndent(bool)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(textLayoutModule->skipRB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(enableSkip(bool)));
|
2009-07-19 21:13:27 +00:00
|
|
|
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(textLayoutModule->twoColumnCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-02-19 05:39:36 +00:00
|
|
|
connect(textLayoutModule->twoColumnCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(setColSep()));
|
2011-12-07 22:33:25 +00:00
|
|
|
connect(textLayoutModule->justCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-07-20 08:09:32 +00:00
|
|
|
|
2019-03-26 16:23:34 +01:00
|
|
|
connect(textLayoutModule->tableStyleCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->lspacingLE->setValidator(new QDoubleValidator(
|
|
|
|
textLayoutModule->lspacingLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
textLayoutModule->indentLE->setValidator(new LengthValidator(
|
2009-07-19 21:13:27 +00:00
|
|
|
textLayoutModule->indentLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
textLayoutModule->skipLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->skipLE));
|
|
|
|
|
2009-07-19 21:13:27 +00:00
|
|
|
textLayoutModule->indentCO->addItem(qt_("Default"));
|
|
|
|
textLayoutModule->indentCO->addItem(qt_("Custom"));
|
2020-06-28 17:20:18 +02:00
|
|
|
textLayoutModule->skipCO->addItem(qt_("Half line height"), VSpace::HALFLINE);
|
|
|
|
textLayoutModule->skipCO->addItem(qt_("Line height"), VSpace::FULLLINE);
|
|
|
|
textLayoutModule->skipCO->addItem(qt_("SmallSkip"), VSpace::SMALLSKIP);
|
|
|
|
textLayoutModule->skipCO->addItem(qt_("MedSkip"), VSpace::MEDSKIP);
|
|
|
|
textLayoutModule->skipCO->addItem(qt_("BigSkip"), VSpace::BIGSKIP);
|
|
|
|
textLayoutModule->skipCO->addItem(qt_("Custom"), VSpace::LENGTH);
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->lspacingCO->insertItem(
|
|
|
|
Spacing::Single, qt_("Single"));
|
|
|
|
textLayoutModule->lspacingCO->insertItem(
|
|
|
|
Spacing::Onehalf, qt_("OneHalf"));
|
|
|
|
textLayoutModule->lspacingCO->insertItem(
|
|
|
|
Spacing::Double, qt_("Double"));
|
|
|
|
textLayoutModule->lspacingCO->insertItem(
|
|
|
|
Spacing::Other, qt_("Custom"));
|
|
|
|
// initialize the length validator
|
2009-07-19 21:13:27 +00:00
|
|
|
bc().addCheckedLineEdit(textLayoutModule->indentLE);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(textLayoutModule->skipLE);
|
2019-06-05 11:16:25 +02:00
|
|
|
|
2019-03-26 16:23:34 +01:00
|
|
|
textLayoutModule->tableStyleCO->addItem(qt_("Default"), toqstr("default"));
|
|
|
|
getTableStyles();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2010-01-07 10:01:26 +00:00
|
|
|
// master/child handling
|
2017-02-26 22:15:49 +01:00
|
|
|
masterChildModule = new UiWidget<Ui::MasterChildUi>(this);
|
2010-01-07 10:01:26 +00:00
|
|
|
|
|
|
|
connect(masterChildModule->childrenTW, SIGNAL(itemDoubleClicked(QTreeWidgetItem *, int)),
|
|
|
|
this, SLOT(includeonlyClicked(QTreeWidgetItem *, int)));
|
|
|
|
connect(masterChildModule->includeonlyRB, SIGNAL(toggled(bool)),
|
|
|
|
masterChildModule->childrenTW, SLOT(setEnabled(bool)));
|
2010-01-10 13:25:41 +00:00
|
|
|
connect(masterChildModule->includeonlyRB, SIGNAL(toggled(bool)),
|
2020-03-13 15:46:35 +01:00
|
|
|
masterChildModule->maintainGB, SLOT(setEnabled(bool)));
|
2010-01-07 10:01:26 +00:00
|
|
|
connect(masterChildModule->includeallRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(masterChildModule->includeonlyRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2020-03-13 15:46:35 +01:00
|
|
|
connect(masterChildModule->maintainCRNoneRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(masterChildModule->maintainCRMostlyRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(masterChildModule->maintainCRStrictRB, SIGNAL(clicked()),
|
2010-01-10 13:25:41 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2010-01-07 10:01:26 +00:00
|
|
|
masterChildModule->childrenTW->setColumnCount(2);
|
|
|
|
masterChildModule->childrenTW->headerItem()->setText(0, qt_("Child Document"));
|
|
|
|
masterChildModule->childrenTW->headerItem()->setText(1, qt_("Include to Output"));
|
2020-02-07 17:23:14 +01:00
|
|
|
#if (QT_VERSION > 0x050000)
|
|
|
|
masterChildModule->childrenTW->header()->setSectionResizeMode(0, QHeaderView::ResizeToContents);
|
|
|
|
masterChildModule->childrenTW->header()->setSectionResizeMode(1, QHeaderView::ResizeToContents);
|
|
|
|
#else
|
|
|
|
masterChildModule->childrenTW->header()->setResizeMode(0, QHeaderView::ResizeToContents);
|
|
|
|
masterChildModule->childrenTW->header()->setResizeMode(1, QHeaderView::ResizeToContents);
|
|
|
|
#endif
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2016-08-28 16:51:15 +01:00
|
|
|
// Formats
|
2017-02-26 22:15:49 +01:00
|
|
|
outputModule = new UiWidget<Ui::OutputUi>(this);
|
2009-04-10 11:06:53 +00:00
|
|
|
|
|
|
|
connect(outputModule->defaultFormatCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2010-04-21 15:20:31 +00:00
|
|
|
connect(outputModule->mathimgSB, SIGNAL(valueChanged(double)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(outputModule->strictCB, SIGNAL(stateChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2011-12-06 22:17:26 +00:00
|
|
|
connect(outputModule->cssCB, SIGNAL(stateChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2010-04-21 15:20:31 +00:00
|
|
|
connect(outputModule->mathoutCB, SIGNAL(currentIndexChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2020-07-13 03:31:48 +02:00
|
|
|
connect(outputModule->tableoutCB, SIGNAL(currentIndexChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-04-10 11:06:53 +00:00
|
|
|
|
2017-08-03 13:07:41 +02:00
|
|
|
connect(outputModule->shellescapeCB, SIGNAL(stateChanged(int)),
|
|
|
|
this, SLOT(shellescapeChanged()));
|
2020-01-10 10:21:09 +01:00
|
|
|
connect(outputModule->outputsyncCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(setOutputSync(bool)));
|
2010-05-25 11:53:58 +00:00
|
|
|
connect(outputModule->synccustomCB, SIGNAL(editTextChanged(QString)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
outputModule->synccustomCB->addItem("");
|
|
|
|
outputModule->synccustomCB->addItem("\\synctex=1");
|
|
|
|
outputModule->synccustomCB->addItem("\\synctex=-1");
|
|
|
|
outputModule->synccustomCB->addItem("\\usepackage[active]{srcltx}");
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2011-09-24 16:39:23 +00:00
|
|
|
outputModule->synccustomCB->setValidator(new NoNewLineValidator(
|
|
|
|
outputModule->synccustomCB));
|
|
|
|
|
2016-07-08 16:36:05 +01:00
|
|
|
connect(outputModule->saveTransientPropertiesCB, SIGNAL(clicked()),
|
2020-01-10 10:21:09 +01:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(outputModule->postponeFragileCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2016-07-08 16:36:05 +01:00
|
|
|
|
2018-04-22 19:06:46 +02:00
|
|
|
|
|
|
|
// language & quote
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
// this must precede font, since fonts depend on this
|
2018-04-22 19:06:46 +02:00
|
|
|
langModule = new UiWidget<Ui::LanguageUi>(this);
|
|
|
|
connect(langModule->languageCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(langModule->languageCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(languageChanged(int)));
|
2019-06-12 11:48:47 +02:00
|
|
|
connect(langModule->encodingCO, SIGNAL(activated(int)),
|
2018-04-22 19:06:46 +02:00
|
|
|
this, SLOT(change_adaptor()));
|
2019-06-12 11:48:47 +02:00
|
|
|
connect(langModule->encodingCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(encodingSwitched(int)));
|
|
|
|
connect(langModule->unicodeEncodingCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2019-06-18 15:42:18 +02:00
|
|
|
connect(langModule->autoEncodingCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2019-06-05 11:16:25 +02:00
|
|
|
connect(langModule->customEncodingCO, SIGNAL(activated(int)),
|
2019-05-12 09:10:24 +02:00
|
|
|
this, SLOT(change_adaptor()));
|
2018-04-22 19:06:46 +02:00
|
|
|
connect(langModule->quoteStyleCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(langModule->languagePackageCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(langModule->languagePackageLE, SIGNAL(textChanged(QString)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(langModule->languagePackageCO, SIGNAL(currentIndexChanged(int)),
|
|
|
|
this, SLOT(languagePackageChanged(int)));
|
|
|
|
connect(langModule->dynamicQuotesCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
|
|
|
langModule->languagePackageLE->setValidator(new NoNewLineValidator(
|
|
|
|
langModule->languagePackageLE));
|
|
|
|
|
|
|
|
QAbstractItemModel * language_model = guiApp->languageModel();
|
|
|
|
// FIXME: it would be nice if sorting was enabled/disabled via a checkbox.
|
|
|
|
language_model->sort(0);
|
|
|
|
langModule->languageCO->setModel(language_model);
|
|
|
|
langModule->languageCO->setModelColumn(0);
|
|
|
|
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->encodingCO->addItem(qt_("Unicode (utf8)"));
|
2019-06-21 09:54:45 +02:00
|
|
|
langModule->encodingCO->addItem(qt_("Traditional (auto-selected)"));
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->encodingCO->addItem(qt_("Custom"));
|
|
|
|
langModule->encodingCO->setItemData(EncodingSets::unicode,
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Select Unicode (utf8) encoding."), Qt::ToolTipRole);
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->encodingCO->setItemData(EncodingSets::legacy,
|
2019-06-26 11:14:20 +02:00
|
|
|
qt_("Use language-dependent traditional encodings."), Qt::ToolTipRole);
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->encodingCO->setItemData(EncodingSets::custom,
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Select a custom, document-wide encoding."), Qt::ToolTipRole);
|
2019-06-18 15:42:18 +02:00
|
|
|
|
2019-06-19 21:07:00 +02:00
|
|
|
// basic Unicode encodings: keep order
|
|
|
|
const QStringList utf8_base_encodings = {"utf8", "utf8-plain", "utf8x"};
|
2019-06-26 08:57:05 +02:00
|
|
|
for (auto const & i : utf8_base_encodings) {
|
|
|
|
langModule->unicodeEncodingCO->addItem(
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_(encodings.fromLyXName(fromqstr(i))->guiName()), i);
|
2019-06-05 11:16:25 +02:00
|
|
|
}
|
2019-06-19 21:07:00 +02:00
|
|
|
langModule->unicodeEncodingCO->setItemData(0,
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Standard Unicode support by the ``inputenc'' package."),
|
2019-06-19 21:07:00 +02:00
|
|
|
Qt::ToolTipRole);
|
|
|
|
langModule->unicodeEncodingCO->setItemData(1,
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Use UTF-8 'as-is': do not load any supporting packages, "
|
|
|
|
"do not convert any characters to LaTeX macros. "
|
|
|
|
"For use with non-TeX fonts (XeTeX/LuaTeX) or custom preamble code."),
|
2019-06-19 21:07:00 +02:00
|
|
|
Qt::ToolTipRole);
|
|
|
|
langModule->unicodeEncodingCO->setItemData(2,
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Load ``inputenc'' with option 'utf8x' "
|
|
|
|
"for extended Unicode support by the ``ucs'' package."),
|
2019-06-19 21:07:00 +02:00
|
|
|
Qt::ToolTipRole);
|
2019-06-26 11:04:56 +02:00
|
|
|
langModule->autoEncodingCO->addItem(qt_("Language Default"), toqstr("auto-legacy"));
|
|
|
|
langModule->autoEncodingCO->addItem(qt_("Language Default (no inputenc)"), toqstr("auto-legacy-plain"));
|
2019-06-18 15:42:18 +02:00
|
|
|
langModule->autoEncodingCO->setItemData(0,
|
2019-06-26 11:14:20 +02:00
|
|
|
qt_("Use the traditional default encoding of the text language. Switch encoding "
|
2019-06-26 11:04:56 +02:00
|
|
|
"if a text part is set to a language with different default."),
|
2019-06-18 15:42:18 +02:00
|
|
|
Qt::ToolTipRole);
|
|
|
|
langModule->autoEncodingCO->setItemData(1,
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Do not load the 'inputenc' package. Switch encoding if required "
|
|
|
|
"but do not write input encoding switch commands to the source."),
|
2019-06-18 15:42:18 +02:00
|
|
|
Qt::ToolTipRole);
|
2019-06-19 21:07:00 +02:00
|
|
|
// sort encodings
|
2019-05-11 11:28:21 +02:00
|
|
|
QMap<QString,QString> encodingmap;
|
2019-06-19 21:07:00 +02:00
|
|
|
QMap<QString,QString> encodingmap_utf8;
|
2018-04-22 19:06:46 +02:00
|
|
|
for (auto const & encvar : encodings) {
|
2019-06-19 21:07:00 +02:00
|
|
|
if (encvar.unsafe() ||encvar.guiName().empty()
|
|
|
|
|| utf8_base_encodings.contains(toqstr(encvar.name())))
|
|
|
|
continue;
|
|
|
|
if (std::string(encvar.name()).find("utf8") == 0)
|
2019-06-26 12:25:53 +02:00
|
|
|
encodingmap_utf8.insert(qt_(encvar.guiName()), toqstr(encvar.name()));
|
2019-06-26 08:57:05 +02:00
|
|
|
else
|
2019-06-26 12:25:53 +02:00
|
|
|
encodingmap.insert(qt_(encvar.guiName()), toqstr(encvar.name()));
|
2019-05-11 11:28:21 +02:00
|
|
|
}
|
2019-06-19 21:07:00 +02:00
|
|
|
for (auto const & i : encodingmap_utf8.keys()) {
|
|
|
|
langModule->unicodeEncodingCO->addItem(i, encodingmap_utf8.value(i));
|
|
|
|
}
|
|
|
|
for (auto const & i : encodingmap.keys()) {
|
|
|
|
langModule->customEncodingCO->addItem(i, encodingmap.value(i));
|
2018-04-22 19:06:46 +02:00
|
|
|
}
|
2019-06-12 11:48:47 +02:00
|
|
|
// equalise the width of encoding selectors
|
2019-06-18 15:42:18 +02:00
|
|
|
langModule->autoEncodingCO->setMinimumSize(
|
|
|
|
langModule->unicodeEncodingCO->minimumSizeHint());
|
|
|
|
langModule->customEncodingCO->setMinimumSize(
|
|
|
|
langModule->unicodeEncodingCO->minimumSizeHint());
|
2018-04-22 19:06:46 +02:00
|
|
|
|
|
|
|
langModule->languagePackageCO->addItem(
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Default"), toqstr("default"));
|
2018-04-22 19:06:46 +02:00
|
|
|
langModule->languagePackageCO->addItem(
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Automatic"), toqstr("auto"));
|
2018-04-22 19:06:46 +02:00
|
|
|
langModule->languagePackageCO->addItem(
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Always Babel"), toqstr("babel"));
|
2018-04-22 19:06:46 +02:00
|
|
|
langModule->languagePackageCO->addItem(
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("Custom"), toqstr("custom"));
|
2018-04-22 19:06:46 +02:00
|
|
|
langModule->languagePackageCO->addItem(
|
2019-06-26 11:04:56 +02:00
|
|
|
qt_("None[[language package]]"), toqstr("none"));
|
2018-04-22 19:06:46 +02:00
|
|
|
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// fonts
|
2017-02-26 22:15:49 +01:00
|
|
|
fontModule = new FontModule(this);
|
2010-11-26 09:42:03 +00:00
|
|
|
connect(fontModule->osFontsCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->osFontsCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(osFontsChanged(bool)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(fontModule->fontsRomanCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontsRomanCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(romanChanged(int)));
|
|
|
|
connect(fontModule->fontsSansCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontsSansCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(sansChanged(int)));
|
|
|
|
connect(fontModule->fontsTypewriterCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontsTypewriterCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(ttChanged(int)));
|
2012-09-22 17:44:00 +02:00
|
|
|
connect(fontModule->fontsMathCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontsMathCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(mathFontChanged(int)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(fontModule->fontsDefaultCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-11-29 14:43:00 +00:00
|
|
|
connect(fontModule->fontencCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontencCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(fontencChanged(int)));
|
|
|
|
connect(fontModule->fontencLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(fontModule->fontsizeCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-06-05 06:18:34 +00:00
|
|
|
connect(fontModule->cjkFontLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2016-06-02 22:40:21 -07:00
|
|
|
connect(fontModule->microtypeCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2017-03-19 20:50:34 +01:00
|
|
|
connect(fontModule->dashesCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(fontModule->scaleSansSB, SIGNAL(valueChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->scaleTypewriterSB, SIGNAL(valueChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontScCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2013-02-11 15:02:24 +01:00
|
|
|
connect(fontModule->fontScCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(fontScToggled(bool)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(fontModule->fontOsfCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2013-02-11 15:02:24 +01:00
|
|
|
connect(fontModule->fontOsfCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(fontOsfToggled(bool)));
|
2019-07-14 11:41:36 +02:00
|
|
|
connect(fontModule->fontSansOsfCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontTypewriterOsfCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2019-07-11 20:28:34 +02:00
|
|
|
connect(fontModule->fontspecRomanLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontspecSansLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(fontModule->fontspecTypewriterLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2011-09-24 16:39:23 +00:00
|
|
|
fontModule->fontencLE->setValidator(new NoNewLineValidator(
|
|
|
|
fontModule->fontencLE));
|
|
|
|
fontModule->cjkFontLE->setValidator(new NoNewLineValidator(
|
|
|
|
fontModule->cjkFontLE));
|
2019-07-11 20:28:34 +02:00
|
|
|
fontModule->fontspecRomanLE->setValidator(new NoNewLineValidator(
|
|
|
|
fontModule->fontspecRomanLE));
|
|
|
|
fontModule->fontspecSansLE->setValidator(new NoNewLineValidator(
|
|
|
|
fontModule->fontspecSansLE));
|
|
|
|
fontModule->fontspecTypewriterLE->setValidator(new NoNewLineValidator(
|
|
|
|
fontModule->fontspecTypewriterLE));
|
2011-09-24 16:39:23 +00:00
|
|
|
|
2009-04-06 06:58:30 +00:00
|
|
|
updateFontlist();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2007-06-01 17:44:04 +00:00
|
|
|
fontModule->fontsizeCO->addItem(qt_("Default"));
|
2007-04-24 19:37:34 +00:00
|
|
|
fontModule->fontsizeCO->addItem(qt_("10"));
|
|
|
|
fontModule->fontsizeCO->addItem(qt_("11"));
|
|
|
|
fontModule->fontsizeCO->addItem(qt_("12"));
|
|
|
|
|
2020-08-23 23:50:11 +03:00
|
|
|
fontModule->fontencCO->addItem(qt_("Automatic[[encoding]]"), QString("auto"));
|
2018-05-11 12:57:28 +02:00
|
|
|
fontModule->fontencCO->addItem(qt_("Class Default"), QString("default"));
|
2012-08-16 13:23:39 +02:00
|
|
|
fontModule->fontencCO->addItem(qt_("Custom"), QString("custom"));
|
2009-11-29 14:43:00 +00:00
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
for (int n = 0; GuiDocument::fontfamilies_gui[n][0]; ++n)
|
2007-04-24 19:37:34 +00:00
|
|
|
fontModule->fontsDefaultCO->addItem(
|
2007-10-06 22:43:21 +00:00
|
|
|
qt_(GuiDocument::fontfamilies_gui[n]));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2011-02-09 08:23:11 +00:00
|
|
|
if (!LaTeXFeatures::isAvailable("fontspec"))
|
|
|
|
fontModule->osFontsCB->setToolTip(
|
2011-02-09 08:31:18 +00:00
|
|
|
qt_("Use OpenType and TrueType fonts directly (requires XeTeX or LuaTeX)\n"
|
2011-02-09 08:23:11 +00:00
|
|
|
"You need to install the package \"fontspec\" to use this feature"));
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// page layout
|
2017-02-26 22:15:49 +01:00
|
|
|
pageLayoutModule = new UiWidget<Ui::PageLayoutUi>(this);
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(pageLayoutModule->papersizeCO, SIGNAL(activated(int)),
|
2009-07-16 08:39:22 +00:00
|
|
|
this, SLOT(papersizeChanged(int)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(pageLayoutModule->papersizeCO, SIGNAL(activated(int)),
|
2009-07-16 08:39:22 +00:00
|
|
|
this, SLOT(papersizeChanged(int)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(pageLayoutModule->portraitRB, SIGNAL(clicked()),
|
2010-05-18 02:56:36 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(pageLayoutModule->papersizeCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->paperheightLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->paperwidthLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->paperwidthUnitCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->paperheightUnitCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->portraitRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->landscapeRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->facingPagesCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pageLayoutModule->pagestyleCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2007-06-01 17:44:04 +00:00
|
|
|
pageLayoutModule->pagestyleCO->addItem(qt_("Default"));
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->pagestyleCO->addItem(qt_("empty"));
|
|
|
|
pageLayoutModule->pagestyleCO->addItem(qt_("plain"));
|
|
|
|
pageLayoutModule->pagestyleCO->addItem(qt_("headings"));
|
|
|
|
pageLayoutModule->pagestyleCO->addItem(qt_("fancy"));
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(pageLayoutModule->paperheightLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->paperheightL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(pageLayoutModule->paperwidthLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->paperwidthL);
|
|
|
|
|
|
|
|
QComboBox * cb = pageLayoutModule->papersizeCO;
|
|
|
|
cb->addItem(qt_("Default"));
|
|
|
|
cb->addItem(qt_("Custom"));
|
|
|
|
cb->addItem(qt_("US letter"));
|
|
|
|
cb->addItem(qt_("US legal"));
|
|
|
|
cb->addItem(qt_("US executive"));
|
2010-05-18 01:22:08 +00:00
|
|
|
cb->addItem(qt_("A0"));
|
|
|
|
cb->addItem(qt_("A1"));
|
|
|
|
cb->addItem(qt_("A2"));
|
2007-04-24 19:37:34 +00:00
|
|
|
cb->addItem(qt_("A3"));
|
|
|
|
cb->addItem(qt_("A4"));
|
|
|
|
cb->addItem(qt_("A5"));
|
2010-05-18 01:22:08 +00:00
|
|
|
cb->addItem(qt_("A6"));
|
|
|
|
cb->addItem(qt_("B0"));
|
|
|
|
cb->addItem(qt_("B1"));
|
|
|
|
cb->addItem(qt_("B2"));
|
2007-04-24 19:37:34 +00:00
|
|
|
cb->addItem(qt_("B3"));
|
|
|
|
cb->addItem(qt_("B4"));
|
|
|
|
cb->addItem(qt_("B5"));
|
2010-05-18 01:22:08 +00:00
|
|
|
cb->addItem(qt_("B6"));
|
2010-07-13 01:06:20 +00:00
|
|
|
cb->addItem(qt_("C0"));
|
|
|
|
cb->addItem(qt_("C1"));
|
|
|
|
cb->addItem(qt_("C2"));
|
|
|
|
cb->addItem(qt_("C3"));
|
|
|
|
cb->addItem(qt_("C4"));
|
|
|
|
cb->addItem(qt_("C5"));
|
|
|
|
cb->addItem(qt_("C6"));
|
2010-05-18 01:22:08 +00:00
|
|
|
cb->addItem(qt_("JIS B0"));
|
|
|
|
cb->addItem(qt_("JIS B1"));
|
|
|
|
cb->addItem(qt_("JIS B2"));
|
|
|
|
cb->addItem(qt_("JIS B3"));
|
|
|
|
cb->addItem(qt_("JIS B4"));
|
|
|
|
cb->addItem(qt_("JIS B5"));
|
|
|
|
cb->addItem(qt_("JIS B6"));
|
2007-04-24 19:37:34 +00:00
|
|
|
// remove the %-items from the unit choice
|
|
|
|
pageLayoutModule->paperwidthUnitCO->noPercents();
|
|
|
|
pageLayoutModule->paperheightUnitCO->noPercents();
|
|
|
|
pageLayoutModule->paperheightLE->setValidator(unsignedLengthValidator(
|
|
|
|
pageLayoutModule->paperheightLE));
|
|
|
|
pageLayoutModule->paperwidthLE->setValidator(unsignedLengthValidator(
|
|
|
|
pageLayoutModule->paperwidthLE));
|
|
|
|
|
|
|
|
|
|
|
|
// margins
|
2017-02-26 22:15:49 +01:00
|
|
|
marginsModule = new UiWidget<Ui::MarginsUi>(this);
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(marginsModule->marginCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(setCustomMargins(bool)));
|
|
|
|
connect(marginsModule->marginCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->topLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->topUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->bottomLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->bottomUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->innerLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->innerUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->outerLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->outerUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->headheightLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->headheightUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->headsepLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->headsepUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->footskipLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->footskipUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(marginsModule->columnsepLE, SIGNAL(textChanged(QString)),
|
2008-02-19 05:24:48 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(marginsModule->columnsepUnit, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->topLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->topLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->bottomLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->bottomLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->innerLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->innerLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->outerLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->outerLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->headsepLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->headsepLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->headheightLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->headheightLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->footskipLE->setValidator(new LengthValidator(
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->footskipLE));
|
2016-05-03 20:34:17 -04:00
|
|
|
marginsModule->columnsepLE->setValidator(new LengthValidator(
|
2008-02-19 05:24:48 +00:00
|
|
|
marginsModule->columnsepLE));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->topLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->topL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->bottomLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->bottomL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->innerLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->innerL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->outerLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->outerL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->headsepLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->headsepL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->headheightLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->headheightL);
|
2007-09-05 20:33:29 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->footskipLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
marginsModule->footskipL);
|
2008-02-19 05:24:48 +00:00
|
|
|
bc().addCheckedLineEdit(marginsModule->columnsepLE,
|
|
|
|
marginsModule->columnsepL);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
// color
|
2017-02-26 22:15:49 +01:00
|
|
|
colorModule = new UiWidget<Ui::ColorUi>(this);
|
2010-04-02 23:39:36 +00:00
|
|
|
connect(colorModule->fontColorPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(changeFontColor()));
|
|
|
|
connect(colorModule->delFontColorTB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(deleteFontColor()));
|
2010-04-02 22:11:50 +00:00
|
|
|
connect(colorModule->noteFontColorPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(changeNoteFontColor()));
|
|
|
|
connect(colorModule->delNoteFontColorTB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(deleteNoteFontColor()));
|
|
|
|
connect(colorModule->backgroundPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(changeBackgroundColor()));
|
2010-04-05 20:31:10 +00:00
|
|
|
connect(colorModule->delBackgroundTB, SIGNAL(clicked()),
|
2010-04-02 22:11:50 +00:00
|
|
|
this, SLOT(deleteBackgroundColor()));
|
2010-04-08 00:14:08 +00:00
|
|
|
connect(colorModule->boxBackgroundPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(changeBoxBackgroundColor()));
|
|
|
|
connect(colorModule->delBoxBackgroundTB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(deleteBoxBackgroundColor()));
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2019-12-24 18:12:22 +01:00
|
|
|
// change tracking
|
|
|
|
changesModule = new UiWidget<Ui::ChangeTrackingUi>(this);
|
|
|
|
connect(changesModule->trackChangesCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2019-12-24 18:43:22 +01:00
|
|
|
connect(changesModule->outputChangesCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(outputChangesToggled(bool)));
|
2019-12-24 18:12:22 +01:00
|
|
|
connect(changesModule->changeBarsCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// numbering
|
2017-02-26 22:15:49 +01:00
|
|
|
numberingModule = new UiWidget<Ui::NumberingUi>(this);
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(numberingModule->depthSL, SIGNAL(valueChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(numberingModule->tocSL, SIGNAL(valueChanged(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(numberingModule->depthSL, SIGNAL(valueChanged(int)),
|
|
|
|
this, SLOT(updateNumbering()));
|
|
|
|
connect(numberingModule->tocSL, SIGNAL(valueChanged(int)),
|
|
|
|
this, SLOT(updateNumbering()));
|
2007-04-24 19:37:34 +00:00
|
|
|
numberingModule->tocTW->setColumnCount(3);
|
|
|
|
numberingModule->tocTW->headerItem()->setText(0, qt_("Example"));
|
|
|
|
numberingModule->tocTW->headerItem()->setText(1, qt_("Numbered"));
|
|
|
|
numberingModule->tocTW->headerItem()->setText(2, qt_("Appears in TOC"));
|
2013-02-03 12:23:31 +01:00
|
|
|
setSectionResizeMode(numberingModule->tocTW->header(), QHeaderView::ResizeToContents);
|
2019-05-24 15:40:09 +02:00
|
|
|
connect(numberingModule->linenoCB, SIGNAL(toggled(bool)),
|
2019-05-24 17:51:42 +02:00
|
|
|
this, SLOT(linenoToggled(bool)));
|
2019-05-24 15:40:09 +02:00
|
|
|
connect(numberingModule->linenoCB, SIGNAL(clicked()),
|
2019-05-23 15:13:27 +02:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(numberingModule->linenoLE, SIGNAL(textChanged(QString)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
// biblio
|
2017-02-26 22:15:49 +01:00
|
|
|
biblioModule = new UiWidget<Ui::BiblioUi>(this);
|
2016-12-31 09:28:51 +01:00
|
|
|
connect(biblioModule->citeEngineCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(citeEngineChanged(int)));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(biblioModule->citeStyleCO, SIGNAL(activated(int)),
|
2016-12-31 14:57:09 +01:00
|
|
|
this, SLOT(citeStyleChanged()));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(biblioModule->bibtopicCB, SIGNAL(clicked()),
|
2011-12-12 16:04:00 +00:00
|
|
|
this, SLOT(biblioChanged()));
|
2017-02-04 12:02:00 +01:00
|
|
|
connect(biblioModule->bibunitsCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(biblioChanged()));
|
2009-05-22 07:20:00 +00:00
|
|
|
connect(biblioModule->bibtexCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(bibtexChanged(int)));
|
2011-09-24 16:39:20 +00:00
|
|
|
connect(biblioModule->bibtexOptionsLE, SIGNAL(textChanged(QString)),
|
2011-12-12 16:04:00 +00:00
|
|
|
this, SLOT(biblioChanged()));
|
2017-01-08 09:39:46 +01:00
|
|
|
connect(biblioModule->citePackageOptionsLE, SIGNAL(textChanged(QString)),
|
|
|
|
this, SLOT(biblioChanged()));
|
2016-12-31 14:57:09 +01:00
|
|
|
connect(biblioModule->defaultBiblioCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(biblioChanged()));
|
|
|
|
connect(biblioModule->defaultBiblioCO, SIGNAL(editTextChanged(QString)),
|
2011-12-12 16:04:00 +00:00
|
|
|
this, SLOT(biblioChanged()));
|
2016-12-31 14:57:09 +01:00
|
|
|
connect(biblioModule->defaultBiblioCO, SIGNAL(editTextChanged(QString)),
|
|
|
|
this, SLOT(updateResetDefaultBiblio()));
|
2017-01-08 09:39:46 +01:00
|
|
|
connect(biblioModule->biblatexBbxCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(biblioChanged()));
|
2018-02-06 12:45:22 +01:00
|
|
|
connect(biblioModule->biblatexBbxCO, SIGNAL(editTextChanged(QString)),
|
|
|
|
this, SLOT(biblioChanged()));
|
2017-01-08 09:39:46 +01:00
|
|
|
connect(biblioModule->biblatexBbxCO, SIGNAL(editTextChanged(QString)),
|
|
|
|
this, SLOT(updateResetDefaultBiblio()));
|
|
|
|
connect(biblioModule->biblatexCbxCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(biblioChanged()));
|
2018-02-06 12:45:22 +01:00
|
|
|
connect(biblioModule->biblatexCbxCO, SIGNAL(editTextChanged(QString)),
|
|
|
|
this, SLOT(biblioChanged()));
|
2017-01-08 09:39:46 +01:00
|
|
|
connect(biblioModule->biblatexCbxCO, SIGNAL(editTextChanged(QString)),
|
|
|
|
this, SLOT(updateResetDefaultBiblio()));
|
2016-12-31 14:57:09 +01:00
|
|
|
connect(biblioModule->rescanBibliosPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(rescanBibFiles()));
|
|
|
|
connect(biblioModule->resetDefaultBiblioPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(resetDefaultBibfile()));
|
2017-01-08 09:39:46 +01:00
|
|
|
connect(biblioModule->resetCbxPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(resetDefaultCbxBibfile()));
|
|
|
|
connect(biblioModule->resetBbxPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(resetDefaultBbxBibfile()));
|
|
|
|
connect(biblioModule->matchBbxPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(matchBiblatexStyles()));
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2016-12-31 09:28:51 +01:00
|
|
|
biblioModule->citeEngineCO->clear();
|
|
|
|
for (LyXCiteEngine const & cet : theCiteEnginesList) {
|
|
|
|
biblioModule->citeEngineCO->addItem(qt_(cet.getName()), toqstr(cet.getID()));
|
|
|
|
int const i = biblioModule->citeEngineCO->findData(toqstr(cet.getID()));
|
|
|
|
biblioModule->citeEngineCO->setItemData(i, qt_(cet.getDescription()),
|
|
|
|
Qt::ToolTipRole);
|
|
|
|
}
|
|
|
|
|
2011-09-24 16:39:23 +00:00
|
|
|
biblioModule->bibtexOptionsLE->setValidator(new NoNewLineValidator(
|
|
|
|
biblioModule->bibtexOptionsLE));
|
2016-12-31 14:57:09 +01:00
|
|
|
biblioModule->defaultBiblioCO->lineEdit()->setValidator(new NoNewLineValidator(
|
|
|
|
biblioModule->defaultBiblioCO->lineEdit()));
|
2017-09-10 10:05:10 +02:00
|
|
|
biblioModule->citePackageOptionsLE->setValidator(new NoNewLineValidator(
|
|
|
|
biblioModule->citePackageOptionsLE));
|
2011-09-24 16:39:23 +00:00
|
|
|
|
2011-02-04 07:37:12 +00:00
|
|
|
// NOTE: we do not provide "custom" here for security reasons!
|
2009-05-22 07:20:00 +00:00
|
|
|
biblioModule->bibtexCO->clear();
|
|
|
|
biblioModule->bibtexCO->addItem(qt_("Default"), QString("default"));
|
2017-12-16 09:55:25 -05:00
|
|
|
for (auto const & alts : lyxrc.bibtex_alternatives) {
|
|
|
|
QString const command = toqstr(alts).left(toqstr(alts).indexOf(" "));
|
2009-05-22 07:20:00 +00:00
|
|
|
biblioModule->bibtexCO->addItem(command, command);
|
|
|
|
}
|
2011-02-03 15:03:38 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-04-16 07:29:01 +00:00
|
|
|
// indices
|
|
|
|
indicesModule = new GuiIndices;
|
|
|
|
connect(indicesModule, SIGNAL(changed()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
// maths
|
2017-02-26 22:15:49 +01:00
|
|
|
mathsModule = new UiWidget<Ui::MathsUi>(this);
|
2013-03-01 15:59:37 +01:00
|
|
|
QStringList headers;
|
|
|
|
headers << qt_("Package") << qt_("Load automatically")
|
|
|
|
<< qt_("Load always") << qt_("Do not load");
|
|
|
|
mathsModule->packagesTW->setHorizontalHeaderLabels(headers);
|
2018-03-18 12:11:26 +01:00
|
|
|
setSectionResizeMode(mathsModule->packagesTW->horizontalHeader(), QHeaderView::Stretch);
|
2013-03-01 15:59:37 +01:00
|
|
|
map<string, string> const & packages = BufferParams::auto_packages();
|
|
|
|
mathsModule->packagesTW->setRowCount(packages.size());
|
2017-12-16 09:55:25 -05:00
|
|
|
int packnum = 0;
|
|
|
|
for (auto const & pkgvar : packages) {
|
|
|
|
docstring const package = from_ascii(pkgvar.first);
|
|
|
|
QString autoTooltip = qt_(pkgvar.second);
|
2012-01-03 20:51:07 +00:00
|
|
|
QString alwaysTooltip;
|
2013-03-01 15:59:37 +01:00
|
|
|
if (package == "amsmath")
|
2012-01-03 20:51:07 +00:00
|
|
|
alwaysTooltip =
|
|
|
|
qt_("The AMS LaTeX packages are always used");
|
|
|
|
else
|
|
|
|
alwaysTooltip = toqstr(bformat(
|
|
|
|
_("The LaTeX package %1$s is always used"),
|
2013-03-01 15:59:37 +01:00
|
|
|
package));
|
|
|
|
QString neverTooltip;
|
|
|
|
if (package == "amsmath")
|
|
|
|
neverTooltip =
|
|
|
|
qt_("The AMS LaTeX packages are never used");
|
|
|
|
else
|
|
|
|
neverTooltip = toqstr(bformat(
|
|
|
|
_("The LaTeX package %1$s is never used"),
|
|
|
|
package));
|
|
|
|
QRadioButton * autoRB = new QRadioButton(mathsModule);
|
|
|
|
QRadioButton * alwaysRB = new QRadioButton(mathsModule);
|
|
|
|
QRadioButton * neverRB = new QRadioButton(mathsModule);
|
|
|
|
QButtonGroup * packageGroup = new QButtonGroup(mathsModule);
|
|
|
|
packageGroup->addButton(autoRB);
|
|
|
|
packageGroup->addButton(alwaysRB);
|
|
|
|
packageGroup->addButton(neverRB);
|
|
|
|
autoRB->setToolTip(autoTooltip);
|
|
|
|
alwaysRB->setToolTip(alwaysTooltip);
|
|
|
|
neverRB->setToolTip(neverTooltip);
|
2018-03-18 12:11:26 +01:00
|
|
|
|
|
|
|
// Pack the buttons in a layout in order to get proper alignment
|
|
|
|
QWidget * autoRBWidget = new QWidget();
|
|
|
|
QHBoxLayout * autoRBLayout = new QHBoxLayout(autoRBWidget);
|
|
|
|
autoRBLayout->addWidget(autoRB);
|
|
|
|
autoRBLayout->setAlignment(Qt::AlignCenter);
|
|
|
|
autoRBLayout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
autoRBWidget->setLayout(autoRBLayout);
|
|
|
|
|
|
|
|
QWidget * alwaysRBWidget = new QWidget();
|
|
|
|
QHBoxLayout * alwaysRBLayout = new QHBoxLayout(alwaysRBWidget);
|
|
|
|
alwaysRBLayout->addWidget(alwaysRB);
|
|
|
|
alwaysRBLayout->setAlignment(Qt::AlignCenter);
|
|
|
|
alwaysRBLayout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
alwaysRBWidget->setLayout(alwaysRBLayout);
|
|
|
|
|
|
|
|
QWidget * neverRBWidget = new QWidget();
|
|
|
|
QHBoxLayout * neverRBLayout = new QHBoxLayout(neverRBWidget);
|
|
|
|
neverRBLayout->addWidget(neverRB);
|
|
|
|
neverRBLayout->setAlignment(Qt::AlignCenter);
|
|
|
|
neverRBLayout->setContentsMargins(0, 0, 0, 0);
|
|
|
|
neverRBWidget->setLayout(neverRBLayout);
|
|
|
|
|
2013-03-01 15:59:37 +01:00
|
|
|
QTableWidgetItem * pack = new QTableWidgetItem(toqstr(package));
|
2017-12-16 09:55:25 -05:00
|
|
|
mathsModule->packagesTW->setItem(packnum, 0, pack);
|
2018-03-18 12:11:26 +01:00
|
|
|
mathsModule->packagesTW->setCellWidget(packnum, 1, autoRBWidget);
|
|
|
|
mathsModule->packagesTW->setCellWidget(packnum, 2, alwaysRBWidget);
|
|
|
|
mathsModule->packagesTW->setCellWidget(packnum, 3, neverRBWidget);
|
2013-03-01 15:59:37 +01:00
|
|
|
|
|
|
|
connect(autoRB, SIGNAL(clicked()),
|
2012-01-03 20:51:07 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2013-03-01 15:59:37 +01:00
|
|
|
connect(alwaysRB, SIGNAL(clicked()),
|
2012-01-03 20:51:07 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2013-03-01 15:59:37 +01:00
|
|
|
connect(neverRB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2017-12-16 09:55:25 -05:00
|
|
|
++packnum;
|
2012-01-03 20:51:07 +00:00
|
|
|
}
|
2013-03-02 10:03:08 +01:00
|
|
|
connect(mathsModule->allPackagesAutoPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(allPackagesAuto()));
|
|
|
|
connect(mathsModule->allPackagesAlwaysPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(allPackagesAlways()));
|
|
|
|
connect(mathsModule->allPackagesNotPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(allPackagesNot()));
|
2013-07-21 19:27:57 +02:00
|
|
|
connect(mathsModule->allPackagesAutoPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(mathsModule->allPackagesAlwaysPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(mathsModule->allPackagesNotPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2017-04-25 02:28:10 +02:00
|
|
|
connect(mathsModule->MathNumberingPosCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
2017-04-25 03:01:39 +02:00
|
|
|
connect(mathsModule->MathIndentCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(mathsModule->MathIndentCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(allowMathIndent()));
|
|
|
|
connect(mathsModule->MathIndentCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(mathsModule->MathIndentCO, SIGNAL(activated(int)),
|
2017-05-09 21:02:03 +02:00
|
|
|
this, SLOT(enableMathIndent(int)));
|
2017-04-25 03:01:39 +02:00
|
|
|
connect(mathsModule->MathIndentLE, SIGNAL(textChanged(const QString &)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(mathsModule->MathIndentLengthCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
|
2017-07-03 13:53:14 -04:00
|
|
|
|
2017-04-25 03:01:39 +02:00
|
|
|
mathsModule->MathIndentCO->addItem(qt_("Default"));
|
|
|
|
mathsModule->MathIndentCO->addItem(qt_("Custom"));
|
|
|
|
mathsModule->MathIndentLE->setValidator(new LengthValidator(
|
|
|
|
mathsModule->MathIndentLE));
|
|
|
|
// initialize the length validator
|
|
|
|
bc().addCheckedLineEdit(mathsModule->MathIndentLE);
|
2017-04-26 00:32:13 +02:00
|
|
|
mathsModule->MathNumberingPosCO->addItem(qt_("Left"));
|
2017-05-02 23:09:36 +02:00
|
|
|
mathsModule->MathNumberingPosCO->addItem(qt_("Default"));
|
2017-05-12 01:06:05 +02:00
|
|
|
mathsModule->MathNumberingPosCO->addItem(qt_("Right"));
|
|
|
|
mathsModule->MathNumberingPosCO->setCurrentIndex(1);
|
2017-07-03 13:53:14 -04:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// latex class
|
2017-02-26 22:15:49 +01:00
|
|
|
latexModule = new UiWidget<Ui::LaTeXUi>(this);
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(latexModule->optionsLE, SIGNAL(textChanged(QString)),
|
2007-04-25 10:25:37 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2008-10-12 09:36:00 +00:00
|
|
|
connect(latexModule->defaultOptionsCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(latexModule->psdriverCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(latexModule->classCO, SIGNAL(activated(int)),
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
this, SLOT(classChanged_adaptor()));
|
2008-01-15 10:38:19 +00:00
|
|
|
connect(latexModule->classCO, SIGNAL(activated(int)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-03-10 21:31:22 +00:00
|
|
|
connect(latexModule->layoutPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(browseLayout()));
|
2008-07-11 02:43:02 +00:00
|
|
|
connect(latexModule->layoutPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-04-28 16:38:56 +00:00
|
|
|
connect(latexModule->childDocGB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(latexModule->childDocLE, SIGNAL(textChanged(QString)),
|
2008-04-28 16:38:56 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(latexModule->childDocPB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(browseMaster()));
|
2009-08-14 00:52:33 +00:00
|
|
|
connect(latexModule->suppressDateCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2010-10-13 12:36:53 +00:00
|
|
|
connect(latexModule->refstyleCB, SIGNAL(clicked()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-10-20 19:53:15 +00:00
|
|
|
|
2011-09-24 16:39:23 +00:00
|
|
|
latexModule->optionsLE->setValidator(new NoNewLineValidator(
|
|
|
|
latexModule->optionsLE));
|
|
|
|
latexModule->childDocLE->setValidator(new NoNewLineValidator(
|
|
|
|
latexModule->childDocLE));
|
|
|
|
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
// postscript drivers
|
2007-04-24 19:37:34 +00:00
|
|
|
for (int n = 0; tex_graphics[n][0]; ++n) {
|
2007-06-01 17:44:04 +00:00
|
|
|
QString enc = qt_(tex_graphics_gui[n]);
|
2007-04-24 19:37:34 +00:00
|
|
|
latexModule->psdriverCO->addItem(enc);
|
|
|
|
}
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
// latex classes
|
2008-03-07 03:53:21 +00:00
|
|
|
LayoutFileList const & bcl = LayoutFileList::get();
|
This is the last of the commits that hopes to enforce the distinction between "layout files" and "document classes" that was introduced by the modules code. For the most part, these changes just refactor code from TextClass between: (a) a TextClass base class; (b) a LayoutFile subclass, which represents the information in a .layout file; and (c) a DocumentClass subclass, which represents the layout information associated with a Buffer---a LayoutFile plus Modules. Methods from TextClass have been apportioned between the three classes depending upon what is needed where, and signatures have been changed where necessary so that the right kind of class is required.
At this point, there are no simple TextClass objects in the main LyX code, and it is impossible to create them, since the TextClass constructor is protected. Only LayoutFile and DocumentClass objects can be constructed, and for the most part these are constructed only by their respective containers: BaseClassList and DocumentClassBundle. There is an exception: LayoutFile does have a public default constructor, but if anyone knows how to make it go away, please do.
There will be one or two more commits along these lines, but these will be simple renamings. For example, BaseClassList should be LayoutFileList.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23343 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-29 02:45:33 +00:00
|
|
|
vector<LayoutFileIndex> classList = bcl.classList();
|
2008-02-28 21:04:55 +00:00
|
|
|
sort(classList.begin(), classList.end(), less_textclass_avail_desc());
|
|
|
|
|
2017-12-16 09:55:25 -05:00
|
|
|
for (auto const & cvar : classList) {
|
|
|
|
LayoutFile const & tc = bcl[cvar];
|
2012-10-09 07:22:48 +02:00
|
|
|
bool const available = tc.isTeXClassAvailable();
|
|
|
|
docstring const guiname = translateIfPossible(from_utf8(tc.description()));
|
|
|
|
// tooltip sensu "KOMA-Script Article [Class 'scrartcl']"
|
|
|
|
QString tooltip = toqstr(bformat(_("%1$s [Class '%2$s']"), guiname, from_utf8(tc.latexname())));
|
|
|
|
if (!available) {
|
2020-07-05 02:31:37 +02:00
|
|
|
docstring const output_type = _("LaTeX");
|
2016-06-11 12:57:18 +01:00
|
|
|
tooltip += '\n' + toqstr(bformat(_("Class not found by LyX. "
|
2012-10-09 07:22:48 +02:00
|
|
|
"Please check if you have the matching %1$s class "
|
2013-01-20 15:32:49 +01:00
|
|
|
"and all required packages (%2$s) installed."),
|
2016-06-11 12:57:18 +01:00
|
|
|
output_type, from_utf8(tc.prerequisites(", "))));
|
2012-10-09 07:22:48 +02:00
|
|
|
}
|
|
|
|
latexModule->classCO->addItemSort(toqstr(tc.name()),
|
|
|
|
toqstr(guiname),
|
|
|
|
toqstr(translateIfPossible(from_utf8(tc.category()))),
|
|
|
|
tooltip,
|
|
|
|
true, true, true, available);
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// branches
|
2017-02-26 22:15:49 +01:00
|
|
|
branchesModule = new GuiBranches(this);
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(branchesModule, SIGNAL(changed()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2009-07-10 06:49:51 +00:00
|
|
|
connect(branchesModule, SIGNAL(renameBranches(docstring const &, docstring const &)),
|
|
|
|
this, SLOT(branchesRename(docstring const &, docstring const &)));
|
2012-03-03 14:39:32 +00:00
|
|
|
connect(branchesModule, SIGNAL(okPressed()), this, SLOT(slotOK()));
|
2009-07-09 09:48:34 +00:00
|
|
|
updateUnknownBranches();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// preamble
|
2017-02-26 22:15:49 +01:00
|
|
|
preambleModule = new PreambleModule(this);
|
2007-05-14 12:09:14 +00:00
|
|
|
connect(preambleModule, SIGNAL(changed()),
|
2007-04-24 19:37:34 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2017-02-26 22:15:49 +01:00
|
|
|
localLayout = new LocalLayout(this);
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
connect(localLayout, SIGNAL(changed()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// bullets
|
2017-02-26 22:15:49 +01:00
|
|
|
bulletsModule = new BulletsModule(this);
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(bulletsModule, SIGNAL(changed()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2008-10-19 01:21:59 +00:00
|
|
|
// Modules
|
2017-02-26 22:15:49 +01:00
|
|
|
modulesModule = new UiWidget<Ui::ModulesUi>(this);
|
2009-08-17 18:43:25 +00:00
|
|
|
modulesModule->availableLV->header()->setVisible(false);
|
2013-02-03 12:23:31 +01:00
|
|
|
setSectionResizeMode(modulesModule->availableLV->header(), QHeaderView::ResizeToContents);
|
2011-02-15 09:37:19 +00:00
|
|
|
modulesModule->availableLV->header()->setStretchLastSection(false);
|
2019-04-05 11:52:37 +02:00
|
|
|
modulesModule->selectedLV->header()->setVisible(false);
|
|
|
|
setSectionResizeMode(modulesModule->selectedLV->header(), QHeaderView::ResizeToContents);
|
|
|
|
modulesModule->selectedLV->header()->setStretchLastSection(false);
|
2008-10-19 01:21:59 +00:00
|
|
|
selectionManager =
|
2017-02-26 22:15:49 +01:00
|
|
|
new ModuleSelectionManager(this, modulesModule->availableLV,
|
|
|
|
modulesModule->selectedLV,
|
|
|
|
modulesModule->addPB,
|
|
|
|
modulesModule->deletePB,
|
|
|
|
modulesModule->upPB,
|
|
|
|
modulesModule->downPB,
|
2019-04-05 11:52:37 +02:00
|
|
|
availableModel(), selectedModel(), this);
|
2008-10-19 01:21:59 +00:00
|
|
|
connect(selectionManager, SIGNAL(updateHook()),
|
|
|
|
this, SLOT(updateModuleInfo()));
|
2008-10-20 19:31:05 +00:00
|
|
|
connect(selectionManager, SIGNAL(selectionChanged()),
|
|
|
|
this, SLOT(modulesChanged()));
|
2019-04-05 11:52:37 +02:00
|
|
|
// The filter bar
|
|
|
|
filter_ = new FancyLineEdit(this);
|
|
|
|
filter_->setButtonPixmap(FancyLineEdit::Right, getPixmap("images/", "editclear", "svgz,png"));
|
|
|
|
filter_->setButtonVisible(FancyLineEdit::Right, true);
|
|
|
|
filter_->setButtonToolTip(FancyLineEdit::Right, qt_("Clear text"));
|
|
|
|
filter_->setAutoHideButton(FancyLineEdit::Right, true);
|
|
|
|
filter_->setPlaceholderText(qt_("All avail. modules"));
|
|
|
|
modulesModule->moduleFilterBarL->addWidget(filter_, 0);
|
|
|
|
modulesModule->findModulesLA->setBuddy(filter_);
|
|
|
|
|
|
|
|
connect(filter_, SIGNAL(rightButtonClicked()),
|
|
|
|
this, SLOT(resetModuleFilter()));
|
|
|
|
connect(filter_, SIGNAL(textEdited(QString)),
|
|
|
|
this, SLOT(moduleFilterChanged(QString)));
|
|
|
|
connect(filter_, SIGNAL(returnPressed()),
|
|
|
|
this, SLOT(moduleFilterPressed()));
|
|
|
|
#if (QT_VERSION < 0x050000)
|
|
|
|
connect(filter_, SIGNAL(downPressed()),
|
|
|
|
modulesModule->availableLV, SLOT(setFocus()));
|
|
|
|
#else
|
|
|
|
connect(filter_, &FancyLineEdit::downPressed,
|
2020-12-29 16:29:06 +02:00
|
|
|
modulesModule->availableLV, [this](){ focusAndHighlight(modulesModule->availableLV); });
|
2019-04-05 11:52:37 +02:00
|
|
|
#endif
|
2008-10-19 01:21:59 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-09-20 22:31:18 +00:00
|
|
|
// PDF support
|
2017-02-26 22:15:49 +01:00
|
|
|
pdfSupportModule = new UiWidget<Ui::PDFSupportUi>(this);
|
2007-09-22 22:20:15 +00:00
|
|
|
connect(pdfSupportModule->use_hyperrefGB, SIGNAL(toggled(bool)),
|
2008-06-09 15:20:38 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(pdfSupportModule->titleLE, SIGNAL(textChanged(QString)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(pdfSupportModule->authorLE, SIGNAL(textChanged(QString)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(pdfSupportModule->subjectLE, SIGNAL(textChanged(QString)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(pdfSupportModule->keywordsLE, SIGNAL(textChanged(QString)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pdfSupportModule->bookmarksGB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pdfSupportModule->bookmarksnumberedCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pdfSupportModule->bookmarksopenGB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2020-05-16 10:31:48 +02:00
|
|
|
connect(pdfSupportModule->bookmarksopenGB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(bookmarksopenChanged(bool)));
|
2007-09-22 22:20:15 +00:00
|
|
|
connect(pdfSupportModule->bookmarksopenlevelSB, SIGNAL(valueChanged(int)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pdfSupportModule->breaklinksCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pdfSupportModule->pdfborderCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
|
|
|
connect(pdfSupportModule->colorlinksCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-10-13 16:01:02 +00:00
|
|
|
connect(pdfSupportModule->backrefCO, SIGNAL(activated(int)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2007-10-10 00:34:23 +00:00
|
|
|
connect(pdfSupportModule->pdfusetitleCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-09-20 22:31:18 +00:00
|
|
|
connect(pdfSupportModule->fullscreenCB, SIGNAL(toggled(bool)),
|
|
|
|
this, SLOT(change_adaptor()));
|
2008-09-20 12:57:12 +00:00
|
|
|
connect(pdfSupportModule->optionsLE, SIGNAL(textChanged(QString)),
|
2007-09-20 22:31:18 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2011-09-24 16:39:23 +00:00
|
|
|
pdfSupportModule->titleLE->setValidator(new NoNewLineValidator(
|
|
|
|
pdfSupportModule->titleLE));
|
|
|
|
pdfSupportModule->authorLE->setValidator(new NoNewLineValidator(
|
|
|
|
pdfSupportModule->authorLE));
|
|
|
|
pdfSupportModule->subjectLE->setValidator(new NoNewLineValidator(
|
|
|
|
pdfSupportModule->subjectLE));
|
|
|
|
pdfSupportModule->keywordsLE->setValidator(new NoNewLineValidator(
|
|
|
|
pdfSupportModule->keywordsLE));
|
|
|
|
pdfSupportModule->optionsLE->setValidator(new NoNewLineValidator(
|
|
|
|
pdfSupportModule->optionsLE));
|
|
|
|
|
2008-10-13 16:01:02 +00:00
|
|
|
for (int i = 0; backref_opts[i][0]; ++i)
|
|
|
|
pdfSupportModule->backrefCO->addItem(qt_(backref_opts_gui[i]));
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// float
|
|
|
|
floatModule = new FloatPlacement;
|
2007-04-25 10:25:37 +00:00
|
|
|
connect(floatModule, SIGNAL(changed()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// listings
|
2017-02-26 22:15:49 +01:00
|
|
|
listingsModule = new UiWidget<Ui::ListingsSettingsUi>(this);
|
2009-07-20 08:09:32 +00:00
|
|
|
connect(listingsModule->listingsED, SIGNAL(textChanged()),
|
|
|
|
this, SLOT(change_adaptor()));
|
2011-12-03 22:15:11 +00:00
|
|
|
connect(listingsModule->bypassCB, SIGNAL(clicked()),
|
2009-07-20 08:09:32 +00:00
|
|
|
this, SLOT(change_adaptor()));
|
2011-12-03 22:15:11 +00:00
|
|
|
connect(listingsModule->bypassCB, SIGNAL(clicked()),
|
2009-07-20 08:09:32 +00:00
|
|
|
this, SLOT(setListingsMessage()));
|
2017-06-12 17:24:26 +02:00
|
|
|
connect(listingsModule->packageCO, SIGNAL(activated(int)),
|
2017-06-07 00:55:23 +02:00
|
|
|
this, SLOT(change_adaptor()));
|
2017-07-31 11:32:28 +02:00
|
|
|
connect(listingsModule->packageCO, SIGNAL(activated(int)),
|
2017-06-12 17:24:26 +02:00
|
|
|
this, SLOT(listingsPackageChanged(int)));
|
2009-07-20 08:09:32 +00:00
|
|
|
connect(listingsModule->listingsED, SIGNAL(textChanged()),
|
|
|
|
this, SLOT(setListingsMessage()));
|
|
|
|
listingsModule->listingsTB->setPlainText(
|
|
|
|
qt_("Input listings parameters below. Enter ? for a list of parameters."));
|
|
|
|
|
2017-06-12 17:24:26 +02:00
|
|
|
for (int i = 0; lst_packages[i][0]; ++i)
|
|
|
|
listingsModule->packageCO->addItem(lst_packages[i]);
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
|
|
|
// add the panels
|
2013-05-12 18:30:59 +02:00
|
|
|
docPS->addPanel(latexModule, N_("Document Class"));
|
|
|
|
docPS->addPanel(masterChildModule, N_("Child Documents"));
|
|
|
|
docPS->addPanel(modulesModule, N_("Modules"));
|
|
|
|
docPS->addPanel(localLayout, N_("Local Layout"));
|
|
|
|
docPS->addPanel(fontModule, N_("Fonts"));
|
|
|
|
docPS->addPanel(textLayoutModule, N_("Text Layout"));
|
|
|
|
docPS->addPanel(pageLayoutModule, N_("Page Layout"));
|
|
|
|
docPS->addPanel(marginsModule, N_("Page Margins"));
|
|
|
|
docPS->addPanel(langModule, N_("Language"));
|
|
|
|
docPS->addPanel(colorModule, N_("Colors"));
|
2019-12-24 18:12:22 +01:00
|
|
|
docPS->addPanel(changesModule, N_("Change Tracking"));
|
2013-05-12 18:30:59 +02:00
|
|
|
docPS->addPanel(numberingModule, N_("Numbering & TOC"));
|
|
|
|
docPS->addPanel(biblioModule, N_("Bibliography"));
|
|
|
|
docPS->addPanel(indicesModule, N_("Indexes"));
|
|
|
|
docPS->addPanel(pdfSupportModule, N_("PDF Properties"));
|
|
|
|
docPS->addPanel(mathsModule, N_("Math Options"));
|
2018-05-10 20:15:11 +02:00
|
|
|
docPS->addPanel(floatModule, N_("Float Settings"));
|
2013-05-12 18:30:59 +02:00
|
|
|
docPS->addPanel(listingsModule, N_("Listings[[inset]]"));
|
|
|
|
docPS->addPanel(bulletsModule, N_("Bullets"));
|
|
|
|
docPS->addPanel(branchesModule, N_("Branches"));
|
2016-08-28 16:51:15 +01:00
|
|
|
docPS->addPanel(outputModule, N_("Formats[[output]]"));
|
2013-05-12 18:30:59 +02:00
|
|
|
docPS->addPanel(preambleModule, N_("LaTeX Preamble"));
|
|
|
|
docPS->setCurrentPanel("Document Class");
|
2007-04-24 19:37:34 +00:00
|
|
|
// FIXME: hack to work around resizing bug in Qt >= 4.2
|
|
|
|
// bug verified with Qt 4.2.{0-3} (JSpitzm)
|
|
|
|
#if QT_VERSION >= 0x040200
|
|
|
|
docPS->updateGeometry();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-11-09 23:37:35 +01:00
|
|
|
void GuiDocument::onBufferViewChanged()
|
2016-10-10 00:35:35 +02:00
|
|
|
{
|
|
|
|
if (isVisibleView())
|
|
|
|
initialiseParams("");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::saveDefaultClicked()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2007-09-05 20:33:29 +00:00
|
|
|
saveDocDefault();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::useDefaultsClicked()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2007-09-05 20:33:29 +00:00
|
|
|
useClassDefaults();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::change_adaptor()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2014-12-21 19:08:41 +01:00
|
|
|
nonModuleChanged_ = true;
|
2007-09-05 20:33:29 +00:00
|
|
|
changed();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-03 13:07:41 +02:00
|
|
|
void GuiDocument::shellescapeChanged()
|
|
|
|
{
|
2017-08-10 01:32:23 +02:00
|
|
|
shellescapeChanged_ = true;
|
|
|
|
changed();
|
|
|
|
}
|
|
|
|
|
2020-05-16 10:31:48 +02:00
|
|
|
void GuiDocument::bookmarksopenChanged(bool state)
|
|
|
|
{
|
|
|
|
pdfSupportModule->bookmarksopenlevelSB->setEnabled(state);
|
|
|
|
pdfSupportModule->bookmarksopenlevelLA->setEnabled(state);
|
|
|
|
}
|
|
|
|
|
2017-08-10 01:32:23 +02:00
|
|
|
|
|
|
|
void GuiDocument::slotApply()
|
|
|
|
{
|
|
|
|
bool only_shellescape_changed = !nonModuleChanged_ && !modulesChanged_;
|
|
|
|
bool wasclean = buffer().isClean();
|
|
|
|
GuiDialog::slotApply();
|
|
|
|
if (wasclean && only_shellescape_changed)
|
|
|
|
buffer().markClean();
|
|
|
|
modulesChanged_ = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::slotOK()
|
|
|
|
{
|
|
|
|
bool only_shellescape_changed = !nonModuleChanged_ && !modulesChanged_;
|
|
|
|
bool wasclean = buffer().isClean();
|
|
|
|
GuiDialog::slotOK();
|
|
|
|
if (wasclean && only_shellescape_changed)
|
|
|
|
buffer().markClean();
|
|
|
|
modulesChanged_ = false;
|
2017-08-03 13:07:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-07-09 09:46:39 +02:00
|
|
|
void GuiDocument::slotButtonBox(QAbstractButton * button)
|
|
|
|
{
|
|
|
|
switch (buttonBox->standardButton(button)) {
|
|
|
|
case QDialogButtonBox::Ok:
|
|
|
|
slotOK();
|
|
|
|
break;
|
|
|
|
case QDialogButtonBox::Apply:
|
|
|
|
slotApply();
|
|
|
|
break;
|
|
|
|
case QDialogButtonBox::Cancel:
|
|
|
|
slotClose();
|
|
|
|
break;
|
|
|
|
case QDialogButtonBox::Reset:
|
|
|
|
case QDialogButtonBox::RestoreDefaults:
|
|
|
|
slotRestore();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-05 11:52:37 +02:00
|
|
|
void GuiDocument::filterModules(QString const & str)
|
|
|
|
{
|
|
|
|
updateAvailableModules();
|
|
|
|
if (str.isEmpty())
|
|
|
|
return;
|
|
|
|
|
|
|
|
modules_av_model_.clear();
|
|
|
|
list<modInfoStruct> modInfoList = getModuleInfo();
|
|
|
|
// Sort names according to the locale
|
|
|
|
modInfoList.sort([](modInfoStruct const & a, modInfoStruct const & b) {
|
|
|
|
return 0 < b.name.localeAwareCompare(a.name);
|
|
|
|
});
|
2019-04-20 09:28:46 +02:00
|
|
|
|
|
|
|
QIcon user_icon(getPixmap("images/", "lyxfiles-user", "svgz,png"));
|
|
|
|
QIcon system_icon(getPixmap("images/", "lyxfiles-system", "svgz,png"));
|
|
|
|
|
2019-04-05 11:52:37 +02:00
|
|
|
int i = 0;
|
|
|
|
for (modInfoStruct const & m : modInfoList) {
|
|
|
|
if (m.name.contains(str, Qt::CaseInsensitive) || contains(m.id, fromqstr(str))) {
|
2019-04-07 11:23:19 +02:00
|
|
|
QStandardItem * item = new QStandardItem();
|
|
|
|
item->setData(m.name, Qt::DisplayRole);
|
|
|
|
item->setData(toqstr(m.id), Qt::UserRole);
|
|
|
|
item->setData(m.description, Qt::ToolTipRole);
|
2019-04-20 09:28:46 +02:00
|
|
|
if (m.local)
|
|
|
|
item->setIcon(user_icon);
|
|
|
|
else
|
|
|
|
item->setIcon(system_icon);
|
2019-04-07 11:23:19 +02:00
|
|
|
modules_av_model_.insertRow(i, item);
|
2019-04-05 11:52:37 +02:00
|
|
|
++i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::moduleFilterChanged(const QString & text)
|
|
|
|
{
|
|
|
|
if (!text.isEmpty()) {
|
|
|
|
filterModules(filter_->text());
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
filterModules(filter_->text());
|
|
|
|
filter_->setFocus();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::moduleFilterPressed()
|
|
|
|
{
|
|
|
|
filterModules(filter_->text());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::resetModuleFilter()
|
|
|
|
{
|
|
|
|
filter_->setText(QString());
|
|
|
|
filterModules(filter_->text());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-01-07 10:01:26 +00:00
|
|
|
void GuiDocument::includeonlyClicked(QTreeWidgetItem * item, int)
|
|
|
|
{
|
2020-02-26 22:29:40 -05:00
|
|
|
if (item == nullptr)
|
2010-01-07 10:01:26 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
string child = fromqstr(item->text(0));
|
|
|
|
if (child.empty())
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (std::find(includeonlys_.begin(),
|
|
|
|
includeonlys_.end(), child) != includeonlys_.end())
|
|
|
|
includeonlys_.remove(child);
|
|
|
|
else
|
|
|
|
includeonlys_.push_back(child);
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2010-01-07 10:01:26 +00:00
|
|
|
updateIncludeonlys();
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-01-07 10:01:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-09-20 12:07:18 +00:00
|
|
|
QString GuiDocument::validateListingsParameters()
|
2007-07-27 18:17:00 +00:00
|
|
|
{
|
2009-07-20 08:09:32 +00:00
|
|
|
if (listingsModule->bypassCB->isChecked())
|
2008-09-20 12:07:18 +00:00
|
|
|
return QString();
|
2017-06-12 17:24:26 +02:00
|
|
|
string const package =
|
|
|
|
lst_packages[listingsModule->packageCO->currentIndex()];
|
2009-07-20 08:09:32 +00:00
|
|
|
string params = fromqstr(listingsModule->listingsED->toPlainText());
|
2017-06-12 11:54:59 +02:00
|
|
|
InsetListingsParams lstparams(params);
|
2017-06-12 17:24:26 +02:00
|
|
|
lstparams.setMinted(package == "Minted");
|
2017-06-12 11:54:59 +02:00
|
|
|
return toqstr(lstparams.validate());
|
2007-07-27 18:17:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-09-20 12:07:18 +00:00
|
|
|
void GuiDocument::setListingsMessage()
|
Add support for listings package. Two listings command \lstinline, \lstinputlisting and an environment \lstlisting are supported, along with preamble \lstset. \lstinputlisting is implemented through Include dialog, and the other two are implemented with a new inset listings, along with its dialog.
* src/LyXAction.cpp: listing-insert action
* src/insets/Inset.h,cpp: LISTINGS_CODE
* src/insets/InsetInclude.cpp: handle \lstinputlisting
* src/insets/InsetListings.h,cpp: new listings inset
* src/insets/InsetListingsParams.h,cpp: parameters from listings package
* src/insets/InsetCommandParams.h,cpp: handle lstinputlisting option
* src/Bidi.cpp: handle LISTINGS_CODE
* src/frontends/qt4/ui/TextLayoutUi.ui: update UI
* src/frontends/qt4/ui/ListingsUi.ui: new dialog
* src/frontends/qt4/ui/IncludeUi.ui: update UI
* src/frontends/qt4/QInclude.h,cpp: add lstinputlisting
* src/frontends/qt4/QDocument.h,cpp: add textedit for preamble listings_params
* src/frontends/qt4/QListings.h,cpp: new listings inset
* src/frontends/qt4/Dialogs.cpp: new listings dialog
* src/frontends/controllers/ControlInclude.h,cpp: add lstinputlisting
* src/frontends/controllers/ControlListings.h,cpp: new listings inset
* src/LyXFunc.cpp: handle LISTING_CODE
* src/Paragraph.cpp: handle LISTING_CODE
* src/factory.cpp: new listings inset
* src/CutAndPaste.cpp: handle LISTINGS_CODE
* src/LaTeXFeatures.cpp: require listings
* src/Text3.cpp: Handle LISTINGS_CODE
* src/lfuns.h: add LFUN_LISTING_INSERT
* src/Buffer.cpp: change lyx file format to 269
* src/BufferParams.h,cpp: add listings_params to preamble
* lib/lyx2lyx/LyX.py: lyx2lyx
* lib/lyx2lyx/lyx_1_5.py: lyx2lyx
* lib/ui/stdmenus.inc: new menu item (no shortcut!)
* src/insets/Makefile.am: update autotools
* src/frontends/controllers/Makefile.am
* src/frontends/qt4/Makefile.dialogs
* src/frontends/qt4/Makefile.am
* po/POTFILES.in: a few more translatable files.
* development/scons/scons_manifest.py: scons build system
* development/FORMAT: document format changes
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18243 a592a061-630c-0410-9148-cb99ea01b6c8
2007-05-09 19:11:42 +00:00
|
|
|
{
|
2013-10-07 18:59:05 -04:00
|
|
|
// FIXME THREAD
|
Add support for listings package. Two listings command \lstinline, \lstinputlisting and an environment \lstlisting are supported, along with preamble \lstset. \lstinputlisting is implemented through Include dialog, and the other two are implemented with a new inset listings, along with its dialog.
* src/LyXAction.cpp: listing-insert action
* src/insets/Inset.h,cpp: LISTINGS_CODE
* src/insets/InsetInclude.cpp: handle \lstinputlisting
* src/insets/InsetListings.h,cpp: new listings inset
* src/insets/InsetListingsParams.h,cpp: parameters from listings package
* src/insets/InsetCommandParams.h,cpp: handle lstinputlisting option
* src/Bidi.cpp: handle LISTINGS_CODE
* src/frontends/qt4/ui/TextLayoutUi.ui: update UI
* src/frontends/qt4/ui/ListingsUi.ui: new dialog
* src/frontends/qt4/ui/IncludeUi.ui: update UI
* src/frontends/qt4/QInclude.h,cpp: add lstinputlisting
* src/frontends/qt4/QDocument.h,cpp: add textedit for preamble listings_params
* src/frontends/qt4/QListings.h,cpp: new listings inset
* src/frontends/qt4/Dialogs.cpp: new listings dialog
* src/frontends/controllers/ControlInclude.h,cpp: add lstinputlisting
* src/frontends/controllers/ControlListings.h,cpp: new listings inset
* src/LyXFunc.cpp: handle LISTING_CODE
* src/Paragraph.cpp: handle LISTING_CODE
* src/factory.cpp: new listings inset
* src/CutAndPaste.cpp: handle LISTINGS_CODE
* src/LaTeXFeatures.cpp: require listings
* src/Text3.cpp: Handle LISTINGS_CODE
* src/lfuns.h: add LFUN_LISTING_INSERT
* src/Buffer.cpp: change lyx file format to 269
* src/BufferParams.h,cpp: add listings_params to preamble
* lib/lyx2lyx/LyX.py: lyx2lyx
* lib/lyx2lyx/lyx_1_5.py: lyx2lyx
* lib/ui/stdmenus.inc: new menu item (no shortcut!)
* src/insets/Makefile.am: update autotools
* src/frontends/controllers/Makefile.am
* src/frontends/qt4/Makefile.dialogs
* src/frontends/qt4/Makefile.am
* po/POTFILES.in: a few more translatable files.
* development/scons/scons_manifest.py: scons build system
* development/FORMAT: document format changes
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18243 a592a061-630c-0410-9148-cb99ea01b6c8
2007-05-09 19:11:42 +00:00
|
|
|
static bool isOK = true;
|
2008-09-20 12:07:18 +00:00
|
|
|
QString msg = validateListingsParameters();
|
|
|
|
if (msg.isEmpty()) {
|
2007-06-12 17:10:28 +00:00
|
|
|
if (isOK)
|
|
|
|
return;
|
|
|
|
isOK = true;
|
2020-03-19 09:57:08 -04:00
|
|
|
// listingsModule->listingsTB->setTextColor("black");
|
2009-07-20 08:09:32 +00:00
|
|
|
listingsModule->listingsTB->setPlainText(
|
|
|
|
qt_("Input listings parameters below. "
|
2015-05-17 17:27:12 +02:00
|
|
|
"Enter ? for a list of parameters."));
|
2007-06-12 17:10:28 +00:00
|
|
|
} else {
|
Add support for listings package. Two listings command \lstinline, \lstinputlisting and an environment \lstlisting are supported, along with preamble \lstset. \lstinputlisting is implemented through Include dialog, and the other two are implemented with a new inset listings, along with its dialog.
* src/LyXAction.cpp: listing-insert action
* src/insets/Inset.h,cpp: LISTINGS_CODE
* src/insets/InsetInclude.cpp: handle \lstinputlisting
* src/insets/InsetListings.h,cpp: new listings inset
* src/insets/InsetListingsParams.h,cpp: parameters from listings package
* src/insets/InsetCommandParams.h,cpp: handle lstinputlisting option
* src/Bidi.cpp: handle LISTINGS_CODE
* src/frontends/qt4/ui/TextLayoutUi.ui: update UI
* src/frontends/qt4/ui/ListingsUi.ui: new dialog
* src/frontends/qt4/ui/IncludeUi.ui: update UI
* src/frontends/qt4/QInclude.h,cpp: add lstinputlisting
* src/frontends/qt4/QDocument.h,cpp: add textedit for preamble listings_params
* src/frontends/qt4/QListings.h,cpp: new listings inset
* src/frontends/qt4/Dialogs.cpp: new listings dialog
* src/frontends/controllers/ControlInclude.h,cpp: add lstinputlisting
* src/frontends/controllers/ControlListings.h,cpp: new listings inset
* src/LyXFunc.cpp: handle LISTING_CODE
* src/Paragraph.cpp: handle LISTING_CODE
* src/factory.cpp: new listings inset
* src/CutAndPaste.cpp: handle LISTINGS_CODE
* src/LaTeXFeatures.cpp: require listings
* src/Text3.cpp: Handle LISTINGS_CODE
* src/lfuns.h: add LFUN_LISTING_INSERT
* src/Buffer.cpp: change lyx file format to 269
* src/BufferParams.h,cpp: add listings_params to preamble
* lib/lyx2lyx/LyX.py: lyx2lyx
* lib/lyx2lyx/lyx_1_5.py: lyx2lyx
* lib/ui/stdmenus.inc: new menu item (no shortcut!)
* src/insets/Makefile.am: update autotools
* src/frontends/controllers/Makefile.am
* src/frontends/qt4/Makefile.dialogs
* src/frontends/qt4/Makefile.am
* po/POTFILES.in: a few more translatable files.
* development/scons/scons_manifest.py: scons build system
* development/FORMAT: document format changes
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18243 a592a061-630c-0410-9148-cb99ea01b6c8
2007-05-09 19:11:42 +00:00
|
|
|
isOK = false;
|
2020-03-19 09:57:08 -04:00
|
|
|
// listingsModule->listingsTB->setTextColor("red");
|
2009-07-20 08:09:32 +00:00
|
|
|
listingsModule->listingsTB->setPlainText(msg);
|
Add support for listings package. Two listings command \lstinline, \lstinputlisting and an environment \lstlisting are supported, along with preamble \lstset. \lstinputlisting is implemented through Include dialog, and the other two are implemented with a new inset listings, along with its dialog.
* src/LyXAction.cpp: listing-insert action
* src/insets/Inset.h,cpp: LISTINGS_CODE
* src/insets/InsetInclude.cpp: handle \lstinputlisting
* src/insets/InsetListings.h,cpp: new listings inset
* src/insets/InsetListingsParams.h,cpp: parameters from listings package
* src/insets/InsetCommandParams.h,cpp: handle lstinputlisting option
* src/Bidi.cpp: handle LISTINGS_CODE
* src/frontends/qt4/ui/TextLayoutUi.ui: update UI
* src/frontends/qt4/ui/ListingsUi.ui: new dialog
* src/frontends/qt4/ui/IncludeUi.ui: update UI
* src/frontends/qt4/QInclude.h,cpp: add lstinputlisting
* src/frontends/qt4/QDocument.h,cpp: add textedit for preamble listings_params
* src/frontends/qt4/QListings.h,cpp: new listings inset
* src/frontends/qt4/Dialogs.cpp: new listings dialog
* src/frontends/controllers/ControlInclude.h,cpp: add lstinputlisting
* src/frontends/controllers/ControlListings.h,cpp: new listings inset
* src/LyXFunc.cpp: handle LISTING_CODE
* src/Paragraph.cpp: handle LISTING_CODE
* src/factory.cpp: new listings inset
* src/CutAndPaste.cpp: handle LISTINGS_CODE
* src/LaTeXFeatures.cpp: require listings
* src/Text3.cpp: Handle LISTINGS_CODE
* src/lfuns.h: add LFUN_LISTING_INSERT
* src/Buffer.cpp: change lyx file format to 269
* src/BufferParams.h,cpp: add listings_params to preamble
* lib/lyx2lyx/LyX.py: lyx2lyx
* lib/lyx2lyx/lyx_1_5.py: lyx2lyx
* lib/ui/stdmenus.inc: new menu item (no shortcut!)
* src/insets/Makefile.am: update autotools
* src/frontends/controllers/Makefile.am
* src/frontends/qt4/Makefile.dialogs
* src/frontends/qt4/Makefile.am
* po/POTFILES.in: a few more translatable files.
* development/scons/scons_manifest.py: scons build system
* development/FORMAT: document format changes
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18243 a592a061-630c-0410-9148-cb99ea01b6c8
2007-05-09 19:11:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-06-12 17:24:26 +02:00
|
|
|
void GuiDocument::listingsPackageChanged(int index)
|
|
|
|
{
|
|
|
|
string const package = lst_packages[index];
|
|
|
|
if (package == "Minted" && lyxrc.pygmentize_command.empty()) {
|
|
|
|
Alert::warning(_("Pygments driver command not found!"),
|
|
|
|
_("The driver command necessary to use the minted package\n"
|
|
|
|
"(pygmentize) has not been found. Make sure you have\n"
|
|
|
|
"the python-pygments module installed or, if the driver\n"
|
|
|
|
"is named differently, to add the following line to the\n"
|
|
|
|
"document preamble:\n\n"
|
|
|
|
"\\AtBeginDocument{\\renewcommand{\\MintedPygmentize}{driver}}\n\n"
|
|
|
|
"where 'driver' is name of the driver command."));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::setLSpacing(int item)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
|
|
|
textLayoutModule->lspacingLE->setEnabled(item == 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-07-19 21:13:27 +00:00
|
|
|
void GuiDocument::setIndent(int item)
|
|
|
|
{
|
|
|
|
bool const enable = (item == 1);
|
|
|
|
textLayoutModule->indentLE->setEnabled(enable);
|
|
|
|
textLayoutModule->indentLengthCO->setEnabled(enable);
|
|
|
|
textLayoutModule->skipLE->setEnabled(false);
|
|
|
|
textLayoutModule->skipLengthCO->setEnabled(false);
|
|
|
|
isValid();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::enableIndent(bool indent)
|
|
|
|
{
|
|
|
|
textLayoutModule->skipLE->setEnabled(!indent);
|
|
|
|
textLayoutModule->skipLengthCO->setEnabled(!indent);
|
|
|
|
if (indent)
|
|
|
|
setIndent(textLayoutModule->indentCO->currentIndex());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::setSkip(int item)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2020-06-28 17:20:18 +02:00
|
|
|
VSpace::VSpaceKind kind =
|
|
|
|
VSpace::VSpaceKind(textLayoutModule->skipCO->itemData(item).toInt());
|
|
|
|
bool const enable = (kind == VSpace::LENGTH);
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->skipLE->setEnabled(enable);
|
|
|
|
textLayoutModule->skipLengthCO->setEnabled(enable);
|
2009-07-19 21:13:27 +00:00
|
|
|
isValid();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::enableSkip(bool skip)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2009-07-19 21:13:27 +00:00
|
|
|
textLayoutModule->indentLE->setEnabled(!skip);
|
|
|
|
textLayoutModule->indentLengthCO->setEnabled(!skip);
|
2007-04-24 19:37:34 +00:00
|
|
|
if (skip)
|
|
|
|
setSkip(textLayoutModule->skipCO->currentIndex());
|
|
|
|
}
|
|
|
|
|
2017-04-20 23:21:11 +02:00
|
|
|
void GuiDocument::allowMathIndent() {
|
|
|
|
// only disable when not checked, checked does not always allow enabling
|
2017-04-25 03:01:39 +02:00
|
|
|
if (!mathsModule->MathIndentCB->isChecked()) {
|
|
|
|
mathsModule->MathIndentLE->setEnabled(false);
|
|
|
|
mathsModule->MathIndentLengthCO->setEnabled(false);
|
2017-04-20 23:21:11 +02:00
|
|
|
}
|
2017-04-25 03:01:39 +02:00
|
|
|
if (mathsModule->MathIndentCB->isChecked()
|
|
|
|
&& mathsModule->MathIndentCO->currentIndex() == 1) {
|
|
|
|
mathsModule->MathIndentLE->setEnabled(true);
|
|
|
|
mathsModule->MathIndentLengthCO->setEnabled(true);
|
2017-04-20 23:21:11 +02:00
|
|
|
}
|
|
|
|
isValid();
|
|
|
|
}
|
|
|
|
|
2017-05-09 21:02:03 +02:00
|
|
|
void GuiDocument::enableMathIndent(int item)
|
2017-04-13 02:31:26 +02:00
|
|
|
{
|
|
|
|
bool const enable = (item == 1);
|
2017-04-25 03:01:39 +02:00
|
|
|
mathsModule->MathIndentLE->setEnabled(enable);
|
|
|
|
mathsModule->MathIndentLengthCO->setEnabled(enable);
|
2017-04-13 02:31:26 +02:00
|
|
|
isValid();
|
|
|
|
}
|
|
|
|
|
2009-04-06 06:58:30 +00:00
|
|
|
|
2010-05-18 02:56:36 +00:00
|
|
|
void GuiDocument::setMargins()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2009-03-28 10:48:16 +00:00
|
|
|
bool const extern_geometry =
|
|
|
|
documentClass().provides("geometry");
|
|
|
|
marginsModule->marginCB->setEnabled(!extern_geometry);
|
|
|
|
if (extern_geometry) {
|
|
|
|
marginsModule->marginCB->setChecked(false);
|
|
|
|
setCustomMargins(true);
|
2010-05-18 21:08:06 +00:00
|
|
|
} else {
|
|
|
|
marginsModule->marginCB->setChecked(!bp_.use_geometry);
|
|
|
|
setCustomMargins(!bp_.use_geometry);
|
2009-03-28 10:48:16 +00:00
|
|
|
}
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-07-16 08:39:22 +00:00
|
|
|
void GuiDocument::papersizeChanged(int paper_size)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2009-07-16 08:39:22 +00:00
|
|
|
setCustomPapersize(paper_size == 1);
|
|
|
|
}
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-07-16 08:39:22 +00:00
|
|
|
void GuiDocument::setCustomPapersize(bool custom)
|
|
|
|
{
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->paperwidthL->setEnabled(custom);
|
|
|
|
pageLayoutModule->paperwidthLE->setEnabled(custom);
|
|
|
|
pageLayoutModule->paperwidthUnitCO->setEnabled(custom);
|
|
|
|
pageLayoutModule->paperheightL->setEnabled(custom);
|
|
|
|
pageLayoutModule->paperheightLE->setEnabled(custom);
|
|
|
|
pageLayoutModule->paperheightLE->setFocus();
|
|
|
|
pageLayoutModule->paperheightUnitCO->setEnabled(custom);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-02-19 05:39:36 +00:00
|
|
|
void GuiDocument::setColSep()
|
|
|
|
{
|
|
|
|
setCustomMargins(marginsModule->marginCB->checkState() == Qt::Checked);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::setCustomMargins(bool custom)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
|
|
|
marginsModule->topL->setEnabled(!custom);
|
|
|
|
marginsModule->topLE->setEnabled(!custom);
|
|
|
|
marginsModule->topUnit->setEnabled(!custom);
|
|
|
|
|
|
|
|
marginsModule->bottomL->setEnabled(!custom);
|
|
|
|
marginsModule->bottomLE->setEnabled(!custom);
|
|
|
|
marginsModule->bottomUnit->setEnabled(!custom);
|
|
|
|
|
|
|
|
marginsModule->innerL->setEnabled(!custom);
|
|
|
|
marginsModule->innerLE->setEnabled(!custom);
|
|
|
|
marginsModule->innerUnit->setEnabled(!custom);
|
|
|
|
|
|
|
|
marginsModule->outerL->setEnabled(!custom);
|
|
|
|
marginsModule->outerLE->setEnabled(!custom);
|
|
|
|
marginsModule->outerUnit->setEnabled(!custom);
|
|
|
|
|
|
|
|
marginsModule->headheightL->setEnabled(!custom);
|
|
|
|
marginsModule->headheightLE->setEnabled(!custom);
|
|
|
|
marginsModule->headheightUnit->setEnabled(!custom);
|
|
|
|
|
|
|
|
marginsModule->headsepL->setEnabled(!custom);
|
|
|
|
marginsModule->headsepLE->setEnabled(!custom);
|
|
|
|
marginsModule->headsepUnit->setEnabled(!custom);
|
|
|
|
|
|
|
|
marginsModule->footskipL->setEnabled(!custom);
|
|
|
|
marginsModule->footskipLE->setEnabled(!custom);
|
|
|
|
marginsModule->footskipUnit->setEnabled(!custom);
|
2008-02-19 05:24:48 +00:00
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
bool const enableColSep = !custom &&
|
2008-02-19 05:39:36 +00:00
|
|
|
textLayoutModule->twoColumnCB->checkState() == Qt::Checked;
|
|
|
|
marginsModule->columnsepL->setEnabled(enableColSep);
|
|
|
|
marginsModule->columnsepLE->setEnabled(enableColSep);
|
|
|
|
marginsModule->columnsepUnit->setEnabled(enableColSep);
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2009-04-11 21:40:11 +00:00
|
|
|
void GuiDocument::changeBackgroundColor()
|
|
|
|
{
|
2009-04-12 09:13:46 +00:00
|
|
|
QColor const & newColor = QColorDialog::getColor(
|
2009-04-12 12:33:35 +00:00
|
|
|
rgb2qcolor(set_backgroundcolor), asQWidget());
|
2009-04-11 21:40:11 +00:00
|
|
|
if (!newColor.isValid())
|
|
|
|
return;
|
2010-04-05 20:31:10 +00:00
|
|
|
// set the button color and text
|
2010-04-02 22:11:50 +00:00
|
|
|
colorModule->backgroundPB->setStyleSheet(
|
2009-04-11 21:40:11 +00:00
|
|
|
colorButtonStyleSheet(newColor));
|
2011-03-18 14:11:36 +00:00
|
|
|
colorModule->backgroundPB->setText(qt_("&Change..."));
|
2009-04-12 09:13:46 +00:00
|
|
|
// save color
|
2009-04-11 21:40:11 +00:00
|
|
|
set_backgroundcolor = rgbFromHexName(fromqstr(newColor.name()));
|
2010-04-05 20:31:10 +00:00
|
|
|
is_backgroundcolor = true;
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2009-04-11 21:40:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::deleteBackgroundColor()
|
|
|
|
{
|
2011-03-18 14:40:38 +00:00
|
|
|
// set the button color back to default by setting an empty StyleSheet
|
2010-04-05 20:31:10 +00:00
|
|
|
colorModule->backgroundPB->setStyleSheet(QLatin1String(""));
|
|
|
|
// change button text
|
2011-03-18 14:11:36 +00:00
|
|
|
colorModule->backgroundPB->setText(qt_("&Default..."));
|
2010-04-05 20:31:10 +00:00
|
|
|
// save default color (white)
|
2009-04-11 21:40:11 +00:00
|
|
|
set_backgroundcolor = rgbFromHexName("#ffffff");
|
2010-04-05 20:31:10 +00:00
|
|
|
is_backgroundcolor = false;
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2009-04-11 21:40:11 +00:00
|
|
|
}
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 23:39:36 +00:00
|
|
|
void GuiDocument::changeFontColor()
|
|
|
|
{
|
|
|
|
QColor const & newColor = QColorDialog::getColor(
|
|
|
|
rgb2qcolor(set_fontcolor), asQWidget());
|
|
|
|
if (!newColor.isValid())
|
|
|
|
return;
|
|
|
|
// set the button color and text
|
|
|
|
colorModule->fontColorPB->setStyleSheet(
|
|
|
|
colorButtonStyleSheet(newColor));
|
2011-03-18 14:11:36 +00:00
|
|
|
colorModule->fontColorPB->setText(qt_("&Change..."));
|
2010-04-02 23:39:36 +00:00
|
|
|
// save color
|
|
|
|
set_fontcolor = rgbFromHexName(fromqstr(newColor.name()));
|
|
|
|
is_fontcolor = true;
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-04-02 23:39:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::deleteFontColor()
|
|
|
|
{
|
2011-03-18 14:40:38 +00:00
|
|
|
// set the button color back to default by setting an empty StyleSheet
|
2010-04-02 23:39:36 +00:00
|
|
|
colorModule->fontColorPB->setStyleSheet(QLatin1String(""));
|
|
|
|
// change button text
|
2011-03-18 14:11:36 +00:00
|
|
|
colorModule->fontColorPB->setText(qt_("&Default..."));
|
2010-04-02 23:39:36 +00:00
|
|
|
// save default color (black)
|
|
|
|
set_fontcolor = rgbFromHexName("#000000");
|
|
|
|
is_fontcolor = false;
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-04-02 23:39:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-03-31 00:46:50 +00:00
|
|
|
void GuiDocument::changeNoteFontColor()
|
|
|
|
{
|
|
|
|
QColor const & newColor = QColorDialog::getColor(
|
|
|
|
rgb2qcolor(set_notefontcolor), asQWidget());
|
|
|
|
if (!newColor.isValid())
|
|
|
|
return;
|
|
|
|
// set the button color
|
2010-04-02 22:11:50 +00:00
|
|
|
colorModule->noteFontColorPB->setStyleSheet(
|
2010-03-31 00:46:50 +00:00
|
|
|
colorButtonStyleSheet(newColor));
|
|
|
|
// save color
|
|
|
|
set_notefontcolor = rgbFromHexName(fromqstr(newColor.name()));
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-03-31 00:46:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::deleteNoteFontColor()
|
|
|
|
{
|
2011-03-18 14:40:38 +00:00
|
|
|
// set the button color back to pref
|
2011-03-19 10:34:59 +00:00
|
|
|
theApp()->getRgbColor(Color_greyedouttext, set_notefontcolor);
|
2010-04-02 22:11:50 +00:00
|
|
|
colorModule->noteFontColorPB->setStyleSheet(
|
2011-03-18 14:40:38 +00:00
|
|
|
colorButtonStyleSheet(rgb2qcolor(set_notefontcolor)));
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-03-31 00:46:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-04-08 00:14:08 +00:00
|
|
|
void GuiDocument::changeBoxBackgroundColor()
|
|
|
|
{
|
|
|
|
QColor const & newColor = QColorDialog::getColor(
|
|
|
|
rgb2qcolor(set_boxbgcolor), asQWidget());
|
|
|
|
if (!newColor.isValid())
|
|
|
|
return;
|
|
|
|
// set the button color
|
|
|
|
colorModule->boxBackgroundPB->setStyleSheet(
|
|
|
|
colorButtonStyleSheet(newColor));
|
|
|
|
// save color
|
|
|
|
set_boxbgcolor = rgbFromHexName(fromqstr(newColor.name()));
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-04-08 00:14:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::deleteBoxBackgroundColor()
|
|
|
|
{
|
2011-03-18 14:40:38 +00:00
|
|
|
// set the button color back to pref
|
|
|
|
theApp()->getRgbColor(Color_shadedbg, set_boxbgcolor);
|
2010-04-08 00:14:08 +00:00
|
|
|
colorModule->boxBackgroundPB->setStyleSheet(
|
2011-03-18 14:40:38 +00:00
|
|
|
colorButtonStyleSheet(rgb2qcolor(set_boxbgcolor)));
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2010-04-08 00:14:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-01-05 14:25:36 +01:00
|
|
|
void GuiDocument::updateQuoteStyles(bool const set)
|
|
|
|
{
|
|
|
|
Language const * lang = lyx::languages.getLanguage(
|
|
|
|
fromqstr(langModule->languageCO->itemData(
|
|
|
|
langModule->languageCO->currentIndex()).toString()));
|
|
|
|
|
2020-11-30 22:34:16 +02:00
|
|
|
QuoteStyle def = bp_.getQuoteStyle(lang->quoteStyle());
|
2017-01-05 14:25:36 +01:00
|
|
|
|
|
|
|
langModule->quoteStyleCO->clear();
|
|
|
|
|
|
|
|
bool has_default = false;
|
|
|
|
for (int i = 0; i < quoteparams.stylescount(); ++i) {
|
2020-11-30 22:34:16 +02:00
|
|
|
QuoteStyle qs = QuoteStyle(i);
|
2020-12-01 00:00:40 +02:00
|
|
|
if (qs == QuoteStyle::Dynamic)
|
2017-01-05 14:25:36 +01:00
|
|
|
continue;
|
|
|
|
bool const langdef = (qs == def);
|
|
|
|
if (langdef) {
|
|
|
|
// add the default style on top
|
|
|
|
langModule->quoteStyleCO->insertItem(0,
|
2020-11-30 22:34:16 +02:00
|
|
|
toqstr(quoteparams.getGuiLabel(qs, langdef)), static_cast<int>(qs));
|
2017-01-05 14:25:36 +01:00
|
|
|
has_default = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
langModule->quoteStyleCO->addItem(
|
2020-11-30 22:34:16 +02:00
|
|
|
toqstr(quoteparams.getGuiLabel(qs, langdef)), static_cast<int>(qs));
|
2017-01-05 14:25:36 +01:00
|
|
|
}
|
|
|
|
if (set && has_default)
|
|
|
|
// (re)set to the default style
|
|
|
|
langModule->quoteStyleCO->setCurrentIndex(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-06-08 05:39:00 +02:00
|
|
|
void GuiDocument::languageChanged(int i)
|
|
|
|
{
|
2019-03-16 12:59:34 +01:00
|
|
|
// some languages only work with Polyglossia
|
2012-06-08 12:54:57 +02:00
|
|
|
Language const * lang = lyx::languages.getLanguage(
|
|
|
|
fromqstr(langModule->languageCO->itemData(i).toString()));
|
2019-05-26 01:45:35 +02:00
|
|
|
if (lang->babel().empty() && !lang->polyglossia().empty()
|
2020-02-28 00:36:55 -05:00
|
|
|
&& lang->required() != "CJK" && lang->required() != "japanese") {
|
2013-07-20 16:15:47 +02:00
|
|
|
// If we force to switch fontspec on, store
|
|
|
|
// current state (#8717)
|
|
|
|
if (fontModule->osFontsCB->isEnabled())
|
|
|
|
forced_fontspec_activation =
|
|
|
|
!fontModule->osFontsCB->isChecked();
|
2012-06-08 05:39:00 +02:00
|
|
|
fontModule->osFontsCB->setChecked(true);
|
|
|
|
fontModule->osFontsCB->setEnabled(false);
|
|
|
|
}
|
2013-07-20 16:15:47 +02:00
|
|
|
else {
|
2012-06-08 05:39:00 +02:00
|
|
|
fontModule->osFontsCB->setEnabled(true);
|
2013-07-20 16:15:47 +02:00
|
|
|
// If we have forced to switch fontspec on,
|
|
|
|
// restore previous state (#8717)
|
|
|
|
if (forced_fontspec_activation)
|
|
|
|
fontModule->osFontsCB->setChecked(false);
|
|
|
|
forced_fontspec_activation = false;
|
|
|
|
}
|
2012-07-01 11:27:42 +02:00
|
|
|
|
|
|
|
// set appropriate quotation mark style
|
2017-01-05 14:25:36 +01:00
|
|
|
updateQuoteStyles(true);
|
2012-06-08 05:39:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-11-26 09:42:03 +00:00
|
|
|
void GuiDocument::osFontsChanged(bool nontexfonts)
|
2009-04-06 06:58:30 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
bool const tex_fonts = !nontexfonts;
|
2015-11-09 07:33:57 +01:00
|
|
|
// store current fonts
|
|
|
|
QString const font_roman = fontModule->fontsRomanCO->itemData(
|
|
|
|
fontModule->fontsRomanCO->currentIndex()).toString();
|
|
|
|
QString const font_sans = fontModule->fontsSansCO->itemData(
|
|
|
|
fontModule->fontsSansCO->currentIndex()).toString();
|
|
|
|
QString const font_typewriter = fontModule->fontsTypewriterCO->itemData(
|
|
|
|
fontModule->fontsTypewriterCO->currentIndex()).toString();
|
|
|
|
QString const font_math = fontModule->fontsMathCO->itemData(
|
|
|
|
fontModule->fontsMathCO->currentIndex()).toString();
|
|
|
|
int const font_sf_scale = fontModule->scaleSansSB->value();
|
|
|
|
int const font_tt_scale = fontModule->scaleTypewriterSB->value();
|
|
|
|
|
2009-04-06 06:58:30 +00:00
|
|
|
updateFontlist();
|
2012-06-07 21:27:01 +02:00
|
|
|
// store default format
|
|
|
|
QString const dformat = outputModule->defaultFormatCO->itemData(
|
|
|
|
outputModule->defaultFormatCO->currentIndex()).toString();
|
2009-04-10 11:06:53 +00:00
|
|
|
updateDefaultFormat();
|
2012-06-07 21:27:01 +02:00
|
|
|
// try to restore default format
|
|
|
|
int index = outputModule->defaultFormatCO->findData(dformat);
|
|
|
|
// set to default if format is not found
|
|
|
|
if (index == -1)
|
|
|
|
index = 0;
|
|
|
|
outputModule->defaultFormatCO->setCurrentIndex(index);
|
2015-11-09 07:33:57 +01:00
|
|
|
|
|
|
|
// try to restore fonts which were selected two toggles ago
|
|
|
|
index = fontModule->fontsRomanCO->findData(fontModule->font_roman);
|
|
|
|
if (index != -1)
|
|
|
|
fontModule->fontsRomanCO->setCurrentIndex(index);
|
|
|
|
index = fontModule->fontsSansCO->findData(fontModule->font_sans);
|
|
|
|
if (index != -1)
|
|
|
|
fontModule->fontsSansCO->setCurrentIndex(index);
|
|
|
|
index = fontModule->fontsTypewriterCO->findData(fontModule->font_typewriter);
|
|
|
|
if (index != -1)
|
|
|
|
fontModule->fontsTypewriterCO->setCurrentIndex(index);
|
|
|
|
index = fontModule->fontsMathCO->findData(fontModule->font_math);
|
|
|
|
if (index != -1)
|
|
|
|
fontModule->fontsMathCO->setCurrentIndex(index);
|
|
|
|
// save fonts for next next toggle
|
|
|
|
fontModule->font_roman = font_roman;
|
|
|
|
fontModule->font_sans = font_sans;
|
|
|
|
fontModule->font_typewriter = font_typewriter;
|
|
|
|
fontModule->font_math = font_math;
|
|
|
|
fontModule->font_sf_scale = font_sf_scale;
|
|
|
|
fontModule->font_tt_scale = font_tt_scale;
|
2019-06-12 11:48:47 +02:00
|
|
|
|
|
|
|
// non-tex fonts override the "\inputencoding" option with "utf8-plain"
|
|
|
|
langModule->encodingCO->setEnabled(tex_fonts);
|
|
|
|
inputencodingToDialog();
|
2009-04-10 14:39:22 +00:00
|
|
|
|
2010-11-26 09:42:03 +00:00
|
|
|
fontModule->fontsDefaultCO->setEnabled(tex_fonts);
|
|
|
|
fontModule->fontsDefaultLA->setEnabled(tex_fonts);
|
|
|
|
fontModule->cjkFontLE->setEnabled(tex_fonts);
|
|
|
|
fontModule->cjkFontLA->setEnabled(tex_fonts);
|
2012-08-16 13:23:39 +02:00
|
|
|
|
|
|
|
updateFontOptions();
|
|
|
|
|
|
|
|
fontModule->fontencLA->setEnabled(tex_fonts);
|
|
|
|
fontModule->fontencCO->setEnabled(tex_fonts);
|
|
|
|
if (!tex_fonts)
|
|
|
|
fontModule->fontencLE->setEnabled(false);
|
|
|
|
else
|
2015-05-17 17:27:12 +02:00
|
|
|
fontencChanged(fontModule->fontencCO->currentIndex());
|
2012-08-16 13:23:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-06-12 11:48:47 +02:00
|
|
|
void GuiDocument::encodingSwitched(int i)
|
2019-05-11 11:28:21 +02:00
|
|
|
{
|
2019-06-05 11:16:25 +02:00
|
|
|
bool const tex_fonts = !fontModule->osFontsCB->isChecked();
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->unicodeEncodingCO->setEnabled(tex_fonts);
|
|
|
|
langModule->customEncodingCO->setEnabled(tex_fonts);
|
2019-06-18 15:42:18 +02:00
|
|
|
langModule->autoEncodingCO->setEnabled(tex_fonts);
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->unicodeEncodingCO->setVisible(i == EncodingSets::unicode);
|
2019-06-18 15:42:18 +02:00
|
|
|
langModule->autoEncodingCO->setVisible(i == EncodingSets::legacy);
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->customEncodingCO->setVisible(i == EncodingSets::custom);
|
2019-06-26 08:57:05 +02:00
|
|
|
if (tex_fonts)
|
|
|
|
langModule->unicodeEncodingCO->setItemText(1, qt_("Direct (No inputenc)"));
|
|
|
|
else
|
|
|
|
langModule->unicodeEncodingCO->setItemText(1, qt_("Direct (XeTeX/LuaTeX)"));
|
2019-06-12 11:48:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void GuiDocument::inputencodingToDialog()
|
|
|
|
{
|
|
|
|
QString inputenc = toqstr(bp_.inputenc);
|
|
|
|
int p;
|
|
|
|
if (fontModule->osFontsCB->isChecked()) { // non-tex fonts require utf8-plain
|
|
|
|
langModule->encodingCO->setCurrentIndex(EncodingSets::unicode);
|
|
|
|
langModule->unicodeEncodingCO->setCurrentIndex(
|
|
|
|
langModule->unicodeEncodingCO->findData("utf8-plain"));
|
|
|
|
} else if (inputenc.startsWith("utf8")) {
|
|
|
|
langModule->encodingCO->setCurrentIndex(EncodingSets::unicode);
|
|
|
|
p = langModule->unicodeEncodingCO->findData(inputenc);
|
2019-06-18 15:42:18 +02:00
|
|
|
if (p == -1)
|
|
|
|
p = 0;
|
|
|
|
langModule->unicodeEncodingCO->setCurrentIndex(p);
|
|
|
|
langModule->autoEncodingCO->setCurrentIndex(0);
|
|
|
|
langModule->customEncodingCO->setCurrentIndex(0);
|
2019-06-12 11:48:47 +02:00
|
|
|
} else if (inputenc.startsWith("auto")) {
|
|
|
|
langModule->encodingCO->setCurrentIndex(EncodingSets::legacy);
|
2019-06-18 15:42:18 +02:00
|
|
|
p = langModule->autoEncodingCO->findData(inputenc);
|
|
|
|
if (p == -1)
|
|
|
|
p = 0;
|
|
|
|
langModule->unicodeEncodingCO->setCurrentIndex(0);
|
|
|
|
langModule->autoEncodingCO->setCurrentIndex(p);
|
|
|
|
langModule->customEncodingCO->setCurrentIndex(0);
|
2019-06-12 11:48:47 +02:00
|
|
|
} else {
|
|
|
|
langModule->encodingCO->setCurrentIndex(EncodingSets::custom);
|
|
|
|
p = langModule->customEncodingCO->findData(inputenc);
|
2019-06-18 15:42:18 +02:00
|
|
|
if (p == -1) {
|
|
|
|
p = 0;
|
2019-06-12 11:48:47 +02:00
|
|
|
langModule->encodingCO->setCurrentIndex(EncodingSets::unicode);
|
2019-06-18 15:42:18 +02:00
|
|
|
}
|
|
|
|
langModule->unicodeEncodingCO->setCurrentIndex(0);
|
|
|
|
langModule->autoEncodingCO->setCurrentIndex(0);
|
|
|
|
langModule->customEncodingCO->setCurrentIndex(p);
|
2019-06-12 11:48:47 +02:00
|
|
|
}
|
|
|
|
encodingSwitched(langModule->encodingCO->currentIndex());
|
2019-05-11 11:28:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-09-22 17:44:00 +02:00
|
|
|
void GuiDocument::mathFontChanged(int)
|
|
|
|
{
|
|
|
|
updateFontOptions();
|
|
|
|
}
|
|
|
|
|
2013-02-11 15:02:24 +01:00
|
|
|
void GuiDocument::fontOsfToggled(bool state)
|
|
|
|
{
|
|
|
|
if (fontModule->osFontsCB->isChecked())
|
|
|
|
return;
|
|
|
|
QString font = fontModule->fontsRomanCO->itemData(
|
|
|
|
fontModule->fontsRomanCO->currentIndex()).toString();
|
|
|
|
if (hasMonolithicExpertSet(font))
|
|
|
|
fontModule->fontScCB->setChecked(state);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::fontScToggled(bool state)
|
|
|
|
{
|
|
|
|
if (fontModule->osFontsCB->isChecked())
|
|
|
|
return;
|
|
|
|
QString font = fontModule->fontsRomanCO->itemData(
|
|
|
|
fontModule->fontsRomanCO->currentIndex()).toString();
|
|
|
|
if (hasMonolithicExpertSet(font))
|
|
|
|
fontModule->fontOsfCB->setChecked(state);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-07-13 14:55:07 +02:00
|
|
|
void GuiDocument::updateExtraOpts()
|
2012-08-16 13:23:39 +02:00
|
|
|
{
|
|
|
|
bool const tex_fonts = !fontModule->osFontsCB->isChecked();
|
|
|
|
QString font;
|
2019-07-11 20:28:34 +02:00
|
|
|
if (tex_fonts)
|
|
|
|
font = fontModule->fontsRomanCO->itemData(
|
|
|
|
fontModule->fontsRomanCO->currentIndex()).toString();
|
|
|
|
bool const rm_opts = providesExtraOpts(font);
|
2010-11-26 09:42:03 +00:00
|
|
|
if (tex_fonts)
|
2012-08-16 13:23:39 +02:00
|
|
|
font = fontModule->fontsSansCO->itemData(
|
|
|
|
fontModule->fontsSansCO->currentIndex()).toString();
|
2019-07-11 20:28:34 +02:00
|
|
|
bool const sf_opts = providesExtraOpts(font);
|
2019-07-13 14:55:07 +02:00
|
|
|
if (tex_fonts)
|
|
|
|
font = fontModule->fontsTypewriterCO->itemData(
|
|
|
|
fontModule->fontsTypewriterCO->currentIndex()).toString();
|
|
|
|
bool const tt_opts = providesExtraOpts(font);
|
|
|
|
fontModule->fontspecRomanLA->setEnabled(!tex_fonts || rm_opts);
|
|
|
|
fontModule->fontspecRomanLE->setEnabled(!tex_fonts || rm_opts);
|
|
|
|
fontModule->fontspecSansLA->setEnabled(!tex_fonts || sf_opts);
|
|
|
|
fontModule->fontspecSansLE->setEnabled(!tex_fonts || sf_opts);
|
|
|
|
fontModule->fontspecTypewriterLA->setEnabled(!tex_fonts || tt_opts);
|
|
|
|
fontModule->fontspecTypewriterLE->setEnabled(!tex_fonts || tt_opts);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::updateFontOptions()
|
|
|
|
{
|
|
|
|
bool const tex_fonts = !fontModule->osFontsCB->isChecked();
|
|
|
|
QString font;
|
|
|
|
if (tex_fonts)
|
|
|
|
font = fontModule->fontsSansCO->itemData(
|
|
|
|
fontModule->fontsSansCO->currentIndex()).toString();
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
bool scalable = providesScale(font);
|
|
|
|
fontModule->scaleSansSB->setEnabled(scalable);
|
|
|
|
fontModule->scaleSansLA->setEnabled(scalable);
|
2019-07-14 11:41:36 +02:00
|
|
|
fontModule->fontSansOsfCB->setEnabled(providesOSF(font));
|
2010-11-26 09:42:03 +00:00
|
|
|
if (tex_fonts)
|
2012-08-16 13:23:39 +02:00
|
|
|
font = fontModule->fontsTypewriterCO->itemData(
|
|
|
|
fontModule->fontsTypewriterCO->currentIndex()).toString();
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
scalable = providesScale(font);
|
|
|
|
fontModule->scaleTypewriterSB->setEnabled(scalable);
|
|
|
|
fontModule->scaleTypewriterLA->setEnabled(scalable);
|
2019-07-14 11:41:36 +02:00
|
|
|
fontModule->fontTypewriterOsfCB->setEnabled(providesOSF(font));
|
2010-11-26 09:42:03 +00:00
|
|
|
if (tex_fonts)
|
2012-08-16 13:23:39 +02:00
|
|
|
font = fontModule->fontsRomanCO->itemData(
|
|
|
|
fontModule->fontsRomanCO->currentIndex()).toString();
|
2009-04-10 14:39:22 +00:00
|
|
|
fontModule->fontScCB->setEnabled(providesSC(font));
|
|
|
|
fontModule->fontOsfCB->setEnabled(providesOSF(font));
|
2019-07-13 14:55:07 +02:00
|
|
|
updateExtraOpts();
|
2012-09-22 17:44:00 +02:00
|
|
|
updateMathFonts(font);
|
2009-04-06 06:58:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::updateFontsize(string const & items, string const & sel)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
|
|
|
fontModule->fontsizeCO->clear();
|
2007-06-01 17:44:04 +00:00
|
|
|
fontModule->fontsizeCO->addItem(qt_("Default"));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
for (int n = 0; !token(items,'|',n).empty(); ++n)
|
|
|
|
fontModule->fontsizeCO->
|
|
|
|
addItem(toqstr(token(items,'|',n)));
|
|
|
|
|
|
|
|
for (int n = 0; n < fontModule->fontsizeCO->count(); ++n) {
|
|
|
|
if (fromqstr(fontModule->fontsizeCO->itemText(n)) == sel) {
|
|
|
|
fontModule->fontsizeCO->setCurrentIndex(n);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
bool GuiDocument::ot1() const
|
|
|
|
{
|
|
|
|
QString const fontenc =
|
|
|
|
fontModule->fontencCO->itemData(fontModule->fontencCO->currentIndex()).toString();
|
2018-04-22 19:06:46 +02:00
|
|
|
int const i = langModule->languageCO->currentIndex();
|
|
|
|
if (i == -1)
|
|
|
|
return false;
|
|
|
|
QString const langname = langModule->languageCO->itemData(i).toString();
|
|
|
|
Language const * newlang = lyx::languages.getLanguage(fromqstr(langname));
|
2012-08-16 13:23:39 +02:00
|
|
|
return (fontenc == "default"
|
2018-04-22 19:06:46 +02:00
|
|
|
|| (fontenc == "auto" && newlang->fontenc(buffer().params()) == "OT1")
|
2012-08-16 13:23:39 +02:00
|
|
|
|| (fontenc == "custom" && fontModule->fontencLE->text() == "OT1"));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-09-22 10:59:53 +02:00
|
|
|
bool GuiDocument::completeFontset() const
|
|
|
|
{
|
|
|
|
return (fontModule->fontsSansCO->itemData(
|
|
|
|
fontModule->fontsSansCO->currentIndex()).toString() == "default"
|
|
|
|
&& fontModule->fontsSansCO->itemData(
|
2015-10-10 21:15:55 +02:00
|
|
|
fontModule->fontsTypewriterCO->currentIndex()).toString() == "default");
|
2012-09-22 10:59:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-09-22 17:44:00 +02:00
|
|
|
bool GuiDocument::noMathFont() const
|
|
|
|
{
|
|
|
|
return (fontModule->fontsMathCO->itemData(
|
|
|
|
fontModule->fontsMathCO->currentIndex()).toString() == "default");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
void GuiDocument::updateTexFonts()
|
|
|
|
{
|
|
|
|
LaTeXFonts::TexFontMap texfontmap = theLaTeXFonts().getLaTeXFonts();
|
|
|
|
|
|
|
|
LaTeXFonts::TexFontMap::const_iterator it = texfontmap.begin();
|
|
|
|
LaTeXFonts::TexFontMap::const_iterator end = texfontmap.end();
|
|
|
|
for (; it != end; ++it) {
|
|
|
|
LaTeXFont lf = it->second;
|
2012-08-25 10:48:37 +02:00
|
|
|
if (lf.name().empty()) {
|
|
|
|
LYXERR0("Error: Unnamed font: " << it->first);
|
|
|
|
continue;
|
|
|
|
}
|
2012-08-16 13:23:39 +02:00
|
|
|
docstring const family = lf.family();
|
|
|
|
docstring guiname = translateIfPossible(lf.guiname());
|
2012-09-22 17:44:00 +02:00
|
|
|
if (!lf.available(ot1(), noMathFont()))
|
2012-08-16 13:23:39 +02:00
|
|
|
guiname += _(" (not installed)");
|
|
|
|
if (family == "rm")
|
|
|
|
rmfonts_.insert(toqstr(guiname), toqstr(it->first));
|
|
|
|
else if (family == "sf")
|
|
|
|
sffonts_.insert(toqstr(guiname), toqstr(it->first));
|
|
|
|
else if (family == "tt")
|
|
|
|
ttfonts_.insert(toqstr(guiname), toqstr(it->first));
|
2012-09-22 17:44:00 +02:00
|
|
|
else if (family == "math")
|
|
|
|
mathfonts_.insert(toqstr(guiname), toqstr(it->first));
|
2012-08-16 13:23:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-04-06 06:58:30 +00:00
|
|
|
void GuiDocument::updateFontlist()
|
|
|
|
{
|
2020-07-14 15:52:20 +02:00
|
|
|
// reset the filters of the CategorizedCombos
|
2020-07-14 15:49:15 +02:00
|
|
|
fontModule->fontsRomanCO->resetFilter();
|
|
|
|
fontModule->fontsSansCO->resetFilter();
|
|
|
|
fontModule->fontsTypewriterCO->resetFilter();
|
2009-04-06 06:58:30 +00:00
|
|
|
fontModule->fontsRomanCO->clear();
|
|
|
|
fontModule->fontsSansCO->clear();
|
|
|
|
fontModule->fontsTypewriterCO->clear();
|
2012-09-22 17:44:00 +02:00
|
|
|
fontModule->fontsMathCO->clear();
|
2009-04-06 06:58:30 +00:00
|
|
|
|
2013-07-20 16:15:47 +02:00
|
|
|
// With fontspec (XeTeX, LuaTeX), we have access to all system fonts, but not the LaTeX fonts
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked()) {
|
2011-04-08 20:37:17 +00:00
|
|
|
fontModule->fontsRomanCO->addItem(qt_("Default"), QString("default"));
|
|
|
|
fontModule->fontsSansCO->addItem(qt_("Default"), QString("default"));
|
|
|
|
fontModule->fontsTypewriterCO->addItem(qt_("Default"), QString("default"));
|
2012-09-24 13:19:25 +02:00
|
|
|
QString unimath = qt_("Non-TeX Fonts Default");
|
|
|
|
if (!LaTeXFeatures::isAvailable("unicode-math"))
|
|
|
|
unimath += qt_(" (not available)");
|
|
|
|
fontModule->fontsMathCO->addItem(qt_("Class Default (TeX Fonts)"), QString("auto"));
|
|
|
|
fontModule->fontsMathCO->addItem(unimath, QString("default"));
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2009-04-06 06:58:30 +00:00
|
|
|
QFontDatabase fontdb;
|
|
|
|
QStringList families(fontdb.families());
|
2020-10-09 09:04:20 +03:00
|
|
|
for (auto const & family : families) {
|
|
|
|
fontModule->fontsRomanCO->addItem(family, family);
|
|
|
|
fontModule->fontsSansCO->addItem(family, family);
|
|
|
|
fontModule->fontsTypewriterCO->addItem(family, family);
|
2009-04-06 06:58:30 +00:00
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
if (rmfonts_.empty())
|
|
|
|
updateTexFonts();
|
|
|
|
|
|
|
|
fontModule->fontsRomanCO->addItem(qt_("Default"), QString("default"));
|
|
|
|
QMap<QString, QString>::const_iterator rmi = rmfonts_.constBegin();
|
|
|
|
while (rmi != rmfonts_.constEnd()) {
|
|
|
|
fontModule->fontsRomanCO->addItem(rmi.key(), rmi.value());
|
|
|
|
++rmi;
|
2009-04-06 06:58:30 +00:00
|
|
|
}
|
2015-05-17 17:27:12 +02:00
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
fontModule->fontsSansCO->addItem(qt_("Default"), QString("default"));
|
|
|
|
QMap<QString, QString>::const_iterator sfi = sffonts_.constBegin();
|
|
|
|
while (sfi != sffonts_.constEnd()) {
|
|
|
|
fontModule->fontsSansCO->addItem(sfi.key(), sfi.value());
|
|
|
|
++sfi;
|
2009-04-06 06:58:30 +00:00
|
|
|
}
|
2015-05-17 17:27:12 +02:00
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
fontModule->fontsTypewriterCO->addItem(qt_("Default"), QString("default"));
|
|
|
|
QMap<QString, QString>::const_iterator tti = ttfonts_.constBegin();
|
|
|
|
while (tti != ttfonts_.constEnd()) {
|
|
|
|
fontModule->fontsTypewriterCO->addItem(tti.key(), tti.value());
|
|
|
|
++tti;
|
2009-04-06 06:58:30 +00:00
|
|
|
}
|
2012-09-22 17:44:00 +02:00
|
|
|
|
|
|
|
fontModule->fontsMathCO->addItem(qt_("Automatic"), QString("auto"));
|
|
|
|
fontModule->fontsMathCO->addItem(qt_("Class Default"), QString("default"));
|
|
|
|
QMap<QString, QString>::const_iterator mmi = mathfonts_.constBegin();
|
|
|
|
while (mmi != mathfonts_.constEnd()) {
|
|
|
|
fontModule->fontsMathCO->addItem(mmi.key(), mmi.value());
|
|
|
|
++mmi;
|
|
|
|
}
|
2009-04-06 06:58:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-11-29 14:43:00 +00:00
|
|
|
void GuiDocument::fontencChanged(int item)
|
|
|
|
{
|
2012-08-16 13:23:39 +02:00
|
|
|
fontModule->fontencLE->setEnabled(
|
|
|
|
fontModule->fontencCO->itemData(item).toString() == "custom");
|
|
|
|
// The availability of TeX fonts depends on the font encoding
|
|
|
|
updateTexFonts();
|
|
|
|
updateFontOptions();
|
2009-11-29 14:43:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-09-22 17:44:00 +02:00
|
|
|
void GuiDocument::updateMathFonts(QString const & rm)
|
|
|
|
{
|
|
|
|
if (fontModule->osFontsCB->isChecked())
|
|
|
|
return;
|
|
|
|
QString const math =
|
|
|
|
fontModule->fontsMathCO->itemData(fontModule->fontsMathCO->currentIndex()).toString();
|
|
|
|
int const i = fontModule->fontsMathCO->findData("default");
|
|
|
|
if (providesNoMath(rm) && i == -1)
|
|
|
|
fontModule->fontsMathCO->insertItem(1, qt_("Class Default"), QString("default"));
|
|
|
|
else if (!providesNoMath(rm) && i != -1) {
|
|
|
|
int const c = fontModule->fontsMathCO->currentIndex();
|
|
|
|
fontModule->fontsMathCO->removeItem(i);
|
|
|
|
if (c == i)
|
|
|
|
fontModule->fontsMathCO->setCurrentIndex(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::romanChanged(int item)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked())
|
2009-04-06 06:58:30 +00:00
|
|
|
return;
|
2012-08-16 13:23:39 +02:00
|
|
|
QString const font =
|
|
|
|
fontModule->fontsRomanCO->itemData(item).toString();
|
2007-10-06 22:43:21 +00:00
|
|
|
fontModule->fontScCB->setEnabled(providesSC(font));
|
|
|
|
fontModule->fontOsfCB->setEnabled(providesOSF(font));
|
2019-07-13 14:55:07 +02:00
|
|
|
updateExtraOpts();
|
2012-09-22 17:44:00 +02:00
|
|
|
updateMathFonts(font);
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::sansChanged(int item)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked())
|
2009-04-06 06:58:30 +00:00
|
|
|
return;
|
2012-08-16 13:23:39 +02:00
|
|
|
QString const font =
|
|
|
|
fontModule->fontsSansCO->itemData(item).toString();
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
bool const scalable = providesScale(font);
|
|
|
|
fontModule->scaleSansSB->setEnabled(scalable);
|
|
|
|
fontModule->scaleSansLA->setEnabled(scalable);
|
2019-07-14 11:41:36 +02:00
|
|
|
fontModule->fontSansOsfCB->setEnabled(providesOSF(font));
|
2019-07-13 14:55:07 +02:00
|
|
|
updateExtraOpts();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::ttChanged(int item)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked())
|
2009-04-06 06:58:30 +00:00
|
|
|
return;
|
2012-08-16 13:23:39 +02:00
|
|
|
QString const font =
|
|
|
|
fontModule->fontsTypewriterCO->itemData(item).toString();
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
bool scalable = providesScale(font);
|
|
|
|
fontModule->scaleTypewriterSB->setEnabled(scalable);
|
|
|
|
fontModule->scaleTypewriterLA->setEnabled(scalable);
|
2019-07-14 11:41:36 +02:00
|
|
|
fontModule->fontTypewriterOsfCB->setEnabled(providesOSF(font));
|
2019-07-13 14:55:07 +02:00
|
|
|
updateExtraOpts();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::updatePagestyle(string const & items, string const & sel)
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2007-06-01 17:44:04 +00:00
|
|
|
pagestyles.clear();
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->pagestyleCO->clear();
|
2007-06-01 17:44:04 +00:00
|
|
|
pageLayoutModule->pagestyleCO->addItem(qt_("Default"));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-09-20 12:57:12 +00:00
|
|
|
for (int n = 0; !token(items, '|', n).empty(); ++n) {
|
2007-06-01 17:44:04 +00:00
|
|
|
string style = token(items, '|', n);
|
2008-09-20 12:57:12 +00:00
|
|
|
QString style_gui = qt_(style);
|
|
|
|
pagestyles.push_back(pair<string, QString>(style, style_gui));
|
|
|
|
pageLayoutModule->pagestyleCO->addItem(style_gui);
|
2007-06-01 17:44:04 +00:00
|
|
|
}
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2007-06-01 17:44:04 +00:00
|
|
|
if (sel == "default") {
|
|
|
|
pageLayoutModule->pagestyleCO->setCurrentIndex(0);
|
|
|
|
return;
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
2007-06-01 17:44:04 +00:00
|
|
|
|
2007-09-08 21:00:49 +00:00
|
|
|
int nn = 0;
|
2007-06-01 17:44:04 +00:00
|
|
|
|
2020-10-09 09:04:20 +03:00
|
|
|
for (auto const & pagestyle : pagestyles)
|
|
|
|
if (pagestyle.first == sel)
|
|
|
|
nn = pageLayoutModule->pagestyleCO->findText(pagestyle.second);
|
2007-06-01 17:44:04 +00:00
|
|
|
|
2007-09-08 21:00:49 +00:00
|
|
|
if (nn > 0)
|
2007-09-08 22:08:46 +00:00
|
|
|
pageLayoutModule->pagestyleCO->setCurrentIndex(nn);
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-03-10 21:31:22 +00:00
|
|
|
void GuiDocument::browseLayout()
|
|
|
|
{
|
2017-12-20 11:36:32 +01:00
|
|
|
QString const label1 = qt_("Lay&outs");
|
2008-03-10 21:31:22 +00:00
|
|
|
QString const dir1 = toqstr(lyxrc.document_path);
|
2008-04-20 19:56:01 +00:00
|
|
|
QStringList const filter(qt_("LyX Layout (*.layout)"));
|
2011-06-01 13:18:08 +00:00
|
|
|
QString file = browseRelToParent(QString(), bufferFilePath(),
|
2008-03-10 21:31:22 +00:00
|
|
|
qt_("Local layout file"), filter, false,
|
|
|
|
label1, dir1);
|
|
|
|
|
2008-04-20 21:05:35 +00:00
|
|
|
if (!file.endsWith(".layout"))
|
2008-03-10 21:31:22 +00:00
|
|
|
return;
|
|
|
|
|
2008-04-21 06:36:06 +00:00
|
|
|
FileName layoutFile = support::makeAbsPath(fromqstr(file),
|
2010-04-21 01:19:30 +00:00
|
|
|
fromqstr(bufferFilePath()));
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2008-07-11 02:43:02 +00:00
|
|
|
int const ret = Alert::prompt(_("Local layout file"),
|
|
|
|
_("The layout file you have selected is a local layout\n"
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
"file, not one in the system or user directory.\n"
|
|
|
|
"Your document will not work with this layout if you\n"
|
|
|
|
"move the layout file to a different directory."),
|
2008-07-11 02:43:02 +00:00
|
|
|
1, 1, _("&Set Layout"), _("&Cancel"));
|
|
|
|
if (ret == 1)
|
|
|
|
return;
|
|
|
|
|
2008-03-10 21:31:22 +00:00
|
|
|
// load the layout file
|
|
|
|
LayoutFileList & bcl = LayoutFileList::get();
|
|
|
|
string classname = layoutFile.onlyFileName();
|
2008-07-11 02:43:02 +00:00
|
|
|
// this will update an existing layout if that layout has been loaded before.
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
LayoutFileIndex name = support::onlyFileName(bcl.addLocalLayout(
|
2008-03-10 21:31:22 +00:00
|
|
|
classname.substr(0, classname.size() - 7),
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
layoutFile.onlyPath().absFileName()));
|
2008-03-10 21:31:22 +00:00
|
|
|
|
|
|
|
if (name.empty()) {
|
|
|
|
Alert::error(_("Error"),
|
2011-12-03 22:15:11 +00:00
|
|
|
_("Unable to read local layout file."));
|
2008-03-10 21:31:22 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
const_cast<Buffer &>(buffer()).setLayoutPos(layoutFile.onlyPath().absFileName());
|
|
|
|
|
2008-03-10 21:31:22 +00:00
|
|
|
// do not trigger classChanged if there is no change.
|
|
|
|
if (latexModule->classCO->currentText() == toqstr(name))
|
|
|
|
return;
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2008-03-10 21:31:22 +00:00
|
|
|
// add to combo box
|
2012-10-09 07:22:48 +02:00
|
|
|
bool const avail = latexModule->classCO->set(toqstr(name));
|
|
|
|
if (!avail) {
|
|
|
|
LayoutFile const & tc = bcl[name];
|
|
|
|
docstring const guiname = translateIfPossible(from_utf8(tc.description()));
|
|
|
|
// tooltip sensu "KOMA-Script Article [Class 'scrartcl']"
|
|
|
|
QString tooltip = toqstr(bformat(_("%1$s [Class '%2$s']"), guiname, from_utf8(tc.latexname())));
|
|
|
|
tooltip += '\n' + qt_("This is a local layout file.");
|
|
|
|
latexModule->classCO->addItemSort(toqstr(tc.name()), toqstr(guiname),
|
|
|
|
toqstr(translateIfPossible(from_utf8(tc.category()))),
|
|
|
|
tooltip,
|
|
|
|
true, true, true, true);
|
|
|
|
latexModule->classCO->set(toqstr(name));
|
|
|
|
}
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2008-03-10 21:31:22 +00:00
|
|
|
classChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-04-28 16:38:56 +00:00
|
|
|
void GuiDocument::browseMaster()
|
|
|
|
{
|
|
|
|
QString const title = qt_("Select master document");
|
|
|
|
QString const dir1 = toqstr(lyxrc.document_path);
|
|
|
|
QString const old = latexModule->childDocLE->text();
|
|
|
|
QString const docpath = toqstr(support::onlyPath(buffer().absFileName()));
|
|
|
|
QStringList const filter(qt_("LyX Files (*.lyx)"));
|
2011-06-01 13:18:08 +00:00
|
|
|
QString file = browseRelToSub(old, docpath, title, filter, false,
|
2017-12-20 11:36:32 +01:00
|
|
|
qt_("D&ocuments"), toqstr(lyxrc.document_path));
|
2008-04-28 16:38:56 +00:00
|
|
|
|
2010-01-01 02:45:22 +00:00
|
|
|
if (!file.isEmpty())
|
|
|
|
latexModule->childDocLE->setText(file);
|
2008-04-28 16:38:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
void GuiDocument::classChanged_adaptor()
|
|
|
|
{
|
|
|
|
const_cast<Buffer &>(buffer()).setLayoutPos(string());
|
|
|
|
classChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::classChanged()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2008-02-28 21:04:55 +00:00
|
|
|
int idx = latexModule->classCO->currentIndex();
|
2011-12-03 22:15:11 +00:00
|
|
|
if (idx < 0)
|
2008-02-28 21:04:55 +00:00
|
|
|
return;
|
2012-10-09 07:22:48 +02:00
|
|
|
string const classname = fromqstr(latexModule->classCO->getData(idx));
|
2008-07-11 02:43:02 +00:00
|
|
|
|
2018-07-09 09:46:39 +02:00
|
|
|
if (buttonBox->button(QDialogButtonBox::Apply)->isEnabled()) {
|
2014-12-21 11:49:08 +01:00
|
|
|
int const ret = Alert::prompt(_("Unapplied changes"),
|
|
|
|
_("Some changes in the dialog were not yet applied.\n"
|
|
|
|
"If you do not apply now, they will be lost after this action."),
|
|
|
|
1, 1, _("&Apply"), _("&Dismiss"));
|
|
|
|
if (ret == 0)
|
|
|
|
applyView();
|
2008-01-10 06:22:42 +00:00
|
|
|
}
|
2008-10-14 18:06:08 +00:00
|
|
|
|
|
|
|
// We load the TextClass as soon as it is selected. This is
|
|
|
|
// necessary so that other options in the dialog can be updated
|
2011-12-03 22:15:11 +00:00
|
|
|
// according to the new class. Note, however, that, if you use
|
|
|
|
// the scroll wheel when sitting on the combo box, we'll load a
|
2008-10-14 18:06:08 +00:00
|
|
|
// lot of TextClass objects very quickly....
|
2018-11-16 21:47:24 +01:00
|
|
|
if (!bp_.setBaseClass(classname, buffer().layoutPos())) {
|
2008-10-14 18:06:08 +00:00
|
|
|
Alert::error(_("Error"), _("Unable to set document class."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (lyxrc.auto_reset_options)
|
|
|
|
bp_.useClassDefaults();
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
// With the introduction of modules came a distinction between the base
|
|
|
|
// class and the document class. The former corresponds to the main layout
|
2008-10-12 22:21:56 +00:00
|
|
|
// file; the latter is that plus the modules (or the document-specific layout,
|
2011-12-03 22:15:11 +00:00
|
|
|
// or whatever else there could be). Our parameters come from the document
|
|
|
|
// class. So when we set the base class, we also need to recreate the document
|
2008-10-12 22:02:31 +00:00
|
|
|
// class. Otherwise, we still have the old one.
|
|
|
|
bp_.makeDocumentClass();
|
2008-10-14 16:59:28 +00:00
|
|
|
paramsToDialog();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-02-03 14:17:31 +00:00
|
|
|
void GuiDocument::languagePackageChanged(int i)
|
|
|
|
{
|
2011-09-24 16:39:20 +00:00
|
|
|
langModule->languagePackageLE->setEnabled(
|
2011-02-03 14:17:31 +00:00
|
|
|
langModule->languagePackageCO->itemData(i).toString() == "custom");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-12-12 16:04:00 +00:00
|
|
|
void GuiDocument::biblioChanged()
|
|
|
|
{
|
2011-12-12 16:38:04 +00:00
|
|
|
biblioChanged_ = true;
|
2014-12-21 19:08:41 +01:00
|
|
|
change_adaptor();
|
2011-12-12 16:04:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-02-08 13:25:19 +01:00
|
|
|
void GuiDocument::checkPossibleCiteEngines()
|
|
|
|
{
|
|
|
|
// Check if the class provides a specific engine,
|
|
|
|
// and if so, enforce this.
|
|
|
|
string force_engine;
|
|
|
|
if (documentClass().provides("natbib")
|
|
|
|
|| documentClass().provides("natbib-internal"))
|
|
|
|
force_engine = "natbib";
|
|
|
|
else if (documentClass().provides("jurabib"))
|
|
|
|
force_engine = "jurabib";
|
|
|
|
else if (documentClass().provides("biblatex"))
|
|
|
|
force_engine = "biblatex";
|
|
|
|
else if (documentClass().provides("biblatex-natbib"))
|
|
|
|
force_engine = "biblatex-natbib";
|
|
|
|
|
|
|
|
if (!force_engine.empty())
|
|
|
|
biblioModule->citeEngineCO->setCurrentIndex(
|
|
|
|
biblioModule->citeEngineCO->findData(toqstr(force_engine)));
|
|
|
|
biblioModule->citeEngineCO->setEnabled(force_engine.empty());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-12-31 14:57:09 +01:00
|
|
|
void GuiDocument::rescanBibFiles()
|
|
|
|
{
|
2017-01-08 09:39:46 +01:00
|
|
|
if (isBiblatex())
|
|
|
|
rescanTexStyles("bbx cbx");
|
|
|
|
else
|
|
|
|
rescanTexStyles("bst");
|
2016-12-31 14:57:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
void GuiDocument::resetDefaultBibfile(string const & which)
|
2016-12-31 14:57:09 +01:00
|
|
|
{
|
|
|
|
QString const engine =
|
|
|
|
biblioModule->citeEngineCO->itemData(
|
|
|
|
biblioModule->citeEngineCO->currentIndex()).toString();
|
|
|
|
|
|
|
|
CiteEngineType const cet =
|
|
|
|
CiteEngineType(biblioModule->citeStyleCO->itemData(
|
|
|
|
biblioModule->citeStyleCO->currentIndex()).toInt());
|
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
updateDefaultBiblio(theCiteEnginesList[fromqstr(engine)]->getDefaultBiblio(cet), which);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::resetDefaultBbxBibfile()
|
|
|
|
{
|
|
|
|
resetDefaultBibfile("bbx");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::resetDefaultCbxBibfile()
|
|
|
|
{
|
|
|
|
resetDefaultBibfile("cbx");
|
2016-12-31 14:57:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-12-31 09:28:51 +01:00
|
|
|
void GuiDocument::citeEngineChanged(int n)
|
|
|
|
{
|
2016-12-31 14:57:09 +01:00
|
|
|
QString const engine =
|
|
|
|
biblioModule->citeEngineCO->itemData(n).toString();
|
2016-12-31 09:28:51 +01:00
|
|
|
|
|
|
|
vector<string> const engs =
|
|
|
|
theCiteEnginesList[fromqstr(engine)]->getEngineType();
|
|
|
|
|
|
|
|
updateCiteStyles(engs);
|
2017-01-08 09:39:46 +01:00
|
|
|
updateEngineDependends();
|
2016-12-31 14:57:09 +01:00
|
|
|
resetDefaultBibfile();
|
2016-12-31 09:28:51 +01:00
|
|
|
biblioChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
void GuiDocument::updateEngineDependends()
|
|
|
|
{
|
|
|
|
bool const biblatex = isBiblatex();
|
|
|
|
|
|
|
|
// These are only useful with BibTeX
|
|
|
|
biblioModule->defaultBiblioCO->setEnabled(!biblatex);
|
|
|
|
biblioModule->bibtexStyleLA->setEnabled(!biblatex);
|
|
|
|
biblioModule->resetDefaultBiblioPB->setEnabled(!biblatex);
|
|
|
|
biblioModule->bibtopicCB->setEnabled(!biblatex);
|
|
|
|
|
|
|
|
// These are only useful with Biblatex
|
|
|
|
biblioModule->biblatexBbxCO->setEnabled(biblatex);
|
|
|
|
biblioModule->biblatexBbxLA->setEnabled(biblatex);
|
|
|
|
biblioModule->biblatexCbxCO->setEnabled(biblatex);
|
|
|
|
biblioModule->biblatexCbxLA->setEnabled(biblatex);
|
|
|
|
biblioModule->resetBbxPB->setEnabled(biblatex);
|
|
|
|
biblioModule->resetCbxPB->setEnabled(biblatex);
|
|
|
|
biblioModule->matchBbxPB->setEnabled(biblatex);
|
2017-01-13 18:23:42 +01:00
|
|
|
|
|
|
|
// These are useful with biblatex, jurabib and natbib
|
|
|
|
QString const engine =
|
|
|
|
biblioModule->citeEngineCO->itemData(
|
|
|
|
biblioModule->citeEngineCO->currentIndex()).toString();
|
|
|
|
LyXCiteEngine const * ce = theCiteEnginesList[fromqstr(engine)];
|
|
|
|
|
2020-02-28 00:36:55 -05:00
|
|
|
bool const citepack = ce->required("biblatex.sty") || ce->required("jurabib.sty")
|
|
|
|
|| ce->required("natbib.sty");
|
2017-01-13 18:23:42 +01:00
|
|
|
biblioModule->citePackageOptionsLE->setEnabled(citepack);
|
|
|
|
biblioModule->citePackageOptionsL->setEnabled(citepack);
|
2017-01-08 09:39:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-12-31 14:57:09 +01:00
|
|
|
void GuiDocument::citeStyleChanged()
|
2009-05-22 07:20:00 +00:00
|
|
|
{
|
2016-12-31 14:57:09 +01:00
|
|
|
QString const engine =
|
|
|
|
biblioModule->citeEngineCO->itemData(
|
|
|
|
biblioModule->citeEngineCO->currentIndex()).toString();
|
2017-01-08 09:39:46 +01:00
|
|
|
QString const currentDef = isBiblatex() ?
|
|
|
|
biblioModule->biblatexBbxCO->currentText()
|
|
|
|
: biblioModule->defaultBiblioCO->currentText();
|
|
|
|
if (theCiteEnginesList[fromqstr(engine)]->isDefaultBiblio(fromqstr(currentDef)))
|
2016-12-31 14:57:09 +01:00
|
|
|
resetDefaultBibfile();
|
2009-05-22 07:20:00 +00:00
|
|
|
|
2012-01-09 13:16:38 +00:00
|
|
|
biblioChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-12-31 14:57:09 +01:00
|
|
|
void GuiDocument::bibtexChanged(int n)
|
2012-01-09 13:16:38 +00:00
|
|
|
{
|
2016-12-31 14:57:09 +01:00
|
|
|
biblioModule->bibtexOptionsLE->setEnabled(
|
|
|
|
biblioModule->bibtexCO->itemData(n).toString() != "default");
|
2012-01-09 13:16:38 +00:00
|
|
|
biblioChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-12-31 09:28:51 +01:00
|
|
|
void GuiDocument::updateCiteStyles(vector<string> const & engs, CiteEngineType const & sel)
|
|
|
|
{
|
|
|
|
biblioModule->citeStyleCO->clear();
|
|
|
|
|
|
|
|
vector<string>::const_iterator it = engs.begin();
|
|
|
|
vector<string>::const_iterator end = engs.end();
|
|
|
|
for (; it != end; ++it) {
|
|
|
|
if (*it == "default")
|
|
|
|
biblioModule->citeStyleCO->addItem(qt_("Basic numerical"),
|
|
|
|
ENGINE_TYPE_DEFAULT);
|
|
|
|
else if (*it == "authoryear")
|
|
|
|
biblioModule->citeStyleCO->addItem(qt_("Author-year"),
|
|
|
|
ENGINE_TYPE_AUTHORYEAR);
|
|
|
|
else if (*it == "numerical")
|
|
|
|
biblioModule->citeStyleCO->addItem(qt_("Author-number"),
|
|
|
|
ENGINE_TYPE_NUMERICAL);
|
|
|
|
}
|
|
|
|
int i = biblioModule->citeStyleCO->findData(sel);
|
|
|
|
if (biblioModule->citeStyleCO->findData(sel) == -1)
|
|
|
|
i = 0;
|
|
|
|
biblioModule->citeStyleCO->setCurrentIndex(i);
|
|
|
|
|
|
|
|
biblioModule->citationStyleL->setEnabled(engs.size() > 1);
|
|
|
|
biblioModule->citeStyleCO->setEnabled(engs.size() > 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-03-01 00:41:30 +00:00
|
|
|
void GuiDocument::updateEngineType(string const & items, CiteEngineType const & sel)
|
|
|
|
{
|
|
|
|
engine_types_.clear();
|
|
|
|
|
|
|
|
int nn = 0;
|
|
|
|
|
|
|
|
for (int n = 0; !token(items, '|', n).empty(); ++n) {
|
|
|
|
nn += 1;
|
|
|
|
string style = token(items, '|', n);
|
|
|
|
engine_types_.push_back(style);
|
|
|
|
}
|
|
|
|
|
2016-12-31 09:28:51 +01:00
|
|
|
updateCiteStyles(engine_types_, sel);
|
2012-03-01 00:41:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-01-09 18:51:02 +00:00
|
|
|
namespace {
|
2011-12-03 22:15:11 +00:00
|
|
|
// FIXME unicode
|
2010-10-29 13:06:52 +00:00
|
|
|
// both of these should take a vector<docstring>
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2008-02-24 15:44:11 +00:00
|
|
|
// This is an insanely complicated attempt to make this sort of thing
|
|
|
|
// work with RTL languages.
|
2011-12-03 22:15:11 +00:00
|
|
|
docstring formatStrVec(vector<string> const & v, docstring const & s)
|
2008-01-09 18:51:02 +00:00
|
|
|
{
|
|
|
|
//this mess formats the list as "v[0], v[1], ..., [s] v[n]"
|
2012-05-28 22:41:32 +02:00
|
|
|
if (v.empty())
|
2008-01-09 18:51:02 +00:00
|
|
|
return docstring();
|
2011-12-03 22:15:11 +00:00
|
|
|
if (v.size() == 1)
|
2010-10-29 08:34:26 +00:00
|
|
|
return translateIfPossible(from_utf8(v[0]));
|
2008-09-20 12:57:12 +00:00
|
|
|
if (v.size() == 2) {
|
2008-01-09 18:51:02 +00:00
|
|
|
docstring retval = _("%1$s and %2$s");
|
|
|
|
retval = subst(retval, _("and"), s);
|
2010-10-29 08:34:26 +00:00
|
|
|
return bformat(retval, translateIfPossible(from_utf8(v[0])),
|
|
|
|
translateIfPossible(from_utf8(v[1])));
|
2008-01-09 18:51:02 +00:00
|
|
|
}
|
2008-09-20 12:57:12 +00:00
|
|
|
// The idea here is to format all but the last two items...
|
|
|
|
int const vSize = v.size();
|
2008-01-09 18:51:02 +00:00
|
|
|
docstring t2 = _("%1$s, %2$s");
|
2010-10-29 08:34:26 +00:00
|
|
|
docstring retval = translateIfPossible(from_utf8(v[0]));
|
2008-01-09 18:51:02 +00:00
|
|
|
for (int i = 1; i < vSize - 2; ++i)
|
2011-12-03 22:15:11 +00:00
|
|
|
retval = bformat(t2, retval, translateIfPossible(from_utf8(v[i])));
|
2008-01-09 18:51:02 +00:00
|
|
|
//...and then to plug them, and the last two, into this schema
|
|
|
|
docstring t = _("%1$s, %2$s, and %3$s");
|
|
|
|
t = subst(t, _("and"), s);
|
2010-10-29 08:34:26 +00:00
|
|
|
return bformat(t, retval, translateIfPossible(from_utf8(v[vSize - 2])),
|
|
|
|
translateIfPossible(from_utf8(v[vSize - 1])));
|
2008-01-09 18:51:02 +00:00
|
|
|
}
|
2011-12-03 22:15:11 +00:00
|
|
|
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
vector<string> idsToNames(vector<string> const & idList)
|
|
|
|
{
|
|
|
|
vector<string> retval;
|
|
|
|
vector<string>::const_iterator it = idList.begin();
|
|
|
|
vector<string>::const_iterator end = idList.end();
|
|
|
|
for (; it != end; ++it) {
|
2009-08-14 15:37:34 +00:00
|
|
|
LyXModule const * const mod = theModuleList[*it];
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (!mod)
|
2011-12-03 22:15:11 +00:00
|
|
|
retval.push_back(to_utf8(bformat(_("%1$s (unavailable)"),
|
2010-10-29 13:06:52 +00:00
|
|
|
translateIfPossible(from_utf8(*it)))));
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
else
|
|
|
|
retval.push_back(mod->getName());
|
|
|
|
}
|
|
|
|
return retval;
|
|
|
|
}
|
2010-07-12 17:40:54 +00:00
|
|
|
} // end anonymous namespace
|
2008-01-09 18:51:02 +00:00
|
|
|
|
|
|
|
|
2008-10-20 20:38:40 +00:00
|
|
|
void GuiDocument::modulesToParams(BufferParams & bp)
|
2008-10-20 19:31:05 +00:00
|
|
|
{
|
|
|
|
// update list of loaded modules
|
2008-10-20 20:38:40 +00:00
|
|
|
bp.clearLayoutModules();
|
2008-10-20 19:31:05 +00:00
|
|
|
int const srows = modules_sel_model_.rowCount();
|
|
|
|
for (int i = 0; i < srows; ++i)
|
2008-10-20 20:38:40 +00:00
|
|
|
bp.addLayoutModule(modules_sel_model_.getIDString(i));
|
2019-04-07 11:23:19 +02:00
|
|
|
updateSelectedModules();
|
2008-10-20 19:31:05 +00:00
|
|
|
|
|
|
|
// update the list of removed modules
|
2008-10-20 20:38:40 +00:00
|
|
|
bp.clearRemovedModules();
|
2009-02-12 15:07:22 +00:00
|
|
|
LayoutModuleList const & reqmods = bp.baseClass()->defaultModules();
|
2008-10-20 19:31:05 +00:00
|
|
|
list<string>::const_iterator rit = reqmods.begin();
|
|
|
|
list<string>::const_iterator ren = reqmods.end();
|
|
|
|
|
|
|
|
// check each of the default modules
|
2012-05-28 22:41:32 +02:00
|
|
|
for (; rit != ren; ++rit) {
|
2008-10-20 20:38:40 +00:00
|
|
|
list<string>::const_iterator mit = bp.getModules().begin();
|
|
|
|
list<string>::const_iterator men = bp.getModules().end();
|
2008-10-20 19:31:05 +00:00
|
|
|
bool found = false;
|
2012-05-28 22:41:32 +02:00
|
|
|
for (; mit != men; ++mit) {
|
2008-10-20 19:31:05 +00:00
|
|
|
if (*rit == *mit) {
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!found) {
|
|
|
|
// the module isn't present so must have been removed by the user
|
2008-10-20 20:38:40 +00:00
|
|
|
bp.addRemovedModule(*rit);
|
2008-10-20 19:31:05 +00:00
|
|
|
}
|
|
|
|
}
|
2008-10-20 20:38:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void GuiDocument::modulesChanged()
|
|
|
|
{
|
|
|
|
modulesToParams(bp_);
|
2014-12-21 11:47:59 +01:00
|
|
|
|
2018-07-09 09:46:39 +02:00
|
|
|
if (buttonBox->button(QDialogButtonBox::Apply)->isEnabled()
|
|
|
|
&& (nonModuleChanged_ || shellescapeChanged_)) {
|
2014-12-21 11:47:59 +01:00
|
|
|
int const ret = Alert::prompt(_("Unapplied changes"),
|
|
|
|
_("Some changes in the dialog were not yet applied.\n"
|
|
|
|
"If you do not apply now, they will be lost after this action."),
|
|
|
|
1, 1, _("&Apply"), _("&Dismiss"));
|
|
|
|
if (ret == 0)
|
|
|
|
applyView();
|
|
|
|
}
|
|
|
|
|
2017-08-10 01:32:23 +02:00
|
|
|
modulesChanged_ = true;
|
2008-10-20 19:31:05 +00:00
|
|
|
bp_.makeDocumentClass();
|
|
|
|
paramsToDialog();
|
2014-12-21 19:08:41 +01:00
|
|
|
changed();
|
2008-10-20 19:31:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::updateModuleInfo()
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
{
|
|
|
|
selectionManager->update();
|
2011-12-03 22:15:11 +00:00
|
|
|
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
//Module description
|
2008-10-20 20:31:33 +00:00
|
|
|
bool const focus_on_selected = selectionManager->selectedFocused();
|
2009-08-14 20:37:12 +00:00
|
|
|
QAbstractItemView * lv;
|
2019-04-07 11:23:19 +02:00
|
|
|
bool category = false;
|
|
|
|
if (focus_on_selected) {
|
2009-08-14 20:37:12 +00:00
|
|
|
lv = modulesModule->selectedLV;
|
2019-04-07 11:23:19 +02:00
|
|
|
category = true;
|
|
|
|
} else
|
2012-03-08 16:43:02 +00:00
|
|
|
lv = modulesModule->availableLV;
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (lv->selectionModel()->selectedIndexes().isEmpty()) {
|
2008-10-19 01:21:59 +00:00
|
|
|
modulesModule->infoML->document()->clear();
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
QModelIndex const & idx = lv->selectionModel()->currentIndex();
|
2019-04-07 13:57:41 +02:00
|
|
|
|
|
|
|
if (!focus_on_selected
|
|
|
|
&& modules_av_model_.itemFromIndex(idx)->hasChildren()) {
|
|
|
|
// This is a category header
|
|
|
|
modulesModule->infoML->document()->clear();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-04-07 11:23:19 +02:00
|
|
|
string const modName = focus_on_selected ?
|
|
|
|
modules_sel_model_.getIDString(idx.row())
|
|
|
|
: fromqstr(modules_av_model_.data(idx, Qt::UserRole).toString());
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
docstring desc = getModuleDescription(modName);
|
|
|
|
|
2009-02-12 15:07:22 +00:00
|
|
|
LayoutModuleList const & provmods = bp_.baseClass()->providedModules();
|
2008-10-23 00:27:03 +00:00
|
|
|
if (std::find(provmods.begin(), provmods.end(), modName) != provmods.end()) {
|
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
|
|
|
desc += _("Module provided by document class.");
|
|
|
|
}
|
|
|
|
|
2019-04-07 11:23:19 +02:00
|
|
|
if (category) {
|
|
|
|
docstring cat = getModuleCategory(modName);
|
|
|
|
if (!cat.empty()) {
|
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
|
|
|
desc += bformat(_("<p><b>Category:</b> %1$s.</p>"),
|
|
|
|
translateIfPossible(cat));
|
|
|
|
}
|
2012-03-08 16:43:04 +00:00
|
|
|
}
|
|
|
|
|
2008-10-20 20:31:33 +00:00
|
|
|
vector<string> pkglist = getPackageList(modName);
|
|
|
|
docstring pkgdesc = formatStrVec(pkglist, _("and"));
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (!pkgdesc.empty()) {
|
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
2019-04-07 11:23:19 +02:00
|
|
|
desc += bformat(_("<p><b>Package(s) required:</b> %1$s.</p>"), pkgdesc);
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
2008-10-20 20:31:33 +00:00
|
|
|
pkglist = getRequiredList(modName);
|
|
|
|
if (!pkglist.empty()) {
|
|
|
|
vector<string> const reqdescs = idsToNames(pkglist);
|
|
|
|
pkgdesc = formatStrVec(reqdescs, _("or"));
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
2019-04-07 11:23:19 +02:00
|
|
|
desc += bformat(_("<p><b>Modules required:</b> %1$s.</p>"), pkgdesc);
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
2008-10-20 20:31:33 +00:00
|
|
|
pkglist = getExcludedList(modName);
|
|
|
|
if (!pkglist.empty()) {
|
|
|
|
vector<string> const reqdescs = idsToNames(pkglist);
|
|
|
|
pkgdesc = formatStrVec(reqdescs, _( "and"));
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
2019-04-07 11:23:19 +02:00
|
|
|
desc += bformat(_("<p><b>Modules excluded:</b> %1$s.</p>"), pkgdesc);
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
}
|
2008-01-09 18:51:02 +00:00
|
|
|
|
2018-10-04 14:02:01 -04:00
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
2019-04-07 11:23:19 +02:00
|
|
|
desc += bformat(_("<p><b>Filename:</b> <tt>%1$s.module</tt>.</p>"), from_utf8(modName));
|
2018-10-04 14:02:01 -04:00
|
|
|
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (!isModuleAvailable(modName)) {
|
|
|
|
if (!desc.empty())
|
|
|
|
desc += "\n";
|
2019-04-07 11:23:19 +02:00
|
|
|
desc += _("<p><font color=red><b>WARNING: Some required packages are unavailable!</b></font></p>");
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
}
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
|
2019-04-07 11:23:19 +02:00
|
|
|
modulesModule->infoML->document()->setHtml(toqstr(desc));
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::updateNumbering()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
2008-10-12 15:34:08 +00:00
|
|
|
DocumentClass const & tclass = documentClass();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
numberingModule->tocTW->setUpdatesEnabled(false);
|
|
|
|
numberingModule->tocTW->clear();
|
|
|
|
|
|
|
|
int const depth = numberingModule->depthSL->value();
|
|
|
|
int const toc = numberingModule->tocSL->value();
|
|
|
|
QString const no = qt_("No");
|
|
|
|
QString const yes = qt_("Yes");
|
2020-02-26 22:29:40 -05:00
|
|
|
QTreeWidgetItem * item = nullptr;
|
2008-03-06 05:59:21 +00:00
|
|
|
|
|
|
|
DocumentClass::const_iterator lit = tclass.begin();
|
|
|
|
DocumentClass::const_iterator len = tclass.end();
|
|
|
|
for (; lit != len; ++lit) {
|
2008-03-06 20:01:30 +00:00
|
|
|
int const toclevel = lit->toclevel;
|
2013-02-09 11:09:56 -05:00
|
|
|
if (toclevel != Layout::NOT_IN_TOC && !lit->counter.empty()) {
|
2007-04-24 19:37:34 +00:00
|
|
|
item = new QTreeWidgetItem(numberingModule->tocTW);
|
2008-03-06 20:01:30 +00:00
|
|
|
item->setText(0, toqstr(translateIfPossible(lit->name())));
|
2007-04-24 19:37:34 +00:00
|
|
|
item->setText(1, (toclevel <= depth) ? yes : no);
|
|
|
|
item->setText(2, (toclevel <= toc) ? yes : no);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
numberingModule->tocTW->setUpdatesEnabled(true);
|
|
|
|
numberingModule->tocTW->update();
|
|
|
|
}
|
|
|
|
|
2007-09-20 22:31:18 +00:00
|
|
|
|
2019-03-26 16:23:34 +01:00
|
|
|
void GuiDocument::getTableStyles()
|
|
|
|
{
|
|
|
|
// We look for lyx files in the subdirectory dir of
|
|
|
|
// 1) user_lyxdir
|
|
|
|
// 2) build_lyxdir (if not empty)
|
|
|
|
// 3) system_lyxdir
|
|
|
|
// in this order. Files with a given sub-hierarchy will
|
|
|
|
// only be listed once.
|
|
|
|
// We also consider i18n subdirectories and store them separately.
|
|
|
|
QStringList dirs;
|
|
|
|
|
|
|
|
// The three locations to look at.
|
|
|
|
string const user = addPath(package().user_support().absFileName(), "tabletemplates");
|
|
|
|
string const build = addPath(package().build_support().absFileName(), "tabletemplates");
|
|
|
|
string const system = addPath(package().system_support().absFileName(), "tabletemplates");
|
|
|
|
|
|
|
|
dirs << toqstr(user)
|
|
|
|
<< toqstr(build)
|
|
|
|
<< toqstr(system);
|
|
|
|
|
|
|
|
for (int i = 0; i < dirs.size(); ++i) {
|
2020-10-31 15:09:46 +02:00
|
|
|
QString const & dir = dirs.at(i);
|
2019-03-26 16:23:34 +01:00
|
|
|
QDirIterator it(dir, QDir::Files, QDirIterator::Subdirectories);
|
|
|
|
while (it.hasNext()) {
|
|
|
|
QString fn = QFileInfo(it.next()).fileName();
|
|
|
|
if (!fn.endsWith(".lyx") || fn.contains("_1x"))
|
|
|
|
continue;
|
|
|
|
QString data = fn.left(fn.lastIndexOf(".lyx"));
|
|
|
|
QString guiname = data;
|
|
|
|
guiname = toqstr(translateIfPossible(qstring_to_ucs4(guiname.replace('_', ' '))));
|
|
|
|
QString relpath = toqstr(makeRelPath(qstring_to_ucs4(fn),
|
|
|
|
qstring_to_ucs4(dir)));
|
|
|
|
if (textLayoutModule->tableStyleCO->findData(data) == -1)
|
|
|
|
textLayoutModule->tableStyleCO->addItem(guiname, data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-04-10 11:06:53 +00:00
|
|
|
void GuiDocument::updateDefaultFormat()
|
|
|
|
{
|
2010-02-01 14:44:12 +00:00
|
|
|
if (!bufferview())
|
|
|
|
return;
|
2009-04-10 11:06:53 +00:00
|
|
|
// make a copy in order to consider unapplied changes
|
2011-05-13 22:26:35 +00:00
|
|
|
BufferParams param_copy = buffer().params();
|
|
|
|
param_copy.useNonTeXFonts = fontModule->osFontsCB->isChecked();
|
|
|
|
int const idx = latexModule->classCO->currentIndex();
|
2009-04-10 11:06:53 +00:00
|
|
|
if (idx >= 0) {
|
2012-10-09 07:22:48 +02:00
|
|
|
string const classname = fromqstr(latexModule->classCO->getData(idx));
|
2018-11-16 21:47:24 +01:00
|
|
|
param_copy.setBaseClass(classname, buffer().layoutPos());
|
2014-02-09 11:15:57 +01:00
|
|
|
param_copy.makeDocumentClass(true);
|
2009-04-10 11:06:53 +00:00
|
|
|
}
|
|
|
|
outputModule->defaultFormatCO->blockSignals(true);
|
|
|
|
outputModule->defaultFormatCO->clear();
|
|
|
|
outputModule->defaultFormatCO->addItem(qt_("Default"),
|
|
|
|
QVariant(QString("default")));
|
2016-10-19 18:11:58 -04:00
|
|
|
FormatList const & formats =
|
2016-10-19 17:28:51 -04:00
|
|
|
param_copy.exportableFormats(true);
|
2016-08-28 01:27:37 +01:00
|
|
|
for (Format const * f : formats)
|
|
|
|
outputModule->defaultFormatCO->addItem
|
|
|
|
(toqstr(translateIfPossible(f->prettyname())),
|
|
|
|
QVariant(toqstr(f->name())));
|
2009-04-10 11:06:53 +00:00
|
|
|
outputModule->defaultFormatCO->blockSignals(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-01-07 10:01:26 +00:00
|
|
|
bool GuiDocument::isChildIncluded(string const & child)
|
|
|
|
{
|
|
|
|
if (includeonlys_.empty())
|
|
|
|
return false;
|
|
|
|
return (std::find(includeonlys_.begin(),
|
|
|
|
includeonlys_.end(), child) != includeonlys_.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-20 21:00:33 +00:00
|
|
|
void GuiDocument::applyView()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
|
|
|
// preamble
|
2008-10-20 21:00:33 +00:00
|
|
|
preambleModule->apply(bp_);
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
localLayout->apply(bp_);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-08-14 00:52:33 +00:00
|
|
|
// date
|
|
|
|
bp_.suppress_date = latexModule->suppressDateCB->isChecked();
|
2010-10-13 12:36:53 +00:00
|
|
|
bp_.use_refstyle = latexModule->refstyleCB->isChecked();
|
2009-08-14 00:52:33 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// biblio
|
2016-12-31 09:28:51 +01:00
|
|
|
string const engine =
|
|
|
|
fromqstr(biblioModule->citeEngineCO->itemData(
|
|
|
|
biblioModule->citeEngineCO->currentIndex()).toString());
|
|
|
|
bp_.setCiteEngine(engine);
|
|
|
|
|
|
|
|
CiteEngineType const style = CiteEngineType(biblioModule->citeStyleCO->itemData(
|
|
|
|
biblioModule->citeStyleCO->currentIndex()).toInt());
|
|
|
|
if (theCiteEnginesList[engine]->hasEngineType(style))
|
|
|
|
bp_.setCiteEngineType(style);
|
2012-01-09 13:16:38 +00:00
|
|
|
else
|
2016-12-31 09:28:51 +01:00
|
|
|
bp_.setCiteEngineType(ENGINE_TYPE_DEFAULT);
|
2012-01-09 13:16:38 +00:00
|
|
|
|
2017-02-04 12:02:00 +01:00
|
|
|
bp_.splitbib(biblioModule->bibtopicCB->isChecked());
|
|
|
|
|
|
|
|
bp_.multibib = fromqstr(biblioModule->bibunitsCO->itemData(
|
|
|
|
biblioModule->bibunitsCO->currentIndex()).toString());
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2017-01-01 08:37:56 +01:00
|
|
|
bp_.setDefaultBiblioStyle(fromqstr(biblioModule->defaultBiblioCO->currentText()));
|
2011-12-12 14:45:30 +00:00
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
bp_.biblatex_bibstyle = fromqstr(biblioModule->biblatexBbxCO->currentText());
|
|
|
|
bp_.biblatex_citestyle = fromqstr(biblioModule->biblatexCbxCO->currentText());
|
|
|
|
bp_.biblio_opts = fromqstr(biblioModule->citePackageOptionsLE->text());
|
|
|
|
|
2009-05-22 07:20:00 +00:00
|
|
|
string const bibtex_command =
|
|
|
|
fromqstr(biblioModule->bibtexCO->itemData(
|
|
|
|
biblioModule->bibtexCO->currentIndex()).toString());
|
2009-05-28 00:25:40 +00:00
|
|
|
string const bibtex_options =
|
2011-09-24 16:39:20 +00:00
|
|
|
fromqstr(biblioModule->bibtexOptionsLE->text());
|
2011-02-04 07:37:12 +00:00
|
|
|
if (bibtex_command == "default" || bibtex_options.empty())
|
2009-05-22 07:20:00 +00:00
|
|
|
bp_.bibtex_command = bibtex_command;
|
|
|
|
else
|
2009-05-28 00:25:40 +00:00
|
|
|
bp_.bibtex_command = bibtex_command + " " + bibtex_options;
|
2009-05-22 07:20:00 +00:00
|
|
|
|
2011-12-12 16:38:04 +00:00
|
|
|
if (biblioChanged_) {
|
|
|
|
buffer().invalidateBibinfoCache();
|
|
|
|
buffer().removeBiblioTempFiles();
|
|
|
|
}
|
|
|
|
|
2009-04-16 07:29:01 +00:00
|
|
|
// Indices
|
|
|
|
indicesModule->apply(bp_);
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// language & quotes
|
2019-06-12 11:48:47 +02:00
|
|
|
switch (langModule->encodingCO->currentIndex()) {
|
|
|
|
case EncodingSets::unicode: {
|
2019-06-21 09:54:45 +02:00
|
|
|
if (!fontModule->osFontsCB->isChecked())
|
|
|
|
bp_.inputenc = fromqstr(langModule->unicodeEncodingCO->itemData(
|
|
|
|
langModule->unicodeEncodingCO->currentIndex()).toString());
|
2019-06-12 11:48:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
case EncodingSets::legacy: {
|
|
|
|
bp_.inputenc = "auto-legacy";
|
2019-06-18 15:42:18 +02:00
|
|
|
bp_.inputenc = fromqstr(langModule->autoEncodingCO->itemData(
|
|
|
|
langModule->autoEncodingCO->currentIndex()).toString());
|
2019-06-12 11:48:47 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
case EncodingSets::custom: {
|
|
|
|
bp_.inputenc = fromqstr(langModule->customEncodingCO->itemData(
|
|
|
|
langModule->customEncodingCO->currentIndex()).toString());
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
// this should never happen
|
|
|
|
bp_.inputenc = "utf8";
|
|
|
|
}
|
2020-11-30 22:34:16 +02:00
|
|
|
bp_.quotes_style = QuoteStyle(langModule->quoteStyleCO->itemData(
|
|
|
|
langModule->quoteStyleCO->currentIndex()).toInt());
|
2016-12-25 12:19:02 +01:00
|
|
|
bp_.dynamic_quotes = langModule->dynamicQuotesCB->isChecked();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2015-06-03 12:14:30 +02:00
|
|
|
QString const langname = langModule->languageCO->itemData(
|
2008-05-08 09:18:45 +00:00
|
|
|
langModule->languageCO->currentIndex()).toString();
|
2015-06-03 12:14:30 +02:00
|
|
|
Language const * newlang = lyx::languages.getLanguage(fromqstr(langname));
|
|
|
|
Cursor & cur = const_cast<BufferView *>(bufferview())->cursor();
|
|
|
|
// If current cursor language was the document language, then update it too.
|
|
|
|
if (cur.current_font.language() == bp_.language) {
|
|
|
|
cur.current_font.setLanguage(newlang);
|
|
|
|
cur.real_current_font.setLanguage(newlang);
|
|
|
|
}
|
|
|
|
bp_.language = newlang;
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2011-02-03 14:17:31 +00:00
|
|
|
QString const pack = langModule->languagePackageCO->itemData(
|
|
|
|
langModule->languagePackageCO->currentIndex()).toString();
|
|
|
|
if (pack == "custom")
|
|
|
|
bp_.lang_package =
|
2011-09-24 16:39:20 +00:00
|
|
|
fromqstr(langModule->languagePackageLE->text());
|
2011-02-03 14:17:31 +00:00
|
|
|
else
|
|
|
|
bp_.lang_package = fromqstr(pack);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
//color
|
|
|
|
bp_.backgroundcolor = set_backgroundcolor;
|
2010-04-05 20:31:10 +00:00
|
|
|
bp_.isbackgroundcolor = is_backgroundcolor;
|
2010-04-02 23:39:36 +00:00
|
|
|
bp_.fontcolor = set_fontcolor;
|
|
|
|
bp_.isfontcolor = is_fontcolor;
|
2010-04-02 22:11:50 +00:00
|
|
|
bp_.notefontcolor = set_notefontcolor;
|
2010-04-08 00:14:08 +00:00
|
|
|
bp_.boxbgcolor = set_boxbgcolor;
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// numbering
|
2008-10-20 21:00:33 +00:00
|
|
|
if (bp_.documentClass().hasTocLevels()) {
|
|
|
|
bp_.tocdepth = numberingModule->tocSL->value();
|
|
|
|
bp_.secnumdepth = numberingModule->depthSL->value();
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
2019-05-24 15:40:09 +02:00
|
|
|
bp_.use_lineno = numberingModule->linenoCB->isChecked();
|
2019-05-23 15:13:27 +02:00
|
|
|
bp_.lineno_opts = fromqstr(numberingModule->linenoLE->text());
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// bullets
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.user_defined_bullet(0) = bulletsModule->bullet(0);
|
|
|
|
bp_.user_defined_bullet(1) = bulletsModule->bullet(1);
|
|
|
|
bp_.user_defined_bullet(2) = bulletsModule->bullet(2);
|
|
|
|
bp_.user_defined_bullet(3) = bulletsModule->bullet(3);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// packages
|
2010-11-26 18:42:53 +00:00
|
|
|
bp_.graphics_driver =
|
2007-06-01 17:44:04 +00:00
|
|
|
tex_graphics[latexModule->psdriverCO->currentIndex()];
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2008-01-05 17:04:56 +00:00
|
|
|
// text layout
|
2008-02-28 21:04:55 +00:00
|
|
|
int idx = latexModule->classCO->currentIndex();
|
|
|
|
if (idx >= 0) {
|
2012-10-09 07:22:48 +02:00
|
|
|
string const classname = fromqstr(latexModule->classCO->getData(idx));
|
2018-11-16 21:47:24 +01:00
|
|
|
bp_.setBaseClass(classname, buffer().layoutPos());
|
2008-02-28 21:04:55 +00:00
|
|
|
}
|
2008-01-05 17:04:56 +00:00
|
|
|
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
// Modules
|
2008-10-20 21:00:33 +00:00
|
|
|
modulesToParams(bp_);
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// Math
|
2013-03-01 15:59:37 +01:00
|
|
|
map<string, string> const & packages = BufferParams::auto_packages();
|
|
|
|
for (map<string, string>::const_iterator it = packages.begin();
|
|
|
|
it != packages.end(); ++it) {
|
|
|
|
QTableWidgetItem * item = mathsModule->packagesTW->findItems(toqstr(it->first), Qt::MatchExactly)[0];
|
|
|
|
if (!item)
|
|
|
|
continue;
|
|
|
|
int row = mathsModule->packagesTW->row(item);
|
2018-03-18 12:11:26 +01:00
|
|
|
|
|
|
|
QRadioButton * rb =
|
|
|
|
(QRadioButton*)mathsModule->packagesTW->cellWidget(row, 1)->layout()->itemAt(0)->widget();
|
2013-03-01 15:59:37 +01:00
|
|
|
if (rb->isChecked()) {
|
|
|
|
bp_.use_package(it->first, BufferParams::package_auto);
|
|
|
|
continue;
|
2012-01-03 20:51:07 +00:00
|
|
|
}
|
2018-03-18 12:11:26 +01:00
|
|
|
rb = (QRadioButton*)mathsModule->packagesTW->cellWidget(row, 2)->layout()->itemAt(0)->widget();
|
2013-03-01 15:59:37 +01:00
|
|
|
if (rb->isChecked()) {
|
|
|
|
bp_.use_package(it->first, BufferParams::package_on);
|
|
|
|
continue;
|
|
|
|
}
|
2018-03-18 12:11:26 +01:00
|
|
|
rb = (QRadioButton*)mathsModule->packagesTW->cellWidget(row, 3)->layout()->itemAt(0)->widget();
|
2013-03-01 15:59:37 +01:00
|
|
|
if (rb->isChecked())
|
|
|
|
bp_.use_package(it->first, BufferParams::package_off);
|
2011-08-10 03:37:33 +00:00
|
|
|
}
|
2017-04-19 16:19:18 +02:00
|
|
|
// if math is indented
|
2017-05-09 01:00:36 +02:00
|
|
|
bp_.is_math_indent = mathsModule->MathIndentCB->isChecked();
|
2017-04-19 16:19:18 +02:00
|
|
|
if (bp_.is_math_indent) {
|
2017-04-25 03:01:39 +02:00
|
|
|
// if formulas are indented
|
|
|
|
switch (mathsModule->MathIndentCO->currentIndex()) {
|
|
|
|
case 0:
|
|
|
|
bp_.setMathIndent(Length());
|
|
|
|
break;
|
|
|
|
case 1: {
|
|
|
|
Length mathindent(widgetsToLength(mathsModule->MathIndentLE,
|
|
|
|
mathsModule->MathIndentLengthCO));
|
|
|
|
bp_.setMathIndent(mathindent);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
// this should never happen
|
|
|
|
bp_.setMathIndent(Length());
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2017-04-25 02:28:10 +02:00
|
|
|
switch (mathsModule->MathNumberingPosCO->currentIndex()) {
|
|
|
|
case 0:
|
2017-05-13 20:39:45 +02:00
|
|
|
bp_.math_numbering_side = BufferParams::LEFT;
|
2017-04-25 02:28:10 +02:00
|
|
|
break;
|
|
|
|
case 1:
|
2017-05-13 20:39:45 +02:00
|
|
|
bp_.math_numbering_side = BufferParams::DEFAULT;
|
2017-05-12 01:06:05 +02:00
|
|
|
break;
|
|
|
|
case 2:
|
2017-05-13 20:39:45 +02:00
|
|
|
bp_.math_numbering_side = BufferParams::RIGHT;
|
2017-04-25 02:28:10 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// this should never happen
|
2017-05-13 20:39:45 +02:00
|
|
|
bp_.math_numbering_side = BufferParams::DEFAULT;
|
2017-04-25 02:28:10 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// Page Layout
|
2007-06-01 17:44:04 +00:00
|
|
|
if (pageLayoutModule->pagestyleCO->currentIndex() == 0)
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.pagestyle = "default";
|
2007-06-01 17:44:04 +00:00
|
|
|
else {
|
2008-09-20 12:57:12 +00:00
|
|
|
QString style_gui = pageLayoutModule->pagestyleCO->currentText();
|
|
|
|
for (size_t i = 0; i != pagestyles.size(); ++i)
|
2007-06-01 17:44:04 +00:00
|
|
|
if (pagestyles[i].second == style_gui)
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.pagestyle = pagestyles[i].first;
|
2007-06-01 17:44:04 +00:00
|
|
|
}
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// Text Layout
|
2007-04-24 19:37:34 +00:00
|
|
|
switch (textLayoutModule->lspacingCO->currentIndex()) {
|
|
|
|
case 0:
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.spacing().set(Spacing::Single);
|
2007-04-24 19:37:34 +00:00
|
|
|
break;
|
|
|
|
case 1:
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.spacing().set(Spacing::Onehalf);
|
2007-04-24 19:37:34 +00:00
|
|
|
break;
|
|
|
|
case 2:
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.spacing().set(Spacing::Double);
|
2007-04-24 19:37:34 +00:00
|
|
|
break;
|
2010-05-14 19:12:59 +00:00
|
|
|
case 3: {
|
|
|
|
string s = widgetToDoubleStr(textLayoutModule->lspacingLE);
|
|
|
|
if (s.empty())
|
|
|
|
bp_.spacing().set(Spacing::Single);
|
|
|
|
else
|
|
|
|
bp_.spacing().set(Spacing::Other, s);
|
2007-04-24 19:37:34 +00:00
|
|
|
break;
|
2010-05-14 19:12:59 +00:00
|
|
|
}
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (textLayoutModule->twoColumnCB->isChecked())
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.columns = 2;
|
2007-04-24 19:37:34 +00:00
|
|
|
else
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.columns = 1;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2011-12-07 22:33:25 +00:00
|
|
|
bp_.justification = textLayoutModule->justCB->isChecked();
|
|
|
|
|
2009-07-19 21:13:27 +00:00
|
|
|
if (textLayoutModule->indentRB->isChecked()) {
|
|
|
|
// if paragraphs are separated by an indentation
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.paragraph_separation = BufferParams::ParagraphIndentSeparation;
|
2009-07-19 21:13:27 +00:00
|
|
|
switch (textLayoutModule->indentCO->currentIndex()) {
|
|
|
|
case 0:
|
2017-04-13 22:51:48 +02:00
|
|
|
bp_.setParIndent(Length());
|
2009-07-19 21:13:27 +00:00
|
|
|
break;
|
2017-04-19 17:49:11 +02:00
|
|
|
case 1: {
|
|
|
|
Length parindent(widgetsToLength(textLayoutModule->indentLE,
|
|
|
|
textLayoutModule->indentLengthCO));
|
|
|
|
bp_.setParIndent(parindent);
|
2009-07-19 21:13:27 +00:00
|
|
|
break;
|
2017-04-19 17:49:11 +02:00
|
|
|
}
|
2009-07-19 21:13:27 +00:00
|
|
|
default:
|
|
|
|
// this should never happen
|
2017-04-13 22:51:48 +02:00
|
|
|
bp_.setParIndent(Length());
|
2009-07-19 21:13:27 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// if paragraphs are separated by a skip
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.paragraph_separation = BufferParams::ParagraphSkipSeparation;
|
2020-06-28 17:20:18 +02:00
|
|
|
VSpace::VSpaceKind spacekind =
|
|
|
|
VSpace::VSpaceKind(textLayoutModule->skipCO->itemData(textLayoutModule->skipCO->currentIndex()).toInt());
|
|
|
|
switch (spacekind) {
|
|
|
|
case VSpace::SMALLSKIP:
|
|
|
|
case VSpace::MEDSKIP:
|
|
|
|
case VSpace::BIGSKIP:
|
|
|
|
case VSpace::HALFLINE:
|
|
|
|
case VSpace::FULLLINE:
|
|
|
|
bp_.setDefSkip(VSpace(spacekind));
|
2009-07-19 21:13:27 +00:00
|
|
|
break;
|
2020-06-28 17:20:18 +02:00
|
|
|
case VSpace::LENGTH: {
|
2009-07-19 21:13:27 +00:00
|
|
|
VSpace vs = VSpace(
|
|
|
|
widgetsToLength(textLayoutModule->skipLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->skipLengthCO)
|
2009-07-19 21:13:27 +00:00
|
|
|
);
|
|
|
|
bp_.setDefSkip(vs);
|
|
|
|
break;
|
2020-06-28 17:20:18 +02:00
|
|
|
}
|
2009-07-19 21:13:27 +00:00
|
|
|
default:
|
|
|
|
// this should never happen
|
|
|
|
bp_.setDefSkip(VSpace(VSpace::MEDSKIP));
|
|
|
|
break;
|
|
|
|
}
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
2019-03-26 16:23:34 +01:00
|
|
|
bp_.tablestyle = fromqstr(textLayoutModule->tableStyleCO->itemData(
|
|
|
|
textLayoutModule->tableStyleCO->currentIndex()).toString());
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.options =
|
2007-04-24 19:37:34 +00:00
|
|
|
fromqstr(latexModule->optionsLE->text());
|
|
|
|
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.use_default_options =
|
2008-10-12 09:36:00 +00:00
|
|
|
latexModule->defaultOptionsCB->isChecked();
|
|
|
|
|
2008-04-28 16:38:56 +00:00
|
|
|
if (latexModule->childDocGB->isChecked())
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.master =
|
2008-04-28 16:38:56 +00:00
|
|
|
fromqstr(latexModule->childDocLE->text());
|
|
|
|
else
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.master = string();
|
2008-04-28 16:38:56 +00:00
|
|
|
|
2010-01-07 10:01:26 +00:00
|
|
|
// Master/Child
|
|
|
|
bp_.clearIncludedChildren();
|
|
|
|
if (masterChildModule->includeonlyRB->isChecked()) {
|
|
|
|
list<string>::const_iterator it = includeonlys_.begin();
|
|
|
|
for (; it != includeonlys_.end() ; ++it) {
|
|
|
|
bp_.addIncludedChildren(*it);
|
|
|
|
}
|
|
|
|
}
|
2020-03-13 15:46:35 +01:00
|
|
|
if (masterChildModule->maintainCRNoneRB->isChecked())
|
|
|
|
bp_.maintain_unincluded_children =
|
|
|
|
BufferParams::CM_None;
|
|
|
|
else if (masterChildModule->maintainCRMostlyRB->isChecked())
|
|
|
|
bp_.maintain_unincluded_children =
|
|
|
|
BufferParams::CM_Mostly;
|
|
|
|
else
|
|
|
|
bp_.maintain_unincluded_children =
|
|
|
|
BufferParams::CM_Strict;
|
2020-03-12 10:37:56 +01:00
|
|
|
updateIncludeonlyDisplay();
|
2010-01-07 10:01:26 +00:00
|
|
|
|
2018-05-10 20:15:11 +02:00
|
|
|
// Float Settings
|
|
|
|
bp_.float_placement = floatModule->getPlacement();
|
|
|
|
bp_.float_alignment = floatModule->getAlignment();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// Listings
|
|
|
|
// text should have passed validation
|
2017-06-12 17:24:26 +02:00
|
|
|
idx = listingsModule->packageCO->currentIndex();
|
|
|
|
bp_.use_minted = string(lst_packages[idx]) == "Minted";
|
2009-07-20 08:09:32 +00:00
|
|
|
bp_.listings_params =
|
|
|
|
InsetListingsParams(fromqstr(listingsModule->listingsED->toPlainText())).params();
|
|
|
|
|
2016-08-28 16:51:15 +01:00
|
|
|
// Formats
|
2010-11-26 18:42:53 +00:00
|
|
|
bp_.default_output_format = fromqstr(outputModule->defaultFormatCO->itemData(
|
2009-04-10 11:06:53 +00:00
|
|
|
outputModule->defaultFormatCO->currentIndex()).toString());
|
|
|
|
|
2010-11-26 09:42:03 +00:00
|
|
|
bool const nontexfonts = fontModule->osFontsCB->isChecked();
|
|
|
|
bp_.useNonTeXFonts = nontexfonts;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2017-08-03 13:07:41 +02:00
|
|
|
bp_.shell_escape = outputModule->shellescapeCB->isChecked();
|
2017-08-10 01:32:23 +02:00
|
|
|
if (!bp_.shell_escape)
|
|
|
|
theSession().shellescapeFiles().remove(buffer().absFileName());
|
|
|
|
else if (!theSession().shellescapeFiles().find(buffer().absFileName()))
|
|
|
|
theSession().shellescapeFiles().insert(buffer().absFileName());
|
|
|
|
Buffer & buf = const_cast<Buffer &>(buffer());
|
|
|
|
buf.params().shell_escape = bp_.shell_escape;
|
2017-08-03 13:07:41 +02:00
|
|
|
|
2010-05-25 11:36:00 +00:00
|
|
|
bp_.output_sync = outputModule->outputsyncCB->isChecked();
|
2015-05-17 17:27:12 +02:00
|
|
|
|
2010-05-25 11:36:00 +00:00
|
|
|
bp_.output_sync_macro = fromqstr(outputModule->synccustomCB->currentText());
|
|
|
|
|
2010-04-21 15:20:31 +00:00
|
|
|
int mathfmt = outputModule->mathoutCB->currentIndex();
|
|
|
|
if (mathfmt == -1)
|
|
|
|
mathfmt = 0;
|
|
|
|
BufferParams::MathOutput const mo =
|
|
|
|
static_cast<BufferParams::MathOutput>(mathfmt);
|
|
|
|
bp_.html_math_output = mo;
|
|
|
|
bp_.html_be_strict = outputModule->strictCB->isChecked();
|
2011-12-06 22:17:26 +00:00
|
|
|
bp_.html_css_as_file = outputModule->cssCB->isChecked();
|
2010-04-21 15:20:31 +00:00
|
|
|
bp_.html_math_img_scale = outputModule->mathimgSB->value();
|
2014-10-18 15:52:43 +02:00
|
|
|
bp_.display_pixel_ratio = theGuiApp()->pixelRatio();
|
2010-04-21 15:20:31 +00:00
|
|
|
|
2020-07-13 03:31:48 +02:00
|
|
|
int tablefmt = outputModule->tableoutCB->currentIndex();
|
|
|
|
if (tablefmt == -1)
|
|
|
|
tablefmt = 0;
|
|
|
|
BufferParams::TableOutput const to =
|
|
|
|
static_cast<BufferParams::TableOutput>(tablefmt);
|
|
|
|
bp_.docbook_table_output = to;
|
|
|
|
|
2016-07-08 16:36:05 +01:00
|
|
|
bp_.save_transient_properties =
|
|
|
|
outputModule->saveTransientPropertiesCB->isChecked();
|
2020-01-10 10:21:09 +01:00
|
|
|
bp_.postpone_fragile_content =
|
|
|
|
outputModule->postponeFragileCB->isChecked();
|
2016-07-08 16:36:05 +01:00
|
|
|
|
2009-04-10 11:06:53 +00:00
|
|
|
// fonts
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_roman[nontexfonts] =
|
2011-04-08 20:37:17 +00:00
|
|
|
fromqstr(fontModule->fontsRomanCO->
|
|
|
|
itemData(fontModule->fontsRomanCO->currentIndex()).toString());
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_roman[!nontexfonts] = fromqstr(fontModule->font_roman);
|
2019-07-11 20:28:34 +02:00
|
|
|
bp_.font_roman_opts = fromqstr(fontModule->fontspecRomanLE->text());
|
2011-04-08 20:37:17 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_sans[nontexfonts] =
|
2011-04-08 20:37:17 +00:00
|
|
|
fromqstr(fontModule->fontsSansCO->
|
|
|
|
itemData(fontModule->fontsSansCO->currentIndex()).toString());
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_sans[!nontexfonts] = fromqstr(fontModule->font_sans);
|
2019-07-11 20:28:34 +02:00
|
|
|
bp_.font_sans_opts = fromqstr(fontModule->fontspecSansLE->text());
|
2011-04-08 20:37:17 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_typewriter[nontexfonts] =
|
2011-04-08 20:37:17 +00:00
|
|
|
fromqstr(fontModule->fontsTypewriterCO->
|
|
|
|
itemData(fontModule->fontsTypewriterCO->currentIndex()).toString());
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_typewriter[!nontexfonts] = fromqstr(fontModule->font_typewriter);
|
2019-07-11 20:28:34 +02:00
|
|
|
bp_.font_typewriter_opts = fromqstr(fontModule->fontspecTypewriterLE->text());
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_math[nontexfonts] =
|
2012-09-22 17:44:00 +02:00
|
|
|
fromqstr(fontModule->fontsMathCO->
|
|
|
|
itemData(fontModule->fontsMathCO->currentIndex()).toString());
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_math[!nontexfonts] = fromqstr(fontModule->font_math);
|
2012-09-22 17:44:00 +02:00
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
QString const fontenc =
|
|
|
|
fontModule->fontencCO->itemData(fontModule->fontencCO->currentIndex()).toString();
|
|
|
|
if (fontenc == "custom")
|
2009-11-29 14:43:00 +00:00
|
|
|
bp_.fontenc = fromqstr(fontModule->fontencLE->text());
|
2012-08-16 13:23:39 +02:00
|
|
|
else
|
|
|
|
bp_.fontenc = fromqstr(fontenc);
|
2009-11-29 14:43:00 +00:00
|
|
|
|
2010-11-26 18:32:29 +00:00
|
|
|
bp_.fonts_cjk =
|
2008-06-05 06:18:34 +00:00
|
|
|
fromqstr(fontModule->cjkFontLE->text());
|
|
|
|
|
2016-06-02 22:40:21 -07:00
|
|
|
bp_.use_microtype = fontModule->microtypeCB->isChecked();
|
2017-12-16 16:11:25 +01:00
|
|
|
bp_.use_dash_ligatures = !fontModule->dashesCB->isChecked();
|
2016-06-02 22:40:21 -07:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_sans_scale[nontexfonts] = fontModule->scaleSansSB->value();
|
|
|
|
bp_.fonts_sans_scale[!nontexfonts] = fontModule->font_sf_scale;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
bp_.fonts_typewriter_scale[nontexfonts] = fontModule->scaleTypewriterSB->value();
|
|
|
|
bp_.fonts_typewriter_scale[!nontexfonts] = fontModule->font_tt_scale;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-11-26 18:32:29 +00:00
|
|
|
bp_.fonts_expert_sc = fontModule->fontScCB->isChecked();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2019-07-14 11:41:36 +02:00
|
|
|
bp_.fonts_roman_osf = fontModule->fontOsfCB->isChecked();
|
|
|
|
bp_.fonts_sans_osf = fontModule->fontSansOsfCB->isChecked();
|
|
|
|
bp_.fonts_typewriter_osf = fontModule->fontTypewriterOsfCB->isChecked();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2010-11-26 09:42:03 +00:00
|
|
|
if (nontexfonts)
|
2010-11-26 18:32:29 +00:00
|
|
|
bp_.fonts_default_family = "default";
|
2009-04-07 08:39:56 +00:00
|
|
|
else
|
2010-11-26 18:32:29 +00:00
|
|
|
bp_.fonts_default_family = GuiDocument::fontfamilies[
|
2009-04-07 08:39:56 +00:00
|
|
|
fontModule->fontsDefaultCO->currentIndex()];
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
if (fontModule->fontsizeCO->currentIndex() == 0)
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.fontsize = "default";
|
2007-04-24 19:37:34 +00:00
|
|
|
else
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.fontsize =
|
2007-04-24 19:37:34 +00:00
|
|
|
fromqstr(fontModule->fontsizeCO->currentText());
|
|
|
|
|
|
|
|
// paper
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.papersize = PAPER_SIZE(
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->papersizeCO->currentIndex());
|
|
|
|
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.paperwidth = widgetsToLength(pageLayoutModule->paperwidthLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->paperwidthUnitCO);
|
|
|
|
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.paperheight = widgetsToLength(pageLayoutModule->paperheightLE,
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->paperheightUnitCO);
|
|
|
|
|
|
|
|
if (pageLayoutModule->facingPagesCB->isChecked())
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.sides = TwoSides;
|
2007-04-24 19:37:34 +00:00
|
|
|
else
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.sides = OneSide;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
if (pageLayoutModule->landscapeRB->isChecked())
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.orientation = ORIENTATION_LANDSCAPE;
|
2007-04-24 19:37:34 +00:00
|
|
|
else
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.orientation = ORIENTATION_PORTRAIT;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// margins
|
2010-05-18 02:56:36 +00:00
|
|
|
bp_.use_geometry = !marginsModule->marginCB->isChecked();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-03-08 07:59:47 +00:00
|
|
|
Ui::MarginsUi const * m = marginsModule;
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-10-20 21:00:33 +00:00
|
|
|
bp_.leftmargin = widgetsToLength(m->innerLE, m->innerUnit);
|
|
|
|
bp_.topmargin = widgetsToLength(m->topLE, m->topUnit);
|
|
|
|
bp_.rightmargin = widgetsToLength(m->outerLE, m->outerUnit);
|
|
|
|
bp_.bottommargin = widgetsToLength(m->bottomLE, m->bottomUnit);
|
|
|
|
bp_.headheight = widgetsToLength(m->headheightLE, m->headheightUnit);
|
|
|
|
bp_.headsep = widgetsToLength(m->headsepLE, m->headsepUnit);
|
|
|
|
bp_.footskip = widgetsToLength(m->footskipLE, m->footskipUnit);
|
|
|
|
bp_.columnsep = widgetsToLength(m->columnsepLE, m->columnsepUnit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-07-11 10:53:29 +00:00
|
|
|
// branches
|
2008-10-20 21:00:33 +00:00
|
|
|
branchesModule->apply(bp_);
|
2007-09-20 22:31:18 +00:00
|
|
|
|
|
|
|
// PDF support
|
2008-10-20 21:00:33 +00:00
|
|
|
PDFOptions & pdf = bp_.pdfoptions();
|
2007-09-22 22:20:15 +00:00
|
|
|
pdf.use_hyperref = pdfSupportModule->use_hyperrefGB->isChecked();
|
2007-09-21 01:00:31 +00:00
|
|
|
pdf.title = fromqstr(pdfSupportModule->titleLE->text());
|
|
|
|
pdf.author = fromqstr(pdfSupportModule->authorLE->text());
|
|
|
|
pdf.subject = fromqstr(pdfSupportModule->subjectLE->text());
|
|
|
|
pdf.keywords = fromqstr(pdfSupportModule->keywordsLE->text());
|
|
|
|
|
|
|
|
pdf.bookmarks = pdfSupportModule->bookmarksGB->isChecked();
|
|
|
|
pdf.bookmarksnumbered = pdfSupportModule->bookmarksnumberedCB->isChecked();
|
|
|
|
pdf.bookmarksopen = pdfSupportModule->bookmarksopenGB->isChecked();
|
2007-09-22 22:20:15 +00:00
|
|
|
pdf.bookmarksopenlevel = pdfSupportModule->bookmarksopenlevelSB->value();
|
2007-09-20 22:31:18 +00:00
|
|
|
|
2007-09-21 01:00:31 +00:00
|
|
|
pdf.breaklinks = pdfSupportModule->breaklinksCB->isChecked();
|
|
|
|
pdf.pdfborder = pdfSupportModule->pdfborderCB->isChecked();
|
2007-10-10 00:34:23 +00:00
|
|
|
pdf.pdfusetitle = pdfSupportModule->pdfusetitleCB->isChecked();
|
2007-09-21 01:00:31 +00:00
|
|
|
pdf.colorlinks = pdfSupportModule->colorlinksCB->isChecked();
|
2008-10-13 16:01:02 +00:00
|
|
|
pdf.backref =
|
|
|
|
backref_opts[pdfSupportModule->backrefCO->currentIndex()];
|
2007-09-20 22:31:18 +00:00
|
|
|
if (pdfSupportModule->fullscreenCB->isChecked())
|
2007-09-21 01:00:31 +00:00
|
|
|
pdf.pagemode = pdf.pagemode_fullscreen;
|
2007-09-22 22:20:15 +00:00
|
|
|
else
|
|
|
|
pdf.pagemode.clear();
|
2008-03-05 01:14:15 +00:00
|
|
|
pdf.quoted_options = pdf.quoted_options_check(
|
|
|
|
fromqstr(pdfSupportModule->optionsLE->text()));
|
2014-12-21 19:08:41 +01:00
|
|
|
|
2019-12-24 18:12:22 +01:00
|
|
|
// change tracking
|
|
|
|
bp_.track_changes = changesModule->trackChangesCB->isChecked();
|
|
|
|
bp_.output_changes = changesModule->outputChangesCB->isChecked();
|
|
|
|
bool const cb_switched_off = (bp_.change_bars
|
|
|
|
&& !changesModule->changeBarsCB->isChecked());
|
|
|
|
bp_.change_bars = changesModule->changeBarsCB->isChecked();
|
|
|
|
if (cb_switched_off)
|
|
|
|
// if change bars have been switched off,
|
|
|
|
// we need to ditch the aux file
|
|
|
|
buffer().requireFreshStart(true);
|
|
|
|
|
2017-08-10 01:32:23 +02:00
|
|
|
// reset trackers
|
2014-12-21 19:08:41 +01:00
|
|
|
nonModuleChanged_ = false;
|
2017-08-10 01:32:23 +02:00
|
|
|
shellescapeChanged_ = false;
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-14 16:59:28 +00:00
|
|
|
void GuiDocument::paramsToDialog()
|
2007-04-24 19:37:34 +00:00
|
|
|
{
|
|
|
|
// set the default unit
|
2011-10-27 11:49:15 +00:00
|
|
|
Length::UNIT const default_unit = Length::defaultUnit();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// preamble
|
2008-10-14 16:59:28 +00:00
|
|
|
preambleModule->update(bp_, id());
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
localLayout->update(bp_, id());
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-08-14 00:52:33 +00:00
|
|
|
// date
|
|
|
|
latexModule->suppressDateCB->setChecked(bp_.suppress_date);
|
2010-10-13 12:36:53 +00:00
|
|
|
latexModule->refstyleCB->setChecked(bp_.use_refstyle);
|
2009-08-14 00:52:33 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// biblio
|
2018-05-20 12:27:03 +02:00
|
|
|
string const cite_engine = bp_.citeEngine();
|
2012-03-01 00:41:30 +00:00
|
|
|
|
2016-12-31 09:28:51 +01:00
|
|
|
biblioModule->citeEngineCO->setCurrentIndex(
|
|
|
|
biblioModule->citeEngineCO->findData(toqstr(cite_engine)));
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2012-03-01 00:41:30 +00:00
|
|
|
updateEngineType(documentClass().opt_enginetype(),
|
|
|
|
bp_.citeEngineType());
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2018-02-08 13:25:19 +01:00
|
|
|
checkPossibleCiteEngines();
|
|
|
|
|
2016-12-31 09:28:51 +01:00
|
|
|
biblioModule->citeStyleCO->setCurrentIndex(
|
|
|
|
biblioModule->citeStyleCO->findData(bp_.citeEngineType()));
|
|
|
|
|
2017-02-04 12:02:00 +01:00
|
|
|
biblioModule->bibtopicCB->setChecked(bp_.splitbib());
|
|
|
|
|
|
|
|
biblioModule->bibunitsCO->clear();
|
|
|
|
biblioModule->bibunitsCO->addItem(qt_("No"), QString());
|
|
|
|
if (documentClass().hasLaTeXLayout("part"))
|
|
|
|
biblioModule->bibunitsCO->addItem(qt_("per part"), toqstr("part"));
|
|
|
|
if (documentClass().hasLaTeXLayout("chapter"))
|
|
|
|
biblioModule->bibunitsCO->addItem(qt_("per chapter"), toqstr("chapter"));
|
|
|
|
if (documentClass().hasLaTeXLayout("section"))
|
|
|
|
biblioModule->bibunitsCO->addItem(qt_("per section"), toqstr("section"));
|
|
|
|
if (documentClass().hasLaTeXLayout("subsection"))
|
|
|
|
biblioModule->bibunitsCO->addItem(qt_("per subsection"), toqstr("subsection"));
|
2017-02-04 19:23:46 +01:00
|
|
|
biblioModule->bibunitsCO->addItem(qt_("per child document"), toqstr("child"));
|
2017-02-04 12:02:00 +01:00
|
|
|
|
|
|
|
int const mbpos = biblioModule->bibunitsCO->findData(toqstr(bp_.multibib));
|
|
|
|
if (mbpos != -1)
|
|
|
|
biblioModule->bibunitsCO->setCurrentIndex(mbpos);
|
|
|
|
else
|
|
|
|
biblioModule->bibunitsCO->setCurrentIndex(0);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
updateEngineDependends();
|
|
|
|
|
|
|
|
if (isBiblatex()) {
|
|
|
|
updateDefaultBiblio(bp_.biblatex_bibstyle, "bbx");
|
|
|
|
updateDefaultBiblio(bp_.biblatex_citestyle, "cbx");
|
|
|
|
} else
|
|
|
|
updateDefaultBiblio(bp_.defaultBiblioStyle());
|
|
|
|
|
|
|
|
biblioModule->citePackageOptionsLE->setText(toqstr(bp_.biblio_opts));
|
2011-12-12 14:45:30 +00:00
|
|
|
|
2009-05-22 07:20:00 +00:00
|
|
|
string command;
|
|
|
|
string options =
|
|
|
|
split(bp_.bibtex_command, command, ' ');
|
|
|
|
|
|
|
|
int const bpos = biblioModule->bibtexCO->findData(toqstr(command));
|
|
|
|
if (bpos != -1) {
|
|
|
|
biblioModule->bibtexCO->setCurrentIndex(bpos);
|
2011-09-24 16:39:20 +00:00
|
|
|
biblioModule->bibtexOptionsLE->setText(toqstr(options).trimmed());
|
2009-05-22 07:20:00 +00:00
|
|
|
} else {
|
2011-02-04 07:37:12 +00:00
|
|
|
// We reset to default if we do not know the specified compiler
|
|
|
|
// This is for security reasons
|
2011-02-03 15:03:38 +00:00
|
|
|
biblioModule->bibtexCO->setCurrentIndex(
|
2011-02-04 07:37:12 +00:00
|
|
|
biblioModule->bibtexCO->findData(toqstr("default")));
|
2011-09-24 16:39:20 +00:00
|
|
|
biblioModule->bibtexOptionsLE->clear();
|
2009-05-22 07:20:00 +00:00
|
|
|
}
|
2011-09-24 16:39:20 +00:00
|
|
|
biblioModule->bibtexOptionsLE->setEnabled(
|
2009-05-22 07:20:00 +00:00
|
|
|
biblioModule->bibtexCO->currentIndex() != 0);
|
|
|
|
|
2011-12-13 12:50:16 +00:00
|
|
|
biblioChanged_ = false;
|
|
|
|
|
2009-04-16 07:29:01 +00:00
|
|
|
// indices
|
2017-07-03 13:53:14 -04:00
|
|
|
// We may be called when there is no Buffer, e.g., when
|
2016-02-20 22:18:03 -05:00
|
|
|
// the last view has just been closed.
|
|
|
|
bool const isReadOnly = isBufferAvailable() ? buffer().isReadonly() : false;
|
2016-02-20 22:14:51 -05:00
|
|
|
indicesModule->update(bp_, isReadOnly);
|
2009-04-16 07:29:01 +00:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// language & quotes
|
2008-05-08 09:18:45 +00:00
|
|
|
int const pos = langModule->languageCO->findData(toqstr(
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.language->lang()));
|
2007-04-24 19:37:34 +00:00
|
|
|
langModule->languageCO->setCurrentIndex(pos);
|
|
|
|
|
2017-01-05 14:25:36 +01:00
|
|
|
updateQuoteStyles();
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
langModule->quoteStyleCO->setCurrentIndex(
|
2020-11-30 22:34:16 +02:00
|
|
|
langModule->quoteStyleCO->findData(static_cast<int>(bp_.quotes_style)));
|
2016-12-25 12:19:02 +01:00
|
|
|
langModule->dynamicQuotesCB->setChecked(bp_.dynamic_quotes);
|
2019-06-12 11:48:47 +02:00
|
|
|
|
|
|
|
// LaTeX input encoding: set after the fonts (see below)
|
|
|
|
|
|
|
|
int p = langModule->languagePackageCO->findData(toqstr(bp_.lang_package));
|
2011-02-03 14:17:31 +00:00
|
|
|
if (p == -1) {
|
|
|
|
langModule->languagePackageCO->setCurrentIndex(
|
|
|
|
langModule->languagePackageCO->findData("custom"));
|
2011-09-24 16:39:20 +00:00
|
|
|
langModule->languagePackageLE->setText(toqstr(bp_.lang_package));
|
2011-02-03 14:17:31 +00:00
|
|
|
} else {
|
|
|
|
langModule->languagePackageCO->setCurrentIndex(p);
|
2011-09-24 16:39:20 +00:00
|
|
|
langModule->languagePackageLE->clear();
|
2011-02-03 14:17:31 +00:00
|
|
|
}
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
//color
|
2010-04-02 23:39:36 +00:00
|
|
|
if (bp_.isfontcolor) {
|
|
|
|
colorModule->fontColorPB->setStyleSheet(
|
|
|
|
colorButtonStyleSheet(rgb2qcolor(bp_.fontcolor)));
|
|
|
|
}
|
|
|
|
set_fontcolor = bp_.fontcolor;
|
|
|
|
is_fontcolor = bp_.isfontcolor;
|
|
|
|
|
2010-04-02 22:11:50 +00:00
|
|
|
colorModule->noteFontColorPB->setStyleSheet(
|
|
|
|
colorButtonStyleSheet(rgb2qcolor(bp_.notefontcolor)));
|
|
|
|
set_notefontcolor = bp_.notefontcolor;
|
2010-04-02 23:39:36 +00:00
|
|
|
|
2010-04-05 20:31:10 +00:00
|
|
|
if (bp_.isbackgroundcolor) {
|
|
|
|
colorModule->backgroundPB->setStyleSheet(
|
|
|
|
colorButtonStyleSheet(rgb2qcolor(bp_.backgroundcolor)));
|
|
|
|
}
|
2010-04-02 22:11:50 +00:00
|
|
|
set_backgroundcolor = bp_.backgroundcolor;
|
2010-04-05 20:31:10 +00:00
|
|
|
is_backgroundcolor = bp_.isbackgroundcolor;
|
2010-04-02 22:11:50 +00:00
|
|
|
|
2010-04-08 00:14:08 +00:00
|
|
|
colorModule->boxBackgroundPB->setStyleSheet(
|
|
|
|
colorButtonStyleSheet(rgb2qcolor(bp_.boxbgcolor)));
|
|
|
|
set_boxbgcolor = bp_.boxbgcolor;
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// numbering
|
2008-02-28 21:04:55 +00:00
|
|
|
int const min_toclevel = documentClass().min_toclevel();
|
|
|
|
int const max_toclevel = documentClass().max_toclevel();
|
|
|
|
if (documentClass().hasTocLevels()) {
|
2007-04-24 19:37:34 +00:00
|
|
|
numberingModule->setEnabled(true);
|
|
|
|
numberingModule->depthSL->setMinimum(min_toclevel - 1);
|
|
|
|
numberingModule->depthSL->setMaximum(max_toclevel);
|
2008-10-14 16:59:28 +00:00
|
|
|
numberingModule->depthSL->setValue(bp_.secnumdepth);
|
2007-04-24 19:37:34 +00:00
|
|
|
numberingModule->tocSL->setMaximum(min_toclevel - 1);
|
|
|
|
numberingModule->tocSL->setMaximum(max_toclevel);
|
2008-10-14 16:59:28 +00:00
|
|
|
numberingModule->tocSL->setValue(bp_.tocdepth);
|
2007-04-24 19:37:34 +00:00
|
|
|
updateNumbering();
|
|
|
|
} else {
|
|
|
|
numberingModule->setEnabled(false);
|
|
|
|
numberingModule->tocTW->clear();
|
|
|
|
}
|
|
|
|
|
2019-05-24 15:40:09 +02:00
|
|
|
numberingModule->linenoCB->setChecked(bp_.use_lineno);
|
|
|
|
numberingModule->linenoLE->setEnabled(bp_.use_lineno);
|
2019-05-24 17:51:42 +02:00
|
|
|
numberingModule->linenoLA->setEnabled(bp_.use_lineno);
|
2019-05-23 15:13:27 +02:00
|
|
|
numberingModule->linenoLE->setText(toqstr(bp_.lineno_opts));
|
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// bullets
|
2008-10-14 16:59:28 +00:00
|
|
|
bulletsModule->setBullet(0, bp_.user_defined_bullet(0));
|
|
|
|
bulletsModule->setBullet(1, bp_.user_defined_bullet(1));
|
|
|
|
bulletsModule->setBullet(2, bp_.user_defined_bullet(2));
|
|
|
|
bulletsModule->setBullet(3, bp_.user_defined_bullet(3));
|
2007-04-24 19:37:34 +00:00
|
|
|
bulletsModule->init();
|
|
|
|
|
|
|
|
// packages
|
2010-11-26 18:42:53 +00:00
|
|
|
int nitem = findToken(tex_graphics, bp_.graphics_driver);
|
2007-06-01 17:44:04 +00:00
|
|
|
if (nitem >= 0)
|
|
|
|
latexModule->psdriverCO->setCurrentIndex(nitem);
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
updateModuleInfo();
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2017-04-05 22:22:47 +02:00
|
|
|
// math
|
2017-05-09 01:00:36 +02:00
|
|
|
mathsModule->MathIndentCB->setChecked(bp_.is_math_indent);
|
2017-04-13 02:31:26 +02:00
|
|
|
if (bp_.is_math_indent) {
|
2017-04-19 17:49:11 +02:00
|
|
|
Length const mathindent = bp_.getMathIndent();
|
|
|
|
int indent = 0;
|
|
|
|
if (!mathindent.empty()) {
|
2017-04-25 03:01:39 +02:00
|
|
|
lengthToWidgets(mathsModule->MathIndentLE,
|
|
|
|
mathsModule->MathIndentLengthCO,
|
2017-04-19 17:49:11 +02:00
|
|
|
mathindent, default_unit);
|
|
|
|
indent = 1;
|
2017-04-05 22:22:47 +02:00
|
|
|
}
|
2017-04-25 03:01:39 +02:00
|
|
|
mathsModule->MathIndentCO->setCurrentIndex(indent);
|
2017-05-09 21:02:03 +02:00
|
|
|
enableMathIndent(indent);
|
2017-04-05 22:22:47 +02:00
|
|
|
}
|
2017-05-13 20:39:45 +02:00
|
|
|
switch(bp_.math_numbering_side) {
|
2017-05-12 11:57:17 +02:00
|
|
|
case BufferParams::LEFT:
|
2017-04-25 02:28:10 +02:00
|
|
|
mathsModule->MathNumberingPosCO->setCurrentIndex(0);
|
2017-05-12 11:57:17 +02:00
|
|
|
break;
|
|
|
|
case BufferParams::DEFAULT:
|
2017-04-25 02:28:10 +02:00
|
|
|
mathsModule->MathNumberingPosCO->setCurrentIndex(1);
|
2017-05-12 11:57:17 +02:00
|
|
|
break;
|
|
|
|
case BufferParams::RIGHT:
|
2017-05-12 01:06:05 +02:00
|
|
|
mathsModule->MathNumberingPosCO->setCurrentIndex(2);
|
2017-05-12 11:57:17 +02:00
|
|
|
}
|
2017-04-05 22:22:47 +02:00
|
|
|
|
2013-03-01 15:59:37 +01:00
|
|
|
map<string, string> const & packages = BufferParams::auto_packages();
|
|
|
|
for (map<string, string>::const_iterator it = packages.begin();
|
|
|
|
it != packages.end(); ++it) {
|
|
|
|
QTableWidgetItem * item = mathsModule->packagesTW->findItems(toqstr(it->first), Qt::MatchExactly)[0];
|
|
|
|
if (!item)
|
|
|
|
continue;
|
|
|
|
int row = mathsModule->packagesTW->row(item);
|
|
|
|
switch (bp_.use_package(it->first)) {
|
|
|
|
case BufferParams::package_off: {
|
2018-03-18 12:11:26 +01:00
|
|
|
QRadioButton * rb =
|
|
|
|
(QRadioButton*)mathsModule->packagesTW->cellWidget(row, 3)->layout()->itemAt(0)->widget();
|
2013-03-01 15:59:37 +01:00
|
|
|
rb->setChecked(true);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BufferParams::package_on: {
|
2018-03-18 12:11:26 +01:00
|
|
|
QRadioButton * rb =
|
|
|
|
(QRadioButton*)mathsModule->packagesTW->cellWidget(row, 2)->layout()->itemAt(0)->widget();
|
2013-03-01 15:59:37 +01:00
|
|
|
rb->setChecked(true);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BufferParams::package_auto: {
|
2018-03-18 12:11:26 +01:00
|
|
|
QRadioButton * rb =
|
|
|
|
(QRadioButton*)mathsModule->packagesTW->cellWidget(row, 1)->layout()->itemAt(0)->widget();
|
2013-03-01 15:59:37 +01:00
|
|
|
rb->setChecked(true);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2012-01-03 20:51:07 +00:00
|
|
|
}
|
2011-08-10 03:37:33 +00:00
|
|
|
|
2008-10-14 16:59:28 +00:00
|
|
|
switch (bp_.spacing().getSpace()) {
|
2007-04-24 19:37:34 +00:00
|
|
|
case Spacing::Other: nitem = 3; break;
|
|
|
|
case Spacing::Double: nitem = 2; break;
|
|
|
|
case Spacing::Onehalf: nitem = 1; break;
|
|
|
|
case Spacing::Default: case Spacing::Single: nitem = 0; break;
|
|
|
|
}
|
|
|
|
|
|
|
|
// text layout
|
2008-10-14 16:59:28 +00:00
|
|
|
string const & layoutID = bp_.baseClassID();
|
2008-03-01 22:08:16 +00:00
|
|
|
setLayoutComboByIDString(layoutID);
|
2008-02-28 21:04:55 +00:00
|
|
|
|
|
|
|
updatePagestyle(documentClass().opt_pagestyle(),
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.pagestyle);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
textLayoutModule->lspacingCO->setCurrentIndex(nitem);
|
2008-10-14 16:59:28 +00:00
|
|
|
if (bp_.spacing().getSpace() == Spacing::Other) {
|
2009-07-12 15:44:26 +00:00
|
|
|
doubleToWidget(textLayoutModule->lspacingLE,
|
|
|
|
bp_.spacing().getValueAsString());
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
setLSpacing(nitem);
|
2019-03-26 16:23:34 +01:00
|
|
|
int ts = textLayoutModule->tableStyleCO->findData(toqstr(bp_.tablestyle));
|
|
|
|
if (ts != -1)
|
|
|
|
textLayoutModule->tableStyleCO->setCurrentIndex(ts);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-07-19 21:13:27 +00:00
|
|
|
if (bp_.paragraph_separation == BufferParams::ParagraphIndentSeparation) {
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->indentRB->setChecked(true);
|
2017-04-13 22:51:48 +02:00
|
|
|
string parindent = bp_.getParIndent().asString();
|
2009-07-19 21:13:27 +00:00
|
|
|
int indent = 0;
|
2017-04-13 22:51:48 +02:00
|
|
|
if (!parindent.empty()) {
|
2009-07-19 21:13:27 +00:00
|
|
|
lengthToWidgets(textLayoutModule->indentLE,
|
2017-04-13 22:51:48 +02:00
|
|
|
textLayoutModule->indentLengthCO,
|
|
|
|
parindent, default_unit);
|
2009-07-19 21:13:27 +00:00
|
|
|
indent = 1;
|
|
|
|
}
|
|
|
|
textLayoutModule->indentCO->setCurrentIndex(indent);
|
|
|
|
setIndent(indent);
|
|
|
|
} else {
|
2007-04-24 19:37:34 +00:00
|
|
|
textLayoutModule->skipRB->setChecked(true);
|
2020-06-28 17:20:18 +02:00
|
|
|
VSpace::VSpaceKind skip = bp_.getDefSkip().kind();
|
|
|
|
textLayoutModule->skipCO->setCurrentIndex(textLayoutModule->skipCO->findData(skip));
|
|
|
|
if (skip == VSpace::LENGTH) {
|
2009-07-19 21:13:27 +00:00
|
|
|
string const length = bp_.getDefSkip().asLyXCommand();
|
|
|
|
lengthToWidgets(textLayoutModule->skipLE,
|
|
|
|
textLayoutModule->skipLengthCO,
|
2011-10-27 11:49:15 +00:00
|
|
|
length, default_unit);
|
2009-07-19 21:13:27 +00:00
|
|
|
}
|
2020-06-28 17:20:18 +02:00
|
|
|
setSkip(textLayoutModule->skipCO->currentIndex());
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
textLayoutModule->twoColumnCB->setChecked(
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.columns == 2);
|
2011-12-07 22:33:25 +00:00
|
|
|
textLayoutModule->justCB->setChecked(bp_.justification);
|
2007-05-28 22:27:45 +00:00
|
|
|
|
2008-10-14 16:59:28 +00:00
|
|
|
if (!bp_.options.empty()) {
|
2007-04-24 19:37:34 +00:00
|
|
|
latexModule->optionsLE->setText(
|
2008-10-14 16:59:28 +00:00
|
|
|
toqstr(bp_.options));
|
2007-04-24 19:37:34 +00:00
|
|
|
} else {
|
2007-09-05 20:33:29 +00:00
|
|
|
latexModule->optionsLE->setText(QString());
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
2008-10-14 17:35:49 +00:00
|
|
|
// latex
|
2008-10-12 09:36:00 +00:00
|
|
|
latexModule->defaultOptionsCB->setChecked(
|
2008-10-14 17:35:49 +00:00
|
|
|
bp_.use_default_options);
|
2008-10-23 00:27:03 +00:00
|
|
|
updateSelectedModules();
|
|
|
|
selectionManager->updateProvidedModules(
|
|
|
|
bp_.baseClass()->providedModules());
|
|
|
|
selectionManager->updateExcludedModules(
|
|
|
|
bp_.baseClass()->excludedModules());
|
2008-10-12 09:36:00 +00:00
|
|
|
|
|
|
|
if (!documentClass().options().empty()) {
|
|
|
|
latexModule->defaultOptionsLE->setText(
|
|
|
|
toqstr(documentClass().options()));
|
|
|
|
} else {
|
|
|
|
latexModule->defaultOptionsLE->setText(
|
|
|
|
toqstr(_("[No options predefined]")));
|
|
|
|
}
|
|
|
|
|
|
|
|
latexModule->defaultOptionsLE->setEnabled(
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.use_default_options
|
2008-10-12 09:36:00 +00:00
|
|
|
&& !documentClass().options().empty());
|
|
|
|
|
|
|
|
latexModule->defaultOptionsCB->setEnabled(
|
|
|
|
!documentClass().options().empty());
|
|
|
|
|
2008-10-14 16:59:28 +00:00
|
|
|
if (!bp_.master.empty()) {
|
2008-04-28 16:38:56 +00:00
|
|
|
latexModule->childDocGB->setChecked(true);
|
|
|
|
latexModule->childDocLE->setText(
|
2008-10-14 16:59:28 +00:00
|
|
|
toqstr(bp_.master));
|
2008-04-28 16:38:56 +00:00
|
|
|
} else {
|
|
|
|
latexModule->childDocLE->setText(QString());
|
|
|
|
latexModule->childDocGB->setChecked(false);
|
|
|
|
}
|
|
|
|
|
2010-01-07 10:01:26 +00:00
|
|
|
// Master/Child
|
2010-10-13 12:43:13 +00:00
|
|
|
if (!bufferview() || !buffer().hasChildren()) {
|
2010-01-10 13:25:41 +00:00
|
|
|
masterChildModule->childrenTW->clear();
|
2010-01-07 10:01:26 +00:00
|
|
|
includeonlys_.clear();
|
2013-05-12 18:30:59 +02:00
|
|
|
docPS->showPanel("Child Documents", false);
|
|
|
|
if (docPS->isCurrentPanel("Child Documents"))
|
|
|
|
docPS->setCurrentPanel("Document Class");
|
2010-01-07 10:01:26 +00:00
|
|
|
} else {
|
2013-05-12 18:30:59 +02:00
|
|
|
docPS->showPanel("Child Documents", true);
|
2010-01-07 10:01:26 +00:00
|
|
|
masterChildModule->setEnabled(true);
|
|
|
|
includeonlys_ = bp_.getIncludedChildren();
|
|
|
|
updateIncludeonlys();
|
2020-03-12 10:37:56 +01:00
|
|
|
updateIncludeonlyDisplay();
|
2010-01-07 10:01:26 +00:00
|
|
|
}
|
2020-03-13 15:46:35 +01:00
|
|
|
switch (bp_.maintain_unincluded_children) {
|
|
|
|
case BufferParams::CM_None:
|
|
|
|
masterChildModule->maintainCRNoneRB->setChecked(true);
|
|
|
|
break;
|
|
|
|
case BufferParams::CM_Mostly:
|
|
|
|
masterChildModule->maintainCRMostlyRB->setChecked(true);
|
|
|
|
break;
|
|
|
|
case BufferParams::CM_Strict:
|
|
|
|
default:
|
|
|
|
masterChildModule->maintainCRStrictRB->setChecked(true);
|
|
|
|
break;
|
|
|
|
}
|
2010-01-07 10:01:26 +00:00
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// Float Settings
|
2018-05-10 20:15:11 +02:00
|
|
|
floatModule->setPlacement(bp_.float_placement);
|
|
|
|
floatModule->setAlignment(bp_.float_alignment);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2009-07-20 08:09:32 +00:00
|
|
|
// ListingsSettings
|
|
|
|
// break listings_params to multiple lines
|
|
|
|
string lstparams =
|
|
|
|
InsetListingsParams(bp_.listings_params).separatedParams();
|
|
|
|
listingsModule->listingsED->setPlainText(toqstr(lstparams));
|
2017-06-12 17:24:26 +02:00
|
|
|
int nn = findToken(lst_packages, bp_.use_minted ? "Minted" : "Listings");
|
|
|
|
if (nn >= 0)
|
|
|
|
listingsModule->packageCO->setCurrentIndex(nn);
|
2017-06-07 00:55:23 +02:00
|
|
|
|
2012-01-31 11:30:52 +00:00
|
|
|
// Fonts
|
2019-03-16 12:59:34 +01:00
|
|
|
// some languages only work with Polyglossia (which requires non-TeX fonts)
|
2013-05-28 11:45:42 +02:00
|
|
|
Language const * lang = lyx::languages.getLanguage(
|
|
|
|
fromqstr(langModule->languageCO->itemData(
|
|
|
|
langModule->languageCO->currentIndex()).toString()));
|
|
|
|
bool const need_fontspec =
|
2019-05-26 01:45:35 +02:00
|
|
|
lang->babel().empty() && !lang->polyglossia().empty()
|
2020-02-28 00:36:55 -05:00
|
|
|
&& lang->required() != "CJK" && lang->required() != "japanese";
|
2011-02-09 08:23:11 +00:00
|
|
|
bool const os_fonts_available =
|
|
|
|
bp_.baseClass()->outputType() == lyx::LATEX
|
|
|
|
&& LaTeXFeatures::isAvailable("fontspec");
|
2013-05-28 11:45:42 +02:00
|
|
|
fontModule->osFontsCB->setEnabled(os_fonts_available && !need_fontspec);
|
2010-11-26 09:42:03 +00:00
|
|
|
fontModule->osFontsCB->setChecked(
|
2013-05-28 11:45:42 +02:00
|
|
|
(os_fonts_available && bp_.useNonTeXFonts) || need_fontspec);
|
2008-02-28 21:04:55 +00:00
|
|
|
updateFontsize(documentClass().opt_fontsize(),
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.fontsize);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
QString font = toqstr(bp_.fontsRoman());
|
2011-04-08 20:37:17 +00:00
|
|
|
int rpos = fontModule->fontsRomanCO->findData(font);
|
|
|
|
if (rpos == -1) {
|
|
|
|
rpos = fontModule->fontsRomanCO->count();
|
|
|
|
fontModule->fontsRomanCO->addItem(font + qt_(" (not installed)"), font);
|
|
|
|
}
|
|
|
|
fontModule->fontsRomanCO->setCurrentIndex(rpos);
|
2015-11-09 07:33:57 +01:00
|
|
|
fontModule->font_roman = toqstr(bp_.fonts_roman[!bp_.useNonTeXFonts]);
|
2011-04-08 20:37:17 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
font = toqstr(bp_.fontsSans());
|
2011-04-08 20:37:17 +00:00
|
|
|
int spos = fontModule->fontsSansCO->findData(font);
|
|
|
|
if (spos == -1) {
|
|
|
|
spos = fontModule->fontsSansCO->count();
|
|
|
|
fontModule->fontsSansCO->addItem(font + qt_(" (not installed)"), font);
|
|
|
|
}
|
|
|
|
fontModule->fontsSansCO->setCurrentIndex(spos);
|
2015-11-09 07:33:57 +01:00
|
|
|
fontModule->font_sans = toqstr(bp_.fonts_sans[!bp_.useNonTeXFonts]);
|
2011-04-08 20:37:17 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
font = toqstr(bp_.fontsTypewriter());
|
2011-04-08 20:37:17 +00:00
|
|
|
int tpos = fontModule->fontsTypewriterCO->findData(font);
|
|
|
|
if (tpos == -1) {
|
|
|
|
tpos = fontModule->fontsTypewriterCO->count();
|
|
|
|
fontModule->fontsTypewriterCO->addItem(font + qt_(" (not installed)"), font);
|
|
|
|
}
|
|
|
|
fontModule->fontsTypewriterCO->setCurrentIndex(tpos);
|
2015-11-09 07:33:57 +01:00
|
|
|
fontModule->font_typewriter = toqstr(bp_.fonts_typewriter[!bp_.useNonTeXFonts]);
|
2011-04-08 20:37:17 +00:00
|
|
|
|
2015-11-09 07:33:57 +01:00
|
|
|
font = toqstr(bp_.fontsMath());
|
2012-09-22 17:44:00 +02:00
|
|
|
int mpos = fontModule->fontsMathCO->findData(font);
|
|
|
|
if (mpos == -1) {
|
|
|
|
mpos = fontModule->fontsMathCO->count();
|
|
|
|
fontModule->fontsMathCO->addItem(font + qt_(" (not installed)"), font);
|
|
|
|
}
|
|
|
|
fontModule->fontsMathCO->setCurrentIndex(mpos);
|
2015-11-09 07:33:57 +01:00
|
|
|
fontModule->font_math = toqstr(bp_.fonts_math[!bp_.useNonTeXFonts]);
|
2012-09-22 17:44:00 +02:00
|
|
|
|
2011-02-09 08:23:11 +00:00
|
|
|
if (bp_.useNonTeXFonts && os_fonts_available) {
|
2009-11-29 14:43:00 +00:00
|
|
|
fontModule->fontencLA->setEnabled(false);
|
|
|
|
fontModule->fontencCO->setEnabled(false);
|
|
|
|
fontModule->fontencLE->setEnabled(false);
|
2009-04-06 06:58:30 +00:00
|
|
|
} else {
|
2009-11-29 14:43:00 +00:00
|
|
|
fontModule->fontencLA->setEnabled(true);
|
|
|
|
fontModule->fontencCO->setEnabled(true);
|
|
|
|
fontModule->fontencLE->setEnabled(true);
|
2011-04-08 20:37:17 +00:00
|
|
|
romanChanged(rpos);
|
|
|
|
sansChanged(spos);
|
|
|
|
ttChanged(tpos);
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
2010-11-26 18:32:29 +00:00
|
|
|
if (!bp_.fonts_cjk.empty())
|
2008-06-05 06:18:34 +00:00
|
|
|
fontModule->cjkFontLE->setText(
|
2010-11-26 18:32:29 +00:00
|
|
|
toqstr(bp_.fonts_cjk));
|
2008-06-05 06:18:34 +00:00
|
|
|
else
|
|
|
|
fontModule->cjkFontLE->setText(QString());
|
2017-07-03 13:53:14 -04:00
|
|
|
|
2016-06-02 22:40:21 -07:00
|
|
|
fontModule->microtypeCB->setChecked(bp_.use_microtype);
|
2017-12-16 16:11:25 +01:00
|
|
|
fontModule->dashesCB->setChecked(!bp_.use_dash_ligatures);
|
2008-06-05 06:18:34 +00:00
|
|
|
|
2010-11-26 18:32:29 +00:00
|
|
|
fontModule->fontScCB->setChecked(bp_.fonts_expert_sc);
|
2019-07-14 11:41:36 +02:00
|
|
|
fontModule->fontOsfCB->setChecked(bp_.fonts_roman_osf);
|
|
|
|
fontModule->fontSansOsfCB->setChecked(bp_.fonts_sans_osf);
|
|
|
|
fontModule->fontTypewriterOsfCB->setChecked(bp_.fonts_typewriter_osf);
|
2015-11-09 07:33:57 +01:00
|
|
|
fontModule->scaleSansSB->setValue(bp_.fontsSansScale());
|
|
|
|
fontModule->font_sf_scale = bp_.fonts_sans_scale[!bp_.useNonTeXFonts];
|
|
|
|
fontModule->scaleTypewriterSB->setValue(bp_.fontsTypewriterScale());
|
|
|
|
fontModule->font_tt_scale = bp_.fonts_typewriter_scale[!bp_.useNonTeXFonts];
|
2019-07-11 20:28:34 +02:00
|
|
|
if (!bp_.font_roman_opts.empty())
|
|
|
|
fontModule->fontspecRomanLE->setText(
|
|
|
|
toqstr(bp_.font_roman_opts));
|
|
|
|
else
|
|
|
|
fontModule->fontspecRomanLE->setText(QString());
|
|
|
|
if (!bp_.font_sans_opts.empty())
|
|
|
|
fontModule->fontspecSansLE->setText(
|
|
|
|
toqstr(bp_.font_sans_opts));
|
|
|
|
else
|
|
|
|
fontModule->fontspecSansLE->setText(QString());
|
|
|
|
if (!bp_.font_typewriter_opts.empty())
|
|
|
|
fontModule->fontspecTypewriterLE->setText(
|
|
|
|
toqstr(bp_.font_typewriter_opts));
|
|
|
|
else
|
|
|
|
fontModule->fontspecTypewriterLE->setText(QString());
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2017-06-12 17:24:26 +02:00
|
|
|
nn = findToken(GuiDocument::fontfamilies, bp_.fonts_default_family);
|
2009-04-06 06:58:30 +00:00
|
|
|
if (nn >= 0)
|
|
|
|
fontModule->fontsDefaultCO->setCurrentIndex(nn);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2019-04-30 09:34:51 +02:00
|
|
|
if (bp_.fontenc == "auto" || bp_.fontenc == "default") {
|
2012-08-16 13:23:39 +02:00
|
|
|
fontModule->fontencCO->setCurrentIndex(
|
|
|
|
fontModule->fontencCO->findData(toqstr(bp_.fontenc)));
|
2010-06-25 03:33:15 +00:00
|
|
|
fontModule->fontencLE->setEnabled(false);
|
|
|
|
} else {
|
2018-04-22 19:06:46 +02:00
|
|
|
fontModule->fontencCO->setCurrentIndex(
|
|
|
|
fontModule->fontencCO->findData("custom"));
|
2009-11-29 14:43:00 +00:00
|
|
|
fontModule->fontencLE->setText(toqstr(bp_.fontenc));
|
|
|
|
}
|
|
|
|
|
2019-06-12 11:48:47 +02:00
|
|
|
// LaTeX input encoding
|
|
|
|
// Set after fonts because non-tex fonts override "\inputencoding".
|
|
|
|
inputencodingToDialog();
|
|
|
|
|
2016-08-28 16:51:15 +01:00
|
|
|
// Formats
|
2012-01-31 11:30:52 +00:00
|
|
|
// This must be set _after_ fonts since updateDefaultFormat()
|
|
|
|
// checks osFontsCB settings.
|
|
|
|
// update combobox with formats
|
|
|
|
updateDefaultFormat();
|
|
|
|
int index = outputModule->defaultFormatCO->findData(toqstr(
|
|
|
|
bp_.default_output_format));
|
|
|
|
// set to default if format is not found
|
|
|
|
if (index == -1)
|
|
|
|
index = 0;
|
|
|
|
outputModule->defaultFormatCO->setCurrentIndex(index);
|
|
|
|
|
2017-08-03 13:07:41 +02:00
|
|
|
outputModule->shellescapeCB->setChecked(bp_.shell_escape);
|
2012-01-31 11:30:52 +00:00
|
|
|
outputModule->outputsyncCB->setChecked(bp_.output_sync);
|
|
|
|
outputModule->synccustomCB->setEditText(toqstr(bp_.output_sync_macro));
|
2020-01-10 10:21:09 +01:00
|
|
|
outputModule->synccustomCB->setEnabled(bp_.output_sync);
|
|
|
|
outputModule->synccustomLA->setEnabled(bp_.output_sync);
|
2012-01-31 11:30:52 +00:00
|
|
|
|
|
|
|
outputModule->mathimgSB->setValue(bp_.html_math_img_scale);
|
|
|
|
outputModule->mathoutCB->setCurrentIndex(bp_.html_math_output);
|
|
|
|
outputModule->strictCB->setChecked(bp_.html_be_strict);
|
|
|
|
outputModule->cssCB->setChecked(bp_.html_css_as_file);
|
|
|
|
|
2020-07-13 03:31:48 +02:00
|
|
|
outputModule->tableoutCB->setCurrentIndex(bp_.docbook_table_output);
|
|
|
|
|
2016-07-08 16:36:05 +01:00
|
|
|
outputModule->saveTransientPropertiesCB
|
|
|
|
->setChecked(bp_.save_transient_properties);
|
2020-01-10 10:21:09 +01:00
|
|
|
outputModule->postponeFragileCB
|
|
|
|
->setChecked(bp_.postpone_fragile_content);
|
2016-07-08 16:36:05 +01:00
|
|
|
|
2007-04-24 19:37:34 +00:00
|
|
|
// paper
|
2009-03-28 10:48:16 +00:00
|
|
|
bool const extern_geometry =
|
|
|
|
documentClass().provides("geometry");
|
2008-10-14 16:59:28 +00:00
|
|
|
int const psize = bp_.papersize;
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->papersizeCO->setCurrentIndex(psize);
|
2009-07-16 08:39:22 +00:00
|
|
|
setCustomPapersize(!extern_geometry && psize == 1);
|
2009-03-28 10:48:16 +00:00
|
|
|
pageLayoutModule->papersizeCO->setEnabled(!extern_geometry);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
bool const landscape =
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.orientation == ORIENTATION_LANDSCAPE;
|
2007-04-24 19:37:34 +00:00
|
|
|
pageLayoutModule->landscapeRB->setChecked(landscape);
|
|
|
|
pageLayoutModule->portraitRB->setChecked(!landscape);
|
2009-03-28 10:48:16 +00:00
|
|
|
pageLayoutModule->landscapeRB->setEnabled(!extern_geometry);
|
|
|
|
pageLayoutModule->portraitRB->setEnabled(!extern_geometry);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
pageLayoutModule->facingPagesCB->setChecked(
|
2008-10-14 16:59:28 +00:00
|
|
|
bp_.sides == TwoSides);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(pageLayoutModule->paperwidthLE,
|
2011-10-27 11:49:15 +00:00
|
|
|
pageLayoutModule->paperwidthUnitCO, bp_.paperwidth, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
lengthToWidgets(pageLayoutModule->paperheightLE,
|
2011-10-27 11:49:15 +00:00
|
|
|
pageLayoutModule->paperheightUnitCO, bp_.paperheight, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
// margins
|
|
|
|
Ui::MarginsUi * m = marginsModule;
|
|
|
|
|
2010-05-18 02:56:36 +00:00
|
|
|
setMargins();
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->topLE, m->topUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.topmargin, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->bottomLE, m->bottomUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.bottommargin, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->innerLE, m->innerUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.leftmargin, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->outerLE, m->outerUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.rightmargin, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->headheightLE, m->headheightUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.headheight, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->headsepLE, m->headsepUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.headsep, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
|
|
|
lengthToWidgets(m->footskipLE, m->footskipUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.footskip, default_unit);
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-02-19 05:24:48 +00:00
|
|
|
lengthToWidgets(m->columnsepLE, m->columnsepUnit,
|
2011-10-27 11:49:15 +00:00
|
|
|
bp_.columnsep, default_unit);
|
2008-02-19 05:24:48 +00:00
|
|
|
|
2009-07-09 09:48:34 +00:00
|
|
|
// branches
|
|
|
|
updateUnknownBranches();
|
2008-10-14 16:59:28 +00:00
|
|
|
branchesModule->update(bp_);
|
2007-09-20 22:31:18 +00:00
|
|
|
|
|
|
|
// PDF support
|
2008-10-14 16:59:28 +00:00
|
|
|
PDFOptions const & pdf = bp_.pdfoptions();
|
2007-09-22 22:20:15 +00:00
|
|
|
pdfSupportModule->use_hyperrefGB->setChecked(pdf.use_hyperref);
|
2011-12-07 21:14:41 +00:00
|
|
|
if (bp_.documentClass().provides("hyperref"))
|
|
|
|
pdfSupportModule->use_hyperrefGB->setTitle(qt_("C&ustomize Hyperref Options"));
|
|
|
|
else
|
|
|
|
pdfSupportModule->use_hyperrefGB->setTitle(qt_("&Use Hyperref Support"));
|
2007-09-21 01:00:31 +00:00
|
|
|
pdfSupportModule->titleLE->setText(toqstr(pdf.title));
|
|
|
|
pdfSupportModule->authorLE->setText(toqstr(pdf.author));
|
|
|
|
pdfSupportModule->subjectLE->setText(toqstr(pdf.subject));
|
|
|
|
pdfSupportModule->keywordsLE->setText(toqstr(pdf.keywords));
|
2007-09-20 22:31:18 +00:00
|
|
|
|
2007-09-21 01:00:31 +00:00
|
|
|
pdfSupportModule->bookmarksGB->setChecked(pdf.bookmarks);
|
|
|
|
pdfSupportModule->bookmarksnumberedCB->setChecked(pdf.bookmarksnumbered);
|
|
|
|
pdfSupportModule->bookmarksopenGB->setChecked(pdf.bookmarksopen);
|
2007-09-20 22:31:18 +00:00
|
|
|
|
2007-09-22 22:20:15 +00:00
|
|
|
pdfSupportModule->bookmarksopenlevelSB->setValue(pdf.bookmarksopenlevel);
|
2020-05-16 10:31:48 +02:00
|
|
|
pdfSupportModule->bookmarksopenlevelSB->setEnabled(pdf.bookmarksopen);
|
|
|
|
pdfSupportModule->bookmarksopenlevelLA->setEnabled(pdf.bookmarksopen);
|
2007-09-20 22:31:18 +00:00
|
|
|
|
2007-09-21 01:00:31 +00:00
|
|
|
pdfSupportModule->breaklinksCB->setChecked(pdf.breaklinks);
|
|
|
|
pdfSupportModule->pdfborderCB->setChecked(pdf.pdfborder);
|
2007-10-10 00:34:23 +00:00
|
|
|
pdfSupportModule->pdfusetitleCB->setChecked(pdf.pdfusetitle);
|
2007-09-21 01:00:31 +00:00
|
|
|
pdfSupportModule->colorlinksCB->setChecked(pdf.colorlinks);
|
2008-10-13 16:01:02 +00:00
|
|
|
|
2009-04-06 06:58:30 +00:00
|
|
|
nn = findToken(backref_opts, pdf.backref);
|
|
|
|
if (nn >= 0)
|
|
|
|
pdfSupportModule->backrefCO->setCurrentIndex(nn);
|
2008-10-13 16:01:02 +00:00
|
|
|
|
2007-09-20 22:31:18 +00:00
|
|
|
pdfSupportModule->fullscreenCB->setChecked
|
2007-09-21 01:00:31 +00:00
|
|
|
(pdf.pagemode == pdf.pagemode_fullscreen);
|
2007-09-20 22:31:18 +00:00
|
|
|
|
|
|
|
pdfSupportModule->optionsLE->setText(
|
2007-09-21 01:00:31 +00:00
|
|
|
toqstr(pdf.quoted_options));
|
2009-02-22 23:02:35 +00:00
|
|
|
|
2019-12-24 18:12:22 +01:00
|
|
|
// change tracking
|
|
|
|
changesModule->trackChangesCB->setChecked(bp_.track_changes);
|
|
|
|
changesModule->outputChangesCB->setChecked(bp_.output_changes);
|
|
|
|
changesModule->changeBarsCB->setChecked(bp_.change_bars);
|
2019-12-24 18:43:22 +01:00
|
|
|
changesModule->changeBarsCB->setEnabled(bp_.output_changes);
|
2019-12-24 18:12:22 +01:00
|
|
|
|
2009-02-22 23:02:35 +00:00
|
|
|
// Make sure that the bc is in the INITIAL state
|
|
|
|
if (bc().policy().buttonStatus(ButtonPolicy::RESTORE))
|
|
|
|
bc().restore();
|
2009-07-11 10:31:32 +00:00
|
|
|
|
|
|
|
// clear changed branches cache
|
|
|
|
changedBranches_.clear();
|
2014-12-21 19:08:41 +01:00
|
|
|
|
2017-08-10 01:32:23 +02:00
|
|
|
// reset trackers
|
2014-12-21 19:08:41 +01:00
|
|
|
nonModuleChanged_ = false;
|
2017-08-10 01:32:23 +02:00
|
|
|
shellescapeChanged_ = false;
|
2007-04-24 19:37:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::saveDocDefault()
|
2006-03-05 17:24:44 +00:00
|
|
|
{
|
|
|
|
// we have to apply the params first
|
2007-09-03 20:28:26 +00:00
|
|
|
applyView();
|
2007-10-06 22:43:21 +00:00
|
|
|
saveAsDefault();
|
2006-03-05 17:24:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
void GuiDocument::updateAvailableModules()
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
{
|
2008-02-28 21:04:55 +00:00
|
|
|
modules_av_model_.clear();
|
2016-05-31 18:47:29 +01:00
|
|
|
list<modInfoStruct> modInfoList = getModuleInfo();
|
|
|
|
// Sort names according to the locale
|
|
|
|
modInfoList.sort([](modInfoStruct const & a, modInfoStruct const & b) {
|
|
|
|
return 0 < b.name.localeAwareCompare(a.name);
|
|
|
|
});
|
2019-04-20 09:28:46 +02:00
|
|
|
QIcon user_icon(getPixmap("images/", "lyxfiles-user", "svgz,png"));
|
|
|
|
QIcon system_icon(getPixmap("images/", "lyxfiles-system", "svgz,png"));
|
2016-05-31 18:47:29 +01:00
|
|
|
int i = 0;
|
2019-04-07 11:23:19 +02:00
|
|
|
QFont catfont;
|
|
|
|
catfont.setBold(true);
|
2019-04-20 09:28:46 +02:00
|
|
|
QBrush unavbrush;
|
|
|
|
unavbrush.setColor(Qt::gray);
|
2016-05-31 18:47:29 +01:00
|
|
|
for (modInfoStruct const & m : modInfoList) {
|
2019-04-07 11:23:19 +02:00
|
|
|
QStandardItem * item = new QStandardItem();
|
2020-02-13 15:24:12 +01:00
|
|
|
QStandardItem * catItem;
|
2019-04-07 11:23:19 +02:00
|
|
|
QString const catname = m.category;
|
|
|
|
QList<QStandardItem *> fcats = modules_av_model_.findItems(catname, Qt::MatchExactly);
|
|
|
|
if (!fcats.empty())
|
|
|
|
catItem = fcats.first();
|
|
|
|
else {
|
2020-02-13 15:24:12 +01:00
|
|
|
catItem = new QStandardItem();
|
2019-04-07 11:23:19 +02:00
|
|
|
catItem->setText(catname);
|
|
|
|
catItem->setFont(catfont);
|
|
|
|
modules_av_model_.insertRow(i, catItem);
|
|
|
|
++i;
|
|
|
|
}
|
2019-04-18 17:33:37 +02:00
|
|
|
item->setEditable(false);
|
2019-04-07 11:23:19 +02:00
|
|
|
catItem->setEditable(false);
|
|
|
|
item->setData(m.name, Qt::DisplayRole);
|
2019-04-20 09:28:46 +02:00
|
|
|
if (m.missingreqs)
|
|
|
|
item->setForeground(unavbrush);
|
2019-04-07 11:23:19 +02:00
|
|
|
item->setData(toqstr(m.id), Qt::UserRole);
|
|
|
|
item->setData(m.description, Qt::ToolTipRole);
|
2019-04-20 09:28:46 +02:00
|
|
|
if (m.local)
|
|
|
|
item->setIcon(user_icon);
|
|
|
|
else
|
|
|
|
item->setIcon(system_icon);
|
2019-04-07 11:23:19 +02:00
|
|
|
catItem->appendRow(item);
|
2016-05-31 18:47:29 +01:00
|
|
|
}
|
2019-04-07 11:23:19 +02:00
|
|
|
modules_av_model_.sort(0);
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
void GuiDocument::updateSelectedModules()
|
This is the last of a series of patches that merges the layout modules development in personal/branches/rgheck back into the tree.
Design goal: Allow the use of layout "modules", which are to LaTeX packages as layout files are to LaTeX document classes. Thus, one could have a module that defined certain character styles, environments, commands, or what have you, and include it in various documents, each of which uses a different document class, without having to modify the layout files themselves. For example, a theorems.module could be used with article.layout to provide support for theorem-type environments, without having to modify article.layout itself, and the same module could be used with book.layout, etc.
This patch adds the GUI for managing modules.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@20282 a592a061-630c-0410-9148-cb99ea01b6c8
2007-09-15 01:55:09 +00:00
|
|
|
{
|
2008-02-28 21:04:55 +00:00
|
|
|
modules_sel_model_.clear();
|
2008-10-14 14:04:21 +00:00
|
|
|
list<modInfoStruct> const selModList = getSelectedModules();
|
2016-05-31 18:47:29 +01:00
|
|
|
int i = 0;
|
|
|
|
for (modInfoStruct const & m : selModList) {
|
|
|
|
modules_sel_model_.insertRow(i, m.name, m.id, m.description);
|
|
|
|
++i;
|
|
|
|
}
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-03-12 10:37:56 +01:00
|
|
|
void GuiDocument::updateIncludeonlyDisplay()
|
2010-01-07 10:01:26 +00:00
|
|
|
{
|
|
|
|
if (includeonlys_.empty()) {
|
|
|
|
masterChildModule->includeallRB->setChecked(true);
|
|
|
|
masterChildModule->childrenTW->setEnabled(false);
|
2020-03-13 15:46:35 +01:00
|
|
|
masterChildModule->maintainGB->setEnabled(false);
|
2010-01-07 10:01:26 +00:00
|
|
|
} else {
|
|
|
|
masterChildModule->includeonlyRB->setChecked(true);
|
|
|
|
masterChildModule->childrenTW->setEnabled(true);
|
2020-03-13 15:46:35 +01:00
|
|
|
masterChildModule->maintainGB->setEnabled(true);
|
2010-01-07 10:01:26 +00:00
|
|
|
}
|
2020-03-12 10:37:56 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::updateIncludeonlys()
|
|
|
|
{
|
|
|
|
masterChildModule->childrenTW->clear();
|
|
|
|
QString const no = qt_("No");
|
|
|
|
QString const yes = qt_("Yes");
|
|
|
|
|
2010-09-29 13:05:57 +00:00
|
|
|
ListOfBuffers children = buffer().getChildren();
|
2010-09-29 11:55:10 +00:00
|
|
|
ListOfBuffers::const_iterator it = children.begin();
|
|
|
|
ListOfBuffers::const_iterator end = children.end();
|
2010-01-07 10:01:26 +00:00
|
|
|
bool has_unincluded = false;
|
|
|
|
bool all_unincluded = true;
|
|
|
|
for (; it != end; ++it) {
|
2015-09-20 10:42:35 +02:00
|
|
|
QTreeWidgetItem * item = new QTreeWidgetItem(masterChildModule->childrenTW);
|
2010-01-07 10:01:26 +00:00
|
|
|
// FIXME Unicode
|
|
|
|
string const name =
|
2010-04-21 01:19:09 +00:00
|
|
|
to_utf8(makeRelPath(from_utf8((*it)->fileName().absFileName()),
|
2010-01-07 10:01:26 +00:00
|
|
|
from_utf8(buffer().filePath())));
|
|
|
|
item->setText(0, toqstr(name));
|
|
|
|
item->setText(1, isChildIncluded(name) ? yes : no);
|
|
|
|
if (!isChildIncluded(name))
|
|
|
|
has_unincluded = true;
|
|
|
|
else
|
|
|
|
all_unincluded = false;
|
|
|
|
}
|
2020-03-12 10:37:56 +01:00
|
|
|
// Both if all children are included and if none is included
|
2017-09-22 09:29:16 +02:00
|
|
|
// is equal to "include all" (i.e., omit \includeonly).
|
2020-03-12 10:37:56 +01:00
|
|
|
if (!has_unincluded || all_unincluded)
|
2010-01-07 10:01:26 +00:00
|
|
|
includeonlys_.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
bool GuiDocument::isBiblatex() const
|
|
|
|
{
|
|
|
|
QString const engine =
|
|
|
|
biblioModule->citeEngineCO->itemData(
|
|
|
|
biblioModule->citeEngineCO->currentIndex()).toString();
|
|
|
|
|
2018-02-12 16:26:27 -05:00
|
|
|
// this can happen if the cite engine is unknown, which can happen
|
|
|
|
// if one is using a file that came from someone else, etc. in that
|
|
|
|
// case, we crash if we proceed.
|
|
|
|
if (engine.isEmpty())
|
|
|
|
return false;
|
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
return theCiteEnginesList[fromqstr(engine)]->getCiteFramework() == "biblatex";
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::updateDefaultBiblio(string const & style,
|
|
|
|
string const & which)
|
2016-12-31 14:57:09 +01:00
|
|
|
{
|
|
|
|
QString const bibstyle = toqstr(style);
|
|
|
|
biblioModule->defaultBiblioCO->clear();
|
|
|
|
|
|
|
|
int item_nr = -1;
|
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
if (isBiblatex()) {
|
|
|
|
if (which != "cbx") {
|
|
|
|
// First the bbx styles
|
2017-01-13 10:57:53 +01:00
|
|
|
biblioModule->biblatexBbxCO->clear();
|
2017-01-08 09:39:46 +01:00
|
|
|
QStringList str = texFileList("bbxFiles.lst");
|
|
|
|
// test whether we have a valid list, otherwise run rescan
|
|
|
|
if (str.isEmpty()) {
|
|
|
|
rescanTexStyles("bbx");
|
|
|
|
str = texFileList("bbxFiles.lst");
|
|
|
|
}
|
|
|
|
for (int i = 0; i != str.size(); ++i)
|
|
|
|
str[i] = onlyFileName(str[i]);
|
|
|
|
// sort on filename only (no path)
|
|
|
|
str.sort();
|
|
|
|
|
|
|
|
for (int i = 0; i != str.count(); ++i) {
|
|
|
|
QString item = changeExtension(str[i], "");
|
|
|
|
if (item == bibstyle)
|
|
|
|
item_nr = i;
|
|
|
|
biblioModule->biblatexBbxCO->addItem(item);
|
|
|
|
}
|
2016-12-31 14:57:09 +01:00
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
if (item_nr == -1 && !bibstyle.isEmpty()) {
|
|
|
|
biblioModule->biblatexBbxCO->addItem(bibstyle);
|
|
|
|
item_nr = biblioModule->biblatexBbxCO->count() - 1;
|
|
|
|
}
|
2016-12-31 14:57:09 +01:00
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
if (item_nr != -1)
|
|
|
|
biblioModule->biblatexBbxCO->setCurrentIndex(item_nr);
|
|
|
|
else
|
|
|
|
biblioModule->biblatexBbxCO->clearEditText();
|
|
|
|
}
|
2016-12-31 14:57:09 +01:00
|
|
|
|
2017-01-08 09:39:46 +01:00
|
|
|
if (which != "bbx") {
|
|
|
|
// now the cbx styles
|
2017-01-13 10:57:53 +01:00
|
|
|
biblioModule->biblatexCbxCO->clear();
|
2017-01-08 09:39:46 +01:00
|
|
|
QStringList str = texFileList("cbxFiles.lst");
|
|
|
|
// test whether we have a valid list, otherwise run rescan
|
|
|
|
if (str.isEmpty()) {
|
|
|
|
rescanTexStyles("cbx");
|
|
|
|
str = texFileList("cbxFiles.lst");
|
|
|
|
}
|
|
|
|
for (int i = 0; i != str.size(); ++i)
|
|
|
|
str[i] = onlyFileName(str[i]);
|
|
|
|
// sort on filename only (no path)
|
|
|
|
str.sort();
|
|
|
|
|
|
|
|
for (int i = 0; i != str.count(); ++i) {
|
|
|
|
QString item = changeExtension(str[i], "");
|
|
|
|
if (item == bibstyle)
|
|
|
|
item_nr = i;
|
|
|
|
biblioModule->biblatexCbxCO->addItem(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item_nr == -1 && !bibstyle.isEmpty()) {
|
|
|
|
biblioModule->biblatexCbxCO->addItem(bibstyle);
|
|
|
|
item_nr = biblioModule->biblatexCbxCO->count() - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item_nr != -1)
|
|
|
|
biblioModule->biblatexCbxCO->setCurrentIndex(item_nr);
|
|
|
|
else
|
|
|
|
biblioModule->biblatexCbxCO->clearEditText();
|
|
|
|
}
|
|
|
|
} else {// BibTeX
|
2017-01-13 10:57:53 +01:00
|
|
|
biblioModule->biblatexBbxCO->clear();
|
|
|
|
biblioModule->biblatexCbxCO->clear();
|
2017-01-08 09:39:46 +01:00
|
|
|
QStringList str = texFileList("bstFiles.lst");
|
|
|
|
// test whether we have a valid list, otherwise run rescan
|
|
|
|
if (str.isEmpty()) {
|
|
|
|
rescanTexStyles("bst");
|
|
|
|
str = texFileList("bstFiles.lst");
|
|
|
|
}
|
|
|
|
for (int i = 0; i != str.size(); ++i)
|
|
|
|
str[i] = onlyFileName(str[i]);
|
|
|
|
// sort on filename only (no path)
|
|
|
|
str.sort();
|
|
|
|
|
|
|
|
for (int i = 0; i != str.count(); ++i) {
|
|
|
|
QString item = changeExtension(str[i], "");
|
|
|
|
if (item == bibstyle)
|
|
|
|
item_nr = i;
|
|
|
|
biblioModule->defaultBiblioCO->addItem(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item_nr == -1 && !bibstyle.isEmpty()) {
|
|
|
|
biblioModule->defaultBiblioCO->addItem(bibstyle);
|
|
|
|
item_nr = biblioModule->defaultBiblioCO->count() - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (item_nr != -1)
|
|
|
|
biblioModule->defaultBiblioCO->setCurrentIndex(item_nr);
|
|
|
|
else
|
|
|
|
biblioModule->defaultBiblioCO->clearEditText();
|
|
|
|
}
|
2016-12-31 14:57:09 +01:00
|
|
|
|
|
|
|
updateResetDefaultBiblio();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::updateResetDefaultBiblio()
|
|
|
|
{
|
|
|
|
QString const engine =
|
|
|
|
biblioModule->citeEngineCO->itemData(
|
|
|
|
biblioModule->citeEngineCO->currentIndex()).toString();
|
|
|
|
CiteEngineType const cet =
|
|
|
|
CiteEngineType(biblioModule->citeStyleCO->itemData(
|
|
|
|
biblioModule->citeStyleCO->currentIndex()).toInt());
|
2017-01-08 09:39:46 +01:00
|
|
|
|
|
|
|
string const defbib = theCiteEnginesList[fromqstr(engine)]->getDefaultBiblio(cet);
|
|
|
|
if (isBiblatex()) {
|
|
|
|
QString const bbx = biblioModule->biblatexBbxCO->currentText();
|
|
|
|
QString const cbx = biblioModule->biblatexCbxCO->currentText();
|
|
|
|
biblioModule->resetCbxPB->setEnabled(defbib != fromqstr(cbx));
|
|
|
|
biblioModule->resetBbxPB->setEnabled(defbib != fromqstr(bbx));
|
|
|
|
biblioModule->matchBbxPB->setEnabled(bbx != cbx && !cbx.isEmpty()
|
|
|
|
&& biblioModule->biblatexBbxCO->findText(cbx) != -1);
|
|
|
|
} else
|
|
|
|
biblioModule->resetDefaultBiblioPB->setEnabled(
|
|
|
|
defbib != fromqstr(biblioModule->defaultBiblioCO->currentText()));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::matchBiblatexStyles()
|
|
|
|
{
|
|
|
|
updateDefaultBiblio(fromqstr(biblioModule->biblatexCbxCO->currentText()), "bbx");
|
|
|
|
biblioChanged();
|
2016-12-31 14:57:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
void GuiDocument::updateContents()
|
|
|
|
{
|
Run codespell on src/frontends
Command was:
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/frontends/
2020-06-26 00:04:31 +02:00
|
|
|
// Nothing to do here as the document settings is not cursor dependent.
|
2008-05-15 08:41:17 +00:00
|
|
|
return;
|
2008-01-15 10:38:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
void GuiDocument::useClassDefaults()
|
2006-03-05 17:24:44 +00:00
|
|
|
{
|
2018-07-09 09:46:39 +02:00
|
|
|
if (buttonBox->button(QDialogButtonBox::Apply)->isEnabled()) {
|
2008-01-15 10:38:19 +00:00
|
|
|
int const ret = Alert::prompt(_("Unapplied changes"),
|
2008-03-09 16:29:01 +00:00
|
|
|
_("Some changes in the dialog were not yet applied.\n"
|
2008-01-15 10:38:19 +00:00
|
|
|
"If you do not apply now, they will be lost after this action."),
|
|
|
|
1, 1, _("&Apply"), _("&Dismiss"));
|
|
|
|
if (ret == 0)
|
|
|
|
applyView();
|
|
|
|
}
|
|
|
|
|
2008-02-28 21:04:55 +00:00
|
|
|
int idx = latexModule->classCO->currentIndex();
|
2012-10-09 07:22:48 +02:00
|
|
|
string const classname = fromqstr(latexModule->classCO->getData(idx));
|
2018-11-16 21:47:24 +01:00
|
|
|
if (!bp_.setBaseClass(classname, buffer().layoutPos())) {
|
2008-02-28 21:04:55 +00:00
|
|
|
Alert::error(_("Error"), _("Unable to set document class."));
|
|
|
|
return;
|
|
|
|
}
|
2007-10-06 22:43:21 +00:00
|
|
|
bp_.useClassDefaults();
|
2008-10-14 16:59:28 +00:00
|
|
|
paramsToDialog();
|
2017-11-01 12:03:54 +01:00
|
|
|
changed();
|
2006-03-05 17:24:44 +00:00
|
|
|
}
|
|
|
|
|
2007-07-27 18:17:00 +00:00
|
|
|
|
2008-10-14 14:04:21 +00:00
|
|
|
void GuiDocument::setLayoutComboByIDString(string const & idString)
|
2008-03-01 22:08:16 +00:00
|
|
|
{
|
2012-10-09 07:22:48 +02:00
|
|
|
if (!latexModule->classCO->set(toqstr(idString)))
|
2011-12-03 22:15:11 +00:00
|
|
|
Alert::warning(_("Can't set layout!"),
|
2008-03-01 22:08:16 +00:00
|
|
|
bformat(_("Unable to set layout for ID: %1$s"), from_utf8(idString)));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
bool GuiDocument::isValid()
|
2007-07-27 18:17:00 +00:00
|
|
|
{
|
2011-12-03 22:15:11 +00:00
|
|
|
return
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
validateListingsParameters().isEmpty() &&
|
|
|
|
localLayout->isValid() &&
|
2018-04-19 23:33:40 -04:00
|
|
|
!localLayout->editing() &&
|
|
|
|
!preambleModule->editing() &&
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
(
|
|
|
|
// if we're asking for skips between paragraphs
|
|
|
|
!textLayoutModule->skipRB->isChecked() ||
|
|
|
|
// then either we haven't chosen custom
|
2011-12-03 22:15:11 +00:00
|
|
|
textLayoutModule->skipCO->currentIndex() != 3 ||
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
// or else a length has been given
|
|
|
|
!textLayoutModule->skipLE->text().isEmpty()
|
2011-12-03 22:15:11 +00:00
|
|
|
) &&
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
(
|
|
|
|
// if we're asking for indentation
|
2011-12-03 22:15:11 +00:00
|
|
|
!textLayoutModule->indentRB->isChecked() ||
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
// then either we haven't chosen custom
|
2011-12-03 22:15:11 +00:00
|
|
|
textLayoutModule->indentCO->currentIndex() != 1 ||
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
// or else a length has been given
|
|
|
|
!textLayoutModule->indentLE->text().isEmpty()
|
2017-04-17 20:58:09 +02:00
|
|
|
) &&
|
|
|
|
(
|
2017-05-09 01:00:36 +02:00
|
|
|
// if we're asking for math indentation
|
2017-04-25 03:01:39 +02:00
|
|
|
!mathsModule->MathIndentCB->isChecked() ||
|
2017-04-17 20:58:09 +02:00
|
|
|
// then either we haven't chosen custom
|
2017-04-25 03:01:39 +02:00
|
|
|
mathsModule->MathIndentCO->currentIndex() != 1 ||
|
2017-04-17 20:58:09 +02:00
|
|
|
// or else a length has been given
|
2017-04-25 03:01:39 +02:00
|
|
|
!mathsModule->MathIndentLE->text().isEmpty()
|
A UI for document-local layout information. LyX has supported this for a
while, but without any UI for it. (There has been local layout in the
Customization manual for a long time, in fact.)
Yes, this is an advanced feature. But, absent a layout editor, it is the
one thing that will make it easier, and possible, for "normal users" to
experiment with layout without having to go through reconfiguration,
etc, etc. To keep too many people from shooting themselves, we validate
the layout information before allowing the user to apply it.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35061 a592a061-630c-0410-9148-cb99ea01b6c8
2010-08-05 22:47:42 +00:00
|
|
|
);
|
2007-07-27 18:17:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
char const * const GuiDocument::fontfamilies[5] = {
|
|
|
|
"default", "rmdefault", "sfdefault", "ttdefault", ""
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
char const * GuiDocument::fontfamilies_gui[5] = {
|
|
|
|
N_("Default"), N_("Roman"), N_("Sans Serif"), N_("Typewriter"), ""
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
bool GuiDocument::initialiseParams(string const &)
|
|
|
|
{
|
2008-09-29 10:52:17 +00:00
|
|
|
BufferView const * view = bufferview();
|
2008-05-15 08:41:17 +00:00
|
|
|
if (!view) {
|
|
|
|
bp_ = BufferParams();
|
2008-10-14 16:59:28 +00:00
|
|
|
paramsToDialog();
|
2008-05-15 08:41:17 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
bp_ = view->buffer().params();
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
loadModuleInfo();
|
2008-05-15 08:41:17 +00:00
|
|
|
updateAvailableModules();
|
|
|
|
//FIXME It'd be nice to make sure here that the selected
|
|
|
|
//modules are consistent: That required modules are actually
|
|
|
|
//selected, and that we don't have conflicts. If so, we could
|
|
|
|
//at least pop up a warning.
|
2008-10-14 16:59:28 +00:00
|
|
|
paramsToDialog();
|
2007-10-06 22:43:21 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::clearParams()
|
|
|
|
{
|
|
|
|
bp_ = BufferParams();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BufferId GuiDocument::id() const
|
|
|
|
{
|
2008-05-15 08:41:17 +00:00
|
|
|
BufferView const * const view = bufferview();
|
2020-02-26 22:29:40 -05:00
|
|
|
return view? &view->buffer() : nullptr;
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-14 14:04:21 +00:00
|
|
|
list<GuiDocument::modInfoStruct> const & GuiDocument::getModuleInfo()
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
|
|
|
return moduleNames_;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-12-03 22:15:11 +00:00
|
|
|
list<GuiDocument::modInfoStruct> const
|
2016-05-31 18:47:29 +01:00
|
|
|
GuiDocument::makeModuleInfo(LayoutModuleList const & mods)
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
2008-10-14 14:04:21 +00:00
|
|
|
list<modInfoStruct> mInfo;
|
2016-05-31 18:47:29 +01:00
|
|
|
for (string const & name : mods) {
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
modInfoStruct m;
|
2016-05-31 18:47:29 +01:00
|
|
|
LyXModule const * const mod = theModuleList[name];
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
if (mod)
|
2016-05-31 18:47:29 +01:00
|
|
|
m = modInfo(*mod);
|
|
|
|
else {
|
|
|
|
m.id = name;
|
|
|
|
m.name = toqstr(name + " (") + qt_("Not Found") + toqstr(")");
|
2019-04-20 09:28:46 +02:00
|
|
|
m.local = false;
|
|
|
|
m.missingreqs = true;
|
2016-05-31 18:47:29 +01:00
|
|
|
}
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
mInfo.push_back(m);
|
|
|
|
}
|
|
|
|
return mInfo;
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-23 00:27:03 +00:00
|
|
|
list<GuiDocument::modInfoStruct> const GuiDocument::getSelectedModules()
|
|
|
|
{
|
|
|
|
return makeModuleInfo(params().getModules());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
list<GuiDocument::modInfoStruct> const GuiDocument::getProvidedModules()
|
|
|
|
{
|
|
|
|
return makeModuleInfo(params().baseClass()->providedModules());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-02-28 21:04:55 +00:00
|
|
|
DocumentClass const & GuiDocument::documentClass() const
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
2008-02-28 21:04:55 +00:00
|
|
|
return bp_.documentClass();
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-09 21:21:01 +00:00
|
|
|
static void dispatch_bufferparams(Dialog const & dialog,
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
BufferParams const & bp, FuncCode lfun, Buffer const * buf)
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
|
|
|
ostringstream ss;
|
|
|
|
ss << "\\begin_header\n";
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
bp.writeFile(ss, buf);
|
2007-10-06 22:43:21 +00:00
|
|
|
ss << "\\end_header\n";
|
2007-10-09 21:21:01 +00:00
|
|
|
dialog.dispatch(FuncRequest(lfun, ss.str()));
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::dispatchParams()
|
|
|
|
{
|
2014-03-03 18:24:51 +01:00
|
|
|
// We need a non-const buffer object.
|
|
|
|
Buffer & buf = const_cast<BufferView *>(bufferview())->buffer();
|
|
|
|
// There may be several undo records; group them (bug #8998)
|
2017-12-13 11:10:49 +01:00
|
|
|
// This handles undo groups automagically
|
|
|
|
UndoGroupHelper ugh(&buf);
|
2014-03-03 18:24:51 +01:00
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
// This must come first so that a language change is correctly noticed
|
|
|
|
setLanguage();
|
|
|
|
|
2018-12-29 00:23:26 -05:00
|
|
|
// We need to load the master before we formally update the params,
|
|
|
|
// since otherwise we run updateBuffer, etc, before the child's master
|
|
|
|
// has been set.
|
2008-04-28 16:38:56 +00:00
|
|
|
if (!params().master.empty()) {
|
|
|
|
FileName const master_file = support::makeAbsPath(params().master,
|
|
|
|
support::onlyPath(buffer().absFileName()));
|
2010-04-21 01:19:31 +00:00
|
|
|
if (isLyXFileName(master_file.absFileName())) {
|
2008-04-28 16:38:56 +00:00
|
|
|
Buffer * master = checkAndLoadLyXFile(master_file);
|
2009-01-08 07:59:37 +00:00
|
|
|
if (master) {
|
|
|
|
if (master->isChild(const_cast<Buffer *>(&buffer())))
|
|
|
|
const_cast<Buffer &>(buffer()).setParent(master);
|
|
|
|
else
|
2011-12-03 22:15:11 +00:00
|
|
|
Alert::warning(_("Assigned master does not include this file"),
|
2009-01-08 07:59:37 +00:00
|
|
|
bformat(_("You must include this file in the document\n"
|
|
|
|
"'%1$s' in order to use the master document\n"
|
|
|
|
"feature."), from_utf8(params().master)));
|
|
|
|
} else
|
2011-12-03 22:15:11 +00:00
|
|
|
Alert::warning(_("Could not load master"),
|
2009-01-08 08:00:37 +00:00
|
|
|
bformat(_("The master document '%1$s'\n"
|
2009-01-08 07:59:37 +00:00
|
|
|
"could not be loaded."),
|
|
|
|
from_utf8(params().master)));
|
2008-04-28 16:38:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-29 00:23:26 -05:00
|
|
|
// Apply the BufferParams. Note that this will set the base class
|
|
|
|
// and then update the buffer's layout.
|
|
|
|
dispatch_bufferparams(*this, params(), LFUN_BUFFER_PARAMS_APPLY, &buffer());
|
|
|
|
|
2007-10-06 22:43:21 +00:00
|
|
|
// Generate the colours requested by each new branch.
|
|
|
|
BranchList & branchlist = params().branchlist();
|
|
|
|
if (!branchlist.empty()) {
|
|
|
|
BranchList::const_iterator it = branchlist.begin();
|
|
|
|
BranchList::const_iterator const end = branchlist.end();
|
|
|
|
for (; it != end; ++it) {
|
2008-09-21 19:27:20 +00:00
|
|
|
docstring const & current_branch = it->branch();
|
2007-10-06 22:43:21 +00:00
|
|
|
Branch const * branch = branchlist.find(current_branch);
|
2008-09-21 19:27:20 +00:00
|
|
|
string const x11hexname = X11hexname(branch->color());
|
2007-10-06 22:43:21 +00:00
|
|
|
// display the new color
|
|
|
|
docstring const str = current_branch + ' ' + from_ascii(x11hexname);
|
|
|
|
dispatch(FuncRequest(LFUN_SET_COLOR, str));
|
|
|
|
}
|
|
|
|
}
|
2009-07-11 10:53:29 +00:00
|
|
|
// rename branches in the document
|
|
|
|
executeBranchRenaming();
|
|
|
|
// and clear changed branches cache
|
|
|
|
changedBranches_.clear();
|
2011-12-03 22:15:11 +00:00
|
|
|
|
2009-04-16 07:29:01 +00:00
|
|
|
// Generate the colours requested by indices.
|
|
|
|
IndicesList & indiceslist = params().indiceslist();
|
|
|
|
if (!indiceslist.empty()) {
|
|
|
|
IndicesList::const_iterator it = indiceslist.begin();
|
|
|
|
IndicesList::const_iterator const end = indiceslist.end();
|
|
|
|
for (; it != end; ++it) {
|
2009-07-13 06:46:52 +00:00
|
|
|
docstring const & current_index = it->shortcut();
|
|
|
|
Index const * index = indiceslist.findShortcut(current_index);
|
2009-04-16 07:29:01 +00:00
|
|
|
string const x11hexname = X11hexname(index->color());
|
|
|
|
// display the new color
|
|
|
|
docstring const str = current_index + ' ' + from_ascii(x11hexname);
|
|
|
|
dispatch(FuncRequest(LFUN_SET_COLOR, str));
|
|
|
|
}
|
|
|
|
}
|
2010-10-14 15:04:57 +00:00
|
|
|
// FIXME LFUN
|
|
|
|
// If we used an LFUN, we would not need these two lines:
|
2008-09-29 10:52:17 +00:00
|
|
|
BufferView * bv = const_cast<BufferView *>(bufferview());
|
|
|
|
bv->processUpdateFlags(Update::Force | Update::FitCursor);
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::setLanguage() const
|
|
|
|
{
|
|
|
|
Language const * const newL = bp_.language;
|
|
|
|
if (buffer().params().language == newL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
string const & lang_name = newL->lang();
|
|
|
|
dispatch(FuncRequest(LFUN_BUFFER_LANGUAGE, lang_name));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::saveAsDefault() const
|
|
|
|
{
|
Fix bug #4812 (Layout in local directory lost on Save As, Copying)
The "save-as" part of the bug is fixed by extending the \textclass tag
such that, if a local layout file is used, its path relative to the
document directory is now stored together with the name. If a relative
path cannot be used, an absolute one is used but, in this case, the
document is not usable on a different platform.
The "copy" part is fixed by introducing a new \origin tag, which is
written when the file is saved. This tag stores the absolute path of
the document directory. If the document is manually copied to a
different location, the local layout file is retrivied by using
\origin (which is only updated on save).
This new tag may prove useful also for locating other files when the
document is manually moved to a different directory.
As in the original implementation the files needed for the layout
(for example, a latex class) had to be in the same directory as the
layout file, this directory has also to be added to TEXINPUTS.
2015-05-13 21:40:51 +02:00
|
|
|
dispatch_bufferparams(*this, params(), LFUN_BUFFER_SAVE_AS_DEFAULT, &buffer());
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
bool GuiDocument::providesOSF(QString const & font) const
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked())
|
2009-04-10 14:39:22 +00:00
|
|
|
// FIXME: we should check if the fonts really
|
|
|
|
// have OSF support. But how?
|
|
|
|
return true;
|
2012-09-22 10:59:53 +02:00
|
|
|
return theLaTeXFonts().getLaTeXFont(
|
2012-09-22 17:44:00 +02:00
|
|
|
qstring_to_ucs4(font)).providesOSF(ot1(),
|
|
|
|
completeFontset(),
|
|
|
|
noMathFont());
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
bool GuiDocument::providesSC(QString const & font) const
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked())
|
2009-04-10 14:39:22 +00:00
|
|
|
return false;
|
2012-09-22 10:59:53 +02:00
|
|
|
return theLaTeXFonts().getLaTeXFont(
|
2012-09-22 17:44:00 +02:00
|
|
|
qstring_to_ucs4(font)).providesSC(ot1(),
|
|
|
|
completeFontset(),
|
|
|
|
noMathFont());
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-16 13:23:39 +02:00
|
|
|
bool GuiDocument::providesScale(QString const & font) const
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
2010-11-26 09:42:03 +00:00
|
|
|
if (fontModule->osFontsCB->isChecked())
|
2009-04-10 14:39:22 +00:00
|
|
|
return true;
|
2012-09-22 10:59:53 +02:00
|
|
|
return theLaTeXFonts().getLaTeXFont(
|
2012-09-22 17:44:00 +02:00
|
|
|
qstring_to_ucs4(font)).providesScale(ot1(),
|
|
|
|
completeFontset(),
|
|
|
|
noMathFont());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-07-11 20:28:34 +02:00
|
|
|
bool GuiDocument::providesExtraOpts(QString const & font) const
|
|
|
|
{
|
|
|
|
if (fontModule->osFontsCB->isChecked())
|
|
|
|
return true;
|
|
|
|
return theLaTeXFonts().getLaTeXFont(
|
2019-07-13 14:55:07 +02:00
|
|
|
qstring_to_ucs4(font)).providesMoreOptions(ot1(),
|
|
|
|
completeFontset(),
|
|
|
|
noMathFont());
|
2019-07-11 20:28:34 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-09-22 17:44:00 +02:00
|
|
|
bool GuiDocument::providesNoMath(QString const & font) const
|
|
|
|
{
|
|
|
|
if (fontModule->osFontsCB->isChecked())
|
|
|
|
return false;
|
|
|
|
return theLaTeXFonts().getLaTeXFont(
|
|
|
|
qstring_to_ucs4(font)).providesNoMath(ot1(),
|
|
|
|
completeFontset());
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-02-11 15:02:24 +01:00
|
|
|
bool GuiDocument::hasMonolithicExpertSet(QString const & font) const
|
|
|
|
{
|
|
|
|
if (fontModule->osFontsCB->isChecked())
|
|
|
|
return false;
|
|
|
|
return theLaTeXFonts().getLaTeXFont(
|
|
|
|
qstring_to_ucs4(font)).hasMonolithicExpertSet(ot1(),
|
|
|
|
completeFontset(),
|
|
|
|
noMathFont());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-05-31 18:47:29 +01:00
|
|
|
//static
|
|
|
|
GuiDocument::modInfoStruct GuiDocument::modInfo(LyXModule const & mod)
|
|
|
|
{
|
|
|
|
// FIXME Unicode: docstrings would be better for these parameters but this
|
|
|
|
// change requires a lot of others
|
|
|
|
modInfoStruct m;
|
|
|
|
m.id = mod.getID();
|
2019-04-20 09:28:46 +02:00
|
|
|
QString const guiname = toqstr(translateIfPossible(from_utf8(mod.getName())));
|
|
|
|
m.missingreqs = !isModuleAvailable(mod.getID());
|
|
|
|
if (m.missingreqs) {
|
|
|
|
m.name = QString(qt_("%1 (missing req.)")).arg(guiname);
|
|
|
|
} else
|
|
|
|
m.name = guiname;
|
2019-04-05 11:52:37 +02:00
|
|
|
m.category = mod.category().empty() ? qt_("Miscellaneous")
|
|
|
|
: toqstr(translateIfPossible(from_utf8(mod.category())));
|
2016-05-31 18:47:29 +01:00
|
|
|
QString desc = toqstr(translateIfPossible(from_utf8(mod.getDescription())));
|
|
|
|
// Find the first sentence of the description
|
|
|
|
QTextBoundaryFinder bf(QTextBoundaryFinder::Sentence, desc);
|
|
|
|
int pos = bf.toNextBoundary();
|
|
|
|
if (pos > 0)
|
|
|
|
desc.truncate(pos);
|
2019-04-20 09:28:46 +02:00
|
|
|
m.local = mod.isLocal();
|
|
|
|
QString const mtype = m.local ? qt_("personal module") : qt_("distributed module");
|
|
|
|
QString modulename = QString(qt_("<b>Module name:</b> <i>%1</i> (%2)")).arg(toqstr(m.id)).arg(mtype);
|
|
|
|
// Tooltip is the desc followed by the module name and the type
|
|
|
|
m.description = QString("%1%2")
|
2016-05-31 18:47:29 +01:00
|
|
|
.arg(desc.isEmpty() ? QString() : QString("<p>%1</p>").arg(desc),
|
|
|
|
modulename);
|
2019-04-20 09:28:46 +02:00
|
|
|
if (m.missingreqs)
|
|
|
|
m.description += QString("<p>%1</p>").arg(qt_("<b>Note:</b> Some requirements for this module are missing!"));
|
2016-05-31 18:47:29 +01:00
|
|
|
return m;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
This commit changes the way individual LyXModule's are represented, both internally and in the .lyx files. The earlier version represented them by their `descriptive name', e.g., "Endnote" or "Theorems (AMS)", these being the same names used in the UI. This was a mistake, as becomes readily apparent when one starts to think about translating these strings. The modules ought to be represented by their filename, without the extension, just as TextClass's are.
The changes that accomplish this part are in ModuleList.{h,cpp}, configure.py, and the *.module files themselves. This is a format change, and the lyx2lyx is in those files.
By itself, that change would not be major, except for the fact that we do not want the module to be represented in the UI by its filename---e.g., theorems-std---but rather by a descriptive name, such as "Theorems". But that change turns out to be wholly non-trivial. The mechanism for choosing modules was the same as---indeed, was borrowed from---that in GuiCitation: You get a list of modules, and choosing them involves moving strings from one QListView to another. The models underlying these views are just QStringListModels, which means that, when you want to know what modules have been selected, you see what strings are in the "selected" QListView. But these are just the descriptive names, and we can't look up a module by its descriptive name if it's been translated. That, indeed, was the whole point of the change to the new representation.
So, we need a more complicated model underlying the QListView, one that will pair an identifying string---the filename minus the extension, in this case---with each item. This turns out not to be terribly difficult, though it took rather a while for me to understand why it's not difficult. There are two parts:
(i) GuiSelectionManger gets re-written to use any QAbstractListModel, not just a QStringListModel. This actually seems to improve the code, independently.
(ii) We then subclass QAbstractListModel to get the associated ID string, using the Qt::UserRole slot associated with each item to store its ID. This would be almost completely trivial if QAbstractListItem::itemData() included the QVariant associated with this role, but it doesn't, so there are some additional hoops through which to jump.
The new model, a GuiIdListModel, is defined in the files by that name. The changes in GuiSelectionManger.{h,cpp} make it more abstract; the changes in GuiDocument.{h,cpp} adapt it to the new framework.
I've also updated the module documenation to accord with this change.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22501 a592a061-630c-0410-9148-cb99ea01b6c8
2008-01-12 04:28:12 +00:00
|
|
|
void GuiDocument::loadModuleInfo()
|
2007-10-06 22:43:21 +00:00
|
|
|
{
|
|
|
|
moduleNames_.clear();
|
2016-05-31 18:47:29 +01:00
|
|
|
for (LyXModule const & mod : theModuleList)
|
2019-04-05 11:52:37 +02:00
|
|
|
moduleNames_.push_back(modInfo(mod));
|
2007-10-06 22:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-07-09 09:48:34 +00:00
|
|
|
void GuiDocument::updateUnknownBranches()
|
|
|
|
{
|
2010-02-01 14:44:12 +00:00
|
|
|
if (!bufferview())
|
|
|
|
return;
|
2009-07-09 09:48:34 +00:00
|
|
|
list<docstring> used_branches;
|
|
|
|
buffer().getUsedBranches(used_branches);
|
|
|
|
list<docstring>::const_iterator it = used_branches.begin();
|
|
|
|
QStringList unknown_branches;
|
2009-07-09 11:16:27 +00:00
|
|
|
for (; it != used_branches.end() ; ++it) {
|
2009-07-09 09:48:34 +00:00
|
|
|
if (!buffer().params().branchlist().find(*it))
|
|
|
|
unknown_branches.append(toqstr(*it));
|
|
|
|
}
|
|
|
|
branchesModule->setUnknownBranches(unknown_branches);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-07-10 06:49:51 +00:00
|
|
|
void GuiDocument::branchesRename(docstring const & oldname, docstring const & newname)
|
|
|
|
{
|
2009-07-11 09:37:28 +00:00
|
|
|
map<docstring, docstring>::iterator it = changedBranches_.begin();
|
|
|
|
for (; it != changedBranches_.end() ; ++it) {
|
|
|
|
if (it->second == oldname) {
|
|
|
|
// branch has already been renamed
|
|
|
|
it->second = newname;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// store new name
|
|
|
|
changedBranches_[oldname] = newname;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::executeBranchRenaming() const
|
|
|
|
{
|
|
|
|
map<docstring, docstring>::const_iterator it = changedBranches_.begin();
|
|
|
|
for (; it != changedBranches_.end() ; ++it) {
|
|
|
|
docstring const arg = '"' + it->first + '"' + " " + '"' + it->second + '"';
|
|
|
|
dispatch(FuncRequest(LFUN_BRANCHES_RENAME, arg));
|
|
|
|
}
|
2009-07-10 06:49:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-02 10:03:08 +01:00
|
|
|
void GuiDocument::allPackagesAuto()
|
|
|
|
{
|
|
|
|
allPackages(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::allPackagesAlways()
|
|
|
|
{
|
|
|
|
allPackages(2);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::allPackagesNot()
|
|
|
|
{
|
|
|
|
allPackages(3);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void GuiDocument::allPackages(int col)
|
|
|
|
{
|
|
|
|
for (int row = 0; row < mathsModule->packagesTW->rowCount(); ++row) {
|
2018-03-18 12:11:26 +01:00
|
|
|
QRadioButton * rb =
|
|
|
|
(QRadioButton*)mathsModule->packagesTW->cellWidget(row, col)->layout()->itemAt(0)->widget();
|
2013-03-02 10:03:08 +01:00
|
|
|
rb->setChecked(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-05-24 17:51:42 +02:00
|
|
|
void GuiDocument::linenoToggled(bool on)
|
2019-05-24 15:40:09 +02:00
|
|
|
{
|
2019-05-24 17:51:42 +02:00
|
|
|
numberingModule->linenoLE->setEnabled(on);
|
|
|
|
numberingModule->linenoLA->setEnabled(on);
|
2019-05-24 15:40:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-12-24 18:43:22 +01:00
|
|
|
void GuiDocument::outputChangesToggled(bool on)
|
|
|
|
{
|
|
|
|
changesModule->changeBarsCB->setEnabled(on);
|
|
|
|
change_adaptor();
|
|
|
|
}
|
|
|
|
|
2020-01-10 10:21:09 +01:00
|
|
|
void GuiDocument::setOutputSync(bool on)
|
|
|
|
{
|
|
|
|
outputModule->synccustomCB->setEnabled(on);
|
|
|
|
outputModule->synccustomLA->setEnabled(on);
|
|
|
|
change_adaptor();
|
|
|
|
}
|
|
|
|
|
2019-12-24 18:43:22 +01:00
|
|
|
|
2006-03-05 17:24:44 +00:00
|
|
|
} // namespace frontend
|
|
|
|
} // namespace lyx
|
2007-04-24 19:37:34 +00:00
|
|
|
|
2008-11-14 14:28:50 +00:00
|
|
|
#include "moc_GuiDocument.cpp"
|