wallet-core/packages/merchant-backend-ui/build.mjs

165 lines
4.5 KiB
JavaScript
Raw Normal View History

2023-03-02 17:51:03 +01:00
#!/usr/bin/env node
/*
This file is part of GNU Taler
(C) 2021-2023 Taler Systems S.A.
GNU Taler is free software; you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software
Foundation; either version 3, or (at your option) any later version.
GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with
GNU Taler; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
*/
import esbuild from "esbuild";
import path from "path";
import fs from "fs";
import linaria from '@linaria/esbuild'
// eslint-disable-next-line no-undef
const BASE = process.cwd();
const preact = path.join(
BASE,
"node_modules",
"preact",
"compat",
"dist",
"compat.module.js",
);
const preactCompatPlugin = {
name: "preact-compat",
setup(build) {
build.onResolve({ filter: /^(react-dom|react)$/ }, (args) => {
//console.log("onresolve", JSON.stringify(args, undefined, 2));
return {
path: preact,
};
});
},
};
const pages = ["OfferTip","OfferRefund","DepletedTip","RequestPayment","ShowOrderDetails"]
const entryPoints = pages.map(p => `src/pages/${p}.tsx`);
let GIT_ROOT = BASE;
while (!fs.existsSync(path.join(GIT_ROOT, ".git")) && GIT_ROOT !== "/") {
GIT_ROOT = path.join(GIT_ROOT, "../");
}
if (GIT_ROOT === "/") {
// eslint-disable-next-line no-undef
console.log("not found");
// eslint-disable-next-line no-undef
process.exit(1);
}
const GIT_HASH = GIT_ROOT === "/" ? undefined : git_hash();
let _package = JSON.parse(fs.readFileSync(path.join(BASE, "package.json")));
function git_hash() {
const rev = fs
.readFileSync(path.join(GIT_ROOT, ".git", "HEAD"))
.toString()
.trim()
.split(/.*[: ]/)
.slice(-1)[0];
if (rev.indexOf("/") === -1) {
return rev;
} else {
return fs.readFileSync(path.join(GIT_ROOT, ".git", rev)).toString().trim();
}
}
2023-03-02 18:09:44 +01:00
function toCamelCaseName(name) {
return name
.replace(/^[A-Z]/, letter => `${letter.toLowerCase()}`) //first letter lowercase
.replace(/[A-Z]/g, letter => `_${letter.toLowerCase()}`) //snake case
.concat(".en.html"); //extension
}
2023-03-02 17:51:03 +01:00
function templatePlugin(options) {
return {
name: "template-backend",
setup(build) {
build.onEnd(() => {
2023-03-02 18:09:44 +01:00
for (const pageName of options.pages) {
const css = fs.readFileSync(path.join(build.initialOptions.outdir, `${pageName}.css`),"utf8").toString()
const js = fs.readFileSync(path.join(build.initialOptions.outdir, `${pageName}.js`),"utf8").toString()
const location = path.join(build.initialOptions.outdir, toCamelCaseName(pageName))
2023-03-02 17:51:03 +01:00
const render = new Function(`${js}; return page.buildTimeRendering();`)()
2023-03-02 18:09:44 +01:00
const html = `
2023-03-02 17:51:03 +01:00
<!doctype html>
<html>
<head>
${render.head}
2023-03-02 18:09:44 +01:00
<style>${css}</style>
2023-03-02 17:51:03 +01:00
</head>
<script id="built_time_data">
</script>
<body>
${render.body}
2023-03-02 18:09:44 +01:00
<script>${js}</script>
2023-03-02 17:51:03 +01:00
<script>page.mount()</script>
</body>
</html>`
2023-03-02 18:09:44 +01:00
fs.writeFileSync(location, html);
2023-03-02 17:51:03 +01:00
}
});
},
};
}
export const buildConfig = {
entryPoints: [...entryPoints],
bundle: true,
outdir: "dist/pages",
2023-04-04 14:08:16 +02:00
/*
* Doing a minified version will replace templatestring to common strings
* This app is building mustache template with placeholders that will be replaced
* with string in runtime by the merchant-backend
*
* To the date, merchant backend is replacing with multiline string so
* doing minified version will brake at runtime
* */
minify: false,
2023-03-02 17:51:03 +01:00
loader: {
".svg": "file",
".png": "dataurl",
".jpeg": "dataurl",
'.ttf': 'file',
'.woff': 'file',
'.woff2': 'file',
'.eot': 'file',
},
target: ["es6"],
format: "iife",
platform: "browser",
sourcemap: false,
globalName: "page",
jsxFactory: "h",
jsxFragment: "Fragment",
define: {
__VERSION__: `"${_package.version}"`,
__GIT_HASH__: `"${GIT_HASH}"`,
},
plugins: [
linaria.default({
babelOptions: {
babelrc: false,
configFile: './babel.config-linaria.json',
},
sourceMap: true,
}),
preactCompatPlugin,
templatePlugin({pages})
],
};
await esbuild.build(buildConfig)