Finally finish this enough to post
From here I will actually track changed with git but I just needed a base to work from. RIP this attomic ass commit
Before Width: | Height: | Size: 71 KiB After Width: | Height: | Size: 60 KiB |
Before Width: | Height: | Size: 447 KiB After Width: | Height: | Size: 388 KiB |
Before Width: | Height: | Size: 64 KiB After Width: | Height: | Size: 54 KiB |
Before Width: | Height: | Size: 949 B After Width: | Height: | Size: 825 B |
Before Width: | Height: | Size: 2.8 KiB After Width: | Height: | Size: 2.5 KiB |
70
public/static/TODO/MiyukoButtonCache.md
Normal file
|
@ -0,0 +1,70 @@
|
|||
|
||||
> I use @11ty/eleventy-fetch for downloading the button images
|
||||
|
||||
> I have a `buttons_.yml` file in the same directory as this file, the root is an array of arrays so all buttons are split into tiers. plus the files that go into the build directory get a hash sum in their filename
|
||||
|
||||
```js
|
||||
import * as crypto from 'node:crypto'
|
||||
import * as fs from 'node:fs/promises'
|
||||
import * as path from 'node:path'
|
||||
import * as yaml from 'yaml'
|
||||
import eleventyFetch from '@11ty/eleventy-fetch'
|
||||
import { getURLHostname } from '../utils'
|
||||
import buttonsFile from './buttons_.yml?raw'
|
||||
|
||||
async function process(buttons) {
|
||||
buttons = await Promise.all(buttons.map(async button => {
|
||||
let image
|
||||
if (button.image.startsWith('./')) {
|
||||
image = await fs.readFile(button.image)
|
||||
} else {
|
||||
image = await eleventyFetch(button.image, {
|
||||
duration: '1w',
|
||||
})
|
||||
}
|
||||
let hash = crypto.createHash('sha512')
|
||||
hash.update(image)
|
||||
let suffix = hash.digest('hex').slice(0, 12)
|
||||
let imageURL = `/buttons/${button.ident}-${suffix}`
|
||||
let imagePath = `public/${imageURL}`
|
||||
await fs.mkdir(path.dirname(imagePath), { recursive: true })
|
||||
await fs.writeFile(imagePath, image)
|
||||
|
||||
return {
|
||||
width: 88,
|
||||
height: 31,
|
||||
...button,
|
||||
alt: button.alt,
|
||||
image: imageURL,
|
||||
originalImage: button.image,
|
||||
}
|
||||
}))
|
||||
|
||||
buttons = buttons.toSorted((a, b) => {
|
||||
if (a.priority !== b.priority) {
|
||||
return a.priority - b.priority
|
||||
}
|
||||
|
||||
let aHost = getURLHostname(a.url)
|
||||
let bHost = getURLHostname(b.url)
|
||||
|
||||
if (aHost < bHost) {
|
||||
return -1
|
||||
} else if (aHost > bHost) {
|
||||
return 1
|
||||
} else {
|
||||
return 0
|
||||
}
|
||||
})
|
||||
|
||||
return buttons
|
||||
}
|
||||
|
||||
let tiers = yaml.parse(buttonsFile)
|
||||
|
||||
export const buttons = await Promise.all(
|
||||
tiers.map(tier => process(tier)),
|
||||
)
|
||||
|
||||
export const buttonsFlattened = buttons.flat()
|
||||
``
|
BIN
public/static/fonts/ComicMono-Bold.ttf
Normal file
BIN
public/static/fonts/ComicMono.ttf
Normal file
BIN
public/static/fonts/NotoSans-Regular.ttf
Normal file
BIN
public/static/fonts/NotoSans-Regular.ttf.gz
Normal file
BIN
public/static/fonts/NotoSans-Regular.ttf.zst
Normal file
BIN
public/static/fonts/comic shanns 2.ttf
Normal file
BIN
public/static/fonts/comic shanns.otf
Normal file
BIN
public/static/img/blog/UseAFramework_20241217_002719.png
Normal file
After Width: | Height: | Size: 28 KiB |
BIN
public/static/img/blog/aira.coffee-cloudflair-alldone.png
Normal file
After Width: | Height: | Size: 21 KiB |
BIN
public/static/img/sites/avatar-ht-f.png
Normal file
After Width: | Height: | Size: 713 KiB |
BIN
public/static/img/sites/avatar-ht-f.webp
Normal file
After Width: | Height: | Size: 30 KiB |
BIN
public/static/img/sites/avatar-ht.png
Normal file
After Width: | Height: | Size: 941 KiB |
BIN
public/static/img/sites/avatar.png
Normal file
After Width: | Height: | Size: 1.6 MiB |