From 12650dfddf9627ded27e0c9e5fc86f165c3eca5f Mon Sep 17 00:00:00 2001 From: Phenom Date: Wed, 27 Jan 2021 16:35:30 +0100 Subject: [PATCH] Fix Forum Post Un/Read Column click when not selected. --- .../src/gui/gxsforums/GxsForumModel.cpp | 17 ++++--- .../gui/gxsforums/GxsForumThreadWidget.cpp | 48 +++++++++---------- 2 files changed, 31 insertions(+), 34 deletions(-) diff --git a/retroshare-gui/src/gui/gxsforums/GxsForumModel.cpp b/retroshare-gui/src/gui/gxsforums/GxsForumModel.cpp index b27443173..3d168acf7 100644 --- a/retroshare-gui/src/gui/gxsforums/GxsForumModel.cpp +++ b/retroshare-gui/src/gui/gxsforums/GxsForumModel.cpp @@ -338,6 +338,7 @@ QVariant RsGxsForumModel::headerData(int section, Qt::Orientation /*orientation* switch(section) { case COLUMN_THREAD_TITLE: return tr("Title"); + case COLUMN_THREAD_READ: return tr("UnRead"); case COLUMN_THREAD_DATE: return tr("Date"); case COLUMN_THREAD_AUTHOR: return tr("Author"); default: @@ -347,9 +348,8 @@ QVariant RsGxsForumModel::headerData(int section, Qt::Orientation /*orientation* if(role == Qt::DecorationRole) switch(section) { - case COLUMN_THREAD_DISTRIBUTION: return FilesDefs::getIconFromQtResourcePath(":/icons/flag-green.png"); - case COLUMN_THREAD_READ: return FilesDefs::getIconFromQtResourcePath(":/images/message-state-read.png"); - default: + case COLUMN_THREAD_DISTRIBUTION: return FilesDefs::getIconFromQtResourcePath(":/icons/flag-green.png"); + default: return QVariant(); } @@ -969,12 +969,11 @@ void RsGxsForumModel::computeMessagesHierarchy(const RsGxsForumGroup& forum_grou #ifdef DEBUG_FORUMS std::cerr << "GxsForumsFillThread::run() Collecting post versions" << std::endl; #endif - mPostVersions.clear(); - std::list msg_stack ; + mPostVersions.clear(); for ( auto msgIt = msgs.begin(); msgIt != msgs.end();++msgIt) - { - if(!msgIt->second.mOrigMsgId.isNull() && msgIt->second.mOrigMsgId != msgIt->second.mMsgId) + { + if(!msgIt->second.mOrigMsgId.isNull() && msgIt->second.mOrigMsgId != msgIt->second.mMsgId) { #ifdef DEBUG_FORUMS std::cerr << " Post " << msgIt->second.mMeta.mMsgId << " is a new version of " << msgIt->second.mMeta.mOrigMsgId << std::endl; @@ -1381,8 +1380,8 @@ void RsGxsForumModel::debug_dump() << QString("%1").arg((uint32_t)e.mPostFlags,8,16,QChar('0')).toStdString() << " " << QString("%1").arg((uint32_t)e.mMsgStatus,8,16,QChar('0')).toStdString() << " "; - for(uint32_t i=0;i +#include #include #include // These should be in retroshare/ folder. @@ -205,7 +206,7 @@ public: class ForumPostSortFilterProxyModel: public QSortFilterProxyModel { public: - ForumPostSortFilterProxyModel(const QHeaderView *header,QObject *parent = NULL): QSortFilterProxyModel(parent),m_header(header) {} + explicit ForumPostSortFilterProxyModel(const QHeaderView *header,QObject *parent = NULL): QSortFilterProxyModel(parent),m_header(header) {} bool lessThan(const QModelIndex& left, const QModelIndex& right) const override { @@ -330,7 +331,7 @@ GxsForumThreadWidget::GxsForumThreadWidget(const RsGxsGroupId &forumId, QWidget QHeaderView_setSectionResizeModeColumn(ttheader, RsGxsForumModel::COLUMN_THREAD_TITLE, QHeaderView::Interactive); QHeaderView_setSectionResizeModeColumn(ttheader, RsGxsForumModel::COLUMN_THREAD_DATE, QHeaderView::Interactive); QHeaderView_setSectionResizeModeColumn(ttheader, RsGxsForumModel::COLUMN_THREAD_AUTHOR, QHeaderView::Interactive); - QHeaderView_setSectionResizeModeColumn(ttheader, RsGxsForumModel::COLUMN_THREAD_READ, QHeaderView::Fixed); + QHeaderView_setSectionResizeModeColumn(ttheader, RsGxsForumModel::COLUMN_THREAD_READ, QHeaderView::Interactive); QHeaderView_setSectionResizeModeColumn(ttheader, RsGxsForumModel::COLUMN_THREAD_DISTRIBUTION, QHeaderView::Fixed); ttheader->setCascadingSectionResizes(true); @@ -468,12 +469,13 @@ void GxsForumThreadWidget::processSettings(bool load) void GxsForumThreadWidget::changedSelection(const QModelIndex& current,const QModelIndex& last) { - if (current!=last - && ( ( last.row()>=0 && last.column()>=0) //Double call when retrieve focus. - || mThreadId.isNull() //For first click - ) - ) - changedThread(current); + if (current!=last + && ( ( last.row()>=0 && last.column()>=0) //Double call when retrieve focus. + || mThreadId.isNull() //For first click + ) + && (current.column() != RsGxsForumModel::COLUMN_THREAD_READ) //clickedThread will changedThread after. + ) + changedThread(current); } void GxsForumThreadWidget::groupIdChanged() @@ -603,8 +605,8 @@ void GxsForumThreadWidget::threadListCustomPopupMenu(QPoint /*point*/) QAction *editAct = new QAction(FilesDefs::getIconFromQtResourcePath(IMAGE_MESSAGEEDIT), tr("Edit"), &contextMnu); connect(editAct, SIGNAL(triggered()), this, SLOT(editforummessage())); - bool is_pinned = mForumGroup.mPinnedPosts.ids.find(mThreadId) != mForumGroup.mPinnedPosts.ids.end(); - QAction *pinUpPostAct = new QAction(FilesDefs::getIconFromQtResourcePath(IMAGE_PINPOST), (is_pinned?tr("Un-pin this post"):tr("Pin this post up")), &contextMnu); + bool this_is_pinned = mForumGroup.mPinnedPosts.ids.find(mThreadId) != mForumGroup.mPinnedPosts.ids.end(); + QAction *pinUpPostAct = new QAction(FilesDefs::getIconFromQtResourcePath(IMAGE_PINPOST), (this_is_pinned?tr("Un-pin this post"):tr("Pin this post up")), &contextMnu); connect(pinUpPostAct , SIGNAL(triggered()), this, SLOT(togglePinUpPost())); QAction *replyAct = new QAction(FilesDefs::getIconFromQtResourcePath(IMAGE_REPLY), tr("Reply"), &contextMnu); @@ -698,10 +700,7 @@ void GxsForumThreadWidget::threadListCustomPopupMenu(QPoint /*point*/) #endif markMsgAsReadChildren->setVisible(has_children); markMsgAsUnreadChildren->setVisible(has_children); - } - if(has_current_post) - { bool is_pinned = mForumGroup.mPinnedPosts.ids.find( current_post.mMsgId ) != mForumGroup.mPinnedPosts.ids.end(); if(!is_pinned) @@ -869,7 +868,6 @@ bool GxsForumThreadWidget::eventFilter(QObject *obj, QEvent *event) } // pass the event on to the parent class return RsGxsUpdateBroadcastWidget::eventFilter(obj, event); - return RsGxsUpdateBroadcastWidget::eventFilter(obj, event); } #endif @@ -1058,22 +1056,22 @@ void GxsForumThreadWidget::updateForumDescription(bool success) forum_description += QString("%1: \t%2
").arg(tr("Posts (at neighbor nodes)")).arg(group.mMeta.mVisibleMsgCount); if(group.mMeta.mLastPost==0) - forum_description += QString("%1: \t%2
").arg(tr("Last post")).arg(tr("Never")); + forum_description += QString("%1: \t%2
").arg(tr("Last post"),tr("Never")); else - forum_description += QString("%1: \t%2
").arg(tr("Last post")).arg(DateTime::formatLongDateTime(group.mMeta.mLastPost)); + forum_description += QString("%1: \t%2
").arg(tr("Last post"),DateTime::formatLongDateTime(group.mMeta.mLastPost)); if(IS_GROUP_SUBSCRIBED(group.mMeta.mSubscribeFlags)) { - forum_description += QString("%1: \t%2
").arg(tr("Synchronization")).arg(getDurationString( rsGxsForums->getSyncPeriod(group.mMeta.mGroupId)/86400 )) ; - forum_description += QString("%1: \t%2
").arg(tr("Storage")).arg(getDurationString( rsGxsForums->getStoragePeriod(group.mMeta.mGroupId)/86400)); + forum_description += QString("%1: \t%2
").arg(tr("Synchronization"),getDurationString( rsGxsForums->getSyncPeriod(group.mMeta.mGroupId)/86400 )) ; + forum_description += QString("%1: \t%2
").arg(tr("Storage"),getDurationString( rsGxsForums->getStoragePeriod(group.mMeta.mGroupId)/86400)); } QString distrib_string = tr("[unknown]"); - switch(group.mMeta.mCircleType) + switch(static_cast(group.mMeta.mCircleType)) { - case GXS_CIRCLE_TYPE_PUBLIC: distrib_string = tr("Public") ; + case RsGxsCircleType::PUBLIC: distrib_string = tr("Public"); break ; - case GXS_CIRCLE_TYPE_EXTERNAL: + case RsGxsCircleType::EXTERNAL: { RsGxsCircleDetails det ; @@ -1085,7 +1083,7 @@ void GxsForumThreadWidget::updateForumDescription(bool success) distrib_string = tr("Restricted to members of circle ")+QString::fromStdString(group.mMeta.mCircleId.toStdString()) ; } break ; - case GXS_CIRCLE_TYPE_YOUR_FRIENDS_ONLY: + case RsGxsCircleType::NODES_GROUP: { distrib_string = tr("Only friends nodes in group ") ; @@ -1098,7 +1096,7 @@ void GxsForumThreadWidget::updateForumDescription(bool success) } break ; - case GXS_CIRCLE_TYPE_LOCAL: distrib_string = tr("Your eyes only"); // this is not yet supported. If you see this, it is a bug! + case RsGxsCircleType::LOCAL: distrib_string = tr("Your eyes only"); // this is not yet supported. If you see this, it is a bug! break ; default: std::cerr << "(EE) badly initialised group distribution ID = " << group.mMeta.mCircleType << std::endl; @@ -1108,7 +1106,7 @@ void GxsForumThreadWidget::updateForumDescription(bool success) forum_description += QString("%1: \t%2
").arg(tr("Owner"), author); if(!anti_spam_features1.isNull()) - forum_description += QString("%1: \t%2
").arg(tr("Anti-spam")).arg(anti_spam_features1); + forum_description += QString("%1: \t%2
").arg(tr("Anti-spam"),anti_spam_features1); ui->subscribeToolButton->setSubscribed(IS_GROUP_SUBSCRIBED(mForumGroup.mMeta.mSubscribeFlags)); ui->newthreadButton->setEnabled(IS_GROUP_SUBSCRIBED(mForumGroup.mMeta.mSubscribeFlags)); @@ -1579,9 +1577,9 @@ void GxsForumThreadWidget::togglePinUpPost() return ; } - QString thread_title = index.sibling(index.row(),RsGxsForumModel::COLUMN_THREAD_TITLE).data(Qt::DisplayRole).toString(); #ifdef DEBUG_FORUMS + QString thread_title = index.sibling(index.row(),RsGxsForumModel::COLUMN_THREAD_TITLE).data(Qt::DisplayRole).toString(); std::cerr << "Toggling Pin-up state of post " << mThreadId.toStdString() << ": \"" << thread_title.toStdString() << "\"" << std::endl; #endif