diff options
author | Lubomir I. Ivanov <neolit123@gmail.com> | 2017-11-10 16:52:12 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2017-11-10 09:21:47 -0800 |
commit | 2c06cb027f20eee42769fb3a56e41c87b1a4d252 (patch) | |
tree | f10ca05b6a01ebfb020c53ae740efc1e01a0a7af /desktop-widgets/preferences | |
parent | f1437cfec7978929a09ff7b1f5ad3a013dd0c713 (diff) | |
download | subsurface-2c06cb027f20eee42769fb3a56e41c87b1a4d252.tar.gz |
preferences: support a pre-defined list of date formats
Add a combo-box in place of the single line text field and
support some pre-defined date formats, such as:
MM/dd/yyyy
Each long format has a corresponding short variant stored in the
QMap dateFormatShortMap and it's updated automatically once
the user selects a combo box item for the long format.
The regex for dates is slighly modified:
[^dMy/\\s:;\\.,\\-]
The user is still allowed to enter custom long / short date foramats.
Fixes #276
Signed-off-by: Lubomir I. Ivanov <neolit123@gmail.com>
Diffstat (limited to 'desktop-widgets/preferences')
-rw-r--r-- | desktop-widgets/preferences/preferences_language.cpp | 21 | ||||
-rw-r--r-- | desktop-widgets/preferences/preferences_language.h | 4 | ||||
-rw-r--r-- | desktop-widgets/preferences/prefs_language.ui | 47 |
3 files changed, 46 insertions, 26 deletions
diff --git a/desktop-widgets/preferences/preferences_language.cpp b/desktop-widgets/preferences/preferences_language.cpp index ff0429721..4d200d82f 100644 --- a/desktop-widgets/preferences/preferences_language.cpp +++ b/desktop-widgets/preferences/preferences_language.cpp @@ -22,6 +22,14 @@ PreferencesLanguage::PreferencesLanguage() : AbstractPreferencesWidget(tr("Langu filterModel->sort(0); connect(ui->languageFilter, &QLineEdit::textChanged, filterModel, &QSortFilterProxyModel::setFilterFixedString); + + dateFormatShortMap.insert("MM/dd/yyyy", "M/d/yy"); + dateFormatShortMap.insert("dd.MM.yyyy", "d.M.yy"); + dateFormatShortMap.insert("yyyy-MM-dd", "yy-M-d"); + foreach (QString format, dateFormatShortMap.keys()) + ui->dateFormatEntry->addItem(format); + connect(ui->dateFormatEntry, SIGNAL(currentIndexChanged(const QString&)), + this, SLOT(dateFormatChanged(const QString&))); } PreferencesLanguage::~PreferencesLanguage() @@ -29,13 +37,18 @@ PreferencesLanguage::~PreferencesLanguage() delete ui; } +void PreferencesLanguage::dateFormatChanged(const QString &text) +{ + ui->shortDateFormatEntry->setText(dateFormatShortMap.value(text)); +} + void PreferencesLanguage::refreshSettings() { ui->languageSystemDefault->setChecked(prefs.locale.use_system_language); ui->timeFormatSystemDefault->setChecked(!prefs.time_format_override); ui->dateFormatSystemDefault->setChecked(!prefs.date_format_override); ui->timeFormatEntry->setText(prefs.time_format); - ui->dateFormatEntry->setText(prefs.date_format); + ui->dateFormatEntry->setCurrentText(prefs.date_format); ui->shortDateFormatEntry->setText(prefs.date_format_short); QAbstractItemModel *m = ui->languageDropdown->model(); QModelIndexList languages = m->match(m->index(0, 0), Qt::UserRole, QString(prefs.locale.lang_locale).replace("-", "_")); @@ -72,7 +85,7 @@ void PreferencesLanguage::syncSettings() lang->setTimeFormatOverride(!ui->timeFormatSystemDefault->isChecked()); lang->setDateFormatOverride(!ui->dateFormatSystemDefault->isChecked()); lang->setTimeFormat(ui->timeFormatEntry->text()); - lang->setDateFormat(ui->dateFormatEntry->text()); + lang->setDateFormat(ui->dateFormatEntry->currentText()); lang->setDateFormatShort(ui->shortDateFormatEntry->text()); uiLanguage(NULL); @@ -81,8 +94,8 @@ void PreferencesLanguage::syncSettings() QMessageBox::warning(this, tr("Literal characters"), tr("Non-special character(s) in time format.\nThese will be used as is. This might not be what you intended.\nSee http://doc.qt.io/qt-5/qdatetime.html#toString")); - QRegExp dfillegalchars("[^dMy/\\s:;\\.,]"); - if (dfillegalchars.indexIn(ui->dateFormatEntry->text()) >= 0 || + QRegExp dfillegalchars("[^dMy/\\s:;\\.,\\-]"); + if (dfillegalchars.indexIn(ui->dateFormatEntry->currentText()) >= 0 || dfillegalchars.indexIn(ui->shortDateFormatEntry->text()) >= 0) QMessageBox::warning(this, tr("Literal characters"), tr("Non-special character(s) in time format.\nThese will be used as is. This might not be what you intended.\nSee http://doc.qt.io/qt-5/qdatetime.html#toString")); diff --git a/desktop-widgets/preferences/preferences_language.h b/desktop-widgets/preferences/preferences_language.h index aaff67eed..4ff268b87 100644 --- a/desktop-widgets/preferences/preferences_language.h +++ b/desktop-widgets/preferences/preferences_language.h @@ -2,6 +2,7 @@ #ifndef PREFERENCES_LANGUAGE_H #define PREFERENCES_LANGUAGE_H +#include <QMap> #include "abstractpreferenceswidget.h" namespace Ui { @@ -17,6 +18,9 @@ public: virtual void syncSettings(); private: Ui::PreferencesLanguage *ui; + QMap<QString, QString> dateFormatShortMap; +public slots: + void dateFormatChanged(const QString&); }; #endif diff --git a/desktop-widgets/preferences/prefs_language.ui b/desktop-widgets/preferences/prefs_language.ui index af3a0ad87..470e8b6d1 100644 --- a/desktop-widgets/preferences/prefs_language.ui +++ b/desktop-widgets/preferences/prefs_language.ui @@ -74,13 +74,6 @@ <string>Date format</string> </property> <layout class="QGridLayout" name="gridLayout"> - <item row="0" column="1"> - <widget class="QLineEdit" name="dateFormatEntry"> - <property name="toolTip"> - <string><html><head/><body><p>Preferred date format. Commonly used fields are</p><p>d (day of month)</p><p>ddd (abbr. day name)</p><p>M (month number)</p><p>MMM (abbr. month name)</p><p>yy/yyyy (2/4 digit year)</p></body></html></string> - </property> - </widget> - </item> <item row="0" column="0"> <widget class="QCheckBox" name="dateFormatSystemDefault"> <property name="text"> @@ -114,6 +107,16 @@ </property> </spacer> </item> + <item row="0" column="1"> + <widget class="QComboBox" name="dateFormatEntry"> + <property name="toolTip"> + <string><html><head/><body><p>Preferred date format. Commonly used fields are</p><p>d (day of month)</p><p>ddd (abbr. day name)</p><p>M (month number)</p><p>MMM (abbr. month name)</p><p>yy/yyyy (2/4 digit year)</p></body></html></string> + </property> + <property name="editable"> + <bool>true</bool> + </property> + </widget> + </item> </layout> </widget> </item> @@ -209,50 +212,50 @@ </hints> </connection> <connection> - <sender>dateFormatSystemDefault</sender> + <sender>timeFormatSystemDefault</sender> <signal>toggled(bool)</signal> - <receiver>dateFormatEntry</receiver> + <receiver>timeFormatEntry</receiver> <slot>setDisabled(bool)</slot> <hints> <hint type="sourcelabel"> <x>79</x> - <y>132</y> + <y>210</y> </hint> <hint type="destinationlabel"> <x>264</x> - <y>132</y> + <y>210</y> </hint> </hints> </connection> <connection> - <sender>timeFormatSystemDefault</sender> + <sender>dateFormatSystemDefault</sender> <signal>toggled(bool)</signal> - <receiver>timeFormatEntry</receiver> + <receiver>shortDateFormatEntry</receiver> <slot>setDisabled(bool)</slot> <hints> <hint type="sourcelabel"> - <x>79</x> - <y>210</y> + <x>99</x> + <y>132</y> </hint> <hint type="destinationlabel"> - <x>264</x> - <y>210</y> + <x>293</x> + <y>169</y> </hint> </hints> </connection> <connection> <sender>dateFormatSystemDefault</sender> <signal>toggled(bool)</signal> - <receiver>shortDateFormatEntry</receiver> + <receiver>dateFormatEntry</receiver> <slot>setDisabled(bool)</slot> <hints> <hint type="sourcelabel"> - <x>99</x> - <y>132</y> + <x>89</x> + <y>103</y> </hint> <hint type="destinationlabel"> - <x>293</x> - <y>169</y> + <x>273</x> + <y>103</y> </hint> </hints> </connection> |