mirror of
https://github.com/qbittorrent/qBittorrent.git
synced 2025-01-21 23:13:46 +03:00
Fix tab order in RSS widget
Related: https://github.com/qbittorrent/qBittorrent/pull/21996#issuecomment-2543127251 PR #21999.
This commit is contained in:
parent
1c82eb3dff
commit
34c8849f22
3 changed files with 73 additions and 71 deletions
|
@ -79,23 +79,19 @@ RSSWidget::RSSWidget(IGUIApplication *app, QWidget *parent)
|
||||||
m_ui->rssDownloaderBtn->setIcon(UIThemeManager::instance()->getIcon(u"downloading"_s, u"download"_s));
|
m_ui->rssDownloaderBtn->setIcon(UIThemeManager::instance()->getIcon(u"downloading"_s, u"download"_s));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
m_articleListWidget = new ArticleListWidget(m_ui->splitterMain);
|
connect(m_ui->articleListWidget, &ArticleListWidget::customContextMenuRequested, this, &RSSWidget::displayItemsListMenu);
|
||||||
m_ui->splitterMain->insertWidget(0, m_articleListWidget);
|
connect(m_ui->articleListWidget, &ArticleListWidget::currentItemChanged, this, &RSSWidget::handleCurrentArticleItemChanged);
|
||||||
connect(m_articleListWidget, &ArticleListWidget::customContextMenuRequested, this, &RSSWidget::displayItemsListMenu);
|
connect(m_ui->articleListWidget, &ArticleListWidget::itemDoubleClicked, this, &RSSWidget::downloadSelectedTorrents);
|
||||||
connect(m_articleListWidget, &ArticleListWidget::currentItemChanged, this, &RSSWidget::handleCurrentArticleItemChanged);
|
|
||||||
connect(m_articleListWidget, &ArticleListWidget::itemDoubleClicked, this, &RSSWidget::downloadSelectedTorrents);
|
|
||||||
|
|
||||||
m_feedListWidget = new FeedListWidget(m_ui->splitterSide);
|
connect(m_ui->feedListWidget, &QAbstractItemView::doubleClicked, this, &RSSWidget::renameSelectedRSSItem);
|
||||||
m_ui->splitterSide->insertWidget(0, m_feedListWidget);
|
connect(m_ui->feedListWidget, &QTreeWidget::currentItemChanged, this, &RSSWidget::handleCurrentFeedItemChanged);
|
||||||
connect(m_feedListWidget, &QAbstractItemView::doubleClicked, this, &RSSWidget::renameSelectedRSSItem);
|
connect(m_ui->feedListWidget, &QWidget::customContextMenuRequested, this, &RSSWidget::displayRSSListMenu);
|
||||||
connect(m_feedListWidget, &QTreeWidget::currentItemChanged, this, &RSSWidget::handleCurrentFeedItemChanged);
|
|
||||||
connect(m_feedListWidget, &QWidget::customContextMenuRequested, this, &RSSWidget::displayRSSListMenu);
|
|
||||||
loadFoldersOpenState();
|
loadFoldersOpenState();
|
||||||
m_feedListWidget->setCurrentItem(m_feedListWidget->stickyUnreadItem());
|
m_ui->feedListWidget->setCurrentItem(m_ui->feedListWidget->stickyUnreadItem());
|
||||||
|
|
||||||
const auto *editHotkey = new QShortcut(Qt::Key_F2, m_feedListWidget, nullptr, nullptr, Qt::WidgetShortcut);
|
const auto *editHotkey = new QShortcut(Qt::Key_F2, m_ui->feedListWidget, nullptr, nullptr, Qt::WidgetShortcut);
|
||||||
connect(editHotkey, &QShortcut::activated, this, &RSSWidget::renameSelectedRSSItem);
|
connect(editHotkey, &QShortcut::activated, this, &RSSWidget::renameSelectedRSSItem);
|
||||||
const auto *deleteHotkey = new QShortcut(QKeySequence::Delete, m_feedListWidget, nullptr, nullptr, Qt::WidgetShortcut);
|
const auto *deleteHotkey = new QShortcut(QKeySequence::Delete, m_ui->feedListWidget, nullptr, nullptr, Qt::WidgetShortcut);
|
||||||
connect(deleteHotkey, &QShortcut::activated, this, &RSSWidget::deleteSelectedItems);
|
connect(deleteHotkey, &QShortcut::activated, this, &RSSWidget::deleteSelectedItems);
|
||||||
|
|
||||||
// Feeds list actions
|
// Feeds list actions
|
||||||
|
@ -134,25 +130,24 @@ RSSWidget::~RSSWidget()
|
||||||
{
|
{
|
||||||
// we need it here to properly mark latest article
|
// we need it here to properly mark latest article
|
||||||
// as read without having additional code
|
// as read without having additional code
|
||||||
m_articleListWidget->clear();
|
m_ui->articleListWidget->clear();
|
||||||
|
|
||||||
saveFoldersOpenState();
|
saveFoldersOpenState();
|
||||||
|
|
||||||
delete m_feedListWidget;
|
|
||||||
delete m_ui;
|
delete m_ui;
|
||||||
}
|
}
|
||||||
|
|
||||||
// display a right-click menu
|
// display a right-click menu
|
||||||
void RSSWidget::displayRSSListMenu(const QPoint &pos)
|
void RSSWidget::displayRSSListMenu(const QPoint &pos)
|
||||||
{
|
{
|
||||||
if (!m_feedListWidget->indexAt(pos).isValid())
|
if (!m_ui->feedListWidget->indexAt(pos).isValid())
|
||||||
// No item under the mouse, clear selection
|
// No item under the mouse, clear selection
|
||||||
m_feedListWidget->clearSelection();
|
m_ui->feedListWidget->clearSelection();
|
||||||
|
|
||||||
QMenu *menu = new QMenu(this);
|
QMenu *menu = new QMenu(this);
|
||||||
menu->setAttribute(Qt::WA_DeleteOnClose);
|
menu->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
|
||||||
const QList<QTreeWidgetItem *> selectedItems = m_feedListWidget->selectedItems();
|
const QList<QTreeWidgetItem *> selectedItems = m_ui->feedListWidget->selectedItems();
|
||||||
if (!selectedItems.isEmpty())
|
if (!selectedItems.isEmpty())
|
||||||
{
|
{
|
||||||
menu->addAction(m_ui->actionUpdate);
|
menu->addAction(m_ui->actionUpdate);
|
||||||
|
@ -162,14 +157,14 @@ void RSSWidget::displayRSSListMenu(const QPoint &pos)
|
||||||
if (selectedItems.size() == 1)
|
if (selectedItems.size() == 1)
|
||||||
{
|
{
|
||||||
QTreeWidgetItem *selectedItem = selectedItems.first();
|
QTreeWidgetItem *selectedItem = selectedItems.first();
|
||||||
if (selectedItem != m_feedListWidget->stickyUnreadItem())
|
if (selectedItem != m_ui->feedListWidget->stickyUnreadItem())
|
||||||
{
|
{
|
||||||
menu->addAction(m_ui->actionRename);
|
menu->addAction(m_ui->actionRename);
|
||||||
if (m_feedListWidget->isFeed(selectedItem))
|
if (m_ui->feedListWidget->isFeed(selectedItem))
|
||||||
menu->addAction(m_ui->actionEditFeedURL);
|
menu->addAction(m_ui->actionEditFeedURL);
|
||||||
menu->addAction(m_ui->actionDelete);
|
menu->addAction(m_ui->actionDelete);
|
||||||
menu->addSeparator();
|
menu->addSeparator();
|
||||||
if (m_feedListWidget->isFolder(selectedItem))
|
if (m_ui->feedListWidget->isFolder(selectedItem))
|
||||||
menu->addAction(m_ui->actionNewFolder);
|
menu->addAction(m_ui->actionNewFolder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -181,7 +176,7 @@ void RSSWidget::displayRSSListMenu(const QPoint &pos)
|
||||||
|
|
||||||
menu->addAction(m_ui->actionNewSubscription);
|
menu->addAction(m_ui->actionNewSubscription);
|
||||||
|
|
||||||
if (m_feedListWidget->isFeed(selectedItems.first()))
|
if (m_ui->feedListWidget->isFeed(selectedItems.first()))
|
||||||
{
|
{
|
||||||
menu->addSeparator();
|
menu->addSeparator();
|
||||||
menu->addAction(m_ui->actionCopyFeedURL);
|
menu->addAction(m_ui->actionCopyFeedURL);
|
||||||
|
@ -202,7 +197,7 @@ void RSSWidget::displayItemsListMenu()
|
||||||
{
|
{
|
||||||
bool hasTorrent = false;
|
bool hasTorrent = false;
|
||||||
bool hasLink = false;
|
bool hasLink = false;
|
||||||
for (const QListWidgetItem *item : asConst(m_articleListWidget->selectedItems()))
|
for (const QListWidgetItem *item : asConst(m_ui->articleListWidget->selectedItems()))
|
||||||
{
|
{
|
||||||
auto *article = item->data(Qt::UserRole).value<RSS::Article *>();
|
auto *article = item->data(Qt::UserRole).value<RSS::Article *>();
|
||||||
Q_ASSERT(article);
|
Q_ASSERT(article);
|
||||||
|
@ -240,17 +235,17 @@ void RSSWidget::askNewFolder()
|
||||||
|
|
||||||
// Determine destination folder for new item
|
// Determine destination folder for new item
|
||||||
QTreeWidgetItem *destItem = nullptr;
|
QTreeWidgetItem *destItem = nullptr;
|
||||||
QList<QTreeWidgetItem *> selectedItems = m_feedListWidget->selectedItems();
|
QList<QTreeWidgetItem *> selectedItems = m_ui->feedListWidget->selectedItems();
|
||||||
if (!selectedItems.empty())
|
if (!selectedItems.empty())
|
||||||
{
|
{
|
||||||
destItem = selectedItems.first();
|
destItem = selectedItems.first();
|
||||||
if (!m_feedListWidget->isFolder(destItem))
|
if (!m_ui->feedListWidget->isFolder(destItem))
|
||||||
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 || (destItem == m_feedListWidget->stickyUnreadItem()))
|
RSS::Folder *rssDestFolder = ((!destItem || (destItem == m_ui->feedListWidget->stickyUnreadItem()))
|
||||||
? RSS::Session::instance()->rootFolder()
|
? RSS::Session::instance()->rootFolder()
|
||||||
: qobject_cast<RSS::Folder *>(m_feedListWidget->getRSSItem(destItem)));
|
: qobject_cast<RSS::Folder *>(m_ui->feedListWidget->getRSSItem(destItem)));
|
||||||
|
|
||||||
const QString newFolderPath = RSS::Item::joinPath(rssDestFolder->path(), newName);
|
const QString newFolderPath = RSS::Item::joinPath(rssDestFolder->path(), newName);
|
||||||
const nonstd::expected<void, QString> result = RSS::Session::instance()->addFolder(newFolderPath);
|
const nonstd::expected<void, QString> result = RSS::Session::instance()->addFolder(newFolderPath);
|
||||||
|
@ -258,10 +253,10 @@ void RSSWidget::askNewFolder()
|
||||||
QMessageBox::warning(this, u"qBittorrent"_s, result.error(), QMessageBox::Ok);
|
QMessageBox::warning(this, u"qBittorrent"_s, result.error(), QMessageBox::Ok);
|
||||||
|
|
||||||
// Expand destination folder to display new feed
|
// Expand destination folder to display new feed
|
||||||
if (destItem && (destItem != m_feedListWidget->stickyUnreadItem()))
|
if (destItem && (destItem != m_ui->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_ui->feedListWidget->setCurrentItem(m_ui->feedListWidget->mapRSSItem(RSS::Session::instance()->itemByPath(newFolderPath)));
|
||||||
}
|
}
|
||||||
|
|
||||||
// add a stream by a button
|
// add a stream by a button
|
||||||
|
@ -281,17 +276,17 @@ void RSSWidget::on_newFeedButton_clicked()
|
||||||
|
|
||||||
// Determine destination folder for new item
|
// Determine destination folder for new item
|
||||||
QTreeWidgetItem *destItem = nullptr;
|
QTreeWidgetItem *destItem = nullptr;
|
||||||
QList<QTreeWidgetItem *> selectedItems = m_feedListWidget->selectedItems();
|
QList<QTreeWidgetItem *> selectedItems = m_ui->feedListWidget->selectedItems();
|
||||||
if (!selectedItems.empty())
|
if (!selectedItems.empty())
|
||||||
{
|
{
|
||||||
destItem = selectedItems.first();
|
destItem = selectedItems.first();
|
||||||
if (!m_feedListWidget->isFolder(destItem))
|
if (!m_ui->feedListWidget->isFolder(destItem))
|
||||||
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 || (destItem == m_feedListWidget->stickyUnreadItem()))
|
RSS::Folder *rssDestFolder = ((!destItem || (destItem == m_ui->feedListWidget->stickyUnreadItem()))
|
||||||
? RSS::Session::instance()->rootFolder()
|
? RSS::Session::instance()->rootFolder()
|
||||||
: qobject_cast<RSS::Folder *>(m_feedListWidget->getRSSItem(destItem)));
|
: qobject_cast<RSS::Folder *>(m_ui->feedListWidget->getRSSItem(destItem)));
|
||||||
|
|
||||||
// NOTE: We still add feed using legacy way (with URL as feed name)
|
// NOTE: We still add feed using legacy way (with URL as feed name)
|
||||||
const QString newFeedPath = RSS::Item::joinPath(rssDestFolder->path(), newURL);
|
const QString newFeedPath = RSS::Item::joinPath(rssDestFolder->path(), newURL);
|
||||||
|
@ -300,18 +295,18 @@ void RSSWidget::on_newFeedButton_clicked()
|
||||||
QMessageBox::warning(this, u"qBittorrent"_s, result.error(), QMessageBox::Ok);
|
QMessageBox::warning(this, u"qBittorrent"_s, result.error(), QMessageBox::Ok);
|
||||||
|
|
||||||
// Expand destination folder to display new feed
|
// Expand destination folder to display new feed
|
||||||
if (destItem && (destItem != m_feedListWidget->stickyUnreadItem()))
|
if (destItem && (destItem != m_ui->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(newFeedPath)));
|
m_ui->feedListWidget->setCurrentItem(m_ui->feedListWidget->mapRSSItem(RSS::Session::instance()->itemByPath(newFeedPath)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSSWidget::deleteSelectedItems()
|
void RSSWidget::deleteSelectedItems()
|
||||||
{
|
{
|
||||||
const QList<QTreeWidgetItem *> selectedItems = m_feedListWidget->selectedItems();
|
const QList<QTreeWidgetItem *> selectedItems = m_ui->feedListWidget->selectedItems();
|
||||||
if (selectedItems.isEmpty())
|
if (selectedItems.isEmpty())
|
||||||
return;
|
return;
|
||||||
if ((selectedItems.size() == 1) && (selectedItems.first() == m_feedListWidget->stickyUnreadItem()))
|
if ((selectedItems.size() == 1) && (selectedItems.first() == m_ui->feedListWidget->stickyUnreadItem()))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QMessageBox::StandardButton answer = QMessageBox::question(
|
QMessageBox::StandardButton answer = QMessageBox::question(
|
||||||
|
@ -321,8 +316,8 @@ void RSSWidget::deleteSelectedItems()
|
||||||
return;
|
return;
|
||||||
|
|
||||||
for (QTreeWidgetItem *item : selectedItems)
|
for (QTreeWidgetItem *item : selectedItems)
|
||||||
if (item != m_feedListWidget->stickyUnreadItem())
|
if (item != m_ui->feedListWidget->stickyUnreadItem())
|
||||||
RSS::Session::instance()->removeItem(m_feedListWidget->itemPath(item));
|
RSS::Session::instance()->removeItem(m_ui->feedListWidget->itemPath(item));
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSSWidget::loadFoldersOpenState()
|
void RSSWidget::loadFoldersOpenState()
|
||||||
|
@ -333,11 +328,11 @@ void RSSWidget::loadFoldersOpenState()
|
||||||
QTreeWidgetItem *parent = nullptr;
|
QTreeWidgetItem *parent = nullptr;
|
||||||
for (const QString &name : asConst(varPath.split(u'\\')))
|
for (const QString &name : asConst(varPath.split(u'\\')))
|
||||||
{
|
{
|
||||||
int nbChildren = (parent ? parent->childCount() : m_feedListWidget->topLevelItemCount());
|
int nbChildren = (parent ? parent->childCount() : m_ui->feedListWidget->topLevelItemCount());
|
||||||
for (int i = 0; i < nbChildren; ++i)
|
for (int i = 0; i < nbChildren; ++i)
|
||||||
{
|
{
|
||||||
QTreeWidgetItem *child = (parent ? parent->child(i) : m_feedListWidget->topLevelItem(i));
|
QTreeWidgetItem *child = (parent ? parent->child(i) : m_ui->feedListWidget->topLevelItem(i));
|
||||||
if (m_feedListWidget->getRSSItem(child)->name() == name)
|
if (m_ui->feedListWidget->getRSSItem(child)->name() == name)
|
||||||
{
|
{
|
||||||
parent = child;
|
parent = child;
|
||||||
parent->setExpanded(true);
|
parent->setExpanded(true);
|
||||||
|
@ -351,8 +346,8 @@ void RSSWidget::loadFoldersOpenState()
|
||||||
void RSSWidget::saveFoldersOpenState()
|
void RSSWidget::saveFoldersOpenState()
|
||||||
{
|
{
|
||||||
QStringList openedFolders;
|
QStringList openedFolders;
|
||||||
for (QTreeWidgetItem *item : asConst(m_feedListWidget->getAllOpenedFolders()))
|
for (QTreeWidgetItem *item : asConst(m_ui->feedListWidget->getAllOpenedFolders()))
|
||||||
openedFolders << m_feedListWidget->itemPath(item);
|
openedFolders << m_ui->feedListWidget->itemPath(item);
|
||||||
Preferences::instance()->setRssOpenFolders(openedFolders);
|
Preferences::instance()->setRssOpenFolders(openedFolders);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -363,7 +358,7 @@ void RSSWidget::refreshAllFeeds()
|
||||||
|
|
||||||
void RSSWidget::downloadSelectedTorrents()
|
void RSSWidget::downloadSelectedTorrents()
|
||||||
{
|
{
|
||||||
for (QListWidgetItem *item : asConst(m_articleListWidget->selectedItems()))
|
for (QListWidgetItem *item : asConst(m_ui->articleListWidget->selectedItems()))
|
||||||
{
|
{
|
||||||
auto *article = item->data(Qt::UserRole).value<RSS::Article *>();
|
auto *article = item->data(Qt::UserRole).value<RSS::Article *>();
|
||||||
Q_ASSERT(article);
|
Q_ASSERT(article);
|
||||||
|
@ -378,7 +373,7 @@ void RSSWidget::downloadSelectedTorrents()
|
||||||
// open the url of the selected RSS articles in the Web browser
|
// open the url of the selected RSS articles in the Web browser
|
||||||
void RSSWidget::openSelectedArticlesUrls()
|
void RSSWidget::openSelectedArticlesUrls()
|
||||||
{
|
{
|
||||||
for (QListWidgetItem *item : asConst(m_articleListWidget->selectedItems()))
|
for (QListWidgetItem *item : asConst(m_ui->articleListWidget->selectedItems()))
|
||||||
{
|
{
|
||||||
auto *article = item->data(Qt::UserRole).value<RSS::Article *>();
|
auto *article = item->data(Qt::UserRole).value<RSS::Article *>();
|
||||||
Q_ASSERT(article);
|
Q_ASSERT(article);
|
||||||
|
@ -393,14 +388,14 @@ void RSSWidget::openSelectedArticlesUrls()
|
||||||
|
|
||||||
void RSSWidget::renameSelectedRSSItem()
|
void RSSWidget::renameSelectedRSSItem()
|
||||||
{
|
{
|
||||||
QList<QTreeWidgetItem *> selectedItems = m_feedListWidget->selectedItems();
|
QList<QTreeWidgetItem *> selectedItems = m_ui->feedListWidget->selectedItems();
|
||||||
if (selectedItems.size() != 1) return;
|
if (selectedItems.size() != 1) return;
|
||||||
|
|
||||||
QTreeWidgetItem *item = selectedItems.first();
|
QTreeWidgetItem *item = selectedItems.first();
|
||||||
if (item == m_feedListWidget->stickyUnreadItem())
|
if (item == m_ui->feedListWidget->stickyUnreadItem())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
RSS::Item *rssItem = m_feedListWidget->getRSSItem(item);
|
RSS::Item *rssItem = m_ui->feedListWidget->getRSSItem(item);
|
||||||
const QString parentPath = RSS::Item::parentPath(rssItem->path());
|
const QString parentPath = RSS::Item::parentPath(rssItem->path());
|
||||||
bool ok = false;
|
bool ok = false;
|
||||||
do
|
do
|
||||||
|
@ -422,12 +417,12 @@ void RSSWidget::renameSelectedRSSItem()
|
||||||
|
|
||||||
void RSSWidget::editSelectedRSSFeedURL()
|
void RSSWidget::editSelectedRSSFeedURL()
|
||||||
{
|
{
|
||||||
QList<QTreeWidgetItem *> selectedItems = m_feedListWidget->selectedItems();
|
QList<QTreeWidgetItem *> selectedItems = m_ui->feedListWidget->selectedItems();
|
||||||
if (selectedItems.size() != 1)
|
if (selectedItems.size() != 1)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
QTreeWidgetItem *item = selectedItems.first();
|
QTreeWidgetItem *item = selectedItems.first();
|
||||||
RSS::Feed *rssFeed = qobject_cast<RSS::Feed *>(m_feedListWidget->getRSSItem(item));
|
RSS::Feed *rssFeed = qobject_cast<RSS::Feed *>(m_ui->feedListWidget->getRSSItem(item));
|
||||||
Q_ASSERT(rssFeed);
|
Q_ASSERT(rssFeed);
|
||||||
if (!rssFeed) [[unlikely]]
|
if (!rssFeed) [[unlikely]]
|
||||||
return;
|
return;
|
||||||
|
@ -445,24 +440,24 @@ void RSSWidget::editSelectedRSSFeedURL()
|
||||||
|
|
||||||
void RSSWidget::refreshSelectedItems()
|
void RSSWidget::refreshSelectedItems()
|
||||||
{
|
{
|
||||||
for (QTreeWidgetItem *item : asConst(m_feedListWidget->selectedItems()))
|
for (QTreeWidgetItem *item : asConst(m_ui->feedListWidget->selectedItems()))
|
||||||
{
|
{
|
||||||
if (item == m_feedListWidget->stickyUnreadItem())
|
if (item == m_ui->feedListWidget->stickyUnreadItem())
|
||||||
{
|
{
|
||||||
refreshAllFeeds();
|
refreshAllFeeds();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_feedListWidget->getRSSItem(item)->refresh();
|
m_ui->feedListWidget->getRSSItem(item)->refresh();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSSWidget::copySelectedFeedsURL()
|
void RSSWidget::copySelectedFeedsURL()
|
||||||
{
|
{
|
||||||
QStringList URLs;
|
QStringList URLs;
|
||||||
for (QTreeWidgetItem *item : asConst(m_feedListWidget->selectedItems()))
|
for (QTreeWidgetItem *item : asConst(m_ui->feedListWidget->selectedItems()))
|
||||||
{
|
{
|
||||||
if (auto *feed = qobject_cast<RSS::Feed *>(m_feedListWidget->getRSSItem(item)))
|
if (auto *feed = qobject_cast<RSS::Feed *>(m_ui->feedListWidget->getRSSItem(item)))
|
||||||
URLs << feed->url();
|
URLs << feed->url();
|
||||||
}
|
}
|
||||||
qApp->clipboard()->setText(URLs.join(u'\n'));
|
qApp->clipboard()->setText(URLs.join(u'\n'));
|
||||||
|
@ -470,16 +465,16 @@ void RSSWidget::copySelectedFeedsURL()
|
||||||
|
|
||||||
void RSSWidget::handleCurrentFeedItemChanged(QTreeWidgetItem *currentItem)
|
void RSSWidget::handleCurrentFeedItemChanged(QTreeWidgetItem *currentItem)
|
||||||
{
|
{
|
||||||
m_articleListWidget->setRSSItem(m_feedListWidget->getRSSItem(currentItem)
|
m_ui->articleListWidget->setRSSItem(m_ui->feedListWidget->getRSSItem(currentItem)
|
||||||
, (currentItem == m_feedListWidget->stickyUnreadItem()));
|
, (currentItem == m_ui->feedListWidget->stickyUnreadItem()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSSWidget::on_markReadButton_clicked()
|
void RSSWidget::on_markReadButton_clicked()
|
||||||
{
|
{
|
||||||
for (QTreeWidgetItem *item : asConst(m_feedListWidget->selectedItems()))
|
for (QTreeWidgetItem *item : asConst(m_ui->feedListWidget->selectedItems()))
|
||||||
{
|
{
|
||||||
m_feedListWidget->getRSSItem(item)->markAsRead();
|
m_ui->feedListWidget->getRSSItem(item)->markAsRead();
|
||||||
if (item == m_feedListWidget->stickyUnreadItem())
|
if (item == m_ui->feedListWidget->stickyUnreadItem())
|
||||||
break; // all items was read
|
break; // all items was read
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -491,7 +486,7 @@ void RSSWidget::handleCurrentArticleItemChanged(QListWidgetItem *currentItem, QL
|
||||||
|
|
||||||
if (previousItem)
|
if (previousItem)
|
||||||
{
|
{
|
||||||
auto *article = m_articleListWidget->getRSSArticle(previousItem);
|
auto *article = m_ui->articleListWidget->getRSSArticle(previousItem);
|
||||||
Q_ASSERT(article);
|
Q_ASSERT(article);
|
||||||
article->markAsRead();
|
article->markAsRead();
|
||||||
}
|
}
|
||||||
|
@ -499,7 +494,7 @@ void RSSWidget::handleCurrentArticleItemChanged(QListWidgetItem *currentItem, QL
|
||||||
if (!currentItem)
|
if (!currentItem)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto *article = m_articleListWidget->getRSSArticle(currentItem);
|
auto *article = m_ui->articleListWidget->getRSSArticle(currentItem);
|
||||||
renderArticle(article);
|
renderArticle(article);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -548,10 +543,10 @@ bool RSSWidget::eventFilter(QObject *obj, QEvent *event)
|
||||||
{
|
{
|
||||||
if ((obj == m_ui->textBrowser) && (event->type() == QEvent::PaletteChange))
|
if ((obj == m_ui->textBrowser) && (event->type() == QEvent::PaletteChange))
|
||||||
{
|
{
|
||||||
QListWidgetItem *currentItem = m_articleListWidget->currentItem();
|
QListWidgetItem *currentItem = m_ui->articleListWidget->currentItem();
|
||||||
if (currentItem)
|
if (currentItem)
|
||||||
{
|
{
|
||||||
const RSS::Article *article = m_articleListWidget->getRSSArticle(currentItem);
|
const RSS::Article *article = m_ui->articleListWidget->getRSSArticle(currentItem);
|
||||||
renderArticle(article);
|
renderArticle(article);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -572,7 +567,7 @@ void RSSWidget::renderArticle(const RSS::Article *article) const
|
||||||
u"<div style='background-color: \"%1\"; font-weight: bold; color: \"%2\";'>%3</div>"_s.arg(highlightedBaseColor, highlightedBaseTextColor, article->title());
|
u"<div style='background-color: \"%1\"; font-weight: bold; color: \"%2\";'>%3</div>"_s.arg(highlightedBaseColor, highlightedBaseTextColor, article->title());
|
||||||
if (article->date().isValid())
|
if (article->date().isValid())
|
||||||
html += u"<div style='background-color: \"%1\";'><b>%2</b>%3</div>"_s.arg(alternateBaseColor, tr("Date: "), QLocale::system().toString(article->date().toLocalTime()));
|
html += u"<div style='background-color: \"%1\";'><b>%2</b>%3</div>"_s.arg(alternateBaseColor, tr("Date: "), QLocale::system().toString(article->date().toLocalTime()));
|
||||||
if (m_feedListWidget->currentItem() == m_feedListWidget->stickyUnreadItem())
|
if (m_ui->feedListWidget->currentItem() == m_ui->feedListWidget->stickyUnreadItem())
|
||||||
html += u"<div style='background-color: \"%1\";'><b>%2</b>%3</div>"_s.arg(alternateBaseColor, tr("Feed: "), article->feed()->title());
|
html += u"<div style='background-color: \"%1\";'><b>%2</b>%3</div>"_s.arg(alternateBaseColor, tr("Feed: "), article->feed()->title());
|
||||||
if (!article->author().isEmpty())
|
if (!article->author().isEmpty())
|
||||||
html += u"<div style='background-color: \"%1\";'><b>%2</b>%3</div>"_s.arg(alternateBaseColor, tr("Author: "), article->author());
|
html += u"<div style='background-color: \"%1\";'><b>%2</b>%3</div>"_s.arg(alternateBaseColor, tr("Author: "), article->author());
|
||||||
|
|
|
@ -37,9 +37,6 @@
|
||||||
class QListWidgetItem;
|
class QListWidgetItem;
|
||||||
class QTreeWidgetItem;
|
class QTreeWidgetItem;
|
||||||
|
|
||||||
class ArticleListWidget;
|
|
||||||
class FeedListWidget;
|
|
||||||
|
|
||||||
namespace RSS
|
namespace RSS
|
||||||
{
|
{
|
||||||
class Article;
|
class Article;
|
||||||
|
@ -94,6 +91,4 @@ private:
|
||||||
void renderArticle(const RSS::Article *article) const;
|
void renderArticle(const RSS::Article *article) const;
|
||||||
|
|
||||||
Ui::RSSWidget *m_ui = nullptr;
|
Ui::RSSWidget *m_ui = nullptr;
|
||||||
ArticleListWidget *m_articleListWidget = nullptr;
|
|
||||||
FeedListWidget *m_feedListWidget = nullptr;
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -94,6 +94,7 @@
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
<enum>Qt::Orientation::Horizontal</enum>
|
<enum>Qt::Orientation::Horizontal</enum>
|
||||||
</property>
|
</property>
|
||||||
|
<widget class="FeedListWidget" name="feedListWidget"/>
|
||||||
<widget class="QWidget" name="layoutWidget">
|
<widget class="QWidget" name="layoutWidget">
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
<item>
|
<item>
|
||||||
|
@ -119,6 +120,7 @@
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
<enum>Qt::Orientation::Horizontal</enum>
|
<enum>Qt::Orientation::Horizontal</enum>
|
||||||
</property>
|
</property>
|
||||||
|
<widget class="ArticleListWidget" name="articleListWidget"/>
|
||||||
<widget class="HtmlBrowser" name="textBrowser">
|
<widget class="HtmlBrowser" name="textBrowser">
|
||||||
<property name="openExternalLinks">
|
<property name="openExternalLinks">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
|
@ -211,6 +213,16 @@
|
||||||
<extends>QTextBrowser</extends>
|
<extends>QTextBrowser</extends>
|
||||||
<header>gui/rss/htmlbrowser.h</header>
|
<header>gui/rss/htmlbrowser.h</header>
|
||||||
</customwidget>
|
</customwidget>
|
||||||
|
<customwidget>
|
||||||
|
<class>FeedListWidget</class>
|
||||||
|
<extends>QTreeWidget</extends>
|
||||||
|
<header>gui/rss/feedlistwidget.h</header>
|
||||||
|
</customwidget>
|
||||||
|
<customwidget>
|
||||||
|
<class>ArticleListWidget</class>
|
||||||
|
<extends>QListWidget</extends>
|
||||||
|
<header>gui/rss/articlelistwidget.h</header>
|
||||||
|
</customwidget>
|
||||||
</customwidgets>
|
</customwidgets>
|
||||||
<resources/>
|
<resources/>
|
||||||
<connections/>
|
<connections/>
|
||||||
|
|
Loading…
Add table
Reference in a new issue