Add a very rudimentary UI for accepting a transfer
authorManuel Nickschas <sputnick@quassel-irc.org>
Sat, 28 Dec 2013 17:55:20 +0000 (18:55 +0100)
committerManuel Nickschas <sputnick@quassel-irc.org>
Wed, 1 Jan 2014 22:15:15 +0000 (23:15 +0100)
This is just a temporary solution for being able to accept or
reject an incoming transfer. We just display a little dialog and offer
a way to specify a path for saving.

This lacks many features and will be replaced by a proper transfer manager
widget later.

src/client/clienttransfermanager.cpp
src/client/clienttransfermanager.h
src/qtui/CMakeLists.txt
src/qtui/mainwin.cpp
src/qtui/mainwin.h
src/qtui/receivefiledlg.cpp [new file with mode: 0644]
src/qtui/receivefiledlg.h [new file with mode: 0644]
src/qtui/ui/receivefiledlg.ui [new file with mode: 0644]

index b67c690..7e89cca 100644 (file)
@@ -28,7 +28,7 @@ INIT_SYNCABLE_OBJECT(ClientTransferManager)
 ClientTransferManager::ClientTransferManager(QObject *parent)
     : TransferManager(parent)
 {
 ClientTransferManager::ClientTransferManager(QObject *parent)
     : TransferManager(parent)
 {
-
+    connect(this, SIGNAL(transferAdded(const Transfer*)), SLOT(onTransferAdded(const Transfer*)));
 }
 
 
 }
 
 
@@ -51,3 +51,10 @@ void ClientTransferManager::onTransferInitDone()
     Q_ASSERT(transfer);
     addTransfer(transfer);
 }
     Q_ASSERT(transfer);
     addTransfer(transfer);
 }
+
+
+void ClientTransferManager::onTransferAdded(const Transfer *transfer)
+{
+    // FIXME just a temporary solution
+    emit newTransfer(transfer);
+}
index 6f60f72..d2483ca 100644 (file)
@@ -39,6 +39,12 @@ public slots:
     void onCoreTransferAdded(const QUuid &uuid);
     void onTransferInitDone();
 
     void onCoreTransferAdded(const QUuid &uuid);
     void onTransferInitDone();
 
+signals:
+    void newTransfer(const Transfer *transfer);
+
+private slots:
+    void onTransferAdded(const Transfer *transfer);
+
 };
 
 #endif
 };
 
 #endif
index 6cb6cdb..e649d15 100644 (file)
@@ -55,6 +55,7 @@ set(SOURCES
     qtuimessageprocessor.cpp
     qtuisettings.cpp
     qtuistyle.cpp
     qtuimessageprocessor.cpp
     qtuisettings.cpp
     qtuistyle.cpp
+    receivefiledlg.cpp
     settingsdlg.cpp
     settingspagedlg.cpp
     simplenetworkeditor.cpp
     settingsdlg.cpp
     settingspagedlg.cpp
     simplenetworkeditor.cpp
@@ -101,6 +102,7 @@ set(MOC_HDRS
     qtuiapplication.h
     qtuimessageprocessor.h
     qtuistyle.h
     qtuiapplication.h
     qtuimessageprocessor.h
     qtuistyle.h
+    receivefiledlg.h
     settingsdlg.h
     settingspagedlg.h
     simplenetworkeditor.h
     settingsdlg.h
     settingspagedlg.h
     simplenetworkeditor.h
@@ -140,6 +142,7 @@ set(FORMS
     settingsdlg.ui
     settingspagedlg.ui
     simplenetworkeditor.ui
     settingsdlg.ui
     settingspagedlg.ui
     simplenetworkeditor.ui
+    receivefiledlg.ui
     topicwidget.ui)
 
 if(HAVE_KDE)
     topicwidget.ui)
 
 if(HAVE_KDE)
index d5e9b0c..573728e 100644 (file)
@@ -62,6 +62,7 @@
 #include "clientbufferviewconfig.h"
 #include "clientbufferviewmanager.h"
 #include "clientignorelistmanager.h"
 #include "clientbufferviewconfig.h"
 #include "clientbufferviewmanager.h"
 #include "clientignorelistmanager.h"
+#include "clienttransfermanager.h"
 #include "coreconfigwizard.h"
 #include "coreconnectdlg.h"
 #include "coreconnection.h"
 #include "coreconfigwizard.h"
 #include "coreconnectdlg.h"
 #include "coreconnection.h"
 #include "qtuimessageprocessor.h"
 #include "qtuisettings.h"
 #include "qtuistyle.h"
 #include "qtuimessageprocessor.h"
 #include "qtuisettings.h"
 #include "qtuistyle.h"
+#include "receivefiledlg.h"
 #include "settingsdlg.h"
 #include "settingspagedlg.h"
 #include "statusnotifieritem.h"
 #include "toolbaractionprovider.h"
 #include "topicwidget.h"
 #include "settingsdlg.h"
 #include "settingspagedlg.h"
 #include "statusnotifieritem.h"
 #include "toolbaractionprovider.h"
 #include "topicwidget.h"
+#include "transfer.h"
 #include "verticaldock.h"
 
 #ifndef HAVE_KDE
 #include "verticaldock.h"
 
 #ifndef HAVE_KDE
@@ -1022,6 +1025,8 @@ void MainWin::connectedToCore()
     connect(Client::bufferViewManager(), SIGNAL(bufferViewConfigDeleted(int)), this, SLOT(removeBufferView(int)));
     connect(Client::bufferViewManager(), SIGNAL(initDone()), this, SLOT(loadLayout()));
 
     connect(Client::bufferViewManager(), SIGNAL(bufferViewConfigDeleted(int)), this, SLOT(removeBufferView(int)));
     connect(Client::bufferViewManager(), SIGNAL(initDone()), this, SLOT(loadLayout()));
 
+    connect(Client::transferManager(), SIGNAL(newTransfer(const Transfer*)), SLOT(showNewTransferDlg(const Transfer*)));
+
     setConnectedState();
 }
 
     setConnectedState();
 }
 
@@ -1358,6 +1363,13 @@ void MainWin::showShortcutsDlg()
 }
 
 
 }
 
 
+void MainWin::showNewTransferDlg(const Transfer *transfer)
+{
+    ReceiveFileDlg *dlg = new ReceiveFileDlg(transfer, this);
+    dlg->show();
+}
+
+
 void MainWin::onFullScreenToggled()
 {
     // Relying on QWidget::isFullScreen is discouraged, see the KToggleFullScreenAction docs
 void MainWin::onFullScreenToggled()
 {
     // Relying on QWidget::isFullScreen is discouraged, see the KToggleFullScreenAction docs
index 9ae9a2a..54c19a1 100644 (file)
@@ -46,6 +46,7 @@ class NickListWidget;
 class SystemTray;
 class ChatMonitorView;
 class TopicWidget;
 class SystemTray;
 class ChatMonitorView;
 class TopicWidget;
+class Transfer;
 
 class QMenu;
 class QLabel;
 
 class QMenu;
 class QLabel;
@@ -122,6 +123,7 @@ private slots:
     void showNotificationsDlg();
     void showIgnoreList(QString newRule = QString());
     void showShortcutsDlg();
     void showNotificationsDlg();
     void showIgnoreList(QString newRule = QString());
     void showShortcutsDlg();
+    void showNewTransferDlg(const Transfer *transfer);
     void onFullScreenToggled();
 
     void handleCoreConnectionError(const QString &errorMsg);
     void onFullScreenToggled();
 
     void handleCoreConnectionError(const QString &errorMsg);
diff --git a/src/qtui/receivefiledlg.cpp b/src/qtui/receivefiledlg.cpp
new file mode 100644 (file)
index 0000000..e736421
--- /dev/null
@@ -0,0 +1,47 @@
+/***************************************************************************
+ *   Copyright (C) 2005-2013 by the Quassel Project                        *
+ *   devel@quassel-irc.org                                                 *
+ *                                                                         *
+ *   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.                                           *
+ *                                                                         *
+ *   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, write to the                         *
+ *   Free Software Foundation, Inc.,                                       *
+ *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.         *
+ ***************************************************************************/
+
+#include <QDir>
+#include <QFileDialog>
+
+#include "receivefiledlg.h"
+
+#include "transfer.h"
+
+ReceiveFileDlg::ReceiveFileDlg(const Transfer *transfer, QWidget *parent)
+    : QDialog(parent),
+    _transfer(transfer)
+{
+    setAttribute(Qt::WA_DeleteOnClose);
+    ui.setupUi(this);
+
+    QString label = tr("<b>%1</b> wants to send you a file:<br>%2 (%3 bytes)").arg(transfer->nick(), transfer->fileName()).arg(transfer->fileSize());
+    ui.infoText->setText(label);
+}
+
+
+void ReceiveFileDlg::on_buttonBox_clicked(QAbstractButton *button)
+{
+    if (ui.buttonBox->standardButton(button) == QDialogButtonBox::Save) {
+        QString name = QFileDialog::getSaveFileName(this, QString(), QDir::currentPath() + "/" + _transfer->fileName());
+        _transfer->accept(name);
+    }
+
+}
diff --git a/src/qtui/receivefiledlg.h b/src/qtui/receivefiledlg.h
new file mode 100644 (file)
index 0000000..982189a
--- /dev/null
@@ -0,0 +1,43 @@
+/***************************************************************************
+ *   Copyright (C) 2005-2013 by the Quassel Project                        *
+ *   devel@quassel-irc.org                                                 *
+ *                                                                         *
+ *   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.                                           *
+ *                                                                         *
+ *   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, write to the                         *
+ *   Free Software Foundation, Inc.,                                       *
+ *   51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.         *
+ ***************************************************************************/
+
+#ifndef RECEIVEFILEDLG_H
+#define RECEIVEFILEDLG_H
+
+#include "ui_receivefiledlg.h"
+
+class Transfer;
+
+class ReceiveFileDlg : public QDialog
+{
+    Q_OBJECT
+
+public:
+    ReceiveFileDlg(const Transfer *transfer, QWidget *parent = 0);
+
+private slots:
+    void on_buttonBox_clicked(QAbstractButton *button);
+
+private:
+    Ui::ReceiveFileDlg ui;
+    const Transfer *_transfer;
+};
+
+#endif
diff --git a/src/qtui/ui/receivefiledlg.ui b/src/qtui/ui/receivefiledlg.ui
new file mode 100644 (file)
index 0000000..6cc7a4e
--- /dev/null
@@ -0,0 +1,74 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ui version="4.0">
+ <class>ReceiveFileDlg</class>
+ <widget class="QDialog" name="ReceiveFileDlg">
+  <property name="geometry">
+   <rect>
+    <x>0</x>
+    <y>0</y>
+    <width>354</width>
+    <height>97</height>
+   </rect>
+  </property>
+  <property name="windowTitle">
+   <string>Incoming File Transfer</string>
+  </property>
+  <layout class="QVBoxLayout" name="verticalLayout">
+   <item>
+    <widget class="QLabel" name="infoText">
+     <property name="text">
+      <string notr="true">Someone is trying to send you a file.</string>
+     </property>
+     <property name="wordWrap">
+      <bool>true</bool>
+     </property>
+    </widget>
+   </item>
+   <item>
+    <widget class="QDialogButtonBox" name="buttonBox">
+     <property name="orientation">
+      <enum>Qt::Horizontal</enum>
+     </property>
+     <property name="standardButtons">
+      <set>QDialogButtonBox::Discard|QDialogButtonBox::Ignore|QDialogButtonBox::Save</set>
+     </property>
+    </widget>
+   </item>
+  </layout>
+ </widget>
+ <resources/>
+ <connections>
+  <connection>
+   <sender>buttonBox</sender>
+   <signal>accepted()</signal>
+   <receiver>ReceiveFileDlg</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>ReceiveFileDlg</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>