X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffrontends%2Fqt4%2FTocWidget.h;h=608920a42ad3f7b7f03519895e6686c1930d9301;hb=59e0cb8f85f0d2f985b31532dd3308315659c662;hp=80d6d3f152a489a30e6734f9bb155bd947d71442;hpb=1d3fcde7f753db099a446ac74d7fb3f970770dbb;p=lyx.git diff --git a/src/frontends/qt4/TocWidget.h b/src/frontends/qt4/TocWidget.h index 80d6d3f152..608920a42a 100644 --- a/src/frontends/qt4/TocWidget.h +++ b/src/frontends/qt4/TocWidget.h @@ -15,6 +15,9 @@ #include "ui_TocUi.h" +#include "Cursor.h" +#include "FuncCode.h" + #include class QModelIndex; @@ -34,43 +37,72 @@ public: /// Initialise GUI. void init(QString const & str); + /// + void doDispatch(Cursor & cur, FuncRequest const & fr); + /// + bool getStatus(Cursor & cur, FuncRequest const & fr, FuncStatus & status) + const; public Q_SLOTS: - /// Update the display of the dialog whilst it is still visible. + /// Schedule new update of the display unless already scheduled. void updateView(); + /// Update the display of the dialog whilst it is still visible. + void updateViewForce(); protected Q_SLOTS: - /// - void setTocModel(size_t type); /// void select(QModelIndex const & index); /// void goTo(QModelIndex const &); void on_tocTV_activated(QModelIndex const &); - void on_tocTV_clicked(QModelIndex const &); + void on_tocTV_pressed(QModelIndex const &); void on_updateTB_clicked(); + void on_sortCB_stateChanged(int state); + void on_persistentCB_stateChanged(int state); void on_depthSL_valueChanged(int depth); void on_typeCO_currentIndexChanged(int value); void on_moveUpTB_clicked(); void on_moveDownTB_clicked(); void on_moveInTB_clicked(); void on_moveOutTB_clicked(); + void filterContents(); + + void showContextMenu(const QPoint & pos); private: /// void enableControls(bool enable = true); /// - int getIndexDepth(QModelIndex const & index, int depth = -1); + bool canOutline() + { return current_type_ == "tableofcontents"; } + /// It is not possible to have synchronous navigation in a correct + /// and efficient way with the label and change type because Toc::item() + /// does a linear search. Even when fixed, it might even not be desirable + /// to do so if we want to support drag&drop of labels and references. + bool canNavigate() + { return current_type_ != "label" && current_type_ != "change"; } + /// + bool isSortable() + { return current_type_ != "tableofcontents"; } /// void setTreeDepth(int depth); /// - void outline(int func_code); + void outline(FuncCode func_code); + /// finds the inset that is connected to the current item, + /// if any, otherwise return null + Inset * itemInset() const; + /// + QString current_type_; /// depth of list shown int depth_; + /// persistence of uncollapsed nodes in toc view + bool persistent_; /// GuiView & gui_view_; + // next delay for outliner update in ms. -1 when already scheduled. + int update_delay_; }; } // namespace frontend