@storybook/cli 6.5.0-beta.0 → 6.5.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/dist/cjs/frameworks/html/js/Header.js +2 -0
  2. package/dist/cjs/frameworks/html/js/Header.stories.js +8 -1
  3. package/dist/cjs/frameworks/html/js/Page.js +29 -2
  4. package/dist/cjs/frameworks/html/js/Page.stories.js +12 -13
  5. package/dist/cjs/frameworks/html/ts/Header.stories.ts +5 -0
  6. package/dist/cjs/frameworks/html/ts/Header.ts +3 -1
  7. package/dist/cjs/frameworks/html/ts/Page.stories.ts +12 -14
  8. package/dist/cjs/frameworks/html/ts/Page.ts +32 -8
  9. package/dist/cjs/frameworks/vue/Header.stories.js +7 -1
  10. package/dist/cjs/frameworks/vue/Header.vue +1 -0
  11. package/dist/cjs/frameworks/vue/Page.stories.js +15 -13
  12. package/dist/cjs/frameworks/vue/Page.vue +7 -7
  13. package/dist/cjs/generators/ANGULAR/index.js +1 -1
  14. package/dist/cjs/generators/AURELIA/index.js +1 -1
  15. package/dist/cjs/generators/EMBER/index.js +1 -1
  16. package/dist/cjs/generators/HTML/index.js +1 -1
  17. package/dist/cjs/generators/METEOR/index.js +1 -1
  18. package/dist/cjs/generators/MITHRIL/index.js +1 -1
  19. package/dist/cjs/generators/PREACT/index.js +1 -1
  20. package/dist/cjs/generators/RAX/index.js +1 -1
  21. package/dist/cjs/generators/RIOT/index.js +1 -1
  22. package/dist/cjs/generators/SERVER/index.js +1 -1
  23. package/dist/cjs/generators/SFC_VUE/index.js +1 -1
  24. package/dist/cjs/generators/VUE/index.js +1 -1
  25. package/dist/cjs/generators/VUE3/index.js +1 -1
  26. package/dist/cjs/generators/WEBPACK_REACT/index.js +1 -1
  27. package/dist/cjs/generators/baseGenerator.js +1 -1
  28. package/dist/cjs/versions.js +56 -56
  29. package/dist/esm/frameworks/html/js/Header.js +2 -0
  30. package/dist/esm/frameworks/html/js/Header.stories.js +8 -1
  31. package/dist/esm/frameworks/html/js/Page.js +29 -2
  32. package/dist/esm/frameworks/html/js/Page.stories.js +12 -13
  33. package/dist/esm/frameworks/html/ts/Header.stories.ts +5 -0
  34. package/dist/esm/frameworks/html/ts/Header.ts +3 -1
  35. package/dist/esm/frameworks/html/ts/Page.stories.ts +12 -14
  36. package/dist/esm/frameworks/html/ts/Page.ts +32 -8
  37. package/dist/esm/frameworks/vue/Header.stories.js +7 -1
  38. package/dist/esm/frameworks/vue/Header.vue +1 -0
  39. package/dist/esm/frameworks/vue/Page.stories.js +15 -13
  40. package/dist/esm/frameworks/vue/Page.vue +7 -7
  41. package/dist/esm/generators/ANGULAR/index.js +1 -1
  42. package/dist/esm/generators/AURELIA/index.js +1 -1
  43. package/dist/esm/generators/EMBER/index.js +1 -1
  44. package/dist/esm/generators/HTML/index.js +1 -1
  45. package/dist/esm/generators/METEOR/index.js +1 -1
  46. package/dist/esm/generators/MITHRIL/index.js +1 -1
  47. package/dist/esm/generators/PREACT/index.js +1 -1
  48. package/dist/esm/generators/RAX/index.js +1 -1
  49. package/dist/esm/generators/RIOT/index.js +1 -1
  50. package/dist/esm/generators/SERVER/index.js +1 -1
  51. package/dist/esm/generators/SFC_VUE/index.js +1 -1
  52. package/dist/esm/generators/VUE/index.js +1 -1
  53. package/dist/esm/generators/VUE3/index.js +1 -1
  54. package/dist/esm/generators/WEBPACK_REACT/index.js +1 -1
  55. package/dist/esm/generators/baseGenerator.js +1 -1
  56. package/dist/esm/versions.js +56 -56
  57. package/dist/modern/frameworks/html/js/Header.js +2 -0
  58. package/dist/modern/frameworks/html/js/Header.stories.js +8 -1
  59. package/dist/modern/frameworks/html/js/Page.js +29 -2
  60. package/dist/modern/frameworks/html/js/Page.stories.js +12 -13
  61. package/dist/modern/frameworks/vue/Header.stories.js +7 -1
  62. package/dist/modern/frameworks/vue/Header.vue +1 -0
  63. package/dist/modern/frameworks/vue/Page.stories.js +15 -13
  64. package/dist/modern/frameworks/vue/Page.vue +7 -7
  65. package/dist/modern/generators/ANGULAR/index.js +1 -1
  66. package/dist/modern/generators/AURELIA/index.js +1 -1
  67. package/dist/modern/generators/EMBER/index.js +1 -1
  68. package/dist/modern/generators/HTML/index.js +1 -1
  69. package/dist/modern/generators/METEOR/index.js +1 -1
  70. package/dist/modern/generators/MITHRIL/index.js +1 -1
  71. package/dist/modern/generators/PREACT/index.js +1 -1
  72. package/dist/modern/generators/RAX/index.js +1 -1
  73. package/dist/modern/generators/RIOT/index.js +1 -1
  74. package/dist/modern/generators/SERVER/index.js +1 -1
  75. package/dist/modern/generators/SFC_VUE/index.js +1 -1
  76. package/dist/modern/generators/VUE/index.js +1 -1
  77. package/dist/modern/generators/VUE3/index.js +1 -1
  78. package/dist/modern/generators/WEBPACK_REACT/index.js +1 -1
  79. package/dist/modern/generators/baseGenerator.js +1 -1
  80. package/dist/modern/versions.js +56 -56
  81. package/package.json +7 -7
@@ -2,6 +2,11 @@ import { createHeader } from './Header';
2
2
 
3
3
  export default {
4
4
  title: 'Example/Header',
5
+ parameters: {
6
+ // More on Story layout: https://storybook.js.org/docs/html/configure/story-layout
7
+ layout: 'fullscreen',
8
+ },
9
+ // More on argTypes: https://storybook.js.org/docs/html/api/argtypes
5
10
  argTypes: {
6
11
  onLogin: { action: 'onLogin' },
7
12
  onLogout: { action: 'onLogout' },
@@ -13,7 +18,9 @@ const Template = (args) => createHeader(args);
13
18
 
14
19
  export const LoggedIn = Template.bind({});
15
20
  LoggedIn.args = {
16
- user: {},
21
+ user: {
22
+ name: 'Jane Doe',
23
+ },
17
24
  };
18
25
 
19
26
  export const LoggedOut = Template.bind({});
@@ -1,11 +1,38 @@
1
1
  import './page.css';
2
2
  import { createHeader } from './Header';
3
3
 
4
- export const createPage = ({ user, onLogout, onLogin, onCreateAccount }) => {
4
+ export const createPage = () => {
5
5
  const article = document.createElement('article');
6
+ let user = null;
7
+ let header = null;
6
8
 
7
- const header = createHeader({ onLogin, onLogout, onCreateAccount, user });
9
+ const rerenderHeader = () => {
10
+ const wrapper = document.getElementsByTagName('article')[0];
11
+ wrapper.replaceChild(createHeaderElement(), wrapper.firstChild);
12
+ };
13
+
14
+ const onLogin = () => {
15
+ user = { name: 'Jane Doe' };
16
+ rerenderHeader();
17
+ };
18
+
19
+ const onLogout = () => {
20
+ user = null;
21
+ rerenderHeader();
22
+ };
23
+
24
+ const onCreateAccount = () => {
25
+ user = { name: 'Jane Doe' };
26
+ rerenderHeader();
27
+ };
28
+
29
+ const createHeaderElement = () => {
30
+ return createHeader({ onLogin, onLogout, onCreateAccount, user });
31
+ };
32
+
33
+ header = createHeaderElement();
8
34
  article.appendChild(header);
35
+
9
36
  const section = `
10
37
  <section>
11
38
  <h2>Pages in Storybook</h2>
@@ -1,24 +1,23 @@
1
+ import { within, userEvent } from '@storybook/testing-library';
1
2
  import { createPage } from './Page';
2
- import * as HeaderStories from './Header.stories';
3
3
 
4
4
  export default {
5
5
  title: 'Example/Page',
6
- argTypes: {
7
- onLogin: { action: 'onLogin' },
8
- onLogout: { action: 'onLogout' },
9
- onCreateAccount: { action: 'onCreateAccount' },
6
+ parameters: {
7
+ // More on Story layout: https://storybook.js.org/docs/html/configure/story-layout
8
+ layout: 'fullscreen',
10
9
  },
11
10
  };
12
11
 
13
- const Template = (args) => createPage(args);
12
+ const Template = () => createPage();
13
+
14
+ export const LoggedOut = Template.bind({});
14
15
 
15
16
  export const LoggedIn = Template.bind({});
16
- LoggedIn.args = {
17
- // More on composing args: https://storybook.js.org/docs/html/writing-stories/args#args-composition
18
- ...HeaderStories.LoggedIn.args,
19
- };
20
17
 
21
- export const LoggedOut = Template.bind({});
22
- LoggedOut.args = {
23
- ...HeaderStories.LoggedOut.args,
18
+ // More on interaction testing: https://storybook.js.org/docs/html/writing-tests/interaction-testing
19
+ LoggedIn.play = async ({ canvasElement }) => {
20
+ const canvas = within(canvasElement);
21
+ const loginButton = await canvas.getByRole('button', { name: /Log in/i });
22
+ await userEvent.click(loginButton);
24
23
  };
@@ -3,6 +3,11 @@ import { createHeader, HeaderProps } from './Header';
3
3
 
4
4
  export default {
5
5
  title: 'Example/Header',
6
+ parameters: {
7
+ // More on Story layout: https://storybook.js.org/docs/html/configure/story-layout
8
+ layout: 'fullscreen',
9
+ },
10
+ // More on argTypes: https://storybook.js.org/docs/html/api/argtypes
6
11
  argTypes: {
7
12
  onLogin: { action: 'onLogin' },
8
13
  onLogout: { action: 'onLogout' },
@@ -2,7 +2,7 @@ import './header.css';
2
2
  import { createButton } from './Button';
3
3
 
4
4
  export interface HeaderProps {
5
- user?: {};
5
+ user?: { name: string };
6
6
  onLogin: () => void;
7
7
  onLogout: () => void;
8
8
  onCreateAccount: () => void;
@@ -33,6 +33,8 @@ export const createHeader = ({ user, onLogout, onLogin, onCreateAccount }: Heade
33
33
 
34
34
  const account = document.createElement('div');
35
35
  if (user) {
36
+ const welcomeMessage = `<span class="welcome">Welcome, <b>${user.name}</b>!</span>`;
37
+ account.innerHTML = welcomeMessage;
36
38
  account.appendChild(createButton({ size: 'small', label: 'Log out', onClick: onLogout }));
37
39
  } else {
38
40
  account.appendChild(createButton({ size: 'small', label: 'Log in', onClick: onLogin }));
@@ -1,26 +1,24 @@
1
+ import { within, userEvent } from '@storybook/testing-library';
1
2
  import { Story, Meta } from '@storybook/html';
2
3
  import { createPage } from './Page';
3
- import * as HeaderStories from './Header.stories';
4
- import { HeaderProps } from './Header';
5
4
 
6
5
  export default {
7
6
  title: 'Example/Page',
8
- argTypes: {
9
- onLogin: { action: 'onLogin' },
10
- onLogout: { action: 'onLogout' },
11
- onCreateAccount: { action: 'onCreateAccount' },
7
+ parameters: {
8
+ // More on Story layout: https://storybook.js.org/docs/html/configure/story-layout
9
+ layout: 'fullscreen',
12
10
  },
13
11
  } as Meta;
14
12
 
15
- const Template: Story<HeaderProps> = (args) => createPage(args);
13
+ const Template: Story = () => createPage();
14
+
15
+ export const LoggedOut = Template.bind({});
16
16
 
17
17
  export const LoggedIn = Template.bind({});
18
- LoggedIn.args = {
19
- // More on composing args: https://storybook.js.org/docs/html/writing-stories/args#args-composition
20
- ...HeaderStories.LoggedIn.args,
21
- };
22
18
 
23
- export const LoggedOut = Template.bind({});
24
- LoggedOut.args = {
25
- ...HeaderStories.LoggedOut.args,
19
+ // More on interaction testing: https://storybook.js.org/docs/html/writing-tests/interaction-testing
20
+ LoggedIn.play = async ({ canvasElement }) => {
21
+ const canvas = within(canvasElement);
22
+ const loginButton = await canvas.getByRole('button', { name: /Log in/i });
23
+ await userEvent.click(loginButton);
26
24
  };
@@ -1,18 +1,42 @@
1
1
  import './page.css';
2
2
  import { createHeader } from './Header';
3
3
 
4
- export interface PageProps {
5
- user?: {};
6
- onLogin: () => void;
7
- onLogout: () => void;
8
- onCreateAccount: () => void;
9
- }
4
+ type User = {
5
+ name: string;
6
+ };
10
7
 
11
- export const createPage = ({ user, onLogout, onLogin, onCreateAccount }: PageProps) => {
8
+ export const createPage = () => {
12
9
  const article = document.createElement('article');
10
+ let user: User = null;
11
+ let header = null;
12
+
13
+ const rerenderHeader = () => {
14
+ const wrapper = document.getElementsByTagName('article')[0];
15
+ wrapper.replaceChild(createHeaderElement(), wrapper.firstChild);
16
+ };
17
+
18
+ const onLogin = () => {
19
+ user = { name: 'Jane Doe' };
20
+ rerenderHeader();
21
+ };
22
+
23
+ const onLogout = () => {
24
+ user = null;
25
+ rerenderHeader();
26
+ };
13
27
 
14
- const header = createHeader({ onLogin, onLogout, onCreateAccount, user });
28
+ const onCreateAccount = () => {
29
+ user = { name: 'Jane Doe' };
30
+ rerenderHeader();
31
+ };
32
+
33
+ const createHeaderElement = () => {
34
+ return createHeader({ onLogin, onLogout, onCreateAccount, user });
35
+ };
36
+
37
+ header = createHeaderElement();
15
38
  article.appendChild(header);
39
+
16
40
  const section = `
17
41
  <section>
18
42
  <h2>Pages in Storybook</h2>
@@ -3,6 +3,10 @@ import MyHeader from './Header';
3
3
  export default {
4
4
  title: 'Example/Header',
5
5
  component: MyHeader,
6
+ parameters: {
7
+ // More on Story layout: https://storybook.js.org/docs/vue/configure/story-layout
8
+ layout: 'fullscreen',
9
+ },
6
10
  };
7
11
 
8
12
  const Template = (args, { argTypes }) => ({
@@ -14,7 +18,9 @@ const Template = (args, { argTypes }) => ({
14
18
 
15
19
  export const LoggedIn = Template.bind({});
16
20
  LoggedIn.args = {
17
- user: {},
21
+ user: {
22
+ name: 'Jane Doe',
23
+ },
18
24
  };
19
25
 
20
26
  export const LoggedOut = Template.bind({});
@@ -21,6 +21,7 @@
21
21
  <h1>Acme</h1>
22
22
  </div>
23
23
  <div>
24
+ <span class="welcome" v-if="user">Welcome, <b>{{ user.name }}</b>!</span>
24
25
  <my-button size="small" @onClick="onLogout" label="Log out" v-if="user" />
25
26
  <my-button size="small" @onClick="onLogin" label="Log in" v-if="!user" />
26
27
  <my-button primary size="small" @onClick="onCreateAccount" label="Sign up" v-if="!user" />
@@ -1,25 +1,27 @@
1
+ import { within, userEvent } from '@storybook/testing-library';
2
+
1
3
  import MyPage from './Page';
2
- import * as HeaderStories from './Header.stories';
3
4
 
4
5
  export default {
5
6
  title: 'Example/Page',
6
7
  component: MyPage,
8
+ parameters: {
9
+ // More on Story layout: https://storybook.js.org/docs/vue/configure/story-layout
10
+ layout: 'fullscreen',
11
+ },
7
12
  };
8
13
 
9
- const Template = (args, { argTypes }) => ({
10
- props: Object.keys(argTypes),
14
+ const Template = () => ({
11
15
  components: { MyPage },
12
- template:
13
- '<my-page :user="user" @onLogin="onLogin" @onLogout="onLogout" @onCreateAccount="onCreateAccount" />',
16
+ template: '<my-page />',
14
17
  });
15
18
 
16
- export const LoggedIn = Template.bind({});
17
- LoggedIn.args = {
18
- // More on composing args: https://storybook.js.org/docs/vue/writing-stories/args#args-composition
19
- ...HeaderStories.LoggedIn.args,
20
- };
21
-
22
19
  export const LoggedOut = Template.bind({});
23
- LoggedOut.args = {
24
- ...HeaderStories.LoggedOut.args,
20
+
21
+ // More on interaction testing: https://storybook.js.org/docs/vue/writing-tests/interaction-testing
22
+ export const LoggedIn = Template.bind({});
23
+ LoggedIn.play = async ({ canvasElement }) => {
24
+ const canvas = within(canvasElement);
25
+ const loginButton = await canvas.getByRole('button', { name: /Log in/i });
26
+ await userEvent.click(loginButton);
25
27
  };
@@ -67,21 +67,21 @@ export default {
67
67
 
68
68
  components: { MyHeader },
69
69
 
70
- props: {
71
- user: {
72
- type: Object,
73
- },
70
+ data() {
71
+ return {
72
+ user: null,
73
+ };
74
74
  },
75
75
 
76
76
  methods: {
77
77
  onLogin() {
78
- this.$emit('onLogin');
78
+ this.user = { name: 'Jane Doe' };
79
79
  },
80
80
  onLogout() {
81
- this.$emit('onLogout');
81
+ this.user = null;
82
82
  },
83
83
  onCreateAccount() {
84
- this.$emit('onCreateAccount');
84
+ this.user = { name: 'Jane Doe' };
85
85
  },
86
86
  },
87
87
  };
@@ -55,7 +55,7 @@ const generator = async (packageManager, npmOptions, options) => {
55
55
  const updatedOptions = isWebpack5 ? Object.assign({}, options, {
56
56
  builder: _project_types.CoreBuilder.Webpack5
57
57
  }) : options;
58
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, updatedOptions, 'angular', {
58
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, updatedOptions, 'angular', {
59
59
  extraPackages: ['@compodoc/compodoc'],
60
60
  addScripts: false
61
61
  });
@@ -33,7 +33,7 @@ function addStorybookExcludeGlobToTsConfig() {
33
33
 
34
34
  const generator = async (packageManager, npmOptions, options) => {
35
35
  addStorybookExcludeGlobToTsConfig();
36
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'aurelia', {
36
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'aurelia', {
37
37
  extraPackages: ['aurelia']
38
38
  });
39
39
  (0, _helpers.copyTemplate)(__dirname);
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'ember', {
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'ember', {
14
14
  extraPackages: [// babel-plugin-ember-modules-api-polyfill is a peerDep of @storybook/ember
15
15
  'babel-plugin-ember-modules-api-polyfill', // babel-plugin-htmlbars-inline-precompile is a peerDep of @storybook/ember
16
16
  'babel-plugin-htmlbars-inline-precompile'],
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'html');
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'html');
14
14
  };
15
15
 
16
16
  var _default = generator;
@@ -16,7 +16,7 @@ var _baseGenerator = require("../baseGenerator");
16
16
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
17
 
18
18
  const generator = async (packageManager, npmOptions, options) => {
19
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'react', {
19
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'react', {
20
20
  extraPackages: ['react', 'react-dom', '@babel/preset-env', '@babel/preset-react'],
21
21
  staticDir: 'dist'
22
22
  }); // create or update .babelrc
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'mithril');
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'mithril');
14
14
  };
15
15
 
16
16
  var _default = generator;
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'preact', {
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'preact', {
14
14
  extraPackages: ['core-js']
15
15
  });
16
16
  };
@@ -23,7 +23,7 @@ const generator = async (packageManager, npmOptions, options) => {
23
23
  packageJson.dependencies['rax-text'] = packageJson.dependencies['rax-text'] || raxVersion;
24
24
  packageJson.dependencies['rax-view'] = packageJson.dependencies['rax-view'] || raxVersion;
25
25
  (0, _jsPackageManager.writePackageJson)(packageJson);
26
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'rax', {
26
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'rax', {
27
27
  extraPackages: ['rax']
28
28
  });
29
29
  };
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'riot', {
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'riot', {
14
14
  extraPackages: ['riot-tag-loader']
15
15
  });
16
16
  };
@@ -12,7 +12,7 @@ var _baseGenerator = require("../baseGenerator");
12
12
  var _helpers = require("../../helpers");
13
13
 
14
14
  const generator = async (packageManager, npmOptions, options) => {
15
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'server', {
15
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'server', {
16
16
  extensions: ['json']
17
17
  });
18
18
  (0, _helpers.copyTemplate)(__dirname);
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'vue');
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'vue');
14
14
  };
15
15
 
16
16
  var _default = generator;
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'vue', {
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'vue', {
14
14
  extraPackages: ['vue-loader@^15.7.0']
15
15
  });
16
16
  };
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'vue3', {
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'vue3', {
14
14
  extraPackages: ['vue-loader@^16.0.0']
15
15
  });
16
16
  };
@@ -10,7 +10,7 @@ require("core-js/modules/es.promise.js");
10
10
  var _baseGenerator = require("../baseGenerator");
11
11
 
12
12
  const generator = async (packageManager, npmOptions, options) => {
13
- (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'react');
13
+ await (0, _baseGenerator.baseGenerator)(packageManager, npmOptions, options, 'react');
14
14
  };
15
15
 
16
16
  var _default = generator;
@@ -56,7 +56,7 @@ const builderDependencies = builder => {
56
56
 
57
57
  const stripVersions = addons => addons.map(addon => (0, _jsPackageManager.getPackageDetails)(addon)[0]);
58
58
 
59
- const hasInteractiveStories = framework => ['react', 'angular', 'preact', 'svelte', 'vue3'].includes(framework);
59
+ const hasInteractiveStories = framework => ['react', 'angular', 'preact', 'svelte', 'vue', 'vue3', 'html'].includes(framework);
60
60
 
61
61
  async function baseGenerator(packageManager, npmOptions, {
62
62
  language,
@@ -6,61 +6,61 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.default = void 0;
7
7
  // auto generated file, do not edit
8
8
  var _default = {
9
- '@storybook/addon-a11y': '6.5.0-beta.0',
10
- '@storybook/addon-actions': '6.5.0-beta.0',
11
- '@storybook/addon-backgrounds': '6.5.0-beta.0',
12
- '@storybook/addon-controls': '6.5.0-beta.0',
13
- '@storybook/addon-docs': '6.5.0-beta.0',
14
- '@storybook/addon-essentials': '6.5.0-beta.0',
15
- '@storybook/addon-interactions': '6.5.0-beta.0',
16
- '@storybook/addon-jest': '6.5.0-beta.0',
17
- '@storybook/addon-links': '6.5.0-beta.0',
18
- '@storybook/addon-measure': '6.5.0-beta.0',
19
- '@storybook/addon-outline': '6.5.0-beta.0',
20
- '@storybook/addon-storyshots': '6.5.0-beta.0',
21
- '@storybook/addon-storyshots-puppeteer': '6.5.0-beta.0',
22
- '@storybook/addon-storysource': '6.5.0-beta.0',
23
- '@storybook/addon-toolbars': '6.5.0-beta.0',
24
- '@storybook/addon-viewport': '6.5.0-beta.0',
25
- '@storybook/addons': '6.5.0-beta.0',
26
- '@storybook/angular': '6.5.0-beta.0',
27
- '@storybook/api': '6.5.0-beta.0',
28
- '@storybook/builder-webpack4': '6.5.0-beta.0',
29
- '@storybook/builder-webpack5': '6.5.0-beta.0',
30
- '@storybook/channel-postmessage': '6.5.0-beta.0',
31
- '@storybook/channel-websocket': '6.5.0-beta.0',
32
- '@storybook/channels': '6.5.0-beta.0',
33
- '@storybook/cli': '6.5.0-beta.0',
34
- '@storybook/client-api': '6.5.0-beta.0',
35
- '@storybook/client-logger': '6.5.0-beta.0',
36
- '@storybook/codemod': '6.5.0-beta.0',
37
- '@storybook/components': '6.5.0-beta.0',
38
- '@storybook/core': '6.5.0-beta.0',
39
- '@storybook/core-client': '6.5.0-beta.0',
40
- '@storybook/core-common': '6.5.0-beta.0',
41
- '@storybook/core-events': '6.5.0-beta.0',
42
- '@storybook/core-server': '6.5.0-beta.0',
43
- '@storybook/csf-tools': '6.5.0-beta.0',
44
- '@storybook/docs-tools': '6.5.0-beta.0',
45
- '@storybook/ember': '6.5.0-beta.0',
46
- '@storybook/html': '6.5.0-beta.0',
47
- '@storybook/instrumenter': '6.5.0-beta.0',
48
- '@storybook/manager-webpack4': '6.5.0-beta.0',
49
- '@storybook/manager-webpack5': '6.5.0-beta.0',
50
- '@storybook/node-logger': '6.5.0-beta.0',
51
- '@storybook/postinstall': '6.5.0-beta.0',
52
- '@storybook/preact': '6.5.0-beta.0',
53
- '@storybook/preview-web': '6.5.0-beta.0',
54
- '@storybook/react': '6.5.0-beta.0',
55
- '@storybook/router': '6.5.0-beta.0',
56
- '@storybook/server': '6.5.0-beta.0',
57
- '@storybook/source-loader': '6.5.0-beta.0',
58
- '@storybook/store': '6.5.0-beta.0',
59
- '@storybook/svelte': '6.5.0-beta.0',
60
- '@storybook/theming': '6.5.0-beta.0',
61
- '@storybook/ui': '6.5.0-beta.0',
62
- '@storybook/vue': '6.5.0-beta.0',
63
- '@storybook/vue3': '6.5.0-beta.0',
64
- '@storybook/web-components': '6.5.0-beta.0'
9
+ '@storybook/addon-a11y': '6.5.0-beta.1',
10
+ '@storybook/addon-actions': '6.5.0-beta.1',
11
+ '@storybook/addon-backgrounds': '6.5.0-beta.1',
12
+ '@storybook/addon-controls': '6.5.0-beta.1',
13
+ '@storybook/addon-docs': '6.5.0-beta.1',
14
+ '@storybook/addon-essentials': '6.5.0-beta.1',
15
+ '@storybook/addon-interactions': '6.5.0-beta.1',
16
+ '@storybook/addon-jest': '6.5.0-beta.1',
17
+ '@storybook/addon-links': '6.5.0-beta.1',
18
+ '@storybook/addon-measure': '6.5.0-beta.1',
19
+ '@storybook/addon-outline': '6.5.0-beta.1',
20
+ '@storybook/addon-storyshots': '6.5.0-beta.1',
21
+ '@storybook/addon-storyshots-puppeteer': '6.5.0-beta.1',
22
+ '@storybook/addon-storysource': '6.5.0-beta.1',
23
+ '@storybook/addon-toolbars': '6.5.0-beta.1',
24
+ '@storybook/addon-viewport': '6.5.0-beta.1',
25
+ '@storybook/addons': '6.5.0-beta.1',
26
+ '@storybook/angular': '6.5.0-beta.1',
27
+ '@storybook/api': '6.5.0-beta.1',
28
+ '@storybook/builder-webpack4': '6.5.0-beta.1',
29
+ '@storybook/builder-webpack5': '6.5.0-beta.1',
30
+ '@storybook/channel-postmessage': '6.5.0-beta.1',
31
+ '@storybook/channel-websocket': '6.5.0-beta.1',
32
+ '@storybook/channels': '6.5.0-beta.1',
33
+ '@storybook/cli': '6.5.0-beta.1',
34
+ '@storybook/client-api': '6.5.0-beta.1',
35
+ '@storybook/client-logger': '6.5.0-beta.1',
36
+ '@storybook/codemod': '6.5.0-beta.1',
37
+ '@storybook/components': '6.5.0-beta.1',
38
+ '@storybook/core': '6.5.0-beta.1',
39
+ '@storybook/core-client': '6.5.0-beta.1',
40
+ '@storybook/core-common': '6.5.0-beta.1',
41
+ '@storybook/core-events': '6.5.0-beta.1',
42
+ '@storybook/core-server': '6.5.0-beta.1',
43
+ '@storybook/csf-tools': '6.5.0-beta.1',
44
+ '@storybook/docs-tools': '6.5.0-beta.1',
45
+ '@storybook/ember': '6.5.0-beta.1',
46
+ '@storybook/html': '6.5.0-beta.1',
47
+ '@storybook/instrumenter': '6.5.0-beta.1',
48
+ '@storybook/manager-webpack4': '6.5.0-beta.1',
49
+ '@storybook/manager-webpack5': '6.5.0-beta.1',
50
+ '@storybook/node-logger': '6.5.0-beta.1',
51
+ '@storybook/postinstall': '6.5.0-beta.1',
52
+ '@storybook/preact': '6.5.0-beta.1',
53
+ '@storybook/preview-web': '6.5.0-beta.1',
54
+ '@storybook/react': '6.5.0-beta.1',
55
+ '@storybook/router': '6.5.0-beta.1',
56
+ '@storybook/server': '6.5.0-beta.1',
57
+ '@storybook/source-loader': '6.5.0-beta.1',
58
+ '@storybook/store': '6.5.0-beta.1',
59
+ '@storybook/svelte': '6.5.0-beta.1',
60
+ '@storybook/theming': '6.5.0-beta.1',
61
+ '@storybook/ui': '6.5.0-beta.1',
62
+ '@storybook/vue': '6.5.0-beta.1',
63
+ '@storybook/vue3': '6.5.0-beta.1',
64
+ '@storybook/web-components': '6.5.0-beta.1'
65
65
  };
66
66
  exports.default = _default;
@@ -26,6 +26,8 @@ export const createHeader = ({ user, onLogout, onLogin, onCreateAccount }) => {
26
26
 
27
27
  const account = document.createElement('div');
28
28
  if (user) {
29
+ const welcomeMessage = `<span class="welcome">Welcome, <b>${user.name}</b>!</span>`;
30
+ account.innerHTML = welcomeMessage;
29
31
  account.appendChild(createButton({ size: 'small', label: 'Log out', onClick: onLogout }));
30
32
  } else {
31
33
  account.appendChild(createButton({ size: 'small', label: 'Log in', onClick: onLogin }));
@@ -2,6 +2,11 @@ import { createHeader } from './Header';
2
2
 
3
3
  export default {
4
4
  title: 'Example/Header',
5
+ parameters: {
6
+ // More on Story layout: https://storybook.js.org/docs/html/configure/story-layout
7
+ layout: 'fullscreen',
8
+ },
9
+ // More on argTypes: https://storybook.js.org/docs/html/api/argtypes
5
10
  argTypes: {
6
11
  onLogin: { action: 'onLogin' },
7
12
  onLogout: { action: 'onLogout' },
@@ -13,7 +18,9 @@ const Template = (args) => createHeader(args);
13
18
 
14
19
  export const LoggedIn = Template.bind({});
15
20
  LoggedIn.args = {
16
- user: {},
21
+ user: {
22
+ name: 'Jane Doe',
23
+ },
17
24
  };
18
25
 
19
26
  export const LoggedOut = Template.bind({});