*
* \author John Levon
*
- * Full author contact details are available in file CREDITS
+ * Full author contact details are available in file CREDITS.
*/
#include <config.h>
+#include "QBibtexDialog.h"
+#include "ui/QBibtexAddDialogBase.h"
+#include "QBibtex.h"
-#include "ControlBibtex.h"
+#include "checkedwidgets.h"
+#include "Qt2BC.h"
#include "qt_helpers.h"
-#include "debug.h"
+#include "validators.h"
+
+#include "controllers/ControlBibtex.h"
+#include "controllers/ButtonPolicies.h"
#include "support/filetools.h"
-#include "support/lyxalgo.h" // eliminate_duplicates
+#include "support/lstrings.h"
-#include <qwidget.h>
#include <qpushbutton.h>
#include <qcombobox.h>
#include <qlineedit.h>
#include <qlistbox.h>
-#include <qcheckbox.h>
-#include <qfiledialog.h>
-#include "ui/QBibtexAddDialogBase.h"
-#include "QBibtexDialog.h"
-#include "QBibtex.h"
+using lyx::support::changeExtension;
+using lyx::support::trim;
-#include <vector>
+using std::string;
+namespace lyx {
+namespace frontend {
QBibtexDialog::QBibtexDialog(QBibtex * form)
: QBibtexDialogBase(0, 0, false, 0),
form, SLOT(slotClose()));
add_ = new QBibtexAddDialogBase(this, "", true);
- connect(add_->addPB, SIGNAL(clicked()), this, SLOT(addDatabase()));
- connect(add_->addPB, SIGNAL(clicked()), this, SLOT(addDatabase()));
- connect(add_->bibLB, SIGNAL(selected(QListBoxItem *)), this, SLOT(addDatabase()));
- connect(add_->bibLB, SIGNAL(selected(QListBoxItem *)), add_, SLOT(accept()));
- connect(add_->bibLB, SIGNAL(currentChanged(QListBoxItem *)), this, SLOT(availableChanged()));
- connect(add_->browsePB, SIGNAL(clicked()), this, SLOT(browseBibPressed()));
+ Qt2BC * bcview = new Qt2BC(add_bc_);
+ add_bc_.view(bcview);
+ add_bc_.bp(new OkCancelPolicy);
+
+ bcview->setOK(add_->addPB);
+ bcview->setCancel(add_->closePB);
+
+ add_->bibED->setValidator(new PathValidator(false, add_->bibED));
+ addCheckedLineEdit(add_bc_.view(), add_->bibED, 0);
+
+ connect(add_->bibED, SIGNAL(textChanged(const QString&)),
+ this, SLOT(bibEDChanged()));
+ connect(add_->addPB, SIGNAL(clicked()),
+ this, SLOT(addDatabase()));
+ connect(add_->bibLB, SIGNAL(selected(QListBoxItem *)),
+ this, SLOT(addDatabase()));
+ connect(add_->bibLB, SIGNAL(selected(QListBoxItem *)),
+ add_, SLOT(accept()));
+ connect(add_->bibLB, SIGNAL(currentChanged(QListBoxItem *)),
+ this, SLOT(availableChanged()));
+ connect(add_->browsePB, SIGNAL(clicked()),
+ this, SLOT(browseBibPressed()));
+}
+
+
+QBibtexDialog::~QBibtexDialog()
+{}
+
+
+void QBibtexDialog::bibEDChanged()
+{
+ // Indicate to the button controller that the contents have
+ // changed. The actual test of validity is carried out by
+ // the checkedLineEdit.
+ add_bc_.valid(true);
}
void QBibtexDialog::browsePressed()
{
- QString const file =
- QFileDialog::getOpenFileName(QString::null,
- qt_("BibTeX style files (*.bst)"),
- this,
- 0,
- qt_("Select a BibTeX style"));
- if (!file.isNull()) {
- string const filen = ChangeExtension(fromqstr(file), "");
+ string const file = form_->controller().browseBst("");
+
+ if (!file.empty()) {
+ string const filen = changeExtension(file, "");
bool present = false;
unsigned int pres = 0;
void QBibtexDialog::browseBibPressed()
{
- QString const file = QFileDialog::getOpenFileName(QString::null,
- qt_("BibTeX database files (*.bib)"), add_, 0, qt_("Select a BibTeX database to add"));
+ string const file = trim(form_->controller().browseBib(""));
- if (!file.isNull()) {
- string const f = ChangeExtension(fromqstr(file), "");
+ if (!file.empty()) {
+ string const f = changeExtension(file, "");
bool present = false;
for (unsigned int i = 0; i != add_->bibLB->count(); i++) {
}
}
+
void QBibtexDialog::addPressed()
{
add_->exec();
+ add_bc_.valid(false);
}
void QBibtexDialog::addDatabase()
{
- QString const file = add_->bibED->text();
-
- if (!file.isNull()) {
- string const f = ChangeExtension(fromqstr(file), "");
- bool present = false;
- for (unsigned int i = 0; i != databaseLB->count(); ++i) {
- if (fromqstr(databaseLB->text(i)) == f)
- present = true;
-
- }
- if (!present) {
- databaseLB->insertItem(f.c_str());
- form_->changed();
+ int const sel = add_->bibLB->currentItem();
+ string const file = trim(fromqstr(add_->bibED->text()));
+
+ if (sel < 0 && file.empty())
+ return;
+
+ // 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));
}
}
+
+ if (!file.empty()) {
+ QString const f = toqstr(changeExtension(file, ""));
+ if ((databaseLB->findItem(f)) == 0)
+ databaseLB->insertItem(f);
+ }
+
+ form_->changed();
}
void QBibtexDialog::availableChanged()
{
- add_->bibED->setText(add_->bibLB->currentText());
+ form_->changed();
}
form_->slotWMHide();
e->accept();
}
+
+} // namespace frontend
+} // namespace lyx