1

Super basic page rendering

This commit is contained in:
Evan Pratten 2022-11-25 12:03:14 -05:00
parent deed18de91
commit 9cd0ac5b88
17 changed files with 180 additions and 768 deletions

View File

@ -14,11 +14,13 @@ render_emoji = true
external_links_target_blank = true
[extra]
# Website
domain_name = "ewpratten.com"
# Me
name = "Evan Pratten"
profession = "Software Developer"
email = "contact@ewpratten.com"
twitter = "ewpratten"
profile_photo = "https://avatars.githubusercontent.com/u/21065412"
# Accounts
email = "evan@ewpratten.com"
github = "ewpratten"
qrz = "va3zza"
linkedin = "ewpratten"
profile_photo = "https://avatars.githubusercontent.com/u/21065412"

View File

@ -0,0 +1,3 @@
#instagram-embed-0 {
margin: auto !important;
}

View File

@ -0,0 +1,4 @@
.markdown-body table {
margin: auto !important;
width: fit-content !important;
}

View File

@ -0,0 +1,4 @@
.mermaid {
width: fit-content;
margin: auto;
}

View File

@ -0,0 +1,4 @@
.tiktok-embed {
border: none !important;
margin: auto !important;
}

View File

@ -0,0 +1,9 @@
.yt-embed {
width: 100%;
height: 400px;
iframe {
width: 100%;
height: 100%;
}
}

View File

@ -1,321 +0,0 @@
h1,
h2,
h3,
h4,
h5,
h6 {
font-family: "Urbanist", sans-serif;
font-weight: bolder;
}
p,
li,
span {
font-family: "Rubik", sans-serif;
font-weight: normal;
}
a {
text-decoration: none;
&:visited {
color: blue;
}
&:hover {
color: blueviolet;
}
}
body {
// margin-bottom: 30px;
margin: 0;
}
.mobile-hidden {
@media only screen and (max-width: 650px) {
display: none;
}
}
.yt-embed {
width: 100%;
height: 400px;
iframe {
width: 100%;
height: 100%;
}
}
.container {
max-width: 700px;
margin: auto;
padding-left: 10px;
padding-right: 10px;
}
.profile-card {
margin-top: 30px;
margin-bottom: 30px;
margin-left: auto;
margin-right: auto;
.row {
width: max-content;
max-width: 95vw;
margin: auto;
overflow-wrap: normal;
.headshot-container {
display: inline-block;
max-width: 150px;
@media only screen and (max-width: 399px) {
display: block;
margin: auto;
text-align: center;
}
img {
width: 100%;
}
}
.text-container {
display: inline-block;
margin-left: 20px;
h1,
p {
margin: 0px;
a {
text-decoration: none;
}
}
}
}
}
.navigation-bar {
text-align: center;
p {
margin: 0px;
a {
text-decoration: none;
}
}
}
.blog-post-li {
margin: 0.25em;
}
.gray {
color: gray;
}
ul {
padding-left: 20px;
}
.events-list {
& > li {
color: gray;
}
& > ul {
& > li {
& > div {
display: table-row;
& > span {
display: table-cell;
&:first-of-type {
color: gray;
width: 30px;
text-align: center;
padding-right: 8px;
// Only Firefox supports this
// letter-spacing: -0.35em;
// text-transform: full-width;
}
}
}
}
}
}
.mermaid {
width: fit-content;
margin: auto;
}
.zola-github-card {
border-radius: 5px;
padding-top: 5px;
padding-bottom: 1px;
box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
transition: all 0.1s ease 0s;
&:hover {
box-shadow: rgba(0, 0, 0, 0.5) 0px 3px 15px;
}
}
#instagram-embed-0 {
margin: auto !important;
}
.tiktok-embed {
border: none !important;
margin: auto !important;
}
.markdown-body table {
margin: auto !important;
width: fit-content !important;
}
.blog-post-listing-item {
color: black !important;
& > div {
border-left: solid rgb(201, 201, 201) 5px;
&:hover {
border-left: solid black 5px;
}
padding-left: 5px;
}
h4,
h1,
p {
padding: 0;
margin: 0;
}
h1 {
margin-bottom: 10px;
}
&:hover {
color: rgb(85, 85, 85) !important;
}
}
.pn-previous,
.pn-next {
border: 1px solid black;
border-radius: 5px;
padding: 5px;
color: black !important;
&:hover {
color: rgb(85, 85, 85) !important;
border: 1px solid rgb(85, 85, 85) !important;
}
}
#footer {
margin-top: 2em;
text-align:center;
}
.carded-section {
border: 1px solid black;
width: 100%;
& > .header {
background-color: aliceblue;
padding-left: 30px;
padding-right: 30px;
padding-top: 15px;
padding-bottom: 15px;
border-bottom: 1px solid rgb(201, 201, 201);
& > span {
font-size: 1.5em;
font-weight: bolder;
}
}
& > .content {
padding-left: 15px;
padding-right: 15px;
}
}
.portfolio-sellout {
margin-top: 15px;
background-color: #afa79e;
border-radius: 5px;
text-align: center;
// color: white;
padding-top: 5px;
padding-bottom: 5px;
box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
// & > p > a {
// color: aqua;
// }
}
.hover-help {
&:hover {
cursor: help;
}
border-bottom: 1px double rgb(171, 167, 167);
}
.small {
font-size: 0.5em;
}
.hover-shadow {
&:hover {
box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}
}
#main-skills {
display: flex;
flex-wrap: wrap;
width: 100%;
justify-content: space-evenly;
@media screen and (max-width: 455px) {
justify-content: left;
}
ul {
margin:0;
}
}
.project {
border: 1px solid gray;
border-radius: 5px;
padding: 1em;
margin-bottom: 1em;
p {
margin-top:0.25em;
margin-bottom:0.25em;
}
h3 {
border-bottom: 1px solid lightgrey;
margin-top:0.25em;
margin-bottom:0.5em;
padding-bottom: 0.5em;
}
ul{
margin-bottom:0;
}
}
.homepage-showoff {
padding-left: 1em;
padding-right: 1em;
padding-top: 0.25em;
padding-bottom: 0.25em;
background-color: #e3e3e3;
color: black;
}
.home-list {
&>ul>li {
padding-top:0.5em;
}
}

View File

@ -1,51 +0,0 @@
.project-mosaic {
display: flex;
flex-wrap: wrap;
justify-content: space-evenly;
width: 100%;
@media (min-width: 437px) {
.project-small {
max-width: 175px !important;
}
}
.conform-height {
height: unset !important;
}
.project {
border: 1px solid #ccc;
border-radius: 5px;
padding: 1rem;
margin-bottom: 1rem;
max-width: 300px;
height: max-content;
img {
margin-bottom: 0.5em;
border-bottom: 1px solid #ccc;
padding-bottom: 0.75em;
width: 100%;
}
h3 {
margin: 0;
margin-bottom: 0.25em;
}
p {
margin-top: 0;
color: rgb(84, 84, 84);
}
span {
display: inline-block;
border-top: 1px solid #ccc;
font-size: 2em;
width: 100%;
padding-top: 0.25em;
text-align: center;
}
}
}

View File

@ -0,0 +1,44 @@
@import url("https://fonts.googleapis.com/css2?family=Roboto&family=Urbanist:wght@700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,400;0,700;1,400;1,700&display=swap");
h1,
h2,
h3,
h4,
h5,
h6 {
font-family: "Urbanist", sans-serif;
font-weight: bolder;
}
p,
li,
span {
font-family: "Rubik", sans-serif;
font-weight: normal;
}
a {
text-decoration: none;
&:visited {
color: blue;
}
&:hover {
color: blueviolet;
}
}
body {
margin: 0;
}
.gray {
color: gray;
}
.hover-help {
&:hover {
cursor: help;
}
border-bottom: 1px double rgb(171, 167, 167);
}

15
sass/styles/utils.scss Normal file
View File

@ -0,0 +1,15 @@
.mobile-hidden {
@media only screen and (max-width: 650px) {
display: none;
}
}
.small {
font-size: 0.5em;
}
.hover-shadow {
&:hover {
box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}
}

View File

@ -1,165 +1,73 @@
{# Allow extenders to pass through variables #}
{% block variable_wormhole %}
{% set title = "NO TITLE SET" %}
{% set description = "" %}
{% set is_article = false %}
{% endblock variable_wormhole %}
<!DOCTYPE html>
<html lang="en">
<head>
{% block head %}
<!-- Google Tag Manager -->
<script>(function (w, d, s, l, i) {
w[l] = w[l] || []; w[l].push({
'gtm.start':
new Date().getTime(), event: 'gtm.js'
}); var f = d.getElementsByTagName(s)[0],
j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src =
'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f);
})(window, document, 'script', 'dataLayer', 'GTM-KFJ95RP');</script>
<!-- End Google Tag Manager -->
{# Page metadata #}
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="shortcut icon" type="image/jpg" href="{{config.extra.profile_photo}}" />
{% if current_url %}
<link rel="canonical" href="{{current_url}}" />
{% endif %}
{% include "components/metadata/advertise-rss.html" %}
{% include "components/metadata/opengraph.html" %}
<link rel="alternate" type="application/rss+xml" title="RSS" href="{{get_url(path=" rss.xml",
trailing_slash=false)}}">
<link rel="webmention" href="https://webmention.io/ewpratten.com/webmention" />
<link rel="pingback" href="https://webmention.io/ewpratten.com/xmlrpc" />
<title>{% block title %}{% endblock title %} | {{config.extra.name}}</title>
{# Page title #}
<title>{{title}} | {{config.title}}</title>
{# Preconnects for external resources #}
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Roboto&family=Urbanist:wght@700&display=swap" rel="stylesheet">
<link href="https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,400;0,700;1,400;1,700&display=swap"
rel="stylesheet">
<link rel="preconnect" href="https://maxst.icons8.com">
{# External styles #}
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/css/bootstrap.min.css" rel="stylesheet"
integrity="sha384-Zenh87qX5JnK2Jl0vWa8Ck2rdkQ2Bzep5IDxbcnCeuOxjzrPF/et3URy9Bv1WTRi" crossorigin="anonymous">
<link rel="stylesheet"
href="https://maxst.icons8.com/vue-static/landings/line-awesome/line-awesome/1.3.0/css/line-awesome.min.css">
<link rel="stylesheet" href="/styles/layout.css">
<link rel="stylesheet" href="/styles/project_mosaic.css">
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/github-markdown-css/4.0.0/github-markdown.min.css"
integrity="sha512-Oy18vBnbSJkXTndr2n6lDMO5NN31UljR8e/ICzVPrGpSud4Gkckb8yUpqhKuUNoE+o9gAb4O/rAxxw1ojyUVzg=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
{# Site-wide styles #}
<link rel="stylesheet" href="/styles/fixes/instagram.css">
<link rel="stylesheet" href="/styles/fixes/markdown.css">
<link rel="stylesheet" href="/styles/fixes/mermaid.css">
<link rel="stylesheet" href="/styles/fixes/tiktok.css">
<link rel="stylesheet" href="/styles/fixes/youtube.css">
<link rel="stylesheet" href="/styles/typography.css">
<link rel="stylesheet" href="/styles/utils.css">
<meta name="twitter:card" content="summary" />
<meta name="og:site" content="ewpratten.com" />
<meta name="og:image" content="{{config.extra.profile_photo}}" />
<meta name="twitter:creator" content="@ewpratten">
<meta name="og:site_name" content="Evan Pratten (VA3ZZA)" />
{% endblock head %}
{# Component styles #}
{% block component_styles %}
{% endblock component_styles %}
</head>
<body>
<div class="container">
<div class="profile-card">
{% block profile %}
<div class="row">
<div class="headshot-container">
<img src="{{config.extra.profile_photo}}" alt="Headshot">
</div>
<div class="text-container">
<h1>{{config.extra.name}}</h1>
<p>
{{config.extra.profession}}
<br><br>
<a href="mailto:{{config.extra.email}}" rel="me"><i class="las la-envelope"></i>
{{config.extra.email}}</a><br>
<a href="https://github.com/{{config.extra.github}}" rel="me"><i class="lab la-github"></i>
{{config.extra.github}}</a><br>
<a href="https://www.linkedin.com/in/{{config.extra.linkedin}}" rel="me"><i
class="lab la-linkedin"></i>
{{config.extra.linkedin}}</a><br>
<a href="https://qrz.com/db/{{config.extra.qrz}}" rel="me"><i
class="las la-broadcast-tower"></i>
{{config.extra.qrz}}</a>
</p>
</div>
</div>
{% endblock profile %}
</div>
<div class="navigation-bar">
<hr>
<p>
<a href="/">Home</a> |
<a href="/blog">Blog</a> |
{# <a href="/blog">Rabbit Hole</a> | #}
{# <a href="/work">My Work</a> | #}
{# <a href="/network">Network</a> | #}
<a href="/contact">Contact</a>
{# <a href="/hobbies">Hobbies</a> #}
{# <a href="/whois">WHOIS</a> #}
{# <a href="/rfc">RFC</a> #}
</p>
<hr>
</div>
<div class="page-content">
{% block content %}
{% endblock content %}
{# The whole page #}
<div class="page">
{# Actual content #}
<div id="content" class="container">
<article class="markdown-body">
{% block content %}{% endblock content %}
</article>
</div>
<div id="footer">
<p class="gray">-- EOF --</p>
<p>
<em>
<a href="https://github.com/ewpratten/va3zza.com"><i class="lab la-github"></i></a>
<a href="https://status.ewpratten.com"><i class="las la-info-circle"></i></a>
<a href="/rss.xml"><i class="las la-rss"></i></a><br>
Thanks for reading :)<br>
Site design & content by: <a href="/info">Evan Pratten</a><br>
Consider <a href="/donate" target="_blank">supporting my work</a> if you like what you see<br>
</em>
</p>
</div>
{# Footer #}
{% include "components/footer.html" %}
</div>
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-5912H4H03P"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag() { dataLayer.push(arguments); }
gtag('js', new Date());
gtag('config', 'G-5912H4H03P');
</script>
<script>
if (window.performance && performance.getEntriesByType) { // avoid error in Safari 10, IE9- and other old browsers
let navTiming = performance.getEntriesByType('navigation')
if (navTiming.length > 0) { // still not supported as of Safari 14...
let serverTiming = navTiming[0].serverTiming
if (serverTiming && serverTiming.length > 0) {
for (let i = 0; i < serverTiming.length; i++) {
if (serverTiming[i].name == 'source') {
if (serverTiming[i].description == 'net44') {
document.getElementById('ampr-notice').style.display = 'block';
}
}
}
}
}
}
</script>
{# URL Rewriter for retrylife.ca #}
<script>
if (window.location.hostname == 'retrylife.ca') {
window.location.href = window.location.href.replace('retrylife.ca', 'ewpratten.com');
}
</script>
{# Meta magic for mastodon verification #}
<a rel="me" href="https://social.ewpratten.com/@evan" style="display:none;"></a>
{# External scripts #}
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/js/bootstrap.bundle.min.js"
integrity="sha384-OERcA2EqjJCMA+/3y+gxIOqMEjwtxJY7qPCqsdltbNJuaOe923+mo//f6V8Qbsw3"
crossorigin="anonymous"></script>
</body>
</html>

View File

View File

@ -0,0 +1,5 @@
{% if current_url %}
<link rel="canonical" href="{{current_url}}" />
{% endif %}
<link rel="alternate" type="application/rss+xml" title="RSS" href="{{get_url(path=config.feed_filename, trailing_slash=false)}}">

View File

@ -0,0 +1,21 @@
{# Site info #}
<meta name="twitter:card" content="summary" />
<meta name="og:site" content="{{config.extra.domain_name}}" />
<meta name="og:site_name" content="{{config.title}}" />
{# Page image #}
<meta name="og:image"
content="{% block opengraph_image_url %}{{config.extra.profile_photo}}{% endblock opengraph_image_url %}" />
{# Page description #}
<meta property="og:description" content="{{description}}" />
<meta property="description" content="{{description}}" />
<meta name="description" content="{{description}}">
{# Page title #}
<meta property="og:title" content="{{title}} - {{config.title}}" />
{# Article-specifics #}
{% if is_article %}
<meta property="og:type" content="article" />
{% endif %}

View File

@ -1,44 +1,13 @@
{% extends "base.html" %}
{% block title %}
{{section.title}}
{% endblock title %}
{% block head %}
{# Pass data through to the base template #}
{% block variable_wormhole %}
{{ super() }}
<meta property="og:description" content="{{config.description}}" />
<meta property="description" content="{{config.description}}" />
<meta name="description" content="{{config.description}}">
<meta name="og:title" content="Evan Pratten (VA3ZZA)" />
<script type="application/ld+json">
{% set person_ld = load_data(path="static/person.jsonld")%}
{% if person_ld %}{{person_ld | safe}}{% endif %}
</script>
<script type="application/ld+json">
{# Import our template file #}
{% set template = load_data(path="jsonld_templates/website.jsonld") %}
{# Now we can fill in any additional data #}
{{ template |
replace(from="{{url}}", to=config.base_url) |
replace(from="{{title}}", to=section.title) |
replace(from="{{description}}", to=config.description) |
replace(from="{{avatar}}", to=config.extra.profile_photo) |
safe
}}
</script>
{# Handle flags #}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/6.4.3/css/flag-icons.min.css"
integrity="sha512-uvXdJud8WaOlQFjlz9B15Yy2Au/bMAvz79F7Xa6OakCl2jvQPdHD0hb3dEqZRdSwG4/sknePXlE7GiarwA/9Wg=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
{% endblock head %}
{% set title = section.title %}
{% set description = config.description %}
{% endblock variable_wormhole %}
{# Page content #}
{% block content %}
{# <br>
<article class="markdown-body"> #}
{{section.content | safe}}
{# </article> #}
{{ section.content | safe }}
{% endblock content %}

View File

@ -1,118 +1,14 @@
{% extends "base.html" %}
{% block title %}
{{page.title}}
{% endblock title %}
{% block head %}
{# <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/github-markdown-css/4.0.0/github-markdown.min.css"
integrity="sha512-Oy18vBnbSJkXTndr2n6lDMO5NN31UljR8e/ICzVPrGpSud4Gkckb8yUpqhKuUNoE+o9gAb4O/rAxxw1ojyUVzg=="
crossorigin="anonymous" referrerpolicy="no-referrer" /> #}
{# Pass data through to the base template #}
{% block variable_wormhole %}
{{ super() }}
{% set title = page.title %}
{% set description = page.description %}
{% set is_article = true %}
{% endblock variable_wormhole %}
{# Disable crawling if requested #}
{% if page.extra.no_crawl %}
<meta name="robots" content="noindex, nofollow">
{% endif %}
{% if page.extra.uses_katex %}
<script src='https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js?config=TeX-MML-AM_CHTML' async></script>
<script type="text/x-mathjax-config">
MathJax.Hub.Config({tex2jax: {inlineMath: [['$','$'], ['\\(','\\)']], displayMath: [ ['$$','$$'], ['\[','\]'] ]}});
</script>
{% endif %}
<meta property="og:title" content="{{page.title}} - Evan Pratten" />
<meta property="og:type" content="article" />
{% if page.description %}
<meta property="og:description" content="{{page.description}}" />
<meta property="description" content="{{page.description}}" />
{% else %}
<meta property="og:description" content="{{config.description}}" />
<meta property="description" content="{{config.description}}" />
{% endif %}
<meta property="article:published_time" content="{{page.date}}T00:00:00" />
{# Handle auto-centering request #}
{% if page.extra.auto_center_images %}
<style>
img {
display: block;
margin-left: auto;
margin-right: auto;
}
</style>
{% endif %}
{# Handle flags #}
{% if page.extra.uses_flags %}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/6.4.3/css/flag-icons.min.css"
integrity="sha512-uvXdJud8WaOlQFjlz9B15Yy2Au/bMAvz79F7Xa6OakCl2jvQPdHD0hb3dEqZRdSwG4/sknePXlE7GiarwA/9Wg=="
crossorigin="anonymous" referrerpolicy="no-referrer" />
{% endif %}
{# Handle loading JSONLD #}
{% if page.extra.is_rfc or page.description and page.date %}
<script type="application/ld+json">
{# Import our template file #}
{% set template = load_data(path="jsonld_templates/blog_post.jsonld") %}
{# Now we can fill in any additional data #}
{{ template |
replace(from="{{url}}", to=config.base_url ~ page.path) |
replace(from="{{title}}", to=page.title) |
replace(from="{{date}}", to=page.date) |
replace(from="{{profile_pic}}", to=config.extra.profile_photo) |
safe
}}
</script>
{% endif %}
{# Handle redirects if needed #}
{% if page.extra.redir_to %}
<meta http-equiv="refresh" content="0; url={{page.extra.redir_to}}" />
{% endif %}
{% endblock head %}
{% block profile %}
<div class="row">
<div class="headshot-container">
<img src="{{config.extra.profile_photo}}" alt="Headshot" style="height:50px;width:auto;">
</div>
<div class="text-container">
<h1>{{config.extra.name}}</h1>
<p>
{{config.extra.profession}}
</p>
</div>
</div>
{% endblock profile %}
{# Page content #}
{% block content %}
<br><br>
<article class="markdown-body">
{% if page.description %}
<h1 style="border:none;margin-bottom:0;padding-bottom:0">{{page.title}}</h1>
<h3 style="margin-top:0;color:gray;padding-bottom:.3em;border-bottom:1px solid #eaecef;">
<em>
<span style="color:rgb(186, 186, 186)">/*</span>
{{page.description}}
<span style="color:rgb(186, 186, 186)">*/</span>
</em>
</h3>
{% else %}
<h1>{{page.title}}</h1>
{% endif %}
<div style="text-align: justify;">
{{page.content | safe}}
</div>
</article>
{% if page.extra.uses_twitter %}
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
{% endif %}
{% if page.extra.uses_graphviz %}
<script src="https://cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.js"></script>
{% endif %}
{{ page.content | safe }}
{% endblock content %}

View File

@ -1,113 +1,13 @@
{% extends "base.html" %}
{% block title %}
{{section.title}}
{% endblock title %}
{% block head %}
{# Pass data through to the base template #}
{% block variable_wormhole %}
{{ super() }}
{% set title = section.title %}
{% set description = section.description %}
{% endblock variable_wormhole %}
{# Disable crawling if requested #}
{% if section.extra.no_crawl %}
<meta name="robots" content="noindex, nofollow">
{% endif %}
<meta property="og:title" content="{{section.title}} - Evan Pratten" />
{% if section.description %}
<meta property="og:description" content="{{section.description}}" />
<meta property="description" content="{{section.description}}" />
{% else %}
<meta property="og:description" content="{{config.description}}" />
<meta property="description" content="{{config.description}}" />
{% endif %}
{# Handle listing blog posts nicely in search #}
{% if section.extra.inject_blog_posts %}
<script type="application/ld+json">
{
"@context":"https://schema.org",
"@type":"ItemList",
"itemListElement":[
{% for page in section.pages %}
{% if not page.extra.hidden %}
{
"@type":"ListItem",
"position": "{{loop.index}}",
"item": {
"@type": "Article",
"headline": "{{page.title}}",
"url":"https://ewpratten.com{{page.path | safe}}",
"author": [{
"@type": "Person",
"name": "Evan Pratten",
"url": "https://ewpratten.com"
}]
}
} {% if not loop.last %},{% endif %}
{% endif %}
{% endfor %}
]
}
</script>
{% endif %}
{% endblock head %}
{# Page content #}
{% block content %}
{% if section.extra.enable_gh_markdown %}
<article class="markdown-body">
{% endif %}
{{section.content | safe}}
{% if section.extra.enable_gh_markdown %}
</article>
{% endif %}
{# Blog posts #}
{% if section.extra.inject_blog_posts %}
<ul style="margin:0">
<div>
{# Posts shall be broken down by year #}
{% set title_year = "3000" %}
{% for page in section.pages %}
{% if not page.extra.hidden %}
{% set page_year = page.date | date(format="%Y")%}
{% if page_year != title_year %}
{% set_global title_year = page_year %}
</ul>
<h2>{{title_year}}</h2>
<ul>
{% endif %}
<li class="blog-post-li"><span style="color:{% if page.draft %}red{% else %}gray{% endif %};">{{page.date}}:</span> <a
href="{{page.path}}">{{page.title}}</a>
</li>
{% endif %}
{% endfor %}
</ul>
<br><br>
{% endif %}
{# RFCs #}
{% if section.extra.inject_rfcs %}
<ul>
{% for page in section.pages %}
{% if not page.extra.hidden %}
<li class="blog-post-li"><a href="{{page.path}}">{{page.title}}</a> <span style="color:gray;">({{page.date}})</span>
</li>
{% endif %}
{% endfor %}
</ul>
{% endif %}
{# Notes #}
{% if section.extra.inject_notes %}
<ul>
{% for page in section.pages %}
{% if not page.extra.hidden %}
<li class="blog-post-li"><a href="{{page.path}}">{{page.title}}</a>
</li>
{% endif %}
{% endfor %}
</ul>
{% endif %}
{{ section.content | safe }}
{% endblock content %}