This commit is contained in:
Martin Rotter 2015-04-27 07:44:47 +02:00
parent 6b27ac84ed
commit 9917a8415e
5 changed files with 59 additions and 5 deletions

View File

@ -8,6 +8,7 @@ Fixed:
Added: Added:
<ul> <ul>
<li>Automatic detection of feeds on websites. User loads website and can add feeds via custom web browser toolbar button. (issue #47)</li>
<li>Better format for logged messages. Logging to file is possible via "rssguard 2> log.txt" command.</li> <li>Better format for logged messages. Logging to file is possible via "rssguard 2> log.txt" command.</li>
<li>Full support for podcasts (issue #81). Supports RSS 2.0 podcasts and ATOM 1.0 podcasts. In ATOM, RSS Guard is able to fetch multiple podcasts per message. Podcasts are displayed as additional URL addresses in message preview panel.</li> <li>Full support for podcasts (issue #81). Supports RSS 2.0 podcasts and ATOM 1.0 podcasts. In ATOM, RSS Guard is able to fetch multiple podcasts per message. Podcasts are displayed as additional URL addresses in message preview panel.</li>
</ul> </ul>

View File

@ -1,3 +1,20 @@
// This file is part of RSS Guard.
//
// Copyright (C) 2011-2015 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 "network-web/discoverfeedsbutton.h" #include "network-web/discoverfeedsbutton.h"
#include "miscellaneous/application.h" #include "miscellaneous/application.h"
@ -7,6 +24,7 @@
DiscoverFeedsButton::DiscoverFeedsButton(QWidget *parent) : QToolButton(parent) { DiscoverFeedsButton::DiscoverFeedsButton(QWidget *parent) : QToolButton(parent) {
setEnabled(false); setEnabled(false);
setIcon(qApp->icons()->fromTheme("folder-feed")); setIcon(qApp->icons()->fromTheme("folder-feed"));
setPopupMode(QToolButton::InstantPopup);
} }
DiscoverFeedsButton::~DiscoverFeedsButton() { DiscoverFeedsButton::~DiscoverFeedsButton() {
@ -24,8 +42,7 @@ void DiscoverFeedsButton::setFeedAddresses(const QStringList &addresses) {
if (menu() == NULL) { if (menu() == NULL) {
setMenu(new QMenu(this)); setMenu(new QMenu(this));
connect(menu(), SIGNAL(triggered(QAction*)), this, SLOT(linkTriggered(QAction*)));
// TODO: pokračovat asi zde, po kliku na menu vyslat signal, ten odchytne webbrowser a provede akce.
} }
menu()->hide(); menu()->hide();
@ -36,7 +53,9 @@ void DiscoverFeedsButton::setFeedAddresses(const QStringList &addresses) {
foreach (const QString &feed, addresses) { foreach (const QString &feed, addresses) {
menu()->addAction(feed); menu()->addAction(feed);
} }
connect(this, SIGNAL(clicked(bool)), this, SLOT(showMenu()));
} }
} }
void DiscoverFeedsButton::linkTriggered(QAction *action) {
emit addingOfFeedRequested(action->text());
}

View File

@ -1,3 +1,20 @@
// This file is part of RSS Guard.
//
// Copyright (C) 2011-2015 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/>.
#ifndef DISCOVERFEEDSBUTTON_H #ifndef DISCOVERFEEDSBUTTON_H
#define DISCOVERFEEDSBUTTON_H #define DISCOVERFEEDSBUTTON_H
@ -13,6 +30,12 @@ class DiscoverFeedsButton : public QToolButton {
void clearFeedAddresses(); void clearFeedAddresses();
void setFeedAddresses(const QStringList &addresses); void setFeedAddresses(const QStringList &addresses);
private slots:
void linkTriggered(QAction *action);
signals:
void addingOfFeedRequested(const QString &feed_link);
}; };
#endif // DISCOVERFEEDSBUTTON_H #endif // DISCOVERFEEDSBUTTON_H

View File

@ -25,6 +25,8 @@
#include "miscellaneous/skinfactory.h" #include "miscellaneous/skinfactory.h"
#include "gui/formmain.h" #include "gui/formmain.h"
#include "gui/tabwidget.h" #include "gui/tabwidget.h"
#include "gui/feedmessageviewer.h"
#include "gui/feedsview.h"
#include <QVBoxLayout> #include <QVBoxLayout>
#include <QHBoxLayout> #include <QHBoxLayout>
@ -36,6 +38,7 @@
#include <QLabel> #include <QLabel>
#include <QProgressBar> #include <QProgressBar>
#include <QToolButton> #include <QToolButton>
#include <QClipboard>
QList<WebBrowser*> WebBrowser::m_runningWebBrowsers; QList<WebBrowser*> WebBrowser::m_runningWebBrowsers;
@ -90,7 +93,7 @@ void WebBrowser::initializeZoomWidget() {
layout->setMargin(3); layout->setMargin(3);
m_zoomButtons->setLayout(layout); m_zoomButtons->setLayout(layout);
// Make connections.. // Make connections.
connect(button_increase, SIGNAL(clicked()), this, SLOT(increaseZoom())); connect(button_increase, SIGNAL(clicked()), this, SLOT(increaseZoom()));
connect(button_decrease, SIGNAL(clicked()), this, SLOT(decreaseZoom())); connect(button_decrease, SIGNAL(clicked()), this, SLOT(decreaseZoom()));
connect(m_btnResetZoom, SIGNAL(clicked()), this, SLOT(resetZoom())); connect(m_btnResetZoom, SIGNAL(clicked()), this, SLOT(resetZoom()));
@ -198,12 +201,18 @@ void WebBrowser::createConnections() {
// Misc connections. // Misc connections.
connect(m_webView, SIGNAL(zoomFactorChanged()), this, SLOT(updateZoomGui())); connect(m_webView, SIGNAL(zoomFactorChanged()), this, SLOT(updateZoomGui()));
connect(m_btnDiscoverFeeds, SIGNAL(addingOfFeedRequested(QString)), this, SLOT(addFeedFromWebsite(QString)));
} }
void WebBrowser::onIconChanged() { void WebBrowser::onIconChanged() {
emit iconChanged(m_index, m_webView->icon()); emit iconChanged(m_index, m_webView->icon());
} }
void WebBrowser::addFeedFromWebsite(const QString &feed_link) {
qApp->clipboard()->setText(feed_link);
qApp->mainForm()->tabWidget()->feedMessageViewer()->feedsView()->addNewFeed();
}
void WebBrowser::onTitleChanged(const QString &new_title) { void WebBrowser::onTitleChanged(const QString &new_title) {
if (new_title.isEmpty()) { if (new_title.isEmpty()) {
//: Webbrowser tab title when no title is available. //: Webbrowser tab title when no title is available.

View File

@ -132,6 +132,8 @@ class WebBrowser : public TabContent {
void onTitleChanged(const QString &new_title); void onTitleChanged(const QString &new_title);
void onIconChanged(); void onIconChanged();
void addFeedFromWebsite(const QString &feed_link);
signals: signals:
// User requests opening of new tab or clicks the link // User requests opening of new tab or clicks the link
// with middle mouse button // with middle mouse button