8d2187d8b8
* refactor: new version of create-astro * chore: update README * fix(create-astro): update project name logic * test(create-astro): fix test on windows * test(create-astro): fix test on windows * test(create-astro): remove unused import * chore: remove log * chore: increase test timeout * fix: message when skipping * fix: message for env.d.ts file * fix: always hard exit * fix: return from next-steps * chore: add message * refactor dependencies, bundle create-astro * chore: disable create-astro typings * chore: switch to arg * chore: update message * fix: split typescript into two steps, fix context test * chore: update wording * chore: update wording * Update packages/create-astro/src/actions/dependencies.ts Co-authored-by: Yan Thomas <61414485+Yan-Thomas@users.noreply.github.com> * refactor: move tests back to mocha/chai * chore: update cli-kit * update test script * chore: add comment about setStdout * chore: update cli-kit * Update packages/create-astro/src/messages.ts Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> * Update packages/create-astro/src/messages.ts Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> * chore: update lockfile * fix(create-astro): support scoped package names, improve project-name tests * better git initialization * update cli-kit --------- Co-authored-by: Nate Moore <nate@astro.build> Co-authored-by: Yan Thomas <61414485+Yan-Thomas@users.noreply.github.com> Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
115 lines
2.9 KiB
JavaScript
115 lines
2.9 KiB
JavaScript
import esbuild from 'esbuild';
|
|
import svelte from '../utils/svelte-plugin.js';
|
|
import { deleteAsync } from 'del';
|
|
import { promises as fs } from 'fs';
|
|
import { dim, green, red, yellow } from 'kleur/colors';
|
|
import glob from 'tiny-glob';
|
|
import prebuild from './prebuild.js';
|
|
|
|
/** @type {import('esbuild').BuildOptions} */
|
|
const defaultConfig = {
|
|
minify: false,
|
|
format: 'esm',
|
|
platform: 'node',
|
|
target: 'node14',
|
|
sourcemap: false,
|
|
sourcesContent: false,
|
|
};
|
|
|
|
const dt = new Intl.DateTimeFormat('en-us', {
|
|
hour: '2-digit',
|
|
minute: '2-digit',
|
|
});
|
|
|
|
function getPrebuilds(isDev, args) {
|
|
let prebuilds = [];
|
|
while (args.includes('--prebuild')) {
|
|
let idx = args.indexOf('--prebuild');
|
|
prebuilds.push(args[idx + 1]);
|
|
args.splice(idx, 2);
|
|
}
|
|
if (prebuilds.length && isDev) {
|
|
prebuilds.unshift('--no-minify');
|
|
}
|
|
return prebuilds;
|
|
}
|
|
|
|
export default async function build(...args) {
|
|
const config = Object.assign({}, defaultConfig);
|
|
const isDev = args.slice(-1)[0] === 'IS_DEV';
|
|
const prebuilds = getPrebuilds(isDev, args);
|
|
const patterns = args
|
|
.filter((f) => !!f) // remove empty args
|
|
.map((f) => f.replace(/^'/, '').replace(/'$/, '')); // Needed for Windows: glob strings contain surrounding string chars??? remove these
|
|
let entryPoints = [].concat(
|
|
...(await Promise.all(
|
|
patterns.map((pattern) => glob(pattern, { filesOnly: true, absolute: true }))
|
|
))
|
|
);
|
|
|
|
const noClean = args.includes('--no-clean-dist');
|
|
const bundle = args.includes('--bundle');
|
|
const forceCJS = args.includes('--force-cjs');
|
|
|
|
const {
|
|
type = 'module',
|
|
version,
|
|
dependencies = {},
|
|
} = await fs.readFile('./package.json').then((res) => JSON.parse(res.toString()));
|
|
// expose PACKAGE_VERSION on process.env for CLI utils
|
|
config.define = { 'process.env.PACKAGE_VERSION': JSON.stringify(version) };
|
|
const format = type === 'module' && !forceCJS ? 'esm' : 'cjs';
|
|
|
|
const outdir = 'dist';
|
|
|
|
if (!noClean) {
|
|
await clean(outdir);
|
|
}
|
|
|
|
if (!isDev) {
|
|
await esbuild.build({
|
|
...config,
|
|
bundle,
|
|
external: bundle ? Object.keys(dependencies) : undefined,
|
|
entryPoints,
|
|
outdir,
|
|
outExtension: forceCJS ? { '.js': '.cjs' } : {},
|
|
format,
|
|
});
|
|
return;
|
|
}
|
|
|
|
const builder = await esbuild.build({
|
|
...config,
|
|
watch: {
|
|
onRebuild(error, result) {
|
|
if (prebuilds.length) {
|
|
prebuild(...prebuilds);
|
|
}
|
|
const date = dt.format(new Date());
|
|
if (error || (result && result.errors.length)) {
|
|
console.error(dim(`[${date}] `) + red(error || result.errors.join('\n')));
|
|
} else {
|
|
if (result.warnings.length) {
|
|
console.log(
|
|
dim(`[${date}] `) + yellow('⚠ updated with warnings:\n' + result.warnings.join('\n'))
|
|
);
|
|
}
|
|
console.log(dim(`[${date}] `) + green('✔ updated'));
|
|
}
|
|
},
|
|
},
|
|
entryPoints,
|
|
outdir,
|
|
format,
|
|
plugins: [svelte({ isDev })],
|
|
});
|
|
|
|
process.on('beforeExit', () => {
|
|
builder.stop && builder.stop();
|
|
});
|
|
}
|
|
|
|
async function clean(outdir) {
|
|
return deleteAsync([`${outdir}/**`, `!${outdir}/**/*.d.ts`]);
|
|
}
|