#include "GuiView.h"
#include "DockView.h"
#include "TocWidget.h"
-#include "FuncRequest.h"
-#include "insets/InsetCommand.h"
-
-#include "TocModel.h"
#include "qt_helpers.h"
#include "Buffer.h"
#include "BufferView.h"
#include "BufferParams.h"
-#include "FloatList.h"
#include "FuncRequest.h"
-#include "TextClass.h"
-#include "support/convert.h"
#include "support/debug.h"
#include "support/gettext.h"
-
-#include <algorithm>
+#include "support/lassert.h"
using namespace std;
namespace frontend {
GuiToc::GuiToc(GuiView & parent, Qt::DockWidgetArea area, Qt::WindowFlags flags)
- : DockView(parent, "toc", qt_("Outline"), area, flags)
+ : DockView(parent, "toc", qt_("Outline"), area, flags), is_closing_(false)
{
- widget_ = new TocWidget(*this, &parent);
+ widget_ = new TocWidget(parent, this);
setWidget(widget_);
+ setFocusProxy(widget_);
}
GuiToc::~GuiToc()
{
- clearTocModels();
delete widget_;
}
-void GuiToc::clearTocModels()
-{
- const unsigned int size = toc_models_.size();
- for (unsigned int i = 0; i < size; ++i) {
- delete toc_models_[i];
- }
- toc_models_.clear();
-}
-
-
-int GuiToc::getTocDepth(int type)
-{
- if (type < 0)
- return 0;
- return toc_models_[type]->modelDepth();
-}
-
-
-QStandardItemModel * GuiToc::tocModel(int type)
-{
- if (type < 0)
- return 0;
-
- if (toc_models_.empty()) {
- LYXERR(Debug::GUI, "GuiToc::tocModel(): no types available ");
- return 0;
- }
-
- LYXERR(Debug::GUI, "GuiToc: type " << type
- << " toc_models_.size() " << toc_models_.size());
-
- BOOST_ASSERT(type >= 0 && type < int(toc_models_.size()));
- return toc_models_[type];
-}
-
-
-QModelIndex GuiToc::currentIndex(int type) const
-{
- if (type < 0)
- return QModelIndex();
-
- return toc_models_[type]->modelIndex(currentTocItem(type));
-}
-
-
-void GuiToc::goTo(int type, QModelIndex const & index)
-{
- if (type < 0 || !index.isValid()
- || index.model() != toc_models_[type]) {
- LYXERR(Debug::GUI, "GuiToc::goTo(): QModelIndex is invalid!");
- return;
- }
-
- BOOST_ASSERT(type >= 0 && type < int(toc_models_.size()));
-
- TocIterator const it = toc_models_[type]->tocIterator(index);
-
- LYXERR(Debug::GUI, "GuiToc::goTo " << to_utf8(it->str()));
-
- string const tmp = convert<string>(it->id());
- dispatch(FuncRequest(LFUN_PARAGRAPH_GOTO, tmp));
-}
-
-
void GuiToc::updateView()
{
widget_->updateView();
-}
-
-
-TocList const & GuiToc::tocs() const
-{
- return buffer().masterBuffer()->tocBackend().tocs();
+ return;
}
bool GuiToc::initialiseParams(string const & data)
{
- LYXERR(Debug::GUI, data);
- QString str = QString::fromUtf8(data.c_str());
- QString new_type;
- if (str.contains("tableofcontents"))
- new_type = "tableofcontents";
- else if (str.contains("floatlist")) {
- if (str.contains("\"figure"))
- new_type = "figure";
- else if (str.contains("\"table"))
- new_type = "table";
- else if (str.contains("\"algorithm"))
- new_type = "algorithm";
- }
-
- types_.clear();
- type_names_.clear();
- clearTocModels();
- TocList const & tocs = buffer().masterBuffer()->tocBackend().tocs();
- TocList::const_iterator it = tocs.begin();
- TocList::const_iterator end = tocs.end();
- for (; it != end; ++it) {
- types_.push_back(toqstr(it->first));
- type_names_.push_back(toqstr(guiName(it->first)));
- toc_models_.push_back(new TocModel(it->second));
- }
-
- int selected_type = -1;
- for (int i = 0; i != types_.size(); ++i) {
- if (new_type == types_[i]) {
- selected_type = i;
- break;
- }
- }
- widget_->updateGui(selected_type);
-
+ widget_->init(toqstr(data));
return true;
}
-bool GuiToc::canOutline(int type) const
-{
- return types_[type] == "tableofcontents";
-}
-
-
-void GuiToc::outlineUp()
-{
- dispatch(FuncRequest(LFUN_OUTLINE_UP));
-}
-
-
-void GuiToc::outlineDown()
-{
- dispatch(FuncRequest(LFUN_OUTLINE_DOWN));
-}
-
-
-void GuiToc::outlineIn()
-{
- dispatch(FuncRequest(LFUN_OUTLINE_IN));
-}
-
-
-void GuiToc::outlineOut()
+void GuiToc::dispatchParams()
{
- dispatch(FuncRequest(LFUN_OUTLINE_OUT));
}
-void GuiToc::updateBackend()
+void GuiToc::enableView(bool enable)
{
- buffer().masterBuffer()->tocBackend().update();
- buffer().structureChanged();
+ if (!enable)
+ // In the opposite case, updateView() will be called anyway.
+ widget_->updateView();
}
-TocIterator GuiToc::currentTocItem(int type) const
+void GuiToc::closeEvent(QCloseEvent * /*event*/)
{
- BOOST_ASSERT(bufferview());
- ParConstIterator it(bufferview()->cursor());
- return buffer().masterBuffer()->tocBackend().item(fromqstr(types_[type]), it);
+ is_closing_ = true;
+ ((GuiView *)parent())->updateToolbars();
+ is_closing_ = false;
}
-docstring GuiToc::guiName(string const & type) const
+void GuiToc::doDispatch(Cursor & cur, FuncRequest const & cmd)
{
- if (type == "tableofcontents")
- return _("Table of Contents");
- if (type == "child")
- return _("Child Documents");
- if (type == "embedded")
- return _("Embedded Files");
- if (type == "equation")
- return _("List of Equations");
- if (type == "footnote")
- return _("List of Foot notes");
- if (type == "listing")
- return _("List of Listings");
- if (type == "index")
- return _("List of Indexes");
- if (type == "marginalnote")
- return _("List of Marginal notes");
- if (type == "note")
- return _("List of Notes");
- if (type == "citation")
- return _("List of Citations");
- if (type == "label")
- return _("Labels and References");
-
- FloatList const & floats = buffer().params().documentClass().floats();
- if (floats.typeExist(type))
- return _(floats.getType(type).listName());
-
- return _(type);
+ widget_->doDispatch(cur, cmd);
}
-void GuiToc::dispatchParams()
+bool GuiToc::getStatus(Cursor & cur, FuncRequest const & cmd,
+ FuncStatus & status) const
{
+ return widget_->getStatus(cur, cmd, status);
}
Dialog * createGuiToc(GuiView & lv)
{
- GuiView & guiview = static_cast<GuiView &>(lv);
-#ifdef Q_WS_MACX
- // On Mac show as a drawer at the right
- return new GuiToc(guiview, Qt::RightDockWidgetArea, Qt::Drawer);
+ GuiToc * toc;
+#ifdef Q_OS_MAC
+ // On Mac show at the right and floating
+ toc = new GuiToc(lv, Qt::RightDockWidgetArea);
+ toc->setFloating(true);
#else
- return new GuiToc(guiview);
+ toc = new GuiToc(lv);
#endif
+ return toc;
}
} // namespace frontend
} // namespace lyx
-#include "GuiToc_moc.cpp"
+#include "moc_GuiToc.cpp"