mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-06 07:21:16 +08:00
90 lines
2.4 KiB
JavaScript
90 lines
2.4 KiB
JavaScript
import fs from 'fs';
|
|
import JSON5 from 'json5';
|
|
import {
|
|
getVersions,
|
|
getPackageJson,
|
|
writePackageJson,
|
|
getBabelDependencies,
|
|
installDependencies,
|
|
copyTemplate,
|
|
} from '../../lib/helpers';
|
|
|
|
export default async (npmOptions, { storyFormat = 'csf' }) => {
|
|
const [
|
|
storybookVersion,
|
|
actionsVersion,
|
|
linksVersion,
|
|
addonsVersion,
|
|
reactVersion,
|
|
reactDomVersion,
|
|
presetEnvVersion,
|
|
presetReactVersion,
|
|
] = await getVersions(
|
|
npmOptions,
|
|
'@storybook/react',
|
|
'@storybook/addon-actions',
|
|
'@storybook/addon-links',
|
|
'@storybook/addons',
|
|
'react',
|
|
'react-dom',
|
|
'@babel/preset-env',
|
|
'@babel/preset-react'
|
|
);
|
|
|
|
copyTemplate(__dirname, storyFormat);
|
|
|
|
const packageJson = getPackageJson();
|
|
packageJson.devDependencies = packageJson.devDependencies || {};
|
|
packageJson.scripts = packageJson.scripts || {};
|
|
packageJson.dependencies = packageJson.dependencies || {};
|
|
|
|
const devDependencies = [
|
|
`@storybook/react@${storybookVersion}`,
|
|
`@storybook/addon-actions@${actionsVersion}`,
|
|
`@storybook/addon-links@${linksVersion}`,
|
|
`@storybook/addons@${addonsVersion}`,
|
|
];
|
|
|
|
// create or update .babelrc
|
|
let babelrc = null;
|
|
if (fs.existsSync('.babelrc')) {
|
|
const babelrcContent = fs.readFileSync('.babelrc', 'utf8');
|
|
babelrc = JSON5.parse(babelrcContent);
|
|
babelrc.plugins = babelrc.plugins || [];
|
|
} else {
|
|
babelrc = {
|
|
presets: [
|
|
['@babel/preset-env', { shippedProposals: true, useBuiltIns: 'usage', corejs: '3' }],
|
|
'@babel/preset-react',
|
|
],
|
|
};
|
|
|
|
devDependencies.push(`@babel/preset-env@${presetEnvVersion}`);
|
|
devDependencies.push(`@babel/preset-react@${presetReactVersion}`);
|
|
}
|
|
|
|
fs.writeFileSync('.babelrc', JSON.stringify(babelrc, null, 2), 'utf8');
|
|
|
|
packageJson.scripts.storybook = 'start-storybook -p 6006';
|
|
packageJson.scripts['build-storybook'] = 'build-storybook';
|
|
|
|
writePackageJson(packageJson);
|
|
|
|
const babelDependencies = await getBabelDependencies(npmOptions, packageJson);
|
|
|
|
// add react packages.
|
|
const dependencies = [];
|
|
if (!packageJson.dependencies.react) {
|
|
dependencies.push(`react@${reactVersion}`);
|
|
}
|
|
if (!packageJson.dependencies['react-dom']) {
|
|
dependencies.push(`react-dom@${reactDomVersion}`);
|
|
}
|
|
|
|
if (dependencies.length > 0) {
|
|
installDependencies({ ...npmOptions, installAsDevDependencies: false }, dependencies);
|
|
}
|
|
|
|
installDependencies(npmOptions, [...devDependencies, ...babelDependencies]);
|
|
};
|