2 * \file QThesaurusDialog.C
3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
8 * Full author contact details are available in file CREDITS.
13 #include "QThesaurusDialog.h"
14 #include "QThesaurus.h"
15 #include "qt_helpers.h"
17 #include "controllers/ControlThesaurus.h"
19 #include <qpushbutton.h>
20 #include <qlistview.h>
21 #include <qlineedit.h>
29 QThesaurusDialog::QThesaurusDialog(QThesaurus * form)
30 : QThesaurusDialogBase(0, 0, false, 0),
33 // hide the pointless QHeader
34 QWidget * w = static_cast<QWidget*>(meaningsLV->child("list view header"));
38 connect(closePB, SIGNAL(clicked()),
39 form, SLOT(slotClose()));
43 void QThesaurusDialog::change_adaptor()
49 void QThesaurusDialog::closeEvent(QCloseEvent * e)
56 void QThesaurusDialog::entryChanged()
62 void QThesaurusDialog::replaceClicked()
68 void QThesaurusDialog::selectionChanged(QListViewItem * item)
70 if (form_->readOnly())
73 string const entry(fromqstr(item->text(0)));
74 replaceED->setText(toqstr(entry));
75 replacePB->setEnabled(true);
80 void QThesaurusDialog::selectionClicked(QListViewItem * item)
82 entryED->setText(item->text(0));
83 selectionChanged(item);
88 void QThesaurusDialog::updateLists()
92 std::vector<string> matches;
94 meaningsLV->setUpdatesEnabled(false);
96 Thesaurus::Meanings meanings = form_->controller().getMeanings(fromqstr(entryED->text()));
98 for (Thesaurus::Meanings::const_iterator cit = meanings.begin();
99 cit != meanings.end(); ++cit) {
100 QListViewItem * i = new QListViewItem(meaningsLV);
101 i->setText(0, toqstr(cit->first));
103 for (std::vector<string>::const_iterator cit2 = cit->second.begin();
104 cit2 != cit->second.end(); ++cit2) {
105 QListViewItem * i2 = new QListViewItem(i);
106 i2->setText(0, toqstr(*cit2));
111 meaningsLV->setUpdatesEnabled(true);
112 meaningsLV->update();
115 } // namespace frontend