mirror of
https://github.com/searxng/searxng.git
synced 2025-12-22 19:50:00 +00:00
Lay the foundation for loading scripts granularly depending on the endpoint it's on. Remove vendor specific prefixes as there are now managed by browserslist and LightningCSS. Enabled quite a few rules in Biome that don't come in recommended to better catch issues and improve consistency. Related: - https://github.com/searxng/searxng/pull/5073#discussion_r2256037965 - https://github.com/searxng/searxng/pull/5073#discussion_r2256057100
63 lines
1.6 KiB
TypeScript
63 lines
1.6 KiB
TypeScript
import fs from "node:fs";
|
|
import path from "node:path";
|
|
import sharp from "sharp";
|
|
import type { Config } from "svgo";
|
|
import { optimize as svgo } from "svgo";
|
|
|
|
// Mapping of src to dest
|
|
export type Src2Dest = {
|
|
// Name of the source file.
|
|
src: string;
|
|
// Name of the destination file.
|
|
dest: string;
|
|
};
|
|
|
|
/**
|
|
* Convert a list of SVG files to PNG.
|
|
*
|
|
* @param items - Array of SVG files (src: SVG, dest:PNG) to convert.
|
|
*/
|
|
export const svg2png = (items: Src2Dest[]): void => {
|
|
for (const item of items) {
|
|
fs.mkdirSync(path.dirname(item.dest), { recursive: true });
|
|
|
|
sharp(item.src)
|
|
.png({
|
|
force: true,
|
|
compressionLevel: 9,
|
|
palette: true
|
|
})
|
|
.toFile(item.dest)
|
|
.then((info) => {
|
|
console.log(`[svg2png] created ${item.dest} -- bytes: ${info.size}, w:${info.width}px, h:${info.height}px`);
|
|
})
|
|
.catch((error) => {
|
|
console.error(`ERROR: ${item.dest} -- ${error}`);
|
|
throw error;
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Optimize SVG images for WEB.
|
|
*
|
|
* @param items - Array of SVG files (src:SVG, dest:SVG) to optimize.
|
|
* @param svgo_opts - Options passed to svgo.
|
|
*/
|
|
export const svg2svg = (items: Src2Dest[], svgo_opts: Config): void => {
|
|
for (const item of items) {
|
|
try {
|
|
fs.mkdirSync(path.dirname(item.dest), { recursive: true });
|
|
|
|
const raw = fs.readFileSync(item.src, "utf8");
|
|
const opt = svgo(raw, svgo_opts);
|
|
|
|
fs.writeFileSync(item.dest, opt.data);
|
|
console.log(`[svg2svg] optimized: ${item.dest} -- src: ${item.src}`);
|
|
} catch (error) {
|
|
console.error(`ERROR: optimize src: ${item.src} -- ${error}`);
|
|
throw error;
|
|
}
|
|
}
|
|
};
|