mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-13 08:17:57 +00:00
commit
c50cee8feb
@ -38,6 +38,8 @@ ArticleListWidget::ArticleListWidget(QWidget *parent)
|
|||||||
{
|
{
|
||||||
setContextMenuPolicy(Qt::CustomContextMenu);
|
setContextMenuPolicy(Qt::CustomContextMenu);
|
||||||
setSelectionMode(QAbstractItemView::ExtendedSelection);
|
setSelectionMode(QAbstractItemView::ExtendedSelection);
|
||||||
|
|
||||||
|
checkInvariant();
|
||||||
}
|
}
|
||||||
|
|
||||||
RSS::Article *ArticleListWidget::getRSSArticle(QListWidgetItem *item) const
|
RSS::Article *ArticleListWidget::getRSSArticle(QListWidgetItem *item) const
|
||||||
@ -55,28 +57,38 @@ void ArticleListWidget::setRSSItem(RSS::Item *rssItem, bool unreadOnly)
|
|||||||
{
|
{
|
||||||
// Clear the list first
|
// Clear the list first
|
||||||
clear();
|
clear();
|
||||||
|
m_rssArticleToListItemMapping.clear();
|
||||||
if (m_rssItem)
|
if (m_rssItem)
|
||||||
m_rssItem->disconnect(this);
|
m_rssItem->disconnect(this);
|
||||||
|
|
||||||
m_unreadOnly = unreadOnly;
|
m_unreadOnly = unreadOnly;
|
||||||
m_rssItem = rssItem;
|
m_rssItem = rssItem;
|
||||||
if (!m_rssItem) return;
|
if (m_rssItem) {
|
||||||
|
connect(m_rssItem, &RSS::Item::newArticle, this, &ArticleListWidget::handleArticleAdded);
|
||||||
|
connect(m_rssItem, &RSS::Item::articleRead, this, &ArticleListWidget::handleArticleRead);
|
||||||
|
connect(m_rssItem, &RSS::Item::articleAboutToBeRemoved, this, &ArticleListWidget::handleArticleAboutToBeRemoved);
|
||||||
|
|
||||||
m_rssItem = rssItem;
|
foreach (auto article, rssItem->articles()) {
|
||||||
connect(m_rssItem, &RSS::Item::newArticle, this, &ArticleListWidget::handleArticleAdded);
|
if (!(m_unreadOnly && article->isRead())) {
|
||||||
connect(m_rssItem, &RSS::Item::articleRead, this, &ArticleListWidget::handleArticleRead);
|
auto item = createItem(article);
|
||||||
connect(m_rssItem, &RSS::Item::articleAboutToBeRemoved, this, &ArticleListWidget::handleArticleAboutToBeRemoved);
|
addItem(item);
|
||||||
|
m_rssArticleToListItemMapping.insert(article, item);
|
||||||
foreach (auto article, rssItem->articles()) {
|
}
|
||||||
if (!(m_unreadOnly && article->isRead()))
|
}
|
||||||
addItem(createItem(article));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkInvariant();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ArticleListWidget::handleArticleAdded(RSS::Article *rssArticle)
|
void ArticleListWidget::handleArticleAdded(RSS::Article *rssArticle)
|
||||||
{
|
{
|
||||||
if (!(m_unreadOnly && rssArticle->isRead()))
|
if (!(m_unreadOnly && rssArticle->isRead())) {
|
||||||
addItem(createItem(rssArticle));
|
auto item = createItem(rssArticle);
|
||||||
|
insertItem(0, item);
|
||||||
|
m_rssArticleToListItemMapping.insert(rssArticle, item);
|
||||||
|
}
|
||||||
|
|
||||||
|
checkInvariant();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ArticleListWidget::handleArticleRead(RSS::Article *rssArticle)
|
void ArticleListWidget::handleArticleRead(RSS::Article *rssArticle)
|
||||||
@ -89,14 +101,22 @@ void ArticleListWidget::handleArticleRead(RSS::Article *rssArticle)
|
|||||||
item->setData(Qt::ForegroundRole, QColor("grey"));
|
item->setData(Qt::ForegroundRole, QColor("grey"));
|
||||||
item->setData(Qt::DecorationRole, QIcon(":/icons/sphere.png"));
|
item->setData(Qt::DecorationRole, QIcon(":/icons/sphere.png"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkInvariant();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ArticleListWidget::handleArticleAboutToBeRemoved(RSS::Article *rssArticle)
|
void ArticleListWidget::handleArticleAboutToBeRemoved(RSS::Article *rssArticle)
|
||||||
{
|
{
|
||||||
delete m_rssArticleToListItemMapping.take(rssArticle);
|
delete m_rssArticleToListItemMapping.take(rssArticle);
|
||||||
|
checkInvariant();
|
||||||
}
|
}
|
||||||
|
|
||||||
QListWidgetItem *ArticleListWidget::createItem(RSS::Article *article)
|
void ArticleListWidget::checkInvariant() const
|
||||||
|
{
|
||||||
|
Q_ASSERT(count() == m_rssArticleToListItemMapping.count());
|
||||||
|
}
|
||||||
|
|
||||||
|
QListWidgetItem *ArticleListWidget::createItem(RSS::Article *article) const
|
||||||
{
|
{
|
||||||
Q_ASSERT(article);
|
Q_ASSERT(article);
|
||||||
QListWidgetItem *item = new QListWidgetItem;
|
QListWidgetItem *item = new QListWidgetItem;
|
||||||
@ -112,6 +132,5 @@ QListWidgetItem *ArticleListWidget::createItem(RSS::Article *article)
|
|||||||
item->setData(Qt::DecorationRole, QIcon(":/icons/sphere2.png"));
|
item->setData(Qt::DecorationRole, QIcon(":/icons/sphere2.png"));
|
||||||
}
|
}
|
||||||
|
|
||||||
m_rssArticleToListItemMapping.insert(article, item);
|
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
@ -56,7 +56,8 @@ private slots:
|
|||||||
void handleArticleAboutToBeRemoved(RSS::Article *rssArticle);
|
void handleArticleAboutToBeRemoved(RSS::Article *rssArticle);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QListWidgetItem *createItem(RSS::Article *article);
|
void checkInvariant() const;
|
||||||
|
QListWidgetItem *createItem(RSS::Article *article) const;
|
||||||
|
|
||||||
RSS::Item *m_rssItem = nullptr;
|
RSS::Item *m_rssItem = nullptr;
|
||||||
bool m_unreadOnly = false;
|
bool m_unreadOnly = false;
|
||||||
|
@ -224,7 +224,7 @@ void RSSWidget::askNewFolder()
|
|||||||
destItem = destItem->parent();
|
destItem = destItem->parent();
|
||||||
}
|
}
|
||||||
// Consider the case where the user clicked on Unread item
|
// Consider the case where the user clicked on Unread item
|
||||||
RSS::Folder *rssDestFolder = ((destItem == m_feedListWidget->stickyUnreadItem())
|
RSS::Folder *rssDestFolder = ((!destItem || (destItem == m_feedListWidget->stickyUnreadItem()))
|
||||||
? RSS::Session::instance()->rootFolder()
|
? RSS::Session::instance()->rootFolder()
|
||||||
: qobject_cast<RSS::Folder *>(m_feedListWidget->getRSSItem(destItem)));
|
: qobject_cast<RSS::Folder *>(m_feedListWidget->getRSSItem(destItem)));
|
||||||
|
|
||||||
@ -234,7 +234,7 @@ void RSSWidget::askNewFolder()
|
|||||||
QMessageBox::warning(this, "qBittorrent", error, QMessageBox::Ok);
|
QMessageBox::warning(this, "qBittorrent", error, QMessageBox::Ok);
|
||||||
|
|
||||||
// Expand destination folder to display new feed
|
// Expand destination folder to display new feed
|
||||||
if (destItem != m_feedListWidget->stickyUnreadItem())
|
if (destItem && (destItem != m_feedListWidget->stickyUnreadItem()))
|
||||||
destItem->setExpanded(true);
|
destItem->setExpanded(true);
|
||||||
// As new RSS items are added synchronously, we can do the following here.
|
// As new RSS items are added synchronously, we can do the following here.
|
||||||
m_feedListWidget->setCurrentItem(m_feedListWidget->mapRSSItem(RSS::Session::instance()->itemByPath(newFolderPath)));
|
m_feedListWidget->setCurrentItem(m_feedListWidget->mapRSSItem(RSS::Session::instance()->itemByPath(newFolderPath)));
|
||||||
|
Loading…
Reference in New Issue
Block a user