/**
* \file QCitationDialog.C
- * Copyright 2001 the LyX Team
- * Read the file COPYING
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * \author Kalle Dalheimer <kalle@klaralvdalens-datakonsult.se>
+ * \author Kalle Dalheimer
+ *
+ * Full author contact details are available in file CREDITS
*/
#include <config.h>
-
-#include "QCitationDialog.h"
-#include "Dialogs.h"
-#include "QCitation.h"
-#include "qt2BC.h"
+
+
+#include <algorithm>
+
+#include "qt_helpers.h"
#include "controllers/ControlCitation.h"
+#include "LyXView.h"
+#include "buffer.h"
#include <qcheckbox.h>
+#include <qcombobox.h>
#include <qlineedit.h>
#include <qlistbox.h>
#include <qmultilineedit.h>
#include <qpushbutton.h>
-
-#include "QtLyXView.h"
-#include <algorithm>
-#include "buffer.h"
+#include "QCitationDialog.h"
+#include "QCitation.h"
+#include "support/lstrings.h"
using std::vector;
using std::find;
using std::max;
-QCitationDialog::QCitationDialog(QCitation * form, QWidget * parent, const char * name, bool modal, WFlags fl)
- : QCitationDialogBase(parent, name, modal, fl),
+
+QCitationDialog::QCitationDialog(QCitation * form)
+ : QCitationDialogBase(0, 0, false, 0),
form_(form)
{
- connect(okPB, SIGNAL(clicked()),
- form, SLOT(slotOK()));
- connect(cancelPB, SIGNAL(clicked()),
- form, SLOT(slotCancel()));
connect(restorePB, SIGNAL(clicked()),
form, SLOT(slotRestore()));
+ connect(okPB, SIGNAL(clicked()),
+ form, SLOT(slotOK()));
connect(applyPB, SIGNAL(clicked()),
form, SLOT(slotApply()));
+ connect(closePB, SIGNAL(clicked()),
+ form, SLOT(slotClose()));
+ connect(searchED, SIGNAL(returnPressed()),
+ this, SLOT(slotNextClicked()));
+
+ textBeforeED->setText(qt_("Not yet supported"));
+ textBeforeED->setReadOnly(true);
+ textBeforeED->setFocusPolicy(QWidget::NoFocus);
+ citationStyleCO->setEnabled(false);
+ citationStyleCO->setFocusPolicy(QWidget::NoFocus);
}
-
+
QCitationDialog::~QCitationDialog()
{
}
-void QCitationDialog::slotBibSelected( int sel )
+void QCitationDialog::slotBibSelected(int sel)
+{
+ slotBibHighlighted(sel);
+
+ if (form_->readOnly())
+ return;
+
+ slotAddClicked();
+}
+
+
+void QCitationDialog::slotBibHighlighted(int sel)
{
biblio::InfoMap const & theMap = form_->controller().bibkeysInfo();
// the selected browser_bib key
infoML->clear();
- infoML->setText(biblio::getInfo(theMap, form_->bibkeys[sel]).c_str());
+ infoML->setText(toqstr(biblio::getInfo(theMap, form_->bibkeys[sel])));
// Highlight the selected browser_bib key in browser_cite if
// present
citeLB->setTopItem(n);
}
- if (!form_->controller().isReadonly()) {
+ if (!form_->readOnly()) {
if (cit != form_->citekeys.end()) {
form_->setBibButtons(QCitation::OFF);
form_->setCiteButtons(QCitation::ON);
}
-void QCitationDialog::slotCiteSelected(int sel)
+void QCitationDialog::slotCiteHighlighted(int sel)
{
biblio::InfoMap const & theMap = form_->controller().bibkeysInfo();
return;
}
- if (!form_->controller().isReadonly()) {
+ if (!form_->readOnly()) {
form_->setBibButtons(QCitation::OFF);
form_->setCiteButtons(QCitation::ON);
}
// Highlight the selected browser_cite key in browser_bib
vector<string>::const_iterator cit =
- std::find(form_->bibkeys.begin(),
+ std::find(form_->bibkeys.begin(),
form_->bibkeys.end(), form_->citekeys[sel]);
if (cit != form_->bibkeys.end()) {
// Put into browser_info the additional info associated
// with the selected browser_cite key
infoML->clear();
- infoML->setText(biblio::getInfo(theMap, form_->bibkeys[sel]).c_str());
+ infoML->setText(toqstr(biblio::getInfo(theMap, form_->citekeys[sel])));
}
}
}
// Add the selected browser_bib key to browser_cite
- citeLB->insertItem(form_->bibkeys[sel].c_str());
+ citeLB->insertItem(toqstr(form_->bibkeys[sel]));
form_->citekeys.push_back(form_->bibkeys[sel]);
int const n = int(form_->citekeys.size());
citeLB->setSelected(n - 1, true);
+ slotBibHighlighted(sel);
form_->setBibButtons(QCitation::OFF);
form_->setCiteButtons(QCitation::ON);
form_->changed();
+ form_->fillStyles();
}
{
int const sel = citeLB->currentItem();
- // FIXME: why ?
+ // FIXME: why ?
if (sel < 0 || sel >= (int)form_->citekeys.size()) {
return;
}
form_->setBibButtons(QCitation::ON);
form_->setCiteButtons(QCitation::OFF);
form_->changed();
+ form_->fillStyles();
+ form_->updateStyle();
}
citeLB->removeItem(sel);
form_->citekeys.erase(it);
- citeLB->insertItem(tmp.c_str(), sel - 1);
+ citeLB->insertItem(toqstr(tmp), sel - 1);
citeLB->setSelected(sel - 1, true);
form_->citekeys.insert(it - 1, tmp);
form_->setCiteButtons(QCitation::ON);
form_->changed();
+ form_->fillStyles();
}
{
int const sel = citeLB->currentItem();
- // FIXME: ?
+ // FIXME: ?
if (sel < 0 || sel >= (int)form_->citekeys.size() - 1) {
return;
}
citeLB->removeItem(sel);
form_->citekeys.erase(it);
- citeLB->insertItem(tmp.c_str(), sel + 1);
+ citeLB->insertItem(toqstr(tmp), sel + 1);
citeLB->setSelected(sel + 1, true);
form_->citekeys.insert(it + 1, tmp);
form_->setCiteButtons(QCitation::ON);
form_->changed();
+ form_->fillStyles();
}
}
-void QCitationDialog::doFind(biblio::Direction const dir)
+void QCitationDialog::changed_adaptor()
+{
+ form_->changed();
+}
+
+
+void QCitationDialog::doFind(biblio::Direction dir)
{
biblio::InfoMap const & theMap = form_->controller().bibkeysInfo();
- string const str = searchED->text().latin1();
+ string const str = fromqstr(searchED->text());
biblio::Search const type =
searchTypeCB->isChecked() ?
start -= 1;
bool const caseSensitive = searchCaseCB->isChecked();
-
- vector<string>::const_iterator const cit =
+
+ vector<string>::const_iterator cit =
biblio::searchKeys(theMap, form_->bibkeys, str,
- start, type, dir, caseSensitive);
+ start, type, dir, caseSensitive);
+ // not found. let's loop round
if (cit == form_->bibkeys.end()) {
- return;
+ if (dir == biblio::FORWARD) {
+ start = form_->bibkeys.begin();
+ }
+ else start = form_->bibkeys.end() - 1;
+
+ cit = biblio::searchKeys(theMap, form_->bibkeys, str,
+ start, type, dir, caseSensitive);
+
+ if (cit == form_->bibkeys.end())
+ return;
}
int const found = int(cit - form_->bibkeys.begin());
int const top = max(found - 5, 1);
bibLB->setTopItem(top);
bibLB->setSelected(found, true);
- slotBibSelected(0);
-}
-
-
-void QCitationDialog::slotCitationStyleSelected( int )
-{
- form_->changed();
-}
-
-
-void QCitationDialog::slotTextBeforeReturn()
-{
- form_->changed();
-}
-
-
-void QCitationDialog::slotTextAfterReturn()
-{
- form_->changed();
+ slotBibHighlighted(found);
}