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"
22 #include "GuiSelectionManager.h"
24 #include "ui_DocumentUi.h"
25 #include "ui_EmbeddedFilesUi.h"
26 #include "ui_FontUi.h"
27 #include "ui_TextLayoutUi.h"
28 #include "ui_MathsUi.h"
29 #include "ui_LaTeXUi.h"
30 #include "ui_PageLayoutUi.h"
31 #include "ui_LanguageUi.h"
32 #include "ui_BiblioUi.h"
33 #include "ui_NumberingUi.h"
34 #include "ui_MarginsUi.h"
35 #include "ui_PreambleUi.h"
36 #include "ui_PDFSupportUi.h"
54 QModelIndex getSelectedIndex(QListView * lv);
57 typedef void const * BufferId;
60 class UiWidget : public QWidget, public UI
63 UiWidget(QWidget * parent = 0) : QWidget(parent) { UI::setupUi(this); }
67 /// SelectionManager for use with modules
68 class ModuleSelMan : public GuiSelectionManager
72 QListView * availableLV,
73 QListView * selectedLV,
78 GuiIdListModel * availableModel,
79 GuiIdListModel * selectedModel);
82 virtual void updateAddPB();
84 virtual void updateUpPB();
86 virtual void updateDownPB();
88 virtual void updateDelPB();
89 /// returns availableModel as a GuiIdListModel
90 GuiIdListModel * getAvailableModel()
92 return dynamic_cast<GuiIdListModel *>(availableModel);
94 /// returns selectedModel as a GuiIdListModel
95 GuiIdListModel * getSelectedModel()
97 return dynamic_cast<GuiIdListModel *>(selectedModel);
102 class GuiDocument : public GuiDialog, public Ui::DocumentUi
106 GuiDocument(GuiView & lv);
108 void updateParams(BufferParams const & params);
109 void apply(BufferParams & params);
111 void updateFontsize(std::string const &, std::string const &);
112 void updatePagestyle(std::string const &, std::string const &);
115 /// validate listings parameters and return an error message, if any
116 docstring validate_listings_params();
119 void updateNumbering();
120 void change_adaptor();
121 void set_listings_msg();
122 void saveDefaultClicked();
123 void useDefaultsClicked();
127 void setLSpacing(int);
128 void setMargins(bool);
129 void setCustomPapersize(int);
131 void setCustomMargins(bool);
132 void romanChanged(int);
133 void sansChanged(int);
136 void enableSkip(bool);
137 void portraitChanged();
139 void updateModuleInfo();
140 void updateEmbeddedFileList();
143 UiWidget<Ui::TextLayoutUi> *textLayoutModule;
144 UiWidget<Ui::FontUi> *fontModule;
145 UiWidget<Ui::PageLayoutUi> *pageLayoutModule;
146 UiWidget<Ui::MarginsUi> *marginsModule;
147 UiWidget<Ui::LanguageUi> *langModule;
148 UiWidget<Ui::NumberingUi> *numberingModule;
149 UiWidget<Ui::BiblioUi> *biblioModule;
150 UiWidget<Ui::MathsUi> *mathsModule;
151 UiWidget<Ui::LaTeXUi> *latexModule;
152 UiWidget<Ui::PDFSupportUi> *pdfSupportModule;
153 UiWidget<Ui::EmbeddedFilesUi> *embeddedFilesModule;
154 PreambleModule *preambleModule;
156 GuiBranches *branchesModule;
158 BulletsModule * bulletsModule;
159 FloatPlacement * floatModule;
161 GuiSelectionManager * selectionManager;
166 /// Available modules
167 GuiIdListModel * availableModel() { return &modules_av_model_; }
169 GuiIdListModel * selectedModel() { return &modules_sel_model_; }
174 void updateContents();
175 /// force content update
178 void updateAvailableModules();
180 void updateSelectedModules();
181 /// save as default template
182 void saveDocDefault();
183 /// reset to default params
184 void useClassDefaults();
186 void setLayoutComboByIDString(std::string const & idString);
187 /// available classes
188 GuiIdListModel classes_model_;
189 /// available modules
190 GuiIdListModel modules_av_model_;
192 GuiIdListModel modules_sel_model_;
194 BufferId current_id_;
197 /// return false if validate_listings_params returns error
200 /// font family names for BufferParams::fontsDefaultFamily
201 static char const * const fontfamilies[5];
202 /// GUI names corresponding fontfamilies
203 static char const * fontfamilies_gui[5];
205 bool initialiseParams(std::string const & data);
209 void dispatchParams();
211 bool isBufferDependent() const { return true; }
212 /// always true since we don't manipulate document contents
213 bool canApply() const { return true; }
215 DocumentClass const & documentClass() const;
217 BufferParams & params() { return bp_; }
219 BufferParams const & params() const { return bp_; }
223 struct modInfoStruct {
227 /// List of available modules
228 std::vector<modInfoStruct> const & getModuleInfo();
229 /// Modules in use in current buffer
230 std::vector<modInfoStruct> const getSelectedModules();
232 void setLanguage() const;
234 void saveAsDefault() const;
236 bool isFontAvailable(std::string const & font) const;
237 /// does this font provide Old Style figures?
238 bool providesOSF(std::string const & font) const;
239 /// does this font provide true Small Caps?
240 bool providesSC(std::string const & font) const;
241 /// does this font provide size adjustment?
242 bool providesScale(std::string const & font) const;
245 void loadModuleInfo();
248 /// List of names of available modules
249 std::vector<modInfoStruct> moduleNames_;
253 class PreambleModule : public UiWidget<Ui::PreambleUi>
258 void update(BufferParams const & params, BufferId id);
259 void apply(BufferParams & params);
262 /// signal that something's changed in the Widget.
266 void closeEvent(QCloseEvent *);
267 void on_preambleTE_textChanged() { changed(); }
270 typedef std::map<BufferId, std::pair<int,int> > Coords;
271 Coords preamble_coords_;
272 BufferId current_id_;
276 } // namespace frontend
279 #endif // GUIDOCUMENT_H