#include "TocWidget.h"
-#include "GuiToc.h"
+#include "TocModel.h"
#include "qt_helpers.h"
-#include "support/filetools.h"
-#include "support/lstrings.h"
-#include "debug.h"
+#include "FuncRequest.h"
+#include "LyXFunc.h"
+
+#include "support/debug.h"
#include <QHeaderView>
-#include <QPushButton>
-#include <QTreeWidgetItem>
+#include <QTimer>
#include <vector>
-#include <string>
-#include <stack>
-
-using std::endl;
-using std::pair;
-using std::stack;
-using std::vector;
-using std::string;
+using namespace std;
namespace lyx {
-
-using support::FileName;
-using support::libFileSearch;
-
namespace frontend {
-TocWidget::TocWidget(GuiToc * form, QWidget * parent)
- : QWidget(parent), form_(form), depth_(0)
+TocWidget::TocWidget(TocModels & models, QWidget * parent)
+ : QWidget(parent), depth_(0), models_(models)
{
setupUi(this);
- connect(form, SIGNAL(modelReset()),
- SLOT(updateGui()));
-
- FileName icon_path = libFileSearch("images", "promote.png");
- moveOutTB->setIcon(QIcon(toqstr(icon_path.absFilename())));
- icon_path = libFileSearch("images", "demote.png");
- moveInTB->setIcon(QIcon(toqstr(icon_path.absFilename())));
- icon_path = libFileSearch("images", "up.png");
- moveUpTB->setIcon(QIcon(toqstr(icon_path.absFilename())));
- icon_path = libFileSearch("images", "down.png");
- moveDownTB->setIcon(QIcon(toqstr(icon_path.absFilename())));
- icon_path = libFileSearch("images", "reload.png");
- updateTB->setIcon(QIcon(toqstr(icon_path.absFilename())));
+ moveOutTB->setIcon(QIcon(":/images/promote.png"));
+ moveInTB->setIcon(QIcon(":/images/demote.png"));
+ moveUpTB->setIcon(QIcon(":/images/up.png"));
+ moveDownTB->setIcon(QIcon(":/images/down.png"));
+ updateTB->setIcon(QIcon(":/images/reload.png"));
// avoid flickering
tocTV->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
}
-void TocWidget::selectionChanged(const QModelIndex & current,
- const QModelIndex & /*previous*/)
+void TocWidget::on_tocTV_activated(QModelIndex const & index)
{
- LYXERR(Debug::GUI)
- << "selectionChanged index " << current.row()
- << ", " << current.column()
- << endl;
+ goTo(index);
+}
+
- form_->goTo(typeCO->currentIndex(), current);
+void TocWidget::on_tocTV_clicked(QModelIndex const & index)
+{
+ goTo(index);
+ // FIXME: It would be nice to return the focus to the work area in this
+ // case. But we need access to the GuiView!
+}
+
+
+void TocWidget::goTo(QModelIndex const & index)
+{
+ LYXERR(Debug::GUI, "goto " << index.row()
+ << ", " << index.column());
+
+ models_.goTo(typeCO->currentIndex(), index);
}
// The backend update can take some time so we disable
// the controls while waiting.
enableControls(false);
- form_->updateBackend();
+ models_.updateBackend();
}
/* FIXME (Ugras 17/11/06):
int TocWidget::getIndexDepth(QModelIndex const & index, int depth)
{
++depth;
- return (index.parent() ==
- QModelIndex())? depth : getIndexDepth(index.parent(),depth);
+ return (index.parent() == QModelIndex())
+ ? depth : getIndexDepth(index.parent(),depth);
}
QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
if (!list.isEmpty()) {
enableControls(false);
- form_->goTo(typeCO->currentIndex(), list[0]);
- form_->outlineUp();
+ goTo(list[0]);
+ dispatch(FuncRequest(LFUN_OUTLINE_UP));
enableControls(true);
}
}
QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
if (!list.isEmpty()) {
enableControls(false);
- form_->goTo(typeCO->currentIndex(), list[0]);
- form_->outlineDown();
+ goTo(list[0]);
+ dispatch(FuncRequest(LFUN_OUTLINE_DOWN));
enableControls(true);
}
}
QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
if (!list.isEmpty()) {
enableControls(false);
- form_->goTo(typeCO->currentIndex(), list[0]);
- form_->outlineIn();
+ goTo(list[0]);
+ dispatch(FuncRequest(LFUN_OUTLINE_IN));
enableControls(true);
}
}
QModelIndexList const & list = tocTV->selectionModel()->selectedIndexes();
if (!list.isEmpty()) {
enableControls(false);
- form_->goTo(typeCO->currentIndex(), list[0]);
- form_->outlineOut();
+ goTo(list[0]);
+ dispatch(FuncRequest(LFUN_OUTLINE_OUT));
enableControls(true);
}
}
void TocWidget::select(QModelIndex const & index)
{
if (!index.isValid()) {
- LYXERR(Debug::GUI)
- << "TocWidget::select(): QModelIndex is invalid!" << endl;
+ LYXERR(Debug::GUI, "TocWidget::select(): QModelIndex is invalid!");
return;
}
- disconnectSelectionModel();
- tocTV->setCurrentIndex(index);
tocTV->scrollTo(index);
- reconnectSelectionModel();
+ tocTV->clearSelection();
+ tocTV->setCurrentIndex(index);
}
{
updateTB->setEnabled(enable);
- if (!form_->canOutline(typeCO->currentIndex()))
+ if (!models_.canOutline(typeCO->currentIndex()))
enable = false;
moveUpTB->setEnabled(enable);
}
-void TocWidget::update()
+void TocWidget::updateView()
{
- LYXERR(Debug::GUI) << "In TocWidget::update()" << endl;
- select(form_->getCurrentIndex(typeCO->currentIndex()));
- QWidget::update();
+ LYXERR(Debug::GUI, "In TocWidget::updateView()");
+ setTreeDepth(depth_);
+ select(models_.currentIndex(typeCO->currentIndex()));
}
-void TocWidget::updateGui()
+void TocWidget::init(QString const & str)
{
- vector<docstring> const & type_names = form_->typeNames();
- if (type_names.empty()) {
+ QStringList const & type_names = models_.typeNames();
+ if (type_names.isEmpty()) {
enableControls(false);
typeCO->clear();
tocTV->setModel(new QStandardItemModel);
return;
}
- QString current_text = typeCO->currentText();
- //lyxerr << "current_text " << fromqstr(current_text) << endl;
+ int selected_type = models_.decodeType(str);
+
+ QString const current_text = typeCO->currentText();
typeCO->blockSignals(true);
typeCO->clear();
- int current_type = -1;
- for (size_t i = 0; i != type_names.size(); ++i) {
- QString item = toqstr(type_names[i]);
- typeCO->addItem(item);
- if (item == current_text)
- current_type = i;
+ for (int i = 0; i != type_names.size(); ++i)
+ typeCO->addItem(type_names[i]);
+ if (!str.isEmpty())
+ typeCO->setCurrentIndex(selected_type);
+ else {
+ int const new_index = typeCO->findText(current_text);
+ if (new_index != -1)
+ typeCO->setCurrentIndex(new_index);
+ else
+ typeCO->setCurrentIndex(selected_type);
}
- if (current_type != -1)
- typeCO->setCurrentIndex(current_type);
- else
- typeCO->setCurrentIndex(form_->selectedType());
+
typeCO->blockSignals(false);
setTocModel(typeCO->currentIndex());
void TocWidget::setTocModel(size_t type)
{
bool controls_enabled = false;
- QStandardItemModel * toc_model = form_->tocModel(type);
+ QStandardItemModel * toc_model = models_.model(type);
if (toc_model) {
controls_enabled = toc_model->rowCount() > 0;
tocTV->setModel(toc_model);
tocTV->setEditTriggers(QAbstractItemView::NoEditTriggers);
+ LYXERR(Debug::GUI, "tocModel()->rowCount "
+ << toc_model->rowCount()
+ << "\nform_->tocModel()->columnCount "
+ << toc_model->columnCount());
}
enableControls(controls_enabled);
- reconnectSelectionModel();
-
if (controls_enabled) {
- depthSL->setMaximum(form_->getTocDepth(type));
+ depthSL->setMaximum(models_.depth(type));
depthSL->setValue(depth_);
}
- LYXERR(Debug::GUI) << "In TocWidget::updateGui()" << endl;
-
- select(form_->getCurrentIndex(typeCO->currentIndex()));
-
- if (toc_model) {
- LYXERR(Debug::GUI)
- << "form_->tocModel()->rowCount "
- << toc_model->rowCount()
- << "\nform_->tocModel()->columnCount "
- << toc_model->columnCount()
- << endl;
- }
-}
-
-
-void TocWidget::reconnectSelectionModel()
-{
- connect(tocTV->selectionModel(),
- SIGNAL(currentChanged(const QModelIndex &,
- const QModelIndex &)),
- this,
- SLOT(selectionChanged(const QModelIndex &,
- const QModelIndex &)));
-}
-
-void TocWidget::disconnectSelectionModel()
-{
- disconnect(tocTV->selectionModel(),
- SIGNAL(currentChanged(const QModelIndex &,
- const QModelIndex &)),
- this,
- SLOT(selectionChanged(const QModelIndex &,
- const QModelIndex &)));
+ // setTocModel produce QTreeView reset and setting depth again
+ // is needed. That must be done after all Qt updates are processed.
+ QTimer::singleShot(0, this, SLOT(updateView()));
}
} // namespace frontend