mirror of
https://invent.kde.org/system/dolphin
synced 2024-10-28 03:21:56 +00:00
Show folder previews for items that have a Places Panel entry
Summary: informationpanelcontent.cpp currently has an explicit check for whether or not a URL has a Places panel entry, and if it does, no folder preview is generated. It's not clear why this is done, but it was reported as a bug: https://bugs.kde.org/show_bug.cgi?id=392621. Removing the logic fixes the bug. BUG: 392621 FIXED-IN: 18.08.0 Test Plan: Before: {F5782793} After: {F5782794} Detailed test procedure: - Open the Information Panel - Turn on previews - Put some pictures in ~/Pictures - Hover over it and see that the Information Panel shows a preview of its contents - Add ~/Pictures to the Places panel - Hover over it again and see that previews are no longer displayed - Apply the patch and restart Dolphin - Hover over it once more and see that there are now previews, yay! Reviewers: #dolphin, markg, elvisangelaccio Reviewed By: markg, elvisangelaccio Subscribers: markg, broulik Differential Revision: https://phabricator.kde.org/D11894
This commit is contained in:
parent
eab70b2ac4
commit
993c47f309
|
@ -160,7 +160,6 @@ void InformationPanelContent::showItem(const KFileItem& item)
|
|||
|
||||
const QUrl itemUrl = item.url();
|
||||
const bool isSearchUrl = itemUrl.scheme().contains(QStringLiteral("search")) && item.localPath().isEmpty();
|
||||
if (!applyPlace(itemUrl)) {
|
||||
setNameLabelText(item.text());
|
||||
if (isSearchUrl) {
|
||||
// in the case of a search-URL the URL is not readable for humans
|
||||
|
@ -192,7 +191,6 @@ void InformationPanelContent::showItem(const KFileItem& item)
|
|||
connect(m_previewJob.data(), &KIO::PreviewJob::failed,
|
||||
this, &InformationPanelContent::showIcon);
|
||||
}
|
||||
}
|
||||
|
||||
if (m_metaDataWidget) {
|
||||
m_metaDataWidget->show();
|
||||
|
@ -313,11 +311,9 @@ void InformationPanelContent::configureSettings(const QList<QAction*>& customCon
|
|||
void InformationPanelContent::showIcon(const KFileItem& item)
|
||||
{
|
||||
m_outdatedPreviewTimer->stop();
|
||||
if (!applyPlace(item.targetUrl())) {
|
||||
QPixmap pixmap = QIcon::fromTheme(item.iconName()).pixmap(KIconLoader::SizeEnormous, KIconLoader::SizeEnormous);
|
||||
KIconLoader::global()->drawOverlays(item.overlays(), pixmap, KIconLoader::Desktop);
|
||||
m_preview->setPixmap(pixmap);
|
||||
}
|
||||
}
|
||||
|
||||
void InformationPanelContent::showPreview(const KFileItem& item,
|
||||
|
@ -352,21 +348,6 @@ void InformationPanelContent::refreshMetaData()
|
|||
}
|
||||
}
|
||||
|
||||
bool InformationPanelContent::applyPlace(const QUrl& url)
|
||||
{
|
||||
const int count = m_placesItemModel->count();
|
||||
for (int i = 0; i < count; ++i) {
|
||||
const PlacesItem* item = m_placesItemModel->placesItem(i);
|
||||
if (item->url().matches(url, QUrl::StripTrailingSlash)) {
|
||||
setNameLabelText(item->text());
|
||||
m_preview->setPixmap(QIcon::fromTheme(item->icon()).pixmap(128, 128));
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
void InformationPanelContent::setNameLabelText(const QString& text)
|
||||
{
|
||||
QTextOption textOption;
|
||||
|
|
|
@ -115,14 +115,6 @@ private slots:
|
|||
void refreshMetaData();
|
||||
|
||||
private:
|
||||
/**
|
||||
* Checks whether the an URL is repesented by a place. If yes,
|
||||
* then the place icon and name are shown instead of a preview.
|
||||
* @return True, if the URL represents exactly a place.
|
||||
* @param url The url to check.
|
||||
*/
|
||||
bool applyPlace(const QUrl& url);
|
||||
|
||||
/**
|
||||
* Sets the text for the label \a m_nameLabel and assures that the
|
||||
* text is split in a way that it can be wrapped within the
|
||||
|
|
Loading…
Reference in a new issue