3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
7 * \author Jürgen Spitzmüller
9 * Full author contact details are available in file CREDITS.
15 #include "QRefDialog.h"
17 #include "qt_helpers.h"
19 #include "controllers/ButtonController.h"
20 #include "controllers/ControlRef.h"
22 #include "insets/insetref.h"
26 #include <QListWidget>
27 #include <QListWidgetItem>
28 #include <QPushButton>
38 typedef QController<ControlRef, QView<QRefDialog> > base_class;
41 QRef::QRef(Dialog & parent)
42 : base_class(parent, _("Cross-reference")),
43 sort_(false), at_ref_(false)
48 void QRef::build_dialog()
50 dialog_.reset(new QRefDialog(this));
52 bcview().setOK(dialog_->okPB);
53 bcview().setApply(dialog_->applyPB);
54 bcview().setCancel(dialog_->closePB);
55 bcview().addReadOnly(dialog_->refsLW);
56 bcview().addReadOnly(dialog_->sortCB);
57 bcview().addReadOnly(dialog_->nameED);
58 bcview().addReadOnly(dialog_->referenceED);
59 bcview().addReadOnly(dialog_->typeCO);
60 bcview().addReadOnly(dialog_->bufferCO);
62 restored_buffer_ = -1;
66 void QRef::update_contents()
68 InsetCommandParams const & params = controller().params();
70 int orig_type = dialog_->typeCO->currentItem();
72 dialog_->referenceED->setText(toqstr(params.getContents()));
74 dialog_->nameED->setText(toqstr(params.getOptions()));
75 dialog_->nameED->setReadOnly(!nameAllowed() && !readOnly());
77 // restore type settings for new insets
78 if (params.getContents().empty())
79 dialog_->typeCO->setCurrentItem(orig_type);
81 dialog_->typeCO->setCurrentItem(InsetRef::getType(params.getCmdName()));
82 dialog_->typeCO->setEnabled(typeAllowed() && !readOnly());
84 dialog_->typeCO->setCurrentItem(0);
86 dialog_->sortCB->setChecked(sort_);
89 dialog_->bufferCO->clear();
90 vector<string> const buffers = controller().getBufferList();
91 for (vector<string>::const_iterator it = buffers.begin();
92 it != buffers.end(); ++it) {
93 dialog_->bufferCO->insertItem(toqstr(*it));
95 // restore the buffer combo setting for new insets
96 if (params.getContents().empty() && restored_buffer_ != -1
97 && restored_buffer_ < dialog_->bufferCO->count())
98 dialog_->bufferCO->setCurrentItem(restored_buffer_);
100 dialog_->bufferCO->setCurrentItem(controller().getBufferNum());
109 InsetCommandParams & params = controller().params();
111 params.setCmdName(InsetRef::getName(dialog_->typeCO->currentItem()));
112 params.setContents(fromqstr(dialog_->referenceED->text()));
113 params.setOptions(fromqstr(dialog_->nameED->text()));
115 restored_buffer_ = dialog_->bufferCO->currentItem();
119 bool QRef::nameAllowed()
121 Kernel::DocType const doc_type = kernel().docType();
122 return doc_type != Kernel::LATEX &&
123 doc_type != Kernel::LITERATE;
127 bool QRef::typeAllowed()
129 Kernel::DocType const doc_type = kernel().docType();
130 return doc_type != Kernel::LINUXDOC &&
131 doc_type != Kernel::DOCBOOK;
135 void QRef::setGoBack()
137 dialog_->gotoPB->setText(qt_("&Go Back"));
138 QToolTip::remove(dialog_->gotoPB);
139 QToolTip::add(dialog_->gotoPB, qt_("Jump back"));
143 void QRef::setGotoRef()
145 dialog_->gotoPB->setText(qt_("&Go to Label"));
146 QToolTip::remove(dialog_->gotoPB);
147 QToolTip::add(dialog_->gotoPB, qt_("Jump to label"));
153 string ref(fromqstr(dialog_->referenceED->text()));
158 controller().gotoBookmark();
162 controller().gotoRef(ref);
168 void QRef::redoRefs()
170 // Prevent these widgets from emitting any signals whilst
171 // we modify their state.
172 dialog_->refsLW->blockSignals(true);
173 dialog_->referenceED->blockSignals(true);
175 int lastref = dialog_->refsLW->currentRow();
177 dialog_->refsLW->setUpdatesEnabled(false);
178 dialog_->refsLW->clear();
180 // need this because Qt will send a highlight() here for
181 // the first item inserted
182 QString const tmp(dialog_->referenceED->text());
184 for (std::vector<string>::const_iterator iter = refs_.begin();
185 iter != refs_.end(); ++iter) {
186 dialog_->refsLW->addItem(toqstr(*iter));
190 dialog_->refsLW->sortItems();
192 dialog_->referenceED->setText(tmp);
194 // restore the last selection for new insets
195 if (tmp.isEmpty() && lastref != -1
196 && lastref < int(dialog_->refsLW->count())) {
197 dialog_->refsLW->setCurrentRow(lastref);
198 dialog_->refsLW->clearSelection();
200 for (unsigned int i = 0; i < dialog_->refsLW->count(); ++i) {
201 if (tmp == dialog_->refsLW->item(i)->text()) {
202 QListWidgetItem * const item = dialog_->refsLW->item(i);
203 dialog_->refsLW->setItemSelected(item, true);
208 dialog_->refsLW->setUpdatesEnabled(true);
209 dialog_->refsLW->update();
211 // Re-activate the emission of signals by these widgets.
212 dialog_->refsLW->blockSignals(false);
213 dialog_->referenceED->blockSignals(false);
217 void QRef::updateRefs()
222 string const name = controller().getBufferName(dialog_->bufferCO->currentItem());
223 refs_ = controller().getLabelList(name);
224 dialog_->sortCB->setEnabled(!refs_.empty());
225 dialog_->refsLW->setEnabled(!refs_.empty());
226 dialog_->gotoPB->setEnabled(!refs_.empty());
232 return !dialog_->referenceED->text().isEmpty();
235 } // namespace frontend