Various Gui improvements:

* Added fallback to only <id> if peer is unknown in LinkCloud.
 * Added CheckFiles, and display status icon to SharedFiles.
 * Fixed SMPlayer startup and added play slot in Main Window.
 * Added Play Files to Local Shared Files. (context menu)
 * Added Play File to completed File Transfers. (context menu)
 * Ensured that selected Transfer stays selected.
 * Corrected Download State enumeration
 * Renamed Peer Details/ Authenticate to Make Friend / Peer Details
 * Removed Network View from Application Window.
 * Mods to RemoteDirModel to get Paths from files.
 * updated Rs Interface files.



git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@450 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
drbob 2008-03-31 18:37:50 +00:00
parent 29a74b9898
commit e07783ac2b
14 changed files with 323 additions and 112 deletions

View File

@ -105,9 +105,9 @@ ApplicationWindow::ApplicationWindow(QWidget* parent, Qt::WFlags flags)
ui.stackPages->add(gamesDialog = new GamesDialog(ui.stackPages), ui.stackPages->add(gamesDialog = new GamesDialog(ui.stackPages),
createPageAction(QIcon(IMAGE_GAMES), tr("Games Launcher"), grp)); createPageAction(QIcon(IMAGE_GAMES), tr("Games Launcher"), grp));
NetworkView *networkView = NULL; //NetworkView *networkView = NULL;
ui.stackPages->add(networkView = new NetworkView(ui.stackPages), //ui.stackPages->add(networkView = new NetworkView(ui.stackPages),
createPageAction(QIcon(IMAGE_NETWORK), tr("Network View"), grp)); // createPageAction(QIcon(IMAGE_NETWORK), tr("Network View"), grp));
PhotoDialog *photoDialog = NULL; PhotoDialog *photoDialog = NULL;
ui.stackPages->add(photoDialog = new PhotoDialog(ui.stackPages), ui.stackPages->add(photoDialog = new PhotoDialog(ui.stackPages),
@ -126,7 +126,7 @@ ApplicationWindow::ApplicationWindow(QWidget* parent, Qt::WFlags flags)
connect(grp, SIGNAL(triggered(QAction *)), ui.stackPages, SLOT(showPage(QAction *))); connect(grp, SIGNAL(triggered(QAction *)), ui.stackPages, SLOT(showPage(QAction *)));
/* Create and bind the messenger button */ /* Create and bind the messenger button */
addAction(new QAction(QIcon(IMAGE_SMPLAYER), tr("SMPlayer"), ui.toolBar), SLOT(showsmplayer())); //addAction(new QAction(QIcon(IMAGE_SMPLAYER), tr("SMPlayer"), ui.toolBar), SLOT(showsmplayer()));
} }

View File

@ -384,6 +384,12 @@ void LinksDialog::updateLinks()
QString timestamp = qtime.toString("yyyy-MM-dd hh:mm:ss"); QString timestamp = qtime.toString("yyyy-MM-dd hh:mm:ss");
QString peerLabel = QString::fromStdString(rsPeers->getPeerName(cit->id)); QString peerLabel = QString::fromStdString(rsPeers->getPeerName(cit->id));
if (peerLabel == "")
{
peerLabel = "<";
peerLabel += QString::fromStdString(cit->id);
peerLabel = ">";
}
peerLabel += " "; peerLabel += " ";
peerLabel += timestamp; peerLabel += timestamp;
child -> setText(2, peerLabel); child -> setText(2, peerLabel);

View File

@ -101,6 +101,8 @@ MainWindow::MainWindow(QWidget* parent, Qt::WFlags flags)
ui.setupUi(this); ui.setupUi(this);
setWindowTitle(tr("RetroShare %1").arg(retroshareVersion())); setWindowTitle(tr("RetroShare %1").arg(retroshareVersion()));
mSMPlayer = NULL;
/* Hide Console frame */ /* Hide Console frame */
//showConsoleFrame(false); //showConsoleFrame(false);
@ -197,7 +199,9 @@ MainWindow::MainWindow(QWidget* parent, Qt::WFlags flags)
connect(grp, SIGNAL(triggered(QAction *)), ui.stackPages, SLOT(showPage(QAction *))); connect(grp, SIGNAL(triggered(QAction *)), ui.stackPages, SLOT(showPage(QAction *)));
// Allow to play files from SharedFilesDialog.
connect(sharedfilesDialog, SIGNAL(playFiles( QStringList )), this, SLOT(playFiles( QStringList )));
connect(transfersDialog, SIGNAL(playFiles( QStringList )), this, SLOT(playFiles( QStringList )));
#ifdef RS_RELEASE_VERSION #ifdef RS_RELEASE_VERSION
addAction(new QAction(QIcon(IMAGE_BLOCK), tr("Unfinished"), ui.toolBar), SLOT(showApplWindow())); addAction(new QAction(QIcon(IMAGE_BLOCK), tr("Unfinished"), ui.toolBar), SLOT(showApplWindow()));
@ -280,7 +284,7 @@ MainWindow::MainWindow(QWidget* parent, Qt::WFlags flags)
menu->addAction(_bandwidthAct); menu->addAction(_bandwidthAct);
#endif #endif
menu->addAction(_prefsAct); menu->addAction(_prefsAct);
//menu->addAction(_smplayerAct); menu->addAction(_smplayerAct);
menu->addSeparator(); menu->addSeparator();
menu->addAction(tr("Minimize"), this, SLOT(showMinimized())); menu->addAction(tr("Minimize"), this, SLOT(showMinimized()));
menu->addAction(tr("Maximize"), this, SLOT(showMaximized())); menu->addAction(tr("Maximize"), this, SLOT(showMaximized()));
@ -461,7 +465,7 @@ MainWindow::~MainWindow()
delete _prefsAct; delete _prefsAct;
delete _bandwidthGraph; delete _bandwidthGraph;
delete _messengerwindowAct; delete _messengerwindowAct;
//delete _smplayerAct; delete _smplayerAct;
} }
/** Create and bind actions to events. Setup for initial /** Create and bind actions to events. Setup for initial
@ -479,8 +483,8 @@ void MainWindow::createActions()
_messengerwindowAct = new QAction(QIcon(IMAGE_RSM16), tr("Open Messenger"), this); _messengerwindowAct = new QAction(QIcon(IMAGE_RSM16), tr("Open Messenger"), this);
connect(_messengerwindowAct, SIGNAL(triggered()),this, SLOT(showMessengerWindow())); connect(_messengerwindowAct, SIGNAL(triggered()),this, SLOT(showMessengerWindow()));
//_smplayerAct = new QAction(QIcon(IMAGE_SMPLAYER), tr("SMPlayer"), this); _smplayerAct = new QAction(QIcon(IMAGE_SMPLAYER), tr("SMPlayer"), this);
//connect(_smplayerAct, SIGNAL(triggered()),this, SLOT(showsmplayer())); connect(_smplayerAct, SIGNAL(triggered()),this, SLOT(showsmplayer()));
//connect(ui.btntoggletoolbox, SIGNAL(toggled(bool)), this, SLOT(showToolboxFrame(bool))); //connect(ui.btntoggletoolbox, SIGNAL(toggled(bool)), this, SLOT(showToolboxFrame(bool)));
@ -640,20 +644,26 @@ void MainWindow::startqcheckers()
} }
/** Shows smplayer */ /** Shows smplayer */
void MainWindow::showsmplayer() void MainWindow::showsmplayer()
{ {
static SMPlayer * smplayer = 0; static SMPlayer * smplayer = 0;
if (smplayer == 0) { if (mSMPlayer == 0)
smplayer = new SMPlayer(QString::null, this); {
/*connect(smplayer->gui(), SIGNAL(quitSolicited()), mSMPlayer = new SMPlayer(QString::null, this);
smplayer->gui(), SLOT(hide()));*/ }
} mSMPlayer->gui()->show();
smplayer->gui()->show();
} }
void MainWindow::playFiles(QStringList files)
{
showsmplayer();
mSMPlayer->gui()->openFiles(files);
}
void MainWindow::showabout() void MainWindow::showabout()
{ {
static HelpDialog *helpdlg = new HelpDialog(this); static HelpDialog *helpdlg = new HelpDialog(this);

View File

@ -54,6 +54,8 @@
#include "../config/rsharesettings.h" #include "../config/rsharesettings.h"
class SMPlayer;
class MainWindow : public QMainWindow class MainWindow : public QMainWindow
{ {
Q_OBJECT Q_OBJECT
@ -97,6 +99,7 @@ public:
MessengerWindow *messengerWindow; MessengerWindow *messengerWindow;
ApplicationWindow *applicationWindow; ApplicationWindow *applicationWindow;
SMPlayer * mSMPlayer;
public slots: public slots:
/** Called when this dialog is to be displayed */ /** Called when this dialog is to be displayed */
@ -107,6 +110,7 @@ public slots:
void startgammon(); void startgammon();
void startqcheckers(); void startqcheckers();
void playFiles(QStringList files);
private slots: private slots:

View File

@ -119,7 +119,7 @@ void NetworkDialog::connecttreeWidgetCostumPopupMenu( QPoint point )
QMenu contextMnu( this ); QMenu contextMnu( this );
QMouseEvent *mevent = new QMouseEvent( QEvent::MouseButtonPress, point, Qt::RightButton, Qt::RightButton, Qt::NoModifier ); QMouseEvent *mevent = new QMouseEvent( QEvent::MouseButtonPress, point, Qt::RightButton, Qt::RightButton, Qt::NoModifier );
peerdetailsAct = new QAction(QIcon(IMAGE_PEERDETAILS), tr( "Peer Details / Authenticate " ), this ); peerdetailsAct = new QAction(QIcon(IMAGE_PEERDETAILS), tr( "Make Friend / Peer Details" ), this );
connect( peerdetailsAct , SIGNAL( triggered() ), this, SLOT( peerdetails() ) ); connect( peerdetailsAct , SIGNAL( triggered() ), this, SLOT( peerdetails() ) );
//authAct = new QAction(QIcon(IMAGE_AUTH), tr( "Authenticate" ), this ); //authAct = new QAction(QIcon(IMAGE_AUTH), tr( "Authenticate" ), this );
@ -472,4 +472,4 @@ void NetworkDialog::displayInfoLogMenu(const QPoint& pos) {
myLogMenu.addAction(ui.actionClearLog); myLogMenu.addAction(ui.actionClearLog);
// XXX: Why mapToGlobal() is not enough? // XXX: Why mapToGlobal() is not enough?
myLogMenu.exec(mapToGlobal(pos)+QPoint(0,320)); myLogMenu.exec(mapToGlobal(pos)+QPoint(0,320));
} }

View File

@ -39,9 +39,12 @@
#include <QMouseEvent> #include <QMouseEvent>
#include <QPixmap> #include <QPixmap>
#include <QHeaderView> #include <QHeaderView>
#include <QTimer>
/* Images for context menu icons */ /* Images for context menu icons */
#define IMAGE_DOWNLOAD ":/images/start.png" #define IMAGE_DOWNLOAD ":/images/start.png"
#define IMAGE_HASH_BUSY ":/images/settings.png"
#define IMAGE_HASH_DONE ":/images/folder_green.png"
/** Constructor */ /** Constructor */
SharedFilesDialog::SharedFilesDialog(QWidget *parent) SharedFilesDialog::SharedFilesDialog(QWidget *parent)
@ -49,6 +52,9 @@ SharedFilesDialog::SharedFilesDialog(QWidget *parent)
{ {
/* Invoke the Qt Designer generated object setup routine */ /* Invoke the Qt Designer generated object setup routine */
ui.setupUi(this); ui.setupUi(this);
connect(ui.checkButton, SIGNAL(clicked()), this, SLOT(forceCheck()));
connect( ui.localDirTreeView, SIGNAL( customContextMenuRequested( QPoint ) ), this, SLOT( shareddirtreeWidgetCostumPopupMenu( QPoint ) ) ); connect( ui.localDirTreeView, SIGNAL( customContextMenuRequested( QPoint ) ), this, SLOT( shareddirtreeWidgetCostumPopupMenu( QPoint ) ) );
@ -107,12 +113,39 @@ SharedFilesDialog::SharedFilesDialog(QWidget *parent)
ui.remoteDirTreeView->setSelectionMode(QAbstractItemView::ExtendedSelection); ui.remoteDirTreeView->setSelectionMode(QAbstractItemView::ExtendedSelection);
ui.localDirTreeView->setSelectionMode(QAbstractItemView::ExtendedSelection); ui.localDirTreeView->setSelectionMode(QAbstractItemView::ExtendedSelection);
QTimer *timer = new QTimer(this);
timer->connect(timer, SIGNAL(timeout()), this, SLOT(checkUpdate()));
timer->start(1000);
/* Hide platform specific features */ /* Hide platform specific features */
#ifdef Q_WS_WIN #ifdef Q_WS_WIN
#endif #endif
} }
void SharedFilesDialog::checkUpdate()
{
/* update */
if (rsicontrol->InDirectoryCheck())
{
ui.hashLabel->setPixmap(QPixmap(IMAGE_HASH_BUSY));
}
else
{
ui.hashLabel->setPixmap(QPixmap(IMAGE_HASH_DONE));
}
return;
}
void SharedFilesDialog::forceCheck()
{
rsicontrol->ForceDirectoryCheck();
return;
}
void SharedFilesDialog::shareddirtreeviewCostumPopupMenu( QPoint point ) void SharedFilesDialog::shareddirtreeviewCostumPopupMenu( QPoint point )
{ {
@ -172,6 +205,34 @@ void SharedFilesDialog::recommendfile()
localModel -> recommendSelected(qism->selectedIndexes()); localModel -> recommendSelected(qism->selectedIndexes());
} }
void SharedFilesDialog::playselectedfiles()
{
/* call back to the model (which does all the interfacing? */
std::cerr << "SharedFilesDialog::playselectedfiles()";
std::cerr << std::endl;
QItemSelectionModel *qism = ui.localDirTreeView->selectionModel();
std::list<std::string> paths;
localModel -> getFilePaths(qism->selectedIndexes(), paths);
std::list<std::string>::iterator it;
QStringList fullpaths;
for(it = paths.begin(); it != paths.end(); it++)
{
std::string fullpath;
rsicontrol->ConvertSharedFilePath(*it, fullpath);
fullpaths.push_back(QString::fromStdString(fullpath));
std::cerr << "Playing: " << fullpath;
std::cerr << std::endl;
}
playFiles(fullpaths);
}
@ -288,12 +349,13 @@ void SharedFilesDialog::shareddirtreeWidgetCostumPopupMenu( QPoint point )
QMenu contextMnu2( this ); QMenu contextMnu2( this );
QMouseEvent *mevent2 = new QMouseEvent( QEvent::MouseButtonPress, point, Qt::RightButton, Qt::RightButton, Qt::NoModifier ); QMouseEvent *mevent2 = new QMouseEvent( QEvent::MouseButtonPress, point, Qt::RightButton, Qt::RightButton, Qt::NoModifier );
openfolderAct = new QAction( tr( "Play File(s)" ), this );
connect( openfolderAct , SIGNAL( triggered() ), this, SLOT( playselectedfiles() ) );
openfileAct = new QAction( tr( "Add to Recommend List" ), this ); openfileAct = new QAction( tr( "Add to Recommend List" ), this );
connect( openfileAct , SIGNAL( triggered() ), this, SLOT( recommendfile() ) ); connect( openfileAct , SIGNAL( triggered() ), this, SLOT( recommendfile() ) );
// openfolderAct = new QAction( tr( "Play File" ), this );
// connect( openfolderAct , SIGNAL( triggered() ), this, SLOT( openfile() ) );
//
/* now we're going to ask who to recommend it to... /* now we're going to ask who to recommend it to...
* First Level. * First Level.
* *
@ -341,6 +403,7 @@ void SharedFilesDialog::shareddirtreeWidgetCostumPopupMenu( QPoint point )
} }
contextMnu2.addAction( openfolderAct);
contextMnu2.addAction( openfileAct); contextMnu2.addAction( openfileAct);
contextMnu2.addMenu( recMenu); contextMnu2.addMenu( recMenu);
contextMnu2.addMenu( msgMenu); contextMnu2.addMenu( msgMenu);

View File

@ -45,10 +45,11 @@ public:
void preModDirectories(bool update_local); void preModDirectories(bool update_local);
void ModDirectories(bool update_local); void ModDirectories(bool update_local);
private slots: private slots:
void checkUpdate();
void forceCheck();
/** Create the context popup menu and it's submenus */ /** Create the context popup menu and it's submenus */
void shareddirtreeviewCostumPopupMenu( QPoint point ); void shareddirtreeviewCostumPopupMenu( QPoint point );
@ -58,6 +59,7 @@ private slots:
void addMsgRemoteSelected(); void addMsgRemoteSelected();
void recommendfile(); void recommendfile();
void playselectedfiles();
void openfile(); void openfile();
void openfolder(); void openfolder();
@ -65,6 +67,9 @@ private slots:
void recommendFilesTo( std::string rsid ); void recommendFilesTo( std::string rsid );
void recommendFilesToMsg( std::string rsid ); void recommendFilesToMsg( std::string rsid );
signals:
void playFiles(QStringList files);
private: private:
/** Define the popup menus for the Context menu */ /** Define the popup menus for the Context menu */
QMenu* contextMnu; QMenu* contextMnu;

View File

@ -5,8 +5,8 @@
<rect> <rect>
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>467</width> <width>445</width>
<height>309</height> <height>401</height>
</rect> </rect>
</property> </property>
<property name="sizePolicy" > <property name="sizePolicy" >
@ -499,18 +499,6 @@
<enum>Qt::NoContextMenu</enum> <enum>Qt::NoContextMenu</enum>
</property> </property>
<layout class="QGridLayout" > <layout class="QGridLayout" >
<property name="leftMargin" >
<number>6</number>
</property>
<property name="topMargin" >
<number>1</number>
</property>
<property name="rightMargin" >
<number>6</number>
</property>
<property name="bottomMargin" >
<number>1</number>
</property>
<property name="horizontalSpacing" > <property name="horizontalSpacing" >
<number>1</number> <number>1</number>
</property> </property>
@ -518,59 +506,10 @@
<number>1</number> <number>1</number>
</property> </property>
<item row="0" column="0" > <item row="0" column="0" >
<layout class="QGridLayout" > <layout class="QVBoxLayout" >
<property name="leftMargin" > <item>
<number>0</number> <layout class="QHBoxLayout" >
</property> <item>
<property name="topMargin" >
<number>0</number>
</property>
<property name="rightMargin" >
<number>0</number>
</property>
<property name="bottomMargin" >
<number>0</number>
</property>
<property name="horizontalSpacing" >
<number>0</number>
</property>
<property name="verticalSpacing" >
<number>0</number>
</property>
<item row="0" column="0" >
<layout class="QGridLayout" >
<property name="leftMargin" >
<number>0</number>
</property>
<property name="topMargin" >
<number>0</number>
</property>
<property name="rightMargin" >
<number>0</number>
</property>
<property name="bottomMargin" >
<number>0</number>
</property>
<property name="horizontalSpacing" >
<number>0</number>
</property>
<property name="verticalSpacing" >
<number>0</number>
</property>
<item row="0" column="1" >
<spacer>
<property name="orientation" >
<enum>Qt::Horizontal</enum>
</property>
<property name="sizeHint" >
<size>
<width>40</width>
<height>20</height>
</size>
</property>
</spacer>
</item>
<item row="0" column="0" >
<layout class="QGridLayout" > <layout class="QGridLayout" >
<property name="leftMargin" > <property name="leftMargin" >
<number>0</number> <number>0</number>
@ -612,9 +551,39 @@ p, li { white-space: pre-wrap; }
</item> </item>
</layout> </layout>
</item> </item>
<item>
<spacer>
<property name="orientation" >
<enum>Qt::Horizontal</enum>
</property>
<property name="sizeHint" >
<size>
<width>271</width>
<height>20</height>
</size>
</property>
</spacer>
</item>
<item>
<widget class="QPushButton" name="checkButton" >
<property name="text" >
<string>check files</string>
</property>
</widget>
</item>
<item>
<widget class="QLabel" name="hashLabel" >
<property name="text" >
<string/>
</property>
<property name="pixmap" >
<pixmap resource="images.qrc" >:/qss/black/checkBox_selected.png</pixmap>
</property>
</widget>
</item>
</layout> </layout>
</item> </item>
<item row="1" column="0" > <item>
<widget class="QSplitter" name="splitter" > <widget class="QSplitter" name="splitter" >
<property name="sizePolicy" > <property name="sizePolicy" >
<sizepolicy vsizetype="Expanding" hsizetype="Expanding" > <sizepolicy vsizetype="Expanding" hsizetype="Expanding" >

View File

@ -42,6 +42,7 @@
#define IMAGE_INFO ":/images/fileinfo.png" #define IMAGE_INFO ":/images/fileinfo.png"
#define IMAGE_CANCEL ":/images/delete.png" #define IMAGE_CANCEL ":/images/delete.png"
#define IMAGE_CLEARCOMPLETED ":/images/deleteall.png" #define IMAGE_CLEARCOMPLETED ":/images/deleteall.png"
#define IMAGE_PLAY ":/images/start.png"
/** Constructor */ /** Constructor */
TransfersDialog::TransfersDialog(QWidget *parent) TransfersDialog::TransfersDialog(QWidget *parent)
@ -141,8 +142,35 @@ void TransfersDialog::downloadListCostumPopupMenu( QPoint point )
QMenu contextMnu( this ); QMenu contextMnu( this );
QMouseEvent *mevent = new QMouseEvent( QEvent::MouseButtonPress, point, Qt::RightButton, Qt::RightButton, Qt::NoModifier ); QMouseEvent *mevent = new QMouseEvent( QEvent::MouseButtonPress, point, Qt::RightButton, Qt::RightButton, Qt::NoModifier );
// showdowninfoAct = new QAction(QIcon(IMAGE_INFO), tr( "Details..." ), this ); //showdowninfoAct = new QAction(QIcon(IMAGE_INFO), tr( "Details..." ), this );
// connect( showdowninfoAct , SIGNAL( triggered() ), this, SLOT( showDownInfoWindow() ) ); //connect( showdowninfoAct , SIGNAL( triggered() ), this, SLOT( showDownInfoWindow() ) );
/* check which item is selected
* - if it is completed - play should appear in menu
*/
std::cerr << "TransfersDialog::downloadListCostumPopupMenu()" << std::endl;
bool addPlayOption = false;
for(int i = 0; i <= DLListModel->rowCount(); i++) {
std::cerr << "Row Status :" << getStatus(i, DLListModel).toStdString() << ":" << std::endl;
if(selection->isRowSelected(i, QModelIndex())) {
std::cerr << "Selected Row Status :" << getStatus(i, DLListModel).toStdString() << ":" << std::endl;
QString qstatus = getStatus(i, DLListModel);
std::string status = (qstatus.trimmed()).toStdString();
if (status == "Complete")
{
std::cerr << "Add Play Option" << std::endl;
addPlayOption = true;
}
}
}
QAction *playAct = NULL;
if (addPlayOption)
{
playAct = new QAction(QIcon(IMAGE_PLAY), tr( "Play" ), this );
connect( playAct , SIGNAL( triggered() ), this, SLOT( playSelectedTransfer() ) );
}
cancelAct = new QAction(QIcon(IMAGE_CANCEL), tr( "Cancel" ), this ); cancelAct = new QAction(QIcon(IMAGE_CANCEL), tr( "Cancel" ), this );
connect( cancelAct , SIGNAL( triggered() ), this, SLOT( cancel() ) ); connect( cancelAct , SIGNAL( triggered() ), this, SLOT( cancel() ) );
@ -151,6 +179,12 @@ void TransfersDialog::downloadListCostumPopupMenu( QPoint point )
connect( clearcompletedAct , SIGNAL( triggered() ), this, SLOT( clearcompleted() ) ); connect( clearcompletedAct , SIGNAL( triggered() ), this, SLOT( clearcompleted() ) );
contextMnu.clear(); contextMnu.clear();
if (addPlayOption)
{
contextMnu.addAction(playAct);
}
contextMnu.addSeparator();
contextMnu.addAction( cancelAct); contextMnu.addAction( cancelAct);
// contextMnu.addSeparator(); // contextMnu.addSeparator();
// contextMnu.addAction( showdowninfoAct); // contextMnu.addAction( showdowninfoAct);
@ -159,6 +193,39 @@ void TransfersDialog::downloadListCostumPopupMenu( QPoint point )
contextMnu.exec( mevent->globalPos() ); contextMnu.exec( mevent->globalPos() );
} }
void TransfersDialog::playSelectedTransfer()
{
std::cerr << "TransfersDialog::playSelectedTransfer()" << std::endl;
/* get the shared directories */
rsiface->lockData(); /* Lock Interface */
std::string incomingdir = rsiface->getConfig().incomingDir;
rsiface->unlockData(); /* UnLock Interface */
/* create the List of Files */
QStringList playList;
for(int i = 0; i <= DLListModel->rowCount(); i++) {
if(selection->isRowSelected(i, QModelIndex())) {
QString qstatus = getStatus(i, DLListModel);
std::string status = (qstatus.trimmed()).toStdString();
if (status == "Complete")
{
QString qname = getFileName(i, DLListModel);
QString fullpath = QString::fromStdString(incomingdir);
fullpath += "/";
fullpath += qname.trimmed();
playList.push_back(fullpath);
std::cerr << "PlayFile:" << fullpath.toStdString() << std::endl;
}
}
}
playFiles(playList);
}
/** Shows Downloads Informations */ /** Shows Downloads Informations */
void TransfersDialog::showDownInfoWindow() void TransfersDialog::showDownInfoWindow()
{ {
@ -282,6 +349,17 @@ void TransfersDialog::insertTransfers()
qlonglong fileSize, completed, remaining; qlonglong fileSize, completed, remaining;
double progress, dlspeed; double progress, dlspeed;
/* get current selection */
std::list<std::string> selectedIds;
for(int i = 0; i <= DLListModel->rowCount(); i++) {
if(selection->isRowSelected(i, QModelIndex())) {
std::string id = getID(i, DLListModel).toStdString();
selectedIds.push_back(id);
}
}
//remove all Items //remove all Items
for(int i = DLListModel->rowCount(); i >= 0; i--) for(int i = DLListModel->rowCount(); i >= 0; i--)
{ {
@ -300,6 +378,9 @@ void TransfersDialog::insertTransfers()
std::list<FileTransferInfo>::const_iterator it; std::list<FileTransferInfo>::const_iterator it;
const std::list<FileTransferInfo> &transfers = rsiface->getTransferList(); const std::list<FileTransferInfo> &transfers = rsiface->getTransferList();
uint32_t dlCount = 0;
uint32_t ulCount = 0;
for(it = transfers.begin(); it != transfers.end(); it++) for(it = transfers.begin(); it != transfers.end(); it++)
{ {
@ -316,21 +397,28 @@ void TransfersDialog::insertTransfers()
switch(it->downloadStatus) switch(it->downloadStatus)
{ {
/* XXX HAND CODED! */
/******** XXX HAND CODED!
#define FT_STATE_FAILED 0
#define FT_STATE_OKAY 1
#define FT_STATE_WAITING 2
#define FT_STATE_DOWNLOADING 3
#define FT_STATE_COMPLETE 4
*******************/
case 0: /* FAILED */ case 0: /* FAILED */
status = "Failed"; status = "Failed";
break; break;
case 1: /* Downloading */ case 1: /* OKAY */
if (it->tfRate > 0.01) status = "Okay";
{
status = "Downloading";
}
else
{
status = "Waiting for Peer";
}
break; break;
case 2: /* COMPLETE */ case 2: /* WAITING */
status = "Waiting";
break;
case 3: /* DOWNLOADING */
status = "Downloading";
break;
case 4: /* COMPLETE */
default: default:
status = "Complete"; status = "Complete";
break; break;
@ -347,11 +435,21 @@ void TransfersDialog::insertTransfers()
{ {
addItem(symbol, name, coreId, fileSize, progress, addItem(symbol, name, coreId, fileSize, progress,
dlspeed, sources, status, completed, remaining); dlspeed, sources, status, completed, remaining);
/* if found in selectedIds -> select again */
if (selectedIds.end() != std::find(selectedIds.begin(), selectedIds.end(), it->hash))
{
selection->select(DLListModel->index(dlCount, 0),
QItemSelectionModel::Rows | QItemSelectionModel::SelectCurrent);
}
dlCount++;
} }
else else
{ {
addUploadItem(symbol, name, coreId, fileSize, progress, addUploadItem(symbol, name, coreId, fileSize, progress,
dlspeed, sources, status, completed, remaining); dlspeed, sources, status, completed, remaining);
ulCount++;
} }
} }

View File

@ -61,7 +61,10 @@ private slots:
void cancel(); void cancel();
/** removes finished Downloads**/ /** removes finished Downloads**/
void clearcompleted(); void clearcompleted();
void playSelectedTransfer();
signals:
void playFiles(QStringList files);
private: private:
QStandardItemModel *DLListModel; QStandardItemModel *DLListModel;

View File

@ -692,3 +692,53 @@ void RemoteDirModel::openSelected(QModelIndexList list)
recommendSelected(list); recommendSelected(list);
} }
void RemoteDirModel::getFilePaths(QModelIndexList list, std::list<std::string> &fullpaths)
{
std::cerr << "RemoteDirModel::getFilePaths()" << std::endl;
if (RemoteMode)
{
std::cerr << "No File Paths for remote files" << std::endl;
return;
}
/* translate */
QModelIndexList::iterator it;
for(it = list.begin(); it != list.end(); it++)
{
void *ref = it -> internalPointer();
DirDetails details;
uint32_t flags = DIR_FLAGS_DETAILS;
flags |= DIR_FLAGS_LOCAL;
if (!rsicontrol->RequestDirDetails(ref, details, flags))
{
std::cerr << "getFilePaths() Bad Request" << std::endl;
continue;
}
if (details.type != DIR_TYPE_FILE)
{
std::cerr << "getFilePaths() Not File" << std::endl;
continue; /* not file! */
}
std::cerr << "::::::::::::File Details:::: " << std::endl;
std::cerr << "Name: " << details.name << std::endl;
std::cerr << "Hash: " << details.hash << std::endl;
std::cerr << "Size: " << details.count << std::endl;
std::cerr << "Path: " << details.path << std::endl;
std::string filepath = details.path + "/";
filepath += details.name;
std::cerr << "Constructed FilePath: " << filepath << std::endl;
if (fullpaths.end() == std::find(fullpaths.begin(), fullpaths.end(), filepath))
{
fullpaths.push_back(filepath);
}
}
std::cerr << "::::::::::::Done getFilePaths" << std::endl;
}

View File

@ -3,6 +3,8 @@
#include <QAbstractItemModel> #include <QAbstractItemModel>
#include <vector> #include <vector>
#include <list>
#include <string>
class RemoteDirModel : public QAbstractItemModel class RemoteDirModel : public QAbstractItemModel
{ {
@ -40,6 +42,8 @@ class RemoteDirModel : public QAbstractItemModel
void recommendSelectedOnly(QModelIndexList list); void recommendSelectedOnly(QModelIndexList list);
void openSelected(QModelIndexList list); void openSelected(QModelIndexList list);
void getFilePaths(QModelIndexList list, std::list<std::string> &fullpaths);
public slots: public slots:
void collapsed ( const QModelIndex & index ) { update(index); } void collapsed ( const QModelIndex & index ) { update(index); }

View File

@ -193,6 +193,10 @@ virtual int StartupRetroShare(RsInit *config) = 0;
virtual int RequestDirDetails(std::string uid, std::string path, DirDetails &details) = 0; virtual int RequestDirDetails(std::string uid, std::string path, DirDetails &details) = 0;
virtual int RequestDirDetails(void *ref, DirDetails &details, uint32_t flags) = 0; virtual int RequestDirDetails(void *ref, DirDetails &details, uint32_t flags) = 0;
virtual bool ConvertSharedFilePath(std::string path, std::string &fullpath) = 0;
virtual void ForceDirectoryCheck() = 0;
virtual bool InDirectoryCheck() = 0;
/****************************************/ /****************************************/
/* Search Actions */ /* Search Actions */
virtual int SearchKeywords(std::list<std::string> keywords, std::list<FileDetail> &results) = 0; virtual int SearchKeywords(std::list<std::string> keywords, std::list<FileDetail> &results) = 0;

View File

@ -65,11 +65,6 @@ virtual bool GetPopupMessageList(std::map<uint32_t, std::string> &list) = 0;
virtual bool SetSysMessageMode(uint32_t sysid, uint32_t mode) = 0; virtual bool SetSysMessageMode(uint32_t sysid, uint32_t mode) = 0;
virtual bool SetPopupMessageMode(uint32_t ptype, uint32_t mode) = 0; virtual bool SetPopupMessageMode(uint32_t ptype, uint32_t mode) = 0;
/* Input from libretroshare */
virtual bool AddPopupMessage(uint32_t ptype, std::string name, std::string msg) = 0;
virtual bool AddSysMessage(uint32_t sysid, uint32_t type,
std::string title, std::string msg) = 0;
}; };