#include "dolphin_generalsettings.h"
#include "viewproperties.h"
-#ifdef HAVE_NEPOMUK
#include <config-nepomuk.h>
+#ifdef HAVE_NEPOMUK
#include <nepomuk/resourcemanager.h>
#endif
m_viewMode->addItem(KIcon("fileview-icon"), i18nc("@item:inlistbox", "Icons"));
m_viewMode->addItem(KIcon("fileview-detailed"), i18nc("@item:inlistbox", "Details"));
m_viewMode->addItem(KIcon("fileview-column"), i18nc("@item:inlistbox", "Column"));
- const int index = static_cast<int>(m_viewProps->viewMode());
- m_viewMode->setCurrentIndex(index);
- const bool iconsViewEnabled = (index == DolphinView::IconsView);
QLabel* sortingLabel = new QLabel(i18nc("@label:listbox", "Sorting:"), propsBox);
QWidget* sortingBox = new QWidget(propsBox);
m_sortOrder = new QComboBox(sortingBox);
m_sortOrder->addItem(i18nc("@item:inlistbox", "Ascending"));
m_sortOrder->addItem(i18nc("@item:inlistbox", "Descending"));
- const int sortOrderIndex = (m_viewProps->sortOrder() == Qt::AscendingOrder) ? 0 : 1;
- m_sortOrder->setCurrentIndex(sortOrderIndex);
m_sorting = new QComboBox(sortingBox);
m_sorting->addItem(i18nc("@item:inlistbox Sort", "By Name"));
m_sorting->addItem(i18nc("@item:inlistbox Sort", "By Tags"));
}
#endif
- m_sorting->setCurrentIndex(m_viewProps->sorting());
QHBoxLayout* sortingLayout = new QHBoxLayout();
sortingLayout->setMargin(0);
QLabel* additionalInfoLabel = new QLabel(i18nc("@label:listbox", "Additional information:"), propsBox);
m_additionalInfo = new QComboBox(propsBox);
- m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info", "No Information"),
- KFileItemDelegate::NoInformation);
- m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info", "Type"),
- KFileItemDelegate::FriendlyMimeType);
- m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info", "Size"),
- KFileItemDelegate::Size);
- m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info", "Date"),
- KFileItemDelegate::ModificationTime);
- const int addInfoIndex = m_additionalInfo->findData(m_viewProps->additionalInfo());
- m_additionalInfo->setCurrentIndex(addInfoIndex);
- m_additionalInfo->setEnabled(iconsViewEnabled);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "No Information"), NoInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Type"), TypeInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Size"), SizeInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Date"), DateInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Type, Size"), TypeInfo | SizeInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Type, Date"), TypeInfo | DateInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Size, Date"), SizeInfo | DateInfo);
+ m_additionalInfo->addItem(i18nc("@item:inlistbox Additional info",
+ "Type, Size, Date"),TypeInfo | SizeInfo | DateInfo);
m_showPreview = new QCheckBox(i18nc("@option:check", "Show preview"), propsBox);
- m_showPreview->setChecked(m_viewProps->showPreview());
-
m_showInGroups = new QCheckBox(i18nc("@option:check", "Show in Groups"), propsBox);
- m_showInGroups->setChecked(m_viewProps->categorizedSorting());
-
m_showHiddenFiles = new QCheckBox(i18nc("@option:check", "Show hidden files"), propsBox);
- m_showHiddenFiles->setChecked(m_viewProps->showHiddenFiles());
QGridLayout* propsBoxLayout = new QGridLayout(propsBox);
propsBoxLayout->addWidget(viewModeLabel, 0, 0);
const KConfigGroup dialogConfig(KSharedConfig::openConfig("dolphinrc"),
"ViewPropertiesDialog");
restoreDialogSize(dialogConfig);
+
+ loadSettings();
}
ViewPropertiesDialog::~ViewPropertiesDialog()
KConfigGroup dialogConfig(KSharedConfig::openConfig("dolphinrc"),
"ViewPropertiesDialog");
- saveDialogSize(dialogConfig, KConfigFlags::Persistent);
+ saveDialogSize(dialogConfig, KConfigBase::Persistent);
}
void ViewPropertiesDialog::slotOk()
const bool iconsViewEnabled = (m_viewProps->viewMode() == DolphinView::IconsView);
m_showInGroups->setEnabled(iconsViewEnabled);
- m_additionalInfo->setEnabled(iconsViewEnabled);
+
+ // TODO: a different approach is required now due to having a lot more additional infos
+ m_additionalInfo->setEnabled(false);
+ //m_additionalInfo->setEnabled(iconsViewEnabled);
}
void ViewPropertiesDialog::slotSortingChanged(int index)
void ViewPropertiesDialog::slotAdditionalInfoChanged(int index)
{
- KFileItemDelegate::AdditionalInformation info = KFileItemDelegate::NoInformation;
- switch (index) {
- case 1: info = KFileItemDelegate::FriendlyMimeType; break;
- case 2: info = KFileItemDelegate::Size; break;
- case 3: info = KFileItemDelegate::ModificationTime; break;
- default: break;
+ const int info = m_additionalInfo->itemData(index).toInt();
+
+ KFileItemDelegate::InformationList list;
+ if (info & TypeInfo) {
+ list.append(KFileItemDelegate::FriendlyMimeType);
+ }
+ if (info & SizeInfo) {
+ list.append(KFileItemDelegate::Size);
+ }
+ if (info & DateInfo) {
+ list.append(KFileItemDelegate::ModificationTime);
}
- m_viewProps->setAdditionalInfo(info);
+
+ m_viewProps->setAdditionalInfo(list);
m_isDirty = true;
}
}
}
+void ViewPropertiesDialog::loadSettings()
+{
+ // load view mode
+ const int index = static_cast<int>(m_viewProps->viewMode());
+ m_viewMode->setCurrentIndex(index);
+ const bool iconsViewEnabled = (index == DolphinView::IconsView);
+
+ // load sort order and sorting
+ const int sortOrderIndex = (m_viewProps->sortOrder() == Qt::AscendingOrder) ? 0 : 1;
+ m_sortOrder->setCurrentIndex(sortOrderIndex);
+ m_sorting->setCurrentIndex(m_viewProps->sorting());
+
+ // load additional info
+ const KFileItemDelegate::InformationList list = m_viewProps->additionalInfo();
+ int info = NoInfo;
+ foreach (KFileItemDelegate::Information currentInfo, list) {
+ switch (currentInfo) {
+ case KFileItemDelegate::FriendlyMimeType:
+ info = info | TypeInfo;
+ break;
+ case KFileItemDelegate::Size:
+ info = info | SizeInfo;
+ break;
+ case KFileItemDelegate::ModificationTime:
+ info = info | DateInfo;
+ break;
+ default:
+ break;
+ }
+ }
+
+ const int addInfoIndex = m_additionalInfo->findData(info);
+ m_additionalInfo->setCurrentIndex(addInfoIndex);
+ // TODO: a different approach is required now due to having a lot more additional infos
+ m_additionalInfo->setEnabled(false);
+ //m_additionalInfo->setEnabled(iconsViewEnabled);
+
+ // load show preview, show in groups and show hidden files settings
+ m_showPreview->setChecked(m_viewProps->showPreview());
+
+ m_showInGroups->setChecked(m_viewProps->categorizedSorting());
+ m_showInGroups->setEnabled(iconsViewEnabled); // only the icons view supports categorized sorting
+
+ m_showHiddenFiles->setChecked(m_viewProps->showHiddenFiles());
+}
+
#include "viewpropertiesdialog.moc"