#include #include "RsGxsUpdateBroadcastBase.h" #include "RsAutoUpdatePage.h" #include "util/RsGxsUpdateBroadcast.h" #include RsGxsUpdateBroadcastBase::RsGxsUpdateBroadcastBase(RsGxsIfaceHelper *ifaceImpl, QWidget *parent) : QObject(parent) { mUpdateWhenInvisible = false; mFillComplete = true; mUpdateBroadcast = RsGxsUpdateBroadcast::get(ifaceImpl); connect(mUpdateBroadcast, SIGNAL(changed()), this, SLOT(updateBroadcastChanged())); connect(mUpdateBroadcast, SIGNAL(grpsChanged(std::list, std::list)), this, SLOT(updateBroadcastGrpsChanged(std::list,std::list))); connect(mUpdateBroadcast, SIGNAL(msgsChanged(std::map >, std::map >)), this, SLOT(updateBroadcastMsgsChanged(std::map >,std::map >))); } RsGxsUpdateBroadcastBase::~RsGxsUpdateBroadcastBase() { } void RsGxsUpdateBroadcastBase::fillComplete() { mFillComplete = true; updateBroadcastChanged(); } void RsGxsUpdateBroadcastBase::securedUpdateDisplay() { if (RsAutoUpdatePage::eventsLocked()) { /* Wait until events are not locked */ QTimer::singleShot(500, this, SLOT(securedUpdateDisplay())); return; } emit fillDisplay(mFillComplete); mFillComplete = false; /* Clear updated ids */ mGrpIds.clear(); mGrpIdsMeta.clear(), mMsgIds.clear(); mMsgIdsMeta.clear(); } void RsGxsUpdateBroadcastBase::showEvent(QShowEvent */*event*/) { if (mFillComplete) { /* Initial fill */ securedUpdateDisplay(); } if (!mUpdateWhenInvisible) { if (!mGrpIds.empty() || !mGrpIdsMeta.empty() || !mMsgIds.empty() || !mMsgIdsMeta.empty()) { securedUpdateDisplay(); } } } void RsGxsUpdateBroadcastBase::updateBroadcastChanged() { QWidget *widget = qobject_cast(parent()); /* Update only update when the widget is visible. */ if (mUpdateWhenInvisible || !widget || widget->isVisible()) { // (cyril) Re-load the entire group is new messages are here, or if group metadata has changed (e.g. visibility permissions, admin rights, etc). // Do not re-load if Msg data has changed, which means basically the READ flag has changed, because this action is done in the UI in the // first place so there's no need to re-update the UI once this is done. // // The question to whether we should re=load when mGrpIds is not empty is still open. It's not harmful anyway. if (!mGrpIds.empty() || !mGrpIdsMeta.empty() /*|| !mMsgIds.empty()*/ || !mMsgIdsMeta.empty()) mFillComplete = true ; securedUpdateDisplay(); } } void RsGxsUpdateBroadcastBase::updateBroadcastGrpsChanged(const std::list &grpIds, const std::list &grpIdsMeta) { std::list::const_iterator it; for (it = grpIds.begin(); it != grpIds.end(); ++it) { if (std::find(mGrpIds.begin(), mGrpIds.end(), *it) == mGrpIds.end()) { mGrpIds.push_back(*it); } } for (it = grpIdsMeta.begin(); it != grpIdsMeta.end(); ++it) { if (std::find(mGrpIdsMeta.begin(), mGrpIdsMeta.end(), *it) == mGrpIdsMeta.end()) { mGrpIdsMeta.push_back(*it); } } } void RsGxsUpdateBroadcastBase::updateBroadcastMsgsChanged(const std::map > &msgIds, const std::map > &msgIdsMeta) { std::map >::const_iterator mapIt; for (mapIt = msgIds.begin(); mapIt != msgIds.end(); ++mapIt) { const RsGxsGroupId &grpId = mapIt->first; const std::vector &srcMsgIds = mapIt->second; std::vector &destMsgIds = mMsgIds[grpId]; std::vector::const_iterator msgIt; for (msgIt = srcMsgIds.begin(); msgIt != srcMsgIds.end(); ++msgIt) { if (std::find(destMsgIds.begin(), destMsgIds.end(), *msgIt) == destMsgIds.end()) { destMsgIds.push_back(*msgIt); } } } for (mapIt = msgIdsMeta.begin(); mapIt != msgIdsMeta.end(); ++mapIt) { const RsGxsGroupId &grpId = mapIt->first; const std::vector &srcMsgIds = mapIt->second; std::vector &destMsgIds = mMsgIdsMeta[grpId]; std::vector::const_iterator msgIt; for (msgIt = srcMsgIds.begin(); msgIt != srcMsgIds.end(); ++msgIt) { if (std::find(destMsgIds.begin(), destMsgIds.end(), *msgIt) == destMsgIds.end()) { destMsgIds.push_back(*msgIt); } } } } void RsGxsUpdateBroadcastBase::getAllGrpIds(std::list &grpIds) { std::list::const_iterator it; for (it = mGrpIds.begin(); it != mGrpIds.end(); ++it) { if (std::find(grpIds.begin(), grpIds.end(), *it) == grpIds.end()) { grpIds.push_back(*it); } } for (it = mGrpIdsMeta.begin(); it != mGrpIdsMeta.end(); ++it) { if (std::find(grpIds.begin(), grpIds.end(), *it) == grpIds.end()) { grpIds.push_back(*it); } } } void RsGxsUpdateBroadcastBase::getAllMsgIds(std::map > &msgIds) { /* Copy first map */ msgIds = mMsgIds; /* Append second map */ std::map >::const_iterator mapIt; for (mapIt = mMsgIdsMeta.begin(); mapIt != mMsgIdsMeta.end(); ++mapIt) { const RsGxsGroupId &grpId = mapIt->first; const std::vector &srcMsgIds = mapIt->second; std::vector &destMsgIds = msgIds[grpId]; std::vector::const_iterator msgIt; for (msgIt = srcMsgIds.begin(); msgIt != srcMsgIds.end(); ++msgIt) { if (std::find(destMsgIds.begin(), destMsgIds.end(), *msgIt) == destMsgIds.end()) { destMsgIds.push_back(*msgIt); } } } }