9f8667fb47
* Give webviews a slide-in animation if reduced motion isn't set. * Auto-hide toolbar in review mode moving the mouse above the main webview expands the toolbar. When the mouse leaves the toolbar, it will collapse after a delay of 2s. * Save some space on bottom toolbars * Use props for all hard-coded transition durations and decrease most commonly used duration (200ms) to 150ms. * Move auto-hide logic into ToolbarWebView and handle auto-hide specific events in the respective webview subclasses. * Fix typing issues * Fix flickering issue * Add auto_hide_toolbar opt-in to preferences * Rename hide_toolbar to collapse_toolbar to better describe the dock-like behaviour. * Rename setting to minimize_distractions * Reduce calls to pm in eventFilter * Run formatter * Revert setting title to something more specific * Increase default animation time to 180ms * Inset toolbar in review mode when auto-hide is not enabled. * Use card background on toolbar and add glass effect * Use flatten/elevate over inset/outset * Use flatten/elevate over inset/outset * Update toolbar.py * Fix toolbar background delay * Tweak styles * Use "collapse" instead of "auto-hide" * Fix background misalignment in collapse mode * Do not collapse toolbar when pointer is outside MainWebView * Reduce hide_timer interval to 1000ms * Use CSS to hide toolbar instead of setting webview height * Add guard to prevent backdrop-filter: blur on Qt 5.14 * Apply transition to body instead of toolbar to not complicate things for #2301. * Fix Qt 5.14 and apply guard globally * Fix background image scaling difference * Tweak preference wording (dae)
98 lines
2.6 KiB
Python
98 lines
2.6 KiB
Python
#!/usr/bin/env python3
|
|
# Copyright: Ankitects Pty Ltd and contributors
|
|
# License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
|
|
import json
|
|
import re
|
|
import sys
|
|
|
|
# bazel genrule "srcs"
|
|
root_vars_css = sys.argv[1]
|
|
|
|
# bazel genrule "outs"
|
|
colors_py = sys.argv[2]
|
|
props_py = sys.argv[3]
|
|
|
|
colors: dict[str, dict[str, str]] = {}
|
|
props: dict[str, dict[str, str]] = {}
|
|
reached_props = False
|
|
comment = ""
|
|
|
|
with open(root_vars_css) as f:
|
|
data = f.read()
|
|
for line in re.split(r"[;\{\}]|\*\/", data):
|
|
line = line.strip()
|
|
|
|
if not line:
|
|
continue
|
|
if line.startswith("/*!"):
|
|
if "props" in line:
|
|
reached_props = True
|
|
elif "rest" in line:
|
|
break
|
|
else:
|
|
comment = re.match(r"\/\*!\s*(.*)$", line)[1]
|
|
continue
|
|
|
|
m = re.match(r"--(.+):(.+)$", line)
|
|
|
|
if not m:
|
|
if (
|
|
line != "}"
|
|
and not ":root" in line
|
|
and "Copyright" not in line
|
|
and "License" not in line
|
|
and "color-scheme" not in line
|
|
and "sourceMappingURL" not in line
|
|
):
|
|
print("failed to match", line)
|
|
continue
|
|
|
|
# convert variable names to Qt style
|
|
var = m.group(1).replace("-", "_").upper()
|
|
val = m.group(2)
|
|
|
|
if reached_props:
|
|
# remove trailing ms from time props
|
|
val = re.sub(r"^(\d+)ms$", r"\1", val)
|
|
|
|
if not var in props:
|
|
props.setdefault(var, {})["comment"] = comment
|
|
props[var]["light"] = val
|
|
else:
|
|
props[var]["dark"] = val
|
|
else:
|
|
if not var in colors:
|
|
colors.setdefault(var, {})["comment"] = comment
|
|
colors[var]["light"] = val
|
|
else:
|
|
colors[var]["dark"] = val
|
|
|
|
comment = ""
|
|
|
|
|
|
copyright_notice = """\
|
|
# Copyright: Ankitects Pty Ltd and contributors
|
|
# License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html\n
|
|
"""
|
|
|
|
with open(colors_py, "w") as buf:
|
|
buf.write(copyright_notice)
|
|
buf.write("# This file was automatically generated from _root-vars.scss\n")
|
|
|
|
for color, val in colors.items():
|
|
if not "dark" in val:
|
|
val["dark"] = val["light"]
|
|
|
|
buf.write(re.sub(r"\"\n", '",\n', f"{color} = {json.dumps(val, indent=4)}\n"))
|
|
|
|
|
|
with open(props_py, "w") as buf:
|
|
buf.write(copyright_notice)
|
|
buf.write("# This file was automatically generated from _root-vars.scss\n")
|
|
|
|
for prop, val in props.items():
|
|
if not "dark" in val:
|
|
val["dark"] = val["light"]
|
|
|
|
buf.write(re.sub(r"\"\n", '",\n', f"{prop} = {json.dumps(val, indent=4)}\n"))
|