mirror of
https://invent.kde.org/network/falkon.git
synced 2024-11-13 18:42:11 +01:00
cf5d399f00
- created new IconChooser class with option to choose icon from file or icon from database Closes #401
131 lines
3.6 KiB
C++
131 lines
3.6 KiB
C++
/* ============================================================
|
||
* QupZilla - WebKit based browser
|
||
* Copyright (C) 2010-2012 David Rosca <nowrep@gmail.com>
|
||
*
|
||
* This program is free software: you can redistribute it and/or modify
|
||
* it under the terms of the GNU General Public License as published by
|
||
* the Free Software Foundation, either version 3 of the License, or
|
||
* (at your option) any later version.
|
||
*
|
||
* This program is distributed in the hope that it will be useful,
|
||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
* GNU General Public License for more details.
|
||
*
|
||
* You should have received a copy of the GNU General Public License
|
||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
* ============================================================ */
|
||
#include "iconchooser.h"
|
||
#include "ui_iconchooser.h"
|
||
|
||
#include <QFileDialog>
|
||
#include <QSqlQuery>
|
||
|
||
IconChooser::IconChooser(QWidget* parent)
|
||
: QDialog(parent),
|
||
ui(new Ui::IconChooser)
|
||
{
|
||
ui->setupUi(this);
|
||
|
||
ui->iconList->setItemDelegate(new IconChooserDelegate(ui->iconList));
|
||
|
||
connect(ui->chooseFile, SIGNAL(clicked()), this, SLOT(chooseFile()));
|
||
connect(ui->siteUrl, SIGNAL(textChanged(QString)), this, SLOT(searchIcon(QString)));
|
||
}
|
||
|
||
void IconChooser::chooseFile()
|
||
{
|
||
const QString &fileTypes = QString("%3(*.png *.jpg *.jpeg *.gif)").arg(tr("Image files"));
|
||
const QString &path = QFileDialog::getOpenFileName(this, tr("Choose icon..."), QDir::homePath(), fileTypes);
|
||
|
||
if (path.isEmpty()) {
|
||
return;
|
||
}
|
||
|
||
ui->iconList->clear();
|
||
QIcon icon(path);
|
||
|
||
if (!icon.isNull()) {
|
||
QListWidgetItem* item = new QListWidgetItem(ui->iconList);
|
||
item->setIcon(icon);
|
||
|
||
ui->iconList->setCurrentItem(item);
|
||
}
|
||
}
|
||
|
||
void IconChooser::searchIcon(const QString &string)
|
||
{
|
||
if (string.size() < 4) {
|
||
return;
|
||
}
|
||
|
||
ui->iconList->clear();
|
||
|
||
QSqlQuery query;
|
||
query.prepare("SELECT icon FROM icons WHERE url LIKE ? LIMIT 20");
|
||
query.bindValue(0, QString("%%1%").arg(string));
|
||
query.exec();
|
||
|
||
while (query.next()) {
|
||
QImage image = QImage::fromData(query.value(0).toByteArray());
|
||
if (!image.isNull()) {
|
||
QListWidgetItem* item = new QListWidgetItem(ui->iconList);
|
||
item->setIcon(QPixmap::fromImage(image));
|
||
}
|
||
}
|
||
}
|
||
|
||
QIcon IconChooser::exec()
|
||
{
|
||
QIcon icon;
|
||
int status = QDialog::exec();
|
||
|
||
if (status == QDialog::Accepted) {
|
||
QList<QListWidgetItem*> selectedItems = ui->iconList->selectedItems();
|
||
if (!selectedItems.isEmpty()) {
|
||
icon = selectedItems.at(0)->icon();
|
||
}
|
||
}
|
||
|
||
// Ensure we are returning 16×16px icon
|
||
if (!icon.isNull()) {
|
||
icon = icon.pixmap(16);
|
||
}
|
||
|
||
return icon;
|
||
}
|
||
|
||
IconChooser::~IconChooser()
|
||
{
|
||
delete ui;
|
||
}
|
||
|
||
IconChooserDelegate::IconChooserDelegate(QWidget* parent)
|
||
: QStyledItemDelegate(parent)
|
||
{
|
||
}
|
||
|
||
void IconChooserDelegate::paint(QPainter* painter, const QStyleOptionViewItem &option, const QModelIndex &index) const
|
||
{
|
||
QStyleOptionViewItemV4 opt = option;
|
||
initStyleOption(&opt, index);
|
||
|
||
const QWidget* w = opt.widget;
|
||
const QStyle* style = w ? w->style() : QApplication::style();
|
||
|
||
// Draw background
|
||
style->drawPrimitive(QStyle::PE_PanelItemViewItem, &opt, painter, w);
|
||
|
||
// Draw icon
|
||
QIcon icon = index.data(Qt::DecorationRole).value<QIcon>();
|
||
icon.paint(painter, opt.rect);
|
||
}
|
||
|
||
QSize IconChooserDelegate::sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const
|
||
{
|
||
Q_UNUSED(option)
|
||
Q_UNUSED(index)
|
||
|
||
return QSize(48, 48);
|
||
}
|