Merge branch '201202_guiaddsuffix' of https://github.com/laanwj/bitcoin

This commit is contained in:
Gavin Andresen 2012-02-22 10:41:11 -05:00
commit f246fc648a
5 changed files with 80 additions and 17 deletions

View File

@ -9,7 +9,6 @@
#include <QSortFilterProxyModel> #include <QSortFilterProxyModel>
#include <QClipboard> #include <QClipboard>
#include <QFileDialog>
#include <QMessageBox> #include <QMessageBox>
#include <QMenu> #include <QMenu>
@ -277,10 +276,9 @@ void AddressBookPage::done(int retval)
void AddressBookPage::exportClicked() void AddressBookPage::exportClicked()
{ {
// CSV is currently the only supported format // CSV is currently the only supported format
QString filename = QFileDialog::getSaveFileName( QString filename = GUIUtil::getSaveFileName(
this, this,
tr("Export Address Book Data"), tr("Export Address Book Data"), QString(),
QDir::currentPath(),
tr("Comma separated file (*.csv)")); tr("Comma separated file (*.csv)"));
if (filename.isNull()) return; if (filename.isNull()) return;

View File

@ -15,6 +15,8 @@
#include <QAbstractItemView> #include <QAbstractItemView>
#include <QApplication> #include <QApplication>
#include <QClipboard> #include <QClipboard>
#include <QFileDialog>
#include <QDesktopServices>
QString GUIUtil::dateTimeStr(qint64 nTime) QString GUIUtil::dateTimeStr(qint64 nTime)
{ {
@ -135,3 +137,50 @@ void GUIUtil::copyEntryData(QAbstractItemView *view, int column, int role)
QApplication::clipboard()->setText(selection.at(0).data(role).toString()); QApplication::clipboard()->setText(selection.at(0).data(role).toString());
} }
} }
QString GUIUtil::getSaveFileName(QWidget *parent, const QString &caption,
const QString &dir,
const QString &filter,
QString *selectedSuffixOut)
{
QString selectedFilter;
QString myDir;
if(dir.isEmpty()) // Default to user documents location
{
myDir = QDesktopServices::storageLocation(QDesktopServices::DocumentsLocation);
}
else
{
myDir = dir;
}
QString result = QFileDialog::getSaveFileName(parent, caption, myDir, filter, &selectedFilter);
/* Extract first suffix from filter pattern "Description (*.foo)" or "Description (*.foo *.bar ...) */
QRegExp filter_re(".* \\(\\*\\.(.*)[ \\)]");
QString selectedSuffix;
if(filter_re.exactMatch(selectedFilter))
{
selectedSuffix = filter_re.cap(1);
}
/* Add suffix if needed */
QFileInfo info(result);
if(!result.isEmpty())
{
if(info.suffix().isEmpty() && !selectedSuffix.isEmpty())
{
/* No suffix specified, add selected suffix */
if(!result.endsWith("."))
result.append(".");
result.append(selectedSuffix);
}
}
/* Return selected suffix if asked to */
if(selectedSuffixOut)
{
*selectedSuffixOut = selectedSuffix;
}
return result;
}

View File

@ -46,6 +46,20 @@ public:
*/ */
static void copyEntryData(QAbstractItemView *view, int column, int role=Qt::EditRole); static void copyEntryData(QAbstractItemView *view, int column, int role=Qt::EditRole);
/** Get save file name, mimics QFileDialog::getSaveFileName, except that it appends a default suffix
when no suffix is provided by the user.
@param[in] parent Parent window (or 0)
@param[in] caption Window caption (or empty, for default)
@param[in] dir Starting directory (or empty, to default to documents directory)
@param[in] filter Filter specification such as "Comma Separated Files (*.csv)"
@param[out] selectedSuffixOut Pointer to return the suffix (file type) that was selected (or 0).
Can be useful when choosing the save file format based on suffix.
*/
static QString getSaveFileName(QWidget *parent=0, const QString &caption=QString(),
const QString &dir=QString(), const QString &filter=QString(),
QString *selectedSuffixOut=0);
}; };
#endif // GUIUTIL_H #endif // GUIUTIL_H

View File

@ -1,9 +1,9 @@
#include "qrcodedialog.h" #include "qrcodedialog.h"
#include "ui_qrcodedialog.h" #include "ui_qrcodedialog.h"
#include "guiutil.h"
#include <QPixmap> #include <QPixmap>
#include <QUrl> #include <QUrl>
#include <QFileDialog>
#include <QDesktopServices>
#include <QDebug> #include <QDebug>
#include <qrencode.h> #include <qrencode.h>
@ -34,8 +34,8 @@ QRCodeDialog::~QRCodeDialog()
delete ui; delete ui;
} }
void QRCodeDialog::genCode() { void QRCodeDialog::genCode()
{
QString uri = getURI(); QString uri = getURI();
//qDebug() << "Encoding:" << uri.toUtf8().constData(); //qDebug() << "Encoding:" << uri.toUtf8().constData();
QRcode *code = QRcode_encodeString(uri.toUtf8().constData(), 0, QR_ECLEVEL_L, QR_MODE_8, 1); QRcode *code = QRcode_encodeString(uri.toUtf8().constData(), 0, QR_ECLEVEL_L, QR_MODE_8, 1);
@ -52,7 +52,8 @@ void QRCodeDialog::genCode() {
ui->lblQRCode->setPixmap(QPixmap::fromImage(myImage).scaled(300, 300)); ui->lblQRCode->setPixmap(QPixmap::fromImage(myImage).scaled(300, 300));
} }
QString QRCodeDialog::getURI() { QString QRCodeDialog::getURI()
{
QString ret = QString("bitcoin:%1").arg(address); QString ret = QString("bitcoin:%1").arg(address);
int paramCount = 0; int paramCount = 0;
@ -80,21 +81,24 @@ QString QRCodeDialog::getURI() {
return ret; return ret;
} }
void QRCodeDialog::on_lnReqAmount_textChanged(const QString &) { void QRCodeDialog::on_lnReqAmount_textChanged(const QString &)
{
genCode(); genCode();
} }
void QRCodeDialog::on_lnLabel_textChanged(const QString &) { void QRCodeDialog::on_lnLabel_textChanged(const QString &)
{
genCode(); genCode();
} }
void QRCodeDialog::on_lnMessage_textChanged(const QString &) { void QRCodeDialog::on_lnMessage_textChanged(const QString &)
{
genCode(); genCode();
} }
void QRCodeDialog::on_btnSaveAs_clicked() void QRCodeDialog::on_btnSaveAs_clicked()
{ {
QString fn = QFileDialog::getSaveFileName(this, "Save Image...", QDesktopServices::storageLocation(QDesktopServices::DocumentsLocation), "Images (*.png)"); QString fn = GUIUtil::getSaveFileName(this, tr("Save Image..."), QString(), tr("PNG Images (*.png)"));
if(!fn.isEmpty()) { if(!fn.isEmpty()) {
myImage.scaled(EXPORT_IMAGE_SIZE, EXPORT_IMAGE_SIZE).save(fn); myImage.scaled(EXPORT_IMAGE_SIZE, EXPORT_IMAGE_SIZE).save(fn);
} }

View File

@ -21,7 +21,6 @@
#include <QTableView> #include <QTableView>
#include <QHeaderView> #include <QHeaderView>
#include <QPushButton> #include <QPushButton>
#include <QFileDialog>
#include <QMessageBox> #include <QMessageBox>
#include <QPoint> #include <QPoint>
#include <QMenu> #include <QMenu>
@ -264,10 +263,9 @@ void TransactionView::changedAmount(const QString &amount)
void TransactionView::exportClicked() void TransactionView::exportClicked()
{ {
// CSV is currently the only supported format // CSV is currently the only supported format
QString filename = QFileDialog::getSaveFileName( QString filename = GUIUtil::getSaveFileName(
this, this,
tr("Export Transaction Data"), tr("Export Transaction Data"), QString(),
QDir::currentPath(),
tr("Comma separated file (*.csv)")); tr("Comma separated file (*.csv)"));
if (filename.isNull()) return; if (filename.isNull()) return;