mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-24 17:09:41 +00:00
merge GuiView/Dialogs
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@21661 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
ae4535adb3
commit
55b4fbcf21
@ -74,9 +74,8 @@
|
|||||||
#include "insets/InsetVSpace.h"
|
#include "insets/InsetVSpace.h"
|
||||||
#include "insets/InsetWrap.h"
|
#include "insets/InsetWrap.h"
|
||||||
|
|
||||||
#include "frontends/Application.h"
|
|
||||||
#include "frontends/alert.h"
|
#include "frontends/alert.h"
|
||||||
#include "frontends/Dialogs.h"
|
#include "frontends/Application.h"
|
||||||
#include "frontends/FileDialog.h"
|
#include "frontends/FileDialog.h"
|
||||||
#include "frontends/FontLoader.h"
|
#include "frontends/FontLoader.h"
|
||||||
#include "frontends/KeySymbol.h"
|
#include "frontends/KeySymbol.h"
|
||||||
@ -592,7 +591,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & cmd) const
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
string const name = cmd.getArg(0);
|
string const name = cmd.getArg(0);
|
||||||
Inset * inset = lyx_view_->getDialogs().getOpenInset(name);
|
Inset * inset = lyx_view_->getOpenInset(name);
|
||||||
if (inset) {
|
if (inset) {
|
||||||
FuncRequest fr(LFUN_INSET_MODIFY, cmd.argument());
|
FuncRequest fr(LFUN_INSET_MODIFY, cmd.argument());
|
||||||
FuncStatus fs;
|
FuncStatus fs;
|
||||||
@ -610,7 +609,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & cmd) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_DIALOG_TOGGLE:
|
case LFUN_DIALOG_TOGGLE:
|
||||||
flag.setOnOff(lyx_view_->getDialogs().visible(cmd.getArg(0)));
|
flag.setOnOff(lyx_view_->isDialogVisible(cmd.getArg(0)));
|
||||||
// fall through to set "enable"
|
// fall through to set "enable"
|
||||||
case LFUN_DIALOG_SHOW: {
|
case LFUN_DIALOG_SHOW: {
|
||||||
string const name = cmd.getArg(0);
|
string const name = cmd.getArg(0);
|
||||||
@ -1540,7 +1539,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
} // end switch(code)
|
} // end switch(code)
|
||||||
if (insetCodeOK)
|
if (insetCodeOK)
|
||||||
lyx_view_->getDialogs().show(name, data, 0);
|
lyx_view_->showDialog(name, data, 0);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1548,7 +1547,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
BOOST_ASSERT(lyx_view_);
|
BOOST_ASSERT(lyx_view_);
|
||||||
string const & name = argument;
|
string const & name = argument;
|
||||||
// Can only update a dialog connected to an existing inset
|
// Can only update a dialog connected to an existing inset
|
||||||
Inset * inset = lyx_view_->getDialogs().getOpenInset(name);
|
Inset * inset = lyx_view_->getOpenInset(name);
|
||||||
if (inset) {
|
if (inset) {
|
||||||
FuncRequest fr(LFUN_INSET_DIALOG_UPDATE, cmd.argument());
|
FuncRequest fr(LFUN_INSET_DIALOG_UPDATE, cmd.argument());
|
||||||
inset->dispatch(view()->cursor(), fr);
|
inset->dispatch(view()->cursor(), fr);
|
||||||
@ -1569,7 +1568,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
|
|
||||||
case LFUN_DIALOG_TOGGLE: {
|
case LFUN_DIALOG_TOGGLE: {
|
||||||
BOOST_ASSERT(lyx_view_);
|
BOOST_ASSERT(lyx_view_);
|
||||||
if (lyx_view_->getDialogs().visible(cmd.getArg(0)))
|
if (lyx_view_->isDialogVisible(cmd.getArg(0)))
|
||||||
dispatch(FuncRequest(LFUN_DIALOG_HIDE, argument));
|
dispatch(FuncRequest(LFUN_DIALOG_HIDE, argument));
|
||||||
else
|
else
|
||||||
dispatch(FuncRequest(LFUN_DIALOG_SHOW, argument));
|
dispatch(FuncRequest(LFUN_DIALOG_SHOW, argument));
|
||||||
@ -1578,7 +1577,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
|
|
||||||
case LFUN_DIALOG_DISCONNECT_INSET:
|
case LFUN_DIALOG_DISCONNECT_INSET:
|
||||||
BOOST_ASSERT(lyx_view_);
|
BOOST_ASSERT(lyx_view_);
|
||||||
lyx_view_->getDialogs().disconnect(argument);
|
lyx_view_->disconnectDialog(argument);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
||||||
@ -1785,7 +1784,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
case LFUN_INSET_APPLY: {
|
case LFUN_INSET_APPLY: {
|
||||||
BOOST_ASSERT(lyx_view_);
|
BOOST_ASSERT(lyx_view_);
|
||||||
string const name = cmd.getArg(0);
|
string const name = cmd.getArg(0);
|
||||||
Inset * inset = lyx_view_->getDialogs().getOpenInset(name);
|
Inset * inset = lyx_view_->getOpenInset(name);
|
||||||
if (inset) {
|
if (inset) {
|
||||||
FuncRequest fr(LFUN_INSET_MODIFY, argument);
|
FuncRequest fr(LFUN_INSET_MODIFY, argument);
|
||||||
inset->dispatch(view()->cursor(), fr);
|
inset->dispatch(view()->cursor(), fr);
|
||||||
|
@ -12,14 +12,12 @@
|
|||||||
|
|
||||||
#include "Dialog.h"
|
#include "Dialog.h"
|
||||||
|
|
||||||
|
#include "Buffer.h"
|
||||||
#include "FuncRequest.h"
|
#include "FuncRequest.h"
|
||||||
#include "FuncStatus.h"
|
#include "FuncStatus.h"
|
||||||
#include "LyXFunc.h"
|
#include "LyXFunc.h"
|
||||||
|
|
||||||
#include "frontends/LyXView.h"
|
#include "LyXView.h"
|
||||||
#include "frontends/Dialogs.h" // FIXME
|
|
||||||
|
|
||||||
#include "Buffer.h"
|
|
||||||
|
|
||||||
|
|
||||||
namespace lyx {
|
namespace lyx {
|
||||||
@ -52,7 +50,7 @@ void Dialog::updateDialog(std::string const & name) const
|
|||||||
|
|
||||||
void Dialog::disconnect(std::string const & name) const
|
void Dialog::disconnect(std::string const & name) const
|
||||||
{
|
{
|
||||||
lyxview_->getDialogs().disconnect(name);
|
lyxview_->disconnectDialog(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,125 +0,0 @@
|
|||||||
// -*- C++ -*-
|
|
||||||
/**
|
|
||||||
* \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/shared_ptr.hpp>
|
|
||||||
|
|
||||||
#include <map>
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
namespace lyx {
|
|
||||||
|
|
||||||
class Inset;
|
|
||||||
|
|
||||||
namespace frontend {
|
|
||||||
|
|
||||||
class Dialog;
|
|
||||||
class LyXView;
|
|
||||||
|
|
||||||
/** Container of all dialogs.
|
|
||||||
*/
|
|
||||||
class Dialogs {
|
|
||||||
public:
|
|
||||||
///
|
|
||||||
Dialogs(LyXView &);
|
|
||||||
|
|
||||||
/** Check the status of all visible dialogs and disable or reenable
|
|
||||||
* them as appropriate.
|
|
||||||
*
|
|
||||||
* Disabling is needed for example when a dialog is open and the
|
|
||||||
* cursor moves to a position where the corresponding inset is not
|
|
||||||
* allowed.
|
|
||||||
*/
|
|
||||||
void checkStatus();
|
|
||||||
|
|
||||||
/// Are the tooltips on or off?
|
|
||||||
static bool tooltipsEnabled();
|
|
||||||
|
|
||||||
/// Hide all visible dialogs
|
|
||||||
void hideAll() const;
|
|
||||||
/// Hide any dialogs that require a buffer for them to operate
|
|
||||||
void hideBufferDependent() const;
|
|
||||||
/** Update visible, buffer-dependent dialogs
|
|
||||||
If the bool is true then a buffer change has occurred
|
|
||||||
else it is still the same buffer.
|
|
||||||
*/
|
|
||||||
void updateBufferDependent(bool) const;
|
|
||||||
|
|
||||||
/** \param name == "bibtex", "citation" etc; an identifier used to
|
|
||||||
launch a particular dialog.
|
|
||||||
\param data is a string representation of the Inset contents.
|
|
||||||
It is often little more than the output from Inset::write.
|
|
||||||
It is passed to, and parsed by, the frontend dialog.
|
|
||||||
Several of these dialogs do not need any data,
|
|
||||||
so it defaults to string().
|
|
||||||
\param inset ownership is _not_ passed to the frontend dialog.
|
|
||||||
It is stored internally and used by the kernel to ascertain
|
|
||||||
what to do with the FuncRequest dispatched from the frontend
|
|
||||||
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 = std::string(), Inset * inset = 0);
|
|
||||||
|
|
||||||
/** \param name == "citation", "bibtex" etc; an identifier used
|
|
||||||
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?
|
|
||||||
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.
|
|
||||||
*/
|
|
||||||
void hide(std::string const & name, Inset * inset);
|
|
||||||
///
|
|
||||||
void disconnect(std::string const & name);
|
|
||||||
///
|
|
||||||
Inset * getOpenInset(std::string const & name) const;
|
|
||||||
|
|
||||||
private:
|
|
||||||
/// noncopyable
|
|
||||||
Dialogs(Dialogs const &);
|
|
||||||
void operator=(Dialogs const &);
|
|
||||||
|
|
||||||
///
|
|
||||||
void redraw() const;
|
|
||||||
///
|
|
||||||
bool isValidName(std::string const & name) const;
|
|
||||||
///
|
|
||||||
Dialog * find_or_build(std::string const & name);
|
|
||||||
///
|
|
||||||
typedef boost::shared_ptr<Dialog> DialogPtr;
|
|
||||||
///
|
|
||||||
Dialog * build(std::string const & name);
|
|
||||||
|
|
||||||
///
|
|
||||||
LyXView & lyxview_;
|
|
||||||
///
|
|
||||||
std::map<std::string, Inset *> open_insets_;
|
|
||||||
|
|
||||||
///
|
|
||||||
std::map<std::string, DialogPtr> dialogs_;
|
|
||||||
|
|
||||||
/// flag against a race condition due to multiclicks in Qt frontend,
|
|
||||||
/// see bug #1119
|
|
||||||
bool in_show_;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace frontend
|
|
||||||
} // namespace lyx
|
|
||||||
|
|
||||||
#endif
|
|
@ -16,6 +16,8 @@
|
|||||||
#include "frontends/Delegates.h"
|
#include "frontends/Delegates.h"
|
||||||
#include "support/strfwd.h"
|
#include "support/strfwd.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace lyx {
|
namespace lyx {
|
||||||
|
|
||||||
namespace support { class FileName; }
|
namespace support { class FileName; }
|
||||||
@ -81,11 +83,6 @@ public:
|
|||||||
///
|
///
|
||||||
virtual bool isToolbarVisible(std::string const & id) = 0;
|
virtual bool isToolbarVisible(std::string const & id) = 0;
|
||||||
|
|
||||||
/// get access to the dialogs
|
|
||||||
virtual Dialogs & getDialogs() = 0;
|
|
||||||
///
|
|
||||||
virtual Dialogs const & getDialogs() const = 0;
|
|
||||||
|
|
||||||
//@}
|
//@}
|
||||||
|
|
||||||
/// load a buffer into the current workarea.
|
/// load a buffer into the current workarea.
|
||||||
@ -120,6 +117,67 @@ public:
|
|||||||
//
|
//
|
||||||
virtual void errors(std::string const &) = 0;
|
virtual void errors(std::string const &) = 0;
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// This View's Dialogs
|
||||||
|
//
|
||||||
|
|
||||||
|
/** Check the status of all visible dialogs and disable or reenable
|
||||||
|
* them as appropriate.
|
||||||
|
*
|
||||||
|
* Disabling is needed for example when a dialog is open and the
|
||||||
|
* cursor moves to a position where the corresponding inset is not
|
||||||
|
* allowed.
|
||||||
|
*/
|
||||||
|
virtual void checkStatus() = 0;
|
||||||
|
|
||||||
|
/// Are the tooltips on or off?
|
||||||
|
virtual bool tooltipsEnabled() = 0;
|
||||||
|
|
||||||
|
/// Hide all visible dialogs
|
||||||
|
virtual void hideAll() const = 0;
|
||||||
|
/// Hide any dialogs that require a buffer for them to operate
|
||||||
|
virtual void hideBufferDependent() const = 0;
|
||||||
|
/** Update visible, buffer-dependent dialogs
|
||||||
|
If the bool is true then a buffer change has occurred
|
||||||
|
else it is still the same buffer.
|
||||||
|
*/
|
||||||
|
virtual void updateBufferDependent(bool) const = 0;
|
||||||
|
|
||||||
|
/** \param name == "bibtex", "citation" etc; an identifier used to
|
||||||
|
launch a particular dialog.
|
||||||
|
\param data is a string representation of the Inset contents.
|
||||||
|
It is often little more than the output from Inset::write.
|
||||||
|
It is passed to, and parsed by, the frontend dialog.
|
||||||
|
Several of these dialogs do not need any data,
|
||||||
|
so it defaults to string().
|
||||||
|
\param inset ownership is _not_ passed to the frontend dialog.
|
||||||
|
It is stored internally and used by the kernel to ascertain
|
||||||
|
what to do with the FuncRequest dispatched from the frontend
|
||||||
|
dialog on 'Apply'; should it be used to create a new inset at
|
||||||
|
the current cursor position or modify an existing, 'open' inset?
|
||||||
|
*/
|
||||||
|
virtual void showDialog(std::string const & name,
|
||||||
|
std::string const & data = std::string(), Inset * inset = 0) = 0;
|
||||||
|
|
||||||
|
/** \param name == "citation", "bibtex" etc; an identifier used
|
||||||
|
to update the contents of a particular dialog with \param data.
|
||||||
|
See the comments to 'show', above.
|
||||||
|
*/
|
||||||
|
virtual void updateDialog(std::string const & name, std::string const & data) = 0;
|
||||||
|
|
||||||
|
/// Is the dialog currently visible?
|
||||||
|
virtual bool isDialogVisible(std::string const & name) const = 0;
|
||||||
|
|
||||||
|
/** All Dialogs of the given \param name will be closed if they are
|
||||||
|
connected to the given \param inset.
|
||||||
|
*/
|
||||||
|
virtual void hideDialog(std::string const & name, Inset * inset) = 0;
|
||||||
|
///
|
||||||
|
virtual void disconnectDialog(std::string const & name) = 0;
|
||||||
|
///
|
||||||
|
virtual Inset * getOpenInset(std::string const & name) const = 0;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/// noncopyable
|
/// noncopyable
|
||||||
LyXView(LyXView const &);
|
LyXView(LyXView const &);
|
||||||
|
@ -13,7 +13,6 @@ liblyxfrontends_la_SOURCES = \
|
|||||||
Application.h \
|
Application.h \
|
||||||
NoGuiFontLoader.h \
|
NoGuiFontLoader.h \
|
||||||
NoGuiFontMetrics.h \
|
NoGuiFontMetrics.h \
|
||||||
Dialogs.h \
|
|
||||||
FileDialog.h \
|
FileDialog.h \
|
||||||
FontLoader.h \
|
FontLoader.h \
|
||||||
FontMetrics.h \
|
FontMetrics.h \
|
||||||
|
@ -1,380 +0,0 @@
|
|||||||
/**
|
|
||||||
* \file qt4/Dialogs.cpp
|
|
||||||
* This file is part of LyX, the document processor.
|
|
||||||
* Licence details can be found in the file COPYING.
|
|
||||||
*
|
|
||||||
* \author Angus Leeming
|
|
||||||
*
|
|
||||||
* Full author contact details are available in file CREDITS.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
|
|
||||||
#include "Dialogs.h"
|
|
||||||
#include "Dialog.h"
|
|
||||||
|
|
||||||
#include <boost/assert.hpp>
|
|
||||||
|
|
||||||
using std::string;
|
|
||||||
|
|
||||||
namespace lyx {
|
|
||||||
|
|
||||||
extern bool quitting;
|
|
||||||
|
|
||||||
namespace frontend {
|
|
||||||
|
|
||||||
Dialogs::Dialogs(LyXView & lyxview)
|
|
||||||
: lyxview_(lyxview), in_show_(false)
|
|
||||||
{}
|
|
||||||
|
|
||||||
|
|
||||||
Dialog * Dialogs::find_or_build(string const & name)
|
|
||||||
{
|
|
||||||
if (!isValidName(name))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
std::map<string, DialogPtr>::iterator it =
|
|
||||||
dialogs_.find(name);
|
|
||||||
|
|
||||||
if (it != dialogs_.end())
|
|
||||||
return it->second.get();
|
|
||||||
|
|
||||||
dialogs_[name].reset(build(name));
|
|
||||||
return dialogs_[name].get();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::show(string const & name, string const & data, Inset * inset)
|
|
||||||
{
|
|
||||||
if (in_show_)
|
|
||||||
return;
|
|
||||||
|
|
||||||
in_show_ = true;
|
|
||||||
Dialog * dialog = find_or_build(name);
|
|
||||||
if (dialog) {
|
|
||||||
dialog->showData(data);
|
|
||||||
if (inset)
|
|
||||||
open_insets_[name] = inset;
|
|
||||||
}
|
|
||||||
in_show_ = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool Dialogs::visible(string const & name) const
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.find(name);
|
|
||||||
if (it == dialogs_.end())
|
|
||||||
return false;
|
|
||||||
return it->second.get()->isVisibleView();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::update(string const & name, string const & data)
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.find(name);
|
|
||||||
if (it == dialogs_.end())
|
|
||||||
return;
|
|
||||||
|
|
||||||
Dialog * const dialog = it->second.get();
|
|
||||||
if (dialog->isVisibleView())
|
|
||||||
dialog->updateData(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::hide(string const & name, Inset* inset)
|
|
||||||
{
|
|
||||||
// Don't send the signal if we are quitting, because on MSVC it is
|
|
||||||
// destructed before the cut stack in CutAndPaste.cpp, and this method
|
|
||||||
// is called from some inset destructor if the cut stack is not empty
|
|
||||||
// on exit.
|
|
||||||
if (quitting)
|
|
||||||
return;
|
|
||||||
|
|
||||||
std::map<string, DialogPtr>::const_iterator it =
|
|
||||||
dialogs_.find(name);
|
|
||||||
if (it == dialogs_.end())
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (inset && inset != getOpenInset(name))
|
|
||||||
return;
|
|
||||||
|
|
||||||
Dialog * const dialog = it->second.get();
|
|
||||||
if (dialog->isVisibleView())
|
|
||||||
dialog->hide();
|
|
||||||
open_insets_[name] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::disconnect(string const & name)
|
|
||||||
{
|
|
||||||
if (!isValidName(name))
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (open_insets_.find(name) != open_insets_.end())
|
|
||||||
open_insets_[name] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Inset * Dialogs::getOpenInset(string const & name) const
|
|
||||||
{
|
|
||||||
if (!isValidName(name))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
std::map<string, Inset *>::const_iterator it =
|
|
||||||
open_insets_.find(name);
|
|
||||||
return it == open_insets_.end() ? 0 : it->second;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::hideAll() const
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
|
|
||||||
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
|
|
||||||
|
|
||||||
for(; it != end; ++it)
|
|
||||||
it->second->hide();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::hideBufferDependent() const
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
|
|
||||||
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
|
|
||||||
|
|
||||||
for(; it != end; ++it) {
|
|
||||||
Dialog * dialog = it->second.get();
|
|
||||||
if (dialog->isBufferDependent())
|
|
||||||
dialog->hide();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::updateBufferDependent(bool switched) const
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
|
|
||||||
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
|
|
||||||
|
|
||||||
for(; it != end; ++it) {
|
|
||||||
Dialog * dialog = it->second.get();
|
|
||||||
if (switched && dialog->isBufferDependent()) {
|
|
||||||
if (dialog->isVisibleView() && dialog->initialiseParams(""))
|
|
||||||
dialog->updateView();
|
|
||||||
else
|
|
||||||
dialog->hide();
|
|
||||||
} else {
|
|
||||||
// A bit clunky, but the dialog will request
|
|
||||||
// that the kernel provides it with the necessary
|
|
||||||
// data.
|
|
||||||
dialog->slotRestore();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::redraw() const
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
|
|
||||||
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
|
|
||||||
|
|
||||||
for(; it != end; ++it)
|
|
||||||
it->second->redraw();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Dialogs::checkStatus()
|
|
||||||
{
|
|
||||||
std::map<string, DialogPtr>::const_iterator it = dialogs_.begin();
|
|
||||||
std::map<string, DialogPtr>::const_iterator end = dialogs_.end();
|
|
||||||
|
|
||||||
for(; it != end; ++it) {
|
|
||||||
Dialog * const dialog = it->second.get();
|
|
||||||
if (dialog && dialog->isVisibleView())
|
|
||||||
dialog->checkStatus();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
// This list should be kept in sync with the list of insets in
|
|
||||||
// src/insets/Inset.cpp. I.e., if a dialog goes with an inset, the
|
|
||||||
// dialog should have the same name as the inset.
|
|
||||||
|
|
||||||
char const * const dialognames[] = {
|
|
||||||
"aboutlyx", "bibitem", "bibtex", "box", "branch", "changes", "character",
|
|
||||||
"citation", "document", "embedding", "errorlist", "ert", "external", "file",
|
|
||||||
"findreplace", "float", "graphics", "include", "index", "nomenclature", "label", "log",
|
|
||||||
"mathdelimiter", "mathmatrix", "note", "paragraph",
|
|
||||||
"prefs", "print", "ref", "sendto", "spellchecker","tabular", "tabularcreate",
|
|
||||||
|
|
||||||
#ifdef HAVE_LIBAIKSAURUS
|
|
||||||
"thesaurus",
|
|
||||||
#endif
|
|
||||||
|
|
||||||
"texinfo", "toc", "href", "view-source", "vspace", "wrap", "listings" };
|
|
||||||
|
|
||||||
char const * const * const end_dialognames =
|
|
||||||
dialognames + (sizeof(dialognames) / sizeof(char *));
|
|
||||||
|
|
||||||
class cmpCStr {
|
|
||||||
public:
|
|
||||||
cmpCStr(char const * name) : name_(name) {}
|
|
||||||
bool operator()(char const * other) {
|
|
||||||
return strcmp(other, name_) == 0;
|
|
||||||
}
|
|
||||||
private:
|
|
||||||
char const * name_;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace anon
|
|
||||||
|
|
||||||
// will be replaced by a proper factory...
|
|
||||||
Dialog * createGuiAbout(LyXView & lv);
|
|
||||||
Dialog * createGuiBibitem(LyXView & lv);
|
|
||||||
Dialog * createGuiBibtex(LyXView & lv);
|
|
||||||
Dialog * createGuiBox(LyXView & lv);
|
|
||||||
Dialog * createGuiBranch(LyXView & lv);
|
|
||||||
Dialog * createGuiChanges(LyXView & lv);
|
|
||||||
Dialog * createGuiCharacter(LyXView & lv);
|
|
||||||
Dialog * createGuiCitation(LyXView & lv);
|
|
||||||
Dialog * createGuiDelimiter(LyXView & lv);
|
|
||||||
Dialog * createGuiDocument(LyXView & lv);
|
|
||||||
Dialog * createGuiErrorList(LyXView & lv);
|
|
||||||
Dialog * createGuiERT(LyXView & lv);
|
|
||||||
Dialog * createGuiExternal(LyXView & lv);
|
|
||||||
Dialog * createGuiFloat(LyXView & lv);
|
|
||||||
Dialog * createGuiGraphics(LyXView & lv);
|
|
||||||
Dialog * createGuiInclude(LyXView & lv);
|
|
||||||
Dialog * createGuiIndex(LyXView & lv);
|
|
||||||
Dialog * createGuiLabel(LyXView & lv);
|
|
||||||
Dialog * createGuiListings(LyXView & lv);
|
|
||||||
Dialog * createGuiLog(LyXView & lv);
|
|
||||||
Dialog * createGuiMathMatrix(LyXView & lv);
|
|
||||||
Dialog * createGuiNomenclature(LyXView & lv);
|
|
||||||
Dialog * createGuiNote(LyXView & lv);
|
|
||||||
Dialog * createGuiParagraph(LyXView & lv);
|
|
||||||
Dialog * createGuiPreferences(LyXView & lv);
|
|
||||||
Dialog * createGuiPrint(LyXView & lv);
|
|
||||||
Dialog * createGuiRef(LyXView & lv);
|
|
||||||
Dialog * createGuiSearch(LyXView & lv);
|
|
||||||
Dialog * createGuiSendTo(LyXView & lv);
|
|
||||||
Dialog * createGuiShowFile(LyXView & lv);
|
|
||||||
Dialog * createGuiSpellchecker(LyXView & lv);
|
|
||||||
Dialog * createGuiTabularCreate(LyXView & lv);
|
|
||||||
Dialog * createGuiTabular(LyXView & lv);
|
|
||||||
Dialog * createGuiTexInfo(LyXView & lv);
|
|
||||||
Dialog * createGuiToc(LyXView & lv);
|
|
||||||
Dialog * createGuiThesaurus(LyXView & lv);
|
|
||||||
Dialog * createGuiHyperlink(LyXView & lv);
|
|
||||||
Dialog * createGuiVSpace(LyXView & lv);
|
|
||||||
Dialog * createGuiViewSource(LyXView & lv);
|
|
||||||
Dialog * createGuiWrap(LyXView & lv);
|
|
||||||
|
|
||||||
|
|
||||||
bool Dialogs::isValidName(string const & name) const
|
|
||||||
{
|
|
||||||
return std::find_if(dialognames, end_dialognames,
|
|
||||||
cmpCStr(name.c_str())) != end_dialognames;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Dialog * Dialogs::build(string const & name)
|
|
||||||
{
|
|
||||||
BOOST_ASSERT(isValidName(name));
|
|
||||||
|
|
||||||
if (name == "aboutlyx")
|
|
||||||
return createGuiAbout(lyxview_);
|
|
||||||
if (name == "bibitem")
|
|
||||||
return createGuiBibitem(lyxview_);
|
|
||||||
if (name == "bibtex")
|
|
||||||
return createGuiBibtex(lyxview_);
|
|
||||||
if (name == "box")
|
|
||||||
return createGuiBox(lyxview_);
|
|
||||||
if (name == "branch")
|
|
||||||
return createGuiBranch(lyxview_);
|
|
||||||
if (name == "changes")
|
|
||||||
return createGuiChanges(lyxview_);
|
|
||||||
if (name == "character")
|
|
||||||
return createGuiCharacter(lyxview_);
|
|
||||||
if (name == "citation")
|
|
||||||
return createGuiCitation(lyxview_);
|
|
||||||
if (name == "document")
|
|
||||||
return createGuiDocument(lyxview_);
|
|
||||||
if (name == "errorlist")
|
|
||||||
return createGuiErrorList(lyxview_);
|
|
||||||
if (name == "ert")
|
|
||||||
return createGuiERT(lyxview_);
|
|
||||||
if (name == "external")
|
|
||||||
return createGuiExternal(lyxview_);
|
|
||||||
if (name == "file")
|
|
||||||
return createGuiShowFile(lyxview_);
|
|
||||||
if (name == "findreplace")
|
|
||||||
return createGuiSearch(lyxview_);
|
|
||||||
if (name == "float")
|
|
||||||
return createGuiFloat(lyxview_);
|
|
||||||
if (name == "graphics")
|
|
||||||
return createGuiGraphics(lyxview_);
|
|
||||||
if (name == "include")
|
|
||||||
return createGuiInclude(lyxview_);
|
|
||||||
if (name == "index")
|
|
||||||
return createGuiIndex(lyxview_);
|
|
||||||
if (name == "nomenclature")
|
|
||||||
return createGuiNomenclature(lyxview_);
|
|
||||||
if (name == "label")
|
|
||||||
return createGuiLabel(lyxview_);
|
|
||||||
if (name == "log")
|
|
||||||
return createGuiLog(lyxview_);
|
|
||||||
if (name == "view-source")
|
|
||||||
return createGuiViewSource(lyxview_);
|
|
||||||
if (name == "mathdelimiter")
|
|
||||||
return createGuiDelimiter(lyxview_);
|
|
||||||
if (name == "mathmatrix")
|
|
||||||
return createGuiMathMatrix(lyxview_);
|
|
||||||
if (name == "note")
|
|
||||||
return createGuiNote(lyxview_);
|
|
||||||
if (name == "paragraph")
|
|
||||||
return createGuiParagraph(lyxview_);
|
|
||||||
if (name == "prefs")
|
|
||||||
return createGuiPreferences(lyxview_);
|
|
||||||
if (name == "print")
|
|
||||||
return createGuiPrint(lyxview_);
|
|
||||||
if (name == "ref")
|
|
||||||
return createGuiRef(lyxview_);
|
|
||||||
if (name == "sendto")
|
|
||||||
return createGuiSendTo(lyxview_);
|
|
||||||
if (name == "spellchecker")
|
|
||||||
return createGuiSpellchecker(lyxview_);
|
|
||||||
if (name == "tabular")
|
|
||||||
return createGuiTabular(lyxview_);
|
|
||||||
if (name == "tabularcreate")
|
|
||||||
return createGuiTabularCreate(lyxview_);
|
|
||||||
if (name == "texinfo")
|
|
||||||
return createGuiTexInfo(lyxview_);
|
|
||||||
#ifdef HAVE_LIBAIKSAURUS
|
|
||||||
if (name == "thesaurus")
|
|
||||||
return createGuiThesaurus(lyxview_);
|
|
||||||
#endif
|
|
||||||
if (name == "toc")
|
|
||||||
return createGuiToc(lyxview_);
|
|
||||||
if (name == "href")
|
|
||||||
return createGuiHyperlink(lyxview_);
|
|
||||||
if (name == "vspace")
|
|
||||||
return createGuiVSpace(lyxview_);
|
|
||||||
if (name == "wrap")
|
|
||||||
return createGuiWrap(lyxview_);
|
|
||||||
if (name == "listings")
|
|
||||||
return createGuiListings(lyxview_);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// Are the tooltips on or off?
|
|
||||||
bool Dialogs::tooltipsEnabled()
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace frontend
|
|
||||||
} // namespace lyx
|
|
@ -17,7 +17,6 @@
|
|||||||
#include "qt_helpers.h"
|
#include "qt_helpers.h"
|
||||||
#include "GuiImage.h"
|
#include "GuiImage.h"
|
||||||
#include "GuiView.h"
|
#include "GuiView.h"
|
||||||
#include "Dialogs.h"
|
|
||||||
|
|
||||||
#include "frontends/alert.h"
|
#include "frontends/alert.h"
|
||||||
#include "frontends/Application.h"
|
#include "frontends/Application.h"
|
||||||
@ -515,7 +514,7 @@ void GuiApplication::hideDialogs(string const & name, Inset * inset) const
|
|||||||
vector<int>::const_iterator it = view_ids_.begin();
|
vector<int>::const_iterator it = view_ids_.begin();
|
||||||
vector<int>::const_iterator const end = view_ids_.end();
|
vector<int>::const_iterator const end = view_ids_.end();
|
||||||
for (; it != end; ++it)
|
for (; it != end; ++it)
|
||||||
view(*it).getDialogs().hide(name, inset);
|
view(*it).hideDialog(name, inset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -13,6 +13,13 @@
|
|||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
|
#include "GuiView.h"
|
||||||
|
#include "Dialog.h"
|
||||||
|
|
||||||
|
#include <boost/assert.hpp>
|
||||||
|
|
||||||
|
using std::string;
|
||||||
|
|
||||||
#include "GuiView.h"
|
#include "GuiView.h"
|
||||||
|
|
||||||
#include "GuiApplication.h"
|
#include "GuiApplication.h"
|
||||||
@ -21,12 +28,9 @@
|
|||||||
#include "GuiMenubar.h"
|
#include "GuiMenubar.h"
|
||||||
#include "GuiToolbar.h"
|
#include "GuiToolbar.h"
|
||||||
#include "GuiToolbars.h"
|
#include "GuiToolbars.h"
|
||||||
#include "Dialogs.h"
|
|
||||||
|
|
||||||
#include "qt_helpers.h"
|
#include "qt_helpers.h"
|
||||||
|
|
||||||
#include "frontends/Dialogs.h"
|
|
||||||
|
|
||||||
#include "support/filetools.h"
|
#include "support/filetools.h"
|
||||||
#include "support/convert.h"
|
#include "support/convert.h"
|
||||||
#include "support/lstrings.h"
|
#include "support/lstrings.h"
|
||||||
@ -147,6 +151,8 @@ private:
|
|||||||
} // namespace anon
|
} // namespace anon
|
||||||
|
|
||||||
|
|
||||||
|
typedef boost::shared_ptr<Dialog> DialogPtr;
|
||||||
|
|
||||||
struct GuiView::GuiViewPrivate
|
struct GuiView::GuiViewPrivate
|
||||||
{
|
{
|
||||||
GuiViewPrivate()
|
GuiViewPrivate()
|
||||||
@ -261,6 +267,16 @@ public:
|
|||||||
GuiToolbars * toolbars_;
|
GuiToolbars * toolbars_;
|
||||||
///
|
///
|
||||||
docstring current_layout;
|
docstring current_layout;
|
||||||
|
|
||||||
|
///
|
||||||
|
std::map<std::string, Inset *> open_insets_;
|
||||||
|
|
||||||
|
///
|
||||||
|
std::map<std::string, DialogPtr> dialogs_;
|
||||||
|
///
|
||||||
|
/// flag against a race condition due to multiclicks
|
||||||
|
/// see bug #1119
|
||||||
|
bool in_show_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -272,7 +288,7 @@ GuiView::GuiView(int id)
|
|||||||
d(*new GuiViewPrivate),
|
d(*new GuiViewPrivate),
|
||||||
quitting_by_menu_(false),
|
quitting_by_menu_(false),
|
||||||
autosave_timeout_(new Timeout(5000)),
|
autosave_timeout_(new Timeout(5000)),
|
||||||
dialogs_(new Dialogs(*this))
|
in_show_(false)
|
||||||
{
|
{
|
||||||
// Start autosave timer
|
// Start autosave timer
|
||||||
if (lyxrc.autosave) {
|
if (lyxrc.autosave) {
|
||||||
@ -296,7 +312,6 @@ GuiView::GuiView(int id)
|
|||||||
setWindowIcon(QPixmap(":/images/lyx.png"));
|
setWindowIcon(QPixmap(":/images/lyx.png"));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
d.splitter_ = new QSplitter;
|
d.splitter_ = new QSplitter;
|
||||||
|
|
||||||
d.initBackground();
|
d.initBackground();
|
||||||
@ -313,7 +328,6 @@ GuiView::GuiView(int id)
|
|||||||
|
|
||||||
GuiView::~GuiView()
|
GuiView::~GuiView()
|
||||||
{
|
{
|
||||||
delete dialogs_;
|
|
||||||
delete autosave_timeout_;
|
delete autosave_timeout_;
|
||||||
delete &d;
|
delete &d;
|
||||||
}
|
}
|
||||||
@ -532,7 +546,7 @@ void GuiView::on_currentWorkAreaChanged(GuiWorkArea * wa)
|
|||||||
// Buffer-dependent dialogs should be updated or
|
// Buffer-dependent dialogs should be updated or
|
||||||
// hidden. This should go here because some dialogs (eg ToC)
|
// hidden. This should go here because some dialogs (eg ToC)
|
||||||
// require bv_->text.
|
// require bv_->text.
|
||||||
dialogs_->updateBufferDependent(true);
|
updateBufferDependent(true);
|
||||||
updateToolbars();
|
updateToolbars();
|
||||||
updateLayoutChoice(false);
|
updateLayoutChoice(false);
|
||||||
updateStatusBar();
|
updateStatusBar();
|
||||||
@ -582,7 +596,7 @@ bool GuiView::event(QEvent * e)
|
|||||||
connectBuffer(bv.buffer());
|
connectBuffer(bv.buffer());
|
||||||
// The document structure, name and dialogs might have
|
// The document structure, name and dialogs might have
|
||||||
// changed in another view.
|
// changed in another view.
|
||||||
dialogs_->updateBufferDependent(true);
|
updateBufferDependent(true);
|
||||||
} else {
|
} else {
|
||||||
setWindowTitle(qt_("LyX"));
|
setWindowTitle(qt_("LyX"));
|
||||||
setWindowIconText(qt_("LyX"));
|
setWindowIconText(qt_("LyX"));
|
||||||
@ -757,7 +771,7 @@ void GuiView::removeWorkArea(GuiWorkArea * work_area)
|
|||||||
if (gwa == d.current_work_area_) {
|
if (gwa == d.current_work_area_) {
|
||||||
disconnectBuffer();
|
disconnectBuffer();
|
||||||
disconnectBufferView();
|
disconnectBufferView();
|
||||||
dialogs_->hideBufferDependent();
|
hideBufferDependent();
|
||||||
d.current_work_area_ = 0;
|
d.current_work_area_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -837,7 +851,7 @@ void GuiView::updateToolbars()
|
|||||||
d.toolbars_->update(false, false, false);
|
d.toolbars_->update(false, false, false);
|
||||||
|
|
||||||
// update read-only status of open dialogs.
|
// update read-only status of open dialogs.
|
||||||
dialogs_->checkStatus();
|
checkStatus();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -942,33 +956,40 @@ void GuiView::errors(string const & error_type)
|
|||||||
{
|
{
|
||||||
ErrorList & el = buffer()->errorList(error_type);
|
ErrorList & el = buffer()->errorList(error_type);
|
||||||
if (!el.empty())
|
if (!el.empty())
|
||||||
dialogs_->show("errorlist", error_type);
|
showDialog("errorlist", error_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GuiView::showDialog(string const & name)
|
void GuiView::showDialog(std::string const & name)
|
||||||
{
|
{
|
||||||
dialogs_->show(name);
|
showDialog(name, string());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GuiView::showDialogWithData(string const & name, string const & data)
|
void GuiView::showDialogWithData(string const & name, string const & data)
|
||||||
{
|
{
|
||||||
dialogs_->show(name, data);
|
showDialog(name, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GuiView::showInsetDialog(string const & name, string const & data,
|
void GuiView::showInsetDialog(string const & name, string const & data,
|
||||||
Inset * inset)
|
Inset * inset)
|
||||||
{
|
{
|
||||||
dialogs_->show(name, data, inset);
|
showDialog(name, data, inset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void GuiView::updateDialog(string const & name, string const & data)
|
void GuiView::updateDialog(string const & name, string const & data)
|
||||||
{
|
{
|
||||||
if (dialogs_->visible(name))
|
if (!isDialogVisible(name))
|
||||||
dialogs_->update(name, data);
|
return;
|
||||||
|
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.find(name);
|
||||||
|
if (it == d.dialogs_.end())
|
||||||
|
return;
|
||||||
|
|
||||||
|
Dialog * const dialog = it->second.get();
|
||||||
|
if (dialog->isVisibleView())
|
||||||
|
dialog->updateData(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1085,6 +1106,341 @@ void GuiView::restartCursor()
|
|||||||
d.current_work_area_->startBlinkingCursor();
|
d.current_work_area_->startBlinkingCursor();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Dialog * GuiView::find_or_build(string const & name)
|
||||||
|
{
|
||||||
|
if (!isValidName(name))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
std::map<string, DialogPtr>::iterator it = d.dialogs_.find(name);
|
||||||
|
|
||||||
|
if (it != d.dialogs_.end())
|
||||||
|
return it->second.get();
|
||||||
|
|
||||||
|
d.dialogs_[name].reset(build(name));
|
||||||
|
return d.dialogs_[name].get();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::showDialog(string const & name, string const & data,
|
||||||
|
Inset * inset)
|
||||||
|
{
|
||||||
|
if (in_show_)
|
||||||
|
return;
|
||||||
|
|
||||||
|
in_show_ = true;
|
||||||
|
Dialog * dialog = find_or_build(name);
|
||||||
|
if (dialog) {
|
||||||
|
dialog->showData(data);
|
||||||
|
if (inset)
|
||||||
|
d.open_insets_[name] = inset;
|
||||||
|
}
|
||||||
|
in_show_ = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool GuiView::isDialogVisible(string const & name) const
|
||||||
|
{
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.find(name);
|
||||||
|
if (it == d.dialogs_.end())
|
||||||
|
return false;
|
||||||
|
return it->second.get()->isVisibleView();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::hideDialog(string const & name, Inset * inset)
|
||||||
|
{
|
||||||
|
// Don't send the signal if we are quitting, because on MSVC it is
|
||||||
|
// destructed before the cut stack in CutAndPaste.cpp, and this method
|
||||||
|
// is called from some inset destructor if the cut stack is not empty
|
||||||
|
// on exit.
|
||||||
|
if (quitting)
|
||||||
|
return;
|
||||||
|
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.find(name);
|
||||||
|
if (it == d.dialogs_.end())
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (inset && inset != getOpenInset(name))
|
||||||
|
return;
|
||||||
|
|
||||||
|
Dialog * const dialog = it->second.get();
|
||||||
|
if (dialog->isVisibleView())
|
||||||
|
dialog->hide();
|
||||||
|
d.open_insets_[name] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::disconnectDialog(string const & name)
|
||||||
|
{
|
||||||
|
if (!isValidName(name))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (d.open_insets_.find(name) != d.open_insets_.end())
|
||||||
|
d.open_insets_[name] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Inset * GuiView::getOpenInset(string const & name) const
|
||||||
|
{
|
||||||
|
if (!isValidName(name))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
std::map<string, Inset *>::const_iterator it = d.open_insets_.find(name);
|
||||||
|
return it == d.open_insets_.end() ? 0 : it->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::hideAll() const
|
||||||
|
{
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
|
||||||
|
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
|
||||||
|
|
||||||
|
for(; it != end; ++it)
|
||||||
|
it->second->hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::hideBufferDependent() const
|
||||||
|
{
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
|
||||||
|
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
|
||||||
|
|
||||||
|
for(; it != end; ++it) {
|
||||||
|
Dialog * dialog = it->second.get();
|
||||||
|
if (dialog->isBufferDependent())
|
||||||
|
dialog->hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::updateBufferDependent(bool switched) const
|
||||||
|
{
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
|
||||||
|
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
|
||||||
|
|
||||||
|
for(; it != end; ++it) {
|
||||||
|
Dialog * dialog = it->second.get();
|
||||||
|
if (switched && dialog->isBufferDependent()) {
|
||||||
|
if (dialog->isVisibleView() && dialog->initialiseParams(""))
|
||||||
|
dialog->updateView();
|
||||||
|
else
|
||||||
|
dialog->hide();
|
||||||
|
} else {
|
||||||
|
// A bit clunky, but the dialog will request
|
||||||
|
// that the kernel provides it with the necessary
|
||||||
|
// data.
|
||||||
|
dialog->slotRestore();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::redrawDialog() const
|
||||||
|
{
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
|
||||||
|
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
|
||||||
|
|
||||||
|
for(; it != end; ++it)
|
||||||
|
it->second->redraw();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GuiView::checkStatus()
|
||||||
|
{
|
||||||
|
std::map<string, DialogPtr>::const_iterator it = d.dialogs_.begin();
|
||||||
|
std::map<string, DialogPtr>::const_iterator end = d.dialogs_.end();
|
||||||
|
|
||||||
|
for(; it != end; ++it) {
|
||||||
|
Dialog * const dialog = it->second.get();
|
||||||
|
if (dialog && dialog->isVisibleView())
|
||||||
|
dialog->checkStatus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
// This list should be kept in sync with the list of insets in
|
||||||
|
// src/insets/Inset.cpp. I.e., if a dialog goes with an inset, the
|
||||||
|
// dialog should have the same name as the inset.
|
||||||
|
|
||||||
|
char const * const dialognames[] = {
|
||||||
|
"aboutlyx", "bibitem", "bibtex", "box", "branch", "changes", "character",
|
||||||
|
"citation", "document", "embedding", "errorlist", "ert", "external", "file",
|
||||||
|
"findreplace", "float", "graphics", "include", "index", "nomenclature", "label", "log",
|
||||||
|
"mathdelimiter", "mathmatrix", "note", "paragraph",
|
||||||
|
"prefs", "print", "ref", "sendto", "spellchecker","tabular", "tabularcreate",
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBAIKSAURUS
|
||||||
|
"thesaurus",
|
||||||
|
#endif
|
||||||
|
|
||||||
|
"texinfo", "toc", "href", "view-source", "vspace", "wrap", "listings" };
|
||||||
|
|
||||||
|
char const * const * const end_dialognames =
|
||||||
|
dialognames + (sizeof(dialognames) / sizeof(char *));
|
||||||
|
|
||||||
|
class cmpCStr {
|
||||||
|
public:
|
||||||
|
cmpCStr(char const * name) : name_(name) {}
|
||||||
|
bool operator()(char const * other) {
|
||||||
|
return strcmp(other, name_) == 0;
|
||||||
|
}
|
||||||
|
private:
|
||||||
|
char const * name_;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace anon
|
||||||
|
|
||||||
|
// will be replaced by a proper factory...
|
||||||
|
Dialog * createGuiAbout(LyXView & lv);
|
||||||
|
Dialog * createGuiBibitem(LyXView & lv);
|
||||||
|
Dialog * createGuiBibtex(LyXView & lv);
|
||||||
|
Dialog * createGuiBox(LyXView & lv);
|
||||||
|
Dialog * createGuiBranch(LyXView & lv);
|
||||||
|
Dialog * createGuiChanges(LyXView & lv);
|
||||||
|
Dialog * createGuiCharacter(LyXView & lv);
|
||||||
|
Dialog * createGuiCitation(LyXView & lv);
|
||||||
|
Dialog * createGuiDelimiter(LyXView & lv);
|
||||||
|
Dialog * createGuiDocument(LyXView & lv);
|
||||||
|
Dialog * createGuiErrorList(LyXView & lv);
|
||||||
|
Dialog * createGuiERT(LyXView & lv);
|
||||||
|
Dialog * createGuiExternal(LyXView & lv);
|
||||||
|
Dialog * createGuiFloat(LyXView & lv);
|
||||||
|
Dialog * createGuiGraphics(LyXView & lv);
|
||||||
|
Dialog * createGuiInclude(LyXView & lv);
|
||||||
|
Dialog * createGuiIndex(LyXView & lv);
|
||||||
|
Dialog * createGuiLabel(LyXView & lv);
|
||||||
|
Dialog * createGuiListings(LyXView & lv);
|
||||||
|
Dialog * createGuiLog(LyXView & lv);
|
||||||
|
Dialog * createGuiMathMatrix(LyXView & lv);
|
||||||
|
Dialog * createGuiNomenclature(LyXView & lv);
|
||||||
|
Dialog * createGuiNote(LyXView & lv);
|
||||||
|
Dialog * createGuiParagraph(LyXView & lv);
|
||||||
|
Dialog * createGuiPreferences(LyXView & lv);
|
||||||
|
Dialog * createGuiPrint(LyXView & lv);
|
||||||
|
Dialog * createGuiRef(LyXView & lv);
|
||||||
|
Dialog * createGuiSearch(LyXView & lv);
|
||||||
|
Dialog * createGuiSendTo(LyXView & lv);
|
||||||
|
Dialog * createGuiShowFile(LyXView & lv);
|
||||||
|
Dialog * createGuiSpellchecker(LyXView & lv);
|
||||||
|
Dialog * createGuiTabularCreate(LyXView & lv);
|
||||||
|
Dialog * createGuiTabular(LyXView & lv);
|
||||||
|
Dialog * createGuiTexInfo(LyXView & lv);
|
||||||
|
Dialog * createGuiToc(LyXView & lv);
|
||||||
|
Dialog * createGuiThesaurus(LyXView & lv);
|
||||||
|
Dialog * createGuiHyperlink(LyXView & lv);
|
||||||
|
Dialog * createGuiVSpace(LyXView & lv);
|
||||||
|
Dialog * createGuiViewSource(LyXView & lv);
|
||||||
|
Dialog * createGuiWrap(LyXView & lv);
|
||||||
|
|
||||||
|
|
||||||
|
bool GuiView::isValidName(string const & name) const
|
||||||
|
{
|
||||||
|
return std::find_if(dialognames, end_dialognames,
|
||||||
|
cmpCStr(name.c_str())) != end_dialognames;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Dialog * GuiView::build(string const & name)
|
||||||
|
{
|
||||||
|
BOOST_ASSERT(isValidName(name));
|
||||||
|
|
||||||
|
if (name == "aboutlyx")
|
||||||
|
return createGuiAbout(*this);
|
||||||
|
if (name == "bibitem")
|
||||||
|
return createGuiBibitem(*this);
|
||||||
|
if (name == "bibtex")
|
||||||
|
return createGuiBibtex(*this);
|
||||||
|
if (name == "box")
|
||||||
|
return createGuiBox(*this);
|
||||||
|
if (name == "branch")
|
||||||
|
return createGuiBranch(*this);
|
||||||
|
if (name == "changes")
|
||||||
|
return createGuiChanges(*this);
|
||||||
|
if (name == "character")
|
||||||
|
return createGuiCharacter(*this);
|
||||||
|
if (name == "citation")
|
||||||
|
return createGuiCitation(*this);
|
||||||
|
if (name == "document")
|
||||||
|
return createGuiDocument(*this);
|
||||||
|
if (name == "errorlist")
|
||||||
|
return createGuiErrorList(*this);
|
||||||
|
if (name == "ert")
|
||||||
|
return createGuiERT(*this);
|
||||||
|
if (name == "external")
|
||||||
|
return createGuiExternal(*this);
|
||||||
|
if (name == "file")
|
||||||
|
return createGuiShowFile(*this);
|
||||||
|
if (name == "findreplace")
|
||||||
|
return createGuiSearch(*this);
|
||||||
|
if (name == "float")
|
||||||
|
return createGuiFloat(*this);
|
||||||
|
if (name == "graphics")
|
||||||
|
return createGuiGraphics(*this);
|
||||||
|
if (name == "include")
|
||||||
|
return createGuiInclude(*this);
|
||||||
|
if (name == "index")
|
||||||
|
return createGuiIndex(*this);
|
||||||
|
if (name == "nomenclature")
|
||||||
|
return createGuiNomenclature(*this);
|
||||||
|
if (name == "label")
|
||||||
|
return createGuiLabel(*this);
|
||||||
|
if (name == "log")
|
||||||
|
return createGuiLog(*this);
|
||||||
|
if (name == "view-source")
|
||||||
|
return createGuiViewSource(*this);
|
||||||
|
if (name == "mathdelimiter")
|
||||||
|
return createGuiDelimiter(*this);
|
||||||
|
if (name == "mathmatrix")
|
||||||
|
return createGuiMathMatrix(*this);
|
||||||
|
if (name == "note")
|
||||||
|
return createGuiNote(*this);
|
||||||
|
if (name == "paragraph")
|
||||||
|
return createGuiParagraph(*this);
|
||||||
|
if (name == "prefs")
|
||||||
|
return createGuiPreferences(*this);
|
||||||
|
if (name == "print")
|
||||||
|
return createGuiPrint(*this);
|
||||||
|
if (name == "ref")
|
||||||
|
return createGuiRef(*this);
|
||||||
|
if (name == "sendto")
|
||||||
|
return createGuiSendTo(*this);
|
||||||
|
if (name == "spellchecker")
|
||||||
|
return createGuiSpellchecker(*this);
|
||||||
|
if (name == "tabular")
|
||||||
|
return createGuiTabular(*this);
|
||||||
|
if (name == "tabularcreate")
|
||||||
|
return createGuiTabularCreate(*this);
|
||||||
|
if (name == "texinfo")
|
||||||
|
return createGuiTexInfo(*this);
|
||||||
|
#ifdef HAVE_LIBAIKSAURUS
|
||||||
|
if (name == "thesaurus")
|
||||||
|
return createGuiThesaurus(*this);
|
||||||
|
#endif
|
||||||
|
if (name == "toc")
|
||||||
|
return createGuiToc(*this);
|
||||||
|
if (name == "href")
|
||||||
|
return createGuiHyperlink(*this);
|
||||||
|
if (name == "vspace")
|
||||||
|
return createGuiVSpace(*this);
|
||||||
|
if (name == "wrap")
|
||||||
|
return createGuiWrap(*this);
|
||||||
|
if (name == "listings")
|
||||||
|
return createGuiListings(*this);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// Are the tooltips on or off?
|
||||||
|
bool GuiView::tooltipsEnabled()
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace frontend
|
} // namespace frontend
|
||||||
} // namespace lyx
|
} // namespace lyx
|
||||||
|
|
||||||
|
@ -17,6 +17,9 @@
|
|||||||
|
|
||||||
#include "frontends/LyXView.h"
|
#include "frontends/LyXView.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
|
||||||
#include <QMainWindow>
|
#include <QMainWindow>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
|
|
||||||
@ -36,6 +39,7 @@ namespace frontend {
|
|||||||
|
|
||||||
class GuiToolbar;
|
class GuiToolbar;
|
||||||
class GuiWorkArea;
|
class GuiWorkArea;
|
||||||
|
class Dialog;
|
||||||
|
|
||||||
QWidget * mainWindow();
|
QWidget * mainWindow();
|
||||||
|
|
||||||
@ -95,8 +99,6 @@ public:
|
|||||||
std::string const & data);
|
std::string const & data);
|
||||||
void showInsetDialog(std::string const & name,
|
void showInsetDialog(std::string const & name,
|
||||||
std::string const & data, Inset * inset);
|
std::string const & data, Inset * inset);
|
||||||
void updateDialog(std::string const & name,
|
|
||||||
std::string const & data);
|
|
||||||
|
|
||||||
/// called on timeout
|
/// called on timeout
|
||||||
void autoSave();
|
void autoSave();
|
||||||
@ -106,11 +108,6 @@ public:
|
|||||||
/// \return the current buffer view.
|
/// \return the current buffer view.
|
||||||
BufferView * view();
|
BufferView * view();
|
||||||
|
|
||||||
/// get access to the dialogs
|
|
||||||
Dialogs & getDialogs() { return *dialogs_; }
|
|
||||||
///
|
|
||||||
Dialogs const & getDialogs() const { return *dialogs_; }
|
|
||||||
|
|
||||||
/// load a buffer into the current workarea.
|
/// load a buffer into the current workarea.
|
||||||
Buffer * loadLyXFile(support::FileName const & name, ///< File to load.
|
Buffer * loadLyXFile(support::FileName const & name, ///< File to load.
|
||||||
bool tolastfiles = true); ///< append to the "Open recent" menu?
|
bool tolastfiles = true); ///< append to the "Open recent" menu?
|
||||||
@ -205,10 +202,83 @@ private:
|
|||||||
|
|
||||||
/// auto-saving of buffers
|
/// auto-saving of buffers
|
||||||
Timeout * const autosave_timeout_;
|
Timeout * const autosave_timeout_;
|
||||||
/// dialogs for this view
|
|
||||||
Dialogs * dialogs_;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
public:
|
||||||
|
///
|
||||||
|
/// dialogs for this view
|
||||||
|
///
|
||||||
|
|
||||||
|
/** Check the status of all visible dialogs and disable or reenable
|
||||||
|
* them as appropriate.
|
||||||
|
*
|
||||||
|
* Disabling is needed for example when a dialog is open and the
|
||||||
|
* cursor moves to a position where the corresponding inset is not
|
||||||
|
* allowed.
|
||||||
|
*/
|
||||||
|
void checkStatus();
|
||||||
|
|
||||||
|
/// Are the tooltips on or off?
|
||||||
|
bool tooltipsEnabled();
|
||||||
|
|
||||||
|
/// Hide all visible dialogs
|
||||||
|
void hideAll() const;
|
||||||
|
/// Hide any dialogs that require a buffer for them to operate
|
||||||
|
void hideBufferDependent() const;
|
||||||
|
/** Update visible, buffer-dependent dialogs
|
||||||
|
If the bool is true then a buffer change has occurred
|
||||||
|
else it is still the same buffer.
|
||||||
|
*/
|
||||||
|
void updateBufferDependent(bool) const;
|
||||||
|
|
||||||
|
/** \param name == "bibtex", "citation" etc; an identifier used to
|
||||||
|
launch a particular dialog.
|
||||||
|
\param data is a string representation of the Inset contents.
|
||||||
|
It is often little more than the output from Inset::write.
|
||||||
|
It is passed to, and parsed by, the frontend dialog.
|
||||||
|
Several of these dialogs do not need any data,
|
||||||
|
so it defaults to string().
|
||||||
|
\param inset ownership is _not_ passed to the frontend dialog.
|
||||||
|
It is stored internally and used by the kernel to ascertain
|
||||||
|
what to do with the FuncRequest dispatched from the frontend
|
||||||
|
dialog on 'Apply'; should it be used to create a new inset at
|
||||||
|
the current cursor position or modify an existing, 'open' inset?
|
||||||
|
*/
|
||||||
|
void showDialog(std::string const & name,
|
||||||
|
std::string const & data = std::string(), Inset * inset = 0);
|
||||||
|
|
||||||
|
/** \param name == "citation", "bibtex" etc; an identifier used
|
||||||
|
to update the contents of a particular dialog with \param data.
|
||||||
|
See the comments to 'show', above.
|
||||||
|
*/
|
||||||
|
void updateDialog(std::string const & name, std::string const & data);
|
||||||
|
|
||||||
|
/// Is the dialog currently visible?
|
||||||
|
bool isDialogVisible(std::string const & name) const;
|
||||||
|
|
||||||
|
/** All Dialogs of the given \param name will be closed if they are
|
||||||
|
connected to the given \param inset.
|
||||||
|
*/
|
||||||
|
void hideDialog(std::string const & name, Inset * inset);
|
||||||
|
///
|
||||||
|
void disconnectDialog(std::string const & name);
|
||||||
|
///
|
||||||
|
Inset * getOpenInset(std::string const & name) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
///
|
||||||
|
void redrawDialog() const;
|
||||||
|
///
|
||||||
|
bool isValidName(std::string const & name) const;
|
||||||
|
///
|
||||||
|
Dialog * find_or_build(std::string const & name);
|
||||||
|
///
|
||||||
|
Dialog * build(std::string const & name);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// flag against a race condition due to multiclicks in Qt frontend,
|
||||||
|
/// see bug #1119
|
||||||
|
bool in_show_;
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace frontend
|
} // namespace frontend
|
||||||
} // namespace lyx
|
} // namespace lyx
|
||||||
|
@ -41,7 +41,6 @@
|
|||||||
#include "support/ForkedcallsController.h"
|
#include "support/ForkedcallsController.h"
|
||||||
|
|
||||||
#include "frontends/Application.h"
|
#include "frontends/Application.h"
|
||||||
#include "frontends/Dialogs.h" // only used in setReadOnly
|
|
||||||
#include "frontends/FontMetrics.h"
|
#include "frontends/FontMetrics.h"
|
||||||
#include "frontends/WorkAreaManager.h"
|
#include "frontends/WorkAreaManager.h"
|
||||||
|
|
||||||
@ -961,7 +960,7 @@ void GuiWorkArea::setReadOnly(bool)
|
|||||||
{
|
{
|
||||||
updateWindowTitle();
|
updateWindowTitle();
|
||||||
if (this == lyx_view_->currentWorkArea())
|
if (this == lyx_view_->currentWorkArea())
|
||||||
lyx_view_->getDialogs().updateBufferDependent(false);
|
lyx_view_->updateBufferDependent(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -56,7 +56,6 @@ SOURCEFILES = \
|
|||||||
ButtonController.cpp \
|
ButtonController.cpp \
|
||||||
ColorCache.cpp \
|
ColorCache.cpp \
|
||||||
CustomizedWidgets.cpp \
|
CustomizedWidgets.cpp \
|
||||||
Dialogs.cpp \
|
|
||||||
EmptyTable.cpp \
|
EmptyTable.cpp \
|
||||||
FileDialog.cpp \
|
FileDialog.cpp \
|
||||||
FloatPlacement.cpp \
|
FloatPlacement.cpp \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user