-
-
Notifications
You must be signed in to change notification settings - Fork 9.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'next' of github.com:storybookjs/storybook into next
- Loading branch information
Showing
7 changed files
with
271 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
#!/usr/bin/env node | ||
|
||
const { writeFile } = require('fs-extra'); | ||
const { exec } = require('child_process'); | ||
const path = require('path'); | ||
const { default: dedent } = require('ts-dedent'); | ||
const { readFile } = require('fs-extra'); | ||
const yml = require('js-yaml'); | ||
|
||
const logger = console; | ||
|
||
async function getTemplatesData(filePath) { | ||
const configContents = await readFile(filePath, 'utf8'); | ||
return yml.load(configContents); | ||
} | ||
|
||
const run = async () => { | ||
logger.log('Generating templates list...'); | ||
const templatesData = await getTemplatesData( | ||
path.resolve(__dirname, '../../../../scripts/next-repro-generators/repro-config.yml') | ||
); | ||
const destination = path.join(__dirname, '..', 'src', 'repro-templates.ts'); | ||
|
||
await writeFile( | ||
destination, | ||
dedent` | ||
// This file was auto generated from generate-repro-templates-list.js, please do not edit! | ||
export default ${JSON.stringify(templatesData, null, 2)} | ||
` | ||
); | ||
|
||
exec(`yarn lint:js:cmd --fix ${destination}`, { | ||
cwd: path.join(__dirname, '..', '..', '..'), | ||
}); | ||
|
||
logger.log('Done! generated ', destination); | ||
}; | ||
|
||
run().catch((e) => { | ||
logger.error(e); | ||
process.exit(1); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,172 @@ | ||
import prompts from 'prompts'; | ||
import fs from 'fs'; | ||
import path from 'path'; | ||
import chalk from 'chalk'; | ||
import boxen from 'boxen'; | ||
import { dedent } from 'ts-dedent'; | ||
import degit from 'degit'; | ||
|
||
import TEMPLATES from './repro-templates'; | ||
|
||
const logger = console; | ||
|
||
interface ReproOptions { | ||
filterValue?: string; | ||
output?: string; | ||
branch?: string; | ||
} | ||
type Choice = keyof typeof TEMPLATES; | ||
|
||
const toChoices = (c: Choice): prompts.Choice => ({ title: TEMPLATES[c].name, value: c }); | ||
|
||
export const reproNext = async ({ output: outputDirectory, filterValue, branch }: ReproOptions) => { | ||
const keys = Object.keys(TEMPLATES) as Choice[]; | ||
// get value from template and reduce through TEMPLATES to filter out the correct template | ||
const choices = keys.reduce<Choice[]>((acc, group) => { | ||
const current = TEMPLATES[group]; | ||
|
||
const filterRegex = new RegExp(filterValue, 'i'); | ||
if (!filterValue) { | ||
acc.push(group); | ||
return acc; | ||
} | ||
|
||
if ( | ||
current.name.match(filterRegex) || | ||
group.match(filterRegex) || | ||
current.expected.builder.match(filterRegex) || | ||
current.expected.framework.match(filterRegex) || | ||
current.expected.renderer.match(filterRegex) | ||
) { | ||
acc.push(group); | ||
return acc; | ||
} | ||
|
||
return acc; | ||
}, []); | ||
|
||
if (choices.length === 0) { | ||
logger.info( | ||
boxen( | ||
dedent` | ||
🔎 You filtered out all templates. 🔍 | ||
After filtering all the templates with "${chalk.yellow( | ||
filterValue | ||
)}", we found no templates. | ||
Available templates: | ||
${keys.map((key) => chalk.blue`- ${key}`).join('\n')} | ||
`.trim(), | ||
{ borderStyle: 'round', padding: 1, borderColor: '#F1618C' } as any | ||
) | ||
); | ||
return; | ||
} | ||
|
||
let selectedTemplate: Choice | null = null; | ||
|
||
if (choices.length === 1) { | ||
[selectedTemplate] = choices; | ||
} else { | ||
logger.info( | ||
boxen( | ||
dedent` | ||
🤗 Welcome to ${chalk.yellow('sb repro NEXT')}! 🤗 | ||
Create a ${chalk.green('new project')} to minimally reproduce Storybook issues. | ||
1. select an environment that most closely matches your project setup. | ||
2. select a location for the reproduction, outside of your project. | ||
After the reproduction is ready, we'll guide you through the next steps. | ||
`.trim(), | ||
{ borderStyle: 'round', padding: 1, borderColor: '#F1618C' } as any | ||
) | ||
); | ||
|
||
selectedTemplate = await promptSelectedTemplate(choices); | ||
} | ||
|
||
const hasSelectedTemplate = !!(selectedTemplate ?? null); | ||
if (!hasSelectedTemplate) { | ||
logger.error('Somehow we got no templates. Please rerun this command!'); | ||
return; | ||
} | ||
|
||
const selectedConfig = TEMPLATES[selectedTemplate]; | ||
|
||
if (!selectedConfig) { | ||
throw new Error('🚨 Repro: please specify a valid template type'); | ||
} | ||
|
||
let selectedDirectory = outputDirectory; | ||
if (!selectedDirectory) { | ||
const { directory } = await prompts({ | ||
type: 'text', | ||
message: 'Enter the output directory', | ||
name: 'directory', | ||
initial: selectedTemplate, | ||
validate: (directoryName) => | ||
fs.existsSync(directoryName) | ||
? `${directoryName} already exists. Please choose another name.` | ||
: true, | ||
}); | ||
selectedDirectory = directory; | ||
} | ||
|
||
try { | ||
const cwd = path.isAbsolute(selectedDirectory) | ||
? selectedDirectory | ||
: path.join(process.cwd(), selectedDirectory); | ||
|
||
logger.info(`🏃 Adding ${selectedConfig.name} into ${cwd}`); | ||
|
||
logger.log('📦 Downloading repro template...'); | ||
try { | ||
// Download the repro based on subfolder "after-storybook" and selected branch | ||
await degit( | ||
`storybookjs/repro-templates-temp/${selectedTemplate}/after-storybook#${branch}`, | ||
{ | ||
force: true, | ||
} | ||
).clone(selectedTemplate.replace('/', '-')); | ||
} catch (err) { | ||
logger.error(`🚨 Failed to download repro template: ${err.message}`); | ||
return; | ||
} | ||
|
||
logger.info( | ||
boxen( | ||
dedent` | ||
🎉 Your Storybook reproduction project is ready to use! 🎉 | ||
${chalk.yellow(`cd ${selectedDirectory}`)} | ||
${chalk.yellow(`yarn storybook`)} | ||
Once you've recreated the problem you're experiencing, please: | ||
1. Document any additional steps in ${chalk.cyan('README.md')} | ||
2. Publish the repository to github | ||
3. Link to the repro repository in your issue | ||
Having a clean repro helps us solve your issue faster! 🙏 | ||
`.trim(), | ||
{ borderStyle: 'round', padding: 1, borderColor: '#F1618C' } as any | ||
) | ||
); | ||
} catch (error) { | ||
logger.error('🚨 Failed to create repro'); | ||
throw error; | ||
} | ||
}; | ||
|
||
async function promptSelectedTemplate(choices: Choice[]): Promise<Choice | null> { | ||
const { template } = await prompts({ | ||
type: 'select', | ||
message: '🌈 Select the template', | ||
name: 'template', | ||
choices: choices.map(toChoices), | ||
}); | ||
|
||
return template || null; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
// auto generated file, do not edit | ||
export default { | ||
'cra/default-js': { | ||
name: 'Create React App (Javascript)', | ||
script: 'npx create-react-app .', | ||
expected: { | ||
framework: '@storybook/cra', | ||
renderer: '@storybook/react', | ||
builder: '@storybook/builder-webpack5', | ||
}, | ||
}, | ||
'cra/default-ts': { | ||
name: 'Create React App (Typescript)', | ||
script: 'npx create-react-app . --template typescript', | ||
expected: { | ||
framework: '@storybook/cra', | ||
renderer: '@storybook/react', | ||
builder: '@storybook/builder-webpack5', | ||
}, | ||
}, | ||
} as const; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters