@@ -0,0 +1,4 @@ | |||||
# Pelican LaTeX theme | |||||
A theme for pelican which mimics the look of LaTeX documents. | |||||
@@ -0,0 +1,69 @@ | |||||
.highlight .hll { background-color: #ffffcc } | |||||
.highlight { background: #f8f8f8; } | |||||
.highlight .c { color: #408080; font-style: italic } /* Comment */ | |||||
.highlight .err { border: 1px solid #FF0000 } /* Error */ | |||||
.highlight .k { color: #008000; font-weight: bold } /* Keyword */ | |||||
.highlight .o { color: #666666 } /* Operator */ | |||||
.highlight .ch { color: #408080; font-style: italic } /* Comment.Hashbang */ | |||||
.highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */ | |||||
.highlight .cp { color: #BC7A00 } /* Comment.Preproc */ | |||||
.highlight .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */ | |||||
.highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */ | |||||
.highlight .cs { color: #408080; font-style: italic } /* Comment.Special */ | |||||
.highlight .gd { color: #A00000 } /* Generic.Deleted */ | |||||
.highlight .ge { font-style: italic } /* Generic.Emph */ | |||||
.highlight .gr { color: #FF0000 } /* Generic.Error */ | |||||
.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */ | |||||
.highlight .gi { color: #00A000 } /* Generic.Inserted */ | |||||
.highlight .go { color: #888888 } /* Generic.Output */ | |||||
.highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */ | |||||
.highlight .gs { font-weight: bold } /* Generic.Strong */ | |||||
.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ | |||||
.highlight .gt { color: #0044DD } /* Generic.Traceback */ | |||||
.highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */ | |||||
.highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */ | |||||
.highlight .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */ | |||||
.highlight .kp { color: #008000 } /* Keyword.Pseudo */ | |||||
.highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */ | |||||
.highlight .kt { color: #B00040 } /* Keyword.Type */ | |||||
.highlight .m { color: #666666 } /* Literal.Number */ | |||||
.highlight .s { color: #BA2121 } /* Literal.String */ | |||||
.highlight .na { color: #7D9029 } /* Name.Attribute */ | |||||
.highlight .nb { color: #008000 } /* Name.Builtin */ | |||||
.highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */ | |||||
.highlight .no { color: #880000 } /* Name.Constant */ | |||||
.highlight .nd { color: #AA22FF } /* Name.Decorator */ | |||||
.highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */ | |||||
.highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */ | |||||
.highlight .nf { color: #0000FF } /* Name.Function */ | |||||
.highlight .nl { color: #A0A000 } /* Name.Label */ | |||||
.highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */ | |||||
.highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */ | |||||
.highlight .nv { color: #19177C } /* Name.Variable */ | |||||
.highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */ | |||||
.highlight .w { color: #bbbbbb } /* Text.Whitespace */ | |||||
.highlight .mb { color: #666666 } /* Literal.Number.Bin */ | |||||
.highlight .mf { color: #666666 } /* Literal.Number.Float */ | |||||
.highlight .mh { color: #666666 } /* Literal.Number.Hex */ | |||||
.highlight .mi { color: #666666 } /* Literal.Number.Integer */ | |||||
.highlight .mo { color: #666666 } /* Literal.Number.Oct */ | |||||
.highlight .sa { color: #BA2121 } /* Literal.String.Affix */ | |||||
.highlight .sb { color: #BA2121 } /* Literal.String.Backtick */ | |||||
.highlight .sc { color: #BA2121 } /* Literal.String.Char */ | |||||
.highlight .dl { color: #BA2121 } /* Literal.String.Delimiter */ | |||||
.highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */ | |||||
.highlight .s2 { color: #BA2121 } /* Literal.String.Double */ | |||||
.highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */ | |||||
.highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */ | |||||
.highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */ | |||||
.highlight .sx { color: #008000 } /* Literal.String.Other */ | |||||
.highlight .sr { color: #BB6688 } /* Literal.String.Regex */ | |||||
.highlight .s1 { color: #BA2121 } /* Literal.String.Single */ | |||||
.highlight .ss { color: #19177C } /* Literal.String.Symbol */ | |||||
.highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */ | |||||
.highlight .fm { color: #0000FF } /* Name.Function.Magic */ | |||||
.highlight .vc { color: #19177C } /* Name.Variable.Class */ | |||||
.highlight .vg { color: #19177C } /* Name.Variable.Global */ | |||||
.highlight .vi { color: #19177C } /* Name.Variable.Instance */ | |||||
.highlight .vm { color: #19177C } /* Name.Variable.Magic */ | |||||
.highlight .il { color: #666666 } /* Literal.Number.Integer.Long */ |
@@ -0,0 +1,404 @@ | |||||
@import url("pygment.css"); | |||||
@font-face { | |||||
font-family: 'Latin Modern'; | |||||
font-style: normal; | |||||
font-weight: normal; | |||||
font-display: swap; | |||||
src: url('../fonts/LM-regular.woff2') format('woff2'), | |||||
url('../fonts/LM-regular.woff') format('woff'), | |||||
url('../fonts/LM-regular.ttf') format('truetype'); | |||||
} | |||||
@font-face { | |||||
font-family: 'Latin Modern'; | |||||
font-style: italic; | |||||
font-weight: normal; | |||||
font-display: swap; | |||||
src: url('../fonts/LM-italic.woff2') format('woff2'), | |||||
url('../fonts/LM-italic.woff') format('woff'), | |||||
url('../fonts/LM-italic.ttf') format('truetype'); | |||||
} | |||||
@font-face { | |||||
font-family: 'Latin Modern'; | |||||
font-style: normal; | |||||
font-weight: bold; | |||||
font-display: swap; | |||||
src: url('../fonts/LM-bold.woff2') format('woff2'), | |||||
url('../fonts/LM-bold.woff') format('woff'), | |||||
url('../fonts/LM-bold.ttf') format('truetype'); | |||||
} | |||||
@font-face { | |||||
font-family: 'Latin Modern'; | |||||
font-style: italic; | |||||
font-weight: bold; | |||||
font-display: swap; | |||||
src: url('../fonts/LM-bold-italic.woff2') format('woff2'), | |||||
url('../fonts/LM-bold-italic.woff') format('woff'), | |||||
url('../fonts/LM-bold-italic.ttf') format('truetype'); | |||||
} | |||||
*, *::before, *::after { | |||||
box-sizing: border-box; | |||||
} | |||||
body, h1, h2, h3, h4, p, ul[class], ol[class], li, figure, figcaption, dl, dd { | |||||
margin: 0; | |||||
} | |||||
html, body { | |||||
height: 98%; | |||||
max-width: 1280px; | |||||
margin: auto; | |||||
} | |||||
html { | |||||
font-size: 1rem; | |||||
scroll-behavior: smooth; | |||||
} | |||||
body { | |||||
display: flex; | |||||
flex-flow: column nowrap; | |||||
font-family: 'Latin Modern', Georgia, Cambria, 'Times New Roman', Times, serif; | |||||
line-height: 1.8; | |||||
min-height: 100vh; | |||||
overflow-x: hidden; | |||||
margin: 0 auto; | |||||
padding: 2rem 1.25rem; | |||||
color: hsl(0, 5%, 10%); | |||||
background-color: hsl(210, 20%, 98%); | |||||
text-rendering: optimizeLegibility; | |||||
} | |||||
p { | |||||
text-align: justify; | |||||
hyphens: auto; | |||||
margin-top: 1rem; | |||||
} | |||||
a:not([class]) { | |||||
text-decoration-skip-ink: auto; | |||||
} | |||||
a, a:visited { | |||||
color: #a00; | |||||
} | |||||
a:focus { | |||||
outline-offset: 2px; | |||||
outline: 2px solid hsl(220, 90%, 52%); | |||||
} | |||||
h1 { | |||||
font-size: 2.5rem; | |||||
line-height: 3.25rem; | |||||
margin-bottom: 1.625rem; | |||||
} | |||||
h2 { | |||||
font-size: 1.7rem; | |||||
line-height: 2rem; | |||||
margin-top: 3rem; | |||||
} | |||||
h3 { | |||||
font-size: 1.4rem; | |||||
margin-top: 2.5rem; | |||||
} | |||||
h4 { | |||||
font-size: 1.2rem; | |||||
margin-top: 2rem; | |||||
} | |||||
h5 { | |||||
font-size: 1rem; | |||||
margin-top: 1.8rem; | |||||
} | |||||
h6 { | |||||
font-size: 1rem; | |||||
font-style: italic; | |||||
font-weight: normal; | |||||
margin-top: 2.5rem; | |||||
} | |||||
h3, h4, h5, h6 { | |||||
line-height: 1.625rem; | |||||
} | |||||
h1 + h2 { | |||||
margin-top: 1.625rem; | |||||
} | |||||
h2 + h3, h3 + h4, h4 + h5 { | |||||
margin-top: 0.8rem; | |||||
} | |||||
h5 + h6 { | |||||
margin-top: -0.8rem; | |||||
} | |||||
h2, h3, h4, h5, h6 { | |||||
margin-bottom: 0.8rem; | |||||
} | |||||
ul, ol { | |||||
padding: 0; | |||||
} | |||||
#banner, #contentinfo { | |||||
width: 100%; | |||||
text-align: center; | |||||
} | |||||
#contentinfo { | |||||
flex-shrink: 0; | |||||
margin-top: 40px | |||||
} | |||||
#container { | |||||
flex: 1 0 auto; | |||||
display: flex; | |||||
align-items: stretch; | |||||
max-width: 100%; | |||||
} | |||||
@media only screen and (max-width: 1024px) { | |||||
#container { | |||||
flex-flow: row wrap; | |||||
} | |||||
} | |||||
#menu { | |||||
min-width: 300px; | |||||
} | |||||
.menuitems { | |||||
list-style: none; | |||||
} | |||||
#content { | |||||
flex: 1 1 auto; | |||||
} | |||||
#post-list li { | |||||
list-style: none; | |||||
} | |||||
.entry-title { | |||||
text-align: center; | |||||
} | |||||
div.post-info { | |||||
text-align: center; | |||||
} | |||||
.author a { | |||||
margin: 0.85rem 0; | |||||
font-variant-caps: small-caps; | |||||
text-align: center; | |||||
} | |||||
footer.post-info { | |||||
display: flex; | |||||
flex-flow: row wrap; | |||||
justify-content: space-between; | |||||
padding: 1rem; | |||||
} | |||||
.entry-title { | |||||
text-align: center; | |||||
} | |||||
/* | |||||
* Links | |||||
*/ | |||||
.entry-content a { | |||||
counter-increment: entrylinks; | |||||
text-decoration: none; | |||||
color: inherit; | |||||
outline: none; | |||||
cursor: default; | |||||
pointer-events: none; | |||||
} | |||||
.entry-content a:after { | |||||
content: '[' counter(entrylinks) ']'; | |||||
margin-left: 2px; | |||||
color: #a00; | |||||
cursor: pointer; | |||||
pointer-events: auto; | |||||
} | |||||
/* | |||||
* Lists | |||||
*/ | |||||
.entry-content ol, | |||||
.entry-content ul { | |||||
padding-left: 40px; | |||||
} | |||||
.entry-content li>ol, | |||||
.entry-content li>ul { | |||||
padding-left: 20px; | |||||
} | |||||
/* | |||||
* Images | |||||
*/ | |||||
.entry-content img { | |||||
counter-increment: figures; | |||||
display: block; | |||||
max-width: 80%; | |||||
margin: 0 auto 0 auto; | |||||
padding: 1rem; | |||||
} | |||||
.entry-content img~em{ | |||||
display: block; | |||||
margin: 0 auto 0 auto; | |||||
text-align: center; | |||||
font-style: normal; | |||||
} | |||||
.entry-content img~em:before { | |||||
content: 'Figure ' counter(figures) ': '; | |||||
font-weight: bold; | |||||
} | |||||
/* | |||||
* Tables | |||||
*/ | |||||
.entry-content table:not([class="highlighttable"]) { | |||||
counter-increment: tables; | |||||
max-width: 80%; | |||||
margin: 0 auto 0 auto; | |||||
padding: 1rem; | |||||
border-collapse: collapse; | |||||
border-spacing: 0; | |||||
} | |||||
.entry-content table~p > em{ | |||||
display: block; | |||||
margin: 0 auto 0 auto; | |||||
text-align: center; | |||||
font-style: normal; | |||||
} | |||||
.entry-content table~p > em:before { | |||||
content: 'Table ' counter(tables) ': '; | |||||
font-weight: bold; | |||||
} | |||||
.entry-content th, td { | |||||
padding: 0.5rem; | |||||
} | |||||
.entry-content td { | |||||
border-bottom: 1px solid hsl(0, 0%, 85%); | |||||
} | |||||
.entry-content th:not([align]), td:not([align]) { | |||||
text-align: left; | |||||
} | |||||
.entry-content th:empty, | |||||
.entry-content td:empty { | |||||
border-left: 1px solid hsl(0, 0%, 85%); | |||||
width: 0; | |||||
padding: 0; | |||||
} | |||||
.entry-content th:empty~th:empty, | |||||
.entry-content td:empty~td:empty { | |||||
border-left: 1px double hsl(0, 0%, 85%); | |||||
} | |||||
.entry-content thead th { | |||||
border-bottom: 2px solid hsl(0, 0%, 70%); | |||||
} | |||||
.entry-content tfoot th { | |||||
border-top: 2px solid hsl(0, 0%, 70%); | |||||
} | |||||
/* | |||||
* Code | |||||
*/ | |||||
.entry-content table.highlighttable, | |||||
.entry-content div.highlight { | |||||
width: 100%; | |||||
max-width: 100%; | |||||
} | |||||
.entry-content div.highlight { | |||||
counter-increment: listings; | |||||
} | |||||
.entry-content table.highlighttable~p > em, | |||||
.entry-content div.highlight~p > em { | |||||
display: block; | |||||
margin: 0 auto 0 auto; | |||||
text-align: center; | |||||
font-style: normal; | |||||
} | |||||
.entry-content table.highlighttable~p > em:before, | |||||
.entry-content div.highlight~p > em:before { | |||||
content: 'Listing ' counter(listings) ': '; | |||||
font-weight: bold; | |||||
} | |||||
.entry-content td.linenos, | |||||
.entry-content td.code { | |||||
border-bottom: none; | |||||
} | |||||
.entry-content code, pre { | |||||
font-family: Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace; | |||||
font-size: 85%; | |||||
} | |||||
.entry-content pre { | |||||
max-width: 100%; | |||||
overflow: auto; | |||||
border-radius: 4px; | |||||
} | |||||
.entry-content pre code { | |||||
font-size: 95%; | |||||
position: relative; | |||||
} | |||||
.linenos { | |||||
width: 3em; | |||||
} | |||||
/* This is old stuff, inherited from LaTeX.css, probably unused */ | |||||
/* Nested ordered list for ToC */ | |||||
.toc ol { | |||||
counter-reset: item; | |||||
padding-left: 2rem; | |||||
} | |||||
.toc li { | |||||
display: block; | |||||
} | |||||
.toc li:before { | |||||
content: counters(item, '.') ' '; | |||||
counter-increment: item; | |||||
padding-right: 0.85rem; | |||||
} | |||||
/* Make footnote text smaller and left align it (looks bad with long URLs) */ | |||||
.footnotes p { | |||||
text-align: left; | |||||
line-height: 1.5; | |||||
font-size: 85%; | |||||
margin-bottom: 0.4rem; | |||||
} | |||||
.footnotes { | |||||
border-top: 1px solid hsl(0, 0%, 39%); | |||||
} | |||||
@@ -0,0 +1,14 @@ | |||||
{% extends "base.html" %} | |||||
{% block title %}{{ SITENAME }} - Archives{% endblock %} | |||||
{% block content %} | |||||
<h1>Archives for {{ SITENAME }}</h1> | |||||
<dl> | |||||
{% for article in dates %} | |||||
<dt>{{ article.locale_date }}</dt> | |||||
<dd><a href="{{ SITEURL }}/{{ article.url }}">{{ article.title }}</a></dd> | |||||
{% endfor %} | |||||
</dl> | |||||
{% endblock %} |
@@ -0,0 +1,69 @@ | |||||
{% extends "base.html" %} | |||||
{% block html_lang %}{{ article.lang }}{% endblock %} | |||||
{% block title %}{{ SITENAME }} - {{ article.title }}{% endblock %} | |||||
{% block head %} | |||||
{{ super() }} | |||||
{% import 'translations.html' as translations with context %} | |||||
{% if translations.entry_hreflang(article) %} | |||||
{{ translations.entry_hreflang(article) }} | |||||
{% endif %} | |||||
{% if article.description %} | |||||
<meta name="description" content="{{article.description}}" /> | |||||
{% endif %} | |||||
{% for tag in article.tags %} | |||||
<meta name="tags" content="{{tag}}" /> | |||||
{% endfor %} | |||||
{% endblock %} | |||||
{% block content %} | |||||
<section id="content" class="body"> | |||||
<header> | |||||
<h2 class="entry-title"> | |||||
<a href="{{ SITEURL }}/{{ article.url }}" rel="bookmark" | |||||
title="Permalink to {{ article.title|striptags }}">{{ article.title }}</a></h2> | |||||
{% import 'translations.html' as translations with context %} | |||||
{{ translations.translations_for(article) }} | |||||
<div class="post-info"> | |||||
<time class="published" datetime="{{ article.date.isoformat() }}"> | |||||
{{ article.locale_date }} | |||||
</time> | |||||
{% if article.modified %} | |||||
<time class="modified" datetime="{{ article.modified.isoformat() }}"> | |||||
{{ article.locale_modified }} | |||||
</time> | |||||
{% endif %} | |||||
{% if article.authors %} | |||||
<address class="vcard author"> | |||||
By {% for author in article.authors %}<a class="url fn" href="{{ SITEURL }}/{{ author.url }}">{{ author }}</a>{% endfor %} | |||||
</address> | |||||
{% endif %} | |||||
</div> | |||||
</header> | |||||
<div class="entry-content"> | |||||
{{ article.content }} | |||||
</div><!-- /.entry-content --> | |||||
<footer class="post-info"> | |||||
{% if article.category %} | |||||
<div class="category"> | |||||
Category: <a href="{{ SITEURL }}/{{ article.category.url }}">{{ article.category }}</a> | |||||
</div> | |||||
{% endif %} | |||||
{% if article.tags %} | |||||
<div class="tags"> | |||||
Tags: | |||||
{% for tag in article.tags %} | |||||
<a href="{{ SITEURL }}/{{ tag.url }}">{{ tag }}</a> | |||||
{% endfor %} | |||||
</div> | |||||
{% endif %} | |||||
</footer><!-- /.post-info --> | |||||
</section> | |||||
{% endblock %} | |||||
<!-- vim:ts=2:sw=2:et:ft=html --> |
@@ -0,0 +1,8 @@ | |||||
{% extends "index.html" %} | |||||
{% block title %}{{ SITENAME }} - Articles by {{ author }}{% endblock %} | |||||
{% block content_title %} | |||||
<h2>Articles by {{ author }}</h2> | |||||
{% endblock %} | |||||
@@ -0,0 +1,12 @@ | |||||
{% extends "base.html" %} | |||||
{% block title %}{{ SITENAME }} - Authors{% endblock %} | |||||
{% block content %} | |||||
<h1>Authors on {{ SITENAME }}</h1> | |||||
<ul> | |||||
{% for author, articles in authors|sort %} | |||||
<li><a href="{{ SITEURL }}/{{ author.url }}">{{ author }}</a> ({{ articles|count }})</li> | |||||
{% endfor %} | |||||
</ul> | |||||
{% endblock %} |
@@ -0,0 +1,82 @@ | |||||
<!DOCTYPE html> | |||||
<html lang="{% block html_lang %}{{ DEFAULT_LANG }}{% endblock html_lang %}"> | |||||
<head> | |||||
{% block head %} | |||||
<title>{% block title %}{{ SITENAME }}{% endblock title %}</title> | |||||
<meta charset="utf-8" /> | |||||
<link rel="stylesheet" type="text/css" href="{{ SITE_URL }}/theme/css/site.css" /> | |||||
{% if FEED_ALL_ATOM %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if FEED_ALL_ATOM_URL %}{{ FEED_ALL_ATOM_URL }}{% else %}{{ FEED_ALL_ATOM }}{% endif %}" type="application/atom+xml" rel="alternate" title="{{ SITENAME }} Full Atom Feed" /> | |||||
{% endif %} | |||||
{% if FEED_ALL_RSS %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if FEED_ALL_RSS_URL %}{{ FEED_ALL_RSS_URL }}{% else %}{{ FEED_ALL_RSS }}{% endif %}" type="application/rss+xml" rel="alternate" title="{{ SITENAME }} Full RSS Feed" /> | |||||
{% endif %} | |||||
{% if FEED_ATOM %} | |||||
<link href="{{ FEED_DOMAIN }}/{%if FEED_ATOM_URL %}{{ FEED_ATOM_URL }}{% else %}{{ FEED_ATOM }}{% endif %}" type="application/atom+xml" rel="alternate" title="{{ SITENAME }} Atom Feed" /> | |||||
{% endif %} | |||||
{% if FEED_RSS %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if FEED_RSS_URL %}{{ FEED_RSS_URL }}{% else %}{{ FEED_RSS }}{% endif %}" type="application/rss+xml" rel="alternate" title="{{ SITENAME }} RSS Feed" /> | |||||
{% endif %} | |||||
{% if CATEGORY_FEED_ATOM and category %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if CATEGORY_FEED_ATOM_URL %}{{ CATEGORY_FEED_ATOM_URL.format(slug=category.slug) }}{% else %}{{ CATEGORY_FEED_ATOM.format(slug=category.slug) }}{% endif %}" type="application/atom+xml" rel="alternate" title="{{ SITENAME }} Categories Atom Feed" /> | |||||
{% endif %} | |||||
{% if CATEGORY_FEED_RSS and category %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if CATEGORY_FEED_RSS_URL %}{{ CATEGORY_FEED_RSS_URL.format(slug=category.slug) }}{% else %}{{ CATEGORY_FEED_RSS.format(slug=category.slug) }}{% endif %}" type="application/rss+xml" rel="alternate" title="{{ SITENAME }} Categories RSS Feed" /> | |||||
{% endif %} | |||||
{% if TAG_FEED_ATOM and tag %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if TAG_FEED_ATOM_URL %}{{ TAG_FEED_ATOM_URL.format(slug=tag.slug) }}{% else %}{{ TAG_FEED_ATOM.format(slug=tag.slug) }}{% endif %}" type="application/atom+xml" rel="alternate" title="{{ SITENAME }} Tags Atom Feed" /> | |||||
{% endif %} | |||||
{% if TAG_FEED_RSS and tag %} | |||||
<link href="{{ FEED_DOMAIN }}/{% if TAG_FEED_RSS_URL %}{{ TAG_FEED_RSS_URL.format(slug=tag.slug) }}{% else %}{{ TAG_FEED_RSS.format(slug=tag.slug) }}{% endif %}" type="application/rss+xml" rel="alternate" title="{{ SITENAME }} Tags RSS Feed" /> | |||||
{% endif %} | |||||
{% endblock head %} | |||||
</head> | |||||
<body id="index" class="home"> | |||||
<header id="banner" class="body"> | |||||
<h1><a href="{{ SITEURL }}/">{{ SITENAME }} <strong>{{ SITESUBTITLE }}</strong></a></h1> | |||||
</header><!-- /#banner --> | |||||
<div id="container"> | |||||
<nav id="menu"> | |||||
{% for title, link in MENUITEMS %} | |||||
<ul class="menuitems"> | |||||
<li><a href="{{ link }}">{{ title }}</a></li> | |||||
</ul> | |||||
{% endfor %} | |||||
{% if DISPLAY_PAGES_ON_MENU %} | |||||
<ul id="pages" class="menuitems"> | |||||
{% for p in pages %} | |||||
<li{% if p == page %} class="active"{% endif %}><a href="{{ SITEURL }}/{{ p.url }}">{{ p.title }}</a></li> | |||||
{% endfor %} | |||||
</ul> | |||||
{% endif %} | |||||
{% if DISPLAY_CATEGORIES_ON_MENU %} | |||||
<ul id="categories" class="menuitems"> | |||||
{% for cat, null in categories %} | |||||
<li{% if cat == category %} class="active"{% endif %}><a href="{{ SITEURL }}/{{ cat.url }}">{{ cat }}</a></li> | |||||
{% endfor %} | |||||
</ul> | |||||
{% endif %} | |||||
</nav><!-- /#menu --> | |||||
{% block content %} | |||||
{% endblock %} | |||||
</div> | |||||
<footer id="contentinfo" class="body"> | |||||
<address id="about" class="vcard body"> | |||||
Proudly powered by <a href="http://getpelican.com/">Pelican</a>, which takes great advantage of <a href="http://python.org">Python</a>. | |||||
</address><!-- /#about --> | |||||
</footer><!-- /#contentinfo --> | |||||
</body> | |||||
</html> | |||||
<!-- vim:ts=2:sw=2:et:ft=html --> |
@@ -0,0 +1,12 @@ | |||||
{% extends "base.html" %} | |||||
{% block title %}{{ SITENAME }} - Categories{% endblock %} | |||||
{% block content %} | |||||
<h1>Categories on {{ SITENAME }}</h1> | |||||
<ul> | |||||
{% for category, articles in categories|sort %} | |||||
<li><a href="{{ SITEURL }}/{{ category.url }}">{{ category }}</a> ({{ articles|count }})</li> | |||||
{% endfor %} | |||||
</ul> | |||||
{% endblock %} |
@@ -0,0 +1,8 @@ | |||||
{% extends "index.html" %} | |||||
{% block title %}{{ SITENAME }} - {{ category }} category{% endblock %} | |||||
{% block content_title %} | |||||
<h2>Articles in the {{ category }} category</h2> | |||||
{% endblock %} | |||||
@@ -0,0 +1,14 @@ | |||||
{% if GOSQUARED_SITENAME %} | |||||
<script type="text/javascript"> | |||||
var GoSquared={}; | |||||
GoSquared.acct = "{{ GOSQUARED_SITENAME }}"; | |||||
(function(w){ | |||||
function gs(){ | |||||
w._gstc_lt=+(new Date); var d=document; | |||||
var g = d.createElement("script"); g.type = "text/javascript"; g.async = true; g.src = "https://d1l6p2sc9645hc.cloudfront.net/tracker.js"; | |||||
var s = d.getElementsByTagName("script")[0]; s.parentNode.insertBefore(g, s); | |||||
} | |||||
w.addEventListener?w.addEventListener("load",gs,false):w.attachEvent("onload",gs); | |||||
})(window); | |||||
</script> | |||||
{% endif %} |
@@ -0,0 +1,44 @@ | |||||
{% extends "base.html" %} | |||||
{% block content %} | |||||
<section id="content"> | |||||
{% block content_title %} | |||||
<h2>All articles</h2> | |||||
{% endblock %} | |||||
<ol id="post-list"> | |||||
{% for article in articles_page.object_list %} | |||||
<li> | |||||
<article class="hentry"> | |||||
<header> | |||||
<h2 class="entry-title"> | |||||
<a href="{{ SITEURL }}/{{ article.url }}" rel="bookmark" title="Permalink to {{ article.title|striptags }}">{{ article.title }}</a> | |||||
</h2> | |||||
<div class="post-info"> | |||||
<time class="published" datetime="{{ article.date.isoformat() }}"> {{ article.locale_date }} </time> | |||||
<address class="vcard author">By | |||||
{% for author in article.authors %} | |||||
<a class="url fn" href="{{ SITEURL }}/{{ author.url }}">{{ author }}</a> | |||||
{% endfor %} | |||||
</address> | |||||
</div><!-- /.post-info --> | |||||
</header> | |||||
<div class="entry-content"> | |||||
{{ article.summary }} | |||||
</div><!-- /.entry-content --> | |||||
</article> | |||||
</li> | |||||
{% endfor %} | |||||
</ol><!-- /#posts-list --> | |||||
{% if articles_page.has_other_pages() %} | |||||
{% include 'pagination.html' %} | |||||
{% endif %} | |||||
</section><!-- /#content --> | |||||
{% endblock content %} | |||||
<!-- vim:ts=2:sw=2:et:ft=html --> |
@@ -0,0 +1,27 @@ | |||||
{% extends "base.html" %} | |||||
{% block html_lang %}{{ page.lang }}{% endblock %} | |||||
{% block title %}{{ SITENAME }} - {{ page.title }}{%endblock%} | |||||
{% block head %} | |||||
{{ super() }} | |||||
{% import 'translations.html' as translations with context %} | |||||
{% if translations.entry_hreflang(page) %} | |||||
{{ translations.entry_hreflang(page) }} | |||||
{% endif %} | |||||
{% endblock %} | |||||
{% block content %} | |||||
<h1>{{ page.title }}</h1> | |||||
{% import 'translations.html' as translations with context %} | |||||
{{ translations.translations_for(page) }} | |||||
{{ page.content }} | |||||
{% if page.modified %} | |||||
<p> | |||||
Last updated: {{ page.locale_modified }} | |||||
</p> | |||||
{% endif %} | |||||
{% endblock %} |
@@ -0,0 +1,11 @@ | |||||
{% if DEFAULT_PAGINATION %} | |||||
<p class="paginator"> | |||||
{% if articles_page.has_previous() %} | |||||
<a href="{{ SITEURL }}/{{ articles_previous_page.url }}">«</a> | |||||
{% endif %} | |||||
Page {{ articles_page.number }} / {{ articles_paginator.num_pages }} | |||||
{% if articles_page.has_next() %} | |||||
<a href="{{ SITEURL }}/{{ articles_next_page.url }}">»</a> | |||||
{% endif %} | |||||
</p> | |||||
{% endif %} |
@@ -0,0 +1,14 @@ | |||||
{% extends "base.html" %} | |||||
{% block title %}{{ SITENAME }} - {{ period | reverse | join(' ') }} archives{% endblock %} | |||||
{% block content %} | |||||
<h1>Archives for {{ period | reverse | join(' ') }}</h1> | |||||
<dl> | |||||
{% for article in dates %} | |||||
<dt>{{ article.locale_date }}</dt> | |||||
<dd><a href="{{ SITEURL }}/{{ article.url }}">{{ article.title }}</a></dd> | |||||
{% endfor %} | |||||
</dl> | |||||
{% endblock %} |
@@ -0,0 +1,7 @@ | |||||
{% extends "index.html" %} | |||||
{% block title %}{{ SITENAME }} - {{ tag }} tag{% endblock %} | |||||
{% block content_title %} | |||||
<h2>Articles tagged with {{ tag }}</h2> | |||||
{% endblock %} |
@@ -0,0 +1,12 @@ | |||||
{% extends "base.html" %} | |||||
{% block title %}{{ SITENAME }} - Tags{% endblock %} | |||||
{% block content %} | |||||
<h1>Tags for {{ SITENAME }}</h1> | |||||
<ul> | |||||
{% for tag, articles in tags|sort %} | |||||
<li><a href="{{ SITEURL }}/{{ tag.url }}">{{ tag }}</a> ({{ articles|count }})</li> | |||||
{% endfor %} | |||||
</ul> | |||||
{% endblock %} |
@@ -0,0 +1,16 @@ | |||||
{% macro translations_for(article) %} | |||||
{% if article.translations %} | |||||
Translations: | |||||
{% for translation in article.translations %} | |||||
<a href="{{ SITEURL }}/{{ translation.url }}" hreflang="{{ translation.lang }}">{{ translation.lang }}</a> | |||||
{% endfor %} | |||||
{% endif %} | |||||
{% endmacro %} | |||||
{% macro entry_hreflang(entry) %} | |||||
{% if entry.translations %} | |||||
{% for translation in entry.translations %} | |||||
<link rel="alternate" hreflang="{{ translation.lang }}" href="{{ SITEURL }}/{{ translation.url }}"> | |||||
{% endfor %} | |||||
{% endif %} | |||||
{% endmacro %} |