Files
integration/website/bin/transform-source-backgrounds.mjs
Emmanuel Pelletier d9859f1564 first commit:
- we have a static astro website under /website. It has the
implementation docs of the homepage/gaufre templates, and it handles the
few API endpoints (the gaufre js, backgrounds, logos)
- we have a vite app under /packages/integration. It has the react
components generating the homepage and the gaufre button, and their css.
Its used to generate an npm package
2024-05-02 00:35:38 +02:00

50 lines
1.5 KiB
JavaScript

import fs from "fs"
import path from "path"
import { promisify } from "util"
import sharp from "sharp"
import svgGradient from "svg-gradient"
const readdir = promisify(fs.readdir)
const sourcesDir = path.join(import.meta.dirname, "..", "src", "assets", "backgrounds", "sources")
const outputDir = path.join(import.meta.dirname, "..", "src", "assets", "backgrounds")
async function resizeSourceBackgrounds() {
try {
console.log(`Resizing source background files…`)
const gradient = await sharp(
Buffer.from(
svgGradient(`linear-gradient(135deg, rgba(0, 0, 145, 0.6) 0%, rgba(225, 0, 15, 0.6) 100%)`),
),
)
.resize(1920, 1200, { fit: "cover" })
.toBuffer()
const backgrounds = await readdir(sourcesDir)
backgrounds.forEach((backgroundFile, i) => {
const srcPath = path.join(sourcesDir, backgroundFile)
const jpegPath = path.join(outputDir, `${i}.jpg`)
const avifPath = path.join(outputDir, `${i}.avif`)
const image = sharp(srcPath)
.resize(1920, 1200, { fit: "cover" })
.composite([{ input: gradient }])
image.toFile(jpegPath).then(() => {
console.log(`Resized ${getFilename(backgroundFile)} to ${getFilename(jpegPath)}`)
})
image.toFile(avifPath).then(() => {
console.log(`Resized ${getFilename(backgroundFile)} to ${getFilename(avifPath)}`)
})
})
} catch (error) {
console.error("Error:", error)
}
}
function getFilename(path) {
return path.split("/").pop()
}
resizeSourceBackgrounds()