X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/69cb2c5db60909817f720fff2c2032b96fffc9e1..27a4b768714efb8a2b78f4fcb155e267cc1da05a:/src/panels/information/informationpanel.cpp diff --git a/src/panels/information/informationpanel.cpp b/src/panels/information/informationpanel.cpp index adf53348f..2b3124b3c 100644 --- a/src/panels/information/informationpanel.cpp +++ b/src/panels/information/informationpanel.cpp @@ -23,17 +23,16 @@ #include #include -#include -#include -#include -#include #include -#include #include +#include +#include +#include #include +#include +#include #include #include -#include #ifdef HAVE_NEPOMUK #include @@ -58,13 +57,23 @@ #include #include +#include "dolphin_informationpanelsettings.h" #include "settings/dolphinsettings.h" -#include "informationpaneldialog.h" #include "metadatawidget.h" #include "metatextlabel.h" #include "phononwidget.h" #include "pixmapviewer.h" +/** + * Helper function for sorting items with qSort() in + * InformationPanel::contextMenu(). + */ +bool lessThan(const QAction* action1, const QAction* action2) +{ + return action1->text() < action2->text(); +} + + InformationPanel::InformationPanel(QWidget* parent) : Panel(parent), m_initialized(false), @@ -80,8 +89,7 @@ InformationPanel::InformationPanel(QWidget* parent) : m_phononWidget(0), m_metaDataWidget(0), m_metaTextArea(0), - m_metaTextLabel(0), - m_dialog(0) + m_metaTextLabel(0) { } @@ -214,17 +222,100 @@ void InformationPanel::contextMenuEvent(QContextMenuEvent* event) { Panel::contextMenuEvent(event); +#ifdef HAVE_NEPOMUK + if (showMultipleSelectionInfo()) { + return; + } + KMenu popup(this); - popup.addAction(i18nc("@action:inmenu", "Configure...")); - if (popup.exec(QCursor::pos()) != 0) { - if (m_dialog == 0) { - m_dialog = new InformationPanelDialog(this); - m_dialog->setAttribute(Qt::WA_DeleteOnClose); - m_dialog->show(); - } else { - m_dialog->raise(); + + QAction* ratingAction = popup.addAction(i18nc("@action:inmenu", "Rating")); + ratingAction->setCheckable(true); + ratingAction->setChecked(InformationPanelSettings::showRating()); + + QAction* commentAction = popup.addAction(i18nc("@action:inmenu", "Comment")); + commentAction->setCheckable(true); + commentAction->setChecked(InformationPanelSettings::showComment()); + + QAction* tagsAction = popup.addAction(i18nc("@action:inmenu", "Tags")); + tagsAction->setCheckable(true); + tagsAction->setChecked(InformationPanelSettings::showTags()); + + KConfig config("kmetainformationrc", KConfig::NoGlobals); + KConfigGroup settings = config.group("Show"); + initMetaInfoSettings(settings); + + QList actions; + + // Get all meta information labels that are available for + // the currently shown file item and add them to the popup. + Nepomuk::Resource res(fileItem().url()); + QHash properties = res.properties(); + QHash::const_iterator it = properties.constBegin(); + while (it != properties.constEnd()) { + Nepomuk::Types::Property prop(it.key()); + const QString key = prop.label(); + + // Meta information provided by Nepomuk that is already + // available from KFileItem should not be configurable. + bool skip = (key == "fileExtension") || + (key == "name") || + (key == "sourceModified") || + (key == "size") || + (key == "mime type"); + if (!skip) { + // Check whether there is already a meta information + // having the same label. In this case don't show it + // twice in the menu. + foreach (const QAction* action, actions) { + if (action->data().toString() == key) { + skip = true; + break; + } + } + } + + if (!skip) { + const QString label = key; // TODO + QAction* action = new QAction(label, &popup); + action->setCheckable(true); + action->setChecked(settings.readEntry(key, true)); + action->setData(key); + actions.append(action); + } + + ++it; + } + + if (actions.count() > 0) { + popup.addSeparator(); + + // add all items alphabetically sorted to the popup + qSort(actions.begin(), actions.end(), lessThan); + foreach (QAction* action, actions) { + popup.addAction(action); } } + + // Open the popup and adjust the settings for the + // selected action. + QAction* action = popup.exec(QCursor::pos()); + if (action == 0) { + return; + } + + if (action == ratingAction) { + // TODO + } else if (action == commentAction) { + // TODO + } else if (action == tagsAction) { + // TODO + } else { + settings.writeEntry(action->data().toString(), action->isChecked()); + settings.sync(); + showMetaInfo(); + } +#endif } void InformationPanel::showItemInfo() @@ -447,15 +538,22 @@ void InformationPanel::showMetaInfo() m_metaTextLabel->add(i18nc("@label", "Modified:"), item.timeString()); #ifdef HAVE_NEPOMUK + KConfig config("kmetainformationrc", KConfig::NoGlobals); + KConfigGroup settings = config.group("Show"); + initMetaInfoSettings(settings); + Nepomuk::Resource res(item.url()); QHash properties = res.properties(); QHash::const_iterator it = properties.constBegin(); while (it != properties.constEnd()) { Nepomuk::Types::Property prop(it.key()); - // TODO: use Nepomuk::formatValue(res, prop) if available - // instead of it.value().toString() - m_metaTextLabel->add(prop.label(), it.value().toString()); + const QString label = prop.label(); + if (settings.readEntry(label, true)) { + // TODO: use Nepomuk::formatValue(res, prop) if available + // instead of it.value().toString() + m_metaTextLabel->add(label, it.value().toString()); + } ++it; } #endif @@ -546,6 +644,25 @@ void InformationPanel::reset() showItemInfo(); } +void InformationPanel::initMetaInfoSettings(KConfigGroup& group) +{ + if (!group.readEntry("initialized", false)) { + // The resource file is read the first time. Assure + // that some meta information is disabled per default. + group.writeEntry("fileExtension", false); + group.writeEntry("url", false); + group.writeEntry("sourceModified", false); + group.writeEntry("parentUrl", false); + group.writeEntry("size", false); + group.writeEntry("mime type", false); + group.writeEntry("depth", false); + group.writeEntry("name", false); + + // mark the group as initialized + group.writeEntry("initialized", true); + } +} + void InformationPanel::init() { const int spacing = KDialog::spacingHint();