env setup

This commit is contained in:
Sebastian 2023-06-01 09:20:36 -03:00
parent 5e4c128319
commit 2332101482
No known key found for this signature in database
GPG Key ID: 173909D1A5F66069
2 changed files with 47 additions and 23 deletions

View File

@ -70,9 +70,13 @@ function copyFilesPlugin(files: Array<string>) {
return { return {
name: "copy-files", name: "copy-files",
setup(build: PluginBuild) { setup(build: PluginBuild) {
if (!files || !files.length) {
return;
}
const outDir = build.initialOptions.outdir; const outDir = build.initialOptions.outdir;
if (outDir === undefined) if (outDir === undefined) {
throw Error("esbuild build options does not specify outdir"); throw Error("esbuild build options does not specify outdir");
}
build.onEnd(() => { build.onEnd(() => {
for (const file of files) { for (const file of files) {
const name = path.parse(file).base; const name = path.parse(file).base;
@ -143,7 +147,6 @@ function linariaPlugin() {
const defaultEsBuildConfig: esbuild.BuildOptions = { const defaultEsBuildConfig: esbuild.BuildOptions = {
bundle: true, bundle: true,
minify: false,
loader: { loader: {
".svg": "file", ".svg": "file",
".inline.svg": "text", ".inline.svg": "text",
@ -157,7 +160,6 @@ const defaultEsBuildConfig: esbuild.BuildOptions = {
target: ["es6"], target: ["es6"],
format: "esm", format: "esm",
platform: "browser", platform: "browser",
sourcemap: true,
jsxFactory: "h", jsxFactory: "h",
jsxFragment: "Fragment", jsxFragment: "Fragment",
alias: { alias: {
@ -171,6 +173,7 @@ const defaultEsBuildConfig: esbuild.BuildOptions = {
}; };
export interface BuildParams { export interface BuildParams {
type: "development" | "test" | "production";
source: { source: {
assets: string[]; assets: string[];
js: string[]; js: string[];
@ -186,33 +189,54 @@ export function computeConfig(params: BuildParams): esbuild.BuildOptions {
copyFilesPlugin(params.source.assets), copyFilesPlugin(params.source.assets),
]; ];
switch (params.css) { if (params.css) {
case "sass": { switch (params.css) {
plugins.push(sassPlugin); case "sass": {
break; plugins.push(sassPlugin);
} break;
case "postcss": { }
plugins.push(postCssPlugin); case "postcss": {
break; plugins.push(postCssPlugin);
} break;
case "linaria": {
if (params.linariaPlugin) {
plugins.push(params.linariaPlugin());
} }
break;
}
default: { case "linaria": {
const cssType: never = params.css; if (params.linariaPlugin) {
throw Error(`not supported: ${cssType}`); plugins.push(params.linariaPlugin());
}
break;
}
default: {
const cssType: never = params.css;
throw Error(`not supported: ${cssType}`);
}
} }
} }
if (!params.type) {
throw Error(
`missing build type, it should be "test", "development" or "production"`,
);
}
if (!params.source.js) {
throw Error(`no javascript entry points, nothing to compile?`);
}
if (!params.destination) {
throw Error(`missing destination folder`);
}
return { return {
...defaultEsBuildConfig, ...defaultEsBuildConfig,
entryPoints: params.source.js, entryPoints: params.source.js,
publicPath: params.public, publicPath: params.public,
outdir: params.destination, outdir: params.destination,
minify: false, //params.type === "production",
sourcemap: true, //params.type !== "production",
define: {
...defaultEsBuildConfig.define,
"process.env.NODE_ENV": JSON.stringify(params.type),
},
plugins, plugins,
}; };
} }

View File

@ -108,9 +108,9 @@ export class BrowserHttpLib implements HttpRequestLibrary {
}, requestTimeout.d_ms); }, requestTimeout.d_ms);
} }
for (const headerName in Object.keys(requestHeadersMap)) { Object.keys(requestHeadersMap).forEach((headerName) => {
myRequest.setRequestHeader(headerName, requestHeadersMap[headerName]); myRequest.setRequestHeader(headerName, requestHeadersMap[headerName]);
} });
myRequest.responseType = "arraybuffer"; myRequest.responseType = "arraybuffer";
myRequest.send(myBody); myRequest.send(myBody);