mirror of
https://github.com/dashpay/dash.git
synced 2024-12-30 14:25:53 +01:00
4cb2af80b1
* qt: Make sure font size in MasternodeList gets scaled as expected * qt: Make sure font size in ShutdownWindow gets scaled as expected * qt: Drop obsolete application font updates * qt: Scale QMenu and QMessageBox globally To make sure non-custom context menus + QMessageBox instances createy by static calls like QMessageBox::critical are scaled also. * qt: Avoid redundant scaling for tooltips and menus * qt: Only update widget's font if required * qt: Merge GUIUtil::mapFontSizeUpdates into GUIUtil::mapNormalFontUpdates * qt: Remove obsolete setFixedPitchFont call * qt: Use setFixedPitchFont in SendCoinsEntry * qt: Scale font size in increments of 0.25 * qt: Properly scale network traffic stats depending on font metrics * qt: Update min/max width of OptionsDialog depending on buttons width * qt: Emit a signal whenever any attribute of AppearanceWidget changed * qt: Update OptionsDialog width if the appearance changed * qt: Calculate the initial wide right after the window showed up Make sure the visibility state of the widgets is correct before width calculations. * qt: Call parent class showEvent + override it explicit Co-authored-by: UdjinM6 <UdjinM6@users.noreply.github.com> * qt: Let OptionsDialog emit a signal if appearance gets changed * qt: Resize main toolbar depending on visible buttons / font attributes * qt: Reset max width after it has been set to still allow window resizing * qt: Properly update the weight of widgets with default font attributes * qt: Handle updates to the font attributes * qt: Use resize() instead of setMaximumWidth() Co-authored-by: UdjinM6 <UdjinM6@users.noreply.github.com> * qt: Call GUIUtil::updateFonts in ModalOverlay constructor * qt: Make sure default fonts are stored properly for the related widget * qt: Ignore some low level classes in GUIUtil::updateFont * rpc: Remove obsolete `.arg()` call * qt: Drop fixedPitchFont * qt: Avoid redundant font updates. Let GUIUtil::updateFont handle them * qt: Scale recent transactions on OverviewPage They were scaled by font inheritance before * qt: Ignore QListView in GUIUtil::updateFonts Co-authored-by: UdjinM6 <UdjinM6@users.noreply.github.com>
223 lines
7.3 KiB
C++
223 lines
7.3 KiB
C++
// Copyright (c) 2011-2015 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#include <qt/receiverequestdialog.h>
|
|
#include <qt/forms/ui_receiverequestdialog.h>
|
|
|
|
#include <qt/bitcoinunits.h>
|
|
#include <qt/guiconstants.h>
|
|
#include <qt/guiutil.h>
|
|
#include <qt/optionsmodel.h>
|
|
|
|
#include <QClipboard>
|
|
#include <QDrag>
|
|
#include <QMenu>
|
|
#include <QMimeData>
|
|
#include <QMouseEvent>
|
|
#include <QPixmap>
|
|
|
|
#if defined(HAVE_CONFIG_H)
|
|
#include <config/dash-config.h> /* for USE_QRCODE */
|
|
#endif
|
|
|
|
#ifdef USE_QRCODE
|
|
#include <qrencode.h>
|
|
#endif
|
|
|
|
QRImageWidget::QRImageWidget(QWidget *parent):
|
|
QLabel(parent), contextMenu(0)
|
|
{
|
|
contextMenu = new QMenu(this);
|
|
QAction *saveImageAction = new QAction(tr("&Save Image..."), this);
|
|
connect(saveImageAction, SIGNAL(triggered()), this, SLOT(saveImage()));
|
|
contextMenu->addAction(saveImageAction);
|
|
QAction *copyImageAction = new QAction(tr("&Copy Image"), this);
|
|
connect(copyImageAction, SIGNAL(triggered()), this, SLOT(copyImage()));
|
|
contextMenu->addAction(copyImageAction);
|
|
}
|
|
|
|
QImage QRImageWidget::exportImage()
|
|
{
|
|
if(!pixmap())
|
|
return QImage();
|
|
return pixmap()->toImage();
|
|
}
|
|
|
|
void QRImageWidget::mousePressEvent(QMouseEvent *event)
|
|
{
|
|
if(event->button() == Qt::LeftButton && pixmap())
|
|
{
|
|
event->accept();
|
|
QMimeData *mimeData = new QMimeData;
|
|
mimeData->setImageData(exportImage());
|
|
|
|
QDrag *drag = new QDrag(this);
|
|
drag->setMimeData(mimeData);
|
|
drag->exec();
|
|
} else {
|
|
QLabel::mousePressEvent(event);
|
|
}
|
|
}
|
|
|
|
void QRImageWidget::saveImage()
|
|
{
|
|
if(!pixmap())
|
|
return;
|
|
QString fn = GUIUtil::getSaveFileName(this, tr("Save QR Code"), QString(), tr("PNG Image (*.png)"), nullptr);
|
|
if (!fn.isEmpty())
|
|
{
|
|
exportImage().save(fn);
|
|
}
|
|
}
|
|
|
|
void QRImageWidget::copyImage()
|
|
{
|
|
if(!pixmap())
|
|
return;
|
|
QApplication::clipboard()->setImage(exportImage());
|
|
}
|
|
|
|
void QRImageWidget::contextMenuEvent(QContextMenuEvent *event)
|
|
{
|
|
if(!pixmap())
|
|
return;
|
|
contextMenu->exec(event->globalPos());
|
|
}
|
|
|
|
ReceiveRequestDialog::ReceiveRequestDialog(QWidget *parent) :
|
|
QDialog(parent),
|
|
ui(new Ui::ReceiveRequestDialog),
|
|
model(0)
|
|
{
|
|
ui->setupUi(this);
|
|
|
|
GUIUtil::updateFonts();
|
|
|
|
#ifndef USE_QRCODE
|
|
ui->btnSaveAs->setVisible(false);
|
|
ui->lblQRCode->setVisible(false);
|
|
#endif
|
|
|
|
connect(ui->btnSaveAs, SIGNAL(clicked()), ui->lblQRCode, SLOT(saveImage()));
|
|
}
|
|
|
|
ReceiveRequestDialog::~ReceiveRequestDialog()
|
|
{
|
|
delete ui;
|
|
}
|
|
|
|
void ReceiveRequestDialog::setModel(WalletModel *_model)
|
|
{
|
|
this->model = _model;
|
|
|
|
if (_model)
|
|
connect(_model->getOptionsModel(), SIGNAL(displayUnitChanged(int)), this, SLOT(update()));
|
|
|
|
// update the display unit if necessary
|
|
update();
|
|
}
|
|
|
|
void ReceiveRequestDialog::setInfo(const SendCoinsRecipient &_info)
|
|
{
|
|
this->info = _info;
|
|
update();
|
|
}
|
|
|
|
void ReceiveRequestDialog::update()
|
|
{
|
|
if(!model)
|
|
return;
|
|
QString target = info.label;
|
|
if(target.isEmpty())
|
|
target = info.address;
|
|
setWindowTitle(tr("Request payment to %1").arg(target));
|
|
|
|
QString uri = GUIUtil::formatBitcoinURI(info);
|
|
ui->btnSaveAs->setEnabled(false);
|
|
QString html;
|
|
html += "<html>";
|
|
html += "<b>" + tr("Payment information") + "</b><br><br>";
|
|
html += "<b>"+tr("URI")+"</b>: ";
|
|
html += QString("<a style=\"%1\"href=\"").arg(GUIUtil::getThemedStyleQString(GUIUtil::ThemedStyle::TS_COMMAND)) +
|
|
uri + "\">" + GUIUtil::HtmlEscape(uri) + "</a><br>";
|
|
html += "<b>"+tr("Address")+"</b>: " + GUIUtil::HtmlEscape(info.address) + "<br>";
|
|
if(info.amount)
|
|
html += "<b>"+tr("Amount")+"</b>: " + BitcoinUnits::formatHtmlWithUnit(model->getOptionsModel()->getDisplayUnit(), info.amount) + "<br>";
|
|
if(!info.label.isEmpty())
|
|
html += "<b>"+tr("Label")+"</b>: " + GUIUtil::HtmlEscape(info.label) + "<br>";
|
|
if(!info.message.isEmpty())
|
|
html += "<b>"+tr("Message")+"</b>: " + GUIUtil::HtmlEscape(info.message) + "<br>";
|
|
if(model->isMultiwallet()) {
|
|
html += "<b>"+tr("Wallet")+"</b>: " + GUIUtil::HtmlEscape(model->getWalletName()) + "<br>";
|
|
}
|
|
ui->outUri->setText(html);
|
|
|
|
#ifdef USE_QRCODE
|
|
ui->lblQRCode->setText("");
|
|
if(!uri.isEmpty())
|
|
{
|
|
// limit URI length
|
|
if (uri.length() > MAX_URI_LENGTH)
|
|
{
|
|
ui->lblQRCode->setText(tr("Resulting URI too long, try to reduce the text for label / message."));
|
|
} else {
|
|
QRcode *code = QRcode_encodeString(uri.toUtf8().constData(), 0, QR_ECLEVEL_L, QR_MODE_8, 1);
|
|
if (!code)
|
|
{
|
|
ui->lblQRCode->setText(tr("Error encoding URI into QR Code."));
|
|
return;
|
|
}
|
|
QImage qrImage = QImage(code->width + 6, code->width + 6, QImage::Format_RGB32);
|
|
qrImage.fill(GUIUtil::getThemedQColor(GUIUtil::ThemedColor::BACKGROUND_WIDGET));
|
|
unsigned char *p = code->data;
|
|
for (int y = 0; y < code->width; y++)
|
|
{
|
|
for (int x = 0; x < code->width; x++)
|
|
{
|
|
qrImage.setPixel(x + 3, y + 3, ((*p & 1) ? GUIUtil::getThemedQColor(GUIUtil::ThemedColor::QR_PIXEL).rgb() : GUIUtil::getThemedQColor(GUIUtil::ThemedColor::BACKGROUND_WIDGET).rgb()));
|
|
p++;
|
|
}
|
|
}
|
|
QRcode_free(code);
|
|
// Create the image with respect to the device pixel ratio
|
|
int qrAddrImageWidth = QR_IMAGE_SIZE;
|
|
int qrAddrImageHeight = QR_IMAGE_SIZE + 20;
|
|
qreal scale = qApp->devicePixelRatio();
|
|
QImage qrAddrImage = QImage(qrAddrImageWidth * scale, qrAddrImageHeight * scale, QImage::Format_RGB32);
|
|
qrAddrImage.setDevicePixelRatio(scale);
|
|
QPainter painter(&qrAddrImage);
|
|
// Fill the whole image with border color
|
|
qrAddrImage.fill(GUIUtil::getThemedQColor(GUIUtil::ThemedColor::BORDER_WIDGET));
|
|
// Create a 2px/2px smaller rect and fill it with background color to keep the 1px border with the border color
|
|
QRect paddedRect = QRect(1, 1, qrAddrImageWidth - 2, qrAddrImageHeight - 2);
|
|
painter.fillRect(paddedRect, GUIUtil::getThemedQColor(GUIUtil::ThemedColor::BACKGROUND_WIDGET));
|
|
painter.drawImage(2, 2, qrImage.scaled(QR_IMAGE_SIZE - 4, QR_IMAGE_SIZE - 4));
|
|
// calculate ideal font size
|
|
QFont font = GUIUtil::getFontNormal();
|
|
qreal font_size = GUIUtil::calculateIdealFontSize((paddedRect.width() - 20), info.address, font);
|
|
font.setPointSizeF(font_size);
|
|
// paint the address
|
|
painter.setFont(font);
|
|
painter.setPen(GUIUtil::getThemedQColor(GUIUtil::ThemedColor::QR_PIXEL));
|
|
paddedRect.setHeight(QR_IMAGE_SIZE + 3);
|
|
painter.drawText(paddedRect, Qt::AlignBottom|Qt::AlignCenter, info.address);
|
|
painter.end();
|
|
|
|
ui->lblQRCode->setPixmap(QPixmap::fromImage(qrAddrImage));
|
|
ui->btnSaveAs->setEnabled(true);
|
|
}
|
|
}
|
|
#endif
|
|
}
|
|
|
|
void ReceiveRequestDialog::on_btnCopyURI_clicked()
|
|
{
|
|
GUIUtil::setClipboard(GUIUtil::formatBitcoinURI(info));
|
|
}
|
|
|
|
void ReceiveRequestDialog::on_btnCopyAddress_clicked()
|
|
{
|
|
GUIUtil::setClipboard(info.address);
|
|
}
|