[29/11/23] As simple as possible, aiming for < 10kB
@ -1,40 +0,0 @@
|
||||
<div class="row row-cols-1 row-cols-md-3">
|
||||
<div class="col col-md-3">
|
||||
<div class="row row-cols-1 g-0 content" id="nav">
|
||||
<img src="/assets/images/me-square.jpg" class="me" style="height: 40px;width: 40px; border-radius: 20px;border: 2px solid white;"><br>
|
||||
<b>andrew conlin</b><br>
|
||||
software engineer @ MathWorks<br>
|
||||
<br>
|
||||
{% for item in site.data.nav %}
|
||||
<div class="col">
|
||||
<h4 style="font-family: Geist Bold;">
|
||||
<a href="{{ item.link }}" class="text-decoration-none" style="color: white;">
|
||||
<img src="/assets/images/{{ item.icon }}.ico" style="height:30px;width:30px;display: inline;"> {{ item.name }}
|
||||
</a>
|
||||
</h4>
|
||||
</div>
|
||||
{% endfor %}
|
||||
<br>
|
||||
<!--<div class="col gy-2" style="font-family: Arial, Helvetica, sans-serif;">
|
||||
<h4>
|
||||
<div>
|
||||
<span>
|
||||
{% for item in site.data.icons %}
|
||||
{% if item.icon != "letterboxd" %}
|
||||
<a rel="me" href="{{ item.link }}" target="_blank"><i class="{{ item.icon }}" style="color: white;"></i></a>
|
||||
{% else %}
|
||||
<a href="{{ item.link }}" target="_blank"><img class="letterboxd" src="/assets/images/letterboxd.png"></a>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
</span>
|
||||
</div>
|
||||
</h4>
|
||||
</div>-->
|
||||
<hr class="menu">
|
||||
</div>
|
||||
</div>
|
||||
<!--
|
||||
<h1 class="display-3 logo" style="font-weight:700;" id="logo">
|
||||
<span style="color:black;background-color:gold;">ac</span>
|
||||
</h1>
|
||||
-->
|
@ -3,32 +3,27 @@
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<meta property="og:image" content="https://andrewconl.in/assets/images/og-image-template.jpg">
|
||||
{% feed_meta %}
|
||||
<title>andrew conlin</title>
|
||||
<link href="https://use.fontawesome.com/releases/v6.0.0/css/all.css" rel="stylesheet">
|
||||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||
<title>Andrew Conlin</title>
|
||||
<link href="/assets/css/default.css" rel="stylesheet">
|
||||
<script async src="https://umami.andrewconl.in/script.js" data-website-id="ba10ad24-2849-4391-ba43-f362ba947bd1"></script>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<script async src="https://umami.andrewconl.in/script.js"
|
||||
data-website-id="ba10ad24-2849-4391-ba43-f362ba947bd1"></script>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div class="container text-start">
|
||||
{% include nav.html %}
|
||||
<div class="col col-md-9 content">
|
||||
<h1 style="font-family: Geist Bold;">
|
||||
{{ page.title }}
|
||||
<div class="container">
|
||||
<div class="content">
|
||||
{% if page.backlink == true %}
|
||||
<a href="/"><-- back</a>
|
||||
{% endif %}
|
||||
<h1>
|
||||
{{ page.title }}
|
||||
</h1>
|
||||
<p>
|
||||
{{ page.subtitle }}
|
||||
</p>
|
||||
{{ page.subtitle }}
|
||||
{{ content }}
|
||||
<br>
|
||||
<br>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
</html>
|
@ -2,10 +2,9 @@
|
||||
layout: default
|
||||
---
|
||||
|
||||
<p style="font-family:Geist;font-style:italic;">
|
||||
<img src="/assets/images/write.ico" style="display: inline;height: 20px;width: 20px;"> {{ page.date | date_to_string }}
|
||||
|
||||
<img src="/assets/images/alarm.ico" style="display: inline;height: 20px;width: 20px;"> {{ content | reading_time | pluralize: "minute" }}
|
||||
<p>
|
||||
Posted {{ page.date | date_to_string }} to <a href="/">Andrew Conlin's blog</a><br>
|
||||
Reading time: {{ content | reading_time | pluralize: "minute" }}
|
||||
</p>
|
||||
<hr>
|
||||
|
||||
|
@ -1,101 +1,32 @@
|
||||
@font-face {
|
||||
font-family: "Geist";
|
||||
src:
|
||||
local("Geist"),
|
||||
url("../fonts/Geist/Geist-Regular.otf") format("opentype"),
|
||||
url("../fonts/Geist/Geist-Regular.woff2") format("woff");
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Geist Bold";
|
||||
src:
|
||||
local("Geist"),
|
||||
url("../fonts/Geist/Geist-Bold.otf") format("opentype"),
|
||||
url("../fonts/Geist/Geist-Bold.otf") format("woff");
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: "Geist Mono";
|
||||
src:
|
||||
local("Geist"),
|
||||
url("../fonts/Geist\ Mono/GeistMono-Regular.otf") format("opentype"),
|
||||
url("../fonts/Geist\ Mono/GeistMono-Regular.woff2") format("woff");
|
||||
}
|
||||
|
||||
b {
|
||||
font-family: "Geist Bold";
|
||||
body {
|
||||
font-family: Arial, Helvetica, sans-serif;
|
||||
}
|
||||
|
||||
hr {
|
||||
border: none;
|
||||
height: 3px;
|
||||
background-color: #282828;
|
||||
opacity: 100%;
|
||||
}
|
||||
|
||||
hr.menu {
|
||||
display: none;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
hr.menu {
|
||||
display: block;
|
||||
}
|
||||
div.container {
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
div.content {
|
||||
width: 40%;
|
||||
height: auto;
|
||||
margin: 0 auto;
|
||||
position: relative;
|
||||
top: 90px;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
@media screen and (max-width: 1080px) {
|
||||
div.content {
|
||||
top: 20px;
|
||||
width: 70%;
|
||||
height: auto;
|
||||
margin: 0 auto;
|
||||
position: relative;
|
||||
}
|
||||
}
|
||||
|
||||
a {
|
||||
color: gold;
|
||||
}
|
||||
|
||||
body {
|
||||
background-color: black;
|
||||
color: white;
|
||||
font-family: "Geist";
|
||||
min-height: 100vh;
|
||||
}
|
||||
|
||||
code {
|
||||
color: gold;
|
||||
font-family: "Geist Mono";
|
||||
}
|
||||
|
||||
pre {
|
||||
color: gold;
|
||||
background-color: #282828;
|
||||
padding: 10px 10px 10px 10px;
|
||||
border-radius: 10px;
|
||||
white-space: pre-wrap;
|
||||
}
|
||||
|
||||
img.letterboxd {
|
||||
display: inline-block;
|
||||
width:20px;
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
img.letterboxd {
|
||||
margin-left: 0;
|
||||
}
|
||||
}
|
||||
|
||||
::selection {
|
||||
background-color: gold;
|
||||
color: black;
|
||||
}
|
||||
|
||||
table, th, td {
|
||||
border: 1px solid;
|
||||
padding: 5px;
|
||||
}|
|
||||
@media screen and (max-width: 768px) {
|
||||
div.content {
|
||||
width: 100%;
|
||||
height: auto;
|
||||
margin: 0 auto;
|
||||
position: relative;
|
||||
}
|
||||
}
|
Before Width: | Height: | Size: 766 B |
Before Width: | Height: | Size: 766 B |
Before Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 766 B |
Before Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 23 KiB |
Before Width: | Height: | Size: 448 KiB |
Before Width: | Height: | Size: 532 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 766 B |
@ -1,418 +0,0 @@
|
||||
! function() {
|
||||
var t;
|
||||
const e = {
|
||||
"|": ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
if ("_" == e) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", "18"), t.setAttribute("y1", "51"), t.setAttribute("x2", "30"), t.setAttribute("y2", "51"), t.setAttribute("class", "part"), u.appendChild(t)
|
||||
}
|
||||
if ("_" == s) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", "0"), t.setAttribute("y1", "51"), t.setAttribute("x2", "12"), t.setAttribute("y2", "51"), t.setAttribute("class", "part"), u.appendChild(t)
|
||||
}
|
||||
if ("_" == i) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", "12"), t.setAttribute("y1", "-3"), t.setAttribute("x2", "30"), t.setAttribute("y2", "-3"), t.setAttribute("class", "part"), u.appendChild(t)
|
||||
}
|
||||
if ("_" == c) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", "0"), t.setAttribute("y1", "-3"), t.setAttribute("x2", "18"), t.setAttribute("y2", "-3"), t.setAttribute("class", "part"), u.appendChild(t)
|
||||
}
|
||||
return u.appendChild(r([!("/" == i && "\\" == c), ["-"].includes(e), !("/" == l && "\\" == o), ["-"].includes(s), "/" == i, "\\" == o, "/" == l, "\\" == c])), u
|
||||
},
|
||||
"-": ([t, e, n, s, i, o, l, c]) => r([
|
||||
["|"].includes(t), !0, ["|"].includes(n), !0, !1, !1, !1, !1
|
||||
]),
|
||||
"~": ([t, e, n, r, s, i, o, l]) => {
|
||||
const c = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
u = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
return u.setAttribute("x1", "9"), u.setAttribute("y1", "27"), u.setAttribute("x2", "24"), u.setAttribute("y2", "27"), u.setAttribute("class", "part"), c.appendChild(u), c
|
||||
},
|
||||
_: t => {
|
||||
const n = e["-"](t);
|
||||
return n.setAttribute("transform", "translate(0 24)"), n
|
||||
},
|
||||
":": ([t, e, n, r, s, i, o, l]) => {
|
||||
const c = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
u = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
if (u.setAttribute("x1", "15"), u.setAttribute("y1", "0"), u.setAttribute("x2", "15"), u.setAttribute("y2", "60"), u.setAttribute("class", "part"), u.setAttribute("style", "stroke-dasharray: 15; stroke-dashoffset: 0;"), c.appendChild(u), "+" == t) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", "15"), t.setAttribute("y1", "-24"), t.setAttribute("x2", "15"), t.setAttribute("y2", "-15"), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if ("+" == n) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", "15"), t.setAttribute("y1", "60"), t.setAttribute("x2", "15"), t.setAttribute("y2", "78"), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
return c
|
||||
},
|
||||
"=": t => {
|
||||
const e = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
n = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
n.setAttribute("x1", "0"), n.setAttribute("y1", "21"), n.setAttribute("x2", "30"), n.setAttribute("y2", "21"), n.setAttribute("class", "part"), e.appendChild(n);
|
||||
const r = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
return r.setAttribute("x1", "0"), r.setAttribute("y1", "30"), r.setAttribute("x2", "30"), r.setAttribute("y2", "30"), r.setAttribute("class", "part"), e.appendChild(r), e
|
||||
},
|
||||
"*": ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
p = document.createElementNS("http://www.w3.org/2000/svg", "circle");
|
||||
return p.setAttribute("cx", "0"), p.setAttribute("cy", "0"), p.setAttribute("r", "21"), p.setAttribute("stroke", "none"), p.setAttribute("transform", "translate(15, 27)"), u.appendChild(p), u.appendChild(r([
|
||||
["+", "|"].includes(t), ["+", "-"].includes(e), ["+", "|"].includes(n), ["+", "-"].includes(s), ["/"].includes(i), ["\\"].includes(o), ["/"].includes(l), ["\\"].includes(c)
|
||||
])), u
|
||||
},
|
||||
o: ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
p = document.createElementNS("http://www.w3.org/2000/svg", "circle");
|
||||
p.setAttribute("cx", "0"), p.setAttribute("cy", "0"), p.setAttribute("r", "18"), p.setAttribute("stroke-width", "6"), p.setAttribute("fill", "none"), p.setAttribute("stroke", "white"), p.setAttribute("transform", "translate(15, 27)"), u.appendChild(p);
|
||||
const a = r([
|
||||
["+", "|"].includes(t), ["+", "-"].includes(e), ["+", "|"].includes(n), ["+", "-"].includes(s), ["/"].includes(i), ["\\"].includes(o), ["/"].includes(l), ["\\"].includes(c)
|
||||
]);
|
||||
u.appendChild(a);
|
||||
const d = document.createElementNS("http://www.w3.org/2000/svg", "circle");
|
||||
return d.setAttribute("cx", "0"), d.setAttribute("cy", "0"), d.setAttribute("r", "15"), d.setAttribute("fill", "white"), d.setAttribute("opacity", "100%"), d.setAttribute("transform", "translate(15, 27)"), u.appendChild(d), u
|
||||
},
|
||||
"/": t => {
|
||||
const [n, s, i, o, l, c, u, p] = t, a = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
if (a.appendChild(r([
|
||||
["|"].includes(n), !1, ["|"].includes(i), !1, !0, !1, !0, !1
|
||||
])), "\\" == s) {
|
||||
const t = r([!1, !1, !1, !1, !1, !1, !0, !1]);
|
||||
t.setAttribute("transform", "translate(30 -54)"), t.setAttribute("clip-path", "polygon(-3 0, 0 0, 0 54, -3 54)"), a.appendChild(t)
|
||||
}
|
||||
if ("\\" == o) {
|
||||
const t = r([!1, !1, !1, !1, !0, !1, !1, !1]);
|
||||
t.setAttribute("transform", "translate(-30 54)"), t.setAttribute("clip-path", "polygon(15 -6, 33 -6, 33 6, 15 6)"), a.appendChild(t)
|
||||
}
|
||||
if ("_" == s) {
|
||||
const n = e._(t);
|
||||
a.appendChild(n)
|
||||
}
|
||||
return a
|
||||
},
|
||||
"\\": t => {
|
||||
const [n, s, i, o, l, c, u, p] = t, a = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
if (a.appendChild(r([
|
||||
["|"].includes(n), !1, ["|"].includes(i), !1, !1, !0, !1, !0
|
||||
])), "/" == o) {
|
||||
const t = r([!1, !1, !1, !1, !1, !0, !1, !1]);
|
||||
t.setAttribute("transform", "translate(-30 -54)"), t.setAttribute("clip-path", "polygon(15 0, 30 0, 30 54, 15 54)"), a.appendChild(t)
|
||||
}
|
||||
if ("/" == s) {
|
||||
const t = r([!1, !1, !1, !1, !1, !1, !1, !0]);
|
||||
t.setAttribute("transform", "translate(30 54)"), t.setAttribute("clip-path", "polygon(-3 0, 0 0, 0 6, -3 6)"), a.appendChild(t)
|
||||
}
|
||||
if ("_" == o) {
|
||||
const n = e._(t);
|
||||
a.appendChild(n)
|
||||
}
|
||||
return a
|
||||
},
|
||||
"#": ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
p = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
||||
return p.setAttribute("points", [
|
||||
[0, 0],
|
||||
[42, 0],
|
||||
[42, 42],
|
||||
[0, 42]
|
||||
].map(([t, e]) => `${t},${e}`).join(" ")), p.setAttribute("transform", "translate(-6, 6)"), u.appendChild(p), u.appendChild(r([
|
||||
["+", "|"].includes(t), ["+", "-"].includes(e), ["+", "|"].includes(n), ["+", "-"].includes(s), ["/"].includes(i), ["\\"].includes(o), ["/"].includes(l), ["\\"].includes(c)
|
||||
])), u
|
||||
},
|
||||
"+": ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
p = ["*", "#", "-", "+", "~", ">", ".", "'", "`"].includes(e),
|
||||
a = ["*", "#", "-", "+", "~", "<", ".", "'", "`"].includes(s),
|
||||
d = ["*", "#", "|", "+", ".", "`", "^"].includes(t),
|
||||
w = ["*", "#", "|", "+", "'", "`", "v"].includes(n),
|
||||
g = ["/", "*", "#"].includes(i),
|
||||
b = ["\\", "*", "#"].includes(o),
|
||||
A = ["\\", "*", "#"].includes(c),
|
||||
h = ["/", "*", "#"].includes(l);
|
||||
if (u.appendChild(r([d, p, w, a, g, b, h, A])), (a || p) && (w || d)) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
||||
t.setAttribute("points", "0,0 6,0 6,6 0,6"), t.setAttribute("transform", "translate(-3 -3) translate(15 27)"), u.appendChild(t)
|
||||
}
|
||||
if (g || A) {
|
||||
const t = r([!1, !1, !1, !1, !1, A, g, !1]);
|
||||
t.setAttribute("clip-path", "polygon(0 -3, 30 -3, 30 0, 0 0)"), u.appendChild(t)
|
||||
}
|
||||
if (b || h) {
|
||||
const t = r([!1, !1, !1, !1, h, !1, !1, b]);
|
||||
t.setAttribute("clip-path", "polygon(0 27, 15 27, 15 30, 0 30)"), u.appendChild(t)
|
||||
}
|
||||
if (h || A) {
|
||||
const t = r([!1, !1, !1, !1, h && b, A && g, !1, !1]);
|
||||
t.setAttribute("clip-path", "polygon(-3 0, 0 0, 0 54, -3 54)"), u.appendChild(t)
|
||||
}
|
||||
if (b || g) {
|
||||
const t = r([!1, !1, !1, !1, !1, !1, g && A, b && h]);
|
||||
t.setAttribute("clip-path", "polygon(15 0, 30 0, 30 54, 15 54)"), u.appendChild(t)
|
||||
}
|
||||
if (p || a) {
|
||||
const t = r([!1, !1, !1, !1, p || h, A, g, a || b]);
|
||||
t.setAttribute("clip-path", "polygon(-3 24, 30 24, 30 30, -3 30)"), u.appendChild(t)
|
||||
}
|
||||
return u
|
||||
},
|
||||
".": ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
if (!("-" != e && "+" != e || "|" != n && "'" != n && "`" != n && "+" != n)) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 30 24\n A 18 18, 0, 0, 0, 12 42\n L 12 54\n L 18 54\n L 18 42\n A 12 12, 0, 0, 1, 30 30\n Z"), u.appendChild(t)
|
||||
}
|
||||
if (!("-" != s && "+" != s || "|" != n && "'" != n && "`" != n && "+" != n)) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 24\n A 18 18, 0, 0, 1, 18 42\n L 18 54\n L 12 54\n L 12 42\n A 12 12, 0, 0, 0, 0 30 \n Z"), u.appendChild(t)
|
||||
}
|
||||
if (!("-" != e && "+" != e || "|" != t && "." != t && "+" != t)) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 30 30\n A 18 18, 0, 0, 1, 12 12\n L 12 0\n L 18 0\n L 18 12\n A 12 12, 0, 0, 0, 30 24\n Z"), u.appendChild(t)
|
||||
}
|
||||
if (!("-" != s && "+" != s || "|" != t && "." != t && "+" != t)) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 30\n A 18 18, 0, 0, 0, 18 12\n L 18 0\n L 12 0\n L 12 12\n A 12 12, 0, 0, 1, 0 24\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("-" == e && "/" == i) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 30 30\n A 12 12, 0, 0, 1, 18 18\n L 18 15\n L 24 15\n L 24 18\n A 6 6, 0, 0, 0, 30 24\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !0, !1, !1, !1]);
|
||||
e.setAttribute("clip-path", "polygon(15px -10px, 30px -10px, 30px 30px, 2px 15px)"), u.appendChild(e)
|
||||
}
|
||||
if ("-" == e && "\\" == c) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M -3 0\n A 60 60, 0, 0, 0, 30 30\n L 30 24\n A 60 60, 0, 0, 1, 0 -6\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("-" == s && "/" == i) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 30\n A 60 60, 0, 0, 0, 33 0\n L 30 -6\n A 60 60, 0, 0, 1, 0 24\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("-" == s && "\\" == c) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 30\n A 12 12, 0, 0, 0, 12 18\n L 12 15\n L 6 15\n L 6 18\n A 6 6, 0, 0, 1, 0 24\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !1, !1, !0]);
|
||||
e.setAttribute("clip-path", "polygon(-3 -3, 12 -3, 12 18, -3 18)"), u.appendChild(e)
|
||||
}
|
||||
if ("|" == n && "/" == i) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 12 54\n A 120 120, 0, 0, 1, 30 -6\n L 37 -6\n A 120 120, 0, 0, 0, 18 54\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("|" == t && "\\" == o) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 30 60\n A 120 120, 0, 0, 1, 12 0\n L 18 0\n A 120 120, 0, 0, 0, 37 60\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("|" == t && "/" == l) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 60\n A 120 120, 0, 0, 0, 18 0\n L 12 0\n A 120 120, 0, 0, 1, -7 60\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("|" == n && "\\" == c) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 12 54\n A 120 120, 0, 0, 0, -7 -6\n L 0 -6\n A 120 120, 0, 0, 1, 18 54\n Z"), u.appendChild(t)
|
||||
}
|
||||
if ("-" == e && "/" == l) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 48\n A 42 42, 0, 0, 1, 30 24\n L 30 30\n A 42 42, 0, 0, 0, 6 48\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !1, !0, !1]);
|
||||
e.setAttribute("clip-path", "polygon(-3 15, 12 15, 12 30, -3 30)"), u.appendChild(e)
|
||||
}
|
||||
if ("-" == s && "\\" == o) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 24\n A 42 42, 0, 0, 1, 30 48\n L 24 48\n A 42 42, 0, 0, 0, 0 30\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !0, !1, !1]);
|
||||
e.setAttribute("clip-path", "polygon(-3 15, 12 15, 21 30, -3 30)"), u.appendChild(e)
|
||||
}
|
||||
if ("-" == s && "/" == l) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 0 24\n A 12 12, 0, 0, 1, 12 39\n L 6 39\n A 6 6, 0, 0, 0, 0 30\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !1, !0, !1]);
|
||||
e.setAttribute("clip-path", "polygon(-3 6, 12 6, 12 30, -3 30)"), u.appendChild(e)
|
||||
}
|
||||
if ("-" == e && "\\" == o) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 30 24\n A 12 12, 0, 0, 0, 18 39\n L 24 39\n A 6 6, 0, 0, 1, 30 30 \n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !0, !1, !1]);
|
||||
e.setAttribute("clip-path", "polygon(3 6, 18 6, 18 30, 3 30)"), u.appendChild(e)
|
||||
}
|
||||
if ("/" == l && "\\" == o) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 3 42\n A 15 15, 0, 0, 1, 27 42\n L 25 51\n A 9 9, 0, 0, 0, 5 51\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !0, !0, !1]);
|
||||
e.setAttribute("clip-path", "polygon(-3 15, 33 15, 33 30, -3 30)"), u.appendChild(e)
|
||||
}
|
||||
if ("\\" == c && "/" == i) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 3 12\n A 15 15, 0, 0, 0, 27 12\n L 22 9\n A 9 9, 0, 0, 1, 8 9\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !0, !1, !1, !0]);
|
||||
e.setAttribute("clip-path", "polygon(-3 -3, 33 -3, 33 12, -3 12)"), u.appendChild(e)
|
||||
}
|
||||
if ("/" == i && "\\" == o) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 22 9\n A 30 30, 0, 0, 0, 22 45\n L 28 45\n A 30 30, 0, 0, 1, 28 9\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !0, !0, !1, !1]);
|
||||
e.setAttribute("clip-path", "polygon(6 -3, 33 -3, 33 57, 6 57)"), u.appendChild(e)
|
||||
}
|
||||
if ("\\" == c && "/" == l) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
||||
t.setAttribute("d", "\n M 8 9\n A 30 30, 0, 0, 1, 8 45\n L 2 45\n A 30 30, 0, 0, 0, 2 9\n Z"), u.appendChild(t);
|
||||
const e = r([!1, !1, !1, !1, !1, !1, !0, !0]);
|
||||
e.setAttribute("clip-path", "polygon(-3 -3, 9 -3, 9 57, -3 57)"), u.appendChild(e)
|
||||
}
|
||||
return u
|
||||
}
|
||||
},
|
||||
n = {
|
||||
"\u250c": "+",
|
||||
"\u2510": "+",
|
||||
"\u2514": "+",
|
||||
"\u2518": "+",
|
||||
"\u2500": "-",
|
||||
"\u25ba": ">",
|
||||
"'": ".",
|
||||
"`": ".",
|
||||
V: "v"
|
||||
};
|
||||
for (const [o, l] of Object.entries(n)) e[o] = t => e[l](t);
|
||||
|
||||
function r([t, e, n, r, s, i, o, l]) {
|
||||
const c = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
if (t) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 15), t.setAttribute("y1", 0), t.setAttribute("x2", 15), t.setAttribute("y2", 27), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (e) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 15), t.setAttribute("y1", 27), t.setAttribute("x2", 30), t.setAttribute("y2", 27), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (n) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 15), t.setAttribute("y1", 27), t.setAttribute("x2", 15), t.setAttribute("y2", 54), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (r) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 0), t.setAttribute("y1", 27), t.setAttribute("x2", 15), t.setAttribute("y2", 27), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (document.createElementNS("http://www.w3.org/2000/svg", "polygon").setAttribute("points", [
|
||||
[0, 0],
|
||||
[20.6, 0],
|
||||
[20.6, 3],
|
||||
[0, 3]
|
||||
].map(([t, e]) => `${t},${e}`).join(" ")), s) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 30), t.setAttribute("y1", 0), t.setAttribute("x2", 15), t.setAttribute("y2", 27), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (i) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 15), t.setAttribute("y1", 27), t.setAttribute("x2", 30), t.setAttribute("y2", 54), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (o) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 15), t.setAttribute("y1", 27), t.setAttribute("x2", 0), t.setAttribute("y2", 54), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
if (l) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", 0), t.setAttribute("y1", 0), t.setAttribute("x2", 15), t.setAttribute("y2", 27), t.setAttribute("class", "part"), c.appendChild(t)
|
||||
}
|
||||
return c
|
||||
}
|
||||
|
||||
function s(t, e) {
|
||||
const n = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
r = document.createElementNS("http://www.w3.org/2000/svg", "text"),
|
||||
s = document.createTextNode(t);
|
||||
return r.appendChild(s), e && r.setAttribute("class", "reserved"), r.setAttribute("transform", [
|
||||
[15, 24]
|
||||
].map(([t, e]) => `translate(${t}, ${e})`).join(" ")), n.appendChild(r), n
|
||||
}
|
||||
|
||||
function i(t, [e, n]) {
|
||||
let r = " ",
|
||||
s = " ",
|
||||
i = " ",
|
||||
o = " ",
|
||||
l = " ",
|
||||
c = " ",
|
||||
u = " ",
|
||||
p = " ";
|
||||
return n > 0 && (s = t[n - 1][e] || " "), e < t[n].length - 1 && (i = t[n][e + 1] || " "), n < t.length - 1 && (o = t[n + 1][e] || " "), e > 0 && (r = t[n][e - 1] || " "), n > 0 && e < t[n - 1].length - 1 && (l = t[n - 1][e + 1] || " "), n + 1 < t.length && e < t[n + 1].length && (c = t[n + 1][e + 1] || " "), n < t.length - 1 && e > 0 && (u = t[n + 1][e - 1] || " "), n > 0 && e > 0 && (p = t[n - 1][e - 1] || " "), [s, i, o, r, l, c, u, p]
|
||||
}
|
||||
e[">"] = ([t, e, n, r, s, i, o, l]) => {
|
||||
const c = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
u = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
||||
u.setAttribute("points", "0,0 42,18 0,36");
|
||||
let p = 0;
|
||||
return "*" != e && "o" != e && "#" != e || (p -= 18), u.setAttribute("transform", `translate(${p} 9)`), c.appendChild(u), c
|
||||
}, e["<"] = ([t, e, n, r, s, i, o, l]) => {
|
||||
const c = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
u = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
||||
u.setAttribute("points", "0,0 42,18 0,36");
|
||||
let p = 30;
|
||||
return "*" != r && "o" != r && "#" != r || (p += 18), u.setAttribute("transform", `translate(${p} 9) translate(0 36) rotate(180)`), c.appendChild(u), c
|
||||
}, e.v = ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
p = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
||||
p.setAttribute("points", "0,0 42,18 0,36");
|
||||
let a = 36;
|
||||
return " " == n ? a = 12 : "_" == n ? a += 18 : "*" != n && "o" != n && "#" != n || (a -= 18), "/" == i ? p.setAttribute("transform", "translate(-36 33) rotate(112.5, 42, 18)") : "\\" == c ? p.setAttribute("transform", "translate(-18 33) rotate(67.5, 42, 18)") : p.setAttribute("transform", `translate(33 ${a}) rotate(90)`), u.appendChild(p), u.appendChild(r([
|
||||
["|", "+"].includes(t), !1, ["|", "+"].includes(t), !1, ["/"].includes(i), !1, !1, ["\\"].includes(c)
|
||||
])), u
|
||||
}, e["^"] = ([t, e, n, s, i, o, l, c]) => {
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
p = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
||||
p.setAttribute("points", "0,0 42,18 0,36");
|
||||
let a = 42;
|
||||
return "-" == t && (a -= 15), "/" == l ? p.setAttribute("transform", "translate(-18 -15) rotate(-67.5, 42, 18)") : "\\" == o ? p.setAttribute("transform", "translate(-36 -15) rotate(-112.5, 42, 18)") : p.setAttribute("transform", `translate(-3 ${a}) rotate(-90)`), u.appendChild(p), u.appendChild(r([!1, !1, ["+", "|"].includes(n), !1, !1, ["\\"].includes(o), ["/"].includes(l), !1])), u
|
||||
}, t = function(t, n, r) {
|
||||
const o = t.split("\n").map(t => t.trimEnd().split(""));
|
||||
o.shift(), o.splice(-1);
|
||||
let l = 0;
|
||||
const c = o.length;
|
||||
for (let e = 0; e < o.length; e++)
|
||||
for (let t = 0; t < o[e].length; t++) o[e].length > l && (l = o[t].length);
|
||||
var u = document.createElementNS("http://www.w3.org/2000/svg", "svg");
|
||||
u.setAttribute("width", 30 * l * n), u.setAttribute("height", 54 * c * n), u.setAttribute("debug", r), u.setAttribute("viewBox", `0 0 ${30*l+0} ${54*c+0}`), u.setAttribute("class", "debug");
|
||||
var p = document.createElementNS("http://www.w3.org/2000/svg", "style");
|
||||
return p.innerHTML = '\n.diagram {\n display: block;\n}\n\n.diagram line, .diagram circle, .diagram rect {\n stroke: white;\n}\n\n.diagram line {\n stroke-width: 2;\n}\n\n.diagram circle {\n r: 3.5;\n}\n\n.diagram rect {\n width: 6px;\n height: 6px;\n}\n\ntext {\n fill:white;\n}\n\n.diagram text, .glyph, .debug text {\n /** font-family: Consolas, Monaco, \'Andale Mono\', \'Ubuntu Mono\', monospace; **/\n font-family: Iosevka Fixed, monospace;\n font-size: 3em;\n text-anchor: middle;\n alignment-baseline: central;\n white-space: pre;\n}\n\n.reserved {\n fill: transparent;\n white-space: pre;\n}\n\n.debug[debug="true"] .reserved {\n fill: white;\n opacity: 0.5;\n}\n\n.debug[debug="true"] line.grid {\n stroke: white;\n stroke-width: 0.2;\n stroke-linecap: butt;\n fill: white;\n opacity: 1%;\n}\n\npolygon {\n stroke-width: 0;\n}\n\n.debug[debug="true"] polygon.inner {\n fill: white;\n stroke: white;\n opacity: 5%;\n}\n\npolygon {\n stroke: white;\n /** stroke-width: 0.2; **/\n stroke-linecap: butt;\n fill: white;\n}\n\n.debug[debug="true"] polygon,\n.debug[debug="true"] line.grid\n{\n opacity: 10%;\n}\n\n.debug[debug="true"] polygon,\n.debug[debug="true"] path,\n.debug[debug="true"] circle\n{\n opacity: 50%;\n}\n\n.debug[debug="true"] polygon {\n fill: red;\n stroke: red;\n}\n\n/**\ncircle {\n fill: white;\n}\n**/\n\n.debug[debug="true"] circle,\n.debug[debug="true"] path\n{\n opacity: 50%;\n fill: red;\n}\n\n.debug[debug="true"] circle {\n stroke: red;\n}\n\n.debug[debug="true"] .inner {\n stroke-width: 0.2;\n}\n\nline.part {\n stroke-width: 6;\n stroke-linecap: butt;\n stroke: white;\n}\n\n.debug[debug="true"] line.part {\n opacity: 50%;\n stroke: red;\n}\n\n.debug[debug="true"] line.center {\n stroke-width: 3;\n stroke-linecap: butt;\n opacity: 10%;\n stroke: white;\n}\n\ntext::selection {\n fill: white;\n background-color: #EEE;\n}\n ', u.appendChild(p), u.appendChild(function(t) {
|
||||
const n = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
for (let r = 0; r < t.length; r++)
|
||||
for (let o = 0; o < t[r].length; o++) {
|
||||
const l = t[r][o];
|
||||
if (" " == l || '"' == l) continue;
|
||||
let c = e[l];
|
||||
const u = document.createElementNS("http://www.w3.org/2000/svg", "g");
|
||||
let p = !1;
|
||||
for (let e = 0; e < o; e++) '"' == t[r][e] && (p = !p);
|
||||
const a = i(t, [o, r]);
|
||||
if (l.match(/[A-Za-z0-9]/)) {
|
||||
const [, t, , e] = a;
|
||||
p = p || e.match(/[A-Za-uw-z0-9]/) || t.match(/[A-Za-uw-z0-9]/)
|
||||
}
|
||||
c = c && !p, c && u.appendChild(e[l](a)), u.appendChild(s(l, c)), u.setAttribute("transform", `translate(${30*o} ${54*r})`), n.appendChild(u)
|
||||
}
|
||||
return n
|
||||
}(o)), r && u.appendChild(function(t, e) {
|
||||
const n = document.createElementNS("http://www.w3.org/2000/svg", "g"),
|
||||
r = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
r.setAttribute("x1", 15), r.setAttribute("y1", 0), r.setAttribute("x2", 15), r.setAttribute("y2", 54), r.setAttribute("class", "center");
|
||||
const s = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
s.setAttribute("x1", 0), s.setAttribute("y1", 30), s.setAttribute("x2", 30), s.setAttribute("y2", 54), s.setAttribute("class", "center");
|
||||
for (let i = 0; i <= 30 * t; i += 3) {
|
||||
const t = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
t.setAttribute("x1", i), t.setAttribute("y1", 0), t.setAttribute("x2", i), t.setAttribute("y2", 54 * e), t.setAttribute("class", "grid"), n.appendChild(t)
|
||||
}
|
||||
for (let i = 0; i <= 54 * e; i += 3) {
|
||||
const e = document.createElementNS("http://www.w3.org/2000/svg", "line");
|
||||
e.setAttribute("x1", 0), e.setAttribute("y1", i), e.setAttribute("x2", 30 * t), e.setAttribute("y2", i), e.setAttribute("class", "grid"), n.appendChild(e)
|
||||
}
|
||||
return n
|
||||
}(l, c)), u
|
||||
}, document.addEventListener("DOMContentLoaded", (function() {
|
||||
for (const e of document.querySelectorAll("script[type='text/typogram']")) {
|
||||
if (e.hasAttribute("disabled")) continue;
|
||||
const n = e.innerText,
|
||||
r = Number(e.getAttribute("zoom") || .3),
|
||||
s = e.hasAttribute("grid"),
|
||||
i = t(n, r, s);
|
||||
e.parentNode.insertBefore(i, e.nextSibling)
|
||||
}
|
||||
}))
|
||||
}();
|
22
index.html
@ -1,24 +1,28 @@
|
||||
---
|
||||
layout: default
|
||||
title: latest posts <span style="font-size:20px;"><a href="/feed/blog.xml"><i class="fas fa-rss-square"></i></a></span>
|
||||
subtitle: all the posts, in reverse chronological. there is an atom feed above.
|
||||
title: Andrew Conlin's blog
|
||||
permalink: /
|
||||
backlink: false
|
||||
---
|
||||
|
||||
|
||||
This site is designed to be kept as simple as possible.<br>
|
||||
It is pure HTML/CSS [*], which keeps things small, fast and accessible.<br>
|
||||
* I use a self-hosted instance of <a href="https://umami.is">umami</a> for analytics. It respects do-not-track signals.<br>
|
||||
--<br>
|
||||
email: <a href="mailto:andrew@andrewconl.in">andrew@andrewconl.in</a><br>
|
||||
masto: <a href="https://mastodon.scot/@andrwcnln">andrwcnln@mastodon.scot</a><br>
|
||||
github: <a href="https://github.com/andrwcnln">@andrwcnln</a><br>
|
||||
--<br>
|
||||
<a href="/til">til</a> · <a href="/feed.xml">rss</a> · <a href="/misc">misc</a>
|
||||
<br><br>
|
||||
<hr>
|
||||
<ul style="list-style-type:none;margin:0;padding:0;">
|
||||
{% for post in site.posts %}
|
||||
{% assign category = post.category %}
|
||||
{% if category == 'blog' %}
|
||||
<li>
|
||||
<h4><a href="{{ post.url }}">{{ post.title }}</a></h4>
|
||||
<div style="font-style: italic;">
|
||||
<img src="/assets/images/write.ico" style="display: inline;height: 20px;width: 20px;"> {{ post.date | date_to_string }}
|
||||
</div>
|
||||
{{ post.content | strip_html | truncatewords: 30 }}
|
||||
<br>
|
||||
<br>
|
||||
<p><a href="{{ post.url }}">{{ post.title }}</a> -- {{ post.date | date_to_string }}</p>
|
||||
</li>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
|
5
misc.html
Normal file
@ -0,0 +1,5 @@
|
||||
---
|
||||
layout: default
|
||||
title: Miscellaneous
|
||||
backlink: true
|
||||
---
|
14
til.html
@ -1,24 +1,18 @@
|
||||
---
|
||||
layout: default
|
||||
title: latest tils <span style="font-size:20px;"><a href="/feed/til.xml"><i class="fas fa-rss-square"></i></a></span>
|
||||
subtitle: my collection of tils (today-i-learned). i use this mainly to collect solutions to weird errors i have faced, and detail the little projects that i work on. this has its own atom feed (above) as they are typically very different from my other posts. all tils are blog posts but not all blog posts are tils.
|
||||
title: TILs
|
||||
permalink: /til/
|
||||
backlink: true
|
||||
---
|
||||
|
||||
|
||||
My collection of TILs (Today-I-Learned). I use this mainly to collect solutions to weird errors I have faced, and detail the little projects that I work on. This has its own atom feed (above) as they are typically very different from my other posts. All TILs are blog posts but not all blog posts are TILs.<br>
|
||||
<hr>
|
||||
<ul style="list-style-type:none;margin:0;padding:0;">
|
||||
{% for post in site.posts %}
|
||||
{% assign category = post.category %}
|
||||
{% if category == 'til' %}
|
||||
<li>
|
||||
<h4><a href="{{ post.url }}">{{ post.title }}</a></h4>
|
||||
<div style="font-family:Geist;font-style: italic;">
|
||||
<img src="/assets/images/write.ico" style="display: inline;height: 20px;width: 20px;"> {{ post.date | date_to_string }}
|
||||
</div>
|
||||
{{ post.content | strip_html | truncatewords: 30 }}
|
||||
<br>
|
||||
<br>
|
||||
<p><a href="{{ post.url }}">{{ post.title }}</a> -- {{ post.date | date_to_string }}</p>
|
||||
</li>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
|