diff --git a/addons/essentials/src/index.ts b/addons/essentials/src/index.ts index d95fb32acf8..470d8d192f6 100644 --- a/addons/essentials/src/index.ts +++ b/addons/essentials/src/index.ts @@ -35,6 +35,6 @@ export function addons(options: PresetOptions = {}) { const main = requireMain(options.configDir); return ['actions', 'docs', 'backgrounds', 'viewport'] .filter((key) => (options as any)[key] !== false) - .map((key) => `@storybook/addon-${key}`) + .map((key) => require.resolve(`@storybook/addon-${key}`)) .filter((addon) => !checkInstalled(addon, main)); } diff --git a/app/angular/src/demo/welcome.component.ts b/app/angular/src/demo/welcome.component.ts index ab8309c1a58..9d97760c1d2 100644 --- a/app/angular/src/demo/welcome.component.ts +++ b/app/angular/src/demo/welcome.component.ts @@ -51,11 +51,9 @@ import { Component, Output, EventEmitter } from '@angular/core'; font-family: 'Helvetica Neue', Helvetica, 'Segoe UI', Arial, freesans, sans-serif; background-color: #ffffff; } - .note { opacity: 0.5; } - .inline-code { font-size: 15px; font-weight: 600; @@ -65,7 +63,6 @@ import { Component, Output, EventEmitter } from '@angular/core'; background-color: #f3f2f2; color: #3a3a3a; } - a { color: #1474f3; text-decoration: none; diff --git a/app/aurelia/demo.d.ts b/app/aurelia/demo.d.ts deleted file mode 100644 index 0183b7ef451..00000000000 --- a/app/aurelia/demo.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -declare module '@storybook/aurelia/demo' { - export const Button: any; - export const Welcome: any; -} diff --git a/app/aurelia/demo.js b/app/aurelia/demo.js deleted file mode 100644 index 64bcd548d7e..00000000000 --- a/app/aurelia/demo.js +++ /dev/null @@ -1,5 +0,0 @@ -/* eslint-disable global-require */ -module.exports = { - Welcome: require('./dist/demo/welcome').default, - Button: require('./dist/demo/button').default, -}; diff --git a/app/aurelia/src/demo/index.ts b/app/aurelia/src/demo/index.ts deleted file mode 100644 index 9463e32d9b5..00000000000 --- a/app/aurelia/src/demo/index.ts +++ /dev/null @@ -1,2 +0,0 @@ -export { default as Button } from './button'; -export { default as Welcome } from './welcome'; diff --git a/app/aurelia/src/demo/button.ts b/examples/aurelia-kitchen-sink/src/stories/button.ts similarity index 100% rename from app/aurelia/src/demo/button.ts rename to examples/aurelia-kitchen-sink/src/stories/button.ts diff --git a/examples/aurelia-kitchen-sink/src/stories/mdx.stories.mdx b/examples/aurelia-kitchen-sink/src/stories/mdx.stories.mdx index 1d2eebc447a..cce4f666a6e 100644 --- a/examples/aurelia-kitchen-sink/src/stories/mdx.stories.mdx +++ b/examples/aurelia-kitchen-sink/src/stories/mdx.stories.mdx @@ -1,10 +1,10 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { CoolButton } from '../cool-button/cool-button'; -import { Button } from '@storybook/aurelia/demo'; import { addComponents } from '@storybook/aurelia'; -import { text, withKnobs, } from '@storybook/addon-knobs'; +import { text, withKnobs } from '@storybook/addon-knobs'; +import Button from './button'; - + # Welcome @@ -15,10 +15,8 @@ This is a test document written in MDX that defines a `CoolButton` story wrapped {{ template: ``, state: { - testText: text('asfdafds', 'asasfdsa') - } + testText: text('asfdafds', 'asasfdsa'), + }, }} - - diff --git a/lib/cli/.babelrc.json b/lib/cli/.babelrc.json index 9ab56eefbb5..d2ad1c00b00 100644 --- a/lib/cli/.babelrc.json +++ b/lib/cli/.babelrc.json @@ -12,6 +12,7 @@ ] ], "ignore": [ + "./src/frameworks", "./src/generators/**/template", "./src/generators/**/template-csf", "./src/generators/**/template-csf-ts", diff --git a/lib/cli/src/generators/.eslintrc.js b/lib/cli/src/.eslintrc.js similarity index 53% rename from lib/cli/src/generators/.eslintrc.js rename to lib/cli/src/.eslintrc.js index d7fac90c788..ae114bfdcc2 100644 --- a/lib/cli/src/generators/.eslintrc.js +++ b/lib/cli/src/.eslintrc.js @@ -3,16 +3,17 @@ const ignore = 0; module.exports = { overrides: [ { - files: '*/template[-?]*/**', + files: '**/template[-?]*/**', env: { browser: true, }, rules: { 'react/no-this-in-sfc': ignore, 'import/no-unresolved': ignore, + 'react/react-in-jsx-scope': ignore, 'import/no-extraneous-dependencies': ignore, 'global-require': ignore, - 'react/react-in-jsx-scope': ignore, + 'no-redeclare': ignore, }, }, { @@ -21,5 +22,18 @@ module.exports = { browser: false, }, }, + { + files: 'frameworks/**/*', + env: { + browser: true, + }, + rules: { + 'jsx-a11y/anchor-is-valid': ignore, + 'import/no-unresolved': ignore, + 'react/prop-types': ignore, + 'react/react-in-jsx-scope': ignore, + 'import/no-extraneous-dependencies': ignore, + }, + }, ], }; diff --git a/lib/cli/src/generators/AURELIA/template-csf/src/stories/0-Welcome.stories.ts b/lib/cli/src/frameworks/angular/0-Welcome.stories.ts similarity index 77% rename from lib/cli/src/generators/AURELIA/template-csf/src/stories/0-Welcome.stories.ts rename to lib/cli/src/frameworks/angular/0-Welcome.stories.ts index 92ddbc26b27..38786fa3260 100644 --- a/lib/cli/src/generators/AURELIA/template-csf/src/stories/0-Welcome.stories.ts +++ b/lib/cli/src/frameworks/angular/0-Welcome.stories.ts @@ -1,4 +1,4 @@ -import { Welcome } from '@storybook/aurelia/demo'; +import Welcome from './welcome.component'; export default { title: 'Welcome', diff --git a/lib/cli/src/generators/ANGULAR/template-csf/src/stories/1-Button.stories.ts b/lib/cli/src/frameworks/angular/1-Button.stories.ts similarity index 94% rename from lib/cli/src/generators/ANGULAR/template-csf/src/stories/1-Button.stories.ts rename to lib/cli/src/frameworks/angular/1-Button.stories.ts index 4f740006eac..e82ad1c3156 100644 --- a/lib/cli/src/generators/ANGULAR/template-csf/src/stories/1-Button.stories.ts +++ b/lib/cli/src/frameworks/angular/1-Button.stories.ts @@ -1,7 +1,7 @@ import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/angular/demo'; +import Button from './button.component'; export default { title: 'Button', diff --git a/lib/cli/src/frameworks/angular/button.component.ts b/lib/cli/src/frameworks/angular/button.component.ts new file mode 100644 index 00000000000..da804e507b7 --- /dev/null +++ b/lib/cli/src/frameworks/angular/button.component.ts @@ -0,0 +1,26 @@ +import { Component, Input, Output, EventEmitter } from '@angular/core'; + +@Component({ + selector: 'storybook-button-component', + template: ` `, + styles: [ + ` + button { + border: 1px solid #eee; + border-radius: 3px; + background-color: #ffffff; + cursor: pointer; + font-size: 15px; + padding: 3px 10px; + margin: 10px; + } + `, + ], +}) +export default class ButtonComponent { + @Input() + text = ''; + + @Output() + onClick = new EventEmitter(); +} diff --git a/lib/cli/src/frameworks/angular/welcome.component.ts b/lib/cli/src/frameworks/angular/welcome.component.ts new file mode 100644 index 00000000000..ab8309c1a58 --- /dev/null +++ b/lib/cli/src/frameworks/angular/welcome.component.ts @@ -0,0 +1,81 @@ +import { Component, Output, EventEmitter } from '@angular/core'; + +@Component({ + selector: 'storybook-welcome-component', + template: ` +
+

Welcome to storybook

+

This is a UI component dev environment for your app.

+

+ We've added some basic stories inside the + src/stories directory.
+ A story is a single state of one or more UI components. You can have as many stories as you + want.
+ (Basically a story is like a visual test case.) +

+

+ See these sample + stories for a component + called Button . +

+

+ Just like that, you can add your own components as stories.
+ You can also edit those components and see changes right away.
+ (Try editing the Button stories located at + src/stories/index.js.) +

+

+ Usually we create stories with smaller UI components in the app.
+ Have a look at the + + Writing Stories + + section in our documentation. +

+

+ NOTE:
+ Have a look at the .storybook/webpack.config.js to add + webpack loaders and plugins you are using in this project. +

+
+ `, + styles: [ + ` + main { + padding: 15px; + line-height: 1.4; + font-family: 'Helvetica Neue', Helvetica, 'Segoe UI', Arial, freesans, sans-serif; + background-color: #ffffff; + } + + .note { + opacity: 0.5; + } + + .inline-code { + font-size: 15px; + font-weight: 600; + padding: 2px 5px; + border: 1px solid #eae9e9; + border-radius: 4px; + background-color: #f3f2f2; + color: #3a3a3a; + } + + a { + color: #1474f3; + text-decoration: none; + border-bottom: 1px solid #1474f3; + padding-bottom: 2px; + } + `, + ], +}) +export default class WelcomeComponent { + @Output() + showApp = new EventEmitter(); +} diff --git a/lib/cli/src/generators/ANGULAR/template-csf/src/stories/0-Welcome.stories.ts b/lib/cli/src/frameworks/aurelia/0-Welcome.stories.ts similarity index 77% rename from lib/cli/src/generators/ANGULAR/template-csf/src/stories/0-Welcome.stories.ts rename to lib/cli/src/frameworks/aurelia/0-Welcome.stories.ts index 058c0cc1355..acefc457a07 100644 --- a/lib/cli/src/generators/ANGULAR/template-csf/src/stories/0-Welcome.stories.ts +++ b/lib/cli/src/frameworks/aurelia/0-Welcome.stories.ts @@ -1,4 +1,4 @@ -import { Welcome } from '@storybook/angular/demo'; +import Welcome from './welcome'; export default { title: 'Welcome', diff --git a/lib/cli/src/generators/AURELIA/template-csf/src/stories/1-Button.stories.ts b/lib/cli/src/frameworks/aurelia/1-Button.stories.ts similarity index 94% rename from lib/cli/src/generators/AURELIA/template-csf/src/stories/1-Button.stories.ts rename to lib/cli/src/frameworks/aurelia/1-Button.stories.ts index 436ff09cb41..25989973d3a 100644 --- a/lib/cli/src/generators/AURELIA/template-csf/src/stories/1-Button.stories.ts +++ b/lib/cli/src/frameworks/aurelia/1-Button.stories.ts @@ -1,7 +1,7 @@ import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/aurelia/demo'; +import Button from './button'; export default { title: 'Button', diff --git a/lib/cli/src/frameworks/aurelia/button.ts b/lib/cli/src/frameworks/aurelia/button.ts new file mode 100644 index 00000000000..86cac656b57 --- /dev/null +++ b/lib/cli/src/frameworks/aurelia/button.ts @@ -0,0 +1,28 @@ +import { customElement, bindable } from 'aurelia'; + +@customElement({ + name: 'storybook-button-component', + template: ` + + `, +}) +export default class Button { + @bindable() + text = ''; + + @bindable() + onClick: MouseEvent; +} diff --git a/app/aurelia/src/demo/welcome.ts b/lib/cli/src/frameworks/aurelia/welcome.ts similarity index 100% rename from app/aurelia/src/demo/welcome.ts rename to lib/cli/src/frameworks/aurelia/welcome.ts diff --git a/lib/cli/src/generators/EMBER/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/ember/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/EMBER/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/ember/0-Welcome.stories.js diff --git a/lib/cli/src/generators/EMBER/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/ember/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/EMBER/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/ember/1-Button.stories.js diff --git a/lib/cli/src/generators/HTML/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/html/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/HTML/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/html/0-Welcome.stories.js diff --git a/lib/cli/src/generators/HTML/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/html/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/HTML/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/html/1-Button.stories.js diff --git a/lib/cli/src/generators/MARIONETTE/template/stories/index.stories.js b/lib/cli/src/frameworks/marionette/index.stories.js similarity index 83% rename from lib/cli/src/generators/MARIONETTE/template/stories/index.stories.js rename to lib/cli/src/frameworks/marionette/index.stories.js index 32f924b9360..a21a5519472 100644 --- a/lib/cli/src/generators/MARIONETTE/template/stories/index.stories.js +++ b/lib/cli/src/frameworks/marionette/index.stories.js @@ -1,11 +1,11 @@ -import Marionette from 'backbone.marionette'; +import { View } from 'backbone.marionette'; import { storiesOf } from '@storybook/marionette'; storiesOf('Demo', module).add( 'button', () => - new Marionette.View({ + new View({ template: () => '', ui: { button: '#my_button', diff --git a/lib/cli/src/generators/MARKO/template-csf/stories/index.stories.js b/lib/cli/src/frameworks/marko/0-Welcome.stories.js similarity index 68% rename from lib/cli/src/generators/MARKO/template-csf/stories/index.stories.js rename to lib/cli/src/frameworks/marko/0-Welcome.stories.js index 41fcb8b4fc1..a0cba3b6d1b 100644 --- a/lib/cli/src/generators/MARKO/template-csf/stories/index.stories.js +++ b/lib/cli/src/frameworks/marko/0-Welcome.stories.js @@ -1,4 +1,4 @@ -import Welcome from './components/welcome/index.marko'; +import Welcome from './welcome.marko'; export default { title: 'Welcome', diff --git a/lib/cli/src/frameworks/marko/welcome.marko b/lib/cli/src/frameworks/marko/welcome.marko new file mode 100644 index 00000000000..828d359bcc4 --- /dev/null +++ b/lib/cli/src/frameworks/marko/welcome.marko @@ -0,0 +1,37 @@ + +class { + onCreate() {} +} + +style { + #app { + font-family: 'Avenir', Helvetica, Arial, sans-serif; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + text-align: center; + color: #2c3e50; + margin-top: 60px; + } + + h1, h2 { + font-weight: normal; + } + + ul { + list-style-type: none; + padding: 0; + } + + li { + display: inline-block; + margin: 0 10px; + } + + a { + color: #42b983; + } +} + + +

Welcome to storybook

+ diff --git a/lib/cli/src/generators/MITHRIL/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/mithril/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/MITHRIL/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/mithril/0-Welcome.stories.js diff --git a/lib/cli/src/generators/MITHRIL/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/mithril/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/MITHRIL/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/mithril/1-Button.stories.js diff --git a/lib/cli/src/generators/MITHRIL/template-csf/stories/Button.js b/lib/cli/src/frameworks/mithril/Button.js similarity index 100% rename from lib/cli/src/generators/MITHRIL/template-csf/stories/Button.js rename to lib/cli/src/frameworks/mithril/Button.js diff --git a/lib/cli/src/generators/MITHRIL/template-csf/stories/Welcome.js b/lib/cli/src/frameworks/mithril/Welcome.js similarity index 100% rename from lib/cli/src/generators/MITHRIL/template-csf/stories/Welcome.js rename to lib/cli/src/frameworks/mithril/Welcome.js diff --git a/lib/cli/src/generators/PREACT/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/preact/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/PREACT/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/preact/0-Welcome.stories.js diff --git a/lib/cli/src/generators/PREACT/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/preact/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/PREACT/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/preact/1-Button.stories.js diff --git a/lib/cli/src/generators/PREACT/template-csf/stories/Button.js b/lib/cli/src/frameworks/preact/Button.js similarity index 74% rename from lib/cli/src/generators/PREACT/template-csf/stories/Button.js rename to lib/cli/src/frameworks/preact/Button.js index 2a3546d48c5..698f9d88193 100644 --- a/lib/cli/src/generators/PREACT/template-csf/stories/Button.js +++ b/lib/cli/src/frameworks/preact/Button.js @@ -1,5 +1,5 @@ /** @jsx h */ -/* eslint-disable react/no-unknown-property, react/prop-types */ +/* eslint-disable react/no-unknown-property */ import { h } from 'preact'; const Button = ({ children, ...props }) => ( diff --git a/lib/cli/src/generators/PREACT/template-csf/stories/Welcome.js b/lib/cli/src/frameworks/preact/Welcome.js similarity index 94% rename from lib/cli/src/generators/PREACT/template-csf/stories/Welcome.js rename to lib/cli/src/frameworks/preact/Welcome.js index b4ce7052f26..7a47695cf12 100644 --- a/lib/cli/src/generators/PREACT/template-csf/stories/Welcome.js +++ b/lib/cli/src/frameworks/preact/Welcome.js @@ -13,7 +13,6 @@ const Main = (props) => ( /> ); -// eslint-disable-next-line react/prop-types const Title = ({ children, ...props }) =>

{children}

; const Note = (props) => ( @@ -40,7 +39,6 @@ const InlineCode = (props) => ( /> ); -// eslint-disable-next-line react/prop-types const Link = ({ children, href, ...props }) => ( ( ); -// eslint-disable-next-line react/prop-types const NavButton = ({ children, ...props }) => ( ); -/* eslint-disable-next-line react/prop-types */ const Welcome = ({ showApp }) => (
Welcome to storybook diff --git a/lib/cli/src/generators/RAX/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/rax/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/RAX/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/rax/0-Welcome.stories.js diff --git a/lib/cli/src/generators/RAX/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/rax/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/RAX/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/rax/1-Button.stories.js diff --git a/lib/cli/src/generators/RAX/template-csf/stories/Welcome.js b/lib/cli/src/frameworks/rax/Welcome.js similarity index 97% rename from lib/cli/src/generators/RAX/template-csf/stories/Welcome.js rename to lib/cli/src/frameworks/rax/Welcome.js index 340844748cd..6995d7de594 100644 --- a/lib/cli/src/generators/RAX/template-csf/stories/Welcome.js +++ b/lib/cli/src/frameworks/rax/Welcome.js @@ -1,4 +1,3 @@ -/* eslint-disable react/prop-types, jsx-a11y/anchor-is-valid */ import { createElement } from 'rax'; import View from 'rax-view'; import Text from 'rax-text'; diff --git a/lib/cli/src/generators/REACT/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/react/js/0-Welcome.stories.js similarity index 83% rename from lib/cli/src/generators/REACT/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/react/js/0-Welcome.stories.js index 9920a416e1f..4c2d95bdb22 100644 --- a/lib/cli/src/generators/REACT/template-csf/stories/0-Welcome.stories.js +++ b/lib/cli/src/frameworks/react/js/0-Welcome.stories.js @@ -1,6 +1,6 @@ import React from 'react'; import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; +import { Welcome } from './Welcome'; export default { title: 'Welcome', diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-csf/src/stories/1-Button.stories.js b/lib/cli/src/frameworks/react/js/1-Button.stories.js similarity index 95% rename from lib/cli/src/generators/REACT_SCRIPTS/template-csf/src/stories/1-Button.stories.js rename to lib/cli/src/frameworks/react/js/1-Button.stories.js index fdbd42fe76f..68a91009701 100644 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-csf/src/stories/1-Button.stories.js +++ b/lib/cli/src/frameworks/react/js/1-Button.stories.js @@ -1,7 +1,7 @@ import React from 'react'; import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/react/demo'; +import { Button } from './Button'; export default { title: 'Button', diff --git a/lib/cli/src/frameworks/react/js/Button.jsx b/lib/cli/src/frameworks/react/js/Button.jsx new file mode 100644 index 00000000000..0b9a6baeb6a --- /dev/null +++ b/lib/cli/src/frameworks/react/js/Button.jsx @@ -0,0 +1,17 @@ +import React from 'react'; + +const styles = { + border: '1px solid #eee', + borderRadius: 3, + backgroundColor: '#FFFFFF', + cursor: 'pointer', + fontSize: 15, + padding: '3px 10px', + margin: 10, +}; + +export const Button = ({ children, onClick }) => ( + +); diff --git a/lib/cli/src/frameworks/react/js/Welcome.jsx b/lib/cli/src/frameworks/react/js/Welcome.jsx new file mode 100644 index 00000000000..45d25f6ebaf --- /dev/null +++ b/lib/cli/src/frameworks/react/js/Welcome.jsx @@ -0,0 +1,126 @@ +import React from 'react'; + +const Main = (props) => ( +
+); + +const Title = ({ children, ...props }) =>

{children}

; + +const Note = (props) => ( +

+); + +const InlineCode = (props) => ( + +); + +const Link = ({ children, href, target, rel, ...props }) => ( + + {children} + +); + +const NavButton = ({ children, onClick, ...props }) => ( + +); + +export const Welcome = ({ showApp }) => ( +

+ Welcome to storybook +

This is a UI component dev environment for your app.

+

+ We've added some basic stories inside the src/stories directory. +
A story is a single state of one or more UI components. You can have as many stories as + you want. +
+ (Basically a story is like a visual test case.) +

+

+ See these sample stories for a component called  + Button. +

+

+ Just like that, you can add your own components as stories. +
+ You can also edit those components and see changes right away. +
+ (Try editing the Button stories located at  + src/stories/1-Button.stories.js + .) +

+

+ Usually we create stories with smaller UI components in the app. +
+ Have a look at the  + + Writing Stories + +  section in our documentation. +

+ + NOTE: +
+ Have a look at the .storybook/webpack.config.js to add webpack + loaders and plugins you are using in this project. +
+
+); diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/src/stories/0-Welcome.stories.tsx b/lib/cli/src/frameworks/react/ts/0-Welcome.stories.tsx similarity index 83% rename from lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/src/stories/0-Welcome.stories.tsx rename to lib/cli/src/frameworks/react/ts/0-Welcome.stories.tsx index 9920a416e1f..4c2d95bdb22 100644 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/src/stories/0-Welcome.stories.tsx +++ b/lib/cli/src/frameworks/react/ts/0-Welcome.stories.tsx @@ -1,6 +1,6 @@ import React from 'react'; import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; +import { Welcome } from './Welcome'; export default { title: 'Welcome', diff --git a/lib/cli/src/generators/REACT/template-csf-ts/src/stories/1-Button.stories.tsx b/lib/cli/src/frameworks/react/ts/1-Button.stories.tsx similarity index 95% rename from lib/cli/src/generators/REACT/template-csf-ts/src/stories/1-Button.stories.tsx rename to lib/cli/src/frameworks/react/ts/1-Button.stories.tsx index fdbd42fe76f..68a91009701 100644 --- a/lib/cli/src/generators/REACT/template-csf-ts/src/stories/1-Button.stories.tsx +++ b/lib/cli/src/frameworks/react/ts/1-Button.stories.tsx @@ -1,7 +1,7 @@ import React from 'react'; import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/react/demo'; +import { Button } from './Button'; export default { title: 'Button', diff --git a/lib/cli/src/frameworks/react/ts/Button.tsx b/lib/cli/src/frameworks/react/ts/Button.tsx new file mode 100644 index 00000000000..42b1313f8bf --- /dev/null +++ b/lib/cli/src/frameworks/react/ts/Button.tsx @@ -0,0 +1,20 @@ +import React, { FunctionComponent, HTMLAttributes } from 'react'; + +const styles = { + border: '1px solid #eee', + borderRadius: 3, + backgroundColor: '#FFFFFF', + cursor: 'pointer', + fontSize: 15, + padding: '3px 10px', + margin: 10, +}; + +export type ButtonProps = HTMLAttributes; +export const Button: FunctionComponent = ({ children, onClick }: ButtonProps) => ( + +); + +export default Button; diff --git a/lib/cli/src/frameworks/react/ts/Welcome.tsx b/lib/cli/src/frameworks/react/ts/Welcome.tsx new file mode 100644 index 00000000000..3d0885f6bbd --- /dev/null +++ b/lib/cli/src/frameworks/react/ts/Welcome.tsx @@ -0,0 +1,159 @@ +import React, { + AnchorHTMLAttributes, + ButtonHTMLAttributes, + DetailedHTMLProps, + FunctionComponent, + HTMLAttributes, +} from 'react'; + +type MainProps = Omit, HTMLElement>, 'style'>; +const Main: FunctionComponent = (props) => ( +
+); + +type TitleProps = DetailedHTMLProps, HTMLHeadingElement>; +const Title: FunctionComponent = ({ children, ...props }) => ( +

{children}

+); + +type NoteProps = Omit< + DetailedHTMLProps, HTMLParagraphElement>, + 'style' +>; +const Note: FunctionComponent = (props) => ( +

+); + +type InlineCodeProps = Omit, HTMLElement>, 'style'>; +const InlineCode: FunctionComponent = (props) => ( + +); + +type LinkProps = Omit< + DetailedHTMLProps, HTMLAnchorElement>, + 'style' +> & { + href: string; + target: string; + rel: string; +}; +const Link: FunctionComponent = ({ children, href, target, rel, ...props }) => ( + + {children} + +); + +type NavButtonProps = Omit< + DetailedHTMLProps, HTMLButtonElement>, + 'style' | 'type' +> & {}; +const NavButton: FunctionComponent = ({ children, onClick, ...props }) => ( + +); + +export interface WelcomeProps { + showApp: () => void; +} +export const Welcome: FunctionComponent = ({ showApp }: WelcomeProps) => ( +

+ Welcome to storybook +

This is a UI component dev environment for your app.

+

+ We've added some basic stories inside the src/stories directory. +
A story is a single state of one or more UI components. You can have as many stories as + you want. +
+ (Basically a story is like a visual test case.) +

+

+ See these sample stories for a component called  + Button. +

+

+ Just like that, you can add your own components as stories. +
+ You can also edit those components and see changes right away. +
+ (Try editing the Button stories located at  + src/stories/1-Button.stories.js + .) +

+

+ Usually we create stories with smaller UI components in the app. +
+ Have a look at the  + + Writing Stories + +  section in our documentation. +

+ + NOTE: +
+ Have a look at the .storybook/webpack.config.js to add webpack + loaders and plugins you are using in this project. +
+
+); +Welcome.displayName = 'Welcome'; + +export { Welcome as default }; diff --git a/lib/cli/src/generators/RIOT/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/riot/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/RIOT/template-csf/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/riot/0-Welcome.stories.js diff --git a/lib/cli/src/generators/RIOT/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/riot/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/RIOT/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/riot/1-Button.stories.js diff --git a/lib/cli/src/generators/RIOT/template-csf/stories/MyButton.tag b/lib/cli/src/frameworks/riot/MyButton.tag similarity index 100% rename from lib/cli/src/generators/RIOT/template-csf/stories/MyButton.tag rename to lib/cli/src/frameworks/riot/MyButton.tag diff --git a/lib/cli/src/generators/RIOT/template-csf/stories/Welcome.tag b/lib/cli/src/frameworks/riot/Welcome.tag similarity index 100% rename from lib/cli/src/generators/RIOT/template-csf/stories/Welcome.tag rename to lib/cli/src/frameworks/riot/Welcome.tag diff --git a/lib/cli/src/generators/SVELTE/template-csf/stories/0-welcome.stories.js b/lib/cli/src/frameworks/svelte/0-welcome.stories.js similarity index 100% rename from lib/cli/src/generators/SVELTE/template-csf/stories/0-welcome.stories.js rename to lib/cli/src/frameworks/svelte/0-welcome.stories.js diff --git a/lib/cli/src/generators/SVELTE/template-csf/stories/1-button.stories.js b/lib/cli/src/frameworks/svelte/1-button.stories.js similarity index 100% rename from lib/cli/src/generators/SVELTE/template-csf/stories/1-button.stories.js rename to lib/cli/src/frameworks/svelte/1-button.stories.js diff --git a/lib/cli/src/generators/SVELTE/template-csf/stories/button.svelte b/lib/cli/src/frameworks/svelte/button.svelte similarity index 100% rename from lib/cli/src/generators/SVELTE/template-csf/stories/button.svelte rename to lib/cli/src/frameworks/svelte/button.svelte diff --git a/lib/cli/src/generators/SVELTE/template-csf/stories/welcome.svelte b/lib/cli/src/frameworks/svelte/welcome.svelte similarity index 100% rename from lib/cli/src/generators/SVELTE/template-csf/stories/welcome.svelte rename to lib/cli/src/frameworks/svelte/welcome.svelte diff --git a/lib/cli/src/generators/SFC_VUE/template-csf/src/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/vue/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/SFC_VUE/template-csf/src/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/vue/0-Welcome.stories.js diff --git a/lib/cli/src/generators/VUE/template-csf/stories/1-Button.stories.js b/lib/cli/src/frameworks/vue/1-Button.stories.js similarity index 96% rename from lib/cli/src/generators/VUE/template-csf/stories/1-Button.stories.js rename to lib/cli/src/frameworks/vue/1-Button.stories.js index 790039811cc..f2f44d6351b 100644 --- a/lib/cli/src/generators/VUE/template-csf/stories/1-Button.stories.js +++ b/lib/cli/src/frameworks/vue/1-Button.stories.js @@ -1,7 +1,7 @@ import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import MyButton from './MyButton'; +import MyButton from './Button.vue'; export default { title: 'Button', diff --git a/lib/cli/src/generators/SFC_VUE/template-csf/src/stories/MyButton.vue b/lib/cli/src/frameworks/vue/Button.vue similarity index 100% rename from lib/cli/src/generators/SFC_VUE/template-csf/src/stories/MyButton.vue rename to lib/cli/src/frameworks/vue/Button.vue diff --git a/lib/cli/src/generators/SFC_VUE/template-csf/src/stories/Welcome.vue b/lib/cli/src/frameworks/vue/Welcome.vue similarity index 100% rename from lib/cli/src/generators/SFC_VUE/template-csf/src/stories/Welcome.vue rename to lib/cli/src/frameworks/vue/Welcome.vue diff --git a/lib/cli/src/generators/WEB-COMPONENTS/template/stories/0-Welcome.stories.js b/lib/cli/src/frameworks/web-components/0-Welcome.stories.js similarity index 100% rename from lib/cli/src/generators/WEB-COMPONENTS/template/stories/0-Welcome.stories.js rename to lib/cli/src/frameworks/web-components/0-Welcome.stories.js diff --git a/lib/cli/src/generators/WEB-COMPONENTS/template/stories/1-Button.stories.js b/lib/cli/src/frameworks/web-components/1-Button.stories.js similarity index 100% rename from lib/cli/src/generators/WEB-COMPONENTS/template/stories/1-Button.stories.js rename to lib/cli/src/frameworks/web-components/1-Button.stories.js diff --git a/lib/cli/src/generators/ANGULAR/index.ts b/lib/cli/src/generators/ANGULAR/index.ts index 9ab5196a019..ddfdc4ba36e 100644 --- a/lib/cli/src/generators/ANGULAR/index.ts +++ b/lib/cli/src/generators/ANGULAR/index.ts @@ -5,45 +5,12 @@ import { getAngularAppTsConfigJson, getAngularAppTsConfigPath, } from './angular-helpers'; -import { getBabelDependencies, writeFileAsJson, copyTemplate } from '../../helpers'; -import { StoryFormat } from '../../project_types'; -import { NpmOptions } from '../../NpmOptions'; -import { Generator, GeneratorOptions } from '../Generator'; -import { JsPackageManager } from '../../js-package-manager'; - -async function addDependencies( - packageManager: JsPackageManager, - npmOptions: NpmOptions, - { storyFormat }: GeneratorOptions -) { - const packages = [ - '@storybook/angular', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - ]; - - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); - } - - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); -} +import { writeFileAsJson, copyTemplate } from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; function editAngularAppTsConfig() { const tsConfigJson = getAngularAppTsConfigJson(); - const glob = '**/*.stories.ts'; + const glob = '**/*.stories.*'; if (!tsConfigJson) { return; } @@ -57,16 +24,15 @@ function editAngularAppTsConfig() { writeFileAsJson(getAngularAppTsConfigPath(), tsConfigJson); } -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { +const generator: Generator = async (packageManager, npmOptions, options) => { if (!isDefaultProjectSet()) { throw new Error( 'Could not find a default project in your Angular workspace.\nSet a defaultProject in your angular.json and re-run the installation.' ); } + baseGenerator(packageManager, npmOptions, options, 'angular'); + copyTemplate(__dirname, options.storyFormat); - copyTemplate(__dirname, storyFormat); - - await addDependencies(packageManager, npmOptions, { storyFormat }); editAngularAppTsConfig(); editStorybookTsConfig(path.resolve('./.storybook/tsconfig.json')); }; diff --git a/lib/cli/src/generators/ANGULAR/template-csf/.storybook/main.js b/lib/cli/src/generators/ANGULAR/template-csf/.storybook/main.js deleted file mode 100644 index 16aa97cdc16..00000000000 --- a/lib/cli/src/generators/ANGULAR/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.ts'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/ANGULAR/template-mdx/.storybook/main.js b/lib/cli/src/generators/ANGULAR/template-mdx/.storybook/main.js deleted file mode 100644 index 43bbb3968c4..00000000000 --- a/lib/cli/src/generators/ANGULAR/template-mdx/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(ts|mdx)'], - addons: ['@storybook/addon-docs', '@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/0-Welcome.stories.mdx b/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/0-Welcome.stories.mdx index 5fc361cd9b6..1abbfd8a65e 100644 --- a/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/0-Welcome.stories.mdx +++ b/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/0-Welcome.stories.mdx @@ -1,5 +1,5 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; -import { Welcome } from '@storybook/angular/demo'; +import Welcome from './welcome.component'; diff --git a/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/1-Button.stories.mdx b/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/1-Button.stories.mdx index 9aabc6f50ed..13c38a6621f 100644 --- a/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/1-Button.stories.mdx +++ b/lib/cli/src/generators/ANGULAR/template-mdx/src/stories/1-Button.stories.mdx @@ -2,7 +2,7 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/angular/demo'; +import Button from './button.component'; diff --git a/lib/cli/src/generators/AURELIA/index.ts b/lib/cli/src/generators/AURELIA/index.ts index 04ec62b89ed..8367b1667ec 100644 --- a/lib/cli/src/generators/AURELIA/index.ts +++ b/lib/cli/src/generators/AURELIA/index.ts @@ -1,6 +1,5 @@ -import { getBabelDependencies, writeFileAsJson, copyTemplate, readFileAsJson } from '../../helpers'; -import { Generator } from '../Generator'; -import { StoryFormat } from '../../project_types'; +import { writeFileAsJson, readFileAsJson, copyTemplate } from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; function addStorybookExcludeGlobToTsConfig() { const tsConfigJson = readFileAsJson('tsconfig.json', true); @@ -17,39 +16,13 @@ function addStorybookExcludeGlobToTsConfig() { tsConfigJson.exclude = [...exclude, glob]; writeFileAsJson('tsconfig.json', tsConfigJson); } -const generator: Generator = async ( - packageManager, - npmOptions, - { storyFormat = StoryFormat.CSF } -) => { - copyTemplate(__dirname, storyFormat); - const packages = [ - '@storybook/aurelia', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - '@storybook/addon-storysource', - '@storybook/addon-knobs', - '@storybook/addon-options', - '@storybook/addon-a11y', - '@storybook/addon-backgrounds', - 'aurelia', - ]; - if (storyFormat === 'mdx') { - packages.push('@storybook/addon-docs'); - } - - const versionedPackages = await packageManager.getVersionedPackages(...packages); - const packageJson = packageManager.retrievePackageJson(); +const generator: Generator = async (packageManager, npmOptions, options) => { addStorybookExcludeGlobToTsConfig(); - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); + baseGenerator(packageManager, npmOptions, options, 'aurelia', { + extraPackages: ['aurelia'], + }); + copyTemplate(__dirname, options.storyFormat); }; export default generator; diff --git a/lib/cli/src/generators/AURELIA/template-csf/.storybook/main.js b/lib/cli/src/generators/AURELIA/template-csf/.storybook/main.js deleted file mode 100644 index 16aa97cdc16..00000000000 --- a/lib/cli/src/generators/AURELIA/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.ts'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/AURELIA/template-mdx/.storybook/main.js b/lib/cli/src/generators/AURELIA/template-mdx/.storybook/main.js deleted file mode 100644 index 43bbb3968c4..00000000000 --- a/lib/cli/src/generators/AURELIA/template-mdx/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(ts|mdx)'], - addons: ['@storybook/addon-docs', '@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/AURELIA/template-mdx/src/stories/0-Welcome.stories.mdx b/lib/cli/src/generators/AURELIA/template-mdx/src/stories/0-Welcome.stories.mdx index 17ad75634de..531a441afb6 100644 --- a/lib/cli/src/generators/AURELIA/template-mdx/src/stories/0-Welcome.stories.mdx +++ b/lib/cli/src/generators/AURELIA/template-mdx/src/stories/0-Welcome.stories.mdx @@ -1,5 +1,5 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; -import { Welcome } from '@storybook/aurelia/demo'; +import Welcome from './welcome'; diff --git a/lib/cli/src/generators/AURELIA/template-mdx/src/stories/1-Button.stories.mdx b/lib/cli/src/generators/AURELIA/template-mdx/src/stories/1-Button.stories.mdx index fe4f4783439..a488b7b8fd7 100644 --- a/lib/cli/src/generators/AURELIA/template-mdx/src/stories/1-Button.stories.mdx +++ b/lib/cli/src/generators/AURELIA/template-mdx/src/stories/1-Button.stories.mdx @@ -2,7 +2,7 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/aurelia/demo'; +import Button from './button'; diff --git a/lib/cli/src/generators/EMBER/index.ts b/lib/cli/src/generators/EMBER/index.ts index 36fb1c1ef53..d1d88751a85 100644 --- a/lib/cli/src/generators/EMBER/index.ts +++ b/lib/cli/src/generators/EMBER/index.ts @@ -1,41 +1,15 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; - -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - babelPluginEmberModulePolyfillVersion, - babelPluginHtmlBarsInlinePrecompileVersion, - linksVersion, - actionsVersion, - addonsVersion, - ] = await packageManager.getVersions( - '@storybook/ember', - // babel-plugin-ember-modules-api-polyfill is a peerDep of @storybook/ember - 'babel-plugin-ember-modules-api-polyfill', - // babel-plugin-htmlbars-inline-precompile is a peerDep of @storybook/ember - 'babel-plugin-htmlbars-inline-precompile', - '@storybook/addon-links', - '@storybook/addon-actions', - '@storybook/addons' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/ember@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addons@${addonsVersion}`, - `babel-plugin-ember-modules-api-polyfill@${babelPluginEmberModulePolyfillVersion}`, - `babel-plugin-htmlbars-inline-precompile@${babelPluginHtmlBarsInlinePrecompileVersion}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +import { baseGenerator, Generator } from '../generator'; + +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'ember', { + extraPackages: [ + // babel-plugin-ember-modules-api-polyfill is a peerDep of @storybook/ember + 'babel-plugin-ember-modules-api-polyfill', + // babel-plugin-htmlbars-inline-precompile is a peerDep of @storybook/ember + 'babel-plugin-htmlbars-inline-precompile', + ], + staticDir: 'dist', + }); }; export default generator; diff --git a/lib/cli/src/generators/EMBER/template-csf/.storybook/main.js b/lib/cli/src/generators/EMBER/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/EMBER/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/Generator.ts b/lib/cli/src/generators/Generator.ts deleted file mode 100644 index 7d081f55c9a..00000000000 --- a/lib/cli/src/generators/Generator.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { NpmOptions } from '../NpmOptions'; -import { StoryFormat } from '../project_types'; -import { JsPackageManager } from '../js-package-manager'; - -export type GeneratorOptions = { - storyFormat: StoryFormat; -}; - -export type Generator = ( - packageManager: JsPackageManager, - npmOptions: NpmOptions, - options: GeneratorOptions -) => Promise; diff --git a/lib/cli/src/generators/HTML/index.ts b/lib/cli/src/generators/HTML/index.ts index eb96ae0ff49..76b975ff825 100755 --- a/lib/cli/src/generators/HTML/index.ts +++ b/lib/cli/src/generators/HTML/index.ts @@ -1,25 +1,12 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; +import { copyTemplate } from '../../helpers'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = ['@storybook/html', '@storybook/addon-actions', '@storybook/addon-links']; - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'html'); + if (options.storyFormat === StoryFormat.MDX) { + copyTemplate(__dirname, StoryFormat.MDX); } - - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); }; export default generator; diff --git a/lib/cli/src/generators/HTML/template-csf/.storybook/main.js b/lib/cli/src/generators/HTML/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/HTML/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/HTML/template-mdx/.storybook/main.js b/lib/cli/src/generators/HTML/template-mdx/.storybook/main.js deleted file mode 100644 index c3211c95188..00000000000 --- a/lib/cli/src/generators/HTML/template-mdx/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.@(js|mdx)'], - addons: ['@storybook/addon-docs'], -}; diff --git a/lib/cli/src/generators/MARIONETTE/index.ts b/lib/cli/src/generators/MARIONETTE/index.ts index c29c891b00e..74496591d55 100644 --- a/lib/cli/src/generators/MARIONETTE/index.ts +++ b/lib/cli/src/generators/MARIONETTE/index.ts @@ -1,22 +1,7 @@ -import fse from 'fs-extra'; -import path from 'path'; -import { getBabelDependencies } from '../../helpers'; -import { Generator } from '../Generator'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions) => { - const storybookVersion = await packageManager.getVersion('@storybook/marionette'); - fse.copySync(path.resolve(__dirname, 'template/'), '.', { overwrite: true }); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/marionette@${storybookVersion}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +const generator: Generator = async (packageManager, npmOptions, options) => { + await baseGenerator(packageManager, npmOptions, options, 'marionette'); }; export default generator; diff --git a/lib/cli/src/generators/MARIONETTE/template/.storybook/main.js b/lib/cli/src/generators/MARIONETTE/template/.storybook/main.js deleted file mode 100644 index a0f65ec500a..00000000000 --- a/lib/cli/src/generators/MARIONETTE/template/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: '../stories/**/*.stories.js', - addons: ['@storybook/addon-actions', '@storybook/addon-knobs'], -}; diff --git a/lib/cli/src/generators/MARKO/index.ts b/lib/cli/src/generators/MARKO/index.ts index f28c62ff86d..01dc5e7bd10 100644 --- a/lib/cli/src/generators/MARKO/index.ts +++ b/lib/cli/src/generators/MARKO/index.ts @@ -1,31 +1,7 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - addonActionVersion, - addonKnobsVersion, - ] = await packageManager.getVersions( - '@storybook/marko', - '@storybook/addon-actions', - '@storybook/addon-knobs' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/marko@${storybookVersion}`, - `@storybook/addon-actions@${addonActionVersion}`, - `@storybook/addon-knobs@${addonKnobsVersion}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +const generator: Generator = async (packageManager, npmOptions, options) => { + await baseGenerator(packageManager, npmOptions, options, 'marko'); }; export default generator; diff --git a/lib/cli/src/generators/MARKO/template-csf/.storybook/main.js b/lib/cli/src/generators/MARKO/template-csf/.storybook/main.js deleted file mode 100644 index c6a06f1fbc3..00000000000 --- a/lib/cli/src/generators/MARKO/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-knobs'], -}; diff --git a/lib/cli/src/generators/MARKO/template-csf/stories/components/welcome/index.marko b/lib/cli/src/generators/MARKO/template-csf/stories/components/welcome/index.marko deleted file mode 100644 index 272d7211f2b..00000000000 --- a/lib/cli/src/generators/MARKO/template-csf/stories/components/welcome/index.marko +++ /dev/null @@ -1,46 +0,0 @@ - -class { - onCreate() {} -} - -style { - #app { - font-family: 'Avenir', Helvetica, Arial, sans-serif; - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - text-align: center; - color: #2c3e50; - margin-top: 60px; - } - - .logo { - background-image:url(''); - background-repeat:no-repeat; - display:inline-block; - width: 365px; - height: 200px; - } - - h1, h2 { - font-weight: normal; - } - - ul { - list-style-type: none; - padding: 0; - } - - li { - display: inline-block; - margin: 0 10px; - } - - a { - color: #42b983; - } -} - - -

Welcome to storybook

- - diff --git a/lib/cli/src/generators/METEOR/index.ts b/lib/cli/src/generators/METEOR/index.ts index 95ae0183490..852f4e29bc0 100644 --- a/lib/cli/src/generators/METEOR/index.ts +++ b/lib/cli/src/generators/METEOR/index.ts @@ -1,43 +1,12 @@ import fs from 'fs'; import JSON5 from 'json5'; -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; -import { writePackageJson } from '../../js-package-manager'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - actionsVersion, - linksVersion, - knobsVersion, - addonsVersion, - reactVersion, - reactDomVersion, - presetEnvVersion, - presetReactVersion, - ] = await packageManager.getVersions( - '@storybook/react', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addon-knobs', - '@storybook/addons', - 'react', - 'react-dom', - '@babel/preset-env', - '@babel/preset-react' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const devDependencies = [ - `@storybook/react@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addon-knobs@${knobsVersion}`, - `@storybook/addons@${addonsVersion}`, - ]; +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'react', { + extraPackages: ['react', 'react-dom', '@babel/preset-env', '@babel/preset-react'], + staticDir: 'dist', + }); // create or update .babelrc let babelrc = null; @@ -52,39 +21,9 @@ const generator: Generator = async (packageManager, npmOptions, { storyFormat }) '@babel/preset-react', ], }; - - devDependencies.push(`@babel/preset-env@${presetEnvVersion}`); - devDependencies.push(`@babel/preset-react@${presetReactVersion}`); } fs.writeFileSync('.babelrc', JSON.stringify(babelrc, null, 2), 'utf8'); - - writePackageJson(packageJson); - - const babelDependencies = await getBabelDependencies(packageManager, 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) { - packageManager.addDependencies( - { ...npmOptions, packageJson, installAsDevDependencies: false }, - dependencies - ); - } - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...devDependencies, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); }; export default generator; diff --git a/lib/cli/src/generators/METEOR/template-csf/.storybook/main.js b/lib/cli/src/generators/METEOR/template-csf/.storybook/main.js deleted file mode 100644 index c6a06f1fbc3..00000000000 --- a/lib/cli/src/generators/METEOR/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-knobs'], -}; diff --git a/lib/cli/src/generators/METEOR/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/generators/METEOR/template-csf/stories/0-Welcome.stories.js deleted file mode 100644 index 9920a416e1f..00000000000 --- a/lib/cli/src/generators/METEOR/template-csf/stories/0-Welcome.stories.js +++ /dev/null @@ -1,12 +0,0 @@ -import React from 'react'; -import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; - -export default { - title: 'Welcome', - component: Welcome, -}; - -export const ToStorybook = () => ; - -ToStorybook.storyName = 'to Storybook'; diff --git a/lib/cli/src/generators/METEOR/template-csf/stories/1-Button.stories.js b/lib/cli/src/generators/METEOR/template-csf/stories/1-Button.stories.js deleted file mode 100644 index 6bcfa214662..00000000000 --- a/lib/cli/src/generators/METEOR/template-csf/stories/1-Button.stories.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from 'react'; -import { action } from '@storybook/addon-actions'; -import { Button } from '@storybook/react/demo'; - -export default { - title: 'Button', - component: Button, -}; - -export const Text = () => ; - -export const Emoji = () => ( - -); diff --git a/lib/cli/src/generators/MITHRIL/index.ts b/lib/cli/src/generators/MITHRIL/index.ts index 329b521c9d7..46ec36e633d 100644 --- a/lib/cli/src/generators/MITHRIL/index.ts +++ b/lib/cli/src/generators/MITHRIL/index.ts @@ -1,37 +1,7 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - actionsVersion, - linksVersion, - knobsVersion, - addonsVersion, - ] = await packageManager.getVersions( - '@storybook/mithril', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addon-knobs', - '@storybook/addons' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/mithril@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addon-knobs@${knobsVersion}`, - `@storybook/addons@${addonsVersion}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'mithril'); }; export default generator; diff --git a/lib/cli/src/generators/MITHRIL/template-csf/.storybook/main.js b/lib/cli/src/generators/MITHRIL/template-csf/.storybook/main.js deleted file mode 100644 index c6a06f1fbc3..00000000000 --- a/lib/cli/src/generators/MITHRIL/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-knobs'], -}; diff --git a/lib/cli/src/generators/PREACT/index.ts b/lib/cli/src/generators/PREACT/index.ts index f6ceceac04d..5c83eb2bfb0 100644 --- a/lib/cli/src/generators/PREACT/index.ts +++ b/lib/cli/src/generators/PREACT/index.ts @@ -1,34 +1,7 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - actionsVersion, - linksVersion, - addonsVersion, - ] = await packageManager.getVersions( - '@storybook/preact', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/preact@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addons@${addonsVersion}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'preact'); }; export default generator; diff --git a/lib/cli/src/generators/PREACT/template-csf/.storybook/main.js b/lib/cli/src/generators/PREACT/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/PREACT/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/RAX/index.ts b/lib/cli/src/generators/RAX/index.ts index ed0b4bdfa3c..fc0ebc038b5 100644 --- a/lib/cli/src/generators/RAX/index.ts +++ b/lib/cli/src/generators/RAX/index.ts @@ -1,24 +1,8 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; +import { baseGenerator, Generator } from '../generator'; import { writePackageJson } from '../../js-package-manager'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - actionsVersion, - linksVersion, - addonsVersion, - latestRaxVersion, - ] = await packageManager.getVersions( - '@storybook/rax', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - 'rax' - ); - - copyTemplate(__dirname, storyFormat); - +const generator: Generator = async (packageManager, npmOptions, options) => { + const [latestRaxVersion] = await packageManager.getVersions('rax'); const packageJson = packageManager.retrievePackageJson(); const raxVersion = packageJson.dependencies.rax || latestRaxVersion; @@ -34,17 +18,9 @@ const generator: Generator = async (packageManager, npmOptions, { storyFormat }) writePackageJson(packageJson); - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/rax@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addons@${addonsVersion}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); + baseGenerator(packageManager, npmOptions, options, 'rax', { + extraPackages: ['rax'], + }); }; export default generator; diff --git a/lib/cli/src/generators/RAX/template-csf/.storybook/main.js b/lib/cli/src/generators/RAX/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/RAX/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/REACT/index.ts b/lib/cli/src/generators/REACT/index.ts index 2a6606bc4d2..06581ac590b 100644 --- a/lib/cli/src/generators/REACT/index.ts +++ b/lib/cli/src/generators/REACT/index.ts @@ -1,32 +1,12 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; +import { copyTemplate } from '../../helpers'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = [ - '@storybook/react', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - ]; - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); +const generator: Generator = async (packageManager, npmOptions, options) => { + await baseGenerator(packageManager, npmOptions, options, 'react'); + if (options.storyFormat === StoryFormat.MDX) { + copyTemplate(__dirname, StoryFormat.MDX); } - - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); }; export default generator; diff --git a/lib/cli/src/generators/REACT/template-csf-ts/.storybook/main.js b/lib/cli/src/generators/REACT/template-csf-ts/.storybook/main.js deleted file mode 100644 index 523dca65b67..00000000000 --- a/lib/cli/src/generators/REACT/template-csf-ts/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(ts|tsx|js|jsx)'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/REACT/template-csf-ts/src/stories/0-Welcome.stories.tsx b/lib/cli/src/generators/REACT/template-csf-ts/src/stories/0-Welcome.stories.tsx deleted file mode 100644 index c76f45f3b4b..00000000000 --- a/lib/cli/src/generators/REACT/template-csf-ts/src/stories/0-Welcome.stories.tsx +++ /dev/null @@ -1,14 +0,0 @@ -import React from 'react'; -import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; - -export default { - title: 'Welcome', - component: Welcome, -}; - -export const ToStorybook = () => ; - -ToStorybook.story = { - name: 'to Storybook', -}; diff --git a/lib/cli/src/generators/REACT/template-csf/.storybook/main.js b/lib/cli/src/generators/REACT/template-csf/.storybook/main.js deleted file mode 100644 index 64815ba01ea..00000000000 --- a/lib/cli/src/generators/REACT/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.@(ts|tsx|js|jsx)'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/REACT/template-csf/stories/1-Button.stories.js b/lib/cli/src/generators/REACT/template-csf/stories/1-Button.stories.js deleted file mode 100644 index fdbd42fe76f..00000000000 --- a/lib/cli/src/generators/REACT/template-csf/stories/1-Button.stories.js +++ /dev/null @@ -1,34 +0,0 @@ -import React from 'react'; -import { action } from '@storybook/addon-actions'; -import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/react/demo'; - -export default { - title: 'Button', - component: Button, -}; - -export const Text = () => ; - -export const Emoji = () => ( - -); - -Emoji.parameters = { notes: 'My notes on a button with emojis' }; - -export const TextWithAction = () => ( - -); - -TextWithAction.storyName = 'With an action'; -TextWithAction.parameters = { notes: 'My notes on a button with emojis' }; - -export const ButtonWithLinkToAnotherStory = () => ( - -); - -ButtonWithLinkToAnotherStory.storyName = 'button with link to another story'; diff --git a/lib/cli/src/generators/REACT/template-mdx/.storybook/main.js b/lib/cli/src/generators/REACT/template-mdx/.storybook/main.js deleted file mode 100644 index e44fb99d3d7..00000000000 --- a/lib/cli/src/generators/REACT/template-mdx/.storybook/main.js +++ /dev/null @@ -1,11 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.@(js|mdx)'], - addons: [ - '@storybook/addon-actions', - '@storybook/addon-links', - { - name: '@storybook/addon-docs', - options: { configureJSX: true }, - }, - ], -}; diff --git a/lib/cli/src/generators/REACT/template-mdx/stories/0-Welcome.stories.mdx b/lib/cli/src/generators/REACT/template-mdx/stories/0-Welcome.stories.mdx index 8f48008a3b5..705382f9fa5 100644 --- a/lib/cli/src/generators/REACT/template-mdx/stories/0-Welcome.stories.mdx +++ b/lib/cli/src/generators/REACT/template-mdx/stories/0-Welcome.stories.mdx @@ -1,8 +1,8 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; +import Welcome from './Welcome'; - + # Welcome diff --git a/lib/cli/src/generators/REACT/template-mdx/stories/1-Button.stories.mdx b/lib/cli/src/generators/REACT/template-mdx/stories/1-Button.stories.mdx index ed90840f9dc..9688920f604 100644 --- a/lib/cli/src/generators/REACT/template-mdx/stories/1-Button.stories.mdx +++ b/lib/cli/src/generators/REACT/template-mdx/stories/1-Button.stories.mdx @@ -1,8 +1,8 @@ import { action } from '@storybook/addon-actions'; -import { Button } from '@storybook/react/demo'; import { Meta, Story } from '@storybook/addon-docs/blocks'; +import Button from './Button'; - + # Button diff --git a/lib/cli/src/generators/REACT_NATIVE/index.ts b/lib/cli/src/generators/REACT_NATIVE/index.ts index a47856934c7..20ece5e36b6 100644 --- a/lib/cli/src/generators/REACT_NATIVE/index.ts +++ b/lib/cli/src/generators/REACT_NATIVE/index.ts @@ -1,30 +1,16 @@ import shell from 'shelljs'; import chalk from 'chalk'; -import { paddedLog, getBabelDependencies, copyTemplate } from '../../helpers'; +import { paddedLog, copyTemplate } from '../../helpers'; import { NpmOptions } from '../../NpmOptions'; -import { GeneratorOptions } from '../Generator'; -import { JsPackageManager, writePackageJson } from '../../js-package-manager'; +import { baseGenerator, GeneratorOptions } from '../generator'; +import { JsPackageManager } from '../../js-package-manager'; -export default async ( +const generator = async ( packageManager: JsPackageManager, npmOptions: NpmOptions, installServer: boolean, - { storyFormat }: GeneratorOptions -) => { - const [ - storybookVersion, - addonsVersion, - actionsVersion, - linksVersion, - ] = await packageManager.getVersions( - '@storybook/react-native', - '@storybook/addons', - '@storybook/addon-actions', - '@storybook/addon-links' - ); - - copyTemplate(__dirname, storyFormat); - + options: GeneratorOptions +): Promise => { // set correct project name on entry files if possible const dirname = shell.ls('-d', 'ios/*.xcodeproj').stdout; @@ -45,38 +31,19 @@ export default async ( const packageJson = packageManager.retrievePackageJson(); - packageJson.dependencies = packageJson.dependencies || {}; - packageJson.devDependencies = packageJson.devDependencies || {}; - - const devDependencies = [ - `@storybook/react-native@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addons@${addonsVersion}`, - ]; - - if (installServer) { - devDependencies.push(`@storybook/react-native-server@${storybookVersion}`); - } - - if (!packageJson.dependencies['react-dom'] && !packageJson.devDependencies['react-dom']) { - if (packageJson.dependencies.react) { - const reactVersion = packageJson.dependencies.react; - devDependencies.push(`react-dom@${reactVersion}`); - } - } - - if (installServer) { - packageJson.scripts = packageJson.scripts || {}; - packageJson.scripts.storybook = 'start-storybook -p 7007'; - } - - writePackageJson(packageJson); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...devDependencies, - ...babelDependencies, - ]); + const missingReactDom = + !packageJson.dependencies['react-dom'] && !packageJson.devDependencies['react-dom']; + const reactVersion = packageJson.dependencies.react; + + await baseGenerator(packageManager, npmOptions, options, 'react-native', { + extraPackages: [ + missingReactDom && reactVersion && `react-dom@${reactVersion}`, + installServer && '@storybook/react-native-server', + ].filter(Boolean), + addScripts: installServer, + addComponents: false, // We copy template-csf as it's wrapped in a storybook folder + }); + copyTemplate(__dirname, options.storyFormat); }; + +export default generator; diff --git a/lib/cli/src/generators/REACT_SCRIPTS/index.ts b/lib/cli/src/generators/REACT_SCRIPTS/index.ts index bba68ba18b7..573d91c8b2c 100644 --- a/lib/cli/src/generators/REACT_SCRIPTS/index.ts +++ b/lib/cli/src/generators/REACT_SCRIPTS/index.ts @@ -1,39 +1,18 @@ import path from 'path'; import fs from 'fs'; -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; - -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = [ - '@storybook/react', - '@storybook/preset-create-react-app', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - ]; - - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); - } - - const versionedPackages = await packageManager.getVersionedPackages(...packages); - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); +import { baseGenerator, Generator } from '../generator'; +import { copyTemplate } from '../../helpers'; +import { StoryFormat } from '../../project_types'; - packageManager.addStorybookCommandInScripts({ - port: 9009, - staticFolder: fs.existsSync(path.resolve('./public')) ? 'public' : undefined, +const generator: Generator = async (packageManager, npmOptions, options) => { + await baseGenerator(packageManager, npmOptions, options, 'react', { + extraAddons: ['@storybook/preset-create-react-app'], + staticDir: fs.existsSync(path.resolve('./public')) ? 'public' : undefined, }); + if (options.storyFormat === StoryFormat.MDX) { + copyTemplate(__dirname, StoryFormat.MDX); + } }; export default generator; diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/.storybook/main.js b/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/.storybook/main.js deleted file mode 100644 index cc503660aed..00000000000 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/.storybook/main.js +++ /dev/null @@ -1,8 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(ts|tsx|js|jsx)'], - addons: [ - '@storybook/preset-create-react-app', - '@storybook/addon-actions', - '@storybook/addon-links', - ], -}; diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/src/stories/1-Button.stories.tsx b/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/src/stories/1-Button.stories.tsx deleted file mode 100644 index 6bcfa214662..00000000000 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-csf-ts/src/stories/1-Button.stories.tsx +++ /dev/null @@ -1,18 +0,0 @@ -import React from 'react'; -import { action } from '@storybook/addon-actions'; -import { Button } from '@storybook/react/demo'; - -export default { - title: 'Button', - component: Button, -}; - -export const Text = () => ; - -export const Emoji = () => ( - -); diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-csf/.storybook/main.js b/lib/cli/src/generators/REACT_SCRIPTS/template-csf/.storybook/main.js deleted file mode 100644 index 8f79d4617f2..00000000000 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-csf/.storybook/main.js +++ /dev/null @@ -1,8 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.js'], - addons: [ - '@storybook/preset-create-react-app', - '@storybook/addon-actions', - '@storybook/addon-links', - ], -}; diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-csf/src/stories/0-Welcome.stories.js b/lib/cli/src/generators/REACT_SCRIPTS/template-csf/src/stories/0-Welcome.stories.js deleted file mode 100644 index 9920a416e1f..00000000000 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-csf/src/stories/0-Welcome.stories.js +++ /dev/null @@ -1,12 +0,0 @@ -import React from 'react'; -import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; - -export default { - title: 'Welcome', - component: Welcome, -}; - -export const ToStorybook = () => ; - -ToStorybook.storyName = 'to Storybook'; diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/.storybook/main.js b/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/.storybook/main.js deleted file mode 100644 index 050ab43274f..00000000000 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/.storybook/main.js +++ /dev/null @@ -1,14 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(js|mdx)'], - addons: [ - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/preset-create-react-app', - { - name: '@storybook/addon-docs', - options: { - configureJSX: true, - }, - }, - ], -}; diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/src/stories/0-Welcome.stories.mdx b/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/stories/0-Welcome.stories.mdx similarity index 78% rename from lib/cli/src/generators/REACT_SCRIPTS/template-mdx/src/stories/0-Welcome.stories.mdx rename to lib/cli/src/generators/REACT_SCRIPTS/template-mdx/stories/0-Welcome.stories.mdx index 8f48008a3b5..705382f9fa5 100644 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/src/stories/0-Welcome.stories.mdx +++ b/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/stories/0-Welcome.stories.mdx @@ -1,8 +1,8 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; +import Welcome from './Welcome'; - + # Welcome diff --git a/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/src/stories/1-Button.stories.mdx b/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/stories/1-Button.stories.mdx similarity index 82% rename from lib/cli/src/generators/REACT_SCRIPTS/template-mdx/src/stories/1-Button.stories.mdx rename to lib/cli/src/generators/REACT_SCRIPTS/template-mdx/stories/1-Button.stories.mdx index 7c87b32323c..2abc573287c 100644 --- a/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/src/stories/1-Button.stories.mdx +++ b/lib/cli/src/generators/REACT_SCRIPTS/template-mdx/stories/1-Button.stories.mdx @@ -1,8 +1,8 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { action } from '@storybook/addon-actions'; -import { Button } from '@storybook/react/demo'; +import Button from './Button'; - + # Button diff --git a/lib/cli/src/generators/RIOT/index.ts b/lib/cli/src/generators/RIOT/index.ts index 404eb4aeacf..21601dfe3b3 100644 --- a/lib/cli/src/generators/RIOT/index.ts +++ b/lib/cli/src/generators/RIOT/index.ts @@ -1,52 +1,9 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; -import { writePackageJson } from '../../js-package-manager'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - actionsVersion, - linksVersion, - addonsVersion, - tagLoaderVersion, - ] = await packageManager.getVersions( - '@storybook/riot', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - 'riot-tag-loader' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - packageJson.dependencies = packageJson.dependencies || {}; - packageJson.devDependencies = packageJson.devDependencies || {}; - - const dependencies = [ - `@storybook/riot@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addons@${addonsVersion}`, - ]; - if ( - !packageJson.devDependencies['riot-tag-loader'] && - !packageJson.dependencies['riot-tag-loader'] - ) { - dependencies.push(`riot-tag-loader@${tagLoaderVersion}`); - } - - writePackageJson(packageJson); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...dependencies, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'riot', { + extraPackages: ['riot-tag-loader'], + }); }; export default generator; diff --git a/lib/cli/src/generators/RIOT/template-csf/.storybook/main.js b/lib/cli/src/generators/RIOT/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/RIOT/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/SFC_VUE/index.ts b/lib/cli/src/generators/SFC_VUE/index.ts index df945f683fa..bced886ae3a 100644 --- a/lib/cli/src/generators/SFC_VUE/index.ts +++ b/lib/cli/src/generators/SFC_VUE/index.ts @@ -1,31 +1,12 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; +import { copyTemplate } from '../../helpers'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = [ - '@storybook/vue', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - ]; - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'vue'); + if (options.storyFormat === StoryFormat.MDX) { + copyTemplate(__dirname, StoryFormat.MDX); } - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); }; export default generator; diff --git a/lib/cli/src/generators/SFC_VUE/template-csf/.storybook/main.js b/lib/cli/src/generators/SFC_VUE/template-csf/.storybook/main.js deleted file mode 100644 index 302586ca409..00000000000 --- a/lib/cli/src/generators/SFC_VUE/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/SFC_VUE/template-csf/src/stories/1-Button.stories.js b/lib/cli/src/generators/SFC_VUE/template-csf/src/stories/1-Button.stories.js deleted file mode 100644 index 2a8f67f6c0a..00000000000 --- a/lib/cli/src/generators/SFC_VUE/template-csf/src/stories/1-Button.stories.js +++ /dev/null @@ -1,32 +0,0 @@ -import { action } from '@storybook/addon-actions'; -import { linkTo } from '@storybook/addon-links'; - -import MyButton from './MyButton.vue'; - -export default { - title: 'Button', - component: MyButton, -}; - -export const Text = () => ({ - components: { MyButton }, - template: 'Hello Button', - methods: { action: action('clicked') }, -}); - -export const TextWithAction = () => ({ - components: { MyButton }, - template: 'Trigger Action', - methods: { action: () => action('This was clicked')() }, -}); - -TextWithAction.storyName = 'With an action'; -TextWithAction.parameters = { notes: 'My notes on a button with emojis' }; - -export const ButtonWithLinkToAnotherStory = () => ({ - components: { MyButton }, - template: 'Go to Welcome Story', - methods: { action: linkTo('Welcome') }, -}); - -ButtonWithLinkToAnotherStory.storyName = 'button with link to another story'; diff --git a/lib/cli/src/generators/SFC_VUE/template-mdx/.storybook/main.js b/lib/cli/src/generators/SFC_VUE/template-mdx/.storybook/main.js deleted file mode 100644 index 320231e699e..00000000000 --- a/lib/cli/src/generators/SFC_VUE/template-mdx/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(js|mdx)'], - addons: ['@storybook/addon-docs', '@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/MyButton.vue b/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/MyButton.vue deleted file mode 100644 index 4ad8ff85f08..00000000000 --- a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/MyButton.vue +++ /dev/null @@ -1,29 +0,0 @@ - - - - - diff --git a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/Welcome.vue b/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/Welcome.vue deleted file mode 100644 index bfb932da3d2..00000000000 --- a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/Welcome.vue +++ /dev/null @@ -1,119 +0,0 @@ - - - - - diff --git a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/0-Welcome.stories.mdx b/lib/cli/src/generators/SFC_VUE/template-mdx/stories/0-Welcome.stories.mdx similarity index 100% rename from lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/0-Welcome.stories.mdx rename to lib/cli/src/generators/SFC_VUE/template-mdx/stories/0-Welcome.stories.mdx diff --git a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/1-Button.stories.mdx b/lib/cli/src/generators/SFC_VUE/template-mdx/stories/1-Button.stories.mdx similarity index 94% rename from lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/1-Button.stories.mdx rename to lib/cli/src/generators/SFC_VUE/template-mdx/stories/1-Button.stories.mdx index f37647542ac..8a5b92a8d63 100644 --- a/lib/cli/src/generators/SFC_VUE/template-mdx/src/stories/1-Button.stories.mdx +++ b/lib/cli/src/generators/SFC_VUE/template-mdx/stories/1-Button.stories.mdx @@ -1,7 +1,7 @@ import { Meta, Story } from '@storybook/addon-docs/blocks'; import { action } from '@storybook/addon-actions'; import { linkTo } from '@storybook/addon-links'; -import MyButton from './MyButton.vue'; +import MyButton from './Button.vue'; diff --git a/lib/cli/src/generators/SVELTE/index.ts b/lib/cli/src/generators/SVELTE/index.ts index 646e234961c..9558f33787c 100644 --- a/lib/cli/src/generators/SVELTE/index.ts +++ b/lib/cli/src/generators/SVELTE/index.ts @@ -1,40 +1,9 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; -import { Generator } from '../Generator'; +import { baseGenerator, Generator } from '../generator'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const [ - storybookVersion, - actionsVersion, - linksVersion, - addonsVersion, - svelte, - svelteLoader, - ] = await packageManager.getVersions( - '@storybook/svelte', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - 'svelte', - 'svelte-loader' - ); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - `@storybook/svelte@${storybookVersion}`, - `@storybook/addon-actions@${actionsVersion}`, - `@storybook/addon-links@${linksVersion}`, - `@storybook/addons@${addonsVersion}`, - `svelte@${svelte}`, - `svelte-loader@${svelteLoader}`, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'svelte', { + extraPackages: ['svelte', 'svelte-loader'], + }); }; export default generator; diff --git a/lib/cli/src/generators/SVELTE/template-csf/.storybook/main.js b/lib/cli/src/generators/SVELTE/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/SVELTE/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/VUE/index.ts b/lib/cli/src/generators/VUE/index.ts index 0efb2d56bb0..bced886ae3a 100644 --- a/lib/cli/src/generators/VUE/index.ts +++ b/lib/cli/src/generators/VUE/index.ts @@ -1,52 +1,12 @@ -import { - getBabelDependencies, - addToDevDependenciesIfNotPresent, - copyTemplate, -} from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; -import { writePackageJson } from '../../js-package-manager'; +import { copyTemplate } from '../../helpers'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = [ - '@storybook/vue', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - '@babel/core', - ]; - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'vue'); + if (options.storyFormat === StoryFormat.MDX) { + copyTemplate(__dirname, StoryFormat.MDX); } - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const packageBabelCoreVersion = - packageJson.dependencies['babel-core'] || packageJson.devDependencies['babel-core']; - - // This seems to be the version installed by the Vue CLI, and it is not handled by - // installBabel below. For some reason it leads to the wrong version of @babel/core (a beta) - // being installed - if (packageBabelCoreVersion === '7.0.0-bridge.0') { - addToDevDependenciesIfNotPresent( - packageJson, - '@babel/core', - await packageManager.getVersion('@babel/core') - ); - } - - writePackageJson(packageJson); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); }; export default generator; diff --git a/lib/cli/src/generators/VUE/template-csf/.storybook/main.js b/lib/cli/src/generators/VUE/template-csf/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/VUE/template-csf/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/VUE/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/generators/VUE/template-csf/stories/0-Welcome.stories.js deleted file mode 100644 index 751d3002ef6..00000000000 --- a/lib/cli/src/generators/VUE/template-csf/stories/0-Welcome.stories.js +++ /dev/null @@ -1,16 +0,0 @@ -import { linkTo } from '@storybook/addon-links'; - -import Welcome from './Welcome'; - -export default { - title: 'Welcome', - component: Welcome, -}; - -export const ToStorybook = () => ({ - components: { Welcome }, - template: '', - methods: { action: linkTo('Button') }, -}); - -ToStorybook.storyName = 'to Storybook'; diff --git a/lib/cli/src/generators/VUE/template-csf/stories/MyButton.js b/lib/cli/src/generators/VUE/template-csf/stories/MyButton.js deleted file mode 100644 index 7ed4b85378d..00000000000 --- a/lib/cli/src/generators/VUE/template-csf/stories/MyButton.js +++ /dev/null @@ -1,29 +0,0 @@ -export default { - name: 'my-button', - - data() { - return { - buttonStyles: { - border: '1px solid #eee', - borderRadius: 3, - backgroundColor: '#FFFFFF', - cursor: 'pointer', - fontSize: 15, - padding: '3px 10px', - margin: 10, - }, - }; - }, - - template: ` - - `, - - methods: { - onClick() { - this.$emit('click'); - }, - }, -}; diff --git a/lib/cli/src/generators/VUE/template-csf/stories/Welcome.js b/lib/cli/src/generators/VUE/template-csf/stories/Welcome.js deleted file mode 100644 index 80df0039e05..00000000000 --- a/lib/cli/src/generators/VUE/template-csf/stories/Welcome.js +++ /dev/null @@ -1,121 +0,0 @@ -// eslint-disable-next-line no-console -const log = () => console.log('Welcome to storybook!'); - -export default { - name: 'welcome', - - props: { - showApp: { - type: Function, - default: log, - }, - }, - - data() { - return { - main: { - padding: 15, - lineHeight: 1.4, - fontFamily: '"Helvetica Neue", Helvetica, "Segoe UI", Arial, freesans, sans-serif', - backgroundColor: '#ffffff', - }, - - logo: { - width: 200, - }, - - link: { - color: '#1474f3', - textDecoration: 'none', - borderBottom: '1px solid #1474f3', - paddingBottom: 2, - }, - - code: { - fontSize: 15, - fontWeight: 600, - padding: '2px 5px', - border: '1px solid #eae9e9', - borderRadius: 4, - backgroundColor: '#f3f2f2', - color: '#3a3a3a', - }, - - note: { - opacity: 0.5, - }, - }; - }, - - template: ` -
-

Welcome to storybook

-

- This is a UI component dev environment for your app. -

-

- We've added some basic stories inside the -
- src/stories -
- directory. -
- A story is a single state of one or more UI components. You can have as many stories as - you want. -
- (Basically a story is like a visual test case.) -

-

- See these sample -
- stories -
- for a component called -
- Button - . -

-

- Just like that, you can add your own components as stories. -
- You can also edit those components and see changes right away. -
- (Try editing the Button component - located at src/stories/Button.js.) -

-

- This is just one thing you can do with Storybook. -
- Have a look at the -
- - Storybook - -
- repo for more information. -

-

- NOTE: -
- Have a look at the -
- .storybook/webpack.config.js -
- to add webpack - loaders and plugins you are using in this project. -

-
- `, - - methods: { - onClick(event) { - event.preventDefault(); - this.showApp(); - }, - }, -}; diff --git a/lib/cli/src/generators/WEB-COMPONENTS/index.ts b/lib/cli/src/generators/WEB-COMPONENTS/index.ts index 03ced0f5e0c..58e11363da3 100755 --- a/lib/cli/src/generators/WEB-COMPONENTS/index.ts +++ b/lib/cli/src/generators/WEB-COMPONENTS/index.ts @@ -1,35 +1,11 @@ -import fse from 'fs-extra'; -import path from 'path'; -import { getBabelDependencies } from '../../helpers'; -import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; - -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = [ - '@storybook/web-components', - '@storybook/addon-actions', - '@storybook/addon-links', - 'lit-html', - ]; - - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - fse.copySync(path.resolve(__dirname, 'template/'), '.', { overwrite: true }); - - if (storyFormat === StoryFormat.MDX) { - // TODO: handle adding of docs mode - } - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); +import { baseGenerator, Generator } from '../generator'; +import { copyTemplate } from '../../helpers'; + +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'web-components', { + extraPackages: ['lit-html'], + }); + copyTemplate(__dirname, options.storyFormat); }; export default generator; diff --git a/lib/cli/src/generators/WEB-COMPONENTS/template/.storybook/preview.js b/lib/cli/src/generators/WEB-COMPONENTS/template-csf/.storybook/preview.js similarity index 100% rename from lib/cli/src/generators/WEB-COMPONENTS/template/.storybook/preview.js rename to lib/cli/src/generators/WEB-COMPONENTS/template-csf/.storybook/preview.js diff --git a/lib/cli/src/generators/WEB-COMPONENTS/template/.storybook/main.js b/lib/cli/src/generators/WEB-COMPONENTS/template/.storybook/main.js deleted file mode 100644 index 3036098563c..00000000000 --- a/lib/cli/src/generators/WEB-COMPONENTS/template/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/WEBPACK_REACT/index.ts b/lib/cli/src/generators/WEBPACK_REACT/index.ts index 5c030def1ee..6a40334f6bf 100644 --- a/lib/cli/src/generators/WEBPACK_REACT/index.ts +++ b/lib/cli/src/generators/WEBPACK_REACT/index.ts @@ -1,31 +1,12 @@ -import { getBabelDependencies, copyTemplate } from '../../helpers'; +import { baseGenerator, Generator } from '../generator'; import { StoryFormat } from '../../project_types'; -import { Generator } from '../Generator'; +import { copyTemplate } from '../../helpers'; -const generator: Generator = async (packageManager, npmOptions, { storyFormat }) => { - const packages = [ - '@storybook/react', - '@storybook/addon-actions', - '@storybook/addon-links', - '@storybook/addons', - ]; - if (storyFormat === StoryFormat.MDX) { - packages.push('@storybook/addon-docs'); +const generator: Generator = async (packageManager, npmOptions, options) => { + baseGenerator(packageManager, npmOptions, options, 'react'); + if (options.storyFormat === StoryFormat.MDX) { + copyTemplate(__dirname, StoryFormat.MDX); } - const versionedPackages = await packageManager.getVersionedPackages(...packages); - - copyTemplate(__dirname, storyFormat); - - const packageJson = packageManager.retrievePackageJson(); - - const babelDependencies = await getBabelDependencies(packageManager, packageJson); - - packageManager.addDependencies({ ...npmOptions, packageJson }, [ - ...versionedPackages, - ...babelDependencies, - ]); - - packageManager.addStorybookCommandInScripts(); }; export default generator; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/.storybook/main.js b/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/.storybook/main.js deleted file mode 100644 index 523dca65b67..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/.storybook/main.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - stories: ['../src/**/*.stories.@(ts|tsx|js|jsx)'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], -}; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/src/stories/0-Welcome.stories.tsx b/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/src/stories/0-Welcome.stories.tsx deleted file mode 100644 index c76f45f3b4b..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/src/stories/0-Welcome.stories.tsx +++ /dev/null @@ -1,14 +0,0 @@ -import React from 'react'; -import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; - -export default { - title: 'Welcome', - component: Welcome, -}; - -export const ToStorybook = () => ; - -ToStorybook.story = { - name: 'to Storybook', -}; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/src/stories/1-Button.stories.tsx b/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/src/stories/1-Button.stories.tsx deleted file mode 100644 index 6bcfa214662..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-csf-ts/src/stories/1-Button.stories.tsx +++ /dev/null @@ -1,18 +0,0 @@ -import React from 'react'; -import { action } from '@storybook/addon-actions'; -import { Button } from '@storybook/react/demo'; - -export default { - title: 'Button', - component: Button, -}; - -export const Text = () => ; - -export const Emoji = () => ( - -); diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-csf/.storybook/main.js b/lib/cli/src/generators/WEBPACK_REACT/template-csf/.storybook/main.js deleted file mode 100644 index 69e89d84f74..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-csf/.storybook/main.js +++ /dev/null @@ -1,9 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.js'], - addons: ['@storybook/addon-actions', '@storybook/addon-links'], - webpackFinal: async (config) => { - // do mutation to the config - - return config; - }, -}; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-csf/stories/0-Welcome.stories.js b/lib/cli/src/generators/WEBPACK_REACT/template-csf/stories/0-Welcome.stories.js deleted file mode 100644 index 9920a416e1f..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-csf/stories/0-Welcome.stories.js +++ /dev/null @@ -1,12 +0,0 @@ -import React from 'react'; -import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; - -export default { - title: 'Welcome', - component: Welcome, -}; - -export const ToStorybook = () => ; - -ToStorybook.storyName = 'to Storybook'; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-csf/stories/1-Button.stories.js b/lib/cli/src/generators/WEBPACK_REACT/template-csf/stories/1-Button.stories.js deleted file mode 100644 index fdbd42fe76f..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-csf/stories/1-Button.stories.js +++ /dev/null @@ -1,34 +0,0 @@ -import React from 'react'; -import { action } from '@storybook/addon-actions'; -import { linkTo } from '@storybook/addon-links'; -import { Button } from '@storybook/react/demo'; - -export default { - title: 'Button', - component: Button, -}; - -export const Text = () => ; - -export const Emoji = () => ( - -); - -Emoji.parameters = { notes: 'My notes on a button with emojis' }; - -export const TextWithAction = () => ( - -); - -TextWithAction.storyName = 'With an action'; -TextWithAction.parameters = { notes: 'My notes on a button with emojis' }; - -export const ButtonWithLinkToAnotherStory = () => ( - -); - -ButtonWithLinkToAnotherStory.storyName = 'button with link to another story'; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-mdx/.storybook/main.js b/lib/cli/src/generators/WEBPACK_REACT/template-mdx/.storybook/main.js deleted file mode 100644 index 055aea01539..00000000000 --- a/lib/cli/src/generators/WEBPACK_REACT/template-mdx/.storybook/main.js +++ /dev/null @@ -1,16 +0,0 @@ -module.exports = { - stories: ['../stories/**/*.stories.@(js|mdx)'], - addons: [ - '@storybook/addon-actions', - '@storybook/addon-links', - { - name: '@storybook/addon-docs', - options: { configureJSX: true }, - }, - ], - webpackFinal: async (config) => { - // do mutation to the config - - return config; - }, -}; diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/0-Welcome.stories.mdx b/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/0-Welcome.stories.mdx index 8f48008a3b5..705382f9fa5 100644 --- a/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/0-Welcome.stories.mdx +++ b/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/0-Welcome.stories.mdx @@ -1,8 +1,8 @@ import { Meta, Story, Preview } from '@storybook/addon-docs/blocks'; import { linkTo } from '@storybook/addon-links'; -import { Welcome } from '@storybook/react/demo'; +import Welcome from './Welcome'; - + # Welcome diff --git a/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/1-Button.stories.mdx b/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/1-Button.stories.mdx index 876782206a8..329ea1da39c 100644 --- a/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/1-Button.stories.mdx +++ b/lib/cli/src/generators/WEBPACK_REACT/template-mdx/stories/1-Button.stories.mdx @@ -1,8 +1,8 @@ import { Meta, Story } from '@storybook/addon-docs/blocks'; import { action } from '@storybook/addon-actions'; -import { Button } from '@storybook/react/demo'; +import Button from './Button'; - + # Button diff --git a/lib/cli/src/generators/configure.ts b/lib/cli/src/generators/configure.ts new file mode 100644 index 00000000000..a390c4a0f6e --- /dev/null +++ b/lib/cli/src/generators/configure.ts @@ -0,0 +1,19 @@ +import fse from 'fs-extra'; + +function mainConfigurationGenerator(addons: string[], custom?: any) { + const hasSrc = fse.existsSync('./src'); + + const config = { + stories: [!hasSrc && '../stories/**/*.stories.*', hasSrc && '../src/**/*.stories.*'].filter( + Boolean + ), + addons, + ...custom, + }; + + const stringified = `module.exports = ${JSON.stringify(config, null, 2)}`; + fse.ensureDirSync('./.storybook'); + fse.writeFileSync('./.storybook/main.js', stringified, { encoding: 'utf8' }); +} + +export default mainConfigurationGenerator; diff --git a/lib/cli/src/generators/generator.ts b/lib/cli/src/generators/generator.ts new file mode 100644 index 00000000000..344c3e8438c --- /dev/null +++ b/lib/cli/src/generators/generator.ts @@ -0,0 +1,89 @@ +import { NpmOptions } from '../NpmOptions'; +import { StoryFormat, SupportedLanguage, SupportedFrameworks } from '../project_types'; +import { getBabelDependencies, copyComponents } from '../helpers'; +import configure from './configure'; +import { JsPackageManager } from '../js-package-manager'; + +export type GeneratorOptions = { + language: SupportedLanguage; + storyFormat: StoryFormat; +}; + +export interface FrameworkOptions { + extraPackages?: string[]; + extraAddons?: string[]; + staticDir?: string; + addScripts?: boolean; + addComponents?: boolean; +} + +export type Generator = ( + packageManager: JsPackageManager, + npmOptions: NpmOptions, + options: GeneratorOptions +) => Promise; + +const defaultOptions: FrameworkOptions = { + extraPackages: [], + extraAddons: [], + staticDir: undefined, + addScripts: true, + addComponents: true, +}; + +export async function baseGenerator( + packageManager: JsPackageManager, + npmOptions: NpmOptions, + { language }: GeneratorOptions, + framework: SupportedFrameworks, + options: FrameworkOptions = defaultOptions +) { + const { extraAddons, extraPackages, staticDir, addScripts, addComponents } = { + ...defaultOptions, + ...options, + }; + + const addons = [ + '@storybook/addon-links', + '@storybook/addon-actions', + // If angular skip `docs` because docs is buggy for now (https://github.com/storybookjs/storybook/issues/9103) + // for others framework add `essentials` i.e. `actions`, `backgrounds`, `docs`, `viewport` + // API of essentials needs to be clarified whether we need to add dependencies or not + framework !== 'angular' && '@storybook/addon-docs', + ].filter(Boolean); + + // ⚠️ Some addons have peer deps that must be added too, like '@storybook/addon-docs' => 'react-is' + const addonsPeerDeps = addons.some( + (addon) => addon === '@storybook/addon-essentials' || addon === '@storybook/addon-docs' + ) + ? ['react-is'] + : []; + + const packages = [ + `@storybook/${framework}`, + ...addons, + ...extraPackages, + ...extraAddons, + ...addonsPeerDeps, + ].filter(Boolean); + const versionedPackages = await packageManager.getVersionedPackages(...packages); + console.log('versionedPackages', versionedPackages); + configure([...addons, ...extraAddons]); + if (addComponents) { + copyComponents(framework, language); + } + + const packageJson = packageManager.retrievePackageJson(); + + if (addScripts) { + packageManager.addStorybookCommandInScripts({ + port: 6006, + staticFolder: staticDir, + }); + } + const babelDependencies = await getBabelDependencies(packageManager, packageJson); + packageManager.addDependencies({ ...npmOptions, packageJson }, [ + ...versionedPackages, + ...babelDependencies, + ]); +} diff --git a/lib/cli/src/helpers.test.ts b/lib/cli/src/helpers.test.ts index 675733fe759..1a7d32cfaf5 100644 --- a/lib/cli/src/helpers.test.ts +++ b/lib/cli/src/helpers.test.ts @@ -2,7 +2,7 @@ import fs from 'fs'; import fse from 'fs-extra'; import * as helpers from './helpers'; -import { StoryFormat } from './project_types'; +import { StoryFormat, SupportedLanguage, SupportedFrameworks } from './project_types'; jest.mock('fs', () => ({ existsSync: jest.fn(), @@ -10,6 +10,8 @@ jest.mock('fs', () => ({ jest.mock('fs-extra', () => ({ copySync: jest.fn(() => ({})), + ensureDir: jest.fn(() => {}), + existsSync: jest.fn(), })); jest.mock('path', () => ({ @@ -50,4 +52,58 @@ describe('Helpers', () => { }).toThrowError(expectedMessage); }); }); + + it.each` + language | exists | expected + ${'javascript'} | ${['js', 'ts']} | ${'/js'} + ${'typescript'} | ${['js', 'ts']} | ${'/ts'} + ${'typescript'} | ${['js']} | ${'/js'} + ${'javascript'} | ${[]} | ${''} + ${'typescript'} | ${[]} | ${''} + `( + `should copy $expected when folder $exists exists for language $language`, + ({ language, exists, expected }) => { + const componentsDirectory = exists.map((folder: string) => `frameworks/react/${folder}`); + const expectedDirectory = `frameworks/react${expected}`; + (fse.existsSync as jest.Mock).mockImplementation((filePath) => { + return componentsDirectory.includes(filePath) || filePath === 'frameworks/react'; + }); + helpers.copyComponents('react', language); + + const copySyncSpy = jest.spyOn(fse, 'copySync'); + expect(copySyncSpy).toHaveBeenCalledWith( + expectedDirectory, + expect.anything(), + expect.anything() + ); + } + ); + + it(`should copy to src folder when exists`, () => { + (fse.existsSync as jest.Mock).mockImplementation((filePath) => { + return filePath === 'frameworks/react' || filePath === './src'; + }); + helpers.copyComponents('react', SupportedLanguage.JAVASCRIPT); + expect(fse.copySync).toHaveBeenCalledWith( + expect.anything(), + './src/stories', + expect.anything() + ); + }); + + it(`should copy to root folder when src doesn't exist`, () => { + (fse.existsSync as jest.Mock).mockImplementation((filePath) => { + return filePath === 'frameworks/react'; + }); + helpers.copyComponents('react', SupportedLanguage.JAVASCRIPT); + expect(fse.copySync).toHaveBeenCalledWith(expect.anything(), './stories', expect.anything()); + }); + + it(`should throw an error for unsupported framework`, () => { + const framework = 'unknown framework' as SupportedFrameworks; + const expectedMessage = `Unsupported framework: ${framework}`; + expect(() => { + helpers.copyComponents(framework, SupportedLanguage.JAVASCRIPT); + }).toThrowError(expectedMessage); + }); }); diff --git a/lib/cli/src/helpers.ts b/lib/cli/src/helpers.ts index 9f32d3c4fac..ad32fc1816f 100644 --- a/lib/cli/src/helpers.ts +++ b/lib/cli/src/helpers.ts @@ -6,7 +6,7 @@ import chalk from 'chalk'; import { satisfies } from '@storybook/semver'; import stripJsonComments from 'strip-json-comments'; -import { StoryFormat } from './project_types'; +import { StoryFormat, SupportedFrameworks, SupportedLanguage } from './project_types'; import { JsPackageManager, PackageJson, PackageJsonWithDepsAndDevDeps } from './js-package-manager'; const logger = console; @@ -165,6 +165,7 @@ export function addToDevDependenciesIfNotPresent( export function copyTemplate(templateRoot: string, storyFormat: StoryFormat) { const templateDir = path.resolve(templateRoot, `template-${storyFormat}/`); + if (!fs.existsSync(templateDir)) { // Fallback to CSF plain first, in case format is typescript but template is not available. if (storyFormat === StoryFormat.CSF_TYPESCRIPT) { @@ -176,3 +177,42 @@ export function copyTemplate(templateRoot: string, storyFormat: StoryFormat) { } fse.copySync(templateDir, '.', { overwrite: true }); } + +export function copyComponents(framework: SupportedFrameworks, language: SupportedLanguage) { + const languageFolderMapping: Record = { + javascript: 'js', + typescript: 'ts', + }; + const componentsPath = () => { + const frameworkPath = `frameworks/${framework}`; + const languageSpecific = path.resolve( + __dirname, + `${frameworkPath}/${languageFolderMapping[language]}` + ); + if (fse.existsSync(languageSpecific)) { + return languageSpecific; + } + const jsFallback = path.resolve( + __dirname, + `${frameworkPath}/${languageFolderMapping.javascript}` + ); + if (fse.existsSync(jsFallback)) { + return jsFallback; + } + const frameworkRootPath = path.resolve(__dirname, frameworkPath); + if (fse.existsSync(frameworkRootPath)) { + return frameworkRootPath; + } + throw new Error(`Unsupported framework: ${framework}`); + }; + + const targetPath = () => { + if (fse.existsSync('./src')) { + return './src/stories'; + } + return './stories'; + }; + + const destinationPath = targetPath(); + fse.copySync(componentsPath(), destinationPath, { overwrite: true }); +} diff --git a/lib/cli/src/initiate.ts b/lib/cli/src/initiate.ts index a204d606a33..743ab7a31fd 100644 --- a/lib/cli/src/initiate.ts +++ b/lib/cli/src/initiate.ts @@ -53,7 +53,8 @@ const installStorybook = (projectType: ProjectType, options: CommandOptions): Pr skipInstall: options.skipInstall, }; - const hasTSDependency = detectLanguage() === SupportedLanguage.TYPESCRIPT; + const language = detectLanguage(); + const hasTSDependency = language === SupportedLanguage.TYPESCRIPT; warn({ hasTSDependency }); @@ -61,6 +62,7 @@ const installStorybook = (projectType: ProjectType, options: CommandOptions): Pr const generatorOptions = { storyFormat: options.storyFormat || defaultStoryFormat, + language, }; const end = () => { diff --git a/lib/cli/src/js-package-manager/JsPackageManager.ts b/lib/cli/src/js-package-manager/JsPackageManager.ts index eeb52bfa4be..43ee1fb5435 100644 --- a/lib/cli/src/js-package-manager/JsPackageManager.ts +++ b/lib/cli/src/js-package-manager/JsPackageManager.ts @@ -129,6 +129,7 @@ export abstract class JsPackageManager { * @param packageNames */ public getVersions(...packageNames: string[]): Promise { + console.log('getVersions', packageNames); return Promise.all(packageNames.map((packageName) => this.getVersion(packageName))); } diff --git a/lib/cli/src/project_types.ts b/lib/cli/src/project_types.ts index 48df5d20076..35cf14657a8 100644 --- a/lib/cli/src/project_types.ts +++ b/lib/cli/src/project_types.ts @@ -1,3 +1,4 @@ +// Should match @storybook/ export type SupportedFrameworks = | 'react' | 'react-native' @@ -11,7 +12,10 @@ export type SupportedFrameworks = | 'meteor' | 'preact' | 'svelte' - | 'rax'; + | 'rax' + | 'aurelia' + | 'html' + | 'web-components'; export enum ProjectType { UNDETECTED = 'UNDETECTED', diff --git a/lib/cli/test/fixtures/sfc_vue/package.json b/lib/cli/test/fixtures/sfc_vue/package.json index ed04921b850..a9bed94b180 100644 --- a/lib/cli/test/fixtures/sfc_vue/package.json +++ b/lib/cli/test/fixtures/sfc_vue/package.json @@ -23,6 +23,7 @@ "@babel/preset-env": "^7.4.1", "@babel/preset-stage-2": "^7.0.0", "@babel/register": "^7.0.0", + "@storybook/semver": "^7.3.2", "autoprefixer": "^9.4.9", "babel-core": "^7.0.0-bridge.0", "babel-loader": "^8.0.5", @@ -42,7 +43,6 @@ "optimize-css-assets-webpack-plugin": "^2.0.0", "ora": "^3.2.0", "rimraf": "^2.6.3", - "@storybook/semver": "^7.3.2", "shelljs": "^0.8.3", "url-loader": "^1.1.2", "vue-loader": "15.7.0", diff --git a/lib/cli/tsconfig.json b/lib/cli/tsconfig.json index c4e40706894..d87605d41af 100644 --- a/lib/cli/tsconfig.json +++ b/lib/cli/tsconfig.json @@ -12,5 +12,5 @@ "noFallthroughCasesInSwitch": true }, "include": ["src/**/*"], - "exclude": ["src/**/template*"] + "exclude": ["src/**/template*", "src/frameworks/**/*"] } diff --git a/lib/cli/versions.json b/lib/cli/versions.json index 484f7588068..32702f5965b 100644 --- a/lib/cli/versions.json +++ b/lib/cli/versions.json @@ -1,17 +1,17 @@ { - "@storybook/angular": "6.0.0-beta.23", - "@storybook/aurelia": "6.0.0-beta.23", - "@storybook/ember": "6.0.0-beta.23", - "@storybook/html": "6.0.0-beta.23", - "@storybook/marionette": "6.0.0-beta.23", - "@storybook/marko": "6.0.0-beta.23", - "@storybook/mithril": "6.0.0-beta.23", - "@storybook/preact": "6.0.0-beta.23", - "@storybook/rax": "6.0.0-beta.23", - "@storybook/react": "6.0.0-beta.23", - "@storybook/riot": "6.0.0-beta.23", - "@storybook/server": "6.0.0-beta.23", - "@storybook/svelte": "6.0.0-beta.23", - "@storybook/vue": "6.0.0-beta.23", - "@storybook/web-components": "6.0.0-beta.23" + "@storybook/angular": "6.0.0-beta.25", + "@storybook/aurelia": "6.0.0-beta.25", + "@storybook/ember": "6.0.0-beta.25", + "@storybook/html": "6.0.0-beta.25", + "@storybook/marionette": "6.0.0-beta.25", + "@storybook/marko": "6.0.0-beta.25", + "@storybook/mithril": "6.0.0-beta.25", + "@storybook/preact": "6.0.0-beta.25", + "@storybook/rax": "6.0.0-beta.25", + "@storybook/react": "6.0.0-beta.25", + "@storybook/riot": "6.0.0-beta.25", + "@storybook/server": "6.0.0-beta.25", + "@storybook/svelte": "6.0.0-beta.25", + "@storybook/vue": "6.0.0-beta.25", + "@storybook/web-components": "6.0.0-beta.25" } \ No newline at end of file diff --git a/scripts/prepare.js b/scripts/prepare.js index 19e50ee6bcc..84c397565b5 100644 --- a/scripts/prepare.js +++ b/scripts/prepare.js @@ -34,9 +34,16 @@ function cleanup() { if (fs.existsSync(path.join(process.cwd(), 'dist'))) { const files = shell.find('dist').filter((filePath) => { // Do not remove folder - // And do not clean anything for @storybook/cli/dist/generators/**/template* because these are the template files + // And do not clean anything for: + // - @storybook/cli/dist/generators/**/template* + // - @storybook/cli/dist/frameworks/* + // because these are the template files // that will be copied to init SB on users' projects - if (fs.lstatSync(filePath).isDirectory() || /generators\/.+\/template.*/.test(filePath)) { + if ( + fs.lstatSync(filePath).isDirectory() || + /generators\/.+\/template.*/.test(filePath) || + /dist\/frameworks\/.*/.test(filePath) + ) { return false; }