* \file Dialogs.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
+ *
* \author Allan Rae
+ * \author Angus Leeming
*
* Full author contact details are available in file CREDITS.
*/
#ifndef DIALOGS_H
#define DIALOGS_H
+#include <boost/signal.hpp>
#include <boost/utility.hpp>
-#include <boost/signals/signal0.hpp>
-#include <boost/signals/signal1.hpp>
-class Dialog;
-class InsetBase;
+#include <map>
+
+namespace lyx {
+
+class Inset;
class LyXView;
-/** Container of all dialogs and signals a LyXView needs or uses to access them
- The list of dialog signals isn't comprehensive but should be a good guide
- for any future additions. Remember don't go overboard -- think minimal.
+namespace frontend { class Dialog; }
+
+/** Container of all dialogs.
*/
-class Dialogs : boost::noncopyable
-{
+class Dialogs : boost::noncopyable {
public:
///
Dialogs(LyXView &);
- ///
- ~Dialogs();
- /** Redraw all visible dialogs because, for example, the GUI colours
- * have been re-mapped.
+ /** Check the status of all visible dialogs and disable or reenable
+ * them as appropriate.
*
- * Note that static boost signals break some compilers, so we return a
- * reference to some hidden magic ;-)
+ * Disabling is needed for example when a dialog is open and the
+ * cursor moves to a position where the corresponding inset is not
+ * allowed.
*/
- static boost::signal0<void> & redrawGUI();
-
- /// Toggle tooltips on/off in all dialogs.
- static void toggleTooltips();
+ void checkStatus();
/// Are the tooltips on or off?
static bool tooltipsEnabled();
- /// Signals slated to go
- //@{
- boost::signal0<void> hideAllSignal;
- boost::signal0<void> hideBufferDependentSignal;
- boost::signal1<void, bool> updateBufferDependentSignal;
- //@}
-
/// Hide all visible dialogs
void hideAll() const;
/// Hide any dialogs that require a buffer for them to operate
*/
void updateBufferDependent(bool) const ;
- /**@name Dialog Access Signals.
- Put into some sort of alphabetical order */
- //@{
- ///
- void showPreamble();
- ///
- void showPreferences();
- /// bring up the spellchecker
- void showSpellchecker();
- //@}
-
/** \param name == "about" etc; an identifier used to
launch a particular dialog.
\param data is a string encoding of the data used to populate
dialog on 'Apply'; should it be used to create a new inset at
the current cursor position or modify an existing, 'open' inset?
*/
- void show(std::string const & name, std::string const & data, InsetBase * inset);
+ void show(std::string const & name, std::string const & data, Inset * inset);
/** \param name == "citation", "bibtex" etc; an identifier used
- to update the contents of a particular dialog with \param data .
+ to update the contents of a particular dialog with \param data.
See the comments to 'show', above.
*/
void update(std::string const & name, std::string const & data);
- /// is the dialog currently visible?
+ /// Is the dialog currently visible?
bool visible(std::string const & name) const;
/** All Dialogs of the given \param name will be closed if they are
connected to the given \param inset.
*/
- static void hide(std::string const & name, InsetBase * inset);
+ static void hide(std::string const & name, Inset * inset);
///
void disconnect(std::string const & name);
///
- InsetBase * getOpenInset(std::string const & name) const;
+ Inset * getOpenInset(std::string const & name) const;
private:
///
- void hideSlot(std::string const & name, InsetBase * inset);
+ void hideSlot(std::string const & name, Inset * inset);
///
void redraw() const;
///
bool isValidName(std::string const & name) const;
///
- Dialog * find_or_build(std::string const & name);
+ frontend::Dialog * find_or_build(std::string const & name);
///
- Dialog * build(std::string const & name);
+ typedef boost::shared_ptr<frontend::Dialog> DialogPtr;
+ ///
+ DialogPtr build(std::string const & name);
///
LyXView & lyxview_;
///
- std::map<std::string, InsetBase *> open_insets_;
+ std::map<std::string, Inset *> open_insets_;
- ///
- typedef boost::shared_ptr<Dialog> DialogPtr;
///
std::map<std::string, DialogPtr> dialogs_;
- /// the stuff below is slated to go...
- void init_pimpl();
- ///
- class Impl;
- ///
- Impl * pimpl_;
+ /// flag against a race condition due to multiclicks in Qt frontend, see bug #1119
+ bool in_show_;
};
+} // namespace lyx
+
#endif