storybook/scripts/utils/compile-tsc.js
2022-11-09 14:27:19 +11:00

102 lines
2.7 KiB
JavaScript

/* eslint-disable no-console */
const fs = require('fs-extra');
const path = require('path');
function getCommand(watch) {
const args = [
'--outDir ./dist/types',
'--listEmittedFiles false',
'--declaration true',
'--noErrorTruncation',
'--pretty',
];
/**
* Only emit declarations if it does not need to be compiled with tsc
* Currently, angular and storyshots (that contains an angular component) need to be compiled
* with tsc. (see comments in compile-babel.js)
*/
const isAngular = process.cwd().includes(path.join('frameworks', 'angular'));
const isStoryshots = process.cwd().includes(path.join('addons', 'storyshots'));
if (!isAngular && !isStoryshots) {
args.push('--emitDeclarationOnly');
}
if (watch) {
args.push('-w', '--preserveWatchOutput');
}
return [`yarn run -T tsc ${args.join(' ')}`, isAngular || isStoryshots];
}
function handleExit(code, stderr, errorCallback) {
if (code !== 0) {
if (errorCallback && typeof errorCallback === 'function') {
errorCallback(stderr);
}
process.exit(code);
}
}
async function run({ optimized, watch, silent, errorCallback }) {
const execa = await import('execa');
return new Promise((resolve, reject) => {
const [command, tscOnly] = getCommand(watch);
if (tscOnly || optimized) {
const child = execa.execaCommand(command, {
buffer: false,
});
let stderr = '';
if (watch) {
child.stdout.pipe(process.stdout);
child.stderr.pipe(process.stderr);
} else {
child.stderr.on('data', (data) => {
stderr += data.toString();
});
child.stdout.on('data', (data) => {
stderr += data.toString();
});
}
child.on('exit', (code) => {
resolve();
handleExit(code, stderr, errorCallback);
});
} else {
console.log(`skipping generating types for ${process.cwd()}`);
const loc = path.join(process.cwd(), 'dist', 'types');
Promise.resolve()
.then(() => fs.emptyDir(loc))
.then(() => fs.writeFile(path.join(loc, 'index.d.ts'), `export * from '../../src/index';`))
.then(resolve);
}
});
}
async function tscfy(options = {}) {
const { watch = false, silent = false, errorCallback, optimized = false } = options;
const tsConfigFile = 'tsconfig.json';
if (!(await fs.pathExists(tsConfigFile))) {
if (!silent) {
console.log(`No ${tsConfigFile}`);
}
return;
}
const tsConfig = await fs.readJSON(tsConfigFile);
if (!(tsConfig && tsConfig.lerna && tsConfig.lerna.disabled === true)) {
await run({ watch, silent, errorCallback, optimized });
}
}
module.exports = {
tscfy,
};