]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt4/GuiToc.cpp
Complete the removal of the embedding stuff. Maybe. It's hard to be sure we got every...
[lyx.git] / src / frontends / qt4 / GuiToc.cpp
index 4a909b9f851f38ef3db4ada120b836aeea19483e..73bd3d751eb4200f8d36a17a003ff5ff7207d355 100644 (file)
@@ -5,6 +5,7 @@
  *
  * \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 "GuiView.h"
+#include "DockView.h"
+#include "TocWidget.h"
+#include "FuncRequest.h"
+
+#include "insets/InsetCommand.h"
 
 #include "TocModel.h"
 #include "qt_helpers.h"
 
-#include "debug.h"
+#include "Buffer.h"
+#include "BufferView.h"
+#include "BufferParams.h"
+#include "FloatList.h"
+#include "FuncRequest.h"
+#include "TextClass.h"
 
-#include "ControlToc.h"
+#include "support/convert.h"
+#include "support/debug.h"
+#include "support/gettext.h"
 
-#include <algorithm>
+#include "support/assert.h"
 
-using std::endl;
+#include <algorithm>
 
-using std::pair;
-using std::vector;
-using std::string;
+using namespace std;
 
 namespace lyx {
 namespace frontend {
 
-
-GuiToc::GuiToc(Dialog & dialog)
-       : ControlToc(dialog)
+GuiToc::GuiToc(GuiView & parent, Qt::DockWidgetArea area, Qt::WindowFlags flags)
+       : DockView(parent, "toc", qt_("Outline"), area, flags)
 {
-#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
+       widget_ = new TocWidget(*this, &parent);
+       setWidget(widget_);
 }
 
 
-bool GuiToc::canOutline(int type) const
+GuiToc::~GuiToc()
 {
-       if (type < 0)
-               return false;
+       clearTocModels();
+       delete widget_;
+}
 
-       return canOutline(type);
+
+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();
 }
 
 
@@ -69,32 +82,24 @@ QStandardItemModel * GuiToc::tocModel(int type)
                return 0;
 
        if (toc_models_.empty()) {
-               LYXERR(Debug::GUI) << "GuiToc::tocModel(): no types available " << endl;
+               LYXERR(Debug::GUI, "GuiToc::tocModel(): no types available ");
                return 0;
        }
 
-       LYXERR(Debug::GUI)
-               << "GuiToc: type " << type
-               << "  toc_models_.size() " << toc_models_.size()
-               << endl;
+       LYXERR(Debug::GUI, "GuiToc: type " << type
+               << "  toc_models_.size() " << toc_models_.size());
 
-       BOOST_ASSERT(type >= 0 && type < int(toc_models_.size()));
+       LASSERT(type >= 0 && type < int(toc_models_.size()), /**/);
        return toc_models_[type];
 }
 
 
-QModelIndex const GuiToc::getCurrentIndex(int type) const
+QModelIndex GuiToc::currentIndex(int type) const
 {
        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(getCurrentTocItem(type));
+       return toc_models_[type]->modelIndex(currentTocItem(type));
 }
 
 
@@ -102,39 +107,164 @@ 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!"
-                       << endl;
+               LYXERR(Debug::GUI, "GuiToc::goTo(): QModelIndex is invalid!");
                return;
        }
 
-       BOOST_ASSERT(type >= 0 && type < int(toc_models_.size()));
+       LASSERT(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;
+       LYXERR(Debug::GUI, "GuiToc::goTo " << to_utf8(it->str()));
 
-       ControlToc::goTo(*it);
+       string const tmp = convert<string>(it->id());
+       dispatch(FuncRequest(LFUN_PARAGRAPH_GOTO, tmp));
 }
 
 
-bool GuiToc::initialiseParams(std::string const & data)
+void GuiToc::updateView()
 {
-       if (!ControlToc::initialiseParams(data))
-               return false;
-       updateView();
-       modelReset();
-       return true;
+       widget_->updateView();
 }
 
 
-void GuiToc::updateView()
+TocList const & GuiToc::tocs() const
 {
-       toc_models_.clear();
-       TocList::const_iterator it = tocs().begin();
-       TocList::const_iterator end = tocs().end();
-       for (; it != end; ++it)
+       return buffer().masterBuffer()->tocBackend().tocs();
+}
+
+
+bool GuiToc::initialiseParams(string const & data)
+{
+       LYXERR(Debug::GUI, data);
+       QString str = toqstr(data);
+       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";
+       } else if (!str.isEmpty()) {
+               new_type = str;
+       } else {
+               // Default to Outliner.
+               new_type = "tableofcontents";
+       }
+
+       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));
+       }
+
+       widget_->updateGui(types_.indexOf(new_type));
+
+       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()
+{
+       dispatch(FuncRequest(LFUN_OUTLINE_OUT));
+}
+
+
+void GuiToc::updateBackend()
+{
+       buffer().masterBuffer()->tocBackend().update();
+       buffer().structureChanged();
+}
+
+
+TocIterator GuiToc::currentTocItem(int type) const
+{
+       LASSERT(bufferview(), /**/);
+       ParConstIterator it(bufferview()->cursor());
+       return buffer().masterBuffer()->tocBackend().item(fromqstr(types_[type]), it);
+}
+
+
+docstring GuiToc::guiName(string const & type) const
+{
+       if (type == "tableofcontents")
+               return _("Table of Contents");
+       if (type == "child")
+               return _("Child Documents");
+       if (type == "graphics")
+               return _("List of Graphics");
+       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);
+}
+
+
+void GuiToc::dispatchParams()
+{
+}
+
+
+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);
+#else
+       return new GuiToc(guiview);
+#endif
 }