// -*- C++ -*- /** * \file GuiCitation.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author Angus Leeming * \author Kalle Dalheimer * \author Abdelrazak Younes * \author Richard Heck * * Full author contact details are available in file CREDITS. */ #ifndef GUICITATION_H #define GUICITATION_H #include "GuiDialog.h" #include "GuiSelectionManager.h" #include "ui_CitationUi.h" #include "support/docstring.h" #include "BiblioInfo.h" #include #include #include namespace lyx { namespace frontend { class GuiCitation : public GuiCommand, public Ui::CitationUi { Q_OBJECT public: /// GuiCitation(GuiView & lv); /// void applyView(); public Q_SLOTS: /// Update the display of the dialog whilst it is still visible. void updateView(); private: /// void showEvent(QShowEvent * e); /// void closeEvent(QCloseEvent * e); /// prepares a call to GuiCitation::searchKeys when we /// are ready to search the BibTeX entries void findText(QString const & text, bool reset = false); /// check whether key is already selected bool isSelected(const QModelIndex &); /// update the display of BibTeX information void updateInfo(QModelIndex const &); private Q_SLOTS: void cleanUp(); void on_okPB_clicked(); void on_cancelPB_clicked(); void on_restorePB_clicked(); void on_applyPB_clicked(); void on_findLE_textChanged(const QString & text); void on_fieldsCO_currentIndexChanged(int index); void on_entriesCO_currentIndexChanged(int index); void on_caseCB_stateChanged(int); void on_regexCB_stateChanged(int); void changed(); /// void setCitedKeys(); /// performs a limited update, suitable for internal call void updateDialog(); private: /// enable/disable buttons void setButtons(); /// fill the styles combo void fillStyles(); /// fill the fields combo void fillFields(); /// fill the entries combo void fillEntries(); /// set the styles combo void updateStyle(); /// last used citation style int style_; GuiSelectionManager * selectionManager; /// void init(); /// Available keys QStringListModel * available() { return &available_model_; } /// Selected keys QStringListModel * selected() { return &selected_model_; } /// Text before cite QString textBefore(); /// Text after cite QString textAfter(); /// Get key description QString getKeyInfo(QString const &); /// Clear selected keys void clearSelection(); /// Return a list of available fields QStringList getFieldsAsQStringList(); /// Return a list of available fields QStringList getEntriesAsQStringList(); /// Find keys containing a string. void findKey( QString const & str, //< string expression bool only_keys, //< set to true if only keys shall be searched. docstring field, // const availableKeys() const; /// \return the list of all used BibTeX fields std::vector const availableFields() const; /// \return the list of all used BibTeX entry types std::vector const availableEntries() const; /// void filterByEntryType( std::vector & keyVector, docstring entryType); /// biblio::CiteEngine getEngine() const; /// \return information for this key. docstring getInfo(docstring const & key) const; /// Search a given string within the passed keys. /// \return the vector of matched keys. std::vector searchKeys( std::vector const & keys_to_search, //< Keys to search. bool only_keys, //< whether to search only the keys docstring const & search_expression, //< Search expression (regex possible) docstring field, //< field to search, empty for all fields bool case_sensitive = false, //< set to true is the search should be case sensitive bool regex = false //< \set to true if \c search_expression is a regex ); // private: /// The BibTeX information available to the dialog BiblioInfo bibkeysInfo_; }; } // namespace frontend } // namespace lyx #endif // GUICITATION_H