X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fsettingspages%2Fappearancesettingspage.cpp;h=7c4551dcc6ed258ca9d34323e84cc9379f8fdb7d;hb=16f8531e383eade0a75a3b74ea11b909b8b1e049;hp=1104bc34b8cd5d754308fd832999b16be7719988;hpb=335c0c0196da3ef371662b3c754f0516991906f4;p=quassel.git diff --git a/src/qtui/settingspages/appearancesettingspage.cpp b/src/qtui/settingspages/appearancesettingspage.cpp index 1104bc34..7c4551dc 100644 --- a/src/qtui/settingspages/appearancesettingspage.cpp +++ b/src/qtui/settingspages/appearancesettingspage.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -20,6 +20,8 @@ #include "appearancesettingspage.h" +#include "buffersettings.h" +#include "chatviewsettings.h" #include "qtui.h" #include "qtuisettings.h" #include "util.h" @@ -33,8 +35,12 @@ AppearanceSettingsPage::AppearanceSettingsPage(QWidget *parent) initStyleComboBox(); initLanguageComboBox(); - connect(ui.styleComboBox, SIGNAL(currentIndexChanged(QString)), this, SLOT(widgetHasChanged())); - connect(ui.languageComboBox, SIGNAL(currentIndexChanged(QString)), this, SLOT(widgetHasChanged())); + foreach(QComboBox *comboBox, findChildren()) { + connect(comboBox, SIGNAL(currentIndexChanged(QString)), this, SLOT(widgetHasChanged())); + } + foreach(QCheckBox *checkBox, findChildren()) { + connect(checkBox, SIGNAL(clicked()), this, SLOT(widgetHasChanged())); + } } void AppearanceSettingsPage::initStyleComboBox() { @@ -67,6 +73,7 @@ void AppearanceSettingsPage::defaults() { void AppearanceSettingsPage::load() { QtUiSettings uiSettings; + // Gui Style settings["Style"] = uiSettings.value("Style", QString("")); if(settings["Style"].toString() == "") { ui.styleComboBox->setCurrentIndex(0); @@ -75,6 +82,7 @@ void AppearanceSettingsPage::load() { QApplication::setStyle(settings["Style"].toString()); } + // Language QLocale locale = uiSettings.value("Locale", QLocale::system()).value(); if(locale == QLocale::system()) ui.languageComboBox->setCurrentIndex(0); @@ -84,6 +92,12 @@ void AppearanceSettingsPage::load() { ui.languageComboBox->setCurrentIndex(ui.languageComboBox->findText(QLocale::languageToString(locale.language()), Qt::MatchExactly)); loadTranslation(selectedLocale()); + ChatViewSettings chatViewSettings; + SettingsPage::load(ui.showWebPreview, chatViewSettings.showWebPreview()); + + BufferSettings bufferSettings; + SettingsPage::load(ui.showUserStateIcons, bufferSettings.showUserStateIcons()); + setChangedState(false); } @@ -102,6 +116,12 @@ void AppearanceSettingsPage::save() { uiSettings.setValue("Locale", selectedLocale()); } + ChatViewSettings chatViewSettings; + chatViewSettings.enableWebPreview(ui.showWebPreview->isChecked()); + + BufferSettings bufferSettings; + bufferSettings.enableUserStateIcons(ui.showUserStateIcons->isChecked()); + load(); setChangedState(false); } @@ -127,6 +147,9 @@ bool AppearanceSettingsPage::testHasChanged() { if(settings["Style"].toString() != ui.styleComboBox->currentText()) return true; if(selectedLocale() != QLocale()) return true; // QLocale() returns the default locale (manipulated via loadTranslation()) + if(SettingsPage::hasChanged(ui.showWebPreview)) return true; + if(SettingsPage::hasChanged(ui.showUserStateIcons)) return true; + return false; }