Merge branch 'more-color-settings' of https://github.com/ProtractorNinja/qutebrowser into ProtractorNinja-more-color-settings
This commit is contained in:
commit
ab27612139
@ -355,12 +355,19 @@ class DownloadItem(QObject):
|
|||||||
if reply.error() != QNetworkReply.NoError:
|
if reply.error() != QNetworkReply.NoError:
|
||||||
QTimer.singleShot(0, lambda: self.error.emit(reply.errorString()))
|
QTimer.singleShot(0, lambda: self.error.emit(reply.errorString()))
|
||||||
|
|
||||||
def bg_color(self):
|
def get_status_color(self, position):
|
||||||
"""Background color to be shown."""
|
"""Choose an appropriate color for presenting the download's status.
|
||||||
start = config.get('colors', 'downloads.bg.start')
|
|
||||||
stop = config.get('colors', 'downloads.bg.stop')
|
Args:
|
||||||
system = config.get('colors', 'downloads.bg.system')
|
position: The color type requested, can be 'fg' or 'bg'.
|
||||||
error = config.get('colors', 'downloads.bg.error')
|
"""
|
||||||
|
# pylint: disable=bad-config-call
|
||||||
|
# WORKAROUND for https://bitbucket.org/logilab/astroid/issue/104/
|
||||||
|
assert position in ("fg", "bg")
|
||||||
|
start = config.get('colors', 'downloads.{}.start'.format(position))
|
||||||
|
stop = config.get('colors', 'downloads.{}.stop'.format(position))
|
||||||
|
system = config.get('colors', 'downloads.{}.system'.format(position))
|
||||||
|
error = config.get('colors', 'downloads.{}.error'.format(position))
|
||||||
if self.error_msg is not None:
|
if self.error_msg is not None:
|
||||||
assert not self.successful
|
assert not self.successful
|
||||||
return error
|
return error
|
||||||
@ -1022,9 +1029,9 @@ class DownloadManager(QAbstractListModel):
|
|||||||
if role == Qt.DisplayRole:
|
if role == Qt.DisplayRole:
|
||||||
data = str(item)
|
data = str(item)
|
||||||
elif role == Qt.ForegroundRole:
|
elif role == Qt.ForegroundRole:
|
||||||
data = config.get('colors', 'downloads.fg')
|
data = item.get_status_color('fg')
|
||||||
elif role == Qt.BackgroundRole:
|
elif role == Qt.BackgroundRole:
|
||||||
data = item.bg_color()
|
data = item.get_status_color('bg')
|
||||||
elif role == ModelRole.item:
|
elif role == ModelRole.item:
|
||||||
data = item
|
data = item
|
||||||
elif role == Qt.ToolTipRole:
|
elif role == Qt.ToolTipRole:
|
||||||
|
@ -321,6 +321,7 @@ class ConfigManager(QObject):
|
|||||||
('colors', 'tab.indicator.system'): 'tabs.indicator.system',
|
('colors', 'tab.indicator.system'): 'tabs.indicator.system',
|
||||||
('tabs', 'auto-hide'): 'hide-auto',
|
('tabs', 'auto-hide'): 'hide-auto',
|
||||||
('completion', 'history-length'): 'cmd-history-max-items',
|
('completion', 'history-length'): 'cmd-history-max-items',
|
||||||
|
('colors', 'downloads.fg'): 'downloads.fg.start',
|
||||||
}
|
}
|
||||||
DELETED_OPTIONS = [
|
DELETED_OPTIONS = [
|
||||||
('colors', 'tab.separator'),
|
('colors', 'tab.separator'),
|
||||||
|
@ -103,6 +103,10 @@ SECTION_DESC = {
|
|||||||
" * A gradient as explained in http://qt-project.org/doc/qt-4.8/"
|
" * A gradient as explained in http://qt-project.org/doc/qt-4.8/"
|
||||||
"stylesheet-reference.html#list-of-property-types[the Qt "
|
"stylesheet-reference.html#list-of-property-types[the Qt "
|
||||||
"documentation] under ``Gradient''.\n\n"
|
"documentation] under ``Gradient''.\n\n"
|
||||||
|
"A *.system value determines the color system to use for color "
|
||||||
|
"interpolation between similarly-named *.start and *.stop entries, "
|
||||||
|
"regardless of how they are defined in the options. "
|
||||||
|
"Valid values are 'rgb', 'hsv', and 'hsl'.\n\n"
|
||||||
"The `hints.*` values are a special case as they're real CSS "
|
"The `hints.*` values are a special case as they're real CSS "
|
||||||
"colors, not Qt-CSS colors. There, for a gradient, you need to use "
|
"colors, not Qt-CSS colors. There, for a gradient, you need to use "
|
||||||
"`-webkit-gradient`, see https://www.webkit.org/blog/175/introducing-"
|
"`-webkit-gradient`, see https://www.webkit.org/blog/175/introducing-"
|
||||||
@ -818,34 +822,67 @@ def data(readonly=False):
|
|||||||
SettingValue(typ.QssColor(), '#ff4444'),
|
SettingValue(typ.QssColor(), '#ff4444'),
|
||||||
"Foreground color of the matched text in the completion."),
|
"Foreground color of the matched text in the completion."),
|
||||||
|
|
||||||
|
('statusbar.fg',
|
||||||
|
SettingValue(typ.QssColor(), 'white'),
|
||||||
|
"Foreground color of the statusbar."),
|
||||||
|
|
||||||
('statusbar.bg',
|
('statusbar.bg',
|
||||||
SettingValue(typ.QssColor(), 'black'),
|
SettingValue(typ.QssColor(), 'black'),
|
||||||
"Foreground color of the statusbar."),
|
"Foreground color of the statusbar."),
|
||||||
|
|
||||||
('statusbar.fg',
|
('statusbar.fg.error',
|
||||||
SettingValue(typ.QssColor(), 'white'),
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
"Foreground color of the statusbar."),
|
"Foreground color of the statusbar if there was an error."),
|
||||||
|
|
||||||
('statusbar.bg.error',
|
('statusbar.bg.error',
|
||||||
SettingValue(typ.QssColor(), 'red'),
|
SettingValue(typ.QssColor(), 'red'),
|
||||||
"Background color of the statusbar if there was an error."),
|
"Background color of the statusbar if there was an error."),
|
||||||
|
|
||||||
|
('statusbar.fg.warning',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
|
"Foreground color of the statusbar if there is a warning."),
|
||||||
|
|
||||||
('statusbar.bg.warning',
|
('statusbar.bg.warning',
|
||||||
SettingValue(typ.QssColor(), 'darkorange'),
|
SettingValue(typ.QssColor(), 'darkorange'),
|
||||||
"Background color of the statusbar if there is a warning."),
|
"Background color of the statusbar if there is a warning."),
|
||||||
|
|
||||||
|
('statusbar.fg.prompt',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
|
"Foreground color of the statusbar if there is a prompt."),
|
||||||
|
|
||||||
('statusbar.bg.prompt',
|
('statusbar.bg.prompt',
|
||||||
SettingValue(typ.QssColor(), 'darkblue'),
|
SettingValue(typ.QssColor(), 'darkblue'),
|
||||||
"Background color of the statusbar if there is a prompt."),
|
"Background color of the statusbar if there is a prompt."),
|
||||||
|
|
||||||
|
('statusbar.fg.insert',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
|
"Foreground color of the statusbar in insert mode."),
|
||||||
|
|
||||||
('statusbar.bg.insert',
|
('statusbar.bg.insert',
|
||||||
SettingValue(typ.QssColor(), 'darkgreen'),
|
SettingValue(typ.QssColor(), 'darkgreen'),
|
||||||
"Background color of the statusbar in insert mode."),
|
"Background color of the statusbar in insert mode."),
|
||||||
|
|
||||||
|
('statusbar.fg.command',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
|
"Foreground color of the statusbar in command mode."),
|
||||||
|
|
||||||
|
('statusbar.bg.command',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.bg}'),
|
||||||
|
"Background color of the statusbar in command mode."),
|
||||||
|
|
||||||
|
('statusbar.fg.caret',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
|
"Foreground color of the statusbar in caret mode."),
|
||||||
|
|
||||||
('statusbar.bg.caret',
|
('statusbar.bg.caret',
|
||||||
SettingValue(typ.QssColor(), 'purple'),
|
SettingValue(typ.QssColor(), 'purple'),
|
||||||
"Background color of the statusbar in caret mode."),
|
"Background color of the statusbar in caret mode."),
|
||||||
|
|
||||||
|
('statusbar.fg.caret-selection',
|
||||||
|
SettingValue(typ.QssColor(), '${statusbar.fg}'),
|
||||||
|
"Foreground color of the statusbar in caret mode with a "
|
||||||
|
"selection"),
|
||||||
|
|
||||||
('statusbar.bg.caret-selection',
|
('statusbar.bg.caret-selection',
|
||||||
SettingValue(typ.QssColor(), '#a12dff'),
|
SettingValue(typ.QssColor(), '#a12dff'),
|
||||||
"Background color of the statusbar in caret mode with a "
|
"Background color of the statusbar in caret mode with a "
|
||||||
@ -882,22 +919,22 @@ def data(readonly=False):
|
|||||||
SettingValue(typ.QtColor(), 'white'),
|
SettingValue(typ.QtColor(), 'white'),
|
||||||
"Foreground color of unselected odd tabs."),
|
"Foreground color of unselected odd tabs."),
|
||||||
|
|
||||||
('tabs.fg.even',
|
|
||||||
SettingValue(typ.QtColor(), 'white'),
|
|
||||||
"Foreground color of unselected even tabs."),
|
|
||||||
|
|
||||||
('tabs.fg.selected',
|
|
||||||
SettingValue(typ.QtColor(), 'white'),
|
|
||||||
"Foreground color of selected tabs."),
|
|
||||||
|
|
||||||
('tabs.bg.odd',
|
('tabs.bg.odd',
|
||||||
SettingValue(typ.QtColor(), 'grey'),
|
SettingValue(typ.QtColor(), 'grey'),
|
||||||
"Background color of unselected odd tabs."),
|
"Background color of unselected odd tabs."),
|
||||||
|
|
||||||
|
('tabs.fg.even',
|
||||||
|
SettingValue(typ.QtColor(), 'white'),
|
||||||
|
"Foreground color of unselected even tabs."),
|
||||||
|
|
||||||
('tabs.bg.even',
|
('tabs.bg.even',
|
||||||
SettingValue(typ.QtColor(), 'darkgrey'),
|
SettingValue(typ.QtColor(), 'darkgrey'),
|
||||||
"Background color of unselected even tabs."),
|
"Background color of unselected even tabs."),
|
||||||
|
|
||||||
|
('tabs.fg.selected',
|
||||||
|
SettingValue(typ.QtColor(), 'white'),
|
||||||
|
"Foreground color of selected tabs."),
|
||||||
|
|
||||||
('tabs.bg.selected',
|
('tabs.bg.selected',
|
||||||
SettingValue(typ.QtColor(), 'black'),
|
SettingValue(typ.QtColor(), 'black'),
|
||||||
"Background color of selected tabs."),
|
"Background color of selected tabs."),
|
||||||
@ -926,10 +963,6 @@ def data(readonly=False):
|
|||||||
SettingValue(typ.CssColor(), 'black'),
|
SettingValue(typ.CssColor(), 'black'),
|
||||||
"Font color for hints."),
|
"Font color for hints."),
|
||||||
|
|
||||||
('hints.fg.match',
|
|
||||||
SettingValue(typ.CssColor(), 'green'),
|
|
||||||
"Font color for the matched part of hints."),
|
|
||||||
|
|
||||||
('hints.bg',
|
('hints.bg',
|
||||||
SettingValue(
|
SettingValue(
|
||||||
typ.CssColor(), '-webkit-gradient(linear, left top, '
|
typ.CssColor(), '-webkit-gradient(linear, left top, '
|
||||||
@ -937,25 +970,42 @@ def data(readonly=False):
|
|||||||
'color-stop(100%,#FFC542))'),
|
'color-stop(100%,#FFC542))'),
|
||||||
"Background color for hints."),
|
"Background color for hints."),
|
||||||
|
|
||||||
('downloads.fg',
|
('hints.fg.match',
|
||||||
SettingValue(typ.QtColor(), '#ffffff'),
|
SettingValue(typ.CssColor(), 'green'),
|
||||||
"Foreground color for downloads."),
|
"Font color for the matched part of hints."),
|
||||||
|
|
||||||
('downloads.bg.bar',
|
('downloads.bg.bar',
|
||||||
SettingValue(typ.QssColor(), 'black'),
|
SettingValue(typ.QssColor(), 'black'),
|
||||||
"Background color for the download bar."),
|
"Background color for the download bar."),
|
||||||
|
|
||||||
|
('downloads.fg.start',
|
||||||
|
SettingValue(typ.QtColor(), 'white'),
|
||||||
|
"Color gradient start for download foreground text."),
|
||||||
|
|
||||||
('downloads.bg.start',
|
('downloads.bg.start',
|
||||||
SettingValue(typ.QtColor(), '#0000aa'),
|
SettingValue(typ.QtColor(), '#0000aa'),
|
||||||
"Color gradient start for downloads."),
|
"Color gradient start for download background."),
|
||||||
|
|
||||||
|
('downloads.fg.stop',
|
||||||
|
SettingValue(typ.QtColor(), '${downloads.fg.start}'),
|
||||||
|
"Color gradient end for download foreground text."),
|
||||||
|
|
||||||
('downloads.bg.stop',
|
('downloads.bg.stop',
|
||||||
SettingValue(typ.QtColor(), '#00aa00'),
|
SettingValue(typ.QtColor(), '#00aa00'),
|
||||||
"Color gradient end for downloads."),
|
"Color gradient stop for download background."),
|
||||||
|
|
||||||
|
('downloads.fg.system',
|
||||||
|
SettingValue(typ.ColorSystem(), 'rgb'),
|
||||||
|
"Color gradient interpolation system for download foreground"
|
||||||
|
"text."),
|
||||||
|
|
||||||
('downloads.bg.system',
|
('downloads.bg.system',
|
||||||
SettingValue(typ.ColorSystem(), 'rgb'),
|
SettingValue(typ.ColorSystem(), 'rgb'),
|
||||||
"Color gradient interpolation system for downloads."),
|
"Color gradient interpolation system for download background."),
|
||||||
|
|
||||||
|
('downloads.fg.error',
|
||||||
|
SettingValue(typ.QtColor(), 'white'),
|
||||||
|
"Foreground color for downloads with errors."),
|
||||||
|
|
||||||
('downloads.bg.error',
|
('downloads.bg.error',
|
||||||
SettingValue(typ.QtColor(), 'red'),
|
SettingValue(typ.QtColor(), 'red'),
|
||||||
|
@ -78,6 +78,11 @@ class StatusBar(QWidget):
|
|||||||
For some reason we need to have this as class attribute
|
For some reason we need to have this as class attribute
|
||||||
so pyqtProperty works correctly.
|
so pyqtProperty works correctly.
|
||||||
|
|
||||||
|
_command_active: If we're currently in command mode.
|
||||||
|
|
||||||
|
For some reason we need to have this as class
|
||||||
|
attribute so pyqtProperty works correctly.
|
||||||
|
|
||||||
_caret_mode: The current caret mode (off/on/selection).
|
_caret_mode: The current caret mode (off/on/selection).
|
||||||
|
|
||||||
For some reason we need to have this as class attribute
|
For some reason we need to have this as class attribute
|
||||||
@ -97,41 +102,60 @@ class StatusBar(QWidget):
|
|||||||
_severity = None
|
_severity = None
|
||||||
_prompt_active = False
|
_prompt_active = False
|
||||||
_insert_active = False
|
_insert_active = False
|
||||||
|
_command_active = False
|
||||||
_caret_mode = CaretMode.off
|
_caret_mode = CaretMode.off
|
||||||
|
|
||||||
STYLESHEET = """
|
STYLESHEET = """
|
||||||
QWidget#StatusBar {
|
|
||||||
|
QWidget#StatusBar,
|
||||||
|
QWidget#StatusBar * {
|
||||||
|
{{ font['statusbar'] }}
|
||||||
{{ color['statusbar.bg'] }}
|
{{ color['statusbar.bg'] }}
|
||||||
|
{{ color['statusbar.fg'] }}
|
||||||
}
|
}
|
||||||
|
|
||||||
QWidget#StatusBar[insert_active="true"] {
|
QWidget#StatusBar[caret_mode="on"],
|
||||||
{{ color['statusbar.bg.insert'] }}
|
QWidget#StatusBar[caret_mode="on"] * {
|
||||||
}
|
{{ color['statusbar.fg.caret'] }}
|
||||||
|
|
||||||
QWidget#StatusBar[caret_mode="on"] {
|
|
||||||
{{ color['statusbar.bg.caret'] }}
|
{{ color['statusbar.bg.caret'] }}
|
||||||
}
|
}
|
||||||
|
|
||||||
QWidget#StatusBar[caret_mode="selection"] {
|
QWidget#StatusBar[caret_mode="selection"],
|
||||||
|
QWidget#StatusBar[caret_mode="selection"] * {
|
||||||
|
{{ color['statusbar.fg.caret-selection'] }}
|
||||||
{{ color['statusbar.bg.caret-selection'] }}
|
{{ color['statusbar.bg.caret-selection'] }}
|
||||||
}
|
}
|
||||||
|
|
||||||
QWidget#StatusBar[prompt_active="true"] {
|
QWidget#StatusBar[severity="error"],
|
||||||
{{ color['statusbar.bg.prompt'] }}
|
QWidget#StatusBar[severity="error"] * {
|
||||||
}
|
{{ color['statusbar.fg.error'] }}
|
||||||
|
|
||||||
QWidget#StatusBar[severity="error"] {
|
|
||||||
{{ color['statusbar.bg.error'] }}
|
{{ color['statusbar.bg.error'] }}
|
||||||
}
|
}
|
||||||
|
|
||||||
QWidget#StatusBar[severity="warning"] {
|
QWidget#StatusBar[severity="warning"],
|
||||||
|
QWidget#StatusBar[severity="warning"] * {
|
||||||
|
{{ color['statusbar.fg.warning'] }}
|
||||||
{{ color['statusbar.bg.warning'] }}
|
{{ color['statusbar.bg.warning'] }}
|
||||||
}
|
}
|
||||||
|
|
||||||
QLabel, QLineEdit {
|
QWidget#StatusBar[prompt_active="true"],
|
||||||
{{ color['statusbar.fg'] }}
|
QWidget#StatusBar[prompt_active="true"] * {
|
||||||
{{ font['statusbar'] }}
|
{{ color['statusbar.fg.prompt'] }}
|
||||||
|
{{ color['statusbar.bg.prompt'] }}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QWidget#StatusBar[insert_active="true"],
|
||||||
|
QWidget#StatusBar[insert_active="true"] * {
|
||||||
|
{{ color['statusbar.fg.insert'] }}
|
||||||
|
{{ color['statusbar.bg.insert'] }}
|
||||||
|
}
|
||||||
|
|
||||||
|
QWidget#StatusBar[command_active="true"],
|
||||||
|
QWidget#StatusBar[command_active="true"] * {
|
||||||
|
{{ color['statusbar.fg.command'] }}
|
||||||
|
{{ color['statusbar.bg.command'] }}
|
||||||
|
}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, win_id, parent=None):
|
def __init__(self, win_id, parent=None):
|
||||||
@ -263,6 +287,11 @@ class StatusBar(QWidget):
|
|||||||
self._prompt_active = val
|
self._prompt_active = val
|
||||||
self.setStyleSheet(style.get_stylesheet(self.STYLESHEET))
|
self.setStyleSheet(style.get_stylesheet(self.STYLESHEET))
|
||||||
|
|
||||||
|
@pyqtProperty(bool)
|
||||||
|
def command_active(self):
|
||||||
|
"""Getter for self.command_active, so it can be used as Qt property."""
|
||||||
|
return self._command_active
|
||||||
|
|
||||||
@pyqtProperty(bool)
|
@pyqtProperty(bool)
|
||||||
def insert_active(self):
|
def insert_active(self):
|
||||||
"""Getter for self.insert_active, so it can be used as Qt property."""
|
"""Getter for self.insert_active, so it can be used as Qt property."""
|
||||||
@ -274,7 +303,7 @@ class StatusBar(QWidget):
|
|||||||
return self._caret_mode.name
|
return self._caret_mode.name
|
||||||
|
|
||||||
def set_mode_active(self, mode, val):
|
def set_mode_active(self, mode, val):
|
||||||
"""Setter for self.{insert,caret}_active.
|
"""Setter for self.{insert,command,caret}_active.
|
||||||
|
|
||||||
Re-set the stylesheet after setting the value, so everything gets
|
Re-set the stylesheet after setting the value, so everything gets
|
||||||
updated by Qt properly.
|
updated by Qt properly.
|
||||||
@ -282,6 +311,9 @@ class StatusBar(QWidget):
|
|||||||
if mode == usertypes.KeyMode.insert:
|
if mode == usertypes.KeyMode.insert:
|
||||||
log.statusbar.debug("Setting insert_active to {}".format(val))
|
log.statusbar.debug("Setting insert_active to {}".format(val))
|
||||||
self._insert_active = val
|
self._insert_active = val
|
||||||
|
if mode == usertypes.KeyMode.command:
|
||||||
|
log.statusbar.debug("Setting command_active to {}".format(val))
|
||||||
|
self._command_active = val
|
||||||
elif mode == usertypes.KeyMode.caret:
|
elif mode == usertypes.KeyMode.caret:
|
||||||
webview = objreg.get('tabbed-browser', scope='window',
|
webview = objreg.get('tabbed-browser', scope='window',
|
||||||
window=self._win_id).currentWidget()
|
window=self._win_id).currentWidget()
|
||||||
@ -473,7 +505,9 @@ class StatusBar(QWidget):
|
|||||||
window=self._win_id)
|
window=self._win_id)
|
||||||
if keyparsers[mode].passthrough:
|
if keyparsers[mode].passthrough:
|
||||||
self._set_mode_text(mode.name)
|
self._set_mode_text(mode.name)
|
||||||
if mode in (usertypes.KeyMode.insert, usertypes.KeyMode.caret):
|
if mode in (usertypes.KeyMode.insert,
|
||||||
|
usertypes.KeyMode.command,
|
||||||
|
usertypes.KeyMode.caret):
|
||||||
self.set_mode_active(mode, True)
|
self.set_mode_active(mode, True)
|
||||||
|
|
||||||
@pyqtSlot(usertypes.KeyMode, usertypes.KeyMode)
|
@pyqtSlot(usertypes.KeyMode, usertypes.KeyMode)
|
||||||
@ -486,7 +520,9 @@ class StatusBar(QWidget):
|
|||||||
self._set_mode_text(new_mode.name)
|
self._set_mode_text(new_mode.name)
|
||||||
else:
|
else:
|
||||||
self.txt.set_text(self.txt.Text.normal, '')
|
self.txt.set_text(self.txt.Text.normal, '')
|
||||||
if old_mode in (usertypes.KeyMode.insert, usertypes.KeyMode.caret):
|
if old_mode in (usertypes.KeyMode.insert,
|
||||||
|
usertypes.KeyMode.command,
|
||||||
|
usertypes.KeyMode.caret):
|
||||||
self.set_mode_active(old_mode, False)
|
self.set_mode_active(old_mode, False)
|
||||||
|
|
||||||
@config.change_filter('ui', 'message-timeout')
|
@config.change_filter('ui', 'message-timeout')
|
||||||
|
Loading…
Reference in New Issue
Block a user