2023-10-20 16:05:57 +00:00
|
|
|
//
|
|
|
|
// Mixins
|
|
|
|
// --------------------------------------------------
|
|
|
|
|
|
|
|
@mixin compact {
|
|
|
|
$selector: &;
|
|
|
|
@at-root [zoteroUIDensity="compact"] {
|
|
|
|
@if $selector {
|
|
|
|
#{$selector} {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@else {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@mixin comfortable {
|
|
|
|
$selector: &;
|
|
|
|
@at-root [zoteroUIDensity="comfortable"] {
|
|
|
|
@if $selector {
|
|
|
|
#{$selector} {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@else {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-10-24 06:36:56 +00:00
|
|
|
|
|
|
|
// @NOTE: this mixin uses `state` mixin, therefore must be used in a selector nested
|
|
|
|
// underneath selectors listed in arguments, e.g., .virtualized-table .row
|
|
|
|
// by default. See `state` mixin for more details.
|
|
|
|
@mixin focus-states(
|
|
|
|
$selectedState: '.row.selected',
|
|
|
|
$focused: '.virtualized-table:focus-within'
|
|
|
|
) {
|
|
|
|
@media (prefers-color-scheme: light) {
|
|
|
|
@content("light");
|
|
|
|
|
|
|
|
@include state($selectedState) {
|
|
|
|
@include state($focused) {
|
|
|
|
@content("white");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@media (prefers-color-scheme: dark) {
|
|
|
|
@content("dark");
|
|
|
|
|
|
|
|
@include state($selectedState) {
|
|
|
|
@include state($focused) {
|
|
|
|
@content("white");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-10-27 13:00:21 +00:00
|
|
|
|
|
|
|
@mixin color-scheme {
|
|
|
|
@media (prefers-color-scheme: light) {
|
|
|
|
@content("light");
|
|
|
|
}
|
|
|
|
|
|
|
|
@media (prefers-color-scheme: dark) {
|
|
|
|
@content("dark");
|
|
|
|
}
|
|
|
|
}
|