Skip to content

Commit

Permalink
feat(storybook): add vue3 support for storybook executer
Browse files Browse the repository at this point in the history
`This PR adds support for 'vue3' so it can be used to run storybook in a NX workspace

Closes #6603
  • Loading branch information
AlmarAubel committed Aug 4, 2021
1 parent a6a2b87 commit 5188d04
Show file tree
Hide file tree
Showing 11 changed files with 78 additions and 8 deletions.
2 changes: 1 addition & 1 deletion docs/angular/api-storybook/executors/storybook.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ Default: `@storybook/angular`

Type: `string`

Possible values: `@storybook/angular`, `@storybook/react`, `@storybook/html`, `@storybook/web-components`, `@storybook/vue`
Possible values: `@storybook/angular`, `@storybook/react`, `@storybook/html`, `@storybook/web-components`, `@storybook/vue`, `@storybook/vue3`

Storybook framework npm package

Expand Down
2 changes: 1 addition & 1 deletion docs/node/api-storybook/executors/storybook.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ Default: `@storybook/angular`

Type: `string`

Possible values: `@storybook/angular`, `@storybook/react`, `@storybook/html`, `@storybook/web-components`, `@storybook/vue`
Possible values: `@storybook/angular`, `@storybook/react`, `@storybook/html`, `@storybook/web-components`, `@storybook/vue`, `@storybook/vue3`

Storybook framework npm package

Expand Down
2 changes: 1 addition & 1 deletion docs/react/api-storybook/executors/storybook.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ Default: `@storybook/angular`

Type: `string`

Possible values: `@storybook/angular`, `@storybook/react`, `@storybook/html`, `@storybook/web-components`, `@storybook/vue`
Possible values: `@storybook/angular`, `@storybook/react`, `@storybook/html`, `@storybook/web-components`, `@storybook/vue`, `@storybook/vue3`

Storybook framework npm package

Expand Down
3 changes: 2 additions & 1 deletion packages/storybook/src/executors/storybook/schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@
"@storybook/react",
"@storybook/html",
"@storybook/web-components",
"@storybook/vue"
"@storybook/vue",
"@storybook/vue3"
],
"default": "@storybook/angular",
"hidden": true
Expand Down
3 changes: 2 additions & 1 deletion packages/storybook/src/executors/storybook/storybook.impl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ export interface StorybookExecutorOptions {
| '@storybook/react'
| '@storybook/html'
| '@storybook/web-components'
| '@storybook/vue';
| '@storybook/vue'
| '@storybook/vue3';
projectBuildConfig?: string;
config: StorybookConfig;
host?: string;
Expand Down
1 change: 1 addition & 0 deletions packages/storybook/src/executors/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ export function getStorybookFrameworkPath(uiFramework) {
'@storybook/react': '@storybook/react/dist/cjs/server/options',
'@storybook/html': '@storybook/html/dist/cjs/server/options',
'@storybook/vue': '@storybook/vue/dist/cjs/server/options',
'@storybook/vue3': '@storybook/vue3/dist/cjs/server/options',
'@storybook/web-components"':
'@storybook/web-components"/dist/cjs/server/options',
};
Expand Down
58 changes: 57 additions & 1 deletion packages/storybook/src/generators/init/init.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,7 @@ describe('@nrwl/storybook:init', () => {
expect(packageJson.devDependencies['@storybook/vue']).not.toBeDefined();
});

it('should add vue related dependencies when using html as uiFramework', async () => {
it('should add vue related dependencies when using vue as uiFramework', async () => {
const existing = 'existing';
const existingVersion = '1.0.0';
addDependenciesToPackageJson(
Expand Down Expand Up @@ -208,6 +208,52 @@ describe('@nrwl/storybook:init', () => {
expect(packageJson.devDependencies['@storybook/vue']).toBeDefined();
});

it('should add vue3 related dependencies when using vue3 as uiFramework', async () => {
const existing = 'existing';
const existingVersion = '1.0.0';
addDependenciesToPackageJson(
tree,
{ '@nrwl/storybook': storybookVersion, [existing]: existingVersion },
{ [existing]: existingVersion }
);
await initGenerator(tree, {
uiFramework: '@storybook/vue3',
});
const packageJson = readJson(tree, 'package.json');

// general deps
expect(packageJson.devDependencies['@nrwl/storybook']).toBeDefined();
expect(packageJson.dependencies['@nrwl/storybook']).toBeUndefined();
expect(packageJson.dependencies[existing]).toBeDefined();
expect(packageJson.devDependencies[existing]).toBeDefined();
expect(
packageJson.devDependencies['@storybook/addon-essentials']
).toBeDefined();

// react specific
expect(packageJson.devDependencies['@storybook/react']).not.toBeDefined();
expect(packageJson.devDependencies['@babel/core']).not.toBeDefined();
expect(packageJson.devDependencies['babel-loader']).not.toBeDefined();

// angular specific
expect(packageJson.devDependencies['@storybook/angular']).not.toBeDefined();
expect(packageJson.devDependencies['@angular/forms']).not.toBeDefined();

// generic html specific
expect(packageJson.devDependencies['@storybook/html']).not.toBeDefined();

// generic vue specific
expect(packageJson.devDependencies['@storybook/vue']).not.toBeDefined();

// generic web-components specific
expect(
packageJson.devDependencies['@storybook/web-components']
).not.toBeDefined();

// generic vue3 specific
expect(packageJson.devDependencies['@storybook/vue3']).toBeDefined();
});

it('should add build-storybook to cacheable operations', async () => {
await initGenerator(tree, {
uiFramework: '@storybook/html',
Expand Down Expand Up @@ -237,4 +283,14 @@ describe('@nrwl/storybook:init', () => {
nxJson.tasksRunnerOptions.default.options.cacheableOperations
).toContain('build-storybook');
});

it('should add build-storybook to cacheable operations for vue3', async () => {
await initGenerator(tree, {
uiFramework: '@storybook/vue3',
});
const nxJson = readJson(tree, 'nx.json');
expect(
nxJson.tasksRunnerOptions.default.options.cacheableOperations
).toContain('build-storybook');
});
});
4 changes: 4 additions & 0 deletions packages/storybook/src/generators/init/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,10 @@ function checkDependenciesInstalled(host: Tree, schema: Schema) {
devDependencies['@storybook/vue'] = storybookVersion;
}

if (isFramework('vue3', schema)) {
devDependencies['@storybook/vue3'] = storybookVersion;
}

if (isFramework('web-components', schema)) {
devDependencies['@storybook/web-components'] = storybookVersion;
}
Expand Down
3 changes: 2 additions & 1 deletion packages/storybook/src/generators/init/schema.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,6 @@ export interface Schema {
| '@storybook/react'
| '@storybook/html'
| '@storybook/web-components'
| '@storybook/vue';
| '@storybook/vue'
| '@storybook/vue3';
}
3 changes: 2 additions & 1 deletion packages/storybook/src/generators/init/schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@
"@storybook/react",
"@storybook/html",
"@storybook/web-components",
"@storybook/vue"
"@storybook/vue",
"@storybook/vue3"
],
"x-prompt": "What UI framework plugin should storybook use?"
}
Expand Down
5 changes: 5 additions & 0 deletions packages/storybook/src/utils/utilities.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ export const Constants = {
html: '@storybook/html',
'web-components': '@storybook/web-components',
vue: '@storybook/vue',
vue3: '@storybook/vue3',
} as const,
};
type Constants = typeof Constants;
Expand Down Expand Up @@ -49,6 +50,10 @@ export function isFramework(
return true;
}

if (type === 'vue3' && schema.uiFramework === '@storybook/vue3') {
return true;
}

return false;
}

Expand Down

0 comments on commit 5188d04

Please sign in to comment.