#include <QPainter>
#include <QPixmap>
#include <QResizeEvent>
+#include <QTextLayout>
+#include <QTextLine>
#include <QTimer>
#include <QVBoxLayout>
void InfoSidebarPage::setUrl(const KUrl& url)
{
SidebarPage::setUrl(url);
- if (url.isValid() && !m_shownUrl.equals(url, KUrl::CompareWithoutTrailingSlash)) {
- if (m_initialized) {
+ if (url.isValid() && !isEqualToShownUrl(url)) {
+ if (isVisible()) {
cancelRequest();
m_shownUrl = url;
showItemInfo();
void InfoSidebarPage::setSelection(const KFileItemList& selection)
{
- if (!m_initialized) {
+ if (!isVisible()) {
return;
}
const int count = selection.count();
if (count == 0) {
- m_shownUrl = url();
- showItemInfo();
+ if (!isEqualToShownUrl(url())) {
+ m_shownUrl = url();
+ showItemInfo();
+ }
} else {
if ((count == 1) && !selection.first().url().isEmpty()) {
m_urlCandidate = selection.first().url();
void InfoSidebarPage::requestDelayedItemInfo(const KFileItem& item)
{
- if (!m_initialized) {
+ if (!isVisible()) {
return;
}
m_pendingPreview = false;
m_infoTimer->start();
}
- } else if (!item.url().isEmpty()) {
- m_urlCandidate = item.url();
- m_fileItem = item;
- m_infoTimer->start();
+ } else {
+ const KUrl url = item.url();
+ if (url.isValid() && !isEqualToShownUrl(url)) {
+ m_urlCandidate = item.url();
+ m_fileItem = item;
+ m_infoTimer->start();
+ }
}
}
void InfoSidebarPage::resizeEvent(QResizeEvent* event)
{
- if (m_initialized) {
+ if (isVisible()) {
// If the text inside the name label or the info label cannot
// get wrapped, then the maximum width of the label is increased
// so that the width of the information sidebar gets increased.
KIconLoader::NoGroup,
KIconLoader::SizeEnormous);
m_preview->setPixmap(icon);
- m_nameLabel->setText(i18ncp("@info", "%1 item selected", "%1 items selected", m_selection.count()));
+ setNameLabelText(i18ncp("@info", "%1 item selected", "%1 items selected", m_selection.count()));
+ m_shownUrl = KUrl();
} else {
const KFileItem item = fileItem();
const KUrl itemUrl = item.url();
m_preview->height(),
0,
0,
- true,
- false);
- job->setIgnoreMaximumSize(true);
+ false,
+ true);
connect(job, SIGNAL(gotPreview(const KFileItem&, const QPixmap&)),
this, SLOT(showPreview(const KFileItem&, const QPixmap&)));
connect(job, SIGNAL(failed(const KFileItem&)),
this, SLOT(showIcon(const KFileItem&)));
- m_nameLabel->setText(itemUrl.fileName());
+ setNameLabelText(itemUrl.fileName());
}
}
QModelIndex index = placesModel->index(i, 0);
if (url.equals(placesModel->url(index), KUrl::CompareWithoutTrailingSlash)) {
- m_nameLabel->setText(placesModel->text(index));
+ setNameLabelText(placesModel->text(index));
m_preview->setPixmap(placesModel->icon(index).pixmap(128, 128));
return true;
}
bool InfoSidebarPage::convertMetaInfo(const QString& key, QString& text) const
{
- // TODO: This code prevents that interesting meta information might be hidden
- // and only bypasses the current problem that not all the meta information should
- // be shown to the user. Check whether it's possible with Nepomuk to show
- // all "user relevant" information in a readable way...
-
struct MetaKey {
const char* key;
- const char* text;
+ QString text;
};
// sorted list of keys, where its data should be shown
static const MetaKey keys[] = {
- { "audio.album", "Album:" },
- { "audio.artist", "Artist:" },
- { "audio.title", "Title:" },
+ { "http://freedesktop.org/standards/xesam/1.0/core#album", i18nc("@label", "Album:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#artist", i18nc("@label", "Artist:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#genre", i18nc("@label", "Genre:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#height", i18nc("@label", "Height:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#lineCount", i18nc("@label", "Lines:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#title", i18nc("@label", "Title:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#type", i18nc("@label", "Type:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#trackNumber", i18nc("@label", "Track:") },
+ { "http://freedesktop.org/standards/xesam/1.0/core#width", i18nc("@label", "Width:") }
};
// do a binary search for the key...
return m_fileItem.isNull() && (m_selection.count() > 1);
}
+bool InfoSidebarPage::isEqualToShownUrl(const KUrl& url) const
+{
+ return m_shownUrl.equals(url, KUrl::CompareWithoutTrailingSlash);
+}
+
+void InfoSidebarPage::setNameLabelText(const QString& text)
+{
+ QTextOption textOption;
+ textOption.setWrapMode(QTextOption::WrapAtWordBoundaryOrAnywhere);
+
+ QTextLayout textLayout(text);
+ textLayout.setFont(m_nameLabel->font());
+ textLayout.setTextOption(textOption);
+
+ QString wrappedText;
+ wrappedText.reserve(text.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());
+
+ line = textLayout.createLine();
+ if (line.isValid()) {
+ wrappedText += QChar::LineSeparator;
+ }
+ }
+ textLayout.endLayout();
+
+ m_nameLabel->setText(wrappedText);
+}
+
void InfoSidebarPage::init()
{
const int spacing = KDialog::spacingHint();
font.setBold(true);
m_nameLabel->setFont(font);
m_nameLabel->setAlignment(Qt::AlignHCenter);
- m_nameLabel->setWordWrap(true);
m_nameLabel->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Fixed);
// preview