]> cloud.milkyroute.net Git - dolphin.git/commitdiff
General settings: Use radiobuttons instead of a combo-box
authorPeter Penz <peter.penz19@gmail.com>
Sun, 15 Apr 2012 18:58:03 +0000 (20:58 +0200)
committerPeter Penz <peter.penz19@gmail.com>
Sun, 15 Apr 2012 18:59:37 +0000 (20:59 +0200)
Revert the change to use a combo-box, it results to clipped texts
with some languages.

src/settings/general/behaviorsettingspage.cpp
src/settings/general/behaviorsettingspage.h

index 57ff601461961cdc35c9a14159b9cd3c08671ada..1ade93c8e605d90b46bb792ef38bf0a510f85dd9 100644 (file)
@@ -38,7 +38,8 @@
 BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) :
     SettingsPageBase(parent),
     m_url(url),
-    m_viewProps(0),
+    m_localViewProps(0),
+    m_globalViewProps(0),
     m_showToolTips(0),
     m_showSelectionToggle(0),
     m_naturalSorting(0)
@@ -46,16 +47,15 @@ BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) :
     QVBoxLayout* topLayout = new QVBoxLayout(this);
 
     // View properties
-    QLabel* viewPropsLabel = new QLabel(i18nc("@label", "View properties:"), this);
+    QGroupBox* viewPropsBox = new QGroupBox(i18nc("@title:group", "View"), this);
+    viewPropsBox->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Maximum);
 
-    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);
+    m_localViewProps = new QRadioButton(i18nc("@option:radio", "Remember properties for each folder"), viewPropsBox);
+    m_globalViewProps = new QRadioButton(i18nc("@option:radio", "Use common properties for all folders"), viewPropsBox);
 
-    QHBoxLayout* viewPropsLayout = new QHBoxLayout(this);
-    viewPropsLayout->addWidget(viewPropsLabel, 0, Qt::AlignRight);
-    viewPropsLayout->addWidget(m_viewProps);
+    QVBoxLayout* viewPropsLayout = new QVBoxLayout(viewPropsBox);
+    viewPropsLayout->addWidget(m_localViewProps);
+    viewPropsLayout->addWidget(m_globalViewProps);
 
     // 'Show tooltips'
     m_showToolTips = new QCheckBox(i18nc("@option:check", "Show tooltips"), this);
@@ -66,9 +66,7 @@ BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) :
     // 'Natural sorting of items'
     m_naturalSorting = new QCheckBox(i18nc("option:check", "Natural sorting of items"), this);
 
-    topLayout->addSpacing(KDialog::spacingHint());
-    topLayout->addLayout(viewPropsLayout);
-    topLayout->addSpacing(KDialog::spacingHint());
+    topLayout->addWidget(viewPropsBox);
     topLayout->addWidget(m_showToolTips);
     topLayout->addWidget(m_showSelectionToggle);
     topLayout->addWidget(m_naturalSorting);
@@ -76,7 +74,8 @@ BehaviorSettingsPage::BehaviorSettingsPage(const KUrl& url, QWidget* parent) :
 
     loadSettings();
 
-    connect(m_viewProps, SIGNAL(currentIndexChanged(int)), this, SIGNAL(changed()));
+    connect(m_localViewProps, SIGNAL(toggled(bool)), this, SIGNAL(changed()));
+    connect(m_globalViewProps, SIGNAL(toggled(bool)), 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()));
@@ -91,15 +90,14 @@ void BehaviorSettingsPage::applySettings()
     GeneralSettings* settings = GeneralSettings::self();
     ViewProperties props(m_url);  // read current view properties
 
-    const int index = m_viewProps->currentIndex();
-    const bool useGlobalProps = m_viewProps->itemData(index).toBool();
-    settings->setGlobalViewProps(useGlobalProps);
+    const bool useGlobalViewProps = m_globalViewProps->isChecked();
+    settings->setGlobalViewProps(useGlobalViewProps);
 
     settings->setShowToolTips(m_showToolTips->isChecked());
     settings->setShowSelectionToggle(m_showSelectionToggle->isChecked());
     settings->writeConfig();
 
-    if (useGlobalProps) {
+    if (useGlobalViewProps) {
         // Remember the global view properties by applying the current view properties.
         // It is important that GeneralSettings::globalViewProps() is set before
         // the class ViewProperties is used, as ViewProperties uses this setting
@@ -126,8 +124,9 @@ void BehaviorSettingsPage::restoreDefaults()
 
 void BehaviorSettingsPage::loadSettings()
 {
-    const int index = (m_viewProps->itemData(0).toBool() == GeneralSettings::globalViewProps()) ? 0 : 1;
-    m_viewProps->setCurrentIndex(index);
+    const bool useGlobalViewProps = GeneralSettings::globalViewProps();
+    m_localViewProps->setChecked(!useGlobalViewProps);
+    m_globalViewProps->setChecked(useGlobalViewProps);
 
     m_showToolTips->setChecked(GeneralSettings::showToolTips());
     m_showSelectionToggle->setChecked(GeneralSettings::showSelectionToggle());
index f1e49ef6852f9b8cee23196f7427f91f8a3b238c..3989862626c6a40caaa424f0a05ef3243214f361 100644 (file)
@@ -51,7 +51,8 @@ private:
 private:
     KUrl m_url;
 
-    KComboBox* m_viewProps;
+    QRadioButton* m_localViewProps;
+    QRadioButton* m_globalViewProps;
 
     QCheckBox* m_showToolTips;
     QLabel* m_configureToolTips;