pride-buttons/main.js

115 lines
3.8 KiB
JavaScript
Raw Normal View History

2025-02-02 19:42:18 +01:00
import data from './data.json' with { type: "json" };
import gm from "gm";
import * as fs from "fs";
const myGm = gm.subClass({imageMagick: true});
const position = {x: 4, y: 2, gravity: "NorthEast"}
const metadatas = []
2025-02-04 20:58:21 +01:00
function createFilename(prideflag, text, now = false) {
2025-02-12 20:11:57 +01:00
const adaptedText = text
.replaceAll("⋅", "_")
.replaceAll(" ", "_")
.replaceAll("\n", '-')
2025-02-13 15:42:03 +01:00
.normalize("NFD").replaceAll(/[\u0300-\u036f]/g, "")
.replaceAll("&", "and")
.replaceAll("+", "")
2025-02-12 20:11:57 +01:00
.toLowerCase();
return `${prideflag.name.en.toLowerCase()}-${adaptedText}${now?'-now':''}.png`;
2025-02-04 20:27:53 +01:00
}
function createButton(source, x, y, text, gravity) {
const turnedText = text
2025-02-13 15:42:03 +01:00
.replaceAll("⋅", "-")
2025-02-04 20:27:53 +01:00
.toUpperCase();
return myGm(source)
.font('./NFPixels-Regular.ttf', 10)
.drawText(x-1, y, turnedText, gravity)
.drawText(x+1, y, turnedText, gravity)
.drawText(x, y+1, turnedText, gravity)
.drawText(x, y-1, turnedText, gravity)
.drawText(x-1, y-1, turnedText, gravity)
.drawText(x+1, y+1, turnedText, gravity)
.drawText(x-1, y+1, turnedText, gravity)
.drawText(x+1, y-1, turnedText, gravity)
.fill("#FFFFFF")
.drawText(x, y, turnedText, gravity);
};
2025-02-04 20:58:21 +01:00
function createMetadatas(prideflag, text, now = false) {
const filename = createFilename(prideflag, text, now);
2025-02-13 15:42:03 +01:00
const textForAlt = text.replaceAll("\n", " ").toLowerCase();
2025-02-04 20:58:21 +01:00
const alt = `Drapeau ${prideflag.name.fr.toLowerCase()} avec écrit "${textForAlt}${now?", now!": ""}"`
2025-02-04 20:27:53 +01:00
return {file:filename, alt:alt, text:textForAlt};
}
2025-02-04 19:45:58 +01:00
let count = 0;
let flagCount = 0;
2025-02-04 19:45:58 +01:00
const start = Date.now();
2025-02-02 19:42:18 +01:00
data.forEach(prideflag => {
console.log(`== Creating flags for ${prideflag.name.en}`);
const imageMetadata = {title:`Drapeau ${prideflag.name.fr.toLowerCase()} :`, list:[]};
prideflag.texts.forEach(text => {
2025-02-04 20:58:21 +01:00
const metadatas = createMetadatas(prideflag, text, false)
2025-02-04 20:27:53 +01:00
imageMetadata.list.push(metadatas);
console.log(`Creating button for text "${metadatas.text}" (${metadatas.file})`);
createButton(prideflag.source, position.x, position.y, text, position.gravity)
.write(`./output/${metadatas.file}`, function (err) {
2025-02-02 19:42:18 +01:00
if (err) {
console.error(err);
throw err;
};
});
2025-02-04 19:45:58 +01:00
count++;
2025-02-02 19:42:18 +01:00
})
2025-02-04 20:58:21 +01:00
if (prideflag.textsNow) {
prideflag.textsNow.forEach(text => {
const metadatas = createMetadatas(prideflag, text, true)
imageMetadata.list.push(metadatas);
console.log(`Creating button for text "${metadatas.text}" (${metadatas.file})`);
createButton(prideflag.source, position.x+12, position.y, text, position.gravity)
.write(`./tmp/${metadatas.file}`, function (err) {
if (err) {
console.error(err);
throw err;
};
});
setTimeout(() => {
myGm(`./tmp/${metadatas.file}`)
.composite("./sources/now.gif")
.write(`./output/${metadatas.file}`, function (err) {
if (err) {
console.error(err);
throw err;
};
});
}, 100);
count++;
})
}
flagCount++;
2025-02-02 19:42:18 +01:00
metadatas.push(imageMetadata);
});
2025-02-04 19:45:58 +01:00
const millis = Date.now() - start;
console.log("");
console.log("-----------------------")
console.log(`Generation finished in ${millis / 1000}s`);
console.log(`${flagCount} flags processed`);
2025-02-04 19:45:58 +01:00
console.log(`${count} files generated`);
2025-02-02 19:42:18 +01:00
fs.writeFile("./output/pridebuttons.json", JSON.stringify(metadatas), (err) => {
if (err) {
console.error(err);
throw err;
}
});