From: Manuel Nickschas Date: Tue, 28 Jul 2009 22:02:19 +0000 (+0200) Subject: Add configuration option for a custom stylesheet X-Git-Tag: 0.5-rc1~115 X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=commitdiff_plain;h=9fb25d34cfc4dee02159b112c72e018c6e26e63f Add configuration option for a custom stylesheet Configure -> Appearance now allows you to select a custom stylesheet that should be loaded. This will override both the default stylesheet and the settings.qss containing your dialog-based settings; it will be overridden by --qss specified on the command line. --- diff --git a/src/qtui/settingspages/appearancesettingspage.cpp b/src/qtui/settingspages/appearancesettingspage.cpp index 3346eeb3..e3338169 100644 --- a/src/qtui/settingspages/appearancesettingspage.cpp +++ b/src/qtui/settingspages/appearancesettingspage.cpp @@ -28,6 +28,7 @@ #include "util.h" #include +#include #include #include #include @@ -37,6 +38,7 @@ AppearanceSettingsPage::AppearanceSettingsPage(QWidget *parent) _fontsChanged(false) { ui.setupUi(this); + initAutoWidgets(); initStyleComboBox(); initLanguageComboBox(); @@ -55,13 +57,13 @@ AppearanceSettingsPage::AppearanceSettingsPage(QWidget *parent) mapper = new QSignalMapper(this); connect(mapper, SIGNAL(mapped(QWidget *)), this, SLOT(chooseFont(QWidget *))); - connect(ui.chooseChatView, SIGNAL(clicked()), mapper, SLOT(map())); connect(ui.chooseBufferView, SIGNAL(clicked()), mapper, SLOT(map())); connect(ui.chooseInputLine, SIGNAL(clicked()), mapper, SLOT(map())); - mapper->setMapping(ui.chooseChatView, ui.demoChatView); mapper->setMapping(ui.chooseBufferView, ui.demoBufferView); mapper->setMapping(ui.chooseInputLine, ui.demoInputLine); + + connect(ui.chooseStyleSheet, SIGNAL(clicked()), SLOT(chooseStyleSheet())); } void AppearanceSettingsPage::initStyleComboBox() { @@ -90,9 +92,9 @@ void AppearanceSettingsPage::defaults() { loadFonts(Settings::Default); _fontsChanged = true; - ui.showWebPreview->setChecked(true); ui.showUserStateIcons->setChecked(true); + SettingsPage::defaults(); widgetHasChanged(); } @@ -120,14 +122,12 @@ void AppearanceSettingsPage::load() { ui.languageComboBox->setProperty("storedValue", ui.languageComboBox->currentIndex()); Quassel::loadTranslation(selectedLocale()); - ChatViewSettings chatViewSettings; - SettingsPage::load(ui.showWebPreview, chatViewSettings.showWebPreview()); - BufferSettings bufferSettings; SettingsPage::load(ui.showUserStateIcons, bufferSettings.showUserStateIcons()); loadFonts(Settings::Custom); + SettingsPage::load(); setChangedState(false); } @@ -165,9 +165,6 @@ void AppearanceSettingsPage::save() { uiSettings.setValue("Locale", selectedLocale()); } - ChatViewSettings chatViewSettings; - chatViewSettings.enableWebPreview(ui.showWebPreview->isChecked()); - BufferSettings bufferSettings; bufferSettings.enableUserStateIcons(ui.showUserStateIcons->isChecked()); @@ -189,7 +186,7 @@ void AppearanceSettingsPage::save() { _fontsChanged = false; - load(); + SettingsPage::save(); setChangedState(false); } @@ -226,6 +223,12 @@ void AppearanceSettingsPage::chooseFont(QWidget *widget) { } } +void AppearanceSettingsPage::chooseStyleSheet() { + QString name = QFileDialog::getOpenFileName(this, tr("Please choose a stylesheet file"), QString(), "*.qss"); + if(!name.isEmpty()) + ui.customStyleSheetPath->setText(name); +} + void AppearanceSettingsPage::widgetHasChanged() { setChangedState(testHasChanged()); } @@ -237,7 +240,6 @@ bool AppearanceSettingsPage::testHasChanged() { 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; diff --git a/src/qtui/settingspages/appearancesettingspage.h b/src/qtui/settingspages/appearancesettingspage.h index c3e51a94..302d78bd 100644 --- a/src/qtui/settingspages/appearancesettingspage.h +++ b/src/qtui/settingspages/appearancesettingspage.h @@ -52,6 +52,8 @@ private slots: void setFont(QLabel *label, const QFont &font); void chooseFont(QWidget *label); + void chooseStyleSheet(); + private: bool testHasChanged(); void initStyleComboBox(); diff --git a/src/qtui/settingspages/appearancesettingspage.ui b/src/qtui/settingspages/appearancesettingspage.ui index 87f871d4..69bb6801 100644 --- a/src/qtui/settingspages/appearancesettingspage.ui +++ b/src/qtui/settingspages/appearancesettingspage.ui @@ -7,13 +7,13 @@ 0 0 521 - 447 + 524 Form - + @@ -56,6 +56,64 @@ + + + + Use Custom Stylesheet + + + true + + + false + + + /UiStyle/UseCustomStyleSheet + + + false + + + + + + + + Path: + + + + + + + + 0 + 0 + + + + false + + + /UiStyle/CustomStyleSheetPath + + + + + + + + + + ... + + + + + + + + @@ -66,63 +124,6 @@ - - - false - - - Set font for the main chat window and the chat monitor - - - Chat window: - - - - - - - false - - - - 0 - 0 - - - - Set font for the main chat window and the chat monitor - - - QFrame::StyledPanel - - - QFrame::Sunken - - - Font - - - Qt::AlignCenter - - - - - - - false - - - - 0 - 0 - - - - Choose... - - - - Set font for channel and nick lists @@ -132,7 +133,7 @@ - + @@ -157,7 +158,7 @@ - + @@ -170,7 +171,7 @@ - + Set font for the input line @@ -180,7 +181,7 @@ - + @@ -205,7 +206,7 @@ - + @@ -227,19 +228,6 @@ Misc - - - - Show a website preview window when hovering the mouse over a web address - - - Show previews of webpages on URL hover - - - true - - - diff --git a/src/uisupport/uistyle.cpp b/src/uisupport/uistyle.cpp index 62c7a0e2..332344c0 100644 --- a/src/uisupport/uistyle.cpp +++ b/src/uisupport/uistyle.cpp @@ -54,7 +54,7 @@ UiStyle::UiStyle(QObject *parent) : QObject(parent) { loadStyleSheet(); } -UiStyle::~ UiStyle() { +UiStyle::~UiStyle() { qDeleteAll(_metricsCache); } @@ -63,11 +63,13 @@ void UiStyle::loadStyleSheet() { _metricsCache.clear(); _formatCache.clear(); - QString styleSheet; + UiStyleSettings s; + QString styleSheet; styleSheet += loadStyleSheet("file:///" + Quassel::findDataFilePath("default.qss")); - styleSheet += loadStyleSheet("file:///" + Quassel::configDirPath() + "custom.qss"); - // styleSheet += loadStyleSheet("file:///" + some custom file name); FIXME + styleSheet += loadStyleSheet("file:///" + Quassel::configDirPath() + "settings.qss"); + if(s.value("UseCustomStyleSheet", false).toBool()) + styleSheet += loadStyleSheet("file:///" + s.value("CustomStyleSheetPath").toString(), true); styleSheet += loadStyleSheet("file:///" + Quassel::optionValue("qss"), true); if(styleSheet.isEmpty())