2022-09-08 21:40:48 +02:00
|
|
|
|
import * as fs from "fs"
|
2024-07-10 11:40:00 +02:00
|
|
|
|
import Script from "./Script"
|
2023-11-19 04:38:34 +01:00
|
|
|
|
|
2021-11-21 02:44:35 +01:00
|
|
|
|
function genImages(dryrun = false) {
|
2020-11-06 01:58:26 +01:00
|
|
|
|
console.log("Generating images")
|
|
|
|
|
const dir = fs.readdirSync("./assets/svg")
|
|
|
|
|
for (const path of dir) {
|
2021-09-09 00:05:51 +02:00
|
|
|
|
if (path.endsWith("license_info.json")) {
|
2022-09-08 21:40:48 +02:00
|
|
|
|
continue
|
2021-04-10 15:01:28 +02:00
|
|
|
|
}
|
2023-07-27 14:15:30 +02:00
|
|
|
|
if (path.endsWith(".license")) {
|
|
|
|
|
continue
|
|
|
|
|
}
|
2021-09-09 00:05:51 +02:00
|
|
|
|
|
2020-11-06 01:58:26 +01:00
|
|
|
|
if (!path.endsWith(".svg")) {
|
2022-09-08 21:40:48 +02:00
|
|
|
|
throw "Non-svg file detected in the svg files: " + path
|
2020-11-06 01:58:26 +01:00
|
|
|
|
}
|
|
|
|
|
|
2022-09-08 21:40:48 +02:00
|
|
|
|
let svg: string = fs
|
|
|
|
|
.readFileSync("./assets/svg/" + path, "utf-8")
|
2020-11-14 02:54:33 +01:00
|
|
|
|
.replace(/<\?xml.*?>/, "")
|
2023-11-19 04:38:34 +01:00
|
|
|
|
.replace(/<!DOCTYPE [^>]*>/, "")
|
2021-09-09 00:05:51 +02:00
|
|
|
|
.replace(/fill: ?none;/g, "fill: none !important;") // This is such a brittle hack...
|
2020-11-06 01:58:26 +01:00
|
|
|
|
.replace(/\n/g, " ")
|
|
|
|
|
.replace(/\r/g, "")
|
|
|
|
|
.replace(/\\/g, "\\")
|
2024-07-10 11:40:00 +02:00
|
|
|
|
.replace(/"/g, "\\\"")
|
2023-10-26 14:13:04 +02:00
|
|
|
|
.replaceAll(" ", " ")
|
2022-07-26 11:38:10 +02:00
|
|
|
|
|
2023-10-26 14:13:04 +02:00
|
|
|
|
let hasNonAsciiChars = Array.from(svg)
|
|
|
|
|
.filter((char) => char.charCodeAt(0) > 127)
|
|
|
|
|
.map((char) => char.charCodeAt(0))
|
|
|
|
|
.join(", ")
|
|
|
|
|
if (hasNonAsciiChars.length > 0) {
|
|
|
|
|
throw "The svg '" + path + "' has non-ascii characters: " + hasNonAsciiChars
|
2022-07-26 11:38:10 +02:00
|
|
|
|
}
|
2022-09-19 12:34:05 +02:00
|
|
|
|
const name = path.substring(0, path.length - 4).replace(/[ -]/g, "_")
|
2021-11-21 02:44:35 +01:00
|
|
|
|
|
2023-10-06 23:56:50 +02:00
|
|
|
|
const nameUC = name.toUpperCase().at(0) + name.substring(1)
|
|
|
|
|
const svelteCode =
|
2024-07-10 11:40:00 +02:00
|
|
|
|
"<script>\nexport let color = \"#000000\"\n</script>\n" +
|
2023-11-16 03:30:29 +01:00
|
|
|
|
svg
|
|
|
|
|
.replace(
|
|
|
|
|
"<svg ",
|
2024-07-10 11:40:00 +02:00
|
|
|
|
"<svg {...$$$$restProps} on:click on:mouseover on:mouseenter on:mouseleave on:keydown ",
|
2023-11-16 03:30:29 +01:00
|
|
|
|
)
|
2024-07-10 11:40:00 +02:00
|
|
|
|
.replace(/\\"/g, "\"")
|
2023-11-16 03:30:29 +01:00
|
|
|
|
.replace(/(rgb\(0%,0%,0%\)|#000000|#000)/g, "{color}")
|
2023-10-06 23:56:50 +02:00
|
|
|
|
fs.writeFileSync("./src/assets/svg/" + nameUC + ".svelte", svelteCode, "utf8")
|
2023-11-19 04:38:34 +01:00
|
|
|
|
|
2024-07-10 11:40:00 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-19 04:38:34 +01:00
|
|
|
|
|
|
|
|
|
|
2024-07-10 11:40:00 +02:00
|
|
|
|
class GenerateIncludedImages extends Script {
|
|
|
|
|
constructor() {
|
|
|
|
|
super("Converts all images from assets/svg into svelte-classes.")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async main(args: string[]): Promise<void> {
|
|
|
|
|
genImages()
|
|
|
|
|
|
2020-11-06 01:58:26 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-09-09 00:05:51 +02:00
|
|
|
|
|
2024-07-10 11:40:00 +02:00
|
|
|
|
new GenerateIncludedImages().run()
|