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;
|
"URW Bookman L", "Georgia Pro", Georgia, serif;
|
||||||
--font-family-slab-serif: Rockwell, "Rockwell Nova", "Roboto Slab",
|
--font-family-slab-serif: Rockwell, "Rockwell Nova", "Roboto Slab",
|
||||||
"DejaVu Serif", "Sitka Small", serif;
|
"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-system-ui: system-ui, sans-serif;
|
||||||
--font-family-monospace: "Nimbus Mono PS", "Courier New", monospace;
|
--font-family-monospace: "Nimbus Mono PS", "Courier New", monospace;
|
||||||
}
|
}
|
||||||
|
|
@ -272,6 +274,34 @@ main {
|
||||||
flex-direction: column;
|
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 {
|
figure {
|
||||||
border-color: var(--container-border);
|
border-color: var(--container-border);
|
||||||
border-width: 1.5pt;
|
border-width: 1.5pt;
|
||||||
|
|
@ -572,6 +602,55 @@ figcaption .mono {
|
||||||
max-width: 100%;
|
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
|
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>
|
||||||