Compare commits
4 commits
506d1e8d69
...
58119f5968
| Author | SHA1 | Date | |
|---|---|---|---|
| 58119f5968 | |||
| 3cc62444fc | |||
| a37436de6a | |||
| 6ac6f9b9d7 |
30
assets/characters/README.md
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
# Characters
|
||||
|
||||
Imaginary friends that help me inject personality into my articles. These are
|
||||
anthropomorphized versions of animals that I have known in real life. I tried to
|
||||
draw them roughly in the style of Chris Pasquini, but failed myself, then tried
|
||||
using Perplexity's image generation. The style isn't quite the same, but I like
|
||||
it for these animals. Also, Perplexity does a horrible job of labeling images,
|
||||
so ignore the ref sheet emotion labels.
|
||||
|
||||
## Spawn of Satan (aka Spawn aka SOS)
|
||||
|
||||

|
||||
|
||||
Spawn of Satan is the name Travis gave to the cannulated cow, and it stuck.
|
||||
Spawn is old and cynical after having every professor with a new idea experiment
|
||||
on her. After being in academia for so long, she knows her way around
|
||||
mathematics and the scientific method reasonably well, even if she's never
|
||||
formally taken a college course in the sciences. She is the realist to any blog
|
||||
post's optimist.
|
||||
|
||||
## Whelen
|
||||
|
||||

|
||||
|
||||
Whelen is a happy-go-lucky German Shepherd/Husky mix puppy. He's been to school
|
||||
once - and that was just to get neutered - so his knowledge of math and science,
|
||||
heck, even of the humanities, isn't very good. He is very naive and thinks
|
||||
everyone is nice and wants to be his friend, but he is also friendly to everyone
|
||||
and is very vocal when he feels left out. He will step in when any blog post is
|
||||
getting too technical and demand an explanation for real people (dogs?).
|
||||
BIN
assets/characters/spawn/_ref-blueeye-perplexity.png
Normal file
|
After Width: | Height: | Size: 908 KiB |
BIN
assets/characters/spawn/_ref-body-perplexity.png
Normal file
|
After Width: | Height: | Size: 954 KiB |
BIN
assets/characters/spawn/_ref-bodysmirk-perplexity.png
Normal file
|
After Width: | Height: | Size: 962 KiB |
BIN
assets/characters/spawn/_ref-face-perplexity.png
Normal file
|
After Width: | Height: | Size: 951 KiB |
BIN
assets/characters/spawn/body-anger.png
Normal file
|
After Width: | Height: | Size: 208 KiB |
BIN
assets/characters/spawn/body-lazy.png
Normal file
|
After Width: | Height: | Size: 133 KiB |
BIN
assets/characters/spawn/body-skeptic.png
Normal file
|
After Width: | Height: | Size: 205 KiB |
BIN
assets/characters/spawn/body-snark.png
Normal file
|
After Width: | Height: | Size: 120 KiB |
BIN
assets/characters/spawn/body-tired.png
Normal file
|
After Width: | Height: | Size: 198 KiB |
BIN
assets/characters/spawn/face-confusion.png
Normal file
|
After Width: | Height: | Size: 52 KiB |
BIN
assets/characters/spawn/face-happy.png
Normal file
|
After Width: | Height: | Size: 38 KiB |
BIN
assets/characters/spawn/face-neutral.png
Normal file
|
After Width: | Height: | Size: 34 KiB |
BIN
assets/characters/spawn/face-sad.png
Normal file
|
After Width: | Height: | Size: 59 KiB |
BIN
assets/characters/spawn/face-toldyouso.png
Normal file
|
After Width: | Height: | Size: 34 KiB |
BIN
assets/characters/whelen/_ref-body-perplexity.png
Normal file
|
After Width: | Height: | Size: 850 KiB |
BIN
assets/characters/whelen/_ref-face-perplexity.png
Normal file
|
After Width: | Height: | Size: 958 KiB |
BIN
assets/characters/whelen/body-determined.png
Normal file
|
After Width: | Height: | Size: 130 KiB |
BIN
assets/characters/whelen/body-happy.png
Normal file
|
After Width: | Height: | Size: 101 KiB |
BIN
assets/characters/whelen/body-neutral.png
Normal file
|
After Width: | Height: | Size: 123 KiB |
BIN
assets/characters/whelen/body-sad.png
Normal file
|
After Width: | Height: | Size: 90 KiB |
BIN
assets/characters/whelen/body-tired.png
Normal file
|
After Width: | Height: | Size: 103 KiB |
BIN
assets/characters/whelen/body-worry.png
Normal file
|
After Width: | Height: | Size: 174 KiB |
BIN
assets/characters/whelen/face-anticipation.png
Normal file
|
After Width: | Height: | Size: 49 KiB |
BIN
assets/characters/whelen/face-bored.png
Normal file
|
After Width: | Height: | Size: 51 KiB |
BIN
assets/characters/whelen/face-happy.png
Normal file
|
After Width: | Height: | Size: 50 KiB |
BIN
assets/characters/whelen/face-neutral.png
Normal file
|
After Width: | Height: | Size: 48 KiB |
BIN
assets/characters/whelen/face-skeptic.png
Normal file
|
After Width: | Height: | Size: 49 KiB |
BIN
assets/characters/whelen/face-tired.png
Normal file
|
After Width: | Height: | Size: 53 KiB |
BIN
assets/characters/whelen/face-worry.png
Normal file
|
After Width: | Height: | Size: 53 KiB |
|
|
@ -185,6 +185,8 @@
|
|||
"URW Bookman L", "Georgia Pro", Georgia, serif;
|
||||
--font-family-slab-serif: Rockwell, "Rockwell Nova", "Roboto Slab",
|
||||
"DejaVu Serif", "Sitka Small", serif;
|
||||
--font-family-transitional: Charter, "Bitstream Charter", "Sitka Text",
|
||||
Cambria, serif;
|
||||
--font-family-system-ui: system-ui, sans-serif;
|
||||
--font-family-monospace: "Nimbus Mono PS", "Courier New", monospace;
|
||||
}
|
||||
|
|
@ -272,6 +274,34 @@ main {
|
|||
flex-direction: column;
|
||||
}
|
||||
|
||||
article p,
|
||||
.character-dialog-text,
|
||||
article li {
|
||||
font-family: var(--font-family-transitional);
|
||||
font-size: 1.15rem;
|
||||
text-justify: inter-word;
|
||||
text-align: justify;
|
||||
hyphens: auto;
|
||||
}
|
||||
|
||||
article > p {
|
||||
text-indent: 2ch;
|
||||
line-height: 1.5em;
|
||||
}
|
||||
|
||||
article h1 + p,
|
||||
article h2 + p,
|
||||
article h3 + p,
|
||||
article h4 + p,
|
||||
article h5 + p,
|
||||
article h6 + p {
|
||||
text-indent: 0;
|
||||
}
|
||||
|
||||
.footnotes p {
|
||||
font-size: smaller;
|
||||
}
|
||||
|
||||
figure {
|
||||
border-color: var(--container-border);
|
||||
border-width: 1.5pt;
|
||||
|
|
@ -572,6 +602,55 @@ figcaption .mono {
|
|||
max-width: 100%;
|
||||
}
|
||||
|
||||
.character-dialog {
|
||||
display: grid;
|
||||
width: calc(100% - 1rem);
|
||||
grid-template-columns: 5rem 1fr;
|
||||
grid-template-rows: auto auto;
|
||||
gap: 1em;
|
||||
margin: 0.5rem;
|
||||
}
|
||||
|
||||
.character-avatar {
|
||||
display: grid;
|
||||
max-width: 100%;
|
||||
grid-row: 1 / span 2;
|
||||
grid-column: 1;
|
||||
align-self: start;
|
||||
align-items: center;
|
||||
justify-items: center;
|
||||
min-width: 5rem;
|
||||
min-height: 5rem;
|
||||
border-radius: 5rem;
|
||||
align-items: center;
|
||||
border-style: solid;
|
||||
border-color: var(--nav-button-background-hover);
|
||||
background-color: var(--cowhide-2);
|
||||
}
|
||||
|
||||
.character-avatar > img {
|
||||
max-width: 4rem;
|
||||
max-height: 4rem;
|
||||
}
|
||||
|
||||
.character-dialog-bubble {
|
||||
display: grid;
|
||||
grid-template-rows: auto auto;
|
||||
align-self: start;
|
||||
border-radius: 0.5em;
|
||||
border-width: 0.2rem;
|
||||
border-color: var(--nav-button-background);
|
||||
border-style: outset;
|
||||
row-gap: 0.5rem;
|
||||
padding: 0.5rem;
|
||||
background-color: var(--container-border);
|
||||
min-height: 5rem;
|
||||
}
|
||||
|
||||
.character-dialog-title {
|
||||
font-weight: bolder;
|
||||
}
|
||||
|
||||
/*
|
||||
Helper classes
|
||||
*/
|
||||
|
|
|
|||
6
layouts/posts/single.html
Normal file
|
|
@ -0,0 +1,6 @@
|
|||
{{ define "main" }}
|
||||
<article>
|
||||
<h1>{{ .Title }}</h1>
|
||||
{{ .Content }}
|
||||
</article>
|
||||
{{ end }}
|
||||
24
layouts/shortcodes/character-dialog.html
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
{{ $character := .Get 0 }}
|
||||
{{ $position := .Get 1 }}
|
||||
{{ $emotion := .Get 2 }}
|
||||
|
||||
{{ $resourceName := print "characters/" $character "/" $position "-" $emotion ".png" }}
|
||||
{{ $characterImageResource := resources.Get $resourceName }}
|
||||
|
||||
{{ $resizedCharacterImage := $characterImageResource.Resize "x100" }}
|
||||
|
||||
|
||||
<div class="character-dialog">
|
||||
<div class="character-avatar">
|
||||
<img
|
||||
src="{{ $resizedCharacterImage.Permalink }}"
|
||||
alt="thumbnail of {{ $character }} in {{ $emotion }} state"
|
||||
/>
|
||||
</div>
|
||||
<div class="character-dialog-bubble">
|
||||
<div class="character-dialog-title">
|
||||
{{ $character | humanize }}
|
||||
</div>
|
||||
<div class="character-dialog-text">{{ .Inner | markdownify }}</div>
|
||||
</div>
|
||||
</div>
|
||||