1
mirror of https://invent.kde.org/network/falkon.git synced 2024-12-20 18:56:34 +01:00

AdBlockIcon: Indicate AdBlock state on current page with icon state

Icon is inactive when AdBlock is disabled or can't run on current page.
This commit is contained in:
David Rosca 2018-01-05 21:15:28 +01:00
parent 74f45f6028
commit 3d171275d2
2 changed files with 82 additions and 135 deletions

View File

@ -28,22 +28,18 @@
#include "qztools.h" #include "qztools.h"
#include <QMenu> #include <QMenu>
#include <QTimer>
AdBlockIcon::AdBlockIcon(QObject *parent) AdBlockIcon::AdBlockIcon(QObject *parent)
: AbstractButtonInterface(parent) : AbstractButtonInterface(parent)
, m_menuAction(0)
, m_flashTimer(0)
, m_timerTicks(0)
, m_enabled(false)
{ {
setTitle(tr("AdBlock")); setTitle(tr("AdBlock"));
setToolTip(tr("AdBlock lets you block unwanted content on web pages")); setIcon(QIcon(QSL(":icons/other/adblock.png")));
updateState();
connect(this, &AbstractButtonInterface::clicked, this, &AdBlockIcon::clicked); connect(this, &AbstractButtonInterface::clicked, this, &AdBlockIcon::clicked);
connect(this, &AbstractButtonInterface::webPageChanged, this, &AdBlockIcon::webPageChanged);
setEnabled(AdBlockManager::instance()->isEnabled()); connect(AdBlockManager::instance(), &AdBlockManager::enabledChanged, this, &AdBlockIcon::updateState);
connect(AdBlockManager::instance(), SIGNAL(enabledChanged(bool)), this, SLOT(setEnabled(bool)));
} }
AdBlockIcon::~AdBlockIcon() AdBlockIcon::~AdBlockIcon()
@ -79,90 +75,6 @@ void AdBlockIcon::popupBlocked(const QString &ruleString, const QUrl &url)
m_blockedPopups.append(pair); m_blockedPopups.append(pair);
mApp->desktopNotifications()->showNotification(QPixmap(":html/adblock_big.png"), tr("Blocked popup window"), tr("AdBlock blocked unwanted popup window.")); mApp->desktopNotifications()->showNotification(QPixmap(":html/adblock_big.png"), tr("Blocked popup window"), tr("AdBlock blocked unwanted popup window."));
if (!m_flashTimer) {
m_flashTimer = new QTimer(this);
}
if (m_flashTimer->isActive()) {
stopAnimation();
}
m_flashTimer->setInterval(500);
m_flashTimer->start();
connect(m_flashTimer, SIGNAL(timeout()), this, SLOT(animateIcon()));
}
QAction* AdBlockIcon::menuAction()
{
if (!m_menuAction) {
m_menuAction = new QAction(tr("AdBlock"), this);
m_menuAction->setMenu(new QMenu);
connect(m_menuAction->menu(), SIGNAL(aboutToShow()), this, SLOT(createMenu()));
}
m_menuAction->setIcon(QIcon(m_enabled ? ":icons/other/adblock.png" : ":icons/other/adblock-disabled.png"));
return m_menuAction;
}
void AdBlockIcon::createMenu(QMenu* menu)
{
if (!menu) {
menu = qobject_cast<QMenu*>(sender());
if (!menu) {
return;
}
}
menu->clear();
WebPage* page = webPage();
if (!page) {
return;
}
AdBlockManager* manager = AdBlockManager::instance();
AdBlockCustomList* customList = manager->customList();
const QUrl pageUrl = page->url();
menu->addAction(tr("Show AdBlock &Settings"), manager, SLOT(showDialog()));
menu->addSeparator();
if (!pageUrl.host().isEmpty() && m_enabled && manager->canRunOnScheme(pageUrl.scheme())) {
const QString host = page->url().host().contains(QLatin1String("www.")) ? pageUrl.host().mid(4) : pageUrl.host();
const QString hostFilter = QString("@@||%1^$document").arg(host);
const QString pageFilter = QString("@@|%1|$document").arg(pageUrl.toString());
QAction* act = menu->addAction(tr("Disable on %1").arg(host));
act->setCheckable(true);
act->setChecked(customList->containsFilter(hostFilter));
act->setData(hostFilter);
connect(act, SIGNAL(triggered()), this, SLOT(toggleCustomFilter()));
act = menu->addAction(tr("Disable only on this page"));
act->setCheckable(true);
act->setChecked(customList->containsFilter(pageFilter));
act->setData(pageFilter);
connect(act, SIGNAL(triggered()), this, SLOT(toggleCustomFilter()));
menu->addSeparator();
}
if (!m_blockedPopups.isEmpty()) {
menu->addAction(tr("Blocked Popup Windows"))->setEnabled(false);
for (int i = 0; i < m_blockedPopups.count(); i++) {
const QPair<AdBlockRule*, QUrl> &pair = m_blockedPopups.at(i);
QString address = pair.second.toString().right(55);
QString actionText = tr("%1 with (%2)").arg(address, pair.first->filter()).replace(QLatin1Char('&'), QLatin1String("&&"));
QAction* action = menu->addAction(actionText, manager, SLOT(showRule()));
action->setData(QVariant::fromValue((void*)pair.first));
}
}
} }
void AdBlockIcon::toggleCustomFilter() void AdBlockIcon::toggleCustomFilter()
@ -185,46 +97,91 @@ void AdBlockIcon::toggleCustomFilter()
} }
} }
void AdBlockIcon::animateIcon() void AdBlockIcon::updateState()
{ {
++m_timerTicks; WebPage *page = webPage();
if (m_timerTicks > 10) { if (!page) {
stopAnimation(); setActive(false);
setToolTip(name());
return; return;
} }
if (!AdBlockManager::instance()->isEnabled()) {
if (icon().isNull()) { setActive(false);
setIcon(QIcon(QSL(":icons/other/adblock.png"))); setToolTip(tr("AdBlock is disabled"));
return;
} }
else { if (!AdBlockManager::instance()->canRunOnScheme(page->url().scheme())) {
setIcon(QIcon()); setActive(false);
setToolTip(tr("AdBlock is disabled on this site "));
return;
} }
setActive(true);
setToolTip(tr("AdBlock is active"));
} }
void AdBlockIcon::stopAnimation() void AdBlockIcon::webPageChanged(WebPage *page)
{ {
m_timerTicks = 0; updateState();
m_flashTimer->stop();
disconnect(m_flashTimer, SIGNAL(timeout()), this, SLOT(animateIcon()));
setEnabled(m_enabled); if (m_page) {
disconnect(m_page, &QWebEnginePage::urlChanged, this, &AdBlockIcon::updateState);
}
m_page = page;
if (m_page) {
connect(m_page, &QWebEnginePage::urlChanged, this, &AdBlockIcon::updateState);
}
} }
void AdBlockIcon::clicked(ClickController *controller) void AdBlockIcon::clicked(ClickController *controller)
{ {
WebPage *page = webPage();
if (!page) {
return;
}
AdBlockManager* manager = AdBlockManager::instance();
AdBlockCustomList* customList = manager->customList();
const QUrl pageUrl = page->url();
QMenu menu; QMenu menu;
createMenu(&menu); menu.addAction(tr("Show AdBlock &Settings"), manager, SLOT(showDialog()));
menu.addSeparator();
if (!pageUrl.host().isEmpty() && manager->isEnabled() && manager->canRunOnScheme(pageUrl.scheme())) {
const QString host = page->url().host().contains(QLatin1String("www.")) ? pageUrl.host().mid(4) : pageUrl.host();
const QString hostFilter = QString("@@||%1^$document").arg(host);
const QString pageFilter = QString("@@|%1|$document").arg(pageUrl.toString());
QAction* act = menu.addAction(tr("Disable on %1").arg(host));
act->setCheckable(true);
act->setChecked(customList->containsFilter(hostFilter));
act->setData(hostFilter);
connect(act, SIGNAL(triggered()), this, SLOT(toggleCustomFilter()));
act = menu.addAction(tr("Disable only on this page"));
act->setCheckable(true);
act->setChecked(customList->containsFilter(pageFilter));
act->setData(pageFilter);
connect(act, SIGNAL(triggered()), this, SLOT(toggleCustomFilter()));
menu.addSeparator();
}
if (!m_blockedPopups.isEmpty()) {
menu.addAction(tr("Blocked Popup Windows"))->setEnabled(false);
for (int i = 0; i < m_blockedPopups.count(); i++) {
const QPair<AdBlockRule*, QUrl> &pair = m_blockedPopups.at(i);
QString address = pair.second.toString().right(55);
QString actionText = tr("%1 with (%2)").arg(address, pair.first->filter()).replace(QLatin1Char('&'), QLatin1String("&&"));
QAction* action = menu.addAction(actionText, manager, SLOT(showRule()));
action->setData(QVariant::fromValue((void*)pair.first));
}
}
menu.exec(controller->popupPosition(menu.sizeHint())); menu.exec(controller->popupPosition(menu.sizeHint()));
} }
void AdBlockIcon::setEnabled(bool enabled)
{
if (enabled) {
setIcon(QIcon(QSL(":icons/other/adblock.png")));
}
else {
setIcon(QIcon(QSL(":icons/other/adblock-disabled.png")));
}
m_enabled = enabled;
}

View File

@ -18,12 +18,12 @@
#ifndef ADBLOCKICON_H #ifndef ADBLOCKICON_H
#define ADBLOCKICON_H #define ADBLOCKICON_H
#include <QPointer>
#include "qzcommon.h" #include "qzcommon.h"
#include "abstractbuttoninterface.h" #include "abstractbuttoninterface.h"
class QUrl; class QUrl;
class QMenu;
class QAction;
class AdBlockRule; class AdBlockRule;
@ -45,27 +45,17 @@ public:
QString name() const override; QString name() const override;
void popupBlocked(const QString &ruleString, const QUrl &url); void popupBlocked(const QString &ruleString, const QUrl &url);
QAction* menuAction();
public slots:
void setEnabled(bool enabled);
void createMenu(QMenu* menu = 0);
private slots: private slots:
void toggleCustomFilter(); void toggleCustomFilter();
void animateIcon();
void stopAnimation();
private: private:
void updateState();
void webPageChanged(WebPage *page);
void clicked(ClickController *controller); void clicked(ClickController *controller);
QAction* m_menuAction; QPointer<WebPage> m_page;
QVector<QPair<AdBlockRule*, QUrl> > m_blockedPopups; QVector<QPair<AdBlockRule*, QUrl> > m_blockedPopups;
QTimer* m_flashTimer;
int m_timerTicks;
bool m_enabled;
}; };
#endif // ADBLOCKICON_H #endif // ADBLOCKICON_H