f169ee0933
* Create widget gallery dialog * Add WidgetGallery to debug dialog * Use enum for its intended purpose * Rename "reduced-motion" to "reduce-motion" * Add another border-radius value and make former large radius a bit smaller. * Revamp preferences, add minimalist mode Also: - create additional and missing widget styles and tweak existing ones - use single profile entry to set widget styles and reduce choices to Anki and Native * Indent QTabBar style definitions * Add missing styles for QPushButton states * Fix QTableView background * Remove unused layout from Preferences * Fix QTabView focused tab style * Highlight QCheckBox and QRadioButton when focused * Fix toolbar styles * Reorder preferences * Add setting to hide bottom toolbar * Move toolbar settings above minimalist modes * Remove unused lines * Implement proper full-screen mode * Sort imports * Tweak deck overview appearance in minimalist mode * Undo TitledContainer changes since nobody asked for that * Remove dynamic toolbar background from minimalist mode * Tweak buttons in minimalist mode * Fix some issues * Reduce theme check interval to 5s on Linux * Increase hide timer interval to 2s * Collapse toolbars with slight delay when moving to review state This should ensure the bottom toolbar collapses too. * Allow users to make hiding exclusive to full screen * Rename full screen option * Fix hide mode dropdown ignoring checkbox state on startup * Fix typing issue * Refine background image handling Giving the toolbar body the main webview height ensures background-size: cover behaves exactly the same. To prevent an override of other background properties, users are advised to only set background-images via the background-image property, not the background shorthand. * Fix top toolbar getting huge when switching modes The issue was caused by the min-height hack to align the background images. A call to web.adjustHeightToFit would set the toolbar to the same height as the main webview, as the function makes use of document.offsetHeight. * Prevent scrollbar from appearing on bottom toolbar resize * Cleanup * Put review tab before editing; fix some tab orders * Rename 'network' to 'syncing' * Fix bottom toolbar disappearing on UI > 100 * Improve Preferences layout by adding vertical spacers to the bottom also make the hiding of video_driver and its label more obvious in preferences.py. * Fix bottom toolbar animating on startup Also fix bottom toolbar not appearing when unchecking hide mode in reviewer. * Hide/Show menubar in fullscreen mode along with toolbar * Attempt to fix broken native theme on macOS * Format * Improve native theme on other systems by not forcing palette with the caveat that theme switching can get weird. * Fix theme switching in native style * Remove redundant condition * Add back check for Qt5 to prevent theme issues * Add check for macOS before setting fusion theme * Do not force scrollbar styles on macOS * Remove all of that crazy theme logic * Use canvas instead of button-bg for ColorRole.Button * Make sure Anki style is always based on Fusion otherwise we can't guarantee the same look on all systems. * Explicitly apply default style when Anki style is not selected This should fix the style not switching back after it was selected. * Remove reduncant default_palette * Revert 8af4c1cc2 On Mac with native theme, both Qt5 and Qt6 look correct already. On the Anki theme, without this change, we get the fusion-style scrollbars instead of the rounded ones. * Rename AnkiStyles enum to WidgetStyle * Fix theme switching shades on same theme * Format * Remove unused placeholderText that caused an error when opening the widget gallery on Qt5. * Check for full screen windowState using bitwise operator to prevent error in Qt5. Credit: https://stackoverflow.com/a/65425151 * Hide style option on Windows also exclude native option from dropdown just in case. * Format * Minor naming tweak
99 lines
1.7 KiB
SCSS
99 lines
1.7 KiB
SCSS
@use "vars" as *;
|
|
@use "root-vars";
|
|
@use "button-mixins" as button;
|
|
@use "sass/scrollbar";
|
|
|
|
$body-color: color(fg);
|
|
$body-bg: color(canvas);
|
|
|
|
$link-hover-color: color(fg-link);
|
|
$link-hover-decoration: none;
|
|
|
|
$utilities: (
|
|
"opacity": (
|
|
property: opacity,
|
|
values: (
|
|
0: 0,
|
|
25: 0.25,
|
|
50: 0.5,
|
|
75: 0.75,
|
|
100: 1,
|
|
),
|
|
),
|
|
);
|
|
|
|
@import "bootstrap/scss/bootstrap-reboot";
|
|
@import "bootstrap/scss/bootstrap-utilities";
|
|
|
|
/* Bootstrap "extensions" */
|
|
.flex-basis-100 {
|
|
flex-basis: 100%;
|
|
}
|
|
|
|
.flex-basis-75 {
|
|
flex-basis: 75%;
|
|
}
|
|
|
|
html,
|
|
body {
|
|
height: 100%;
|
|
}
|
|
|
|
html {
|
|
overflow-x: hidden;
|
|
overscroll-behavior: none;
|
|
}
|
|
|
|
body {
|
|
&:not(.isMac),
|
|
&:not(.isMac) * {
|
|
@include scrollbar.custom;
|
|
}
|
|
&.reduce-motion,
|
|
&.reduce-motion * {
|
|
transition: none !important;
|
|
animation: none !important;
|
|
}
|
|
&.no-blur * {
|
|
backdrop-filter: none !important;
|
|
}
|
|
&:not(.fancy),
|
|
&:not(.fancy) * {
|
|
box-shadow: none !important;
|
|
backdrop-filter: none !important;
|
|
}
|
|
}
|
|
|
|
button {
|
|
/* override transition for instant hover response */
|
|
transition: color var(--transition) ease-in-out, box-shadow var(--transition) ease-in-out !important;
|
|
border-radius: prop(border-radius);
|
|
@include button.base;
|
|
}
|
|
|
|
pre,
|
|
code,
|
|
kbd,
|
|
samp {
|
|
unicode-bidi: normal !important;
|
|
}
|
|
|
|
.reduce-motion * {
|
|
transition: none !important;
|
|
animation: none !important;
|
|
}
|
|
|
|
label,
|
|
input[type="radio"],
|
|
input[type="checkbox"] {
|
|
cursor: pointer;
|
|
}
|
|
input[type="text"] {
|
|
border-radius: prop(border-radius);
|
|
outline: none;
|
|
border: 1px solid color(border);
|
|
&:focus {
|
|
border-color: color(border-focus);
|
|
}
|
|
}
|