diff --git a/retroshare-gui/src/gui/notifyqt.cpp b/retroshare-gui/src/gui/notifyqt.cpp new file mode 100644 index 000000000..21ce02319 --- /dev/null +++ b/retroshare-gui/src/gui/notifyqt.cpp @@ -0,0 +1,402 @@ + +#include "notifyqt.h" +#include "rsiface/rsnotify.h" +#include "rsiface/rspeers.h" +#include "rsiface/rsphoto.h" +#ifdef TURTLE_HOPPING +#include +#endif + +#include "gui/NetworkDialog.h" +#include "gui/PeersDialog.h" +#include "gui/SharedFilesDialog.h" +#include "gui/TransfersDialog.h" +#include "gui/MessagesDialog.h" +#include "gui/MessengerWindow.h" + +#include "gui/toaster/OnlineToaster.h" +#include "gui/toaster/MessageToaster.h" +#include "gui/toaster/ChatToaster.h" +#include "gui/toaster/CallToaster.h" + +#include "gui/settings/rsharesettings.h" + +#include +#include + +/***** + * #define NOTIFY_DEBUG + ****/ + +void NotifyQt::notifyErrorMsg(int list, int type, std::string msg) +{ + (void) list; + (void) type; + (void) msg; + + return; +} + +void NotifyQt::notifyOwnAvatarChanged() +{ + std::cerr << "Notifyqt:: notified that own avatar changed" << std::endl ; + emit ownAvatarChanged() ; +} + +std::string NotifyQt::askForPassword(const std::string& window_title,const std::string& text) +{ + return QInputDialog::getText(NULL, QString::fromStdString(window_title), + QString::fromStdString(text), QLineEdit::Password, + NULL, NULL).toStdString(); +} + +void NotifyQt::notifyOwnStatusMessageChanged() +{ + std::cerr << "Notifyqt:: notified that own avatar changed" << std::endl ; + emit ownStatusMessageChanged() ; +} + +void NotifyQt::notifyPeerHasNewAvatar(std::string peer_id) +{ + std::cerr << "notifyQt: notification of new avatar." << std::endl ; + emit peerHasNewAvatar(QString::fromStdString(peer_id)) ; +} + +void NotifyQt::notifyCustomState(const std::string& peer_id) +{ + std::cerr << "notifyQt: Received custom status string notification" << std::endl ; + emit peerHasNewCustomStateString(QString::fromStdString(peer_id)) ; +} + +void NotifyQt::notifyChatStatus(const std::string& peer_id,const std::string& status_string,bool is_private) +{ + std::cerr << "notifyQt: Received chat status string: " << status_string << std::endl ; + emit chatStatusChanged(QString::fromStdString(peer_id),QString::fromStdString(status_string),is_private) ; +} + +void NotifyQt::notifyTurtleSearchResult(uint32_t search_id,const std::list& files) +{ + std::cerr << "in notify search result..." << std::endl ; + + for(std::list::const_iterator it(files.begin());it!=files.end();++it) + { + FileDetail det ; + det.rank = 0 ; + det.age = 0 ; + det.name = (*it).name ; + det.hash = (*it).hash ; + det.size = (*it).size ; + det.id = "Anonymous" ; + + emit gotTurtleSearchResult(search_id,det) ; + } +} + +void NotifyQt::notifyHashingInfo(std::string fileinfo) +{ + emit hashingInfoChanged(QString::fromStdString(fileinfo)) ; +} + +//void NotifyQt::notifyChat() +//{ +// std::cerr << "Received chat notification" << std::endl ; +// return; +//} + +void NotifyQt::notifyListChange(int list, int type) +{ +#ifdef NOTIFY_DEBUG + std::cerr << "NotifyQt::notifyListChange()" << std::endl; +#endif + switch(list) + { + case NOTIFY_LIST_NEIGHBOURS: +#ifdef DEBUG + std::cerr << "received neighbrs changed" << std::endl ; +#endif + emit neighborsChanged(); + break; + case NOTIFY_LIST_FRIENDS: +#ifdef DEBUG + std::cerr << "received friends changed" << std::endl ; +#endif + emit friendsChanged() ; + break; + case NOTIFY_LIST_DIRLIST_LOCAL: +#ifdef DEBUG + std::cerr << "received files changed" << std::endl ; +#endif + emit filesPostModChanged(true) ; /* Local */ + break; + case NOTIFY_LIST_DIRLIST_FRIENDS: +#ifdef DEBUG + std::cerr << "received files changed" << std::endl ; +#endif + emit filesPostModChanged(false) ; /* Local */ + break; + case NOTIFY_LIST_SEARCHLIST: + break; + case NOTIFY_LIST_MESSAGELIST: +#ifdef DEBUG + std::cerr << "received msg changed" << std::endl ; +#endif + emit messagesChanged() ; + break; + case NOTIFY_LIST_CHANNELLIST: + break; + case NOTIFY_LIST_TRANSFERLIST: +#ifdef DEBUG + std::cerr << "received transfer changed" << std::endl ; +#endif + emit transfersChanged() ; + break; + case NOTIFY_LIST_CONFIG: +#ifdef DEBUG + std::cerr << "received config changed" << std::endl ; +#endif + emit configChanged() ; + break ; + default: + break; + } + return; +} + + +void NotifyQt::notifyListPreChange(int list, int type) +{ +#ifdef NOTIFY_DEBUG + std::cerr << "NotifyQt::notifyListPreChange()" << std::endl; +#endif + switch(list) + { + case NOTIFY_LIST_NEIGHBOURS: + break; + case NOTIFY_LIST_FRIENDS: + emit friendsChanged() ; + break; + case NOTIFY_LIST_DIRLIST_FRIENDS: + emit filesPreModChanged(false) ; /* remote */ + break ; + case NOTIFY_LIST_DIRLIST_LOCAL: + emit filesPreModChanged(true) ; /* local */ + 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() +{ + /* hack to force updates until we've fixed that part */ + static time_t lastTs = 0; + +// std::cerr << "Got update signal t=" << lastTs << std::endl ; + + lastTs = time(NULL) ; + + 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(); + + already_updated = true ; + } + + /* Finally Check for PopupMessages / System Error Messages */ + + if (rsNotify) + { + uint32_t sysid; + uint32_t type; + std::string title, id, msg; + + if (rsNotify->NotifyPopupMessage(type, id, msg)) + { + RshareSettings settings; + uint popupflags = settings.getNotifyFlags(); + + /* id the name */ + std::string name = rsPeers->getPeerName(id); + std::string realmsg = "" + name + ""; + switch(type) + { + case RS_POPUP_MSG: + if (popupflags & RS_POPUP_MSG) + { + MessageToaster * msgToaster = new MessageToaster(); + //msgToaster->setMessage(QString::fromStdString(title)); + msgToaster->setName(QString::fromStdString(realmsg)); + msgToaster->displayPopup(); + } + break; + case RS_POPUP_CHAT: + if (popupflags & RS_POPUP_CHAT) + { + ChatToaster * chatToaster = new ChatToaster(); + chatToaster->setMessage(QString::fromStdString(realmsg)); + chatToaster->show(); + } + break; + case RS_POPUP_CALL: + if (popupflags & RS_POPUP_CALL) + { + CallToaster * callToaster = new CallToaster(); + callToaster->setMessage(QString::fromStdString(realmsg)); + callToaster->show(); + } + break; + default: + case RS_POPUP_CONNECT: + if (popupflags & RS_POPUP_CONNECT) + { + OnlineToaster * onlineToaster = new OnlineToaster(); + onlineToaster->setMessage(QString::fromStdString(realmsg)); + onlineToaster->show(); + } + 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; + } + } + 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: + case RS_SYS_INFO: emit logInfoChanged(QString(logMesString.c_str())); + default:; + } + } + } +} + +//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() +//{ +// +// +//} + + + diff --git a/retroshare-gui/src/gui/notifyqt.h b/retroshare-gui/src/gui/notifyqt.h new file mode 100644 index 000000000..e6e0409ab --- /dev/null +++ b/retroshare-gui/src/gui/notifyqt.h @@ -0,0 +1,101 @@ +#ifndef RSIFACE_NOTIFY_TXT_H +#define RSIFACE_NOTIFY_TXT_H + +#include "rsiface/rsiface.h" +#include "rsiface/rsturtle.h" +#include + +#include + +class NetworkDialog; +class PeersDialog; +class SharedFilesDialog; +class TransfersDialog; +class ChatDialog; +class MessagesDialog; +class ChannelsDialog; +class MessengerWindow; +struct TurtleFileInfo ; + +//class NotifyQt: public NotifyBase, public QObject +class NotifyQt: public QObject, public NotifyBase +{ + Q_OBJECT + public: + NotifyQt() + : cDialog(NULL) + { return; } + + virtual ~NotifyQt() { return; } + + void setNetworkDialog(NetworkDialog *c) { cDialog = c; } + + virtual void notifyListPreChange(int list, int type); + virtual void notifyListChange(int list, int type); + virtual void notifyErrorMsg(int list, int sev, std::string msg); + virtual void notifyChatStatus(const std::string& peer_id,const std::string& status_string,bool is_private); + virtual void notifyCustomState(const std::string& peer_id); + virtual void notifyHashingInfo(std::string fileinfo); + virtual void notifyTurtleSearchResult(uint32_t search_id,const std::list& found_files); + virtual void notifyPeerHasNewAvatar(std::string peer_id) ; + virtual void notifyOwnAvatarChanged() ; + virtual void notifyOwnStatusMessageChanged() ; + virtual std::string askForPassword(const std::string& window_title,const std::string& text) ; + + signals: + // It's beneficial to send info to the GUI using signals, because signals are thread-safe + // as they get queued by Qt. + // + void hashingInfoChanged(const QString&) const ; + void filesPreModChanged(bool) const ; + void filesPostModChanged(bool) const ; + void transfersChanged() const ; + void friendsChanged() const ; + void neighborsChanged() const ; + void messagesChanged() const ; + void configChanged() const ; + void logInfoChanged(const QString&) const ; + void chatStatusChanged(const QString&,const QString&,bool) const ; + void peerHasNewCustomStateString(const QString&) const ; + void gotTurtleSearchResult(qulonglong search_id,FileDetail file) const ; + void peerHasNewAvatar(const QString& peer_id) const ; + void ownAvatarChanged() const ; + void ownStatusMessageChanged() const ; + + public slots: + + void UpdateGUI(); /* called by timer */ + + private: + +// void displayNeighbours(); +// void displayFriends(); +// void displayDirectories(); +// void displaySearch(); +// void displayChat(); +// void displayMessages(); +// void displayChannels(); +// void displayTransfers(); + +// void preDisplayNeighbours(); +// void preDisplayFriends(); +// void preDisplayDirectories(); +// void preDisplaySearch(); +// void preDisplayMessages(); +// void preDisplayChannels(); +// void preDisplayTransfers(); + + /* so we can update windows */ + NetworkDialog *cDialog; +// PeersDialog *pDialog; +// SharedFilesDialog *dDialog; +// TransfersDialog *tDialog; +// ChatDialog *hDialog; +// MessagesDialog *mDialog; +// ChannelsDialog *sDialog; +// MessengerWindow *mWindow; + +// RsIface *iface; +}; + +#endif