From 2188121c53667c555da876048f4562df1dce630a Mon Sep 17 00:00:00 2001 From: hypnos Date: Wed, 23 Aug 2017 02:43:52 +0300 Subject: [PATCH] CLI (React Native): ensure having an explicit dependency on `prop-types` --- lib/cli/generators/REACT_NATIVE/index.js | 7 ++++++- lib/cli/generators/REACT_NATIVE_SCRIPTS/index.js | 7 ++++++- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/lib/cli/generators/REACT_NATIVE/index.js b/lib/cli/generators/REACT_NATIVE/index.js index b4d4f66152d0..eded1d6d68b0 100644 --- a/lib/cli/generators/REACT_NATIVE/index.js +++ b/lib/cli/generators/REACT_NATIVE/index.js @@ -9,7 +9,8 @@ module.exports = Promise.all([ latestVersion('@storybook/react'), latestVersion('@storybook/addon-actions'), latestVersion('@storybook/addon-links'), -]).then(([storybookVersion, actionsVersion, linksVersion]) => { + latestVersion('prop-types'), +]).then(([storybookVersion, actionsVersion, linksVersion, propTypesVersion]) => { // copy all files from the template directory to project directory mergeDirs(path.resolve(__dirname, 'template/'), '.', 'overwrite'); @@ -41,6 +42,10 @@ module.exports = Promise.all([ packageJson.devDependencies['react-dom'] = reactVersion; } + if (!packageJson.dependencies['prop-types'] && !packageJson.devDependencies['prop-types']) { + packageJson.devDependencies['prop-types'] = `^${propTypesVersion}`; + } + packageJson.scripts = packageJson.scripts || {}; packageJson.scripts.storybook = 'storybook start -p 7007'; diff --git a/lib/cli/generators/REACT_NATIVE_SCRIPTS/index.js b/lib/cli/generators/REACT_NATIVE_SCRIPTS/index.js index 2a15f05a12f3..42e704fb94be 100644 --- a/lib/cli/generators/REACT_NATIVE_SCRIPTS/index.js +++ b/lib/cli/generators/REACT_NATIVE_SCRIPTS/index.js @@ -7,7 +7,8 @@ module.exports = Promise.all([ latestVersion('@storybook/react'), latestVersion('@storybook/addon-actions'), latestVersion('@storybook/addon-links'), -]).then(([storybookVersion, actionsVersion, linksVersion]) => { + latestVersion('prop-types'), +]).then(([storybookVersion, actionsVersion, linksVersion, propTypesVersion]) => { // copy all files from the template directory to project directory mergeDirs(path.resolve(__dirname, 'template/'), '.', 'overwrite'); @@ -25,6 +26,10 @@ module.exports = Promise.all([ packageJson.devDependencies['react-dom'] = reactVersion; } + if (!packageJson.dependencies['prop-types'] && !packageJson.devDependencies['prop-types']) { + packageJson.devDependencies['prop-types'] = `^${propTypesVersion}`; + } + packageJson.scripts = packageJson.scripts || {}; packageJson.scripts.storybook = 'storybook start -p 7007';