mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-12-17 01:24:15 -05:00
fixed PostedGroupItem
This commit is contained in:
parent
5e4249663e
commit
6b88c9a49e
2 changed files with 50 additions and 38 deletions
|
|
@ -35,29 +35,55 @@
|
||||||
PostedGroupItem::PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId &groupId, bool isHome, bool autoUpdate) :
|
PostedGroupItem::PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId &groupId, bool isHome, bool autoUpdate) :
|
||||||
GxsGroupFeedItem(feedHolder, feedId, groupId, isHome, rsPosted, autoUpdate)
|
GxsGroupFeedItem(feedHolder, feedId, groupId, isHome, rsPosted, autoUpdate)
|
||||||
{
|
{
|
||||||
mIsLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
setup();
|
mLoadingStatus = NO_DATA;
|
||||||
|
|
||||||
requestGroup();
|
setup();
|
||||||
}
|
}
|
||||||
|
|
||||||
PostedGroupItem::PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsPostedGroup &group, bool isHome, bool autoUpdate) :
|
//PostedGroupItem::PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsPostedGroup &group, bool isHome, bool autoUpdate) :
|
||||||
GxsGroupFeedItem(feedHolder, feedId, group.mMeta.mGroupId, isHome, rsPosted, autoUpdate)
|
// GxsGroupFeedItem(feedHolder, feedId, group.mMeta.mGroupId, isHome, rsPosted, autoUpdate)
|
||||||
|
//{
|
||||||
|
// mIsLoadingGroup = false;
|
||||||
|
// setup();
|
||||||
|
//
|
||||||
|
// setGroup(group);
|
||||||
|
//}
|
||||||
|
|
||||||
|
void PostedGroupItem::paintEvent(QPaintEvent *e)
|
||||||
{
|
{
|
||||||
mIsLoadingGroup = false;
|
/* This method employs a trick to trigger a deferred loading. The post and group is requested only
|
||||||
setup();
|
* when actually displayed on the screen. */
|
||||||
|
|
||||||
setGroup(group);
|
if(mLoadingStatus != FILLED && !mGroup.mMeta.mGroupId.isNull())
|
||||||
|
mLoadingStatus = HAS_DATA;
|
||||||
|
|
||||||
|
if(mGroup.mMeta.mGroupId.isNull() && !mLoadingGroup)
|
||||||
|
loadGroup();
|
||||||
|
|
||||||
|
switch(mLoadingStatus)
|
||||||
|
{
|
||||||
|
case FILLED:
|
||||||
|
case NO_DATA:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case HAS_DATA:
|
||||||
|
fill();
|
||||||
|
mLoadingStatus = FILLED;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GxsGroupFeedItem::paintEvent(e) ;
|
||||||
|
}
|
||||||
PostedGroupItem::~PostedGroupItem()
|
PostedGroupItem::~PostedGroupItem()
|
||||||
{
|
{
|
||||||
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( mIsLoadingGroup && std::chrono::steady_clock::now() < timeout)
|
while( mLoadingGroup && std::chrono::steady_clock::now() < timeout)
|
||||||
{
|
{
|
||||||
RsDbg() << __PRETTY_FUNCTION__ << " is Waiting "
|
RsDbg() << __PRETTY_FUNCTION__ << " is Waiting "
|
||||||
<< (mIsLoadingGroup ? "Group " : "")
|
<< (mLoadingGroup ? "Group " : "")
|
||||||
<< "loading finished." << std::endl;
|
<< "loading finished." << std::endl;
|
||||||
|
|
||||||
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
||||||
|
|
@ -91,23 +117,9 @@ void PostedGroupItem::setup()
|
||||||
ui->expandFrame->hide();
|
ui->expandFrame->hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PostedGroupItem::setGroup(const RsPostedGroup &group)
|
|
||||||
{
|
|
||||||
if (groupId() != group.mMeta.mGroupId) {
|
|
||||||
std::cerr << "PostedGroupItem::setContent() - Wrong id, cannot set post";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
mGroup = group;
|
|
||||||
fill();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void PostedGroupItem::loadGroup()
|
void PostedGroupItem::loadGroup()
|
||||||
{
|
{
|
||||||
mIsLoadingGroup = true;
|
mLoadingGroup = true;
|
||||||
|
|
||||||
RsThread::async([this]()
|
RsThread::async([this]()
|
||||||
{
|
{
|
||||||
|
|
@ -123,7 +135,7 @@ void PostedGroupItem::loadGroup()
|
||||||
if(!rsPosted->getBoardsInfo(groupIds,groups))
|
if(!rsPosted->getBoardsInfo(groupIds,groups))
|
||||||
{
|
{
|
||||||
RsErr() << "GxsPostedGroupItem::loadGroup() ERROR getting data" << std::endl;
|
RsErr() << "GxsPostedGroupItem::loadGroup() ERROR getting data" << std::endl;
|
||||||
mIsLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -131,7 +143,7 @@ void PostedGroupItem::loadGroup()
|
||||||
{
|
{
|
||||||
std::cerr << "GxsPostedGroupItem::loadGroup() Wrong number of Items";
|
std::cerr << "GxsPostedGroupItem::loadGroup() Wrong number of Items";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
mIsLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
RsPostedGroup group(groups[0]);
|
RsPostedGroup group(groups[0]);
|
||||||
|
|
@ -142,8 +154,8 @@ void PostedGroupItem::loadGroup()
|
||||||
* thread, for example to update the data model with new information
|
* thread, for example to update the data model with new information
|
||||||
* after a blocking call to RetroShare API complete */
|
* after a blocking call to RetroShare API complete */
|
||||||
|
|
||||||
setGroup(group);
|
mGroup = group;
|
||||||
mIsLoadingGroup = false;
|
mLoadingGroup = false;
|
||||||
|
|
||||||
}, this );
|
}, this );
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -37,21 +37,20 @@ class PostedGroupItem : public GxsGroupFeedItem
|
||||||
public:
|
public:
|
||||||
/** Default Constructor */
|
/** Default Constructor */
|
||||||
PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId &groupId, bool isHome, bool autoUpdate);
|
PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsGxsGroupId &groupId, bool isHome, bool autoUpdate);
|
||||||
PostedGroupItem(FeedHolder *feedHolder, uint32_t feedId, const RsPostedGroup &group, bool isHome, bool autoUpdate);
|
virtual ~PostedGroupItem() override;
|
||||||
~PostedGroupItem();
|
|
||||||
|
|
||||||
bool setGroup(const RsPostedGroup &group);
|
|
||||||
|
|
||||||
uint64_t uniqueIdentifier() const override { return hash_64bits("PostedGroupItem " + groupId().toStdString()) ; }
|
uint64_t uniqueIdentifier() const override { return hash_64bits("PostedGroupItem " + groupId().toStdString()) ; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
virtual void paintEvent(QPaintEvent *e) override;
|
||||||
|
|
||||||
/* FeedItem */
|
/* FeedItem */
|
||||||
virtual void doExpand(bool open);
|
virtual void doExpand(bool open) 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_UNKNOWN; }
|
virtual RetroShareLink::enumType getLinkType() override { return RetroShareLink::TYPE_UNKNOWN; }
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void toggle() override;
|
void toggle() override;
|
||||||
|
|
@ -63,7 +62,8 @@ private:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
RsPostedGroup mGroup;
|
RsPostedGroup mGroup;
|
||||||
bool mIsLoadingGroup;
|
bool mLoadingGroup;
|
||||||
|
LoadingStatus mLoadingStatus;
|
||||||
|
|
||||||
/** Qt Designer generated object */
|
/** Qt Designer generated object */
|
||||||
Ui::PostedGroupItem *ui;
|
Ui::PostedGroupItem *ui;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue