1
mirror of https://invent.kde.org/network/falkon.git synced 2024-11-15 19:42:10 +01:00
falkonOfficial/src/plugins/TestPlugin/testplugin.cpp

180 lines
5.6 KiB
C++
Raw Normal View History

/* ============================================================
* QupZilla - WebKit based browser
2013-03-11 17:45:48 +01:00
* Copyright (C) 2010-2013 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/>.
* ============================================================ */
2011-03-02 16:57:41 +01:00
#include "testplugin.h"
#include "testplugin_sidebar.h"
#include "qupzilla.h"
#include "webview.h"
#include "pluginproxy.h"
#include "mainapplication.h"
#include "sidebar.h"
2011-03-02 16:57:41 +01:00
#include <QTranslator>
#include <QPushButton>
#include <QWebHitTestResult>
#include <QMenu>
TestPlugin::TestPlugin()
: QObject()
, m_view(0)
{
// Don't do anything expensive in constructor!
// It will be called even if user doesn't have
// plugin allowed
}
PluginSpec TestPlugin::pluginSpec()
2011-03-02 16:57:41 +01:00
{
PluginSpec spec;
spec.name = "Example Plugin";
spec.info = "Example minimal plugin";
spec.description = "Very simple minimal plugin example";
spec.version = "0.1.6";
spec.author = "David Rosca <nowrep@gmail.com>";
spec.icon = QPixmap(":qupzilla.png");
spec.hasSettings = true;
return spec;
}
void TestPlugin::init(const QString &sPath)
{
qDebug() << __FUNCTION__ << "called";
// This function is called right after plugin is loaded
// it will be called even if we return false from testPlugin()
// so it is recommended not to call any QupZilla function here
// Settings path is PROFILE/extensions/, in this directory
// you can use global .ini file for QSettings named "extensions.ini"
// or create new folder for your plugin and save in it anything you want
m_settingsPath = sPath;
// Registering this plugin as a MousePressHandler.
// Otherwise mousePress() function will never be called
QZ_REGISTER_EVENT_HANDLER(PluginProxy::MousePressHandler);
// Adding new sidebar into application
SideBarManager::addSidebar("testplugin-sidebar", new TestPlugin_Sidebar(this));
}
void TestPlugin::unload()
{
2011-03-02 16:57:41 +01:00
qDebug() << __FUNCTION__ << "called";
// This function will be called when unloading plugin
// it will be also called if we return false from testPlugin()
// Removing sidebar from application
SideBarManager::removeSidebar("testplugin-sidebar");
// Deleting settings dialog if opened
delete m_settings.data();
2011-03-02 16:57:41 +01:00
}
bool TestPlugin::testPlugin()
{
2011-03-03 22:52:15 +01:00
//This function is called right after init()
2011-03-02 16:57:41 +01:00
//There should be some testing if plugin is loaded correctly
//If this function returns false, plugin is automatically unloaded
return (QupZilla::VERSION == QLatin1String("1.5.0"));
2011-03-02 16:57:41 +01:00
}
QTranslator* TestPlugin::getTranslator(const QString &locale)
2011-03-02 16:57:41 +01:00
{
// Loads translation according to locale file
// QString locale will contains "fr_FR.qm" for French locale
QTranslator* translator = new QTranslator(this);
translator->load(locale, ":/testplugin/locale/");
2011-03-02 16:57:41 +01:00
return translator;
}
void TestPlugin::showSettings(QWidget* parent)
2011-03-02 16:57:41 +01:00
{
// This function will be called from Preferences after clicking on Settings button.
// Settings button will be enabled if PluginSpec.hasSettings == true
if (!m_settings) {
m_settings = new QDialog(parent);
QPushButton* b = new QPushButton("Example Plugin v0.0.1");
QPushButton* closeButton = new QPushButton(tr("Close"));
QLabel* label = new QLabel();
label->setPixmap(QPixmap(":icons/other/about.png"));
QVBoxLayout* l = new QVBoxLayout(m_settings.data());
l->addWidget(label);
l->addWidget(b);
l->addWidget(closeButton);
m_settings.data()->setLayout(l);
m_settings.data()->setAttribute(Qt::WA_DeleteOnClose);
m_settings.data()->setWindowTitle(tr("Example Plugin Settings"));
m_settings.data()->setWindowIcon(QIcon(":qupzilla.png"));
connect(closeButton, SIGNAL(clicked()), m_settings.data(), SLOT(close()));
}
m_settings.data()->show();
m_settings.data()->raise();
2011-03-02 16:57:41 +01:00
}
void TestPlugin::populateWebViewMenu(QMenu* menu, WebView* view, const QWebHitTestResult &r)
2011-03-02 16:57:41 +01:00
{
// Called from WebView when creating context menu
m_view = view;
2011-03-02 16:57:41 +01:00
QString title;
if (!r.imageUrl().isEmpty()) {
2011-03-02 16:57:41 +01:00
title += " on image";
}
if (!r.linkUrl().isEmpty()) {
2011-03-02 16:57:41 +01:00
title += " on link";
}
if (r.isContentEditable()) {
title += " on input";
}
2011-03-02 16:57:41 +01:00
menu->addAction(tr("My first plugin action") + title, this, SLOT(actionSlot()));
2011-03-02 16:57:41 +01:00
}
bool TestPlugin::mousePress(const Qz::ObjectName &type, QObject* obj, QMouseEvent* event)
{
qDebug() << "mousePress" << type << obj << event;
// Returning false means, that we don't want to block propagating this event
// Returning true may affect behaviour of QupZilla, so make sure you know what
// you are doing!
return false;
}
2011-03-02 16:57:41 +01:00
void TestPlugin::actionSlot()
{
QMessageBox::information(m_view, tr("Hello"), tr("First plugin action works :-)"));
2011-03-02 16:57:41 +01:00
}
// Export plugin macro
// This macro has to be only in class derived from PluginInterface
// Don't call it in other files!
#if QT_VERSION < 0x050000
2011-03-02 16:57:41 +01:00
Q_EXPORT_PLUGIN2(ExamplePlugin, TestPlugin)
#endif