From 2a9290b3dfedb718dbd5fc7da09775eb803f9764 Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Tue, 22 Apr 2025 18:18:50 +0000
Subject: [PATCH] fix(transclude): blockref detection
---
quartz/styles/base.scss | 118 +++++++++++++++++++++++++++++++++++++----------------------
1 files changed, 74 insertions(+), 44 deletions(-)
diff --git a/quartz/styles/base.scss b/quartz/styles/base.scss
index 8511b2d..60d2d8f 100644
--- a/quartz/styles/base.scss
+++ b/quartz/styles/base.scss
@@ -1,3 +1,5 @@
+@use "sass:map";
+
@use "./variables.scss" as *;
@use "./syntax.scss";
@use "./callouts.scss";
@@ -63,6 +65,21 @@
}
}
+article {
+ > mjx-container.MathJax,
+ blockquote > div > mjx-container.MathJax {
+ display: flex;
+ > svg {
+ margin-left: auto;
+ margin-right: auto;
+ }
+ }
+ blockquote > div > mjx-container.MathJax > svg {
+ margin-top: 1rem;
+ margin-bottom: 1rem;
+ }
+}
+
strong {
font-weight: $semiBoldWeight;
}
@@ -85,7 +102,7 @@
line-height: 1.4rem;
&:has(> img) {
- background-color: none;
+ background-color: transparent;
border-radius: 0;
padding: 0;
}
@@ -121,7 +138,7 @@
}
.page {
- max-width: calc(#{map-get($breakpoints, desktop)} + 300px);
+ max-width: calc(#{map.get($breakpoints, desktop)} + 300px);
margin: 0 auto;
& article {
& > h1 {
@@ -151,27 +168,28 @@
& > #quartz-body {
display: grid;
- grid-template-columns: #{map-get($desktopGrid, templateColumns)};
- grid-template-rows: #{map-get($desktopGrid, templateRows)};
- column-gap: #{map-get($desktopGrid, columnGap)};
- row-gap: #{map-get($desktopGrid, rowGap)};
- grid-template-areas: #{map-get($desktopGrid, templateAreas)};
- @media all and ($desktop) {
- grid-template-columns: #{map-get($tabletGrid, templateColumns)};
- grid-template-rows: #{map-get($tabletGrid, templateRows)};
- column-gap: #{map-get($tabletGrid, columnGap)};
- row-gap: #{map-get($tabletGrid, rowGap)};
- grid-template-areas: #{map-get($tabletGrid, templateAreas)};
+ grid-template-columns: #{map.get($desktopGrid, templateColumns)};
+ grid-template-rows: #{map.get($desktopGrid, templateRows)};
+ column-gap: #{map.get($desktopGrid, columnGap)};
+ row-gap: #{map.get($desktopGrid, rowGap)};
+ grid-template-areas: #{map.get($desktopGrid, templateAreas)};
+
+ @media all and ($tablet) {
+ grid-template-columns: #{map.get($tabletGrid, templateColumns)};
+ grid-template-rows: #{map.get($tabletGrid, templateRows)};
+ column-gap: #{map.get($tabletGrid, columnGap)};
+ row-gap: #{map.get($tabletGrid, rowGap)};
+ grid-template-areas: #{map.get($tabletGrid, templateAreas)};
}
@media all and ($mobile) {
- grid-template-columns: #{map-get($mobileGrid, templateColumns)};
- grid-template-rows: #{map-get($mobileGrid, templateRows)};
- column-gap: #{map-get($mobileGrid, columnGap)};
- row-gap: #{map-get($mobileGrid, rowGap)};
- grid-template-areas: #{map-get($mobileGrid, templateAreas)};
+ grid-template-columns: #{map.get($mobileGrid, templateColumns)};
+ grid-template-rows: #{map.get($mobileGrid, templateRows)};
+ column-gap: #{map.get($mobileGrid, columnGap)};
+ row-gap: #{map.get($mobileGrid, rowGap)};
+ grid-template-areas: #{map.get($mobileGrid, templateAreas)};
}
- @media all and ($desktop) {
+ @media all and not ($desktop) {
padding: 0 1rem;
}
@media all and ($mobile) {
@@ -190,7 +208,7 @@
& .sidebar.left {
z-index: 1;
- grid-area: sidebar-left;
+ grid-area: grid-sidebar-left;
flex-direction: column;
@media all and ($mobile) {
gap: 0;
@@ -205,14 +223,14 @@
}
& .sidebar.right {
- grid-area: sidebar-right;
+ grid-area: grid-sidebar-right;
margin-right: 0;
flex-direction: column;
@media all and ($mobile) {
margin-left: inherit;
margin-right: inherit;
}
- @media all and ($desktop) {
+ @media all and not ($desktop) {
position: initial;
height: unset;
width: 100%;
@@ -220,6 +238,7 @@
padding: 0;
& > * {
flex: 1;
+ max-height: 24rem;
}
& > .toc {
display: none;
@@ -232,7 +251,7 @@
}
& .page-header {
- grid-area: page-header;
+ grid-area: grid-header;
margin: $topSpacing 0 0 0;
@media all and ($mobile) {
margin-top: 0;
@@ -241,11 +260,11 @@
}
& .center > article {
- grid-area: page-center;
+ grid-area: grid-center;
}
- & .page-footer {
- grid-area: page-footer;
+ & footer {
+ grid-area: grid-footer;
}
& .center,
@@ -254,10 +273,11 @@
min-width: 100%;
margin-left: auto;
margin-right: auto;
- @media all and ($desktop) {
+ @media all and ($tablet) {
margin-right: 0;
}
@media all and ($mobile) {
+ margin-right: 0;
margin-left: 0;
}
}
@@ -347,6 +367,10 @@
&[id]:hover > a {
opacity: 1;
}
+
+ &:not([id]) > a[role="anchor"] {
+ display: none;
+ }
}
// typography improvements
@@ -387,7 +411,7 @@
font-size: 0.9rem;
padding: 0.1rem 0.5rem;
border: 1px solid var(--lightgray);
- width: max-content;
+ width: fit-content;
border-radius: 5px;
margin-bottom: -0.5rem;
color: var(--darkgray);
@@ -511,6 +535,7 @@
max-width: 100%;
border-radius: 5px;
margin: 1rem 0;
+ content-visibility: auto;
}
p > img + em {
@@ -533,38 +558,32 @@
}
.spacer {
- flex: 1 1 auto;
+ flex: 2 1 auto;
}
div:has(> .overflow) {
- display: flex;
- overflow-y: auto;
max-height: 100%;
+ overflow-y: hidden;
}
ul.overflow,
ol.overflow {
max-height: 100%;
overflow-y: auto;
+ width: 100%;
+ margin-bottom: 0;
// clearfix
content: "";
clear: both;
- & > li:last-of-type {
- margin-bottom: 30px;
+ & > li.overflow-end {
+ height: 0.5rem;
+ margin: 0;
}
- &:after {
- pointer-events: none;
- content: "";
- width: 100%;
- height: 50px;
- position: absolute;
- left: 0;
- bottom: 0;
- opacity: 1;
- transition: opacity 0.3s ease;
- background: linear-gradient(transparent 0px, var(--light));
+
+ &.gradient-active {
+ mask-image: linear-gradient(to bottom, black calc(100% - 50px), transparent 100%);
}
}
@@ -586,3 +605,14 @@
width: 100%;
border-radius: 5px;
}
+
+.navigation-progress {
+ position: fixed;
+ top: 0;
+ left: 0;
+ width: 0;
+ height: 3px;
+ background: var(--secondary);
+ transition: width 0.2s ease;
+ z-index: 9999;
+}
--
Gitblit v1.10.0