#include <klocale.h>
#include <kmenu.h>
#include <kseparator.h>
+#include <kstringhandler.h>
#include <Phonon/BackendCapabilities>
#include <Phonon/MediaObject>
#include <QPointer>
#include <QResizeEvent>
#include <QScrollArea>
+#include <QTextDocument>
#include <QTextLayout>
#include <QTextLine>
#include <QTimer>
#include "pixmapviewer.h"
InformationPanelContent::InformationPanelContent(QWidget* parent) :
- Panel(parent),
+ QWidget(parent),
m_item(),
m_pendingPreview(false),
m_outdatedPreviewTimer(0),
connect(m_outdatedPreviewTimer, SIGNAL(timeout()),
this, SLOT(markOutdatedPreview()));
- QVBoxLayout* layout = new QVBoxLayout;
+ QVBoxLayout* layout = new QVBoxLayout(this);
layout->setSpacing(KDialog::spacingHint());
// preview
m_preview->setMinimumHeight(KIconLoader::SizeEnormous);
m_phononWidget = new PhononWidget(parent);
+ m_phononWidget->hide();
m_phononWidget->setMinimumWidth(minPreviewWidth);
connect(m_phononWidget, SIGNAL(playingStarted()),
this, SLOT(slotPlayingStarted()));
containerLayout->setContentsMargins(0, 0, 0, 0);
containerLayout->setSpacing(0);
containerLayout->addWidget(m_metaDataWidget);
- QWidget* stretchWidget = new QWidget(metaDataWidgetContainer);
- stretchWidget->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::MinimumExpanding);
- containerLayout->addWidget(stretchWidget);
+ containerLayout->addStretch();
m_metaDataArea = new QScrollArea(parent);
m_metaDataArea->setWidget(metaDataWidgetContainer);
layout->addWidget(m_nameLabel);
layout->addWidget(new KSeparator());
layout->addWidget(m_metaDataArea);
- parent->setLayout(layout);
}
InformationPanelContent::~InformationPanelContent()
m_pendingPreview = false;
const KUrl itemUrl = item.url();
- const bool isNepomukSearchUrl = itemUrl.protocol().startsWith("nepomuk") && item.nepomukUri().isEmpty();
+ const bool isSearchUrl = itemUrl.protocol().contains("search") && item.nepomukUri().isEmpty();
if (!applyPlace(itemUrl)) {
- if (isNepomukSearchUrl) {
- // in the case of a Nepomuk query-URL the URL is not readable for humans
+ setNameLabelText(item.text());
+ if (isSearchUrl) {
+ // in the case of a search-URL the URL is not readable for humans
// (at least not useful to show in the Information Panel)
KIconLoader iconLoader;
QPixmap icon = iconLoader.loadIcon("nepomuk",
KIconLoader::NoGroup,
KIconLoader::SizeEnormous);
m_preview->setPixmap(icon);
- setNameLabelText(QString());
} else {
// try to get a preview pixmap from the item...
m_pendingPreview = true;
this, SLOT(showPreview(const KFileItem&, const QPixmap&)));
connect(job, SIGNAL(failed(const KFileItem&)),
this, SLOT(showIcon(const KFileItem&)));
-
- setNameLabelText(item.text());
}
}
if (m_metaDataWidget != 0) {
- if (isNepomukSearchUrl) {
- m_metaDataWidget->hide();
- } else {
- m_metaDataWidget->show();
- m_metaDataWidget->setItems(KFileItemList() << item);
- }
+ m_metaDataWidget->show();
+ m_metaDataWidget->setItems(KFileItemList() << item);
}
if (InformationPanelSettings::showPreview()) {
break;
}
- return Panel::eventFilter(obj, event);
+ return QWidget::eventFilter(obj, event);
}
void InformationPanelContent::configureSettings()
void InformationPanelContent::markOutdatedPreview()
{
- KIconEffect iconEffect;
- QPixmap disabledPixmap = iconEffect.apply(m_preview->pixmap(),
- KIconLoader::Desktop,
- KIconLoader::DisabledState);
+ KIconEffect *iconEffect = KIconLoader::global()->iconEffect();
+ QPixmap disabledPixmap = iconEffect->apply(m_preview->pixmap(),
+ KIconLoader::Desktop,
+ KIconLoader::DisabledState);
m_preview->setPixmap(disabledPixmap);
}
QTextOption textOption;
textOption.setWrapMode(QTextOption::WrapAtWordBoundaryOrAnywhere);
- QTextLayout textLayout(text);
+ const QString processedText = Qt::mightBeRichText(text) ? text : KStringHandler::preProcessWrap(text);
+
+ QTextLayout textLayout(processedText);
textLayout.setFont(m_nameLabel->font());
textLayout.setTextOption(textOption);
QString wrappedText;
- wrappedText.reserve(text.length());
+ wrappedText.reserve(processedText.length());
// wrap the text to fit into the width of m_nameLabel
textLayout.beginLayout();
QTextLine line = textLayout.createLine();
while (line.isValid()) {
line.setLineWidth(m_nameLabel->width());
- wrappedText += text.mid(line.textStart(), line.textLength());
+ wrappedText += processedText.mid(line.textStart(), line.textLength());
line = textLayout.createLine();
if (line.isValid()) {