]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt4/GuiCitation.h
do what the FIXME suggested
[lyx.git] / src / frontends / qt4 / GuiCitation.h
index 7059106ef87427e32b391f8aab4a366b08ffa420..f8029ece78554dbd69a5b640cdb16c90636eb87e 100644 (file)
 #ifndef GUICITATION_H
 #define GUICITATION_H
 
-#include "ControlCitation.h"
+#include "GuiDialog.h"
+#include "GuiSelectionManager.h"
+#include "ui_CitationUi.h"
 #include "support/docstring.h"
+#include "BiblioInfo.h"
 
+#include <QKeyEvent>
 #include <QStringList>
 #include <QStringListModel>
 
 namespace lyx {
 namespace frontend {
 
-class GuiCitation : public ControlCitation
+class GuiCitation : public GuiCommand, public Ui::CitationUi
 {
+       Q_OBJECT
+
 public:
        ///
-       GuiCitation(Dialog &);
-       virtual ~GuiCitation() {}
-       virtual bool initialiseParams(std::string const & data);
+       GuiCitation(GuiView & lv);
 
        ///
-       void init();
+       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_citationStyleCO_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();
+       /// set the formatting widgets
+       void updateFormatting(biblio::CiteStyle currentStyle);
+       /// 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();
        
@@ -74,10 +126,8 @@ public:
        QStringList citationStyles(int);
 
        /// Set the Params variable for the Controller.
-       virtual void apply(int const choice, bool const full, bool const force,
+       void apply(int const choice, bool const full, bool const force,
                                          QString before, QString after);
-       
-       void setCitedKeys();
 
 private:
        /// available keys.
@@ -88,8 +138,48 @@ private:
        QStringList all_keys_;
        /// Cited keys.
        QStringList cited_keys_;
-};
 
+       ///
+       bool initialiseParams(std::string const & data);
+
+       /// clean-up on hide.
+       void clearParams();
+
+       /** Disconnect from the inset when the Apply button is pressed.
+        *  Allows easy insertion of multiple citations.
+        */
+       bool disconnectOnApply() const { return true; }
+
+       /// \return the list of all available bibliography keys.
+       std::vector<docstring> const availableKeys() const;
+       /// \return the list of all used BibTeX fields
+       std::vector<docstring> const availableFields() const;
+       /// \return the list of all used BibTeX entry types
+       std::vector<docstring> const availableEntries() const;
+       ///
+       void filterByEntryType(
+               std::vector<docstring> & 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<docstring> searchKeys(
+               std::vector<docstring> 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