208 lines
8.4 KiB
C++
208 lines
8.4 KiB
C++
// This file is part of RSS Guard.
|
|
//
|
|
// Copyright (C) 2011-2016 by Martin Rotter <rotter.martinos@gmail.com>
|
|
//
|
|
// RSS Guard 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.
|
|
//
|
|
// RSS Guard 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 RSS Guard. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#include "gui/messagepreviewer.h"
|
|
|
|
#include "miscellaneous/application.h"
|
|
#include "network-web/webfactory.h"
|
|
#include "gui/messagebox.h"
|
|
#include "gui/dialogs/formmain.h"
|
|
#include "services/abstract/serviceroot.h"
|
|
|
|
#include <QScrollBar>
|
|
#include <QToolBar>
|
|
#include <QSqlQuery>
|
|
|
|
|
|
MessagePreviewer::MessagePreviewer(QWidget *parent) : QWidget(parent),
|
|
m_ui(new Ui::MessagePreviewer) {
|
|
m_ui->setupUi(this);
|
|
m_ui->m_txtMessage->viewport()->setAutoFillBackground(true);
|
|
|
|
connect(m_ui->m_txtMessage, &QTextBrowser::anchorClicked, [=](const QUrl &url) {
|
|
// User clicked some URL. Open it in external browser or download?
|
|
MessageBox box(qApp->mainForm());
|
|
|
|
box.setText(tr("You clicked link \"%1\". You can download the link contents or open it in external web browser.").arg(url.toString()));
|
|
box.setInformativeText(tr("What action do you want to take?"));
|
|
QAbstractButton *btn_open = box.addButton(tr("Open in external browser"), QMessageBox::AcceptRole);
|
|
QAbstractButton *btn_download = box.addButton(tr("Download"), QMessageBox::RejectRole);
|
|
|
|
box.exec();
|
|
|
|
if (box.clickedButton() == btn_open) {
|
|
WebFactory::instance()->openUrlInExternalBrowser(url.toString());
|
|
}
|
|
else if (box.clickedButton() == btn_download) {
|
|
qApp->downloadManager()->download(url);
|
|
}
|
|
});
|
|
|
|
m_toolBar = new QToolBar(this);
|
|
m_toolBar->setOrientation(Qt::Vertical);
|
|
m_ui->m_layout->addWidget(m_toolBar, 0, 0, -1, 1);
|
|
|
|
connect(m_actionMarkRead = m_toolBar->addAction(qApp->icons()->fromTheme("mail-mark-read"), tr("Mark message as read")),
|
|
&QAction::triggered,
|
|
this,
|
|
&MessagePreviewer::markMessageAsRead);
|
|
connect(m_actionMarkUnread = m_toolBar->addAction(qApp->icons()->fromTheme("mail-mark-unread"), tr("Mark message as unread")),
|
|
&QAction::triggered,
|
|
this,
|
|
&MessagePreviewer::markMessageAsUnread);
|
|
connect(m_actionSwitchImportance = m_toolBar->addAction(qApp->icons()->fromTheme("mail-mark-favorite"), tr("Switch message importance")),
|
|
&QAction::triggered,
|
|
this,
|
|
&MessagePreviewer::switchMessageImportance);
|
|
|
|
m_actionSwitchImportance->setCheckable(true);
|
|
|
|
clear();
|
|
}
|
|
|
|
MessagePreviewer::~MessagePreviewer() {
|
|
}
|
|
|
|
void MessagePreviewer::clear() {
|
|
m_ui->m_lblTitle->clear();
|
|
m_ui->m_txtMessage->clear();
|
|
|
|
hide();
|
|
}
|
|
|
|
void MessagePreviewer::loadMessage(const Message &message, RootItem *root) {
|
|
m_message = message;
|
|
m_root = root;
|
|
|
|
if (!m_root.isNull()) {
|
|
updateButtons();
|
|
m_actionSwitchImportance->setChecked(m_message.m_isImportant);
|
|
|
|
m_ui->m_lblTitle->setText(m_message.m_title);
|
|
m_ui->m_txtMessage->setHtml(prepareHtmlForMessage(m_message));
|
|
|
|
updateTitle();
|
|
show();
|
|
|
|
m_ui->m_txtMessage->verticalScrollBar()->triggerAction(QScrollBar::SliderToMinimum);
|
|
}
|
|
}
|
|
|
|
void MessagePreviewer::markMessageAsRead() {
|
|
if (!m_root.isNull()) {
|
|
if (m_root->getParentServiceRoot()->onBeforeSetMessagesRead(m_root.data(),
|
|
QList<Message>() << m_message,
|
|
RootItem::Read)) {
|
|
QSqlQuery query_read_msg(qApp->database()->connection(objectName(), DatabaseFactory::FromSettings));
|
|
query_read_msg.setForwardOnly(true);
|
|
|
|
query_read_msg.prepare(QSL("UPDATE Messages SET is_read = :read WHERE id = :id;"));
|
|
query_read_msg.bindValue(QSL(":id"), m_message.m_id);
|
|
query_read_msg.bindValue(QSL(":read"), 1);
|
|
query_read_msg.exec();
|
|
|
|
m_root->getParentServiceRoot()->onAfterSetMessagesRead(m_root.data(),
|
|
QList<Message>() << m_message,
|
|
RootItem::Read);
|
|
|
|
emit requestMessageListReload(false);
|
|
m_message.m_isRead = true;
|
|
updateButtons();
|
|
updateTitle();
|
|
}
|
|
}
|
|
}
|
|
|
|
void MessagePreviewer::markMessageAsUnread() {
|
|
if (!m_root.isNull()) {
|
|
if (m_root->getParentServiceRoot()->onBeforeSetMessagesRead(m_root.data(),
|
|
QList<Message>() << m_message,
|
|
RootItem::Unread)) {
|
|
QSqlQuery query_read_msg(qApp->database()->connection(objectName(), DatabaseFactory::FromSettings));
|
|
query_read_msg.setForwardOnly(true);
|
|
|
|
query_read_msg.prepare(QSL("UPDATE Messages SET is_read = :read WHERE id = :id;"));
|
|
query_read_msg.bindValue(QSL(":id"), m_message.m_id);
|
|
query_read_msg.bindValue(QSL(":read"), 0);
|
|
query_read_msg.exec();
|
|
|
|
m_root->getParentServiceRoot()->onAfterSetMessagesRead(m_root.data(),
|
|
QList<Message>() << m_message,
|
|
RootItem::Unread);
|
|
|
|
emit requestMessageListReload(false);
|
|
m_message.m_isRead = false;
|
|
updateButtons();
|
|
updateTitle();
|
|
}
|
|
}
|
|
}
|
|
|
|
void MessagePreviewer::switchMessageImportance(bool checked) {
|
|
if (!m_root.isNull()) {
|
|
if (m_root->getParentServiceRoot()->onBeforeSwitchMessageImportance(m_root.data(),
|
|
QList<ImportanceChange>() << ImportanceChange(m_message,
|
|
m_message.m_isImportant ?
|
|
RootItem::NotImportant :
|
|
RootItem::Important))) {
|
|
QSqlQuery query_read_msg(qApp->database()->connection(objectName(), DatabaseFactory::FromSettings));
|
|
query_read_msg.setForwardOnly(true);
|
|
|
|
query_read_msg.prepare(QSL("UPDATE Messages SET is_important = :important WHERE id = :id;"));
|
|
query_read_msg.bindValue(QSL(":id"), m_message.m_id);
|
|
query_read_msg.bindValue(QSL(":important"), (int) checked);
|
|
query_read_msg.exec();
|
|
|
|
m_root->getParentServiceRoot()->onBeforeSwitchMessageImportance(m_root.data(),
|
|
QList<ImportanceChange>() << ImportanceChange(m_message,
|
|
m_message.m_isImportant ?
|
|
RootItem::NotImportant :
|
|
RootItem::Important));
|
|
|
|
emit requestMessageListReload(false);
|
|
m_message.m_isImportant = checked;
|
|
}
|
|
}
|
|
}
|
|
|
|
void MessagePreviewer::updateButtons() {
|
|
m_actionMarkRead->setEnabled(!m_message.m_isRead);
|
|
m_actionMarkUnread->setEnabled(m_message.m_isRead);
|
|
}
|
|
|
|
void MessagePreviewer::updateTitle() {
|
|
QFont fon = m_ui->m_lblTitle->font();
|
|
fon.setBold(!m_message.m_isRead);
|
|
m_ui->m_lblTitle->setFont(fon);
|
|
}
|
|
|
|
QString MessagePreviewer::prepareHtmlForMessage(const Message &message) {
|
|
QString html = QString("<p>[url] <a href=\"%1\">%1</a></p>").arg(message.m_url);
|
|
|
|
foreach (const Enclosure &enc, message.m_enclosures) {
|
|
html += QString("<p>[%2] <a href=\"%1\">%1</a></p>").arg(enc.m_url, enc.m_mimeType);
|
|
}
|
|
|
|
if (!message.m_enclosures.isEmpty()) {
|
|
html += "<hr/>";
|
|
}
|
|
|
|
html += message.m_contents;
|
|
|
|
return html;
|
|
}
|