summaryrefslogtreecommitdiff
path: root/client/simple/tools/img.js
blob: 0b1b96ed8ca13ff1ff1db151b8b79469bdd54520 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import fs from "node:fs";
import path from "node:path";
import sharp from "sharp";
import { optimize as svgo } from "svgo";

/**
 * @typedef {object} Src2Dest - Mapping of src to dest
 * @property {string} src - Name of the source file.
 * @property {string} dest - Name of the destination file.
 */

/**
 * Convert a list of SVG files to PNG.
 *
 * @param {Src2Dest[]} items - Array of SVG files (src: SVG, dest:PNG) to convert.
 */
async function svg2png(items) {
  for (const item of items) {
    try {
      fs.mkdir(path.dirname(item.dest), { recursive: true }, (err) => {
        if (err) throw err;
      });

      const info = await sharp(item.src)
        .png({
          force: true,
          compressionLevel: 9,
          palette: true
        })
        .toFile(item.dest);

      console.log(`[svg2png] created ${item.dest} -- bytes: ${info.size}, w:${info.width}px,  h:${info.height}px`);
    } catch (err) {
      console.error(`ERROR: ${item.dest} -- ${err}`);
      throw err;
    }
  }
}

/**
 * Optimize SVG images for WEB.
 *
 * @param {Src2Dest[]} items - Array of SVG files (src:SVG, dest:SVG) to optimize.
 * @param {import('svgo').Config} svgo_opts - Options passed to svgo.
 */
async function svg2svg(items, svgo_opts) {
  for (const item of items) {
    try {
      fs.mkdir(path.dirname(item.dest), { recursive: true }, (err) => {
        if (err) throw err;
      });

      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 (err) {
      console.error(`ERROR: optimize src: ${item.src} -- ${err}`);
      throw err;
    }
  }
}

export { svg2png, svg2svg };