X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffrontends%2Fqt4%2FGuiDocument.h;h=0bfbc1692e9512cd28562f49892729f0f30bc981;hb=be5965ae9183ebd17e71b74d4721520d85be6e6c;hp=9cd42926a1e26d1abe2994387e0448477991a8df;hpb=59124528ac01becd6bfe12adc9ade2b63c8391ab;p=lyx.git diff --git a/src/frontends/qt4/GuiDocument.h b/src/frontends/qt4/GuiDocument.h index 9cd42926a1..0bfbc1692e 100644 --- a/src/frontends/qt4/GuiDocument.h +++ b/src/frontends/qt4/GuiDocument.h @@ -19,38 +19,40 @@ #include "BulletsModule.h" #include "GuiDialog.h" #include "GuiIdListModel.h" -#include "GuiSelectionManager.h" +#include "ui_BiblioUi.h" +#include "ui_ColorUi.h" #include "ui_DocumentUi.h" #include "ui_FontUi.h" -#include "ui_TextLayoutUi.h" -#include "ui_MathsUi.h" -#include "ui_LaTeXUi.h" -#include "ui_PageLayoutUi.h" #include "ui_LanguageUi.h" -#include "ui_BiblioUi.h" -#include "ui_NumberingUi.h" +#include "ui_LaTeXUi.h" +#include "ui_ListingsSettingsUi.h" +#include "ui_LocalLayoutUi.h" #include "ui_MarginsUi.h" -#include "ui_PreambleUi.h" +#include "ui_MasterChildUi.h" +#include "ui_MathsUi.h" +#include "ui_ModulesUi.h" +#include "ui_NumberingUi.h" +#include "ui_OutputUi.h" +#include "ui_PageLayoutUi.h" #include "ui_PDFSupportUi.h" - -#include -#include - -class FloatPlacement; +#include "ui_PreambleUi.h" +#include "ui_TextLayoutUi.h" namespace lyx { class BufferParams; +class LayoutModuleList; class TextClass; namespace frontend { +class FloatPlacement; class GuiBranches; +class GuiIndices; +class ModuleSelectionManager; class PreambleModule; - -/// -QModelIndex getSelectedIndex(QListView * lv); +class LocalLayout; /// typedef void const * BufferId; @@ -63,125 +65,117 @@ public: }; -/// SelectionManager for use with modules -class ModuleSelMan : public GuiSelectionManager -{ -public: - ModuleSelMan( - QListView * availableLV, - QListView * selectedLV, - QPushButton * addPB, - QPushButton * delPB, - QPushButton * upPB, - QPushButton * downPB, - GuiIdListModel * availableModel, - GuiIdListModel * selectedModel); -private: - /// - virtual void updateAddPB(); - /// - virtual void updateUpPB(); - /// - virtual void updateDownPB(); - /// - virtual void updateDelPB(); - /// returns availableModel as a GuiIdListModel - GuiIdListModel * getAvailableModel() - { - return dynamic_cast(availableModel); - }; - /// returns selectedModel as a GuiIdListModel - GuiIdListModel * getSelectedModel() - { - return dynamic_cast(selectedModel); - }; -}; - - class GuiDocument : public GuiDialog, public Ui::DocumentUi { Q_OBJECT public: GuiDocument(GuiView & lv); - void updateParams(BufferParams const & params); - void apply(BufferParams & params); - + void paramsToDialog(); void updateFontsize(std::string const &, std::string const &); + void updateFontlist(); + void updateDefaultFormat(); + void updateEngineType(std::string const &, CiteEngineType const &); void updatePagestyle(std::string const &, std::string const &); + bool isChildIncluded(std::string const &); - void showPreamble(); - /// validate listings parameters and return an error message, if any - docstring validate_listings_params(); + /// + BufferParams const & params() const { return bp_; } -public Q_SLOTS: +private Q_SLOTS: void updateNumbering(); void change_adaptor(); - void set_listings_msg(); + void includeonlyClicked(QTreeWidgetItem * item, int); + void setListingsMessage(); void saveDefaultClicked(); void useDefaultsClicked(); - -private Q_SLOTS: - void updateParams(); void setLSpacing(int); - void setMargins(bool); - void setCustomPapersize(int); + void setMargins(); + void papersizeChanged(int); void setColSep(); void setCustomMargins(bool); + void fontencChanged(int); 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 languagePackageChanged(int); + void biblioChanged(); + void bibtexChanged(int); + void setAuthorYear(bool); + void setNumerical(bool); void updateModuleInfo(); - + void modulesChanged(); + void changeBackgroundColor(); + void deleteBackgroundColor(); + void changeFontColor(); + void deleteFontColor(); + void changeNoteFontColor(); + void deleteNoteFontColor(); + void changeBoxBackgroundColor(); + void deleteBoxBackgroundColor(); + void languageChanged(int); + void osFontsChanged(bool); + void mathFontChanged(int); + void branchesRename(docstring const &, docstring const &); private: + /// validate listings parameters and return an error message, if any + QString validateListingsParameters(); + UiWidget *textLayoutModule; + UiWidget *masterChildModule; UiWidget *fontModule; UiWidget *pageLayoutModule; UiWidget *marginsModule; UiWidget *langModule; + UiWidget *colorModule; UiWidget *numberingModule; UiWidget *biblioModule; UiWidget *mathsModule; UiWidget *latexModule; UiWidget *pdfSupportModule; - PreambleModule *preambleModule; - - GuiBranches *branchesModule; + UiWidget *modulesModule; + UiWidget *outputModule; + UiWidget *listingsModule; + PreambleModule * preambleModule; + LocalLayout * localLayout; + + GuiBranches * branchesModule; + GuiIndices * indicesModule; BulletsModule * bulletsModule; FloatPlacement * floatModule; - GuiSelectionManager * selectionManager; + ModuleSelectionManager * selectionManager; /// Available modules GuiIdListModel * availableModel() { return &modules_av_model_; } /// Selected modules GuiIdListModel * selectedModel() { return &modules_sel_model_; } -private: + /// Apply changes void applyView(); /// update void updateContents(); - /// force content update - void forceUpdate(); /// void updateAvailableModules(); /// void updateSelectedModules(); + /// + void updateIncludeonlys(); /// save as default template void saveDocDefault(); /// reset to default params void useClassDefaults(); /// void setLayoutComboByIDString(std::string const & idString); - /// available classes - GuiIdListModel classes_model_; + /// available modules GuiIdListModel modules_av_model_; /// selected modules @@ -189,11 +183,10 @@ private: /// current buffer BufferId current_id_; -protected: /// return false if validate_listings_params returns error bool isValid(); - /// font family names for BufferParams::fontsDefaultFamily + /// font family names for BufferParams::fonts_default_family static char const * const fontfamilies[5]; /// GUI names corresponding fontfamilies static char const * fontfamilies_gui[5]; @@ -204,6 +197,8 @@ protected: /// void dispatchParams(); /// + void modulesToParams(BufferParams &); + /// bool isBufferDependent() const { return true; } /// always true since we don't manipulate document contents bool canApply() const { return true; } @@ -212,8 +207,6 @@ protected: /// BufferParams & params() { return bp_; } /// - BufferParams const & params() const { return bp_; } - /// BufferId id() const; /// struct modInfoStruct { @@ -222,28 +215,57 @@ protected: QString description; }; /// List of available modules - std::vector const & getModuleInfo(); + std::list const & getModuleInfo(); /// Modules in use in current buffer - std::vector const getSelectedModules(); + std::list const getSelectedModules(); + /// + std::list const getProvidedModules(); + /// + std::list const + makeModuleInfo(LayoutModuleList const & mods); /// void setLanguage() const; /// void saveAsDefault() const; - /// - bool isFontAvailable(std::string const & font) const; /// does this font provide Old Style figures? - bool providesOSF(std::string const & font) const; + bool providesOSF(QString const & font) const; /// does this font provide true Small Caps? - bool providesSC(std::string const & font) const; + bool providesSC(QString const & font) const; /// does this font provide size adjustment? - bool providesScale(std::string const & font) const; + bool providesScale(QString const & font) const; + /// does this font provide an alternative without math? + bool providesNoMath(QString const & font) const; + /// + void executeBranchRenaming() const; + /// + void setCustomPapersize(bool custom); private: /// void loadModuleInfo(); /// + void updateUnknownBranches(); + /// + void updateTexFonts(); + /// + void updateMathFonts(QString const & rm); + /// + void updateFontOptions(); + /// + bool ot1() const; + /// + bool completeFontset() const; + /// + bool noMathFont() const; + /// BufferParams bp_; /// List of names of available modules - std::vector moduleNames_; + std::list moduleNames_; + /// + std::map changedBranches_; + /// + std::list includeonlys_; + /// + bool biblioChanged_; }; @@ -270,6 +292,33 @@ private: }; +class LocalLayout : public UiWidget +{ + Q_OBJECT +public: + LocalLayout(); + void update(BufferParams const & params, BufferId id); + void apply(BufferParams & params); + bool isValid() const { return validated_; } + +Q_SIGNALS: + /// signal that something's changed in the Widget. + void changed(); + +private: + void validate(); + void convert(); +private Q_SLOTS: + void textChanged(); + void validatePressed(); + void convertPressed(); + +private: + BufferId current_id_; + bool validated_; +}; + + } // namespace frontend } // namespace lyx