diff options
author | Aqua-sama <aqua@iserlohn-fortress.net> | 2018-01-15 00:35:58 +0100 |
---|---|---|
committer | Aqua-sama <aqua@iserlohn-fortress.net> | 2018-01-15 00:35:58 +0100 |
commit | 2660fff9e6191808aa83197639a663b73a27bbfa (patch) | |
tree | e01930c4202d87c5b74f701938a0004a952425a1 /src | |
parent | Initial plugins testing (diff) | |
download | smolbote-2660fff9e6191808aa83197639a663b73a27bbfa.tar.xz |
Moved ProfileView to ProfileEditorPlugin
Diffstat (limited to 'src')
-rw-r--r-- | src/browser.cpp | 41 | ||||
-rw-r--r-- | src/browser.h | 8 | ||||
-rw-r--r-- | src/forms/profileview.cpp | 132 | ||||
-rw-r--r-- | src/forms/profileview.h | 42 | ||||
-rw-r--r-- | src/forms/profileview.ui | 230 | ||||
-rw-r--r-- | src/mainwindow.cpp | 39 | ||||
-rw-r--r-- | src/mainwindow.h | 5 | ||||
-rw-r--r-- | src/widgets/mainwindowmenubar.cpp | 13 |
8 files changed, 50 insertions, 460 deletions
diff --git a/src/browser.cpp b/src/browser.cpp index 542465b..43cee5f 100644 --- a/src/browser.cpp +++ b/src/browser.cpp @@ -13,9 +13,6 @@ #include <bookmarks/bookmarkswidget.h> #include <downloads/downloadswidget.h> -#include <QPluginLoader> -#include <QtPlugin> - Browser::Browser(int &argc, char *argv[]) : SingleApplication(argc, argv) { @@ -29,33 +26,38 @@ Browser::~Browser() { if(m_config) { QtConcurrent::run(QThreadPool::globalInstance(), m_config.get(), &Configuration::writeIfNeeded); - //m_config->writeIfNeeded(); } if(m_bookmarksManager) { QtConcurrent::run(QThreadPool::globalInstance(), m_bookmarksManager.get(), &BookmarksWidget::save); - //m_bookmarksManager->save(); } - qDebug("Waiting for threads to wind down: %s", QThreadPool::globalInstance()->waitForDone() ? "done" : "failed"); - - qDeleteAll(m_plugins); + qDebug("Waiting for threads to wind down..."); + qDebug("Thread pool is done: %s", QThreadPool::globalInstance()->waitForDone() ? "okay" : "failed"); } void Browser::setConfiguration(std::shared_ptr<Configuration> &config) { m_config = config; - // plugin loader - QPluginLoader loader("plugins/ProfileEditor/libProfileEditorPlugin.so"); - qDebug("Trying to load %s: %s", qUtf8Printable(loader.fileName()), loader.load() ? "ok" : "failed"); - if(!loader.isLoaded()) { - qDebug("Error: %s", qUtf8Printable(loader.errorString())); - } else { - PluginInterface *plugin = qobject_cast<PluginInterface *>(loader.instance()); - m_plugins.append(plugin); - //qDebug("author: %s", qUtf8Printable(loader.metaData()["MetaData"].toObject()["author"].toString())); + QDir pluginsDir(QString::fromStdString(m_config->value<std::string>("plugins.path").value())); + if(pluginsDir.exists()) { + const QStringList entries = pluginsDir.entryList(QDir::Files | QDir::Readable); + for (const QString &name : entries) { + QPluginLoader loader(pluginsDir.absoluteFilePath(name)); + qDebug("Loading plugin %s: %s", qUtf8Printable(name), loader.load() ? "ok" : "failed"); + if (!loader.isLoaded()) { + qDebug("Error: %s", qUtf8Printable(loader.errorString())); + } else { + Plugin d; + d.meta = loader.metaData()["MetaData"].toObject(); + d.pointer = loader.instance(); + d.pointer->setParent(this); + m_plugins.append(d); + } + } } + m_bookmarksManager = std::make_shared<BookmarksWidget>(QString::fromStdString(m_config->value<std::string>("bookmarks.path").value())); m_downloadManager = std::make_shared<DownloadsWidget>(QString::fromStdString(m_config->value<std::string>("downloads.path").value())); @@ -141,8 +143,3 @@ std::shared_ptr<WebEngineProfile> Browser::profile(const QString storageName) return _profile; } - -QStringList Browser::profiles() const -{ - return m_profiles.keys(); -} diff --git a/src/browser.h b/src/browser.h index 236b0fb..5b1a760 100644 --- a/src/browser.h +++ b/src/browser.h @@ -26,6 +26,11 @@ class Browser : public SingleApplication Q_OBJECT public: + struct Plugin { + QJsonObject meta; + QObject *pointer; + }; + explicit Browser(int &argc, char *argv[]); ~Browser() final; Q_DISABLE_COPY(Browser) @@ -33,7 +38,6 @@ public: void setConfiguration(std::shared_ptr<Configuration> &config); std::shared_ptr<WebEngineProfile> profile(const QString storageName); - QStringList profiles() const; public slots: MainWindow *createSession(const QString &profileName, bool newWindow, const QStringList &urls); @@ -44,7 +48,7 @@ private: std::shared_ptr<Configuration> m_config; QVector<MainWindow *> m_windows; - QVector<PluginInterface *> m_plugins; + QVector<Plugin> m_plugins; QHash<QString, std::shared_ptr<WebEngineProfile>> m_profiles; std::shared_ptr<WebEngineProfile> m_defaultProfile; diff --git a/src/forms/profileview.cpp b/src/forms/profileview.cpp deleted file mode 100644 index 3d85963..0000000 --- a/src/forms/profileview.cpp +++ /dev/null @@ -1,132 +0,0 @@ -/* - * This file is part of smolbote. It's copyrighted by the contributors recorded - * in the version control history of the file, available from its original - * location: git://neueland.iserlohn-fortress.net/smolbote.git - * - * SPDX-License-Identifier: GPL-3.0 - */ - -#include "profileview.h" -#include "ui_profileview.h" - -#include "forms/cookiesform.h" -#include "webengine/webengineprofile.h" -#include <QComboBox> -#include <QLineEdit> -#include <QPlainTextEdit> -#include <QPushButton> - -#include <QDialogButtonBox> - -#include <QFormLayout> - -ProfileView::ProfileView(WebEngineProfile *profile, QWidget *parent) - : QDialog(parent) - , ui(new Ui::ProfileView) -{ - ui->setupUi(this); - setProfile(profile); - - // actions - connect(ui->clearCache_pushButton, &QPushButton::clicked, [this]() { - this->m_profile->clearHttpCache(); - }); - connect(ui->clearHistory_pushButton, &QPushButton::clicked, [this]() { - this->m_profile->clearAllVisitedLinks(); - }); - - connect(ui->buttonBox, &QDialogButtonBox::accepted, this, &ProfileView::updateProfile); - connect(ui->buttonBox, &QDialogButtonBox::rejected, this, &ProfileView::close); -} - -ProfileView::~ProfileView() -{ - delete ui; -} - -void ProfileView::setProfile(WebEngineProfile *profile) -{ - Q_CHECK_PTR(profile); - - m_profile = profile; - setWindowTitle(m_profile->name()); - - m_cookiesForm = new CookiesForm(m_profile->cookieStore(), this); - //ui->tabWidget->addTab(m_cookiesForm, m_cookiesForm->windowTitle()); - - // general - ui->homepage_lineEdit->setText(m_profile->homepage().toString()); - ui->newtab_lineEdit->setText(m_profile->newtab().toString()); - - // http - ui->userAgent->setPlainText(m_profile->httpUserAgent()); - ui->acceptLanguage->setPlainText(m_profile->httpAcceptLanguage()); - ui->cacheType->setCurrentIndex(m_profile->httpCacheType()); - ui->cacheSize->setText(QString::number(m_profile->httpCacheMaximumSize())); - - // path - ui->storagePath_lineEdit->setText(m_profile->persistentStoragePath()); - ui->cachePath_lineEdit->setText(m_profile->cachePath()); - - // policy - ui->cookiePolicy->setCurrentIndex(m_profile->persistentCookiesPolicy()); - - //ui->formLayout_3->addWidget(m_cookiesForm); - ui->verticalLayout_3->addWidget(m_cookiesForm); -} - -void ProfileView::showProfile() -{ - ui->tabWidget->setCurrentIndex(0); - show(); -} - -void ProfileView::showCookies() -{ - ui->tabWidget->setCurrentIndex(2); - show(); -} - -void ProfileView::updateProfile() -{ - qDebug("Updating profile [%s]...", qUtf8Printable(m_profile->name())); - - // general - m_profile->setHomepage(QUrl::fromUserInput(ui->homepage_lineEdit->text())); - m_profile->setNewtab(QUrl::fromUserInput(ui->newtab_lineEdit->text())); - - // http - m_profile->setHttpUserAgent(ui->userAgent->toPlainText()); - m_profile->setHttpAcceptLanguage(ui->acceptLanguage->toPlainText()); - switch(ui->cacheType->currentIndex()) { - case 0: - m_profile->setHttpCacheType(QWebEngineProfile::MemoryHttpCache); - break; - case 1: - m_profile->setHttpCacheType(QWebEngineProfile::DiskHttpCache); - break; - case 2: - m_profile->setHttpCacheType(QWebEngineProfile::NoCache); - break; - default: - break; - } - m_profile->setHttpCacheMaximumSize(ui->cacheSize->text().toInt()); - - // policy - switch(ui->cookiePolicy->currentIndex()) { - case 0: - m_profile->setPersistentCookiesPolicy(QWebEngineProfile::NoPersistentCookies); - break; - case 1: - m_profile->setPersistentCookiesPolicy(QWebEngineProfile::AllowPersistentCookies); - break; - case 2: - m_profile->setPersistentCookiesPolicy(QWebEngineProfile::ForcePersistentCookies); - break; - default: - break; - } - - m_profile->saveProfile(); -} diff --git a/src/forms/profileview.h b/src/forms/profileview.h deleted file mode 100644 index bf44346..0000000 --- a/src/forms/profileview.h +++ /dev/null @@ -1,42 +0,0 @@ -/* - * This file is part of smolbote. It's copyrighted by the contributors recorded - * in the version control history of the file, available from its original - * location: git://neueland.iserlohn-fortress.net/smolbote.git - * - * SPDX-License-Identifier: GPL-3.0 - */ - -#ifndef PROFILEDIALOG_H -#define PROFILEDIALOG_H - -#include <QDialog> - -namespace Ui -{ -class ProfileView; -} - -class WebEngineProfile; -class CookiesForm; -class ProfileView : public QDialog -{ - Q_OBJECT - -public: - explicit ProfileView(WebEngineProfile *profile, QWidget *parent = nullptr); - ~ProfileView(); - - void setProfile(WebEngineProfile *profile); - -public slots: - void showProfile(); - void showCookies(); - void updateProfile(); - -private: - Ui::ProfileView *ui; - WebEngineProfile *m_profile; - CookiesForm *m_cookiesForm; -}; - -#endif // PROFILEDIALOG_H diff --git a/src/forms/profileview.ui b/src/forms/profileview.ui deleted file mode 100644 index 7590e87..0000000 --- a/src/forms/profileview.ui +++ /dev/null @@ -1,230 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<ui version="4.0"> - <class>ProfileView</class> - <widget class="QWidget" name="ProfileView"> - <property name="geometry"> - <rect> - <x>0</x> - <y>0</y> - <width>480</width> - <height>640</height> - </rect> - </property> - <property name="minimumSize"> - <size> - <width>200</width> - <height>0</height> - </size> - </property> - <property name="windowTitle"> - <string>Profile</string> - </property> - <layout class="QVBoxLayout" name="verticalLayout"> - <item> - <widget class="QTabWidget" name="tabWidget"> - <property name="currentIndex"> - <number>0</number> - </property> - <widget class="QWidget" name="tab"> - <attribute name="title"> - <string>General</string> - </attribute> - <layout class="QFormLayout" name="formLayout"> - <item row="0" column="0"> - <widget class="QLabel" name="label_2"> - <property name="text"> - <string>Homepage</string> - </property> - </widget> - </item> - <item row="0" column="1"> - <widget class="QLineEdit" name="homepage_lineEdit"/> - </item> - <item row="1" column="0"> - <widget class="QLabel" name="label_3"> - <property name="text"> - <string>Newtab</string> - </property> - </widget> - </item> - <item row="1" column="1"> - <widget class="QLineEdit" name="newtab_lineEdit"/> - </item> - </layout> - </widget> - <widget class="QWidget" name="httpTab"> - <attribute name="title"> - <string>HTTP</string> - </attribute> - <layout class="QFormLayout" name="formLayout_2"> - <item row="0" column="0"> - <widget class="QLabel" name="label"> - <property name="text"> - <string>User Agent</string> - </property> - </widget> - </item> - <item row="0" column="1"> - <widget class="QPlainTextEdit" name="userAgent"/> - </item> - <item row="1" column="0"> - <widget class="QLabel" name="label_4"> - <property name="text"> - <string>Accept Language</string> - </property> - </widget> - </item> - <item row="2" column="0"> - <widget class="QLabel" name="label_5"> - <property name="text"> - <string>Cache Type</string> - </property> - </widget> - </item> - <item row="3" column="0"> - <widget class="QLabel" name="label_6"> - <property name="text"> - <string>Cache Size</string> - </property> - </widget> - </item> - <item row="1" column="1"> - <widget class="QPlainTextEdit" name="acceptLanguage"/> - </item> - <item row="2" column="1"> - <widget class="QComboBox" name="cacheType"> - <item> - <property name="text"> - <string>Memory Cache</string> - </property> - </item> - <item> - <property name="text"> - <string>Disk Cache</string> - </property> - </item> - <item> - <property name="text"> - <string>Disabled</string> - </property> - </item> - </widget> - </item> - <item row="3" column="1"> - <widget class="QLineEdit" name="cacheSize"/> - </item> - <item row="6" column="0"> - <widget class="QLabel" name="storagePath_label"> - <property name="text"> - <string>Storage Path</string> - </property> - </widget> - </item> - <item row="6" column="1"> - <widget class="QLineEdit" name="storagePath_lineEdit"> - <property name="enabled"> - <bool>false</bool> - </property> - </widget> - </item> - <item row="4" column="0"> - <widget class="QLabel" name="cachePath_label"> - <property name="text"> - <string>Cache Path</string> - </property> - </widget> - </item> - <item row="4" column="1"> - <widget class="QLineEdit" name="cachePath_lineEdit"> - <property name="enabled"> - <bool>false</bool> - </property> - </widget> - </item> - <item row="5" column="1"> - <widget class="QPushButton" name="clearCache_pushButton"> - <property name="text"> - <string>Clear Cache</string> - </property> - </widget> - </item> - </layout> - </widget> - <widget class="QWidget" name="policiesTab"> - <attribute name="title"> - <string>Cookies</string> - </attribute> - <layout class="QVBoxLayout" name="verticalLayout_3"> - <item> - <layout class="QFormLayout" name="cookies_formLayout"> - <item row="0" column="0"> - <widget class="QLabel" name="label_7"> - <property name="text"> - <string>Cookies</string> - </property> - </widget> - </item> - <item row="0" column="1"> - <widget class="QComboBox" name="cookiePolicy"> - <item> - <property name="text"> - <string>No Persistent Cookies</string> - </property> - </item> - <item> - <property name="text"> - <string>Allow Persistent Cookies</string> - </property> - </item> - <item> - <property name="text"> - <string>Force Persistent Cookies</string> - </property> - </item> - </widget> - </item> - </layout> - </item> - </layout> - </widget> - <widget class="QWidget" name="actionsTab"> - <attribute name="title"> - <string>History</string> - </attribute> - <layout class="QVBoxLayout" name="verticalLayout_2"> - <item> - <widget class="QPushButton" name="clearHistory_pushButton"> - <property name="text"> - <string>Clear History</string> - </property> - </widget> - </item> - <item> - <spacer name="verticalSpacer"> - <property name="orientation"> - <enum>Qt::Vertical</enum> - </property> - <property name="sizeHint" stdset="0"> - <size> - <width>20</width> - <height>40</height> - </size> - </property> - </spacer> - </item> - </layout> - </widget> - </widget> - </item> - <item> - <widget class="QDialogButtonBox" name="buttonBox"> - <property name="standardButtons"> - <set>QDialogButtonBox::Close|QDialogButtonBox::Save</set> - </property> - </widget> - </item> - </layout> - </widget> - <resources/> - <connections/> -</ui> diff --git a/src/mainwindow.cpp b/src/mainwindow.cpp index 913885d..4306afd 100644 --- a/src/mainwindow.cpp +++ b/src/mainwindow.cpp @@ -308,24 +308,25 @@ void MainWindow::handleTitleUpdated(const QString &title) //setWindowTitle(browser->settings()->value("window.title").toString().replace("title", title).replace("profile", tabBar->profile()->name())); } -void MainWindow::addPlugins(QVector<PluginInterface *> &plugins) { - for(PluginInterface *plugin : plugins) { - ProfileInterface *profilePlugin = dynamic_cast<ProfileInterface *>(plugin); - QWidget *w = profilePlugin->createWidget(m_profile.get(), this); - - QAction *profileAction = new QAction(this); - profileAction->setText("Profile Action"); - ui->navigationToolBar->addAction(profileAction); - connect(profileAction, &QAction::triggered, this, [this, w]() { - w->setVisible(!w->isVisible()); - if(w->isVisible()) { - w->adjustSize(); - QPoint pos = ui->navigationToolBar->pos(); - pos.setX(pos.x() + ui->navigationToolBar->width() - w->width()); - pos.setY(pos.y() + ui->navigationToolBar->height()); - w->move(mapToGlobal(pos)); - w->show(); - } - }); +void MainWindow::addPlugins(const QVector<Browser::Plugin> &plugins) +{ + for(const Browser::Plugin &plugin : plugins) { + ProfileInterface *iProfilePlugin = qobject_cast<ProfileInterface *>(plugin.pointer); + if(iProfilePlugin) { + QWidget *w = iProfilePlugin->createWidget(m_profile.get(), this); + + auto *profileAction = new QAction(tr("Profile Action"), this); + ui->navigationToolBar->addAction(profileAction); + connect(profileAction, &QAction::triggered, this, [this, w]() { + w->setVisible(!w->isVisible()); + if(w->isVisible()) { + QPoint pos = ui->navigationToolBar->pos(); + pos.setX(pos.x() + ui->navigationToolBar->width() - w->width()); + pos.setY(pos.y() + ui->navigationToolBar->height()); + w->move(mapToGlobal(pos)); + w->show(); + } + }); + } } } diff --git a/src/mainwindow.h b/src/mainwindow.h index 6d1e190..79773d3 100644 --- a/src/mainwindow.h +++ b/src/mainwindow.h @@ -9,14 +9,15 @@ #ifndef MAINWINDOW_H #define MAINWINDOW_H +#include "browser.h" #include "lib/navigation/navigationbutton.h" #include "webengine/webengineprofile.h" #include "widgets/loadingbar.h" #include "widgets/mainwindowtabbar.h" #include <QMainWindow> #include <QUrl> -#include <memory> #include <interfaces.h> +#include <memory> namespace Ui { @@ -60,7 +61,7 @@ public slots: void setBookmarksWidget(std::shared_ptr<BookmarksWidget> &widget); void setDownloadsWidget(std::shared_ptr<DownloadsWidget> &widget); - void addPlugins(QVector<PluginInterface *> &plugins); + void addPlugins(const QVector<Browser::Plugin> &plugins); void toggleFullscreen(); diff --git a/src/widgets/mainwindowmenubar.cpp b/src/widgets/mainwindowmenubar.cpp index c0bea4f..f8275c0 100644 --- a/src/widgets/mainwindowmenubar.cpp +++ b/src/widgets/mainwindowmenubar.cpp @@ -7,14 +7,9 @@ */ #include "mainwindowmenubar.h" -#include "forms/profileview.h" +#include "downloads/downloadswidget.h" #include "mainwindow.h" -#include <QApplication> #include <QInputDialog> -#include <settings/configuration.h> - -#include "browser.h" -#include "downloads/downloadswidget.h" MainWindowMenuBar::MainWindowMenuBar(std::shared_ptr<Configuration> config, MainWindow *parent) : QMenuBar(parent) @@ -69,11 +64,7 @@ MainWindowMenuBar::MainWindowMenuBar(std::shared_ptr<Configuration> config, Main // Profile menu QMenu *profileMenu = addMenu(tr("Profile")); m_profileAction = profileMenu->addAction(tr("Current profile")); - connect(m_profileAction, &QAction::triggered, this, [parent]() { - ProfileView *dlg = new ProfileView(parent->profile(), parent); - dlg->exec(); - delete dlg; - }); + m_profileAction->setEnabled(false); QMenu *loadMenu = profileMenu->addMenu(tr("Load")); loadMenu->setEnabled(false); |