summaryrefslogtreecommitdiff
path: root/client/simple/tools/img.ts
blob: db4e0864573e45a1d1c1f8382f8f785e37ef795d (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
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 = async (items: Src2Dest[]) => {
  for (const item of items) {
    try {
      fs.mkdirSync(path.dirname(item.dest), { recursive: true });

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