X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Fqtui%2Fsettingspages%2Fappearancesettingspage.cpp;h=0795e91197c6bb42af5d2f3bb30a568e4cc930cc;hb=e3314686ed9fe6203ed194ab4d73791176c2e051;hp=19d2d9c836d9f54042ffd3236d4fc46723166b0a;hpb=a8c38cbe8d8686cc36c42b04d556a3d51d37576d;p=quassel.git diff --git a/src/qtui/settingspages/appearancesettingspage.cpp b/src/qtui/settingspages/appearancesettingspage.cpp index 19d2d9c8..0795e911 100644 --- a/src/qtui/settingspages/appearancesettingspage.cpp +++ b/src/qtui/settingspages/appearancesettingspage.cpp @@ -39,6 +39,9 @@ AppearanceSettingsPage::AppearanceSettingsPage(QWidget *parent) #ifdef Q_WS_MAC ui.minimizeOnClose->hide(); #endif +#ifdef QT_NO_SYSTEMTRAYICON + ui.useSystemTrayIcon->hide(); +#endif initAutoWidgets(); initStyleComboBox(); @@ -75,19 +78,25 @@ void AppearanceSettingsPage::initStyleComboBox() { } void AppearanceSettingsPage::initLanguageComboBox() { - QDir i18nDir(Quassel::translationDirPath(), "quassel_*.qm"); + QDir i18nDir(Quassel::translationDirPath(), "*.qm"); + QRegExp rx("(qt_)?([a-zA-Z_]+)\\.qm"); foreach(QString translationFile, i18nDir.entryList()) { - QString localeName(translationFile.mid(8)); - localeName.chop(3); - QLocale locale(localeName); - _locales << locale; - ui.languageComboBox->addItem(QLocale::languageToString(locale.language())); + if(!rx.exactMatch(translationFile)) + continue; + if(!rx.cap(1).isEmpty()) + continue; + QLocale locale(rx.cap(2)); + _locales[QLocale::languageToString(locale.language())] = locale; + } + foreach(QString language, _locales.keys()) { + ui.languageComboBox->addItem(language); } } void AppearanceSettingsPage::defaults() { ui.styleComboBox->setCurrentIndex(0); + ui.languageComboBox->setCurrentIndex(1); SettingsPage::defaults(); widgetHasChanged(); @@ -108,9 +117,9 @@ void AppearanceSettingsPage::load() { // Language QLocale locale = uiSettings.value("Locale", QLocale::system()).value(); if(locale == QLocale::system()) - ui.languageComboBox->setCurrentIndex(0); - else if(locale.language() == QLocale::C) ui.languageComboBox->setCurrentIndex(1); + else if(locale.language() == QLocale::C) // we use C for "untranslated" + ui.languageComboBox->setCurrentIndex(0); else ui.languageComboBox->setCurrentIndex(ui.languageComboBox->findText(QLocale::languageToString(locale.language()), Qt::MatchExactly)); ui.languageComboBox->setProperty("storedValue", ui.languageComboBox->currentIndex()); @@ -146,12 +155,14 @@ void AppearanceSettingsPage::save() { uiSettings.setValue("Style", ui.styleComboBox->currentText()); QApplication::setStyle(ui.styleComboBox->currentText()); } + ui.styleComboBox->setProperty("storedValue", ui.styleComboBox->currentIndex()); - if(ui.languageComboBox->currentIndex() == 0) { + if(ui.languageComboBox->currentIndex() == 1) { uiSettings.remove("Locale"); // force the default (QLocale::system()) } else { uiSettings.setValue("Locale", selectedLocale()); } + ui.languageComboBox->setProperty("storedValue", ui.languageComboBox->currentIndex()); bool needsStyleReload = ui.useCustomStyleSheet->isChecked() != ui.useCustomStyleSheet->property("storedValue").toBool() @@ -194,12 +205,12 @@ void AppearanceSettingsPage::save() { QLocale AppearanceSettingsPage::selectedLocale() const { QLocale locale; int index = ui.languageComboBox->currentIndex(); - if(index == 0) + if(index == 1) locale = QLocale::system(); - else if(index == 1) + else if(index == 0) locale = QLocale::c(); else if(index > 1) - locale = _locales[index - 2]; + locale = _locales.values()[index - 2]; return locale; } @@ -222,8 +233,7 @@ void AppearanceSettingsPage::widgetHasChanged() { bool AppearanceSettingsPage::testHasChanged() { if(ui.styleComboBox->currentIndex() != ui.styleComboBox->property("storedValue").toInt()) return true; - - if(selectedLocale() != QLocale()) return true; // QLocale() returns the default locale (manipulated via loadTranslation()) + if(ui.languageComboBox->currentIndex() != ui.languageComboBox->property("storedValue").toInt()) return true; if(SettingsPage::hasChanged(ui.userNoticesInStatusBuffer)) return true; if(SettingsPage::hasChanged(ui.userNoticesInDefaultBuffer)) return true;