2007-11-14 22:18:48 -05:00
|
|
|
|
|
|
|
#include "rsiface/notifyqt.h"
|
2008-03-05 11:32:18 -05:00
|
|
|
#include "rsiface/rsnotify.h"
|
|
|
|
#include "rsiface/rspeers.h"
|
2008-03-17 10:03:47 -04:00
|
|
|
#include "rsiface/rsphoto.h"
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef TURTLE_HOPPING
|
|
|
|
#include <rsiface/rsturtle.h>
|
|
|
|
#endif
|
2007-11-14 22:18:48 -05:00
|
|
|
|
|
|
|
#include "gui/NetworkDialog.h"
|
|
|
|
#include "gui/PeersDialog.h"
|
|
|
|
#include "gui/SharedFilesDialog.h"
|
|
|
|
#include "gui/TransfersDialog.h"
|
2009-05-05 13:22:03 -04:00
|
|
|
//#include "gui/ChatDialog.h"
|
2007-11-14 22:18:48 -05:00
|
|
|
#include "gui/MessagesDialog.h"
|
|
|
|
#include "gui/ChannelsDialog.h"
|
|
|
|
#include "gui/MessengerWindow.h"
|
|
|
|
|
2008-08-08 15:47:50 -04:00
|
|
|
#include "gui/toaster/OnlineToaster.h"
|
2008-03-05 11:32:18 -05:00
|
|
|
#include "gui/toaster/MessageToaster.h"
|
|
|
|
#include "gui/toaster/ChatToaster.h"
|
|
|
|
#include "gui/toaster/CallToaster.h"
|
|
|
|
|
2008-12-07 09:19:13 -05:00
|
|
|
#include "gui/Preferences/rsharesettings.h"
|
|
|
|
|
2007-11-14 22:18:48 -05:00
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
|
2008-07-09 05:53:47 -04:00
|
|
|
/*****
|
|
|
|
* #define NOTIFY_DEBUG
|
|
|
|
****/
|
|
|
|
|
2007-11-14 22:18:48 -05:00
|
|
|
void NotifyQt::notifyErrorMsg(int list, int type, std::string msg)
|
|
|
|
{
|
|
|
|
(void) list;
|
|
|
|
(void) type;
|
|
|
|
(void) msg;
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2009-05-05 09:18:53 -04:00
|
|
|
void NotifyQt::notifyChatStatus(const std::string& peer_id,const std::string& status_string)
|
|
|
|
{
|
|
|
|
std::cerr << "Received chat status string: " << status_string << std::endl ;
|
|
|
|
emit chatStatusChanged(QString::fromStdString(peer_id),QString::fromStdString(status_string)) ;
|
|
|
|
}
|
|
|
|
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef TURTLE_HOPPING
|
|
|
|
void NotifyQt::notifyTurtleSearchResult(uint32_t search_id,const std::list<TurtleFileInfo>& files)
|
|
|
|
{
|
|
|
|
std::cerr << "in notify search result..." << std::endl ;
|
|
|
|
|
|
|
|
for(std::list<TurtleFileInfo>::const_iterator it(files.begin());it!=files.end();++it)
|
|
|
|
emit gotTurtleSearchResult(search_id,*it) ;
|
|
|
|
}
|
|
|
|
#endif
|
2009-01-22 16:06:54 -05:00
|
|
|
void NotifyQt::notifyHashingInfo(std::string fileinfo)
|
|
|
|
{
|
2009-02-22 12:36:39 -05:00
|
|
|
emit hashingInfoChanged(QString::fromStdString(fileinfo)) ;
|
2009-01-22 16:06:54 -05:00
|
|
|
}
|
|
|
|
|
2009-05-05 09:18:53 -04:00
|
|
|
//void NotifyQt::notifyChat()
|
|
|
|
//{
|
|
|
|
// std::cerr << "Received chat notification" << std::endl ;
|
|
|
|
// return;
|
|
|
|
//}
|
2007-11-14 22:18:48 -05:00
|
|
|
|
|
|
|
void NotifyQt::notifyListChange(int list, int type)
|
|
|
|
{
|
|
|
|
(void) type;
|
2008-07-09 05:53:47 -04:00
|
|
|
|
|
|
|
#ifdef NOTIFY_DEBUG
|
2007-11-14 22:18:48 -05:00
|
|
|
std::cerr << "NotifyQt::notifyListChange()" << std::endl;
|
2008-07-09 05:53:47 -04:00
|
|
|
#endif
|
2007-11-14 22:18:48 -05:00
|
|
|
switch(list)
|
|
|
|
{
|
|
|
|
case NOTIFY_LIST_NEIGHBOURS:
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef DEBUG
|
|
|
|
std::cerr << "received neighbrs changed" << std::endl ;
|
|
|
|
#endif
|
2009-02-22 12:36:39 -05:00
|
|
|
emit neighborsChanged();
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_FRIENDS:
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef DEBUG
|
|
|
|
std::cerr << "received friends changed" << std::endl ;
|
|
|
|
#endif
|
2009-02-22 12:36:39 -05:00
|
|
|
emit friendsChanged() ;
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_DIRLIST:
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef DEBUG
|
|
|
|
std::cerr << "received files changed" << std::endl ;
|
|
|
|
#endif
|
2009-02-22 12:36:39 -05:00
|
|
|
emit filesPostModChanged(false) ; /* Remote */
|
|
|
|
emit filesPostModChanged(true) ; /* Local */
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_SEARCHLIST:
|
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_MESSAGELIST:
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef DEBUG
|
|
|
|
std::cerr << "received msg changed" << std::endl ;
|
|
|
|
#endif
|
2009-02-22 12:36:39 -05:00
|
|
|
emit messagesChanged() ;
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_CHANNELLIST:
|
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_TRANSFERLIST:
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef DEBUG
|
|
|
|
std::cerr << "received transfer changed" << std::endl ;
|
|
|
|
#endif
|
2009-02-22 12:36:39 -05:00
|
|
|
emit transfersChanged() ;
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
2009-02-22 12:36:39 -05:00
|
|
|
case NOTIFY_LIST_CONFIG:
|
2009-03-15 18:45:40 -04:00
|
|
|
#ifdef DEBUG
|
|
|
|
std::cerr << "received config changed" << std::endl ;
|
|
|
|
#endif
|
2009-02-22 12:36:39 -05:00
|
|
|
emit configChanged() ;
|
|
|
|
break ;
|
2007-11-14 22:18:48 -05:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void NotifyQt::notifyListPreChange(int list, int type)
|
|
|
|
{
|
2008-07-09 05:53:47 -04:00
|
|
|
#ifdef NOTIFY_DEBUG
|
2007-11-14 22:18:48 -05:00
|
|
|
std::cerr << "NotifyQt::notifyListPreChange()" << std::endl;
|
2008-07-09 05:53:47 -04:00
|
|
|
#endif
|
2007-11-14 22:18:48 -05:00
|
|
|
switch(list)
|
|
|
|
{
|
|
|
|
case NOTIFY_LIST_NEIGHBOURS:
|
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_FRIENDS:
|
2009-02-22 12:36:39 -05:00
|
|
|
emit friendsChanged() ;
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_DIRLIST:
|
2009-02-22 12:36:39 -05:00
|
|
|
emit filesPreModChanged(false) ; /* remote */
|
|
|
|
emit filesPreModChanged(true) ; /* local */
|
2007-11-14 22:18:48 -05:00
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_SEARCHLIST:
|
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_MESSAGELIST:
|
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_CHANNELLIST:
|
|
|
|
break;
|
|
|
|
case NOTIFY_LIST_TRANSFERLIST:
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* New Timer Based Update scheme ...
|
|
|
|
* means correct thread seperation
|
|
|
|
*
|
|
|
|
* uses Flags, to detect changes
|
|
|
|
*/
|
|
|
|
|
|
|
|
void NotifyQt::UpdateGUI()
|
|
|
|
{
|
2008-01-25 03:49:40 -05:00
|
|
|
/* hack to force updates until we've fixed that part */
|
2009-02-22 12:36:39 -05:00
|
|
|
static time_t lastTs = 0;
|
2008-01-25 03:49:40 -05:00
|
|
|
|
2009-03-15 18:45:40 -04:00
|
|
|
// std::cerr << "Got update signal t=" << lastTs << std::endl ;
|
|
|
|
|
2009-02-22 12:36:39 -05:00
|
|
|
if (time(NULL) > lastTs) // always update, every 1 sec.
|
2008-01-25 03:49:40 -05:00
|
|
|
{
|
2009-02-22 12:36:39 -05:00
|
|
|
emit transfersChanged();
|
|
|
|
emit friendsChanged() ;
|
2008-01-25 03:49:40 -05:00
|
|
|
}
|
|
|
|
|
2009-02-22 12:36:39 -05:00
|
|
|
if (time(NULL) > lastTs + 5) // update every 5 seconds. I don't know what to do with these.
|
|
|
|
{
|
2009-05-05 09:18:53 -04:00
|
|
|
// displayChannels();
|
2009-02-22 12:36:39 -05:00
|
|
|
}
|
2007-11-14 22:18:48 -05:00
|
|
|
|
2009-03-01 10:18:34 -05:00
|
|
|
lastTs = time(NULL) ;
|
|
|
|
|
2009-02-22 12:36:39 -05:00
|
|
|
static bool already_updated = false ; // these only update once at start because they may already have been set before
|
|
|
|
// the gui is running, then they get updated by callbacks.
|
|
|
|
if(!already_updated)
|
|
|
|
{
|
|
|
|
emit messagesChanged() ;
|
|
|
|
emit neighborsChanged();
|
|
|
|
emit configChanged();
|
2007-11-14 22:18:48 -05:00
|
|
|
|
2009-02-22 12:36:39 -05:00
|
|
|
already_updated = true ;
|
|
|
|
}
|
|
|
|
|
2008-03-05 11:32:18 -05:00
|
|
|
/* Finally Check for PopupMessages / System Error Messages */
|
2007-11-14 22:18:48 -05:00
|
|
|
|
2008-03-05 11:32:18 -05:00
|
|
|
if (rsNotify)
|
|
|
|
{
|
|
|
|
uint32_t sysid;
|
|
|
|
uint32_t type;
|
|
|
|
std::string title, id, msg;
|
|
|
|
|
|
|
|
if (rsNotify->NotifyPopupMessage(type, id, msg))
|
|
|
|
{
|
2008-12-07 09:19:13 -05:00
|
|
|
RshareSettings settings;
|
|
|
|
uint popupflags = settings.getNotifyFlags();
|
|
|
|
|
2008-03-05 11:32:18 -05:00
|
|
|
/* id the name */
|
|
|
|
std::string name = rsPeers->getPeerName(id);
|
2008-11-16 22:03:23 -05:00
|
|
|
std::string realmsg = msg + "<strong>" + name + "</strong>";
|
2008-03-05 11:32:18 -05:00
|
|
|
switch(type)
|
|
|
|
{
|
|
|
|
case RS_POPUP_MSG:
|
2008-12-07 09:19:13 -05:00
|
|
|
if (popupflags & RS_POPUP_MSG)
|
2008-03-05 11:32:18 -05:00
|
|
|
{
|
|
|
|
MessageToaster * msgToaster = new MessageToaster();
|
|
|
|
msgToaster->setMessage(QString::fromStdString(realmsg));
|
|
|
|
msgToaster->show();
|
|
|
|
}
|
2008-12-07 09:19:13 -05:00
|
|
|
break;
|
2008-03-05 11:32:18 -05:00
|
|
|
case RS_POPUP_CHAT:
|
2008-12-07 09:19:13 -05:00
|
|
|
if (popupflags & RS_POPUP_CHAT)
|
2008-03-05 11:32:18 -05:00
|
|
|
{
|
|
|
|
ChatToaster * chatToaster = new ChatToaster();
|
|
|
|
chatToaster->setMessage(QString::fromStdString(realmsg));
|
|
|
|
chatToaster->show();
|
|
|
|
}
|
2008-12-07 09:19:13 -05:00
|
|
|
break;
|
2008-03-05 11:32:18 -05:00
|
|
|
case RS_POPUP_CALL:
|
2008-12-07 09:19:13 -05:00
|
|
|
if (popupflags & RS_POPUP_CALL)
|
2008-03-05 11:32:18 -05:00
|
|
|
{
|
|
|
|
CallToaster * callToaster = new CallToaster();
|
|
|
|
callToaster->setMessage(QString::fromStdString(realmsg));
|
|
|
|
callToaster->show();
|
|
|
|
}
|
2008-12-07 09:19:13 -05:00
|
|
|
break;
|
2008-03-05 11:32:18 -05:00
|
|
|
default:
|
|
|
|
case RS_POPUP_CONNECT:
|
2008-12-07 09:19:13 -05:00
|
|
|
if (popupflags & RS_POPUP_CONNECT)
|
2008-03-05 11:32:18 -05:00
|
|
|
{
|
2008-08-08 15:47:50 -04:00
|
|
|
OnlineToaster * onlineToaster = new OnlineToaster();
|
|
|
|
onlineToaster->setMessage(QString::fromStdString(realmsg));
|
|
|
|
onlineToaster->show();
|
2008-03-05 11:32:18 -05:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (rsNotify->NotifySysMessage(sysid, type, title, msg))
|
|
|
|
{
|
|
|
|
/* make a warning message */
|
|
|
|
switch(type)
|
|
|
|
{
|
|
|
|
case RS_SYS_ERROR:
|
|
|
|
QMessageBox::critical(0,
|
|
|
|
QString::fromStdString(title),
|
|
|
|
QString::fromStdString(msg));
|
|
|
|
break;
|
|
|
|
case RS_SYS_WARNING:
|
|
|
|
QMessageBox::warning(0,
|
|
|
|
QString::fromStdString(title),
|
|
|
|
QString::fromStdString(msg));
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
case RS_SYS_INFO:
|
|
|
|
QMessageBox::information(0,
|
|
|
|
QString::fromStdString(title),
|
|
|
|
QString::fromStdString(msg));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2009-05-05 09:35:36 -04:00
|
|
|
if (rsNotify->NotifyLogMessage(sysid, type, title, msg))
|
|
|
|
{
|
|
|
|
/* make a log message */
|
|
|
|
std::string logMesString = title + " " + msg;
|
|
|
|
switch(type)
|
|
|
|
{
|
|
|
|
case RS_SYS_ERROR:
|
|
|
|
case RS_SYS_WARNING:
|
2009-05-05 15:50:45 -04:00
|
|
|
case RS_SYS_INFO: emit logInfoChanged(QString(logMesString.c_str()));
|
|
|
|
default:;
|
2009-05-05 09:35:36 -04:00
|
|
|
}
|
|
|
|
}
|
2008-03-05 11:32:18 -05:00
|
|
|
}
|
|
|
|
}
|
2007-11-14 22:18:48 -05:00
|
|
|
|
2009-05-05 09:18:53 -04:00
|
|
|
//void NotifyQt::displaySearch()
|
|
|
|
//{
|
|
|
|
// iface->lockData(); /* Lock Interface */
|
|
|
|
//
|
|
|
|
//#ifdef NOTIFY_DEBUG
|
|
|
|
// std::ostringstream out;
|
|
|
|
// std::cerr << out.str();
|
|
|
|
//#endif
|
|
|
|
//
|
|
|
|
// iface->unlockData(); /* UnLock Interface */
|
|
|
|
//}
|
|
|
|
|
|
|
|
// void NotifyQt::displayChat()
|
|
|
|
// {
|
|
|
|
// iface->lockData(); /* Lock Interface */
|
|
|
|
//
|
|
|
|
// #ifdef NOTIFY_DEBUG
|
|
|
|
// std::ostringstream out;
|
|
|
|
// std::cerr << out.str();
|
|
|
|
// #endif
|
|
|
|
//
|
|
|
|
// iface->unlockData(); /* UnLock Interface */
|
|
|
|
//
|
|
|
|
// if (hDialog)
|
|
|
|
// hDialog -> insertChat();
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//void NotifyQt::displayChannels()
|
|
|
|
//{
|
|
|
|
// iface->lockData(); /* Lock Interface */
|
|
|
|
//
|
|
|
|
//#ifdef NOTIFY_DEBUG
|
|
|
|
// std::ostringstream out;
|
|
|
|
// std::cerr << out.str();
|
|
|
|
//#endif
|
|
|
|
//
|
|
|
|
// iface->unlockData(); /* UnLock Interface */
|
|
|
|
//
|
|
|
|
// if (sDialog)
|
|
|
|
// sDialog -> insertChannels();
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//void NotifyQt::displayTransfers()
|
|
|
|
//{
|
|
|
|
// /* Do the GUI */
|
|
|
|
// if (tDialog)
|
|
|
|
// tDialog->insertTransfers();
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//void NotifyQt::preDisplayNeighbours()
|
|
|
|
//{
|
|
|
|
//
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//void NotifyQt::preDisplayFriends()
|
|
|
|
//{
|
|
|
|
//
|
|
|
|
//}
|
|
|
|
|
|
|
|
//void NotifyQt::preDisplaySearch()
|
|
|
|
//{
|
|
|
|
//
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//void NotifyQt::preDisplayMessages()
|
|
|
|
//{
|
|
|
|
//
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//void NotifyQt::preDisplayChannels()
|
|
|
|
//{
|
|
|
|
//
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//void NotifyQt::preDisplayTransfers()
|
|
|
|
//{
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//}
|
2007-11-14 22:18:48 -05:00
|
|
|
|
|
|
|
|
|
|
|
|