aboutsummaryrefslogtreecommitdiff
path: root/packages/taler-wallet-webextension/build-fast-with-linaria.mjs
blob: 890217ae201bf223ab89bf7a879374591d987677 (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
65
66
67
68
69
70
71
72
73
74
75
76
77

import linaria from '@linaria/esbuild'
import esbuild from 'esbuild'
import path from "path"
import fs from "fs"

function getFilesInDirectory(startPath, regex) {
  if (!fs.existsSync(startPath)) {
    return;
  }
  const files = fs.readdirSync(startPath);
  const result = files.flatMap(file => {
    const filename = path.join(startPath, file);

    const stat = fs.lstatSync(filename);
    if (stat.isDirectory()) {
      return getFilesInDirectory(filename, regex);
    }
    else if (regex.test(filename)) {
      return filename
    }
  }).filter(x => !!x)

  return result
}

const allTestFiles = getFilesInDirectory(path.join(process.cwd(), 'src'), /.test.ts$/)

const preact = path.join(process.cwd(), "node_modules", "preact", "compat", "dist", "compat.module.js");
const preactCompatPlugin = {
  name: "preact-compat",
  setup(build) {
    build.onResolve({ filter: /^(react-dom|react)$/ }, args => ({ path: preact }));
  }
}

const entryPoints = [
  'src/popupEntryPoint.tsx', 'src/walletEntryPoint.tsx', 'src/background.ts', 'src/browserWorkerEntry.ts'
]

await esbuild
  .build({
    entryPoints: [...entryPoints, ...allTestFiles],
    bundle: true,
    outdir: 'dist',
    minify: false,
    loader: {
      '.svg': 'text',
      '.png': 'file',
    },
    target: [
      'es6'
    ],
    format: 'iife',
    platform: 'browser',
    sourcemap: 'external',
    jsxFactory: 'h',
    jsxFragment: 'Fragment',
    // define: {
    //   'process.env.NODE_ENV': '"development"',
    // },
    plugins: [
      preactCompatPlugin,
      linaria.default({
        babelOptions: {
          babelrc: false,
          configFile: './babel.config-linaria.json',
        },
        sourceMap: true,
      }),
    ],
  })
  .catch((e) => {
    console.log(e)
    process.exit(1)
  });