mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 18:53:23 -03:00
Merge branch '201202_guiaddsuffix' of https://github.com/laanwj/bitcoin
This commit is contained in:
commit
f246fc648a
5 changed files with 80 additions and 17 deletions
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Add table
Reference in a new issue