Work on download manager.

This commit is contained in:
Martin Rotter 2015-01-04 19:47:06 +01:00
parent 44725dbb5a
commit 28ffb4d6e3
11 changed files with 59 additions and 9 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

View File

@ -87,6 +87,7 @@ QList<QAction*> FormMain::allActions() {
// Add basic actions. // Add basic actions.
actions << m_ui->m_actionSettings; actions << m_ui->m_actionSettings;
actions << m_ui->m_actionDownloadManager;
actions << m_ui->m_actionImportFeeds; actions << m_ui->m_actionImportFeeds;
actions << m_ui->m_actionExportFeeds; actions << m_ui->m_actionExportFeeds;
actions << m_ui->m_actionRestoreDatabaseSettings; actions << m_ui->m_actionRestoreDatabaseSettings;
@ -206,6 +207,7 @@ void FormMain::setupIcons() {
IconFactory *icon_theme_factory = qApp->icons(); IconFactory *icon_theme_factory = qApp->icons();
// Setup icons of this main window. // Setup icons of this main window.
m_ui->m_actionDownloadManager->setIcon(icon_theme_factory->fromTheme("download-manager"));
m_ui->m_actionSettings->setIcon(icon_theme_factory->fromTheme("application-settings")); m_ui->m_actionSettings->setIcon(icon_theme_factory->fromTheme("application-settings"));
m_ui->m_actionQuit->setIcon(icon_theme_factory->fromTheme("application-exit")); m_ui->m_actionQuit->setIcon(icon_theme_factory->fromTheme("application-exit"));
m_ui->m_actionRestart->setIcon(icon_theme_factory->fromTheme("go-refresh")); m_ui->m_actionRestart->setIcon(icon_theme_factory->fromTheme("go-refresh"));
@ -350,6 +352,7 @@ void FormMain::createConnections() {
// Menu "Tools" connections. // Menu "Tools" connections.
connect(m_ui->m_actionSettings, SIGNAL(triggered()), this, SLOT(showSettings())); connect(m_ui->m_actionSettings, SIGNAL(triggered()), this, SLOT(showSettings()));
connect(m_ui->m_actionDownloadManager, SIGNAL(triggered()), m_ui->m_tabWidget, SLOT(showDownloadManager()));
// Menu "Help" connections. // Menu "Help" connections.
connect(m_ui->m_actionAboutGuard, SIGNAL(triggered()), this, SLOT(showAbout())); connect(m_ui->m_actionAboutGuard, SIGNAL(triggered()), this, SLOT(showAbout()));

View File

@ -100,6 +100,7 @@
<addaction name="m_actionSettings"/> <addaction name="m_actionSettings"/>
<addaction name="separator"/> <addaction name="separator"/>
<addaction name="m_actionDefragmentDatabase"/> <addaction name="m_actionDefragmentDatabase"/>
<addaction name="m_actionDownloadManager"/>
</widget> </widget>
<widget class="QMenu" name="m_menuWebBrowser"> <widget class="QMenu" name="m_menuWebBrowser">
<property name="title"> <property name="title">
@ -637,6 +638,11 @@
<string notr="true"/> <string notr="true"/>
</property> </property>
</action> </action>
<action name="m_actionDownloadManager">
<property name="text">
<string>&amp;Downloads</string>
</property>
</action>
</widget> </widget>
<customwidgets> <customwidgets>
<customwidget> <customwidget>

View File

@ -37,6 +37,7 @@ TabBar::~TabBar() {
void TabBar::setTabType(int index, const TabBar::TabType &type) { void TabBar::setTabType(int index, const TabBar::TabType &type) {
switch (type) { switch (type) {
case TabBar::DownloadManager:
case TabBar::Closable: { case TabBar::Closable: {
PlainToolButton *close_button = new PlainToolButton(this); PlainToolButton *close_button = new PlainToolButton(this);
@ -46,9 +47,7 @@ void TabBar::setTabType(int index, const TabBar::TabType &type) {
close_button->setFixedSize(iconSize()); close_button->setFixedSize(iconSize());
// Close underlying tab when button is clicked. // Close underlying tab when button is clicked.
connect(close_button, SIGNAL(clicked()), connect(close_button, SIGNAL(clicked()),this, SLOT(closeTabViaButton()));
this, SLOT(closeTabViaButton()));
setTabButton(index, QTabBar::RightSide, close_button); setTabButton(index, QTabBar::RightSide, close_button);
break; break;
} }

View File

@ -86,6 +86,20 @@ void TabWidget::openMainMenu() {
m_menuMain->exec(mapToGlobal(button_position)); m_menuMain->exec(mapToGlobal(button_position));
} }
void TabWidget::showDownloadManager() {
for (int i = 0; i < count(); i++) {
if (QString(widget(i)->metaObject()->className()) == "DownloadManager") {
setCurrentIndex(i);
return;
}
}
// Download manager is not opened. Create tab with it.
qApp->downloadManager()->setParent(this);
addTab(qApp->downloadManager(), qApp->icons()->fromTheme("download-manager"), tr("Downloads"), TabBar::DownloadManager);
setCurrentIndex(count() - 1);
}
void TabWidget::checkTabBarVisibility() { void TabWidget::checkTabBarVisibility() {
bool should_be_visible = count() > 1 || !qApp->settings()->value(GROUP(GUI), SETTING(GUI::HideTabBarIfOnlyOneTab)).toBool(); bool should_be_visible = count() > 1 || !qApp->settings()->value(GROUP(GUI), SETTING(GUI::HideTabBarIfOnlyOneTab)).toBool();
@ -172,7 +186,11 @@ void TabWidget::setupIcons() {
bool TabWidget::closeTab(int index) { bool TabWidget::closeTab(int index) {
if (tabBar()->tabType(index) == TabBar::Closable) { if (tabBar()->tabType(index) == TabBar::Closable) {
removeTab(index); removeTab(index, true);
return true;
}
else if (tabBar()->tabType(index) == TabBar::DownloadManager) {
removeTab(index, false);
return true; return true;
} }
else { else {
@ -216,8 +234,11 @@ void TabWidget::closeAllTabsExceptCurrent() {
} }
} }
void TabWidget::removeTab(int index) { void TabWidget::removeTab(int index, bool clear_from_memory) {
widget(index)->deleteLater(); if (clear_from_memory) {
widget(index)->deleteLater();
}
QTabWidget::removeTab(index); QTabWidget::removeTab(index);
} }

View File

@ -47,7 +47,7 @@ class TabWidget : public QTabWidget {
const TabBar::TabType &type = TabBar::Closable); const TabBar::TabType &type = TabBar::Closable);
int insertTab(int index, QWidget *widget, const QIcon &icon, int insertTab(int index, QWidget *widget, const QIcon &icon,
const QString &label, const TabBar::TabType &type = TabBar::NonClosable); const QString &label, const TabBar::TabType &type = TabBar::NonClosable);
void removeTab(int index); void removeTab(int index, bool clear_from_memory);
// Returns tab bar. // Returns tab bar.
inline TabBar *tabBar() { inline TabBar *tabBar() {
@ -98,8 +98,11 @@ class TabWidget : public QTabWidget {
bool closeTab(int index); bool closeTab(int index);
bool closeCurrentTab(); bool closeCurrentTab();
// Opens main menu.
void openMainMenu(); void openMainMenu();
void showDownloadManager();
// Closes all "closable" tabs except the active tab. // Closes all "closable" tabs except the active tab.
void closeAllTabsExceptCurrent(); void closeAllTabsExceptCurrent();

View File

@ -33,7 +33,7 @@ Application::Application(const QString &id, int &argc, char **argv)
: QtSingleApplication(id, argc, argv), : QtSingleApplication(id, argc, argv),
m_closeLock(NULL), m_userActions(QList<QAction*>()), m_mainForm(NULL), m_closeLock(NULL), m_userActions(QList<QAction*>()), m_mainForm(NULL),
m_trayIcon(NULL), m_settings(NULL), m_system(NULL), m_skins(NULL), m_trayIcon(NULL), m_settings(NULL), m_system(NULL), m_skins(NULL),
m_localization(NULL), m_icons(NULL), m_database(NULL), m_shouldRestart(false) { m_localization(NULL), m_icons(NULL), m_database(NULL), m_downloadManager(NULL), m_shouldRestart(false) {
connect(this, SIGNAL(aboutToQuit()), this, SLOT(onAboutToQuit())); connect(this, SIGNAL(aboutToQuit()), this, SLOT(onAboutToQuit()));
connect(this, SIGNAL(commitDataRequest(QSessionManager&)), this, SLOT(onCommitData(QSessionManager&))); connect(this, SIGNAL(commitDataRequest(QSessionManager&)), this, SLOT(onCommitData(QSessionManager&)));
connect(this, SIGNAL(saveStateRequest(QSessionManager&)), this, SLOT(onSaveState(QSessionManager&))); connect(this, SIGNAL(saveStateRequest(QSessionManager&)), this, SLOT(onSaveState(QSessionManager&)));

View File

@ -27,6 +27,7 @@
#include "miscellaneous/localization.h" #include "miscellaneous/localization.h"
#include "miscellaneous/databasefactory.h" #include "miscellaneous/databasefactory.h"
#include "gui/systemtrayicon.h" #include "gui/systemtrayicon.h"
#include "network-web/downloadmanager.h"
#include <QMutex> #include <QMutex>
#include <QList> #include <QList>
@ -93,6 +94,14 @@ class Application : public QtSingleApplication {
IconFactory *icons(); IconFactory *icons();
inline DownloadManager *downloadManager() {
if (m_downloadManager == NULL) {
m_downloadManager = new DownloadManager();
}
return m_downloadManager;
}
inline Settings *settings() { inline Settings *settings() {
if (m_settings == NULL) { if (m_settings == NULL) {
m_settings = Settings::setupSettings(this); m_settings = Settings::setupSettings(this);
@ -205,6 +214,7 @@ class Application : public QtSingleApplication {
Localization *m_localization; Localization *m_localization;
IconFactory *m_icons; IconFactory *m_icons;
DatabaseFactory *m_database; DatabaseFactory *m_database;
DownloadManager *m_downloadManager;
bool m_shouldRestart; bool m_shouldRestart;
}; };

View File

@ -23,9 +23,15 @@ DownloadManager::DownloadManager(QWidget *parent) : TabContent(parent), m_ui(new
} }
DownloadManager::~DownloadManager() { DownloadManager::~DownloadManager() {
qDebug("Destroying DownloadManager.");
delete m_ui; delete m_ui;
} }
// TODO: pokračovat, převzít downloaditem, edittableview z arory // TODO: pokračovat, převzít downloaditem, edittableview z arory
// přistup k downloadmanageru bude z qApp->downloadManager(), // přistup k downloadmanageru bude z qApp->downloadManager(),
// bude se využívat pro stahování skrze webview // bude se využívat pro stahování skrze webview
WebBrowser *DownloadManager::webBrowser() {
return NULL;
}

View File

@ -34,6 +34,8 @@ class DownloadManager : public TabContent {
explicit DownloadManager(QWidget *parent = 0); explicit DownloadManager(QWidget *parent = 0);
virtual ~DownloadManager(); virtual ~DownloadManager();
WebBrowser *webBrowser();
private: private:
Ui::DownloadManager *m_ui; Ui::DownloadManager *m_ui;
}; };

View File

@ -52,7 +52,7 @@ WebView::WebView(QWidget *parent)
} }
WebView::~WebView() { WebView::~WebView() {
qDebug("Destroying BaseWebView."); qDebug("Destroying WebView.");
} }
void WebView::onLoadFinished(bool ok) { void WebView::onLoadFinished(bool ok) {