diff --git a/src/plugins/texteditor/colorscheme.h b/src/plugins/texteditor/colorscheme.h
index e333d6b128a969988f7cc55cfb7a14a4b2c59070..cc327bdfcd89718bb707e8954510a534c9bca65b 100644
--- a/src/plugins/texteditor/colorscheme.h
+++ b/src/plugins/texteditor/colorscheme.h
@@ -81,6 +81,9 @@ class ColorScheme
 public:
     ColorScheme();
 
+    inline bool isEmpty() const
+    { return m_formats.isEmpty(); }
+
     bool contains(const QString &category) const;
 
     Format &formatFor(const QString &category);
diff --git a/src/plugins/texteditor/editcolorschemedialog.cpp b/src/plugins/texteditor/editcolorschemedialog.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..0fc58ea21c357573850d627381a98ecb9c1d9db6
--- /dev/null
+++ b/src/plugins/texteditor/editcolorschemedialog.cpp
@@ -0,0 +1,215 @@
+/**************************************************************************
+**
+** This file is part of Qt Creator
+**
+** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+**
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** Commercial Usage
+**
+** Licensees holding valid Qt Commercial licenses may use this file in
+** accordance with the Qt Commercial License Agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Nokia.
+**
+** GNU Lesser General Public License Usage
+**
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file.  Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** If you are unsure which license is appropriate for your use, please
+** contact the sales department at http://www.qtsoftware.com/contact.
+**
+**************************************************************************/
+
+#include "editcolorschemedialog.h"
+#include "ui_editcolorschemedialog.h"
+
+#include <QtGui/QColorDialog>
+
+using namespace TextEditor::Internal;
+
+static inline QString colorButtonStyleSheet(const QColor &bgColor)
+{
+    if (bgColor.isValid()) {
+        QString rc = QLatin1String("border: 2px solid black; border-radius: 2px; background:");
+        rc += bgColor.name();
+        return rc;
+    }
+    return QLatin1String("border: 2px dotted black; border-radius: 2px;");
+}
+
+EditColorSchemeDialog::EditColorSchemeDialog(const FormatDescriptions &fd,
+                                             const FontSettings &fontSettings,
+                                             const ColorScheme &scheme,
+                                             QWidget *parent) :
+    QDialog(parent),
+    m_descriptions(fd),
+    m_fontSettings(fontSettings),
+    m_scheme(scheme),
+    m_curItem(-1),
+    m_ui(new Ui::EditColorSchemeDialog)
+{
+    m_ui->setupUi(this);
+
+    foreach (const FormatDescription &d, fd)
+        m_ui->itemListWidget->addItem(d.trName());
+
+    connect(m_ui->itemListWidget, SIGNAL(itemSelectionChanged()), SLOT(itemChanged()));
+    connect(m_ui->foregroundToolButton, SIGNAL(clicked()), SLOT(changeForeColor()));
+    connect(m_ui->backgroundToolButton, SIGNAL(clicked()), SLOT(changeBackColor()));
+    connect(m_ui->eraseBackgroundToolButton, SIGNAL(clicked()), SLOT(eraseBackColor()));
+    connect(m_ui->boldCheckBox, SIGNAL(toggled(bool)), SLOT(checkCheckBoxes()));
+    connect(m_ui->italicCheckBox, SIGNAL(toggled(bool)), SLOT(checkCheckBoxes()));
+
+    if (!m_descriptions.empty())
+        m_ui->itemListWidget->setCurrentRow(0);
+}
+
+EditColorSchemeDialog::~EditColorSchemeDialog()
+{
+    delete m_ui;
+}
+
+void EditColorSchemeDialog::itemChanged()
+{
+    QListWidgetItem *item = m_ui->itemListWidget->currentItem();
+    if (!item)
+        return;
+
+    const int numFormats = m_descriptions.size();
+    for (int i = 0; i < numFormats; i++) {
+        if (m_descriptions[i].trName() == item->text()) {
+            m_curItem = i;
+            const Format &format = m_scheme.formatFor(m_descriptions[i].name());
+            m_ui->foregroundToolButton->setStyleSheet(colorButtonStyleSheet(format.foreground()));
+            m_ui->backgroundToolButton->setStyleSheet(colorButtonStyleSheet(format.background()));
+
+            m_ui->eraseBackgroundToolButton->setEnabled(i > 0 && format.background().isValid());
+
+            const bool boldBlocked = m_ui->boldCheckBox->blockSignals(true);
+            m_ui->boldCheckBox->setChecked(format.bold());
+            m_ui->boldCheckBox->blockSignals(boldBlocked);
+            const bool italicBlocked = m_ui->italicCheckBox->blockSignals(true);
+            m_ui->italicCheckBox->setChecked(format.italic());
+            m_ui->italicCheckBox->blockSignals(italicBlocked);
+            updatePreview();
+            break;
+        }
+    }
+}
+
+void EditColorSchemeDialog::changeForeColor()
+{
+    if (m_curItem == -1)
+        return;
+    QColor color = m_scheme.formatFor(m_descriptions[m_curItem].name()).foreground();
+    const QColor newColor = QColorDialog::getColor(color, m_ui->boldCheckBox->window());
+    if (!newColor.isValid())
+        return;
+    QPalette p = m_ui->foregroundToolButton->palette();
+    p.setColor(QPalette::Active, QPalette::Button, newColor);
+    m_ui->foregroundToolButton->setStyleSheet(colorButtonStyleSheet(newColor));
+
+    const int numFormats = m_descriptions.size();
+    for (int i = 0; i < numFormats; i++) {
+        QList<QListWidgetItem*> items = m_ui->itemListWidget->findItems(m_descriptions[i].trName(), Qt::MatchExactly);
+        if (!items.isEmpty() && items.first()->isSelected())
+            m_scheme.formatFor(m_descriptions[i].name()).setForeground(newColor);
+    }
+
+    updatePreview();
+}
+
+void EditColorSchemeDialog::changeBackColor()
+{
+    if (m_curItem == -1)
+        return;
+    QColor color = m_scheme.formatFor(m_descriptions[m_curItem].name()).background();
+    const QColor newColor = QColorDialog::getColor(color, m_ui->boldCheckBox->window());
+    if (!newColor.isValid())
+        return;
+    m_ui->backgroundToolButton->setStyleSheet(colorButtonStyleSheet(newColor));
+    m_ui->eraseBackgroundToolButton->setEnabled(true);
+
+    const int numFormats = m_descriptions.size();
+    for (int i = 0; i < numFormats; i++) {
+        QList<QListWidgetItem*> items = m_ui->itemListWidget->findItems(m_descriptions[i].trName(), Qt::MatchExactly);
+        if (!items.isEmpty() && items.first()->isSelected())
+            m_scheme.formatFor(m_descriptions[i].name()).setBackground(newColor);
+    }
+
+    updatePreview();
+}
+
+void EditColorSchemeDialog::eraseBackColor()
+{
+    if (m_curItem == -1)
+        return;
+    QColor newColor;
+    m_ui->backgroundToolButton->setStyleSheet(colorButtonStyleSheet(newColor));
+
+    const int numFormats = m_descriptions.size();
+    for (int i = 0; i < numFormats; i++) {
+        QList<QListWidgetItem*> items = m_ui->itemListWidget->findItems(m_descriptions[i].trName(), Qt::MatchExactly);
+        if (!items.isEmpty() && items.first()->isSelected())
+            m_scheme.formatFor(m_descriptions[i].name()).setBackground(newColor);
+    }
+    m_ui->eraseBackgroundToolButton->setEnabled(false);
+
+    updatePreview();
+}
+
+void EditColorSchemeDialog::checkCheckBoxes()
+{
+    if (m_curItem == -1)
+        return;
+    const int numFormats = m_descriptions.size();
+    for (int i = 0; i < numFormats; i++) {
+        QList<QListWidgetItem*> items = m_ui->itemListWidget->findItems(m_descriptions[i].trName(), Qt::MatchExactly);
+        if (!items.isEmpty() && items.first()->isSelected()) {
+            m_scheme.formatFor(m_descriptions[i].name()).setBold(m_ui->boldCheckBox->isChecked());
+            m_scheme.formatFor(m_descriptions[i].name()).setItalic(m_ui->italicCheckBox->isChecked());
+        }
+    }
+    updatePreview();
+}
+
+void EditColorSchemeDialog::updatePreview()
+{
+    if (m_curItem == -1)
+        return;
+
+    const Format &currentFormat = m_scheme.formatFor(m_descriptions[m_curItem].name());
+    const Format &baseFormat = m_scheme.formatFor(QLatin1String("Text"));
+
+    QPalette pal = QApplication::palette();
+    if (baseFormat.foreground().isValid()) {
+        pal.setColor(QPalette::Text, baseFormat.foreground());
+        pal.setColor(QPalette::Foreground, baseFormat.foreground());
+    }
+    if (baseFormat.background().isValid())
+        pal.setColor(QPalette::Base, baseFormat.background());
+
+    m_ui->previewTextEdit->setPalette(pal);
+
+    QTextCharFormat format;
+    if (currentFormat.foreground().isValid())
+        format.setForeground(QBrush(currentFormat.foreground()));
+    if (currentFormat.background().isValid())
+        format.setBackground(QBrush(currentFormat.background()));
+    format.setFontFamily(m_fontSettings.family());
+    format.setFontStyleStrategy(m_fontSettings.antialias() ? QFont::PreferAntialias : QFont::NoAntialias);
+    format.setFontPointSize(m_fontSettings.fontSize());
+    format.setFontItalic(currentFormat.italic());
+    if (currentFormat.bold())
+        format.setFontWeight(QFont::Bold);
+    m_ui->previewTextEdit->setCurrentCharFormat(format);
+
+    m_ui->previewTextEdit->setPlainText(tr("\n\tThis is only an example."));
+}
diff --git a/src/plugins/texteditor/editcolorschemedialog.h b/src/plugins/texteditor/editcolorschemedialog.h
new file mode 100644
index 0000000000000000000000000000000000000000..d727b2eb15d873bf811a85d91588abb5285b15ca
--- /dev/null
+++ b/src/plugins/texteditor/editcolorschemedialog.h
@@ -0,0 +1,81 @@
+/**************************************************************************
+**
+** This file is part of Qt Creator
+**
+** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+**
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** Commercial Usage
+**
+** Licensees holding valid Qt Commercial licenses may use this file in
+** accordance with the Qt Commercial License Agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Nokia.
+**
+** GNU Lesser General Public License Usage
+**
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file.  Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** If you are unsure which license is appropriate for your use, please
+** contact the sales department at http://www.qtsoftware.com/contact.
+**
+**************************************************************************/
+
+#ifndef EDITCOLORSCHEMEDIALOG_H
+#define EDITCOLORSCHEMEDIALOG_H
+
+#include "colorscheme.h"
+#include "fontsettingspage.h"
+
+#include <QtGui/QDialog>
+
+namespace TextEditor {
+namespace Internal {
+
+namespace Ui {
+class EditColorSchemeDialog;
+}
+
+class EditColorSchemeDialog : public QDialog
+{
+    Q_OBJECT
+
+public:
+    EditColorSchemeDialog(const FormatDescriptions &fd,
+                          const FontSettings &fontSettings,
+                          const ColorScheme &scheme,
+                          QWidget *parent = 0);
+    ~EditColorSchemeDialog();
+
+    ColorScheme colorScheme() const
+    { return m_scheme; }
+
+private slots:
+    void itemChanged();
+    void changeForeColor();
+    void changeBackColor();
+    void eraseBackColor();
+    void checkCheckBoxes();
+    void updatePreview();
+
+private:
+    const TextEditor::FormatDescriptions m_descriptions;
+    const FontSettings m_fontSettings;
+
+    ColorScheme m_scheme;
+    int m_curItem;
+
+    Ui::EditColorSchemeDialog *m_ui;
+};
+
+
+} // namespace Internal
+} // namespace TextEditor
+
+#endif // EDITCOLORSCHEMEDIALOG_H
diff --git a/src/plugins/texteditor/editcolorschemedialog.ui b/src/plugins/texteditor/editcolorschemedialog.ui
new file mode 100644
index 0000000000000000000000000000000000000000..4810a5c8d365b556927583760a2900d81984d4ef
--- /dev/null
+++ b/src/plugins/texteditor/editcolorschemedialog.ui
@@ -0,0 +1,231 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ui version="4.0">
+ <class>TextEditor::Internal::EditColorSchemeDialog</class>
+ <widget class="QDialog" name="TextEditor::Internal::EditColorSchemeDialog">
+  <property name="geometry">
+   <rect>
+    <x>0</x>
+    <y>0</y>
+    <width>462</width>
+    <height>416</height>
+   </rect>
+  </property>
+  <property name="windowTitle">
+   <string>Edit Color Scheme</string>
+  </property>
+  <layout class="QVBoxLayout" name="verticalLayout">
+   <item>
+    <widget class="QGroupBox" name="groupBox_2">
+     <property name="sizePolicy">
+      <sizepolicy hsizetype="Expanding" vsizetype="Expanding">
+       <horstretch>0</horstretch>
+       <verstretch>1</verstretch>
+      </sizepolicy>
+     </property>
+     <property name="title">
+      <string>Text Categories</string>
+     </property>
+     <layout class="QHBoxLayout">
+      <item>
+       <widget class="QListWidget" name="itemListWidget">
+        <property name="sizePolicy">
+         <sizepolicy hsizetype="Expanding" vsizetype="Expanding">
+          <horstretch>1</horstretch>
+          <verstretch>0</verstretch>
+         </sizepolicy>
+        </property>
+        <property name="selectionMode">
+         <enum>QAbstractItemView::ExtendedSelection</enum>
+        </property>
+       </widget>
+      </item>
+      <item>
+       <layout class="QGridLayout" name="_2">
+        <item row="2" column="0">
+         <widget class="QCheckBox" name="boldCheckBox">
+          <property name="text">
+           <string>Bold</string>
+          </property>
+         </widget>
+        </item>
+        <item row="2" column="1">
+         <widget class="QCheckBox" name="italicCheckBox">
+          <property name="text">
+           <string>Italic</string>
+          </property>
+         </widget>
+        </item>
+        <item row="0" column="1">
+         <widget class="QToolButton" name="foregroundToolButton">
+          <property name="sizePolicy">
+           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
+            <horstretch>0</horstretch>
+            <verstretch>0</verstretch>
+           </sizepolicy>
+          </property>
+          <property name="text">
+           <string/>
+          </property>
+         </widget>
+        </item>
+        <item row="1" column="0">
+         <widget class="QLabel" name="label_2">
+          <property name="sizePolicy">
+           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
+            <horstretch>0</horstretch>
+            <verstretch>0</verstretch>
+           </sizepolicy>
+          </property>
+          <property name="text">
+           <string>Background:</string>
+          </property>
+         </widget>
+        </item>
+        <item row="0" column="0">
+         <widget class="QLabel" name="label">
+          <property name="sizePolicy">
+           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
+            <horstretch>0</horstretch>
+            <verstretch>0</verstretch>
+           </sizepolicy>
+          </property>
+          <property name="text">
+           <string>Foreground:</string>
+          </property>
+         </widget>
+        </item>
+        <item row="3" column="1">
+         <spacer>
+          <property name="orientation">
+           <enum>Qt::Vertical</enum>
+          </property>
+          <property name="sizeHint" stdset="0">
+           <size>
+            <width>20</width>
+            <height>40</height>
+           </size>
+          </property>
+         </spacer>
+        </item>
+        <item row="1" column="1">
+         <layout class="QHBoxLayout" name="horizontalLayout">
+          <item>
+           <widget class="QToolButton" name="backgroundToolButton">
+            <property name="sizePolicy">
+             <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
+              <horstretch>0</horstretch>
+              <verstretch>0</verstretch>
+             </sizepolicy>
+            </property>
+            <property name="text">
+             <string/>
+            </property>
+           </widget>
+          </item>
+          <item>
+           <widget class="QToolButton" name="eraseBackgroundToolButton">
+            <property name="toolTip">
+             <string>Erase background</string>
+            </property>
+            <property name="text">
+             <string>x</string>
+            </property>
+            <property name="arrowType">
+             <enum>Qt::LeftArrow</enum>
+            </property>
+           </widget>
+          </item>
+         </layout>
+        </item>
+       </layout>
+      </item>
+     </layout>
+    </widget>
+   </item>
+   <item>
+    <widget class="QLabel" name="label_3">
+     <property name="text">
+      <string>Preview:</string>
+     </property>
+    </widget>
+   </item>
+   <item>
+    <widget class="QTextEdit" name="previewTextEdit">
+     <property name="sizePolicy">
+      <sizepolicy hsizetype="Expanding" vsizetype="Expanding">
+       <horstretch>0</horstretch>
+       <verstretch>0</verstretch>
+      </sizepolicy>
+     </property>
+     <property name="maximumSize">
+      <size>
+       <width>16777215</width>
+       <height>100</height>
+      </size>
+     </property>
+     <property name="readOnly">
+      <bool>true</bool>
+     </property>
+    </widget>
+   </item>
+   <item>
+    <spacer name="verticalSpacer">
+     <property name="orientation">
+      <enum>Qt::Vertical</enum>
+     </property>
+     <property name="sizeHint" stdset="0">
+      <size>
+       <width>20</width>
+       <height>10</height>
+      </size>
+     </property>
+    </spacer>
+   </item>
+   <item>
+    <widget class="QDialogButtonBox" name="buttonBox">
+     <property name="orientation">
+      <enum>Qt::Horizontal</enum>
+     </property>
+     <property name="standardButtons">
+      <set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
+     </property>
+    </widget>
+   </item>
+  </layout>
+ </widget>
+ <resources/>
+ <connections>
+  <connection>
+   <sender>buttonBox</sender>
+   <signal>accepted()</signal>
+   <receiver>TextEditor::Internal::EditColorSchemeDialog</receiver>
+   <slot>accept()</slot>
+   <hints>
+    <hint type="sourcelabel">
+     <x>248</x>
+     <y>254</y>
+    </hint>
+    <hint type="destinationlabel">
+     <x>157</x>
+     <y>274</y>
+    </hint>
+   </hints>
+  </connection>
+  <connection>
+   <sender>buttonBox</sender>
+   <signal>rejected()</signal>
+   <receiver>TextEditor::Internal::EditColorSchemeDialog</receiver>
+   <slot>reject()</slot>
+   <hints>
+    <hint type="sourcelabel">
+     <x>316</x>
+     <y>260</y>
+    </hint>
+    <hint type="destinationlabel">
+     <x>286</x>
+     <y>274</y>
+    </hint>
+   </hints>
+  </connection>
+ </connections>
+</ui>
diff --git a/src/plugins/texteditor/fontsettings.h b/src/plugins/texteditor/fontsettings.h
index 20eb325bebf646fed8cb1718cd0fe61e18620789..c74524b618c14764560cce668ed3cd688c6249ae 100644
--- a/src/plugins/texteditor/fontsettings.h
+++ b/src/plugins/texteditor/fontsettings.h
@@ -59,7 +59,7 @@ public:
 
     FontSettings();
     void clear();
-    inline bool isEmpty() const { return m_formats.isEmpty(); }
+    inline bool isEmpty() const { return m_scheme.isEmpty(); }
 
     void toSettings(const QString &category,
                     const FormatDescriptions &descriptions,
@@ -103,6 +103,12 @@ public:
      */
     Format &formatFor(const QString &category);
 
+    ColorScheme colorScheme() const
+    { return m_scheme; }
+
+    void setColorScheme(const ColorScheme &scheme)
+    { m_scheme = scheme; }
+
     bool equals(const FontSettings &f) const;
 
     static QString defaultFixedFontFamily();
diff --git a/src/plugins/texteditor/fontsettingspage.cpp b/src/plugins/texteditor/fontsettingspage.cpp
index c19d950f51796564aad513356e21485bb391ec47..6d5a5f4e2f7f1dfa027650c9725046461e4f5f39 100644
--- a/src/plugins/texteditor/fontsettingspage.cpp
+++ b/src/plugins/texteditor/fontsettingspage.cpp
@@ -28,6 +28,8 @@
 **************************************************************************/
 
 #include "fontsettingspage.h"
+
+#include "editcolorschemedialog.h"
 #include "fontsettings.h"
 #include "texteditorconstants.h"
 #include "ui_fontsettingspage.h"
@@ -38,7 +40,6 @@
 #include <QtCore/QSettings>
 #include <QtCore/QTimer>
 #include <QtGui/QCheckBox>
-#include <QtGui/QColorDialog>
 #include <QtGui/QComboBox>
 #include <QtGui/QFontDatabase>
 #include <QtGui/QListWidget>
@@ -48,16 +49,6 @@
 #include <QtGui/QTextEdit>
 #include <QtGui/QToolButton>
 
-static inline QString colorButtonStyleSheet(const QColor &bgColor)
-{
-    if (bgColor.isValid()) {
-        QString rc = QLatin1String("border: 2px solid black; border-radius: 2px; background:");
-        rc += bgColor.name();
-        return rc;
-    }
-    return QLatin1String("border: 2px dotted black; border-radius: 2px;");
-}
-
 namespace TextEditor {
 namespace Internal {
 
@@ -78,7 +69,6 @@ public:
     TextEditor::FormatDescriptions m_descriptions;
     FontSettings m_value;
     FontSettings m_lastValue;
-    int m_curItem;
     Ui::FontSettingsPage ui;
 };
 
@@ -90,8 +80,7 @@ FontSettingsPagePrivate::FontSettingsPagePrivate(const TextEditor::FormatDescrip
     m_settingsGroup(Core::Utils::settingsKey(category)),
     m_category(category),
     m_trCategory(trCategory),
-    m_descriptions(fd),
-    m_curItem(-1)
+    m_descriptions(fd)
 {
     bool settingsFound = false;
     if (const QSettings *settings = Core::ICore::instance()->settings())
@@ -231,10 +220,9 @@ QWidget *FontSettingsPage::createPage(QWidget *parent)
     QWidget *w = new QWidget(parent);
     d_ptr->ui.setupUi(w);
 
-    d_ptr->ui.itemListWidget->setSelectionMode(QAbstractItemView::ExtendedSelection);
-
-    foreach (const FormatDescription &d, d_ptr->m_descriptions)
-        d_ptr->ui.itemListWidget->addItem(d.trName());
+    d_ptr->ui.schemeListWidget->addItem(tr("Default"));
+    d_ptr->ui.schemeListWidget->setCurrentIndex(d_ptr->ui.schemeListWidget->model()->index(0, 0));
+    d_ptr->ui.editButton->setEnabled(true);
 
     QFontDatabase db;
     const QStringList families = db.families();
@@ -245,170 +233,13 @@ QWidget *FontSettingsPage::createPage(QWidget *parent)
     d_ptr->ui.antialias->setChecked(d_ptr->m_value.antialias());
 
     connect(d_ptr->ui.familyComboBox, SIGNAL(activated(int)), this, SLOT(updatePointSizes()));
-    connect(d_ptr->ui.sizeComboBox, SIGNAL(activated(int)), this, SLOT(updatePreview()));
-    connect(d_ptr->ui.antialias, SIGNAL(toggled(bool)), this, SLOT(updatePreview()));
-    connect(d_ptr->ui.itemListWidget, SIGNAL(itemSelectionChanged()),
-        this, SLOT(itemChanged()));
-    connect(d_ptr->ui.foregroundToolButton, SIGNAL(clicked()),
-        this, SLOT(changeForeColor()));
-    connect(d_ptr->ui.backgroundToolButton, SIGNAL(clicked()),
-        this, SLOT(changeBackColor()));
-    connect(d_ptr->ui.eraseBackgroundToolButton, SIGNAL(clicked()),
-        this, SLOT(eraseBackColor()));
-    connect(d_ptr->ui.boldCheckBox, SIGNAL(toggled(bool)), this, SLOT(checkCheckBoxes()));
-    connect(d_ptr->ui.italicCheckBox, SIGNAL(toggled(bool)), this, SLOT(checkCheckBoxes()));
-
-    if (!d_ptr->m_descriptions.empty())
-        d_ptr->ui.itemListWidget->setCurrentRow(0);
+    connect(d_ptr->ui.editButton, SIGNAL(clicked()), this, SLOT(editColorScheme()));
 
     updatePointSizes();
     d_ptr->m_lastValue = d_ptr->m_value;
     return w;
 }
 
-void FontSettingsPage::itemChanged()
-{
-    QListWidgetItem *item = d_ptr->ui.itemListWidget->currentItem();
-    if (!item)
-        return;
-
-    const int numFormats = d_ptr->m_descriptions.size();
-    for (int i = 0; i < numFormats; i++) {
-        if (d_ptr->m_descriptions[i].trName() == item->text()) {
-            d_ptr->m_curItem = i;
-            const Format &format = d_ptr->m_value.formatFor(d_ptr->m_descriptions[i].name());
-            d_ptr->ui.foregroundToolButton->setStyleSheet(colorButtonStyleSheet(format.foreground()));
-            d_ptr->ui.backgroundToolButton->setStyleSheet(colorButtonStyleSheet(format.background()));
-
-            d_ptr->ui.eraseBackgroundToolButton->setEnabled(i > 0 && format.background().isValid());
-
-            const bool boldBlocked = d_ptr->ui.boldCheckBox->blockSignals(true);
-            d_ptr->ui.boldCheckBox->setChecked(format.bold());
-            d_ptr->ui.boldCheckBox->blockSignals(boldBlocked);
-            const bool italicBlocked = d_ptr->ui.italicCheckBox->blockSignals(true);
-            d_ptr->ui.italicCheckBox->setChecked(format.italic());
-            d_ptr->ui.italicCheckBox->blockSignals(italicBlocked);
-            updatePreview();
-            break;
-        }
-    }
-}
-
-void FontSettingsPage::changeForeColor()
-{
-    if (d_ptr->m_curItem == -1)
-        return;
-    QColor color = d_ptr->m_value.formatFor(d_ptr->m_descriptions[d_ptr->m_curItem].name()).foreground();
-    const QColor newColor = QColorDialog::getColor(color, d_ptr->ui.boldCheckBox->window());
-    if (!newColor.isValid())
-        return;
-    QPalette p = d_ptr->ui.foregroundToolButton->palette();
-    p.setColor(QPalette::Active, QPalette::Button, newColor);
-    d_ptr->ui.foregroundToolButton->setStyleSheet(colorButtonStyleSheet(newColor));
-
-    const int numFormats = d_ptr->m_descriptions.size();
-    for (int i = 0; i < numFormats; i++) {
-        QList<QListWidgetItem*> items = d_ptr->ui.itemListWidget->findItems(d_ptr->m_descriptions[i].trName(), Qt::MatchExactly);
-        if (!items.isEmpty() && items.first()->isSelected())
-            d_ptr->m_value.formatFor(d_ptr->m_descriptions[i].name()).setForeground(newColor);
-    }
-
-    updatePreview();
-}
-
-void FontSettingsPage::changeBackColor()
-{
-    if (d_ptr->m_curItem == -1)
-        return;
-    QColor color = d_ptr->m_value.formatFor(d_ptr->m_descriptions[d_ptr->m_curItem].name()).background();
-    const QColor newColor = QColorDialog::getColor(color, d_ptr->ui.boldCheckBox->window());
-    if (!newColor.isValid())
-        return;
-    d_ptr->ui.backgroundToolButton->setStyleSheet(colorButtonStyleSheet(newColor));
-    d_ptr->ui.eraseBackgroundToolButton->setEnabled(true);
-
-    const int numFormats = d_ptr->m_descriptions.size();
-    for (int i = 0; i < numFormats; i++) {
-        QList<QListWidgetItem*> items = d_ptr->ui.itemListWidget->findItems(d_ptr->m_descriptions[i].trName(), Qt::MatchExactly);
-        if (!items.isEmpty() && items.first()->isSelected())
-            d_ptr->m_value.formatFor(d_ptr->m_descriptions[i].name()).setBackground(newColor);
-    }
-
-    updatePreview();
-}
-
-void FontSettingsPage::eraseBackColor()
-{
-    if (d_ptr->m_curItem == -1)
-        return;
-    QColor newColor;
-    d_ptr->ui.backgroundToolButton->setStyleSheet(colorButtonStyleSheet(newColor));
-
-    const int numFormats = d_ptr->m_descriptions.size();
-    for (int i = 0; i < numFormats; i++) {
-        QList<QListWidgetItem*> items = d_ptr->ui.itemListWidget->findItems(d_ptr->m_descriptions[i].trName(), Qt::MatchExactly);
-        if (!items.isEmpty() && items.first()->isSelected())
-            d_ptr->m_value.formatFor(d_ptr->m_descriptions[i].name()).setBackground(newColor);
-    }
-    d_ptr->ui.eraseBackgroundToolButton->setEnabled(false);
-
-    updatePreview();
-}
-
-void FontSettingsPage::checkCheckBoxes()
-{
-    if (d_ptr->m_curItem == -1)
-        return;
-    const int numFormats = d_ptr->m_descriptions.size();
-    for (int i = 0; i < numFormats; i++) {
-        QList<QListWidgetItem*> items = d_ptr->ui.itemListWidget->findItems(d_ptr->m_descriptions[i].trName(), Qt::MatchExactly);
-        if (!items.isEmpty() && items.first()->isSelected()) {
-            d_ptr->m_value.formatFor(d_ptr->m_descriptions[i].name()).setBold(d_ptr->ui.boldCheckBox->isChecked());
-            d_ptr->m_value.formatFor(d_ptr->m_descriptions[i].name()).setItalic(d_ptr->ui.italicCheckBox->isChecked());
-        }
-    }
-    updatePreview();
-}
-
-void FontSettingsPage::updatePreview()
-{
-    if (d_ptr->m_curItem == -1)
-        return;
-
-    const Format &currentFormat = d_ptr->m_value.formatFor(d_ptr->m_descriptions[d_ptr->m_curItem].name());
-    const Format &baseFormat = d_ptr->m_value.formatFor(QLatin1String("Text"));
-
-    QPalette pal = QApplication::palette();
-    if (baseFormat.foreground().isValid()) {
-        pal.setColor(QPalette::Text, baseFormat.foreground());
-        pal.setColor(QPalette::Foreground, baseFormat.foreground());
-    }
-    if (baseFormat.background().isValid())
-        pal.setColor(QPalette::Base, baseFormat.background());
-
-    d_ptr->ui.previewTextEdit->setPalette(pal);
-
-    QTextCharFormat format;
-    if (currentFormat.foreground().isValid())
-        format.setForeground(QBrush(currentFormat.foreground()));
-    if (currentFormat.background().isValid())
-        format.setBackground(QBrush(currentFormat.background()));
-    format.setFontFamily(d_ptr->ui.familyComboBox->currentText());
-    format.setFontStyleStrategy(d_ptr->ui.antialias->isChecked() ? QFont::PreferAntialias : QFont::NoAntialias);
-    bool ok;
-    int size = d_ptr->ui.sizeComboBox->currentText().toInt(&ok);
-    if (!ok) {
-        size = QFont().pointSize();
-    }
-    format.setFontPointSize(size);
-    format.setFontItalic(currentFormat.italic());
-    if (currentFormat.bold())
-        format.setFontWeight(QFont::Bold);
-    d_ptr->ui.previewTextEdit->setCurrentCharFormat(format);
-
-    d_ptr->ui.previewTextEdit->setPlainText(tr("\n\tThis is only an example."));
-}
-
 void FontSettingsPage::updatePointSizes()
 {
     const int oldSize = d_ptr->m_value.fontSize();
@@ -424,14 +255,32 @@ void FontSettingsPage::updatePointSizes()
     const QList<int> sizeLst = db.pointSizes(d_ptr->ui.familyComboBox->currentText());
     int idx = 0;
     int i = 0;
-    for (; i<sizeLst.count(); ++i) {
+    for (; i < sizeLst.count(); ++i) {
         if (idx == 0 && sizeLst.at(i) >= oldSize)
             idx = i;
         d_ptr->ui.sizeComboBox->addItem(QString::number(sizeLst.at(i)));
     }
     if (d_ptr->ui.sizeComboBox->count())
         d_ptr->ui.sizeComboBox->setCurrentIndex(idx);
-    updatePreview();
+}
+
+void FontSettingsPage::editColorScheme()
+{
+    d_ptr->m_value.setFamily(d_ptr->ui.familyComboBox->currentText());
+    d_ptr->m_value.setAntialias(d_ptr->ui.antialias->isChecked());
+
+    bool ok = true;
+    const int size = d_ptr->ui.sizeComboBox->currentText().toInt(&ok);
+    if (ok)
+        d_ptr->m_value.setFontSize(size);
+
+    EditColorSchemeDialog dialog(d_ptr->m_descriptions,
+                                 d_ptr->m_value,
+                                 d_ptr->m_value.colorScheme(),
+                                 d_ptr->ui.editButton->window());
+
+    if (dialog.exec() == QDialog::Accepted)
+        d_ptr->m_value.setColorScheme(dialog.colorScheme());
 }
 
 void FontSettingsPage::delayedChange()
diff --git a/src/plugins/texteditor/fontsettingspage.h b/src/plugins/texteditor/fontsettingspage.h
index c9d1c3dcaa1206c63b2943484c912b3ae56b07df..17e00a0f2d41b5adcac70d0d0c0e18c18d92c16a 100644
--- a/src/plugins/texteditor/fontsettingspage.h
+++ b/src/plugins/texteditor/fontsettingspage.h
@@ -109,13 +109,8 @@ signals:
 
 private slots:
     void delayedChange();
-    void itemChanged();
-    void changeForeColor();
-    void changeBackColor();
-    void eraseBackColor();
-    void checkCheckBoxes();
     void updatePointSizes();
-    void updatePreview();
+    void editColorScheme();
 
 private:
     Internal::FontSettingsPagePrivate *d_ptr;
diff --git a/src/plugins/texteditor/fontsettingspage.ui b/src/plugins/texteditor/fontsettingspage.ui
index 543dc5ce3cc6bb9889e10e10085d353cd3294af5..799c2c0a8f95f4d6e96215e2476ff275e46e47d9 100644
--- a/src/plugins/texteditor/fontsettingspage.ui
+++ b/src/plugins/texteditor/fontsettingspage.ui
@@ -6,18 +6,18 @@
    <rect>
     <x>0</x>
     <y>0</y>
-    <width>572</width>
-    <height>471</height>
+    <width>391</width>
+    <height>344</height>
    </rect>
   </property>
-  <layout class="QVBoxLayout">
+  <layout class="QVBoxLayout" name="verticalLayout">
    <item>
     <widget class="QGroupBox" name="groupBox">
      <property name="title">
       <string>Font</string>
      </property>
-     <layout class="QHBoxLayout">
-      <item>
+     <layout class="QGridLayout" name="gridLayout">
+      <item row="0" column="0">
        <widget class="QLabel" name="label_5">
         <property name="sizePolicy">
          <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
@@ -30,7 +30,7 @@
         </property>
        </widget>
       </item>
-      <item>
+      <item row="0" column="1">
        <widget class="QComboBox" name="familyComboBox">
         <property name="sizePolicy">
          <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
@@ -40,7 +40,7 @@
         </property>
        </widget>
       </item>
-      <item>
+      <item row="0" column="2">
        <spacer>
         <property name="orientation">
          <enum>Qt::Horizontal</enum>
@@ -56,7 +56,7 @@
         </property>
        </spacer>
       </item>
-      <item>
+      <item row="0" column="3">
        <widget class="QLabel" name="label_6">
         <property name="sizePolicy">
          <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
@@ -69,7 +69,7 @@
         </property>
        </widget>
       </item>
-      <item>
+      <item row="0" column="4">
        <widget class="QComboBox" name="sizeComboBox">
         <property name="sizePolicy">
          <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
@@ -79,14 +79,7 @@
         </property>
        </widget>
       </item>
-      <item>
-       <widget class="QCheckBox" name="antialias">
-        <property name="text">
-         <string>Antialias</string>
-        </property>
-       </widget>
-      </item>
-      <item>
+      <item row="0" column="5">
        <spacer>
         <property name="orientation">
          <enum>Qt::Horizontal</enum>
@@ -99,148 +92,71 @@
         </property>
        </spacer>
       </item>
+      <item row="1" column="0" colspan="2">
+       <widget class="QCheckBox" name="antialias">
+        <property name="text">
+         <string>Antialias</string>
+        </property>
+       </widget>
+      </item>
      </layout>
     </widget>
    </item>
    <item>
     <widget class="QGroupBox" name="groupBox_2">
-     <property name="sizePolicy">
-      <sizepolicy hsizetype="Expanding" vsizetype="Expanding">
-       <horstretch>0</horstretch>
-       <verstretch>0</verstretch>
-      </sizepolicy>
-     </property>
      <property name="title">
       <string>Color Scheme</string>
      </property>
-     <layout class="QHBoxLayout">
-      <item>
-       <widget class="QListWidget" name="itemListWidget">
-        <property name="sizePolicy">
-         <sizepolicy hsizetype="Expanding" vsizetype="Expanding">
-          <horstretch>1</horstretch>
-          <verstretch>0</verstretch>
-         </sizepolicy>
+     <layout class="QGridLayout" name="gridLayout_2">
+      <item row="0" column="1">
+       <widget class="QPushButton" name="importButton">
+        <property name="enabled">
+         <bool>false</bool>
+        </property>
+        <property name="text">
+         <string>Import</string>
+        </property>
+       </widget>
+      </item>
+      <item row="1" column="1">
+       <widget class="QPushButton" name="exportButton">
+        <property name="enabled">
+         <bool>false</bool>
+        </property>
+        <property name="text">
+         <string>Export</string>
         </property>
        </widget>
       </item>
-      <item>
-       <layout class="QGridLayout">
-        <item row="2" column="0">
-         <widget class="QCheckBox" name="boldCheckBox">
-          <property name="text">
-           <string>Bold</string>
-          </property>
-         </widget>
-        </item>
-        <item row="2" column="1">
-         <widget class="QCheckBox" name="italicCheckBox">
-          <property name="text">
-           <string>Italic</string>
-          </property>
-         </widget>
-        </item>
-        <item row="0" column="1">
-         <widget class="QToolButton" name="foregroundToolButton">
-          <property name="sizePolicy">
-           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
-            <horstretch>0</horstretch>
-            <verstretch>0</verstretch>
-           </sizepolicy>
-          </property>
-          <property name="text">
-           <string/>
-          </property>
-         </widget>
-        </item>
-        <item row="1" column="0">
-         <widget class="QLabel" name="label_2">
-          <property name="sizePolicy">
-           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
-            <horstretch>0</horstretch>
-            <verstretch>0</verstretch>
-           </sizepolicy>
-          </property>
-          <property name="text">
-           <string>Background:</string>
-          </property>
-         </widget>
-        </item>
-        <item row="0" column="0">
-         <widget class="QLabel" name="label">
-          <property name="sizePolicy">
-           <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
-            <horstretch>0</horstretch>
-            <verstretch>0</verstretch>
-           </sizepolicy>
-          </property>
-          <property name="text">
-           <string>Foreground:</string>
-          </property>
-         </widget>
-        </item>
-        <item row="3" column="1">
-         <spacer>
-          <property name="orientation">
-           <enum>Qt::Vertical</enum>
-          </property>
-          <property name="sizeHint" stdset="0">
-           <size>
-            <width>20</width>
-            <height>40</height>
-           </size>
-          </property>
-         </spacer>
-        </item>
-        <item row="1" column="1">
-         <layout class="QHBoxLayout" name="horizontalLayout">
-          <item>
-           <widget class="QToolButton" name="backgroundToolButton">
-            <property name="sizePolicy">
-             <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
-              <horstretch>0</horstretch>
-              <verstretch>0</verstretch>
-             </sizepolicy>
-            </property>
-            <property name="text">
-             <string/>
-            </property>
-           </widget>
-          </item>
-          <item>
-           <widget class="QToolButton" name="eraseBackgroundToolButton">
-            <property name="toolTip">
-             <string>Erase background</string>
-            </property>
-            <property name="text">
-             <string>x</string>
-            </property>
-            <property name="arrowType">
-             <enum>Qt::LeftArrow</enum>
-            </property>
-           </widget>
-          </item>
-         </layout>
-        </item>
-       </layout>
+      <item row="2" column="1">
+       <widget class="QPushButton" name="editButton">
+        <property name="enabled">
+         <bool>false</bool>
+        </property>
+        <property name="text">
+         <string>Edit</string>
+        </property>
+       </widget>
+      </item>
+      <item row="3" column="1">
+       <spacer name="verticalSpacer">
+        <property name="orientation">
+         <enum>Qt::Vertical</enum>
+        </property>
+        <property name="sizeHint" stdset="0">
+         <size>
+          <width>20</width>
+          <height>87</height>
+         </size>
+        </property>
+       </spacer>
+      </item>
+      <item row="0" column="0" rowspan="4">
+       <widget class="QListWidget" name="schemeListWidget"/>
       </item>
      </layout>
     </widget>
    </item>
-   <item>
-    <widget class="QLabel" name="label_3">
-     <property name="text">
-      <string>Preview:</string>
-     </property>
-    </widget>
-   </item>
-   <item>
-    <widget class="QTextEdit" name="previewTextEdit">
-     <property name="readOnly">
-      <bool>true</bool>
-     </property>
-    </widget>
-   </item>
   </layout>
  </widget>
  <resources/>
diff --git a/src/plugins/texteditor/texteditor.pro b/src/plugins/texteditor/texteditor.pro
index 32a0867755bff837a7f4505af1f167bac566e9a5..2a97349b7564f6a83518a868fd2c18306eb9f0bc 100644
--- a/src/plugins/texteditor/texteditor.pro
+++ b/src/plugins/texteditor/texteditor.pro
@@ -27,7 +27,8 @@ SOURCES += texteditorplugin.cpp \
     texteditorsettings.cpp \
     codecselector.cpp \
     findincurrentfile.cpp \
-    colorscheme.cpp
+    colorscheme.cpp \
+    editcolorschemedialog.cpp
 HEADERS += texteditorplugin.h \
     textfilewizard.h \
     plaintexteditor.h \
@@ -58,9 +59,11 @@ HEADERS += texteditorplugin.h \
     texteditorsettings.h \
     codecselector.h \
     findincurrentfile.h \
-    colorscheme.h
+    colorscheme.h \
+    editcolorschemedialog.h
 FORMS += behaviorsettingspage.ui \
     displaysettingspage.ui \
-    fontsettingspage.ui
+    fontsettingspage.ui \
+    editcolorschemedialog.ui
 RESOURCES += texteditor.qrc
 OTHER_FILES += TextEditor.pluginspec