diff options
| author | Peter Penz <[email protected]> | 2012-04-08 23:15:32 +0200 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2012-04-08 23:18:20 +0200 |
| commit | e0ac8b61fb907ac19f9bebf01cb5be17d4c88ba8 (patch) | |
| tree | 3774c1753847d346879590c9339d9459e2e8863c /src/settings/general/behaviorsettingspage.cpp | |
| parent | 05082aed16cdf7e511d9c97d0cf07e270af493e5 (diff) | |
Layout improvements for settings
- Handle 'Context Menu' settings as part of the services
- Handle 'Version Control' settings as part of the services
- Move the confirmations-settings into own tab
- Use combobox for view-property settings
- A lot of minor spacing cleanups
Diffstat (limited to 'src/settings/general/behaviorsettingspage.cpp')
| -rw-r--r-- | src/settings/general/behaviorsettingspage.cpp | 89 |
1 files changed, 24 insertions, 65 deletions
diff --git a/src/settings/general/behaviorsettingspage.cpp b/src/settings/general/behaviorsettingspage.cpp index 4ed98e5d7..57ff60146 100644 --- a/src/settings/general/behaviorsettingspage.cpp +++ b/src/settings/general/behaviorsettingspage.cpp @@ -22,6 +22,7 @@ #include "dolphin_generalsettings.h" +#include <KComboBox> #include <KDialog> #include <KLocale> @@ -34,48 +35,27 @@ #include <views/viewproperties.h> -const bool CONFIRM_TRASH = false; -const bool CONFIRM_DELETE = true; - BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) : SettingsPageBase(parent), m_url(url), - m_localProps(0), - m_globalProps(0), - m_confirmMoveToTrash(0), - m_confirmDelete(0), + m_viewProps(0), m_showToolTips(0), m_showSelectionToggle(0), m_naturalSorting(0) { QVBoxLayout* topLayout = new QVBoxLayout(this); - // 'View Properties' box - QGroupBox* propsBox = new QGroupBox(i18nc("@title:group", "View Properties"), this); - propsBox->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Maximum); - - m_localProps = new QRadioButton(i18nc("@option:radio", "Remember view properties for each folder"), propsBox); - - m_globalProps = new QRadioButton(i18nc("@option:radio", "Use common view properties for all folders"), propsBox); + // View properties + QLabel* viewPropsLabel = new QLabel(i18nc("@label", "View properties:"), this); - QVBoxLayout* propsBoxLayout = new QVBoxLayout(propsBox); - propsBoxLayout->addWidget(m_localProps); - propsBoxLayout->addWidget(m_globalProps); + m_viewProps = new KComboBox(this); + const bool useGlobalProps = true; + m_viewProps->addItem(i18nc("@option:radio", "Remember view properties for each folder"), !useGlobalProps); + m_viewProps->addItem(i18nc("@option:radio", "Use common view properties for all folders"), useGlobalProps); - // 'Ask Confirmation For' box - QGroupBox* confirmBox = new QGroupBox(i18nc("@title:group", "Ask For Confirmation When"), this); - confirmBox->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Maximum); - m_confirmMoveToTrash = new QCheckBox(i18nc("@option:check Ask for Confirmation When", - "Moving files or folders to trash"), confirmBox); - m_confirmDelete = new QCheckBox(i18nc("@option:check Ask for Confirmation When", - "Deleting files or folders"), confirmBox); - m_confirmClosingMultipleTabs = new QCheckBox(i18nc("@option:check Ask for Confirmation When", - "Closing windows with multiple tabs"), confirmBox); - - QVBoxLayout* confirmBoxLayout = new QVBoxLayout(confirmBox); - confirmBoxLayout->addWidget(m_confirmMoveToTrash); - confirmBoxLayout->addWidget(m_confirmDelete); - confirmBoxLayout->addWidget(m_confirmClosingMultipleTabs); + QHBoxLayout* viewPropsLayout = new QHBoxLayout(this); + viewPropsLayout->addWidget(viewPropsLabel, 0, Qt::AlignRight); + viewPropsLayout->addWidget(m_viewProps); // 'Show tooltips' m_showToolTips = new QCheckBox(i18nc("@option:check", "Show tooltips"), this); @@ -86,8 +66,9 @@ BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) : // 'Natural sorting of items' m_naturalSorting = new QCheckBox(i18nc("option:check", "Natural sorting of items"), this); - topLayout->addWidget(propsBox); - topLayout->addWidget(confirmBox); + topLayout->addSpacing(KDialog::spacingHint()); + topLayout->addLayout(viewPropsLayout); + topLayout->addSpacing(KDialog::spacingHint()); topLayout->addWidget(m_showToolTips); topLayout->addWidget(m_showSelectionToggle); topLayout->addWidget(m_naturalSorting); @@ -95,11 +76,7 @@ BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) : loadSettings(); - connect(m_localProps, SIGNAL(toggled(bool)), this, SIGNAL(changed())); - connect(m_globalProps, SIGNAL(toggled(bool)), this, SIGNAL(changed())); - connect(m_confirmMoveToTrash, SIGNAL(toggled(bool)), this, SIGNAL(changed())); - connect(m_confirmDelete, SIGNAL(toggled(bool)), this, SIGNAL(changed())); - connect(m_confirmClosingMultipleTabs, SIGNAL(toggled(bool)), this, SIGNAL(changed())); + connect(m_viewProps, SIGNAL(currentIndexChanged(int)), this, SIGNAL(changed())); connect(m_showToolTips, SIGNAL(toggled(bool)), this, SIGNAL(changed())); connect(m_showSelectionToggle, SIGNAL(toggled(bool)), this, SIGNAL(changed())); connect(m_naturalSorting, SIGNAL(toggled(bool)), this, SIGNAL(changed())); @@ -111,13 +88,17 @@ BehaviorSettingsPage::~BehaviorSettingsPage() void BehaviorSettingsPage::applySettings() { + GeneralSettings* settings = GeneralSettings::self(); ViewProperties props(m_url); // read current view properties - const bool useGlobalProps = m_globalProps->isChecked(); - - GeneralSettings* settings = GeneralSettings::self(); + const int index = m_viewProps->currentIndex(); + const bool useGlobalProps = m_viewProps->itemData(index).toBool(); settings->setGlobalViewProps(useGlobalProps); + settings->setShowToolTips(m_showToolTips->isChecked()); + settings->setShowSelectionToggle(m_showSelectionToggle->isChecked()); + settings->writeConfig(); + if (useGlobalProps) { // Remember the global view properties by applying the current view properties. // It is important that GeneralSettings::globalViewProps() is set before @@ -127,17 +108,6 @@ void BehaviorSettingsPage::applySettings() globalProps.setDirProperties(props); } - KSharedConfig::Ptr kioConfig = KSharedConfig::openConfig("kiorc", KConfig::NoGlobals); - KConfigGroup confirmationGroup(kioConfig, "Confirmations"); - confirmationGroup.writeEntry("ConfirmTrash", m_confirmMoveToTrash->isChecked()); - confirmationGroup.writeEntry("ConfirmDelete", m_confirmDelete->isChecked()); - confirmationGroup.sync(); - - settings->setConfirmClosingMultipleTabs(m_confirmClosingMultipleTabs->isChecked()); - settings->setShowToolTips(m_showToolTips->isChecked()); - settings->setShowSelectionToggle(m_showSelectionToggle->isChecked()); - settings->writeConfig(); - const bool naturalSorting = m_naturalSorting->isChecked(); if (KGlobalSettings::naturalSorting() != naturalSorting) { KConfigGroup group(KGlobal::config(), "KDE"); @@ -152,24 +122,13 @@ void BehaviorSettingsPage::restoreDefaults() settings->useDefaults(true); loadSettings(); settings->useDefaults(false); - m_confirmMoveToTrash->setChecked(CONFIRM_TRASH); - m_confirmDelete->setChecked(CONFIRM_DELETE); } void BehaviorSettingsPage::loadSettings() { - if (GeneralSettings::globalViewProps()) { - m_globalProps->setChecked(true); - } else { - m_localProps->setChecked(true); - } - - KSharedConfig::Ptr kioConfig = KSharedConfig::openConfig("kiorc", KConfig::IncludeGlobals); - const KConfigGroup confirmationGroup(kioConfig, "Confirmations"); - m_confirmMoveToTrash->setChecked(confirmationGroup.readEntry("ConfirmTrash", CONFIRM_TRASH)); - m_confirmDelete->setChecked(confirmationGroup.readEntry("ConfirmDelete", CONFIRM_DELETE)); + const int index = (m_viewProps->itemData(0).toBool() == GeneralSettings::globalViewProps()) ? 0 : 1; + m_viewProps->setCurrentIndex(index); - m_confirmClosingMultipleTabs->setChecked(GeneralSettings::confirmClosingMultipleTabs()); m_showToolTips->setChecked(GeneralSettings::showToolTips()); m_showSelectionToggle->setChecked(GeneralSettings::showSelectionToggle()); m_naturalSorting->setChecked(KGlobalSettings::naturalSorting()); |
