diff options
Diffstat (limited to 'src/useragent/useragentmanager.cpp')
-rw-r--r-- | src/useragent/useragentmanager.cpp | 138 |
1 files changed, 138 insertions, 0 deletions
diff --git a/src/useragent/useragentmanager.cpp b/src/useragent/useragentmanager.cpp new file mode 100644 index 00000000..db6e0708 --- /dev/null +++ b/src/useragent/useragentmanager.cpp @@ -0,0 +1,138 @@ +/* ============================================================ +* +* This file is a part of the rekonq project +* +* Copyright (C) 2011 by Andrea Diamantini <adjam7 at gmail dot 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 2 of +* the License or (at your option) version 3 or any later version +* accepted by the membership of KDE e.V. (or its successor approved +* by the membership of KDE e.V.), which shall act as a proxy +* defined in Section 14 of version 3 of the license. +* +* 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/>. +* +* ============================================================ */ + + +// Self Includes +#include "useragentmanager.h" +#include "useragentmanager.moc" + +// Local Includes +#include "useragentinfo.h" +#include "useragentwidget.h" +#include "application.h" +#include "mainwindow.h" +#include "webtab.h" + +// KDE Includes +#include <KAction> +#include <KDialog> +#include <KMenu> + + +UserAgentManager::UserAgentManager(QObject *parent) + : QObject(parent) + , _uaSettingsAction(0) + , _uaMenu(new KMenu) +{ + _uaSettingsAction = new KAction(KIcon("preferences-web-browser-identification"), i18n("Browser Identification"), this); + connect(_uaSettingsAction, SIGNAL(triggered(bool)), this, SLOT(showSettings())); + + connect(_uaMenu, SIGNAL(aboutToShow()), this, SLOT(populateUserAgentMenu())); +} + + +UserAgentManager::~UserAgentManager() +{ + delete _uaMenu; +} + + +KMenu *UserAgentManager::userAgentMenu() +{ + return _uaMenu; +} + + +void UserAgentManager::showSettings() +{ + QPointer<KDialog> dialog = new KDialog; + dialog->setCaption(i18nc("@title:window", "User Agent Settings")); + dialog->setButtons(KDialog::Ok); + + UserAgentWidget widget; + dialog->setMainWidget(&widget); + dialog->exec(); + + dialog->deleteLater(); +} + + +void UserAgentManager::populateUserAgentMenu() +{ + bool defaultUA = true; + KUrl url = rApp->mainWindow()->currentTab()->url(); + + QAction *a, *defaultAction; + + // just to be sure... + _uaMenu->clear(); + + defaultAction = new QAction(i18nc("Default rekonq user agent", "Default"), this); + defaultAction->setData(-1); + defaultAction->setCheckable(true); + connect(defaultAction, SIGNAL(triggered(bool)), this, SLOT(setUserAgent())); + + _uaMenu->addAction(defaultAction); + _uaMenu->addSeparator(); + + UserAgentInfo uaInfo; + QStringList UAlist = uaInfo.availableUserAgents(); + int uaIndex = uaInfo.uaIndexForHost(url.host()); + + for (int i = 0; i < UAlist.count(); ++i) + { + QString uaDesc = UAlist.at(i); + + a = new QAction(uaDesc, this); + a->setData(i); + a->setCheckable(true); + connect(a, SIGNAL(triggered(bool)), this, SLOT(setUserAgent())); + + if (i == uaIndex) + { + a->setChecked(true); + defaultUA = false; + } + _uaMenu->addAction(a); + } + defaultAction->setChecked(defaultUA); + + _uaMenu->addSeparator(); + _uaMenu->addAction(_uaSettingsAction); +} + + +void UserAgentManager::setUserAgent() +{ + QAction *sender = static_cast<QAction *>(QObject::sender()); + + QString desc = sender->text(); + int uaIndex = sender->data().toInt(); + + KUrl url = rApp->mainWindow()->currentTab()->url(); + UserAgentInfo uaInfo; + uaInfo.setUserAgentForHost(uaIndex, url.host()); + rApp->mainWindow()->currentTab()->page()->triggerAction(QWebPage::Reload); +} |