mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-12-18 10:02:41 -05:00
fixed deferred loading of GxsChannelPostItem
This commit is contained in:
parent
b9cd766707
commit
c8a93d75f2
2 changed files with 53 additions and 202 deletions
|
|
@ -45,37 +45,9 @@
|
||||||
* #define DEBUG_ITEM 1
|
* #define DEBUG_ITEM 1
|
||||||
****/
|
****/
|
||||||
|
|
||||||
GxsChannelPostItem::GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGroupMetaData& group_meta, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate,const std::set<RsGxsMessageId>& older_versions) :
|
|
||||||
GxsFeedItem(feedHolder, feedId, group_meta.mGroupId, messageId, isHome, rsGxsChannels, autoUpdate),
|
|
||||||
mGroupMeta(group_meta)
|
|
||||||
{
|
|
||||||
mLoadingGroup = false;
|
|
||||||
mLoadingMessage = false;
|
|
||||||
mLoadingComment = false;
|
|
||||||
|
|
||||||
mPost.mMeta.mMsgId = messageId; // useful for uniqueIdentifer() before the post is loaded
|
|
||||||
mPost.mMeta.mGroupId = mGroupMeta.mGroupId;
|
|
||||||
|
|
||||||
QVector<RsGxsMessageId> v;
|
|
||||||
//bool self = false;
|
|
||||||
|
|
||||||
for(std::set<RsGxsMessageId>::const_iterator it(older_versions.begin());it!=older_versions.end();++it)
|
|
||||||
v.push_back(*it) ;
|
|
||||||
|
|
||||||
if(older_versions.find(messageId) == older_versions.end())
|
|
||||||
v.push_back(messageId);
|
|
||||||
|
|
||||||
setMessageVersions(v) ;
|
|
||||||
setup();
|
|
||||||
|
|
||||||
// no call to loadGroup() here because we have it already.
|
|
||||||
}
|
|
||||||
|
|
||||||
GxsChannelPostItem::GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId& groupId, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate,const std::set<RsGxsMessageId>& older_versions) :
|
GxsChannelPostItem::GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId& groupId, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate,const std::set<RsGxsMessageId>& older_versions) :
|
||||||
GxsFeedItem(feedHolder, feedId, groupId, messageId, isHome, rsGxsChannels, autoUpdate) // this one should be in GxsFeedItem
|
GxsFeedItem(feedHolder, feedId, groupId, messageId, isHome, rsGxsChannels, autoUpdate) // this one should be in GxsFeedItem
|
||||||
{
|
{
|
||||||
mPost.mMeta.mMsgId = messageId; // useful for uniqueIdentifer() before the post is loaded
|
|
||||||
|
|
||||||
QVector<RsGxsMessageId> v;
|
QVector<RsGxsMessageId> v;
|
||||||
//bool self = false;
|
//bool self = false;
|
||||||
|
|
||||||
|
|
@ -85,55 +57,38 @@ GxsChannelPostItem::GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId,
|
||||||
if(older_versions.find(messageId) == older_versions.end())
|
if(older_versions.find(messageId) == older_versions.end())
|
||||||
v.push_back(messageId);
|
v.push_back(messageId);
|
||||||
|
|
||||||
setMessageVersions(v) ;
|
mLoadingStatus = NO_DATA;
|
||||||
|
|
||||||
|
setMessageVersions(v) ;
|
||||||
setup();
|
setup();
|
||||||
|
|
||||||
loadGroup();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GxsChannelPostItem::GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsChannelPost& post, bool isHome, bool autoUpdate,const std::set<RsGxsMessageId>& older_versions) :
|
|
||||||
// GxsFeedItem(feedHolder, feedId, post.mMeta.mGroupId, post.mMeta.mMsgId, isHome, rsGxsChannels, autoUpdate)
|
|
||||||
// {
|
|
||||||
// mPost.mMeta.mMsgId.clear(); // security
|
|
||||||
// init(post.mMeta.mMsgId,older_versions) ;
|
|
||||||
// mPost = post ;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// void GxsChannelPostItem::init(const RsGxsMessageId& messageId,const std::set<RsGxsMessageId>& older_versions)
|
|
||||||
// {
|
|
||||||
// QVector<RsGxsMessageId> v;
|
|
||||||
// //bool self = false;
|
|
||||||
//
|
|
||||||
// for(std::set<RsGxsMessageId>::const_iterator it(older_versions.begin());it!=older_versions.end();++it)
|
|
||||||
// v.push_back(*it) ;
|
|
||||||
//
|
|
||||||
// if(older_versions.find(messageId) == older_versions.end())
|
|
||||||
// v.push_back(messageId);
|
|
||||||
//
|
|
||||||
// setMessageVersions(v) ;
|
|
||||||
//
|
|
||||||
// setup();
|
|
||||||
//
|
|
||||||
// mLoaded = false ;
|
|
||||||
// }
|
|
||||||
|
|
||||||
void GxsChannelPostItem::paintEvent(QPaintEvent *e)
|
void GxsChannelPostItem::paintEvent(QPaintEvent *e)
|
||||||
{
|
{
|
||||||
/* This method employs a trick to trigger a deferred loading. The post and group is requested only
|
/* This method employs a trick to trigger a deferred loading. The post and group is requested only
|
||||||
* when actually displayed on the screen. */
|
* when actually displayed on the screen. */
|
||||||
|
|
||||||
if(!mLoaded)
|
if(mLoadingStatus != FILLED && !mGroupMeta.mGroupId.isNull() && !mPost.mMeta.mMsgId.isNull() )
|
||||||
{
|
mLoadingStatus = HAS_DATA;
|
||||||
mLoaded = true ;
|
|
||||||
|
|
||||||
std::set<RsGxsMessageId> older_versions; // not so nice. We need to use std::set everywhere
|
if(mGroupMeta.mGroupId.isNull() && !mLoadingGroup)
|
||||||
for(auto& m:messageVersions())
|
requestGroup();
|
||||||
older_versions.insert(m);
|
|
||||||
|
|
||||||
fill();
|
if(mPost.mMeta.mMsgId.isNull() && !mLoadingMessage)
|
||||||
requestMessage();
|
requestMessage();
|
||||||
requestComment();
|
|
||||||
}
|
switch(mLoadingStatus)
|
||||||
|
{
|
||||||
|
case FILLED:
|
||||||
|
case NO_DATA:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case HAS_DATA:
|
||||||
|
fill();
|
||||||
|
mLoadingStatus = FILLED;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
GxsFeedItem::paintEvent(e) ;
|
GxsFeedItem::paintEvent(e) ;
|
||||||
}
|
}
|
||||||
|
|
@ -142,13 +97,12 @@ GxsChannelPostItem::~GxsChannelPostItem()
|
||||||
{
|
{
|
||||||
auto timeout = std::chrono::steady_clock::now() + std::chrono::milliseconds(GROUP_ITEM_LOADING_TIMEOUT_ms);
|
auto timeout = std::chrono::steady_clock::now() + std::chrono::milliseconds(GROUP_ITEM_LOADING_TIMEOUT_ms);
|
||||||
|
|
||||||
while( (mLoadingGroup || mLoadingMessage || mLoadingComment)
|
while( (mLoadingGroup || mLoadingMessage)
|
||||||
&& std::chrono::steady_clock::now() < timeout)
|
&& std::chrono::steady_clock::now() < timeout)
|
||||||
{
|
{
|
||||||
RsDbg() << __PRETTY_FUNCTION__ << " is Waiting for "
|
RsDbg() << __PRETTY_FUNCTION__ << " is Waiting for "
|
||||||
<< (mLoadingGroup ? "Group " : "")
|
<< (mLoadingGroup ? "Group " : "")
|
||||||
<< (mLoadingMessage ? "Message " : "")
|
<< (mLoadingMessage ? "Message " : "")
|
||||||
<< (mLoadingComment ? "Comment " : "")
|
|
||||||
<< "loading." << std::endl;
|
<< "loading." << std::endl;
|
||||||
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
||||||
}
|
}
|
||||||
|
|
@ -188,9 +142,7 @@ void GxsChannelPostItem::setup()
|
||||||
|
|
||||||
setAttribute(Qt::WA_DeleteOnClose, true);
|
setAttribute(Qt::WA_DeleteOnClose, true);
|
||||||
|
|
||||||
mInFill = false;
|
|
||||||
mCloseOnRead = false;
|
mCloseOnRead = false;
|
||||||
mLoaded = false;
|
|
||||||
|
|
||||||
/* clear ui */
|
/* clear ui */
|
||||||
ui->titleLabel->setText(tr("Loading..."));
|
ui->titleLabel->setText(tr("Loading..."));
|
||||||
|
|
@ -210,7 +162,7 @@ void GxsChannelPostItem::setup()
|
||||||
connect(ui->downloadButton, SIGNAL(clicked()), this, SLOT(download()));
|
connect(ui->downloadButton, SIGNAL(clicked()), this, SLOT(download()));
|
||||||
// HACK FOR NOW.
|
// HACK FOR NOW.
|
||||||
ui->commentButton->hide();// hidden until properly enabled.
|
ui->commentButton->hide();// hidden until properly enabled.
|
||||||
connect(ui->commentButton, SIGNAL(clicked()), this, SLOT(loadComments()));
|
// connect(ui->commentButton, SIGNAL(clicked()), this, SLOT(loadComments()));
|
||||||
|
|
||||||
connect(ui->playButton, SIGNAL(clicked()), this, SLOT(play(void)));
|
connect(ui->playButton, SIGNAL(clicked()), this, SLOT(play(void)));
|
||||||
//connect(ui->editButton, SIGNAL(clicked()), this, SLOT(edit(void)));
|
//connect(ui->editButton, SIGNAL(clicked()), this, SLOT(edit(void)));
|
||||||
|
|
@ -246,22 +198,9 @@ void GxsChannelPostItem::setup()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool GxsChannelPostItem::setPost(const RsGxsChannelPost &post, bool doFill)
|
bool GxsChannelPostItem::setPost(const RsGxsChannelPost &post)
|
||||||
{
|
{
|
||||||
if (groupId() != post.mMeta.mGroupId || messageId() != post.mMeta.mMsgId) {
|
|
||||||
std::cerr << "GxsChannelPostItem::setPost() - Wrong id, cannot set post";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
mPost = post;
|
mPost = post;
|
||||||
|
|
||||||
if (doFill) {
|
|
||||||
fill();
|
|
||||||
}
|
|
||||||
|
|
||||||
updateItem();
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -282,18 +221,10 @@ QString GxsChannelPostItem::groupName()
|
||||||
return QString::fromUtf8(mGroupMeta.mGroupName.c_str());
|
return QString::fromUtf8(mGroupMeta.mGroupName.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void GxsChannelPostItem::loadComments()
|
|
||||||
{
|
|
||||||
QString title = QString::fromUtf8(mPost.mMeta.mMsgName.c_str());
|
|
||||||
comments(title);
|
|
||||||
}
|
|
||||||
|
|
||||||
void GxsChannelPostItem::loadGroup()
|
void GxsChannelPostItem::loadGroup()
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_ITEM
|
std::cerr << "GxsChannelGroupItem::loadGroup()" << std::endl;
|
||||||
std::cerr << "GxsChannelGroupItem::loadGroup()";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
mLoadingGroup = true;
|
mLoadingGroup = true;
|
||||||
|
|
||||||
RsThread::async([this]()
|
RsThread::async([this]()
|
||||||
|
|
@ -305,14 +236,14 @@ void GxsChannelPostItem::loadGroup()
|
||||||
|
|
||||||
if(!rsGxsChannels->getChannelsInfo(groupIds,groups)) // would be better to call channel Summaries for a single group
|
if(!rsGxsChannels->getChannelsInfo(groupIds,groups)) // would be better to call channel Summaries for a single group
|
||||||
{
|
{
|
||||||
RsErr() << "GxsGxsChannelGroupItem::loadGroup() ERROR getting data" << std::endl;
|
RsErr() << "GxsGxsChannelGroupItem::loadGroup() ERROR getting data for group " << groupId() << std::endl;
|
||||||
mLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (groups.size() != 1)
|
if (groups.size() != 1)
|
||||||
{
|
{
|
||||||
std::cerr << "GxsGxsChannelGroupItem::loadGroup() Wrong number of Items";
|
std::cerr << "GxsGxsChannelGroupItem::loadGroup() Wrong number of Items for group " << groupId() ;
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
mLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
return;
|
return;
|
||||||
|
|
@ -328,6 +259,8 @@ void GxsChannelPostItem::loadGroup()
|
||||||
mGroupMeta = group.mMeta;
|
mGroupMeta = group.mMeta;
|
||||||
mLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
|
|
||||||
|
update(); // this triggers a paintEvent if needed.
|
||||||
|
|
||||||
}, this );
|
}, this );
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
@ -365,28 +298,9 @@ void GxsChannelPostItem::loadMessage()
|
||||||
{
|
{
|
||||||
setPost(post);
|
setPost(post);
|
||||||
mLoadingMessage = false;
|
mLoadingMessage = false;
|
||||||
|
update(); // this triggers a paintEvent if needed.
|
||||||
|
|
||||||
}, this );
|
}, this );
|
||||||
}
|
|
||||||
else if(comments.size() == 1)
|
|
||||||
{
|
|
||||||
const RsGxsComment& cmt = comments[0];
|
|
||||||
#ifdef DEBUG_ITEM
|
|
||||||
std::cerr << (void*)this << ": Obtained comment, setting messageId to threadID = " << cmt.mMeta.mThreadId << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
RsQThreadUtils::postToObject( [cmt,this]()
|
|
||||||
{
|
|
||||||
ui->newCommentLabel->show();
|
|
||||||
ui->commLabel->show();
|
|
||||||
ui->commLabel->setText(QString::fromUtf8(cmt.mComment.c_str()));
|
|
||||||
|
|
||||||
// Change this item to be uploaded with thread element. Note: this is terrible coding.
|
|
||||||
setMessageId(cmt.mMeta.mThreadId);
|
|
||||||
mLoadingMessage = false;
|
|
||||||
|
|
||||||
requestMessage();
|
|
||||||
}, this );
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
@ -399,55 +313,12 @@ void GxsChannelPostItem::loadMessage()
|
||||||
{
|
{
|
||||||
removeItem();
|
removeItem();
|
||||||
mLoadingMessage = false;
|
mLoadingMessage = false;
|
||||||
|
update(); // this triggers a paintEvent if needed.
|
||||||
}, this );
|
}, this );
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void GxsChannelPostItem::loadComment()
|
|
||||||
{
|
|
||||||
#ifdef DEBUG_ITEM
|
|
||||||
std::cerr << "GxsChannelPostItem::loadComment()";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
mLoadingComment = true;
|
|
||||||
|
|
||||||
RsThread::async([this]()
|
|
||||||
{
|
|
||||||
// 1 - get group data
|
|
||||||
|
|
||||||
std::set<RsGxsMessageId> msgIds;
|
|
||||||
|
|
||||||
for(auto MsgId: messageVersions())
|
|
||||||
msgIds.insert(MsgId);
|
|
||||||
|
|
||||||
std::vector<RsGxsChannelPost> posts;
|
|
||||||
std::vector<RsGxsComment> comments;
|
|
||||||
|
|
||||||
if(! rsGxsChannels->getChannelComments( groupId(),msgIds,comments))
|
|
||||||
{
|
|
||||||
RsErr() << "GxsGxsChannelGroupItem::loadGroup() ERROR getting data" << std::endl;
|
|
||||||
mLoadingComment = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
int comNb = comments.size();
|
|
||||||
|
|
||||||
RsQThreadUtils::postToObject( [comNb,this]()
|
|
||||||
{
|
|
||||||
QString sComButText = tr("Comment");
|
|
||||||
if (comNb == 1)
|
|
||||||
sComButText = sComButText.append("(1)");
|
|
||||||
else if(comNb > 1)
|
|
||||||
sComButText = tr("Comments ").append("(%1)").arg(comNb);
|
|
||||||
|
|
||||||
ui->commentButton->setText(sComButText);
|
|
||||||
mLoadingComment = false;
|
|
||||||
|
|
||||||
}, this );
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void GxsChannelPostItem::fill()
|
void GxsChannelPostItem::fill()
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_ITEM
|
#ifdef DEBUG_ITEM
|
||||||
|
|
@ -455,8 +326,6 @@ void GxsChannelPostItem::fill()
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
mInFill = true;
|
|
||||||
|
|
||||||
QString title;
|
QString title;
|
||||||
QString msgText;
|
QString msgText;
|
||||||
//float f = QFontMetricsF(font()).height()/14.0 ;
|
//float f = QFontMetricsF(font()).height()/14.0 ;
|
||||||
|
|
@ -559,21 +428,6 @@ void GxsChannelPostItem::fill()
|
||||||
ui->commentButton->hide();
|
ui->commentButton->hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
// THIS CODE IS doesn't compile - disabling until fixed.
|
|
||||||
#if 0
|
|
||||||
if (post.mComments)
|
|
||||||
{
|
|
||||||
QString commentText = QString::number(post.mComments);
|
|
||||||
commentText += " ";
|
|
||||||
commentText += tr("Comments");
|
|
||||||
ui->commentButton->setText(commentText);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ui->commentButton->setText(tr("Comment"));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
@ -639,8 +493,6 @@ void GxsChannelPostItem::fill()
|
||||||
QLayout *layout = ui->expandFrame->layout();
|
QLayout *layout = ui->expandFrame->layout();
|
||||||
layout->addWidget(fi);
|
layout->addWidget(fi);
|
||||||
}
|
}
|
||||||
|
|
||||||
mInFill = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GxsChannelPostItem::fillExpandFrame()
|
void GxsChannelPostItem::fillExpandFrame()
|
||||||
|
|
@ -871,10 +723,6 @@ void GxsChannelPostItem::play()
|
||||||
|
|
||||||
void GxsChannelPostItem::readToggled(bool /*checked*/)
|
void GxsChannelPostItem::readToggled(bool /*checked*/)
|
||||||
{
|
{
|
||||||
if (mInFill) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
mCloseOnRead = false;
|
mCloseOnRead = false;
|
||||||
|
|
||||||
RsGxsGrpMsgIdPair msgPair = std::make_pair(groupId(), messageId());
|
RsGxsGrpMsgIdPair msgPair = std::make_pair(groupId(), messageId());
|
||||||
|
|
|
||||||
|
|
@ -44,17 +44,25 @@ public:
|
||||||
|
|
||||||
GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId& groupId, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate, const std::set<RsGxsMessageId>& older_versions = std::set<RsGxsMessageId>());
|
GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId& groupId, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate, const std::set<RsGxsMessageId>& older_versions = std::set<RsGxsMessageId>());
|
||||||
|
|
||||||
|
#ifdef UNUSED
|
||||||
// This one is used in channel thread widget. We don't want the group data to reload at every post, so we load it in the hosting
|
// This one is used in channel thread widget. We don't want the group data to reload at every post, so we load it in the hosting
|
||||||
// GxsChannelsPostsWidget and pass it to created items.
|
// GxsChannelsPostsWidget and pass it to created items.
|
||||||
|
|
||||||
GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGroupMetaData& group, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate, const std::set<RsGxsMessageId>& older_versions = std::set<RsGxsMessageId>());
|
GxsChannelPostItem(FeedHolder *feedHolder, uint32_t feedId, const RsGroupMetaData& group, const RsGxsMessageId &messageId, bool isHome, bool autoUpdate, const std::set<RsGxsMessageId>& older_versions = std::set<RsGxsMessageId>());
|
||||||
|
#endif
|
||||||
|
|
||||||
virtual ~GxsChannelPostItem();
|
virtual ~GxsChannelPostItem();
|
||||||
|
|
||||||
uint64_t uniqueIdentifier() const override { return hash_64bits("GxsChannelPostItem " + messageId().toStdString()) ; }
|
uint64_t uniqueIdentifier() const override { return hash_64bits("GxsChannelPostItem " + messageId().toStdString()) ; }
|
||||||
|
|
||||||
bool setGroup(const RsGxsChannelGroup& group, bool doFill = true);
|
protected:
|
||||||
bool setPost(const RsGxsChannelPost& post, bool doFill = true);
|
enum LoadingStatus {
|
||||||
|
NO_DATA = 0x00,
|
||||||
|
HAS_DATA = 0x01,
|
||||||
|
FILLED = 0x02
|
||||||
|
};
|
||||||
|
|
||||||
|
bool setPost(const RsGxsChannelPost& post);
|
||||||
|
|
||||||
//void setFileCleanUpWarning(uint32_t time_left);
|
//void setFileCleanUpWarning(uint32_t time_left);
|
||||||
|
|
||||||
|
|
@ -62,19 +70,17 @@ public:
|
||||||
QString getMsgLabel();
|
QString getMsgLabel();
|
||||||
const std::list<SubFileItem *> &getFileItems() {return mFileItems; }
|
const std::list<SubFileItem *> &getFileItems() {return mFileItems; }
|
||||||
|
|
||||||
bool isLoaded() const {return mLoaded;};
|
|
||||||
bool isUnread() const ;
|
bool isUnread() const ;
|
||||||
void setReadStatus(bool isNew, bool isUnread);
|
void setReadStatus(bool isNew, bool isUnread);
|
||||||
|
|
||||||
const std::set<RsGxsMessageId>& olderVersions() const { return mPost.mOlderVersions; }
|
const std::set<RsGxsMessageId>& olderVersions() const { return mPost.mOlderVersions; }
|
||||||
|
|
||||||
static uint64_t computeIdentifier(const RsGxsMessageId& msgid) { return hash64("GxsChannelPostItem " + msgid.toStdString()) ; }
|
static uint64_t computeIdentifier(const RsGxsMessageId& msgid) { return hash64("GxsChannelPostItem " + msgid.toStdString()) ; }
|
||||||
protected:
|
|
||||||
//void init(const RsGxsMessageId& messageId,const std::set<RsGxsMessageId>& older_versions);
|
//void init(const RsGxsMessageId& messageId,const std::set<RsGxsMessageId>& older_versions);
|
||||||
|
|
||||||
/* FeedItem */
|
/* FeedItem */
|
||||||
virtual void doExpand(bool open);
|
virtual void doExpand(bool open) override;
|
||||||
virtual void expandFill(bool first);
|
virtual void expandFill(bool first) override;
|
||||||
|
|
||||||
// This does nothing except triggering the loading of the post data and comments. This function is mainly used to detect
|
// This does nothing except triggering the loading of the post data and comments. This function is mainly used to detect
|
||||||
// when the post is actually made visible.
|
// when the post is actually made visible.
|
||||||
|
|
@ -82,14 +88,14 @@ protected:
|
||||||
virtual void paintEvent(QPaintEvent *) override;
|
virtual void paintEvent(QPaintEvent *) override;
|
||||||
|
|
||||||
/* GxsGroupFeedItem */
|
/* GxsGroupFeedItem */
|
||||||
virtual QString groupName();
|
virtual QString groupName() override;
|
||||||
virtual void loadGroup() override;
|
virtual void loadGroup() override;
|
||||||
virtual RetroShareLink::enumType getLinkType() { return RetroShareLink::TYPE_CHANNEL; }
|
virtual RetroShareLink::enumType getLinkType() override{ return RetroShareLink::TYPE_CHANNEL; }
|
||||||
|
|
||||||
/* GxsFeedItem */
|
/* GxsFeedItem */
|
||||||
virtual QString messageName();
|
virtual QString messageName() override;
|
||||||
virtual void loadMessage();
|
virtual void loadMessage() override;
|
||||||
virtual void loadComment();
|
virtual void loadComment() override {}
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
/* default stuff */
|
/* default stuff */
|
||||||
|
|
@ -98,7 +104,6 @@ private slots:
|
||||||
void download();
|
void download();
|
||||||
void play();
|
void play();
|
||||||
void edit();
|
void edit();
|
||||||
void loadComments();
|
|
||||||
|
|
||||||
void readToggled(bool checked);
|
void readToggled(bool checked);
|
||||||
|
|
||||||
|
|
@ -117,14 +122,12 @@ private:
|
||||||
void fillExpandFrame();
|
void fillExpandFrame();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool mInFill;
|
|
||||||
bool mCloseOnRead;
|
bool mCloseOnRead;
|
||||||
bool mLoaded;
|
|
||||||
|
LoadingStatus mLoadingStatus;
|
||||||
|
|
||||||
bool mLoadingMessage;
|
bool mLoadingMessage;
|
||||||
bool mLoadingGroup;
|
bool mLoadingGroup;
|
||||||
bool mLoadingComment;
|
|
||||||
|
|
||||||
|
|
||||||
RsGroupMetaData mGroupMeta;
|
RsGroupMetaData mGroupMeta;
|
||||||
RsGxsChannelPost mPost;
|
RsGxsChannelPost mPost;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue