1 /***************************************************************************
2 * Copyright (C) 2005-2016 by the Quassel Project *
3 * devel@quassel-irc.org *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
19 ***************************************************************************/
25 #include "qtuisettings.h"
27 class QtUiStyle : public UiStyle
32 QtUiStyle(QObject *parent = 0);
35 virtual inline qreal firstColumnSeparator() const { return 6; }
36 virtual inline qreal secondColumnSeparator() const { return 6; }
40 * Generates initial settingsQss if it doesn't exist
42 * This allows for default fonts, colors, etc to specified.
45 void initializeSettingsQss();
48 * Generates UI stylesheet based on selected fonts, colors, etc
50 void generateSettingsQss() const;
54 * Updates knowledge of whether or not to use the custom timestamp format
56 void updateUseCustomTimestampFormat();
59 * Updates knowledge of the current timestamp format
61 void updateTimestampFormatString();
64 * Updates knowledge of whether or not to show sender prefixmodes
66 void updateShowSenderPrefixes();
69 * Updates knowledge of whether or not to show sender brackets
71 void updateShowSenderBrackets();
74 QString fontDescription(const QFont &font) const;
77 * Generate a Qt stylesheet color string from a given setting
79 * @param[in] key Reference to settings key containing a QColor
80 * @param[in] settings UiSettings manager to search
81 * @param[in] defaultColor Fallback color if not found; when unspecified default is black
83 QString color(const QString &key, UiSettings &settings, const QColor &defaultColor = QColor()) const;
85 QString msgTypeQss(const QString &msgType, const QString &key, UiSettings &settings) const;
88 * Generates the Qss color palette stylesheet for sender colors
90 * This must be called before generating any Qss dependent on these colors.
92 * @see QtUiStyle::senderQss()
93 * @param[in] settings Reference to current UI settings, used for loading color values
94 * @return Quassel-theme-compatible Qss color palette
96 QString senderPaletteQss(UiSettings &settings) const;
99 * Generate a snippet of Qss stylesheet for a given sender-hash index
101 * This depends on the color palette generated by QtUiStyle::senderPaletteQss()
103 * @param[in] i Sender hash index from 0 - 15
104 * @param[in] messageType Type of message to filter, e.g. 'plain' or 'action'
105 * @param[in] includeNick Also apply foreground color to Nick
106 * @return Snippet of Quassel-theme-compatible Qss stylesheet
108 QString senderQss(int i, const QString &messageType, bool includeNick = false) const;
111 * Generate a snippet of Qss stylesheet for a given IRC nickname sender-hash index
113 * This depends on the color palette generated by QtUiStyle::senderPaletteQss()
115 * @param[in] i Sender hash index from 0 - 15
116 * @return Snippet of Quassel-theme-compatible Qss stylesheet
118 QString nickQss(int i) const;
120 QString chatListItemQss(const QString &state, const QString &key, UiSettings &settings) const;