Files
website/core-page-style.typ
2025-07-26 14:27:09 +02:00

185 lines
3.9 KiB
Typst

#import "common.typ": *
// pdfs need to be smaller text
#let small-font-size = if is-web { 14pt } else { 9pt }
#let default-font-size = if is-web { 17pt } else { 10pt }
#let core-page-style(html-head: [], content) = {context html-opt-elem("html", (:))[
#context if is-html() {
html.elem("head",[
#html-head
#html.elem("meta", attrs:(charset:"utf-8"))
#if not is-nano [
#html.elem("meta", attrs:(name:"viewport", content:"width=device-width, initial-scale=1"))
#let ico = res-path()+"favicon.png"
#html.elem("link", attrs:(rel:"icon", sizes:"512x512", href:ico))
#html.elem("link", attrs:(rel:"image_src", type:"image/png", href:ico))
#html.elem("link", attrs:(type:"application/atom+xml", rel:"alternate", title:"alexs168's blog", href:"atom.xml"))
]
])
}
#context html-opt-elem("body", (:))[
#show: x => context {
set page(width: auto, height: auto) if is-web and not is-html()
set page(paper: "a4") if not is-web and not is-html()
set page(numbering: "1 of 1") if not is-web and not is-html()
x
}
#set text(font: "DejaVu Sans Mono", size: default-font-size)
#show raw: it => if is-nano == true {
html-code(text(it))
} else {
if it.block {
html-style-div("margin-top:4pt;",
box(
stroke: black,
radius: 2pt,
inset: if is-html() { 1.6pt } else { 5pt },
outset: 0pt,
it
))
} else {
box(
stroke: black,
radius: 2pt,
inset: if is-html() { 1.6pt } else { 5pt },
outset: 0pt,
baseline: 3.1pt,
it
)
}
}
#show box: it => {
context if is-html() {
html.elem("span", attrs: (style: css-style(it)+"display:inline-block"))[#it.body]
} else {
it
}
}
#show block: it => {
context if is-html() {
html.elem("div", attrs: (style: css-style(it)))[#it.body]
} else {
it
}
}
#show heading: it => if is-nano { it } else { underline(it + v(3pt)) }
#set underline(stroke: 1pt, offset: 2pt)
#show footnote: it => if is-web or is-nano { [] } else { it }
#show footnote.entry: it => if is-web or is-nano { [] } else { it }
#context if is-html() and not is-nano {
let link-color = "3f51b5";
html.elem("style", "
@font-face {
font-family: 'DejaVu Sans Mono';
src:local('DejaVu Sans Mono'),
url('res/DejaVuSansMono.woff2') format('woff2'),
local('Courier New'),
local(Courier),
local(monospace);
font-weight: normal;
font-style: normal;
font-display: swap;
}
/*
@font-face {
font-family: 'DejaVu Sans Mono';
src:local('DejaVu Sans Mono'),
url('res/DejaVuSansMono-Bold.woff2') format('woff2'),
local('Courier New'),
local(Courier),
local(monospace);
font-weight: bold;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'DejaVu Sans';
src:local('DejaVu Sans'),
url('res/DejaVuSans-Bold.woff2') format('woff2'),
local('Courier New');
font-weight: bold;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'DejaVu Sans';
src:local('DejaVu Sans'),
url('res/DejaVuSans.woff2') format('woff2'),
local('Courier New');
font-weight: normal;
font-style: normal;
font-display: swap;
}*/
body {
font-family: DejaVu Sans Mono;
font-size: "+len2css(default-font-size)+";
}
td {
width: 100%;
display: inline;
vertical-align: top;
}
h1,h2,h3,h4 {
margin-top: 1%;
margin-bottom: 0.75%;
" + if is-web { "margin-left: -0.75%;" } else { "" }
+
"
}
p {
margin-top: 0.75%;
margin-bottom: 0.75%;
}
ul {
margin-top: 0%;
}
.current {
font-weight: bold;
}
pre {
margin-top: 0px;
margin-bottom: 0px;
display: inline;
}
a {
color: #"+link-color+";
text-decoration: none;
}
a:visited {
color: #"+link-color+";
text-decoration: none;
}
")
}
#content
]]
}