2023-04-18 19:59:45 -04:00
|
|
|
// main template that everything inherits from
|
|
|
|
|
2023-07-27 14:38:41 -04:00
|
|
|
#let script-size = 9pt
|
|
|
|
#let footnote-size = 8pt
|
|
|
|
#let small-size = 8pt
|
|
|
|
#let normal-size = 9pt
|
|
|
|
#let large-size = 9pt
|
2023-04-18 19:59:45 -04:00
|
|
|
|
2023-11-29 16:19:54 -05:00
|
|
|
#let font = "Liberation Sans"
|
|
|
|
#let heading_font = "Liberation Sans"
|
2023-06-19 20:40:36 -04:00
|
|
|
#let mono_font = "DejaVu Sans Mono"
|
2023-04-18 19:59:45 -04:00
|
|
|
|
2023-07-10 13:01:07 -04:00
|
|
|
#let settings = yaml("/settings.yml")
|
|
|
|
|
|
|
|
// reference based on TYPST_ROOT
|
|
|
|
// use paths like "/problems/problem.pdf"
|
|
|
|
// which will translate to "/home/user/docs/problems/problem.pdf"
|
|
|
|
#let lref(
|
2023-07-10 18:57:49 -04:00
|
|
|
// whether or not to prepend 'pdfref://' to the link. as long as the handler
|
|
|
|
// is installed, it allows specifying the page number linked to
|
|
|
|
// see https://github.com/dogeystamp/pyinstantref for details
|
|
|
|
pdfref: false,
|
2023-07-10 13:01:07 -04:00
|
|
|
url,
|
|
|
|
text
|
|
|
|
) = {
|
2023-07-10 18:57:49 -04:00
|
|
|
let realUrl = settings.prefix + url;
|
|
|
|
if (pdfref) {
|
|
|
|
realUrl = "pdfref://" + realUrl
|
|
|
|
}
|
|
|
|
return link(realUrl, text)
|
2023-07-10 13:01:07 -04:00
|
|
|
}
|
|
|
|
|
2023-04-18 19:59:45 -04:00
|
|
|
#let gen_title(
|
|
|
|
title: none,
|
|
|
|
) = {
|
|
|
|
// Set document metadata.
|
2023-08-08 21:23:42 -04:00
|
|
|
text(size: 20pt, weight: "black", title, font: heading_font)
|
2023-04-18 19:59:45 -04:00
|
|
|
}
|
|
|
|
|
2023-12-02 20:47:28 -05:00
|
|
|
#let author_string(authors: none) = {
|
2023-04-18 19:59:45 -04:00
|
|
|
if authors == none {
|
|
|
|
authors = (
|
|
|
|
(
|
2023-07-10 13:01:07 -04:00
|
|
|
name: settings.me,
|
2023-04-18 19:59:45 -04:00
|
|
|
),
|
|
|
|
)
|
|
|
|
}
|
2023-12-02 20:47:28 -05:00
|
|
|
|
2023-04-18 19:59:45 -04:00
|
|
|
let names = authors.map(author => author.name)
|
2023-12-02 20:47:28 -05:00
|
|
|
return if authors.len() == 2 {
|
2023-04-18 19:59:45 -04:00
|
|
|
names.join(" and ")
|
|
|
|
} else {
|
|
|
|
names.join(", ", last: ", and ")
|
|
|
|
}
|
2023-12-02 20:47:28 -05:00
|
|
|
}
|
2023-04-18 19:59:45 -04:00
|
|
|
|
2023-12-02 20:47:28 -05:00
|
|
|
#let gen_authors(
|
|
|
|
authors: none,
|
|
|
|
) = {
|
2023-12-18 18:41:25 -05:00
|
|
|
text(author_string(authors: authors))
|
2023-08-08 21:23:42 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#let gen_preamble(
|
|
|
|
title: none,
|
|
|
|
authors: none,
|
|
|
|
prefix: none,
|
|
|
|
suffix: none,
|
|
|
|
) = {
|
|
|
|
pad(left: -2%, {
|
|
|
|
gen_title(title: title)
|
|
|
|
v(13pt, weak: true)
|
|
|
|
pad(left: 1.5pt, prefix)
|
|
|
|
align(right,
|
|
|
|
rect(
|
|
|
|
width: 50%,
|
|
|
|
stroke: none,
|
|
|
|
{
|
|
|
|
[
|
|
|
|
#{gen_authors(authors: authors)}
|
|
|
|
]
|
|
|
|
suffix
|
|
|
|
})
|
|
|
|
)
|
|
|
|
v(10pt)
|
|
|
|
line(length: 100%, stroke: 1pt + rgb("#555555"))
|
2023-04-18 19:59:45 -04:00
|
|
|
})
|
2023-08-08 21:23:42 -04:00
|
|
|
v(5%, weak: true)
|
2023-04-18 19:59:45 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// this template sets up the document
|
|
|
|
// but does not do things like title, authors, etc.
|
|
|
|
#let doc_template(
|
2023-10-24 18:10:36 -04:00
|
|
|
paper-size: "us-letter",
|
2023-12-02 20:47:28 -05:00
|
|
|
title: "",
|
2023-12-18 20:36:00 -05:00
|
|
|
authors: none,
|
|
|
|
enable-footer: true,
|
2023-04-18 19:59:45 -04:00
|
|
|
|
|
|
|
// Content to wrap
|
|
|
|
body,
|
|
|
|
) = {
|
2023-11-09 20:51:19 -05:00
|
|
|
set text(size: normal-size, font: font, weight: "regular", lang: settings.lang)
|
2023-05-13 12:18:51 -04:00
|
|
|
show link: body => text(fill: rgb("#777777"), weight: "bold", body)
|
2023-06-19 20:40:36 -04:00
|
|
|
show math.equation: eq => eq
|
2023-11-22 21:14:01 -05:00
|
|
|
set math.equation(numbering: "(1)")
|
2023-07-11 22:34:00 -04:00
|
|
|
show figure: fig => {
|
|
|
|
show: pad.with(x: 1em)
|
2023-07-11 22:38:51 -04:00
|
|
|
set image(width: 50%)
|
2023-07-11 22:34:00 -04:00
|
|
|
set align(center)
|
|
|
|
v(1em)
|
|
|
|
fig.body
|
|
|
|
if fig.has("caption") {
|
|
|
|
v(1em, weak: true)
|
|
|
|
fig.caption
|
|
|
|
}
|
|
|
|
}
|
2023-10-14 16:34:25 -04:00
|
|
|
set table(inset: 10pt, stroke: 0.5pt + black)
|
2023-04-29 18:51:42 -04:00
|
|
|
show heading: set text(font: heading_font, weight: "black")
|
2023-07-30 11:01:51 -04:00
|
|
|
set heading(numbering: "1.")
|
2023-04-29 18:51:42 -04:00
|
|
|
show raw.where(block: true): txt => pad(
|
|
|
|
left: 0.5em,
|
|
|
|
block(
|
2023-11-29 16:19:54 -05:00
|
|
|
radius: 0em,
|
2023-04-29 18:51:42 -04:00
|
|
|
stroke: luma(230),
|
2023-11-29 16:19:54 -05:00
|
|
|
fill: luma(250),
|
2023-04-29 18:51:42 -04:00
|
|
|
pad(
|
|
|
|
left: 1em,
|
|
|
|
right: 1em,
|
|
|
|
top: 1em,
|
|
|
|
bottom: 1em,
|
|
|
|
txt
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2023-04-18 19:59:45 -04:00
|
|
|
|
|
|
|
set page(
|
|
|
|
paper: paper-size,
|
2023-10-24 18:10:36 -04:00
|
|
|
margin: (top: 8%, rest: 10%),
|
2023-12-02 20:47:28 -05:00
|
|
|
footer-descent: 50%,
|
2023-12-18 20:36:00 -05:00
|
|
|
footer: if enable-footer [
|
2023-12-02 20:47:28 -05:00
|
|
|
#set text(size: 8pt, fill: luma(80))
|
|
|
|
#columns(3)[
|
|
|
|
#align(left)[
|
|
|
|
©
|
2023-12-18 20:36:00 -05:00
|
|
|
#author_string(authors: authors)
|
2023-12-02 20:47:28 -05:00
|
|
|
#datetime.today().year()
|
|
|
|
]
|
|
|
|
#colbreak()
|
|
|
|
|
|
|
|
#align(center)[
|
|
|
|
_ #title _
|
|
|
|
]
|
|
|
|
#colbreak()
|
|
|
|
|
|
|
|
#align(right)[
|
|
|
|
#counter(page).display("1")
|
|
|
|
]
|
|
|
|
]
|
|
|
|
],
|
2023-04-18 19:59:45 -04:00
|
|
|
)
|
2023-05-20 10:11:34 -04:00
|
|
|
set list(indent: 5pt, body-indent: 5pt)
|
|
|
|
set enum(indent: 5pt, body-indent: 5pt)
|
2023-04-18 19:59:45 -04:00
|
|
|
|
|
|
|
// Configure paragraph properties.
|
2023-04-29 18:51:42 -04:00
|
|
|
set par(justify: true)
|
2023-04-18 19:59:45 -04:00
|
|
|
|
|
|
|
// Display the article's contents.
|
|
|
|
v(29pt, weak: true)
|
|
|
|
body
|
|
|
|
}
|