#include "controllers/ControlBibtex.h"
#include "controllers/ButtonPolicies.h"
+#include "debug.h"
#include "support/filetools.h"
#include "support/lstrings.h"
-#include <qpushbutton.h>
-#include <qlineedit.h>
-#include <q3listbox.h>
+#include <QPushButton>
+#include <QListWidget>
+#include <QLineEdit>
using lyx::support::changeExtension;
using lyx::support::trim;
: form_(form)
{
setupUi(this);
+ QDialog::setModal(true);
connect(okPB, SIGNAL(clicked()),
form, SLOT(slotOK()));
connect(closePB, SIGNAL(clicked()),
form, SLOT(slotClose()));
-
- connect( stylePB, SIGNAL( clicked() ), this, SLOT( browsePressed() ) );
- connect( deletePB, SIGNAL( clicked() ), this, SLOT( deletePressed() ) );
- connect( styleCB, SIGNAL( textChanged(const QString&) ), this, SLOT( change_adaptor() ) );
- connect( databaseLB, SIGNAL( selectionChanged() ), this, SLOT( databaseChanged() ) );
- connect( bibtocCB, SIGNAL( toggled(bool) ), this, SLOT( change_adaptor() ) );
- connect( btPrintCO, SIGNAL( activated(int) ), this, SLOT( change_adaptor() ) );
- connect( addBibPB, SIGNAL( clicked() ), this, SLOT( addPressed() ) );
+ connect(stylePB, SIGNAL( clicked() ),
+ this, SLOT( browsePressed() ) );
+ connect(deletePB, SIGNAL( clicked() ),
+ this, SLOT( deletePressed() ) );
+ connect(styleCB, SIGNAL( textChanged(const QString&) ),
+ this, SLOT( change_adaptor() ) );
+ connect(databaseLW, SIGNAL( selectionChanged() ),
+ this, SLOT( databaseChanged() ) );
+ connect(bibtocCB, SIGNAL( toggled(bool) ),
+ this, SLOT( change_adaptor() ) );
+ connect(btPrintCO, SIGNAL( activated(int) ),
+ this, SLOT( change_adaptor() ) );
+ connect(addBibPB, SIGNAL( clicked() ),
+ this, SLOT( addPressed() ) );
add_ = new UiDialog<Ui::QBibtexAddUi>(this, true);
this, SLOT(bibEDChanged()));
connect(add_->addPB, SIGNAL(clicked()),
this, SLOT(addDatabase()));
- connect(add_->bibLB, SIGNAL(selected(Q3ListBoxItem *)),
+ connect(add_->addPB, SIGNAL(clicked()),
+ add_, SLOT(accept()) );
+ connect(add_->bibLW, SIGNAL(itemActivated(QListWidgetItem *)),
this, SLOT(addDatabase()));
- connect(add_->bibLB, SIGNAL(selected(Q3ListBoxItem *)),
+ connect(add_->bibLW, SIGNAL(itemActivated(QListWidgetItem *)),
add_, SLOT(accept()));
- connect(add_->bibLB, SIGNAL(currentChanged(Q3ListBoxItem *)),
+ connect(add_->bibLW, SIGNAL(itemChanged(QListWidgetItem *)),
this, SLOT(availableChanged()));
connect(add_->browsePB, SIGNAL(clicked()),
this, SLOT(browseBibPressed()));
-
- connect( add_->addPB, SIGNAL( clicked() ), this, SLOT( accept() ) );
- connect( add_->closePB, SIGNAL( clicked() ), this, SLOT( reject() ) );
+ connect(add_->closePB, SIGNAL( clicked() ),
+ add_, SLOT( reject() ) );
}
unsigned int pres = 0;
for (int i = 0; i != styleCB->count(); ++i) {
- if (fromqstr(styleCB->text(i)) == filen) {
+ if (fromqstr(styleCB->itemText(i)) == filen) {
present = true;
pres = i;
}
}
if (!present)
- styleCB->insertItem(toqstr(filen),0);
+ styleCB->insertItem(0, toqstr(filen));
- styleCB->setCurrentItem(pres);
+ styleCB->setCurrentIndex(pres);
form_->changed();
}
}
string const file = trim(form_->controller().browseBib(""));
if (!file.empty()) {
- string const f = changeExtension(file, "");
+ QString const f = toqstr(changeExtension(file, ""));
bool present = false;
- for (unsigned int i = 0; i != add_->bibLB->count(); i++) {
- if (fromqstr(add_->bibLB->text(i)) == f)
+ for (int i = 0; i < add_->bibLW->count(); ++i) {
+ if (add_->bibLW->item(i)->text() == f)
present = true;
}
if (!present) {
- add_->bibLB->insertItem(toqstr(f));
+ add_->bibLW->addItem(f);
form_->changed();
}
- add_->bibED->setText(toqstr(f));
+ add_->bibED->setText(f);
}
}
void QBibtexDialog::addDatabase()
{
- int const sel = add_->bibLB->currentItem();
+ int const sel = add_->bibLW->currentRow();
string const file = trim(fromqstr(add_->bibED->text()));
if (sel < 0 && file.empty())
// Add the selected browser_bib keys to browser_database
// multiple selections are possible
- for (unsigned int i = 0; i != add_->bibLB->count(); i++) {
- if (add_->bibLB->isSelected(i)) {
- // do not allow duplicates
- if ((databaseLB->findItem(add_->bibLB->text(i))) == 0)
- databaseLB->insertItem(add_->bibLB->text(i));
+ for (int i = 0; i != add_->bibLW->count(); ++i) {
+ QListWidgetItem * const item = add_->bibLW->item(i);
+ if (add_->bibLW->isItemSelected(item)) {
+ add_->bibLW->setItemSelected(item, false);
+ QList<QListWidgetItem *> matches =
+ databaseLW->findItems(item->text(), Qt::MatchExactly);
+ if (matches.empty())
+ databaseLW->addItem(item->text());
}
}
if (!file.empty()) {
+ add_->bibED->clear();
QString const f = toqstr(changeExtension(file, ""));
- if ((databaseLB->findItem(f)) == 0)
- databaseLB->insertItem(f);
+ QList<QListWidgetItem *> matches =
+ databaseLW->findItems(f, Qt::MatchExactly);
+ if (matches.empty())
+ databaseLW->addItem(f);
}
form_->changed();
void QBibtexDialog::deletePressed()
{
- databaseLB->removeItem(databaseLB->currentItem());
+ databaseLW->takeItem(databaseLW->currentRow());
}
void QBibtexDialog::databaseChanged()
{
- deletePB->setEnabled(!form_->readOnly() && databaseLB->currentItem() != -1);
+ deletePB->setEnabled(!form_->readOnly() && databaseLW->currentRow() != -1);
}
e->accept();
}
+
} // namespace frontend
} // namespace lyx
+
+#include "QBibtexDialog_moc.cpp"