actually show plain images, work on proper simple article layout aka old nonwebengine

This commit is contained in:
Martin Rotter 2022-04-07 14:29:11 +02:00
parent 3f402b1861
commit d3ec7ac4b3
2 changed files with 73 additions and 4 deletions

View file

@ -24,7 +24,7 @@
#include <QWheelEvent> #include <QWheelEvent>
LiteHtmlViewer::LiteHtmlViewer(QWidget* parent) : QLiteHtmlWidget(parent), m_downloader(new Downloader(this)), LiteHtmlViewer::LiteHtmlViewer(QWidget* parent) : QLiteHtmlWidget(parent), m_downloader(new Downloader(this)),
m_reloadingWithImages(false) { m_reloadingWithImages(false), m_useSimpleArticleLayout(false) {
setResourceHandler([this](const QUrl& url) { setResourceHandler([this](const QUrl& url) {
emit loadProgress(-1); emit loadProgress(-1);
return m_reloadingWithImages ? handleResource(url) : QByteArray{}; return m_reloadingWithImages ? handleResource(url) : QByteArray{};
@ -94,8 +94,8 @@ void LiteHtmlViewer::setUrl(const QUrl& url) {
} }
else { else {
if (content_type.startsWith(QSL("image/"))) { if (content_type.startsWith(QSL("image/"))) {
html_str = html_str = QSL("<img src=\"data:%1;base64,%2\">").arg(content_type,
"<img src=\"\">"; QString::fromLocal8Bit(m_downloader->lastOutputData().toBase64()));
} }
else { else {
html_str = QString::fromUtf8(m_downloader->lastOutputData()); html_str = QString::fromUtf8(m_downloader->lastOutputData());
@ -128,8 +128,62 @@ void LiteHtmlViewer::clear() {
setHtml({}); setHtml({});
} }
QPair<QString, QUrl> LiteHtmlViewer::prepareHtmlForMessage(const QList<Message>& messages, RootItem* selected_item) const {
QString html;
for (const Message& message : messages) {
html += QString("<h2 align=\"center\">%1</h2>").arg(message.m_title);
if (!message.m_url.isEmpty()) {
html += QString("[url] <a href=\"%1\">%1</a><br/>").arg(message.m_url);
}
for (const Enclosure& enc : message.m_enclosures) {
html += QString("[%2] <a href=\"%1\">%1</a><br/>").arg(enc.m_url, enc.m_mimeType);
}
QRegularExpression imgTagRegex("\\<img[^\\>]*src\\s*=\\s*[\"\']([^\"\']*)[\"\'][^\\>]*\\>",
QRegularExpression::PatternOption::CaseInsensitiveOption |
QRegularExpression::PatternOption::InvertedGreedinessOption);
QRegularExpressionMatchIterator i = imgTagRegex.globalMatch(message.m_contents);
QString pictures_html;
while (i.hasNext()) {
QRegularExpressionMatch match = i.next();
pictures_html += QString("<br/>[%1] <a href=\"%2\">%2</a>").arg(tr("image"), match.captured(1));
}
/*if (qApp->settings()->value(GROUP(Messages), SETTING(Messages::DisplayImagePlaceholders)).toBool()) {
html += message.m_contents;
}
else {*/
QString cnts = message.m_contents;
html += cnts.replace(imgTagRegex, QString());
//}
html += pictures_html;
}
// TODO: If FgInteresting not defined by the skin
// use current pallette/Highlight color perhaps.
return { QSL("<html>"
"<head><style>"
"a { color: %2; }"
"</style></head>"
"<body>%1</body>"
"</html>").arg(html,
qApp->skins()->currentSkin()
.colorForModel(SkinEnums::PaletteColors::FgInteresting)
.value<QColor>().name()),
QUrl() };
}
void LiteHtmlViewer::loadMessages(const QList<Message>& messages, RootItem* root) { void LiteHtmlViewer::loadMessages(const QList<Message>& messages, RootItem* root) {
auto html_messages = qApp->skins()->generateHtmlOfArticles(messages, root); auto html_messages = m_useSimpleArticleLayout
? prepareHtmlForMessage(messages, root)
: qApp->skins()->generateHtmlOfArticles(messages, root);
setHtml(html_messages.first, html_messages.second); setHtml(html_messages.first, html_messages.second);
emit loadFinished(true); emit loadFinished(true);
@ -160,6 +214,10 @@ void LiteHtmlViewer::setZoomFactor(qreal zoom_factor) {
} }
} }
void LiteHtmlViewer::simpleLayoutChanged(bool activated) {
m_useSimpleArticleLayout = activated;
}
void LiteHtmlViewer::selectedTextChanged(bool available) { void LiteHtmlViewer::selectedTextChanged(bool available) {
if (!available) { if (!available) {
return; return;
@ -233,10 +291,16 @@ void LiteHtmlViewer::showContextMenu(const QPoint& pos, const QUrl& url) {
} }
}); });
m_actionSimpleLayout.reset(new QAction(qApp->icons()->fromTheme(QSL("view-list-details")),
tr("Use simple article layout"),
this));
m_actionSimpleLayout->setCheckable(true);
m_actionReloadWithImages.reset(new QAction(qApp->icons()->fromTheme(QSL("viewimage"), QSL("view-refresh")), m_actionReloadWithImages.reset(new QAction(qApp->icons()->fromTheme(QSL("viewimage"), QSL("view-refresh")),
tr("Reload with images"), tr("Reload with images"),
this)); this));
connect(m_actionSimpleLayout.data(), &QAction::triggered, this, &LiteHtmlViewer::simpleLayoutChanged);
connect(m_actionReloadWithImages.data(), &QAction::triggered, this, &LiteHtmlViewer::reloadPageWithImages); connect(m_actionReloadWithImages.data(), &QAction::triggered, this, &LiteHtmlViewer::reloadPageWithImages);
} }
@ -248,6 +312,7 @@ void LiteHtmlViewer::showContextMenu(const QPoint& pos, const QUrl& url) {
m_contextMenu->addActions({ m_actionCopyUrl.data(), m_contextMenu->addActions({ m_actionCopyUrl.data(),
m_actionCopyText.data(), m_actionCopyText.data(),
m_actionOpenLinkExternally.data(), m_actionOpenLinkExternally.data(),
m_actionSimpleLayout.data(),
m_actionReloadWithImages.data() }); m_actionReloadWithImages.data() });
if (url.isValid()) { if (url.isValid()) {

View file

@ -35,6 +35,7 @@ class LiteHtmlViewer : public QLiteHtmlWidget, public WebViewer {
virtual void setZoomFactor(qreal zoom_factor); virtual void setZoomFactor(qreal zoom_factor);
private slots: private slots:
void simpleLayoutChanged(bool activated);
void selectedTextChanged(bool available); void selectedTextChanged(bool available);
void onLinkClicked(const QUrl& link); void onLinkClicked(const QUrl& link);
void reloadPageWithImages(); void reloadPageWithImages();
@ -55,6 +56,7 @@ class LiteHtmlViewer : public QLiteHtmlWidget, public WebViewer {
virtual void keyPressEvent(QKeyEvent* event); virtual void keyPressEvent(QKeyEvent* event);
private: private:
QPair<QString, QUrl> prepareHtmlForMessage(const QList<Message>& messages, RootItem* selected_item) const;
BlockingResult blockedWithAdblock(const QUrl& url); BlockingResult blockedWithAdblock(const QUrl& url);
QByteArray handleResource(const QUrl& url); QByteArray handleResource(const QUrl& url);
@ -64,8 +66,10 @@ class LiteHtmlViewer : public QLiteHtmlWidget, public WebViewer {
QScopedPointer<QAction> m_actionCopyUrl; QScopedPointer<QAction> m_actionCopyUrl;
QScopedPointer<QAction> m_actionCopyText; QScopedPointer<QAction> m_actionCopyText;
QScopedPointer<QAction> m_actionOpenLinkExternally; QScopedPointer<QAction> m_actionOpenLinkExternally;
QScopedPointer<QAction> m_actionSimpleLayout;
QScopedPointer<QAction> m_actionReloadWithImages; QScopedPointer<QAction> m_actionReloadWithImages;
bool m_reloadingWithImages; bool m_reloadingWithImages;
bool m_useSimpleArticleLayout;
}; };
#endif // LITEHTMLVIEWER_H #endif // LITEHTMLVIEWER_H