Skip to content

Commit

Permalink
wip: rework links page
Browse files Browse the repository at this point in the history
  • Loading branch information
mlcdf committed May 26, 2022
1 parent 3616e10 commit 5ca764a
Show file tree
Hide file tree
Showing 7 changed files with 388 additions and 3 deletions.
19 changes: 19 additions & 0 deletions content/links/optimise-fonts.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
Title: 5 steps to faster web fonts
Date: 2022-05-22
Category: Links
Link: https://iainbean.com/posts/2021/5-steps-to-faster-web-fonts/

> Use the most modern file formats
<div></div>

> By subsetting a font, we can generate a new smaller font file which only includes the glyphs (a glyph is an individual character or symbol) we need.
En suivant ces deux recommandations, j'ai drastiquement réduit la taille des polices que j'embarque sur ce site :

- taille d'une police en TTF téléchargée sur Google Fonts : ~250Ko
- conversion en WOFF : ~110Ko
- soustraction des glyphes unitilisés : ~40Ko.

*[WOFF]: Web Open Font Format
*[TTF]: True Type Font
259 changes: 259 additions & 0 deletions content/lorem-ipsum.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,259 @@
Title: Lorem Ipsum
Date: 2022-03-03
Category: Articles
Status: draft

```python
a = "test"
```

<p>Sunrise humble abomination foreign broil faithless metal westward Rohan portents! Left other's wanes pile squealing thieves Precious beards. Sport sadness they'll walking forgetting where's handkerchief disappointment Wraiths. There is one Dwarf yet in Moria who still draws breath.</p>
<h2>Grumbling maggot draining bog Ravenhill guardian.</h2>
<p>Wraith mountain laws peace pigheaded fast branch. I was there the day the strength of Men failed. Forced EIf-witch pursued?</p>
<h3>Swords forged Gloin wear pursuit sort merchants tunnel.</h3>
<h4>lorem </h4>
<h5>ipsum</h5>
<h6>Dolore</h6>

<p>Dangers unsavory bravely Ettenmoors sleepless apothecary ponies soul these killed chap flaming. Tongs bargemen Brego forked nine seat youngest govern highest entrusted sneak perfected. All right, then. Keep your secrets. Reproductions marshaling Fenmarch.</p>
<ul>
<li>Emyn.</li>
<li>Nori.</li>
<li>Ori!</li>
<li>Lórien?</li>
<li>Sauron's.</li>
</ul>
<ul>
<li>Pack moldy bottom littIe Noldorin.</li>
<li>Tomorrow Faramir greedily life midnight.</li>
<li>Risen holds Front teeming slight during!</li>
<li>Sweeter sweeps road guesses certain city crime picking Dî nor?</li>
<li>Rob festers Helm Hammerhand correctly kinsmen hair dung engages.</li>
</ul>
<h3>Fellowship horrid sending Shire's well-done stare.</h3>
<p>Head-on strength's Morgul-rats risky think exaggerate joking invite penalty tied room. Army risked shown pass establishment Worrywort bay tried! Brings dies know became Boffins diversion protect. It's some form of Elvish. I can't read it.</p>
<ol>
<li>Bracegirdles.</li>
<li>Morgul-rats.</li>
<li>Freda?</li>
<li>Bag-end?</li>
<li>Ingrates?</li>aa
</ol>
<ol>
<li>Beings freed permitted arrows treachery forebears pages foolish Gundabad?</li>
<li>Entire shattered overthrown checked Grond earned corrupt forgiven!</li>
<li>Balls afraid why Orcrist near asked show don't.</li>
<li>Physical bloodline laboring fully Luncheon called?</li>
<li>Master Théoden's seriously greedy back that's stair.</li>
</ol>
<h3>Track father's trick standing tender Sigrid.</h3>
<p>Undimmed painted guards filleting Arwen's thee scraped grab rules secure shattered? Farther Shire dreams pa mustn't purring 10000. One does not simply walk into Mordor.</p>
<table>
<thead>
<tr>
<th></th>
<th>Dangers</th>
<th>Thirsty</th>
<th>Swish</th>
<th>Fortify</th>
<th>Surrender</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cloth</td>
<td>cook</td>
<td>while</td>
<td>least</td>
<td>inspection</td>
<td>promise</td>
</tr>
<tr>
<td>Buy</td>
<td>wearing</td>
<td>talisman</td>
<td>drown</td>
<td>lanterns</td>
<td>people's</td>
</tr>
<tr>
<td>Mattress</td>
<td>ordered</td>
<td>slightest</td>
<td>terribly</td>
<td>grief</td>
<td>1296</td>
</tr>
<tr>
<td>Coward</td>
<td>haste</td>
<td>wonder</td>
<td>renowned</td>
<td>evening</td>
<td>setting</td>
</tr>
<tr>
<td>Downfall</td>
<td>morninged</td>
<td>unmade</td>
<td>thrice</td>
<td>overreacting</td>
<td>bowl</td>
</tr>
<tr>
<td>Ambition</td>
<td>tree</td>
<td>trammel</td>
<td>bitterness</td>
<td>rose</td>
<td>omen</td>
</tr>
</tbody>
<tfoot>
<tr>
<td>writing</td>
<td>eyeses</td>
<td>miles</td>
<td>thunderstorm</td>
<td>covers</td>
<td>fall</td>
</tr>
</tfoot>
</table>
<h4>Westfarthing searing mellon marched sake battered gardeners prefers.</h4>
<p>Emptied fairer Dwalin first-born mice possibly fears uncomfortable arm! Rotten Barad-dûr soul remembered hail? Hungers pickle spells rift Bill walked returning books torches marched yelp fitted! A wizard is never late, Frodo Baggins. Nor is he early. He arrives precisely when he means to.</p>
<blockquote>
<p>That is no trinket you carry.</p>
<footer>—Iáve, <cite>multiplied blankets wept removed mend</cite></footer>
</blockquote>
<h5>Pearl brought it'll alike whoa sulfur Nori leaf.</h5>
<p>Murder Stone-Giants strain fruitless bay yearned? Funny victory box ugly Crebain bargain unseen whereabouts riddle crows 2000. I can cut across country easily enough.</p>
<pre>Declare we've starters Hornblowers spread tastes. Southrons numbers enemy jacketses fat. Tragedy Bolgers faster beasts woodland!</pre>
<h6>Corpses Middle-earth draining responsible were sweet-taking shine probably.</h6>
<p>Unspoken hardship <time>Fellowship</time> take! Club supplies Éomer armories treasury <code>moves dawn fool who's</code>. Greed wharf snap chance <em>comfort begins</em> Sit. World's <q>armory iron-forged lock</q> wanted Brandybuck locking spreads. Faster master <abbr>Farthing</abbr> goodwill? Reforge knowing pass <var>Wraiths</var>. Seasoning fireworks launching Gorgoroth <kbd>M</kbd> sires. Troop mad with new <dfn>floater improve flavor</dfn> Fellowship. Dragon-Slayer dragon's <del>fingers bury</del> bridge keen relight! Nerves use confounded <cite>usurpers marshes</cite> Lower defense. <sub>Radagast the Brown</sub> low canal robbed wanting. Nearly must blowing <strong>Galeton Thranduil Took's East-farthing Edoras</strong>. <samp>Bolg Thrain Uruk-hai Think</samp> eternally starlight funny. <a>Narsil Thorin's Sackville-Bagginses Moon Sebastian Fenmarch</a> impressive ahead garden travelers. Orcrist following knockers <small>clearly act gaze</small>! Served <ins>manners hoard</ins> Elendil them. Law Thofin understand <sup>veil</sup> supplant going. Ring fruitless gollum understandable <mark>burst bacon stabbed grace</mark> ended.</p>
<hr>
<dl>
<dt>Ridiculous</dt>
<dd>Hardy seat heed bitterness Théodred's mind hatched handkerchiefs greedy?</dd>
<dt>Open</dt>
<dd>Garrison killing generation Bard washed devil rain bit sees!</dd>
<dd>Uttermost Smeagol's odds cursed tunnels posts ate supplant remuneration amidst?</dd>
<dt>Heir</dt>
<dd>Ravens glimpse liar twiddle exile finally inferno tapestry bodyguard pool.</dd>
<dd>Scent blockheaded marshes shape Ered knife-work what'll tosses pan.</dd>
<dd>Fountains gift fears flowers spare alongside Wraith child amidst.</dd>
</dl>
<form>
<fieldset>
<legend>Said soldiers pity</legend>
<div>
<label>Text</label>
<input type="text">
</div>
<div>
<label>Email</label>
<input type="email">
</div>
<div>
<label>Password</label>
<input type="password">
</div>
<div>
<label>Url</label>
<input type="url">
</div>
<div>
<label>Number</label>
<input type="number">
</div>
<div>
<label>Tel</label>
<input type="tel">
</div>
<div>
<label>Search</label>
<input type="search">
</div>
<div>
<label>Time</label>
<input type="time">
</div>
<div>
<label>Date</label>
<input type="date">
</div>
<div>
<label>Datetime-local</label>
<input type="datetime-local">
</div>
<div>
<label>Week</label>
<input type="week">
</div>
<div>
<label>Textarea</label>
<textarea></textarea>
</div>
</fieldset>
<fieldset>
<legend>Forebears littIe</legend>
<div>
<label>Month</label>
<input type="month">
</div>
<div>
<label><input type="checkbox" name="checkbox">full wonderful</label>
</div>
<div>
<label>Color</label>
<input type="color">
</div>
<div>
<label>File</label>
<input type="file">
</div>
<div>
<label>Hidden</label>
<input type="hidden">
</div>
<div>
<label>Image</label>
<input type="image">
</div>
<div>
<label>robber firm fun fish approve potatoes</label>
<label><input type="radio" name="radio">endured required</label>
<label><input type="radio" name="radio">incident altogether</label>
<label><input type="radio" name="radio">n servants</label>
</div>
<div>
<label>Range</label>
<input type="range">
</div>
<div>
<input type="button" value="Button">
</div>
<div>
<input type="reset" value="Reset">
</div>
<div>
<input type="submit" value="Submit">
</div>
<button>unimpeachable despair miss</button>
<div>
<label>Select</label>
<select>
<optgroup label="volley summer's usually">
<option>order</option>
<option>where's</option>
<option>alongside</option>
</optgroup>
<optgroup label="banners wait">
<option>ill-favored</option>
<option>tea</option>
<option>let's</option>
</optgroup>
</select>
</div>
</fieldset>
</form>
23 changes: 23 additions & 0 deletions content/pipenv-scripts.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
Title: Pipenv scripts
Date: 2022-05-22
Category: Articles
Tags: logiciel

Après avoir passé des mois (années ?) à me plaindre qu'il y avait pas d'équivalent aux [`npm-run-script`](https://docs.npmjs.com/cli/v7/commands/npm-run-script), j'ai récemment découvert qu'il existait une solution similaire via [pipenv](https://pipenv.pypa.io/en/latest/advanced/#custom-script-shortcuts) !

Je m'en sers dans le dépôt qui construit ce site même, ça donne ça :

```toml
[scripts]
dev = "./scripts/dev.py"
publish = "pelican --settings publishconf.py --delete-output-directory"
preview = "env PREVIEW=True pelican --settings publishconf.py --delete-output-directory --listen --autoreload"
clean = "rm -rf ./cache ./output"
```

Et pour lancer une commande :
```python
pipenv run dev
```

## Limitations
19 changes: 18 additions & 1 deletion pelicanconf.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import datetime
import locale
import logging
import os

import pelican
from pelican.plugins import jinja2content
Expand All @@ -19,6 +20,9 @@
DESCRIPTION = "Artisan logiciel polyglotte et ingénieur DevOps le jour. Photographe en herbe et mordu de cinéma la nuit."

PATH = "content"
ARTICLE_PATHS = ["", "links"]
ARTICLE_EXCLUDES = [os.path.join(os.getcwd(), "content/pages")]

OUTPUT_PATH = "output/"

TIMEZONE = "Europe/Paris"
Expand Down Expand Up @@ -56,6 +60,8 @@

RELATIVE_URLS = True

SLUGIFY_SOURCE = "basename"

ARTICLE_SAVE_AS = "{slug}/index.html"
ARTICLE_URL = "{slug}"

Expand All @@ -64,6 +70,13 @@

INDEX_SAVE_AS = "index.html"

LINKS_SAVE_AS = "links/index.html"

DIRECT_TEMPLATES = ["index", "links"]
# TEMPLATE_PAGES = {
# os.path.join(os.getcwd(), "theme/templates/links.html"): "links/index.html",
# }

STATIC_PATHS = ["extra"]

EXTRA_PATH_METADATA = {
Expand Down Expand Up @@ -92,7 +105,11 @@
"strftime": DateFormatter(),
}

JINJA_GLOBALS = {"BUILD_DATE": BUILD_DATE}
JINJA_GLOBALS = {
"BUILD_DATE": BUILD_DATE,
}

JINJA_ENVIRONMENT = {"extensions": ["jinja2.ext.loopcontrols"]}

PLUGIN_PATHS = ["plugins"]
PLUGINS = ["asset_reving", "strike", "styled_rss", "typography", jinja2content]
Expand Down
2 changes: 1 addition & 1 deletion theme/templates/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ <h1>Billets</h1>
</div>

<div class="posts">
{% for article in articles_page.object_list %}
{% for article in articles_page.object_list | selectattr("category", "==", "Articles") %}
<div class="post">
<h2 class="post-title serif" id="#{{ article.slug }}">
<a href="/{{ article.url }}">{{ article.title }}</a>
Expand Down
2 changes: 1 addition & 1 deletion theme/templates/layout.html
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,8 @@
</h1> -->
<nav>
<a href="/">Blog</a>
<a href="/links/">Liens</a>
<a href="/projets/">Projets</a>
<a href="/liens/">Liens</a>
</nav>
</div>
</header>
Expand Down
Loading

0 comments on commit 5ca764a

Please sign in to comment.