]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt4/GuiDocument.h
If we are in a closeEvent, we don't want to close all buffers, because these may...
[lyx.git] / src / frontends / qt4 / GuiDocument.h
index af66737fe988980454ac3f806b0f997b7075f38b..ea9924effccaf172720296d881d87027d54ed42c 100644 (file)
 #include "ui_MarginsUi.h"
 #include "ui_PreambleUi.h"
 #include "ui_PDFSupportUi.h"
+#include "ui_ModulesUi.h"
+#include "ui_OutputUi.h"
+#include "ui_ListingsSettingsUi.h"
 
+#include <list>
 #include <map>
-#include <vector>
 
 namespace lyx {
 
 class BufferParams;
 class FloatPlacement;
+class LayoutModuleList;
 class TextClass;
 
 namespace frontend {
 
 class GuiBranches;
-class GuiSelectionManager;
+class GuiIndices;
+class ModuleSelectionManager;
 class PreambleModule;
 
 ///
@@ -65,13 +70,15 @@ class GuiDocument : public GuiDialog, public Ui::DocumentUi
 public:
        GuiDocument(GuiView & lv);
 
-       void paramsToDialog(BufferParams const & params);
-       void apply(BufferParams & params);
-
+       void paramsToDialog();
        void updateFontsize(std::string const &, std::string const &);
+       void updateFontlist();
+       void updateDefaultFormat();
        void updatePagestyle(std::string const &, std::string const &);
 
        void showPreamble();
+       ///
+       BufferParams const & params() const { return bp_; }
 
 private Q_SLOTS:
        void updateNumbering();
@@ -81,20 +88,27 @@ private Q_SLOTS:
        void useDefaultsClicked();
        void setLSpacing(int);
        void setMargins(bool);
-       void setCustomPapersize(int);
+       void papersizeChanged(int);
        void setColSep();
        void setCustomMargins(bool);
        void romanChanged(int);
        void sansChanged(int);
        void ttChanged(int);
+       void setIndent(int);
+       void enableIndent(bool);
        void setSkip(int);
        void enableSkip(bool);
        void portraitChanged();
        void browseLayout();
        void browseMaster();
        void classChanged();
+       void bibtexChanged(int);
        void updateModuleInfo();
-
+       void modulesChanged();
+       void changeBackgroundColor();
+       void deleteBackgroundColor();
+       void xetexChanged(bool);
+       void branchesRename(docstring const &, docstring const &);
 private:
        /// validate listings parameters and return an error message, if any
        QString validateListingsParameters();
@@ -109,14 +123,18 @@ private:
        UiWidget<Ui::MathsUi> *mathsModule;
        UiWidget<Ui::LaTeXUi> *latexModule;
        UiWidget<Ui::PDFSupportUi> *pdfSupportModule;
-       PreambleModule *preambleModule;
+       UiWidget<Ui::ModulesUi> *modulesModule;
+       UiWidget<Ui::OutputUi> *outputModule;
+       UiWidget<Ui::ListingsSettingsUi> *listingsModule;
+       PreambleModule * preambleModule;
        
-       GuiBranches *branchesModule;
+       GuiBranches * branchesModule;
+       GuiIndices * indicesModule;
 
        BulletsModule * bulletsModule;
        FloatPlacement * floatModule;
 
-       GuiSelectionManager * selectionManager;
+       ModuleSelectionManager * selectionManager;
 
        /// Available modules
        GuiIdListModel * availableModel() { return &modules_av_model_; }
@@ -160,6 +178,8 @@ private:
        ///
        void dispatchParams();
        ///
+       void modulesToParams(BufferParams &);
+       ///
        bool isBufferDependent() const { return true; }
        /// always true since we don't manipulate document contents
        bool canApply() const { return true; }
@@ -168,8 +188,6 @@ private:
        ///
        BufferParams & params() { return bp_; }
        ///
-       BufferParams const & params() const { return bp_; }
-       ///
        BufferId id() const;
        ///
        struct modInfoStruct {
@@ -178,9 +196,14 @@ private:
                QString description;
        };
        /// List of available modules
-       std::vector<modInfoStruct> const & getModuleInfo();
+       std::list<modInfoStruct> const & getModuleInfo();
        /// Modules in use in current buffer
-       std::vector<modInfoStruct> const getSelectedModules();
+       std::list<modInfoStruct> const getSelectedModules();
+       ///
+       std::list<modInfoStruct> const getProvidedModules();
+       ///
+       std::list<modInfoStruct> const 
+                       makeModuleInfo(LayoutModuleList const & mods);
        ///
        void setLanguage() const;
        ///
@@ -193,13 +216,21 @@ private:
        bool providesSC(std::string const & font) const;
        /// does this font provide size adjustment?
        bool providesScale(std::string const & font) const;
+       ///
+       void executeBranchRenaming() const;
+       ///
+       void setCustomPapersize(bool custom);
 private:
        ///
        void loadModuleInfo();
        ///
+       void updateUnknownBranches();
+       ///
        BufferParams bp_;
        /// List of names of available modules
-       std::vector<modInfoStruct> moduleNames_;
+       std::list<modInfoStruct> moduleNames_;
+       ///
+       std::map<docstring, docstring> changedBranches_;
 };