*
* \author John Levon
* \author Abdelrazak Younes
+ * \author Angus Leeming
*
* Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "GuiToc.h"
-
-#include "TocModel.h"
+#include "GuiView.h"
+#include "DockView.h"
+#include "TocWidget.h"
#include "qt_helpers.h"
-#include "debug.h"
-
-#include "ControlToc.h"
-
-#include <algorithm>
+#include "Buffer.h"
+#include "BufferView.h"
+#include "BufferParams.h"
+#include "FuncRequest.h"
-using std::endl;
+#include "support/debug.h"
+#include "support/gettext.h"
+#include "support/lassert.h"
-using std::pair;
-using std::vector;
-using std::string;
+using namespace std;
namespace lyx {
namespace frontend {
-
-GuiToc::GuiToc(LyXView & lv)
- : GuiDialog(lv, "toc")
+GuiToc::GuiToc(GuiView & parent, Qt::DockWidgetArea area, Qt::WindowFlags flags)
+ : DockView(parent, "toc", qt_("Outline"), area, flags),
+ widget_(new TocWidget(parent, this)),
+ is_closing_(false)
{
- setViewTitle(_("Outline"));
- setController(new ControlToc(*this));
-#ifdef Q_WS_MACX
- // On Mac show as a drawer at the right
- //setView(new DockView<GuiToc, TocWidget>(
- // *dialog, qtoc, &gui_view, _("Outline"), Qt::RightDockWidgetArea, Qt::Drawer));
-#else
- //setView(new DockView<GuiToc, TocWidget>(
-// *dialog, qtoc, &gui_view, _("Outline")));
-#endif
- bc().setPolicy(ButtonPolicy::OkCancelPolicy);
+ setWidget(widget_);
+ setFocusProxy(widget_);
}
-ControlToc & GuiToc::controller() const
+void GuiToc::updateView()
{
- return static_cast<ControlToc &>(Dialog::controller());
+ widget_->updateView();
}
-bool GuiToc::canOutline(int type) const
+bool GuiToc::initialiseParams(string const & data)
{
- if (type < 0)
- return false;
-
- return controller().canOutline(type);
+ widget_->init(toqstr(data));
+ return true;
}
-int GuiToc::getTocDepth(int type)
+void GuiToc::dispatchParams()
{
- if (type < 0)
- return 0;
- return toc_models_[type]->modelDepth();
}
-QStandardItemModel * GuiToc::tocModel(int type)
+void GuiToc::enableView(bool enable)
{
- if (type < 0)
- return 0;
-
- if (toc_models_.empty()) {
- LYXERR(Debug::GUI) << "GuiToc::tocModel(): no types available " << endl;
- return 0;
- }
-
- LYXERR(Debug::GUI)
- << "GuiToc: type " << type
- << " toc_models_.size() " << toc_models_.size()
- << endl;
-
- BOOST_ASSERT(type >= 0 && type < int(toc_models_.size()));
- return toc_models_[type];
+ if (!enable)
+ // In the opposite case, updateView() will be called anyway.
+ widget_->updateViewNow();
}
-QModelIndex const GuiToc::getCurrentIndex(int type) const
+void GuiToc::closeEvent(QCloseEvent * /*event*/)
{
- if (type < 0)
- return QModelIndex();
-
- // FIXME: The TocBackend infrastructure is not ready for LOF and LOT
- // This is because a proper ParConstIterator is not constructed in
- // InsetCaption::addToToc()
- if(!canOutline(type))
- return QModelIndex();
-
- return toc_models_[type]->modelIndex(controller().getCurrentTocItem(type));
+ is_closing_ = true;
+ static_cast<GuiView *>(parent())->updateToolbars();
+ is_closing_ = false;
}
-void GuiToc::goTo(int type, QModelIndex const & index)
+void GuiToc::doDispatch(Cursor & cur, FuncRequest const & cmd)
{
- if (type < 0 || !index.isValid()
- || index.model() != toc_models_[type]) {
- LYXERR(Debug::GUI)
- << "GuiToc::goTo(): QModelIndex is invalid!"
- << endl;
- 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()) << endl;
-
- controller().goTo(*it);
+ widget_->doDispatch(cur, cmd);
}
-bool GuiToc::initialiseParams(std::string const & data)
+bool GuiToc::getStatus(Cursor & cur, FuncRequest const & cmd,
+ FuncStatus & status) const
{
- if (!controller().initialiseParams(data))
- return false;
- updateView();
- modelReset();
- return true;
+ return widget_->getStatus(cur, cmd, status);
}
-void GuiToc::updateView()
+Dialog * createGuiToc(GuiView & lv)
{
- toc_models_.clear();
- TocList::const_iterator it = controller().tocs().begin();
- TocList::const_iterator end = controller().tocs().end();
- for (; it != end; ++it)
- toc_models_.push_back(new TocModel(it->second));
+ return new GuiToc(lv);
}
} // namespace frontend
} // namespace lyx
-#include "GuiToc_moc.cpp"
+#include "moc_GuiToc.cpp"