From ff086a69bbbf587fea5deaa724330be1f232d9cf Mon Sep 17 00:00:00 2001 From: Kovid Goyal Date: Wed, 29 Jul 2020 23:10:23 +0530 Subject: [PATCH] Edit book: In dark mode, make the preview panel also dark. Fixes #1888071 [[Enhancement] Make Editor file preview background color customizable](https://bugs.launchpad.net/calibre/+bug/1888071) --- resources/dark_mode.css | 64 ++++++++++++++++++++++++++ src/calibre/gui2/palette.py | 12 ++--- src/calibre/gui2/tweak_book/preview.py | 39 +++++++++++++++- 3 files changed, 108 insertions(+), 7 deletions(-) create mode 100644 resources/dark_mode.css diff --git a/resources/dark_mode.css b/resources/dark_mode.css new file mode 100644 index 0000000000..00a8290a86 --- /dev/null +++ b/resources/dark_mode.css @@ -0,0 +1,64 @@ +/* + * dark_mode.css + * Copyright (C) 2020 Kovid Goyal + * + * Distributed under terms of the MIT license. + */ + +::-webkit-scrollbar { + background: #2B2B2B; + width: 14px; +} + +::-webkit-scrollbar-button { + background: #4B4B4B; + border: 1px solid #4B4B4B; + border-radius: 0; + height: 14px; + width: 14px; +} + +::-webkit-scrollbar-thumb { + background: #666666; + border: 1px solid #959595; + border-radius: 2px; +} +::-webkit-scrollbar-thumb:hover { + background: #929292; +} +::-webkit-scrollbar-thumb:active { + background: #929292; +} +::-webkit-scrollbar-thumb:vertical { + min-height: 40px; +} +::-webkit-scrollbar-track { + background: #4B4B4B; + border: 2px solid #4B4B4B; + border-radius: 0; +} +::-webkit-scrollbar-track:hover { + background: #666666; +} +::-webkit-scrollbar-track:active { + background: #333333; +} +::-webkit-scrollbar-corner { + background: #999999; +} + +::-webkit-scrollbar-button:vertical:start { + width: 14px; + height: 14px; + background-repeat: no-repeat; + background-position: center; + background-image: url() +} + +::-webkit-scrollbar-button:vertical:end { + width: 14px; + height: 14px; + background-repeat: no-repeat; + background-position: center; + background-image: url() +} diff --git a/src/calibre/gui2/palette.py b/src/calibre/gui2/palette.py index 5989013368..b4971b6af0 100644 --- a/src/calibre/gui2/palette.py +++ b/src/calibre/gui2/palette.py @@ -9,23 +9,23 @@ from calibre.constants import dark_link_color dark_link_color = QColor(dark_link_color) +dark_color = QColor(45,45,45) +dark_text_color = QColor('#eee') def dark_palette(): p = QPalette() - dark_color = QColor(45,45,45) disabled_color = QColor(127,127,127) - text_color = QColor('#eee') p.setColor(p.Window, dark_color) - p.setColor(p.WindowText, text_color) + p.setColor(p.WindowText, dark_text_color) p.setColor(p.Base, QColor(18,18,18)) p.setColor(p.AlternateBase, dark_color) p.setColor(p.ToolTipBase, dark_color) - p.setColor(p.ToolTipText, text_color) - p.setColor(p.Text, text_color) + p.setColor(p.ToolTipText, dark_text_color) + p.setColor(p.Text, dark_text_color) p.setColor(p.Disabled, p.Text, disabled_color) p.setColor(p.Button, dark_color) - p.setColor(p.ButtonText, text_color) + p.setColor(p.ButtonText, dark_text_color) p.setColor(p.Disabled, p.ButtonText, disabled_color) p.setColor(p.BrightText, Qt.red) p.setColor(p.Link, dark_link_color) diff --git a/src/calibre/gui2/tweak_book/preview.py b/src/calibre/gui2/tweak_book/preview.py index e6804113ef..3f48d57f69 100644 --- a/src/calibre/gui2/tweak_book/preview.py +++ b/src/calibre/gui2/tweak_book/preview.py @@ -3,6 +3,7 @@ # License: GPLv3 Copyright: 2015, Kovid Goyal from __future__ import absolute_import, division, print_function, unicode_literals +import json import textwrap import time from collections import defaultdict @@ -24,7 +25,8 @@ from calibre.constants import ( ) from calibre.ebooks.oeb.base import OEB_DOCS, XHTML_MIME, serialize from calibre.ebooks.oeb.polish.parsing import parse -from calibre.gui2 import NO_URL_FORMATTING, error_dialog, open_url +from calibre.gui2 import NO_URL_FORMATTING, error_dialog, is_dark_theme, open_url +from calibre.gui2.palette import dark_color, dark_text_color from calibre.gui2.tweak_book import TOP, actions, current_container, editors, tprefs from calibre.gui2.tweak_book.file_list import OpenWithHandler from calibre.gui2.viewer.web_view import handle_mathjax_request, send_reply @@ -243,10 +245,37 @@ def create_profile(): compile_editor() js = P('editor.js', data=True, allow_user_override=False) cparser = P('csscolorparser.js', data=True, allow_user_override=False) + dark_mode_css = P('dark_mode.css', data=True, allow_user_override=False).decode('utf-8') insert_scripts(ans, create_script('csscolorparser.js', cparser), create_script('editor.js', js), + create_script('dark-mode.js', ''' + (function() {if (%s) { + var dark_bg = "%s", dark_fg = "%s", css = %s; + function apply_css() { + var style = document.createElement('style'); + style.textContent = css; + document.documentElement.appendChild(style); + } + + function apply_dark_mode(event) { + if (document.documentElement) { + document.documentElement.style.backgroundColor = dark_bg; + document.documentElement.style.color = dark_fg; + } + if (document.body) { + document.body.style.backgroundColor = dark_bg; + document.body.style.color = dark_fg; + } + } + apply_css(); + apply_dark_mode(); + document.addEventListener("DOMContentLoaded", apply_dark_mode); + } })(); + ''' % ( + 'true' if is_dark_theme() else 'false', dark_color.name(), dark_text_color.name(), json.dumps(dark_mode_css)), + injection_point=QWebEngineScript.DocumentCreation) ) url_handler = UrlSchemeHandler(ans) ans.installUrlSchemeHandler(QByteArray(FAKE_PROTOCOL.encode('ascii')), url_handler) @@ -443,7 +472,9 @@ class Preview(QWidget): self.view._page.bridge.request_sync.connect(self.request_sync) self.view._page.bridge.request_split.connect(self.request_split) self.view._page.bridge.live_css_data.connect(self.live_css_data) + self.view._page.bridge.bridge_ready.connect(self.on_bridge_ready) self.view._page.loadFinished.connect(self.load_finished) + self.view._page.loadStarted.connect(self.load_started) self.view.render_process_restarted.connect(self.render_process_restarted) self.pending_go_to_anchor = None self.inspector = self.view.inspector @@ -649,6 +680,12 @@ class Preview(QWidget): def stop_split(self): actions['split-in-preview'].setChecked(False) + def load_started(self): + pass + + def on_bridge_ready(self): + pass + def load_finished(self, ok): if self.pending_go_to_anchor: self.view._page.go_to_anchor(self.pending_go_to_anchor)