4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
8 * \author Richard Heck (modules)
10 * Full author contact details are available in file CREDITS.
18 #include "BufferParams.h"
19 #include "BulletsModule.h"
20 #include "GuiDialog.h"
21 #include "GuiIdListModel.h"
23 #include "ui_DocumentUi.h"
24 #include "ui_FontUi.h"
25 #include "ui_TextLayoutUi.h"
26 #include "ui_MathsUi.h"
27 #include "ui_LaTeXUi.h"
28 #include "ui_PageLayoutUi.h"
29 #include "ui_LanguageUi.h"
30 #include "ui_BiblioUi.h"
31 #include "ui_NumberingUi.h"
32 #include "ui_MarginsUi.h"
33 #include "ui_PreambleUi.h"
34 #include "ui_PDFSupportUi.h"
35 #include "ui_ModulesUi.h"
36 #include "ui_OutputUi.h"
37 #include "ui_ListingsSettingsUi.h"
46 class LayoutModuleList;
53 class ModuleSelectionManager;
57 typedef void const * BufferId;
60 class UiWidget : public QWidget, public UI
63 UiWidget(QWidget * parent = 0) : QWidget(parent) { UI::setupUi(this); }
67 class GuiDocument : public GuiDialog, public Ui::DocumentUi
71 GuiDocument(GuiView & lv);
73 void paramsToDialog();
74 void updateFontsize(std::string const &, std::string const &);
75 void updateFontlist();
76 void updateDefaultFormat();
77 void updatePagestyle(std::string const &, std::string const &);
81 BufferParams const & params() const { return bp_; }
84 void updateNumbering();
85 void change_adaptor();
86 void setListingsMessage();
87 void saveDefaultClicked();
88 void useDefaultsClicked();
89 void setLSpacing(int);
90 void setMargins(bool);
91 void papersizeChanged(int);
93 void setCustomMargins(bool);
94 void fontencChanged(int);
95 void romanChanged(int);
96 void sansChanged(int);
99 void enableIndent(bool);
101 void enableSkip(bool);
102 void portraitChanged();
106 void bibtexChanged(int);
107 void updateModuleInfo();
108 void modulesChanged();
109 void changeBackgroundColor();
110 void deleteBackgroundColor();
111 void xetexChanged(bool);
112 void branchesRename(docstring const &, docstring const &);
114 /// validate listings parameters and return an error message, if any
115 QString validateListingsParameters();
117 UiWidget<Ui::TextLayoutUi> *textLayoutModule;
118 UiWidget<Ui::FontUi> *fontModule;
119 UiWidget<Ui::PageLayoutUi> *pageLayoutModule;
120 UiWidget<Ui::MarginsUi> *marginsModule;
121 UiWidget<Ui::LanguageUi> *langModule;
122 UiWidget<Ui::NumberingUi> *numberingModule;
123 UiWidget<Ui::BiblioUi> *biblioModule;
124 UiWidget<Ui::MathsUi> *mathsModule;
125 UiWidget<Ui::LaTeXUi> *latexModule;
126 UiWidget<Ui::PDFSupportUi> *pdfSupportModule;
127 UiWidget<Ui::ModulesUi> *modulesModule;
128 UiWidget<Ui::OutputUi> *outputModule;
129 UiWidget<Ui::ListingsSettingsUi> *listingsModule;
130 PreambleModule * preambleModule;
132 GuiBranches * branchesModule;
133 GuiIndices * indicesModule;
135 BulletsModule * bulletsModule;
136 FloatPlacement * floatModule;
138 ModuleSelectionManager * selectionManager;
140 /// Available modules
141 GuiIdListModel * availableModel() { return &modules_av_model_; }
143 GuiIdListModel * selectedModel() { return &modules_sel_model_; }
148 void updateContents();
150 void updateAvailableModules();
152 void updateSelectedModules();
153 /// save as default template
154 void saveDocDefault();
155 /// reset to default params
156 void useClassDefaults();
158 void setLayoutComboByIDString(std::string const & idString);
159 /// available classes
160 GuiIdListModel classes_model_;
161 /// available modules
162 GuiIdListModel modules_av_model_;
164 GuiIdListModel modules_sel_model_;
166 BufferId current_id_;
168 /// return false if validate_listings_params returns error
171 /// font family names for BufferParams::fontsDefaultFamily
172 static char const * const fontfamilies[5];
173 /// GUI names corresponding fontfamilies
174 static char const * fontfamilies_gui[5];
176 bool initialiseParams(std::string const & data);
180 void dispatchParams();
182 void modulesToParams(BufferParams &);
184 bool isBufferDependent() const { return true; }
185 /// always true since we don't manipulate document contents
186 bool canApply() const { return true; }
188 DocumentClass const & documentClass() const;
190 BufferParams & params() { return bp_; }
194 struct modInfoStruct {
199 /// List of available modules
200 std::list<modInfoStruct> const & getModuleInfo();
201 /// Modules in use in current buffer
202 std::list<modInfoStruct> const getSelectedModules();
204 std::list<modInfoStruct> const getProvidedModules();
206 std::list<modInfoStruct> const
207 makeModuleInfo(LayoutModuleList const & mods);
209 void setLanguage() const;
211 void saveAsDefault() const;
213 bool isFontAvailable(std::string const & font) const;
214 /// does this font provide Old Style figures?
215 bool providesOSF(std::string const & font) const;
216 /// does this font provide true Small Caps?
217 bool providesSC(std::string const & font) const;
218 /// does this font provide size adjustment?
219 bool providesScale(std::string const & font) const;
221 void executeBranchRenaming() const;
223 void setCustomPapersize(bool custom);
226 void loadModuleInfo();
228 void updateUnknownBranches();
231 /// List of names of available modules
232 std::list<modInfoStruct> moduleNames_;
234 std::map<docstring, docstring> changedBranches_;
238 class PreambleModule : public UiWidget<Ui::PreambleUi>
243 void update(BufferParams const & params, BufferId id);
244 void apply(BufferParams & params);
247 /// signal that something's changed in the Widget.
251 void closeEvent(QCloseEvent *);
252 void on_preambleTE_textChanged() { changed(); }
255 typedef std::map<BufferId, std::pair<int,int> > Coords;
256 Coords preamble_coords_;
257 BufferId current_id_;
261 } // namespace frontend
264 #endif // GUIDOCUMENT_H