1
mirror of https://invent.kde.org/network/falkon.git synced 2024-12-20 10:46:35 +01:00

SessionManager: Add Session Manager dialog instead of menu structure

See #2331
This commit is contained in:
David Rosca 2017-06-08 14:12:54 +02:00
parent bc65a0a038
commit 93d4d66054
7 changed files with 505 additions and 137 deletions

View File

@ -81,6 +81,11 @@ void MainMenu::initSuperMenu(QMenu* superMenu) const
superMenu->addAction(m_actions[QSL("File/NewPrivateWindow")]); superMenu->addAction(m_actions[QSL("File/NewPrivateWindow")]);
superMenu->addAction(m_actions[QSL("File/OpenFile")]); superMenu->addAction(m_actions[QSL("File/OpenFile")]);
superMenu->addSeparator(); superMenu->addSeparator();
QMenu* sessionsSubmenu = new QMenu(tr("Sessions"));
connect(sessionsSubmenu, SIGNAL(aboutToShow()), mApp->sessionManager(), SLOT(aboutToShowSessionsMenu()));
superMenu->addMenu(sessionsSubmenu);
superMenu->addAction(m_actions[QSL("File/SessionManager")]);
superMenu->addSeparator();
superMenu->addAction(m_actions[QSL("File/SendLink")]); superMenu->addAction(m_actions[QSL("File/SendLink")]);
superMenu->addAction(m_actions[QSL("File/Print")]); superMenu->addAction(m_actions[QSL("File/Print")]);
superMenu->addSeparator(); superMenu->addSeparator();
@ -529,17 +534,13 @@ void MainMenu::init()
m_menuFile->addSeparator(); m_menuFile->addSeparator();
if (!mApp->isPrivate()) { if (!mApp->isPrivate()) {
action = new QAction(tr("New Session..."), this);
connect(action, SIGNAL(triggered()), mApp->sessionManager(), SLOT(newSession()));
m_actions[QSL("File/NewSession")] = action;
m_menuFile->addAction(action);
action = new QAction(tr("Save Session..."), this);
connect(action, SIGNAL(triggered()), mApp->sessionManager(), SLOT(saveSession()));
m_actions[QSL("File/SaveSession")] = action;
m_menuFile->addAction(action);
QMenu* sessionsSubmenu = new QMenu(tr("Sessions")); QMenu* sessionsSubmenu = new QMenu(tr("Sessions"));
connect(sessionsSubmenu, SIGNAL(aboutToShow()), mApp->sessionManager(), SLOT(aboutToShowSessionsMenu())); connect(sessionsSubmenu, SIGNAL(aboutToShow()), mApp->sessionManager(), SLOT(aboutToShowSessionsMenu()));
m_menuFile->addMenu(sessionsSubmenu); m_menuFile->addMenu(sessionsSubmenu);
action = new QAction(tr("Session Manager"), this);
connect(action, SIGNAL(triggered()), mApp->sessionManager(), SLOT(openSessionManagerDialog()));
m_actions[QSL("File/SessionManager")] = action;
m_menuFile->addAction(action);
m_menuFile->addSeparator(); m_menuFile->addSeparator();
} }

View File

@ -167,6 +167,7 @@ SOURCES += \
session/recoveryjsobject.cpp \ session/recoveryjsobject.cpp \
session/restoremanager.cpp \ session/restoremanager.cpp \
session/sessionmanager.cpp \ session/sessionmanager.cpp \
session/sessionmanagerdialog.cpp \
sidebar/bookmarkssidebar.cpp \ sidebar/bookmarkssidebar.cpp \
sidebar/historysidebar.cpp \ sidebar/historysidebar.cpp \
sidebar/sidebar.cpp \ sidebar/sidebar.cpp \
@ -202,11 +203,13 @@ SOURCES += \
tools/progressbar.cpp \ tools/progressbar.cpp \
tools/qzregexp.cpp \ tools/qzregexp.cpp \
tools/qztools.cpp \ tools/qztools.cpp \
tools/removeitemfocusdelegate.cpp \
tools/scripts.cpp \ tools/scripts.cpp \
tools/sqldatabase.cpp \ tools/sqldatabase.cpp \
tools/toolbutton.cpp \ tools/toolbutton.cpp \
tools/treewidget.cpp \ tools/treewidget.cpp \
tools/widget.cpp \ tools/widget.cpp \
tools/wheelhelper.cpp \
webengine/javascript/autofilljsobject.cpp \ webengine/javascript/autofilljsobject.cpp \
webengine/javascript/externaljsobject.cpp \ webengine/javascript/externaljsobject.cpp \
webengine/loadrequest.cpp \ webengine/loadrequest.cpp \
@ -219,7 +222,6 @@ SOURCES += \
webtab/searchtoolbar.cpp \ webtab/searchtoolbar.cpp \
webtab/tabbedwebview.cpp \ webtab/tabbedwebview.cpp \
webtab/webtab.cpp \ webtab/webtab.cpp \
tools/wheelhelper.cpp \
HEADERS += \ HEADERS += \
3rdparty/fancytabwidget.h \ 3rdparty/fancytabwidget.h \
@ -349,6 +351,7 @@ HEADERS += \
session/recoveryjsobject.h \ session/recoveryjsobject.h \
session/restoremanager.h \ session/restoremanager.h \
session/sessionmanager.h \ session/sessionmanager.h \
session/sessionmanagerdialog.h \
sidebar/bookmarkssidebar.h \ sidebar/bookmarkssidebar.h \
sidebar/historysidebar.h \ sidebar/historysidebar.h \
sidebar/sidebar.h \ sidebar/sidebar.h \
@ -385,11 +388,13 @@ HEADERS += \
tools/progressbar.h \ tools/progressbar.h \
tools/qzregexp.h \ tools/qzregexp.h \
tools/qztools.h \ tools/qztools.h \
tools/removeitemfocusdelegate.h \
tools/scripts.h \ tools/scripts.h \
tools/sqldatabase.h \ tools/sqldatabase.h \
tools/toolbutton.h \ tools/toolbutton.h \
tools/treewidget.h \ tools/treewidget.h \
tools/widget.h \ tools/widget.h \
tools/wheelhelper.h \
webengine/javascript/autofilljsobject.h \ webengine/javascript/autofilljsobject.h \
webengine/javascript/externaljsobject.h \ webengine/javascript/externaljsobject.h \
webengine/loadrequest.h \ webengine/loadrequest.h \
@ -402,7 +407,6 @@ HEADERS += \
webtab/searchtoolbar.h \ webtab/searchtoolbar.h \
webtab/tabbedwebview.h \ webtab/tabbedwebview.h \
webtab/webtab.h \ webtab/webtab.h \
tools/wheelhelper.h \
FORMS += \ FORMS += \
adblock/adblockaddsubscriptiondialog.ui \ adblock/adblockaddsubscriptiondialog.ui \
@ -437,6 +441,7 @@ FORMS += \
preferences/preferences.ui \ preferences/preferences.ui \
preferences/thememanager.ui \ preferences/thememanager.ui \
preferences/useragentdialog.ui \ preferences/useragentdialog.ui \
session/sessionmanagerdialog.ui \
sidebar/bookmarkssidebar.ui \ sidebar/bookmarkssidebar.ui \
sidebar/historysidebar.ui \ sidebar/historysidebar.ui \
tools/certificateinfowidget.ui \ tools/certificateinfowidget.ui \

View File

@ -20,6 +20,7 @@
#include "mainapplication.h" #include "mainapplication.h"
#include "restoremanager.h" #include "restoremanager.h"
#include "sessionmanager.h" #include "sessionmanager.h"
#include "sessionmanagerdialog.h"
#include "settings.h" #include "settings.h"
#include <QAction> #include <QAction>
@ -42,99 +43,28 @@ SessionManager::SessionManager(QObject* parent)
{ {
QFileSystemWatcher* sessionFilesWatcher = new QFileSystemWatcher({DataPaths::path(DataPaths::Sessions)}, this); QFileSystemWatcher* sessionFilesWatcher = new QFileSystemWatcher({DataPaths::path(DataPaths::Sessions)}, this);
connect(sessionFilesWatcher, SIGNAL(directoryChanged(QString)), this, SLOT(sessionsDirectoryChanged())); connect(sessionFilesWatcher, SIGNAL(directoryChanged(QString)), this, SLOT(sessionsDirectoryChanged()));
connect(sessionFilesWatcher, &QFileSystemWatcher::directoryChanged, this, &SessionManager::sessionsMetaDataChanged);
loadSettings(); loadSettings();
} }
static void addSessionSubmenu(QObject* receiver, QMenu* menu, const QString &title, const QString &filePath, const QFileInfo &lastActiveSessionFileInfo)
{
QMenu* sessionSubmenu = new QMenu(title, menu);
QObject::connect(sessionSubmenu, SIGNAL(aboutToShow()), receiver, SLOT(aboutToShowSessionSubmenu()));
QAction* action = menu->addMenu(sessionSubmenu);
action->setData(filePath);
action->setCheckable(true);
action->setChecked(QFileInfo(filePath) == lastActiveSessionFileInfo);
}
static void addSessionsMetaDataToMenu(QObject* receiver, QMenu* menu, const QFileInfo &lastActiveSessionFileInfo, const QList<SessionManager::SessionMetaData> &sessionsMetaDataList)
{
for (const SessionManager::SessionMetaData &metaData : sessionsMetaDataList) {
addSessionSubmenu(receiver, menu, metaData.name, metaData.filePath, lastActiveSessionFileInfo);
}
}
void SessionManager::aboutToShowSessionsMenu() void SessionManager::aboutToShowSessionsMenu()
{ {
QMenu* menu = qobject_cast<QMenu*>(sender()); QMenu* menu = qobject_cast<QMenu*>(sender());
menu->clear(); menu->clear();
const QFileInfo lastActiveSessionInfo(m_lastActiveSessionPath); QActionGroup *group = new QActionGroup(menu);
fillSessionsMetaDataListIfNeeded(); const auto sessions = sessionMetaData(/*withBackups*/ false);
for (const SessionManager::SessionMetaData &metaData : sessions) {
addSessionsMetaDataToMenu(this, menu, lastActiveSessionInfo, m_sessionsMetaDataList); QAction* action = menu->addAction(metaData.name);
action->setCheckable(true);
menu->addSeparator(); action->setChecked(metaData.isActive);
group->addAction(action);
if (QFile::exists(m_firstBackupSession)) connect(action, &QAction::triggered, this, [=]() {
addSessionSubmenu(this, menu, tr("First Backup"), m_firstBackupSession, lastActiveSessionInfo); switchToSession(metaData.filePath);
if (QFile::exists(m_secondBackupSession)) });
addSessionSubmenu(this, menu, tr("Second Backup"), m_secondBackupSession, lastActiveSessionInfo);
}
void SessionManager::aboutToShowSessionSubmenu()
{
QMenu* menu = qobject_cast<QMenu*>(sender());
menu->clear();
const QString sessionFilePath = menu->menuAction()->data().toString();
const QFileInfo currentSessionFileInfo(m_lastActiveSessionPath);
const QFileInfo sessionFileInfo(sessionFilePath);
QList<QAction*> actions;
QAction* action;
if (sessionFileInfo != currentSessionFileInfo || mApp->restoreManager()) {
if (sessionFileInfo != QFileInfo(m_firstBackupSession) && sessionFileInfo != QFileInfo(m_secondBackupSession)) {
action = new QAction(SessionManager::tr("Switch To"), menu);
action->setData(sessionFilePath);
QObject::connect(action, SIGNAL(triggered(bool)), this, SLOT(switchToSession()));
actions << action;
}
action = new QAction(SessionManager::tr("Open"), menu);
action->setData(sessionFilePath);
QObject::connect(action, SIGNAL(triggered(bool)), this, SLOT(openSession()));
actions << action;
action = new QAction(menu);
action->setSeparator(true);
actions << action;
} }
action = new QAction(SessionManager::tr("Clone"), menu);
action->setData(sessionFilePath);
QObject::connect(action, SIGNAL(triggered(bool)), this, SLOT(cloneSession()));
actions << action;
if (sessionFileInfo != currentSessionFileInfo) {
action = new QAction(SessionManager::tr("Rename"), menu);
action->setData(sessionFilePath);
QObject::connect(action, SIGNAL(triggered(bool)), this, SLOT(renameSession()));
actions << action;
}
if (sessionFileInfo != currentSessionFileInfo && sessionFileInfo != QFileInfo(defaultSessionPath()) &&
sessionFileInfo != QFileInfo(m_firstBackupSession) && sessionFileInfo != QFileInfo(m_secondBackupSession)) {
action = new QAction(SessionManager::tr("Remove"), menu);
action->setData(sessionFilePath);
QObject::connect(action, SIGNAL(triggered(bool)), this, SLOT(deleteSession()));
actions << action;
}
menu->addActions(actions);
} }
void SessionManager::sessionsDirectoryChanged() void SessionManager::sessionsDirectoryChanged()
@ -142,15 +72,6 @@ void SessionManager::sessionsDirectoryChanged()
m_sessionsMetaDataList.clear(); m_sessionsMetaDataList.clear();
} }
void SessionManager::switchToSession()
{
QAction* action = qobject_cast<QAction*>(sender());
if (!action)
return;
openSession(action->data().toString(), true);
}
void SessionManager::openSession(QString sessionFilePath, bool switchSession) void SessionManager::openSession(QString sessionFilePath, bool switchSession)
{ {
if (sessionFilePath.isEmpty()) { if (sessionFilePath.isEmpty()) {
@ -161,6 +82,10 @@ void SessionManager::openSession(QString sessionFilePath, bool switchSession)
sessionFilePath = action->data().toString(); sessionFilePath = action->data().toString();
} }
if (isActive(sessionFilePath)) {
return;
}
QVector<RestoreManager::WindowData> sessionData; QVector<RestoreManager::WindowData> sessionData;
RestoreManager::createFromFile(sessionFilePath, sessionData); RestoreManager::createFromFile(sessionFilePath, sessionData);
@ -178,6 +103,7 @@ void SessionManager::openSession(QString sessionFilePath, bool switchSession)
} }
m_lastActiveSessionPath = QFileInfo(sessionFilePath).canonicalFilePath(); m_lastActiveSessionPath = QFileInfo(sessionFilePath).canonicalFilePath();
m_sessionsMetaDataList.clear();
} }
mApp->openSession(window, sessionData); mApp->openSession(window, sessionData);
@ -214,34 +140,15 @@ void SessionManager::renameSession(QString sessionFilePath, bool clone)
QMessageBox::information(mApp->activeWindow(), tr("Error!"), tr("An error occurred when cloning session file.")); QMessageBox::information(mApp->activeWindow(), tr("Error!"), tr("An error occurred when cloning session file."));
return; return;
} }
} } else {
else if (!QFile::rename(sessionFilePath, newSessionPath)) { if (!QFile::rename(sessionFilePath, newSessionPath)) {
QMessageBox::information(mApp->activeWindow(), tr("Error!"), tr("An error occurred when renaming session file.")); QMessageBox::information(mApp->activeWindow(), tr("Error!"), tr("An error occurred when renaming session file."));
return; return;
} }
} if (isActive(sessionFilePath)) {
m_lastActiveSessionPath = newSessionPath;
void SessionManager::cloneSession() m_sessionsMetaDataList.clear();
{ }
QAction* action = qobject_cast<QAction*>(sender());
if (!action)
return;
renameSession(action->data().toString(), true);
}
void SessionManager::deleteSession()
{
QAction* action = qobject_cast<QAction*>(sender());
if (!action)
return;
const QString filePath = action->data().toString();
QMessageBox::StandardButton result = QMessageBox::information(mApp->activeWindow(), tr("Warning!"), tr("Are you sure to delete following session?\n%1")
.arg(QDir::toNativeSeparators(filePath)), QMessageBox::Yes | QMessageBox::No);
if (result == QMessageBox::Yes) {
QFile::remove(filePath);
} }
} }
@ -265,6 +172,25 @@ void SessionManager::saveSession()
writeCurrentSession(filePath); writeCurrentSession(filePath);
} }
void SessionManager::switchToSession(const QString &filePath)
{
openSession(filePath, /*switchSession*/ true);
}
void SessionManager::cloneSession(const QString &filePath)
{
renameSession(filePath, /*clone*/ true);
}
void SessionManager::deleteSession(const QString &filePath)
{
QMessageBox::StandardButton result = QMessageBox::information(mApp->activeWindow(), tr("Warning!"), tr("Are you sure to delete following session?\n%1")
.arg(QDir::toNativeSeparators(filePath)), QMessageBox::Yes | QMessageBox::No);
if (result == QMessageBox::Yes) {
QFile::remove(filePath);
}
}
void SessionManager::newSession() void SessionManager::newSession()
{ {
bool ok; bool ok;
@ -294,6 +220,40 @@ void SessionManager::newSession()
autoSaveLastSession(); autoSaveLastSession();
} }
QList<SessionManager::SessionMetaData> SessionManager::sessionMetaData(bool withBackups)
{
fillSessionsMetaDataListIfNeeded();
auto out = m_sessionsMetaDataList;
if (withBackups && QFile::exists(m_firstBackupSession)) {
SessionMetaData data;
data.name = tr("First Backup");
data.filePath = m_firstBackupSession;
data.isBackup = true;
out.append(data);
}
if (withBackups && QFile::exists(m_secondBackupSession)) {
SessionMetaData data;
data.name = tr("Second Backup");
data.filePath = m_secondBackupSession;
data.isBackup = true;
out.append(data);
}
return out;
}
bool SessionManager::isActive(const QString &filePath) const
{
return QFileInfo(filePath) == QFileInfo(m_lastActiveSessionPath);
}
bool SessionManager::isActive(const QFileInfo &fileInfo) const
{
return fileInfo == QFileInfo(m_lastActiveSessionPath);
}
void SessionManager::fillSessionsMetaDataListIfNeeded() void SessionManager::fillSessionsMetaDataListIfNeeded()
{ {
if (!m_sessionsMetaDataList.isEmpty()) if (!m_sessionsMetaDataList.isEmpty())
@ -316,12 +276,18 @@ void SessionManager::fillSessionsMetaDataListIfNeeded()
SessionMetaData metaData; SessionMetaData metaData;
metaData.name = fileInfo.baseName(); metaData.name = fileInfo.baseName();
if (fileInfo == QFileInfo(defaultSessionPath())) if (fileInfo == QFileInfo(defaultSessionPath())) {
metaData.name = tr("Default Session"); metaData.name = tr("Default Session");
else if (fileNames.contains(fileInfo.baseName())) metaData.isDefault = true;
} else if (fileNames.contains(fileInfo.baseName())) {
metaData.name = fileInfo.fileName(); metaData.name = fileInfo.fileName();
else } else {
metaData.name = fileInfo.baseName(); metaData.name = fileInfo.baseName();
}
if (isActive(fileInfo)) {
metaData.isActive = true;
}
fileNames << metaData.name; fileNames << metaData.name;
metaData.filePath = fileInfo.canonicalFilePath(); metaData.filePath = fileInfo.canonicalFilePath();
@ -385,6 +351,12 @@ void SessionManager::writeCurrentSession(const QString &filePath)
file.commit(); file.commit();
} }
void SessionManager::openSessionManagerDialog()
{
SessionManagerDialog *dialog = new SessionManagerDialog(mApp->getWindow());
dialog->open();
}
void SessionManager::autoSaveLastSession() void SessionManager::autoSaveLastSession()
{ {
if (mApp->isPrivate() || mApp->isRestoring() || mApp->windowCount() == 0 || mApp->restoreManager()) { if (mApp->isPrivate() || mApp->isRestoring() || mApp->windowCount() == 0 || mApp->restoreManager()) {

View File

@ -22,7 +22,7 @@
class QAction; class QAction;
class QMenu; class QMenu;
class QFileInfo;
class QUPZILLA_EXPORT SessionManager : public QObject class QUPZILLA_EXPORT SessionManager : public QObject
{ {
@ -34,6 +34,9 @@ public:
struct SessionMetaData { struct SessionMetaData {
QString name; QString name;
QString filePath; QString filePath;
bool isActive = false;
bool isDefault = false;
bool isBackup = false;
}; };
void loadSettings(); void loadSettings();
@ -46,22 +49,30 @@ public:
void backupSavedSessions(); void backupSavedSessions();
void writeCurrentSession(const QString &filePath); void writeCurrentSession(const QString &filePath);
signals:
void sessionsMetaDataChanged();
public slots: public slots:
void autoSaveLastSession(); void autoSaveLastSession();
void openSessionManagerDialog();
private slots: private slots:
void aboutToShowSessionsMenu(); void aboutToShowSessionsMenu();
void aboutToShowSessionSubmenu();
void sessionsDirectoryChanged(); void sessionsDirectoryChanged();
void switchToSession();
void openSession(QString sessionFilePath = QString(), bool switchSession = false); void openSession(QString sessionFilePath = QString(), bool switchSession = false);
void renameSession(QString sessionFilePath = QString(), bool clone = false); void renameSession(QString sessionFilePath = QString(), bool clone = false);
void cloneSession();
void deleteSession();
void saveSession(); void saveSession();
void switchToSession(const QString &filePath);
void cloneSession(const QString &filePath);
void deleteSession(const QString &filePath);
void newSession(); void newSession();
QList<SessionMetaData> sessionMetaData(bool withBackups = true);
private: private:
bool isActive(const QString &filePath) const;
bool isActive(const QFileInfo &fileInfo) const;
void fillSessionsMetaDataListIfNeeded(); void fillSessionsMetaDataListIfNeeded();
QList<SessionMetaData> m_sessionsMetaDataList; QList<SessionMetaData> m_sessionsMetaDataList;
@ -69,6 +80,8 @@ private:
QString m_firstBackupSession; QString m_firstBackupSession;
QString m_secondBackupSession; QString m_secondBackupSession;
QString m_lastActiveSessionPath; QString m_lastActiveSessionPath;
friend class SessionManagerDialog;
}; };
#endif // SESSIONMANAGER_H #endif // SESSIONMANAGER_H

View File

@ -0,0 +1,182 @@
/* ============================================================
* QupZilla - Qt web browser
* Copyright (C) 2017 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/>.
* ============================================================ */
#include "sessionmanagerdialog.h"
#include "ui_sessionmanagerdialog.h"
#include "mainapplication.h"
#include "sessionmanager.h"
#include "removeitemfocusdelegate.h"
#include <QFileInfo>
#include <QDateTime>
SessionManagerDialog::SessionManagerDialog(QWidget *parent) :
QDialog(parent),
ui(new Ui::SessionManagerDialog)
{
ui->setupUi(this);
setAttribute(Qt::WA_DeleteOnClose);
ui->treeWidget->setItemDelegate(new RemoveItemFocusDelegate(ui->treeWidget));
connect(ui->newButton, &QPushButton::clicked, this, &SessionManagerDialog::newSession);
connect(ui->renameButton, &QPushButton::clicked, this, &SessionManagerDialog::renameSession);
connect(ui->cloneButton, &QPushButton::clicked, this, &SessionManagerDialog::cloneSession);
connect(ui->deleteButton, &QPushButton::clicked, this, &SessionManagerDialog::deleteSession);
connect(ui->switchToButton, &QPushButton::clicked, this, &SessionManagerDialog::switchToSession);
connect(ui->treeWidget, &QTreeWidget::currentItemChanged, this, &SessionManagerDialog::updateButtons);
refresh();
connect(mApp->sessionManager(), &SessionManager::sessionsMetaDataChanged, this, &SessionManagerDialog::refresh);
}
SessionManagerDialog::~SessionManagerDialog()
{
delete ui;
}
void SessionManagerDialog::newSession()
{
mApp->sessionManager()->newSession();
}
void SessionManagerDialog::renameSession()
{
QTreeWidgetItem *item = ui->treeWidget->currentItem();
if (!item) {
return;
}
const QString filePath = item->data(0, SessionFileRole).toString();
if (!filePath.isEmpty()) {
mApp->sessionManager()->renameSession(filePath);
}
}
void SessionManagerDialog::cloneSession()
{
QTreeWidgetItem *item = ui->treeWidget->currentItem();
if (!item) {
return;
}
const QString filePath = item->data(0, SessionFileRole).toString();
if (!filePath.isEmpty()) {
mApp->sessionManager()->cloneSession(filePath);
}
}
void SessionManagerDialog::deleteSession()
{
QTreeWidgetItem *item = ui->treeWidget->currentItem();
if (!item) {
return;
}
const QString filePath = item->data(0, SessionFileRole).toString();
if (!filePath.isEmpty()) {
mApp->sessionManager()->deleteSession(filePath);
}
}
void SessionManagerDialog::switchToSession()
{
QTreeWidgetItem *item = ui->treeWidget->currentItem();
if (!item) {
return;
}
const QString filePath = item->data(0, SessionFileRole).toString();
if (!filePath.isEmpty()) {
close();
mApp->sessionManager()->switchToSession(filePath);
}
}
void SessionManagerDialog::refresh()
{
ui->treeWidget->clear();
const auto sessions = mApp->sessionManager()->sessionMetaData();
for (const auto &session : sessions) {
QTreeWidgetItem *item = new QTreeWidgetItem;
item->setText(0, session.name);
item->setText(1, QFileInfo(session.filePath).lastModified().toString(Qt::DefaultLocaleShortDate));
item->setData(0, SessionFileRole, session.filePath);
item->setData(0, IsBackupSessionRole, session.isBackup);
item->setData(0, IsActiveSessionRole, session.isActive);
item->setData(0, IsDefaultSessionRole, session.isDefault);
updateItem(item);
ui->treeWidget->addTopLevelItem(item);
}
updateButtons();
}
void SessionManagerDialog::updateButtons()
{
QTreeWidgetItem *item = ui->treeWidget->currentItem();
const bool isBackup = item && item->data(0, IsBackupSessionRole).toBool();
const bool isActive = item && item->data(0, IsActiveSessionRole).toBool();
const bool isDefault = item && item->data(0, IsDefaultSessionRole).toBool();
ui->renameButton->setEnabled(item && !isDefault && !isBackup);
ui->cloneButton->setEnabled(item && !isBackup);
ui->deleteButton->setEnabled(item && !isBackup && !isDefault && !isActive);
ui->switchToButton->setEnabled(item && !isActive && !isBackup);
}
void SessionManagerDialog::updateItem(QTreeWidgetItem *item)
{
const bool isBackup = item->data(0, IsBackupSessionRole).toBool();
const bool isActive = item->data(0, IsActiveSessionRole).toBool();
const bool isDefault = item->data(0, IsDefaultSessionRole).toBool();
QFont font = item->font(0);
if (isBackup) {
const QColor color = palette().color(QPalette::Disabled, QPalette::WindowText);
item->setForeground(0, color);
item->setForeground(1, color);
}
if (isActive) {
font.setBold(true);
item->setFont(0, font);
item->setFont(1, font);
}
if (isDefault) {
font.setItalic(true);
item->setFont(0, font);
item->setFont(1, font);
}
}
void SessionManagerDialog::showEvent(QShowEvent *e)
{
QDialog::showEvent(e);
resizeViewHeader();
}
void SessionManagerDialog::resizeEvent(QResizeEvent *e)
{
QDialog::resizeEvent(e);
resizeViewHeader();
}
void SessionManagerDialog::resizeViewHeader()
{
const int headerWidth = ui->treeWidget->header()->width();
ui->treeWidget->header()->resizeSection(0, headerWidth - headerWidth / 2.5);
}

View File

@ -0,0 +1,62 @@
/* ============================================================
* QupZilla - Qt web browser
* Copyright (C) 2017 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/>.
* ============================================================ */
#ifndef SESSIONMANAGERDIALOG_H
#define SESSIONMANAGERDIALOG_H
#include <QDialog>
namespace Ui {
class SessionManagerDialog;
}
class QTreeWidgetItem;
class SessionManagerDialog : public QDialog
{
Q_OBJECT
public:
explicit SessionManagerDialog(QWidget *parent = 0);
~SessionManagerDialog();
private:
enum Roles {
SessionFileRole = Qt::UserRole + 10,
IsBackupSessionRole,
IsActiveSessionRole,
IsDefaultSessionRole
};
void newSession();
void renameSession();
void cloneSession();
void deleteSession();
void switchToSession();
void refresh();
void updateButtons();
void updateItem(QTreeWidgetItem *item);
void showEvent(QShowEvent *e) override;
void resizeEvent(QResizeEvent *e) override;
void resizeViewHeader();
Ui::SessionManagerDialog *ui;
};
#endif // SESSIONMANAGERDIALOG_H

View File

@ -0,0 +1,133 @@
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>SessionManagerDialog</class>
<widget class="QDialog" name="SessionManagerDialog">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>466</width>
<height>323</height>
</rect>
</property>
<property name="windowTitle">
<string>Session Manager</string>
</property>
<layout class="QGridLayout" name="gridLayout">
<item row="0" column="0">
<widget class="QTreeWidget" name="treeWidget">
<property name="rootIsDecorated">
<bool>false</bool>
</property>
<column>
<property name="text">
<string>Session</string>
</property>
</column>
<column>
<property name="text">
<string>Last Modified</string>
</property>
</column>
</widget>
</item>
<item row="0" column="1">
<layout class="QVBoxLayout" name="verticalLayout">
<item>
<widget class="QPushButton" name="newButton">
<property name="text">
<string>New</string>
</property>
</widget>
</item>
<item>
<widget class="QPushButton" name="renameButton">
<property name="text">
<string>Rename</string>
</property>
</widget>
</item>
<item>
<widget class="QPushButton" name="cloneButton">
<property name="text">
<string>Clone</string>
</property>
</widget>
</item>
<item>
<widget class="QPushButton" name="deleteButton">
<property name="text">
<string>Delete</string>
</property>
</widget>
</item>
<item>
<widget class="QPushButton" name="switchToButton">
<property name="text">
<string>Switch to</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>
</item>
<item row="1" column="0" colspan="2">
<widget class="QDialogButtonBox" name="buttonBox">
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
<property name="standardButtons">
<set>QDialogButtonBox::Close</set>
</property>
</widget>
</item>
</layout>
</widget>
<resources/>
<connections>
<connection>
<sender>buttonBox</sender>
<signal>accepted()</signal>
<receiver>SessionManagerDialog</receiver>
<slot>accept()</slot>
<hints>
<hint type="sourcelabel">
<x>248</x>
<y>254</y>
</hint>
<hint type="destinationlabel">
<x>157</x>
<y>274</y>
</hint>
</hints>
</connection>
<connection>
<sender>buttonBox</sender>
<signal>rejected()</signal>
<receiver>SessionManagerDialog</receiver>
<slot>reject()</slot>
<hints>
<hint type="sourcelabel">
<x>316</x>
<y>260</y>
</hint>
<hint type="destinationlabel">
<x>286</x>
<y>274</y>
</hint>
</hints>
</connection>
</connections>
</ui>