Bug 242956

Summary: Konversation seems to not follow system wide color options
Product: [Applications] konversation Reporter: Edney Matias <edneymatias>
Component: generalAssignee: Konversation Developers <konversation-devel>
Status: RESOLVED FIXED    
Severity: normal CC: hein
Priority: NOR    
Version: 1.3-beta1   
Target Milestone: ---   
Platform: Fedora RPMs   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:
Attachments: Color scheme

Description Edney Matias 2010-06-27 17:31:10 UTC
Version:           1.3-beta1 (using Devel) 
OS:                Linux

It seems that konversation don't follow the the system colors. I mean, right now i have a dark scheme selected and i can't see the characters i type on the message box. I actually have to select them to be able to read. Every single text box follow the scheme but konvesation.

Reproducible: Always

Steps to Reproduce:
Use the color scheme i uploaded an type on konversation text box.

Actual Results:  
Can't see the text.

Expected Results:  
Konversation should use system defined colors for text and i would be able to see the text.
Comment 1 Edney Matias 2010-06-27 17:32:36 UTC
Created attachment 48373 [details]
Color scheme
Comment 2 Eike Hein 2010-06-27 18:48:40 UTC
You probably have Settings -> Configure Konversation -> Interface -> Colors -> Use custom colors for input box enabled.
Comment 3 Edney Matias 2010-06-27 21:48:05 UTC
Sorry... but that option isn't enabled but if i check it i then can see the text.

Thank you.
Comment 4 Eike Hein 2010-06-27 21:58:48 UTC
Ah, OK, you shouldn't have to though, so you found a bug indeed; I could reproduce it now. Sorry, will be fixed in 1.3.1.
Comment 5 Eike Hein 2010-06-28 03:49:17 UTC
commit baf802b651a79cadf877700e80aedbac5d4d7431
Author: Eike Hein <hein@kde.org>
Date:   Mon Jun 28 03:47:49 2010 +0200

    Numerous fixes to color handling in the UI.
    
    BUG:242956

diff --git a/ChangeLog b/ChangeLog
index c28d3b2..2db1523 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -19,6 +19,14 @@ Changes since 1.3:
   to be sent in the future. This avoids getting kicked off a server for
   flooding when multiple clients are connected to a bouncer that forwards
   PONGs to all of them.
+* Fixed numerous cases in which Konversation would incorrectly apply the
+  KDE system color scheme to input lines, nickname lists and the listview
+  version of the tab bar. This general overhaul of the relevant code also
+  brought about minor efficiency and memory usage improvements..
+* Fixed nickname lists not respecting the "Alternate Background" setting
+  when set to use custom colors.
+* Fixed the listview version of the tab bar not greying out disconnected
+  tabs when set to use custom colors.
 
 
 Changes from 1.3-beta1 to 1.3:
diff --git a/src/commit.h b/src/commit.h
index 7c73225..de11388 100644
--- a/src/commit.h
+++ b/src/commit.h
@@ -1,4 +1,4 @@
 // This COMMIT number is added to version string to be used as "patch level"
 #ifndef COMMIT
-#define COMMIT 4053
+#define COMMIT 4054
 #endif
diff --git a/src/dcc/chatcontainer.cpp b/src/dcc/chatcontainer.cpp
index 80d0eb3..9467342 100644
--- a/src/dcc/chatcontainer.cpp
+++ b/src/dcc/chatcontainer.cpp
@@ -140,6 +140,8 @@ namespace Konversation
                 case Chat::Chatting:
                     getTextView()->appendServerMessage(i18n("DCC"), m_chat->statusDetails());
                     m_dccChatInput->setReadOnly(false);
+                    // KTextEdit::setReadOnly(true) from the ChatContainer constructor fucked up the palette.
+                    m_dccChatInput->updateAppearance();
                     break;
                 case Chat::Failed:
                 default:
@@ -247,36 +249,6 @@ namespace Konversation
             return true;
         }
 
-        void ChatContainer::updateAppearance()
-        {
-            QColor fg, bg;
-
-            if (Preferences::self()->inputFieldsBackgroundColor())
-            {
-                fg = Preferences::self()->color(Preferences::ChannelMessage);
-                bg = Preferences::self()->color(Preferences::TextViewBackground);
-            }
-            else
-            {
-                fg = palette().windowText().color();
-                bg = palette().base().color();
-            }
-
-            QPalette queryInputPalette(m_dccChatInput->palette());
-            queryInputPalette.setColor(QPalette::WindowText, fg);
-            queryInputPalette.setColor(QPalette::Text, fg);
-            queryInputPalette.setColor(QPalette::Base, bg);
-
-            m_dccChatInput->setPalette(queryInputPalette);
-
-            if (Preferences::self()->customTextFont())
-                m_dccChatInput->setFont(Preferences::self()->textFont());
-            else
-                m_dccChatInput->setFont(KGlobalSettings::generalFont());
-
-            ChatWindow::updateAppearance();
-        }
-
         void ChatContainer::setChannelEncoding(const QString &encoding)
         {
             m_chat->setEncoding(encoding);
diff --git a/src/dcc/chatcontainer.h b/src/dcc/chatcontainer.h
index 9ec3b42..997e88f 100644
--- a/src/dcc/chatcontainer.h
+++ b/src/dcc/chatcontainer.h
@@ -53,7 +53,6 @@ namespace Konversation
                 virtual void childAdjustFocus();
 
             public slots:
-                void updateAppearance();
                 void appendInputText(const QString &text, bool fromCursor);
             // ChatWindow end
 
diff --git a/src/irc/channel.cpp b/src/irc/channel.cpp
index 3fc0b18..6717e1d 100644
--- a/src/irc/channel.cpp
+++ b/src/irc/channel.cpp
@@ -48,7 +48,6 @@
 #include <KGlobalSettings>
 #include <KMessageBox>
 #include <KIconLoader>
-#include <KColorScheme>
 #include <KVBox>
 #include <KHBox>
 #include <KComboBox>
@@ -2404,29 +2403,16 @@ void Channel::syncSplitters()
 
 void Channel::updateAppearance()
 {
-    QColor fg,bg,abg;
+    QPalette palette;
 
-    if(Preferences::self()->inputFieldsBackgroundColor())
+    if (Preferences::self()->inputFieldsBackgroundColor())
     {
-        fg=Preferences::self()->color(Preferences::ChannelMessage);
-        bg=Preferences::self()->color(Preferences::TextViewBackground);
-        abg=Preferences::self()->color(Preferences::AlternateBackground);
+        palette.setColor(QPalette::Text, Preferences::self()->color(Preferences::ChannelMessage));
+        palette.setColor(QPalette::Base, Preferences::self()->color(Preferences::TextViewBackground));
+        palette.setColor(QPalette::AlternateBase, Preferences::self()->color(Preferences::AlternateBackground));
     }
-    else
-    {
-        fg = palette().windowText().color();
-        bg = palette().base().color();
-        abg = palette().alternateBase().color();
-    }
-
-    QPalette newPalette;
-    newPalette.setColor(QPalette::WindowText, fg);
-    newPalette.setColor(QPalette::Text, fg);
-    newPalette.setColor(QPalette::Base, bg);
-    newPalette.setColor(QPalette::AlternateBase, abg);
 
-    channelInput->setPalette(newPalette);
-    limit->setPalette(newPalette);
+    limit->setPalette(palette);
     topicLine->setPalette(QPalette());
 
     if (Preferences::self()->customTextFont())
@@ -2445,7 +2431,8 @@ void Channel::updateAppearance()
     }
 
     nicknameListView->resort();
-    nicknameListView->setPalette(newPalette);
+    nicknameListView->setPalette(palette);
+    nicknameListView->setAlternatingRowColors(Preferences::self()->inputFieldsBackgroundColor());
 
     if (Preferences::self()->customListFont())
         nicknameListView->setFont(Preferences::self()->listFont());
diff --git a/src/irc/nick.cpp b/src/irc/nick.cpp
index 4e460b7..cef0043 100644
--- a/src/irc/nick.cpp
+++ b/src/irc/nick.cpp
@@ -65,7 +65,7 @@ void Nick::refresh()
         {
             // Brush of the first column will be used for all columns
             setForeground(NicknameColumn,
-                qApp->palette(treeWidget()).brush(QPalette::Disabled, QPalette::WindowText));
+                qApp->palette(treeWidget()).brush(QPalette::Disabled, QPalette::Text));
 
             flags = 1;
         }
@@ -73,7 +73,7 @@ void Nick::refresh()
         {
             // Brush of the first column will be used for all columns
             setForeground(NicknameColumn,
-                treeWidget()->palette().brush(QPalette::Normal, QPalette::WindowText));
+                treeWidget()->palette().brush(QPalette::Normal, QPalette::Text));
         }
 
         Images* images = Application::instance()->images();
diff --git a/src/irc/query.cpp b/src/irc/query.cpp
index 8aa89ad..f350cea 100644
--- a/src/irc/query.cpp
+++ b/src/irc/query.cpp
@@ -294,37 +294,6 @@ void Query::sendQueryText(const QString& sendLine)
     } // for
 }
 
-void Query::updateAppearance()
-{
-    QColor fg, bg;
-
-    if (Preferences::self()->inputFieldsBackgroundColor())
-    {
-        fg = Preferences::self()->color(Preferences::ChannelMessage);
-        bg = Preferences::self()->color(Preferences::TextViewBackground);
-    }
-    else
-    {
-        fg = palette().windowText().color();
-        bg = palette().base().color();
-    }
-
-    QPalette queryInputPalette(queryInput->palette());
-    queryInputPalette.setColor(QPalette::WindowText, fg);
-    queryInputPalette.setColor(QPalette::Text, fg);
-    queryInputPalette.setColor(QPalette::Base, bg);
-
-    queryInput->setPalette(queryInputPalette);
-
-
-    if (Preferences::self()->customTextFont())
-        queryInput->setFont(Preferences::self()->textFont());
-    else
-        queryInput->setFont(KGlobalSettings::generalFont());
-
-    ChatWindow::updateAppearance();
-}
-
 void Query::textPasted(const QString& text)
 {
     if(m_server)
diff --git a/src/irc/query.h b/src/irc/query.h
index aeec260..a5d2ad0 100644
--- a/src/irc/query.h
+++ b/src/irc/query.h
@@ -87,7 +87,6 @@ class Query : public ChatWindow
         void sendQueryText(const QString& text);
         void appendInputText(const QString& s, bool fromCursor);
         virtual void indicateAway(bool show);
-        void updateAppearance();
         void setEncryptedOutput(bool);
         void connectionStateChanged(Server*, Konversation::ConnectionState);
 
diff --git a/src/viewer/ircinput.cpp b/src/viewer/ircinput.cpp
index d1a9a14..6716d47 100644
--- a/src/viewer/ircinput.cpp
+++ b/src/viewer/ircinput.cpp
@@ -156,6 +156,21 @@ void IRCInput::slotSpellCheckDone(const QString& s)
 
 void IRCInput::updateAppearance()
 {
+    QPalette palette;
+
+    if (Preferences::self()->inputFieldsBackgroundColor())
+    {
+        palette.setColor(QPalette::Text, Preferences::self()->color(Preferences::ChannelMessage));
+        palette.setColor(QPalette::Base, Preferences::self()->color(Preferences::TextViewBackground));
+    }
+
+    setPalette(palette);
+
+    if (Preferences::self()->customTextFont())
+        setFont(Preferences::self()->textFont());
+    else
+        setFont(KGlobalSettings::generalFont());
+
     m_multiRow = Preferences::self()->useMultiRowInputBox();
     setLineWrapMode(m_multiRow ? WidgetWidth : NoWrap);
 
diff --git a/src/viewer/statuspanel.cpp b/src/viewer/statuspanel.cpp
index a6126b7..75f909e 100644
--- a/src/viewer/statuspanel.cpp
+++ b/src/viewer/statuspanel.cpp
@@ -151,38 +151,17 @@ void StatusPanel::textPasted(const QString& text)
 
 void StatusPanel::updateAppearance()
 {
-    QColor fg, bg;
-
-    if (Preferences::self()->inputFieldsBackgroundColor())
-    {
-        fg = Preferences::self()->color(Preferences::ChannelMessage);
-        bg = Preferences::self()->color(Preferences::TextViewBackground);
-    }
-    else
+    if (Preferences::self()->showNicknameBox())
     {
-        fg = palette().windowText().color();
-        bg = palette().base().color();
-    }
-
-    QPalette statusInputPalette(statusInput->palette());
-    statusInputPalette.setColor(QPalette::WindowText, fg);
-    statusInputPalette.setColor(QPalette::Text, fg);
-    statusInputPalette.setColor(QPalette::Base, bg);
-    statusInput->setPalette(statusInputPalette);
-
+        if (Preferences::self()->customTextFont())
+            nicknameCombobox->setFont(Preferences::self()->textFont());
+        else
+            nicknameCombobox->setFont(KGlobalSettings::generalFont());
 
-    if (Preferences::self()->customTextFont())
-    {
-        statusInput->setFont(Preferences::self()->textFont());
-        nicknameCombobox->setFont(Preferences::self()->textFont());
+        nicknameCombobox->show();
     }
     else
-    {
-        statusInput->setFont(KGlobalSettings::generalFont());
-        nicknameCombobox->setFont(KGlobalSettings::generalFont());
-    }
-
-    showNicknameBox(Preferences::self()->showNicknameBox());
+        nicknameCombobox->hide();
 
     ChatWindow::updateAppearance();
 }
@@ -351,18 +330,6 @@ void StatusPanel::serverOnline(bool online)
     nicknameCombobox->setEnabled(online);
 }
 
-void StatusPanel::showNicknameBox(bool show)
-{
-    if(show)
-    {
-        nicknameCombobox->show();
-    }
-    else
-    {
-        nicknameCombobox->hide();
-    }
-}
-
 void StatusPanel::setServer(Server* server)
 {
     ChatWindow::setServer(server);
diff --git a/src/viewer/statuspanel.h b/src/viewer/statuspanel.h
index 707fc76..5eecd53 100644
--- a/src/viewer/statuspanel.h
+++ b/src/viewer/statuspanel.h
@@ -55,7 +55,6 @@ class StatusPanel : public ChatWindow
     public slots:
         void setNickname(const QString& newNickname);
         virtual void indicateAway(bool show);
-        void showNicknameBox(bool show);
         void updateAppearance();
         virtual void appendInputText(const QString&, bool fromCursor);
         void updateName();
diff --git a/src/viewer/viewcontainer.cpp b/src/viewer/viewcontainer.cpp
index 5355b11..208956b 100644
--- a/src/viewer/viewcontainer.cpp
+++ b/src/viewer/viewcontainer.cpp
@@ -1072,7 +1072,7 @@ void ViewContainer::unsetViewNotification(ChatWindow* view)
         }
 
         QColor textColor = (Preferences::self()->inputFieldsBackgroundColor()
-            ? Preferences::self()->color(Preferences::ChannelMessage) : m_window->palette().windowText().color());
+            ? Preferences::self()->color(Preferences::ChannelMessage) : QColor());
 
         if (view->getType() == ChatWindow::Channel)
         {
diff --git a/src/viewer/viewtree.cpp b/src/viewer/viewtree.cpp
index c2ad40c..12288da 100644
--- a/src/viewer/viewtree.cpp
+++ b/src/viewer/viewtree.cpp
@@ -68,6 +68,8 @@ ViewTree::ViewTree(QWidget *parent)
     connect(this, SIGNAL(aboutToMove()), SLOT(slotAboutToMoveView()));
     connect(this, SIGNAL(moved()), SLOT(slotMovedView()));
 
+    setBackgroundRole(QPalette::Base);
+
     updateAppearance();
 }
 
@@ -83,24 +85,16 @@ void ViewTree::updateAppearance()
     else
         setFont(KGlobalSettings::generalFont());
 
-    QColor fg, bg;
     QPalette palette;
 
     if (Preferences::self()->inputFieldsBackgroundColor())
     {
-        fg = Preferences::self()->color(Preferences::ChannelMessage);
-        bg = Preferences::self()->color(Preferences::TextViewBackground);
-    }
-    else
-    {
-        fg = palette.windowText().color();
-        bg = palette.base().color();
+        // Only override the active color to keep around the disabled text color
+        // for the disconnect label greyout.
+        palette.setColor(QPalette::Active, QPalette::Text, Preferences::self()->color(Preferences::ChannelMessage));
+        palette.setColor(QPalette::Base, Preferences::self()->color(Preferences::TextViewBackground));
     }
 
-    palette.setColor(QPalette::WindowText, fg);
-    palette.setColor(QPalette::Text, fg);
-    palette.setColor(QPalette::Base, bg);
-    palette.setColor(QPalette::Window, bg);
     setPalette(palette);
 }
 
diff --git a/src/viewer/viewtreeitem.cpp b/src/viewer/viewtreeitem.cpp
index 6e8e1ba..77751f0 100644
--- a/src/viewer/viewtreeitem.cpp
+++ b/src/viewer/viewtreeitem.cpp
@@ -35,9 +35,6 @@ ViewTreeItem::ViewTreeItem(Q3ListView* parent, const QString& name, ChatWindow*
     setView(view);
     setViewType(view->getType());
 
-    m_color = Application::instance()->palette().color(QPalette::Active, QPalette::Text);//KGlobalSettings::textColor();
-    m_customColorSet = false;
-
     setOpen(true);
     setDragEnabled(true);
 
@@ -64,16 +61,12 @@ ViewTreeItem::ViewTreeItem(Q3ListViewItem* parent, const QString& name, ChatWind
     setView(view);
     setViewType(view->getType());
 
-    m_color = Application::instance()->palette().color(QPalette::Active, QPalette::Text);//KGlobalSettings::textColor();
-    m_customColorSet = false;
-
     setOpen(true);
     setDragEnabled(true);
 
     m_isSeparator = false;
     m_isHighlighted = false;
     m_isTruncated = false;
-    m_customColorSet = false;
 
     images = Application::instance()->images();
     m_closeButtonShown = false;
@@ -89,16 +82,12 @@ ViewTreeItem::ViewTreeItem(Q3ListViewItem* parent, Q3ListViewItem* afterItem, co
     setView(view);
     setViewType(view->getType());
 
-    m_color = Application::instance()->palette().color(QPalette::Active, QPalette::Text);//KGlobalSettings::textColor();
-    m_customColorSet = false;
-
     setOpen(true);
     setDragEnabled(true);
 
     m_isSeparator = false;
     m_isHighlighted = false;
     m_isTruncated = false;
-    m_customColorSet = false;
 
     images = Application::instance()->images();
     m_closeButtonShown = false;
@@ -170,22 +159,21 @@ void ViewTreeItem::setColor(QColor color)
     if (color != m_color)
     {
         m_color = color;
-        m_customColorSet = true;
         repaint();
     }
 }
 
 QColor ViewTreeItem::getColor() const
 {
-    if (!m_customColorSet)
+    if (m_color.isValid())
+        return m_color;
+    else
     {
         if (Preferences::self()->inputFieldsBackgroundColor())
             return Preferences::self()->color(Preferences::ChannelMessage);
         else
-            return Application::instance()->palette().color(QPalette::Active, QPalette::Text);//KGlobalSettings::textColor();
+            return Application::instance()->palette().color(QPalette::Active, QPalette::Text); 
     }
-    else
-        return m_color;
 }
 
 void ViewTreeItem::setIcon(const QPixmap& pm)
diff --git a/src/viewer/viewtreeitem.h b/src/viewer/viewtreeitem.h
index e64feef..d01568c 100644
--- a/src/viewer/viewtreeitem.h
+++ b/src/viewer/viewtreeitem.h
@@ -77,7 +77,6 @@ class ViewTreeItem : public Q3ListViewItem
         bool m_isSeparator;
         bool m_isHighlighted;
         bool m_isTruncated;
-        bool m_customColorSet;
 
         Images* images;