@storybook/angular 7.0.0-alpha.53 → 7.0.0-alpha.55
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.
- package/dist/client/angular-beta/ComputesTemplateFromComponent.d.ts +2 -2
- package/dist/client/angular-beta/ComputesTemplateFromComponent.js +3 -3
- package/dist/client/angular-beta/ComputesTemplateFromComponent.test.js +2 -1
- package/dist/client/angular-beta/DocsRenderer.js +2 -2
- package/dist/client/angular-beta/RendererFactory.test.js +1 -1
- package/dist/client/decorateStory.js +2 -2
- package/dist/client/docs/compodoc.d.ts +4 -10
- package/dist/client/docs/compodoc.js +5 -3
- package/dist/client/docs/sourceDecorator.js +3 -3
- package/dist/client/render.d.ts +2 -2
- package/dist/server/framework-preset-angular-cli.test.js +2 -12
- package/package.json +16 -17
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Type } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { ArgTypes } from '@storybook/types';
|
|
3
3
|
import { ICollection } from '../types';
|
|
4
4
|
/**
|
|
5
5
|
* Converts a component into a template with inputs/outputs present in initial props
|
|
@@ -14,4 +14,4 @@ export declare const computesTemplateFromComponent: (component: Type<unknown>, i
|
|
|
14
14
|
* @param initialProps
|
|
15
15
|
* @param innerTemplate
|
|
16
16
|
*/
|
|
17
|
-
export declare const computesTemplateSourceFromComponent: (component: Type<unknown>, initialProps?: ICollection, argTypes?:
|
|
17
|
+
export declare const computesTemplateSourceFromComponent: (component: Type<unknown>, initialProps?: ICollection, argTypes?: ArgTypes) => string;
|
|
@@ -37,9 +37,9 @@ const computesTemplateFromComponent = (component, initialProps, innerTemplate =
|
|
|
37
37
|
};
|
|
38
38
|
exports.computesTemplateFromComponent = computesTemplateFromComponent;
|
|
39
39
|
const createAngularInputProperty = ({ propertyName, value, argType, }) => {
|
|
40
|
-
const { name: type = null
|
|
41
|
-
let templateValue = type === 'enum' &&
|
|
42
|
-
const actualType = type === 'enum' &&
|
|
40
|
+
const { name: type = null } = (typeof argType?.type === 'object' && argType?.type) || {};
|
|
41
|
+
let templateValue = type === 'enum' && value;
|
|
42
|
+
const actualType = type === 'enum' && typeof value;
|
|
43
43
|
const requiresBrackets = ['object', 'any', 'boolean', 'enum', 'number'].includes(actualType);
|
|
44
44
|
if (typeof value === 'object') {
|
|
45
45
|
templateValue = propertyName;
|
|
@@ -335,7 +335,7 @@ describe('angular source decorator', () => {
|
|
|
335
335
|
type: {
|
|
336
336
|
name: 'enum',
|
|
337
337
|
required: true,
|
|
338
|
-
|
|
338
|
+
value: [],
|
|
339
339
|
},
|
|
340
340
|
},
|
|
341
341
|
};
|
|
@@ -362,6 +362,7 @@ describe('angular source decorator', () => {
|
|
|
362
362
|
type: {
|
|
363
363
|
name: 'object',
|
|
364
364
|
required: true,
|
|
365
|
+
value: {},
|
|
365
366
|
},
|
|
366
367
|
},
|
|
367
368
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.DocsRenderer = void 0;
|
|
4
|
-
const
|
|
4
|
+
const preview_api_1 = require("@storybook/preview-api");
|
|
5
5
|
const core_events_1 = require("@storybook/core-events");
|
|
6
6
|
const AbstractRenderer_1 = require("./AbstractRenderer");
|
|
7
7
|
class DocsRenderer extends AbstractRenderer_1.AbstractRenderer {
|
|
8
8
|
async render(options) {
|
|
9
|
-
const channel =
|
|
9
|
+
const channel = preview_api_1.addons.getChannel();
|
|
10
10
|
/**
|
|
11
11
|
* Destroy and recreate the PlatformBrowserDynamic of angular
|
|
12
12
|
* For several stories to be rendered in the same docs we should
|
|
@@ -261,7 +261,7 @@ describe('RendererFactory', () => {
|
|
|
261
261
|
.getElementById('storybook-root')
|
|
262
262
|
.appendChild(global.document.createElement('👾'));
|
|
263
263
|
expect(global.document.getElementById('storybook-root').innerHTML).toContain('Canvas 🖼');
|
|
264
|
-
|
|
264
|
+
await rendererFactory.getRendererInstance('my-story-in-docs', rootDocstargetDOMNode);
|
|
265
265
|
expect(global.document.getElementById('storybook-root').innerHTML).toBe('');
|
|
266
266
|
});
|
|
267
267
|
});
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.decorateStory = void 0;
|
|
4
|
-
const
|
|
4
|
+
const preview_api_1 = require("@storybook/preview-api");
|
|
5
5
|
const ComputesTemplateFromComponent_1 = require("./angular-beta/ComputesTemplateFromComponent");
|
|
6
6
|
function decorateStory(mainStoryFn, decorators) {
|
|
7
7
|
const returnDecorators = [cleanArgsDecorator, ...decorators].reduce((previousStoryFn, decorator) => (context) => {
|
|
8
8
|
const decoratedStory = decorator((update) => {
|
|
9
9
|
return previousStoryFn({
|
|
10
10
|
...context,
|
|
11
|
-
...(0,
|
|
11
|
+
...(0, preview_api_1.sanitizeStoryContextUpdate)(update),
|
|
12
12
|
});
|
|
13
13
|
}, context);
|
|
14
14
|
return decoratedStory;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ArgTypes, SBType } from '@storybook/types';
|
|
2
2
|
import { Class, CompodocJson, Component, Injectable, Method, Pipe, Property, Directive } from './types';
|
|
3
3
|
export declare const isMethod: (methodOrProp: Method | Property) => methodOrProp is Method;
|
|
4
4
|
export declare const setCompodocJson: (compodocJson: CompodocJson) => void;
|
|
@@ -6,13 +6,7 @@ export declare const getCompodocJson: () => CompodocJson;
|
|
|
6
6
|
export declare const checkValidComponentOrDirective: (component: Component | Directive) => void;
|
|
7
7
|
export declare const checkValidCompodocJson: (compodocJson: CompodocJson) => void;
|
|
8
8
|
export declare const findComponentByName: (name: string, compodocJson: CompodocJson) => Class | Injectable | Pipe | Directive;
|
|
9
|
-
export declare const extractType: (property: Property, defaultValue: any) =>
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
} | {
|
|
13
|
-
name: string;
|
|
14
|
-
value: any[];
|
|
15
|
-
};
|
|
16
|
-
export declare const extractArgTypesFromData: (componentData: Class | Directive | Injectable | Pipe) => API_ArgTypes;
|
|
17
|
-
export declare const extractArgTypes: (component: Component | Directive) => API_ArgTypes;
|
|
9
|
+
export declare const extractType: (property: Property, defaultValue: any) => SBType;
|
|
10
|
+
export declare const extractArgTypesFromData: (componentData: Class | Directive | Injectable | Pipe) => ArgTypes<import("@storybook/types").Args>;
|
|
11
|
+
export declare const extractArgTypes: (component: Component | Directive) => ArgTypes<import("@storybook/types").Args>;
|
|
18
12
|
export declare const extractComponentDescription: (component: Component | Directive) => string;
|
|
@@ -121,11 +121,13 @@ const extractType = (property, defaultValue) => {
|
|
|
121
121
|
return { name: compodocType };
|
|
122
122
|
case undefined:
|
|
123
123
|
case null:
|
|
124
|
-
return { name: 'void' };
|
|
124
|
+
return { name: 'other', value: 'void' };
|
|
125
125
|
default: {
|
|
126
126
|
const resolvedType = resolveTypealias(compodocType);
|
|
127
127
|
const enumValues = extractEnumValues(resolvedType);
|
|
128
|
-
return enumValues
|
|
128
|
+
return enumValues
|
|
129
|
+
? { name: 'enum', value: enumValues }
|
|
130
|
+
: { name: 'other', value: 'empty-enum' };
|
|
129
131
|
}
|
|
130
132
|
}
|
|
131
133
|
};
|
|
@@ -201,7 +203,7 @@ const extractArgTypesFromData = (componentData) => {
|
|
|
201
203
|
const section = mapItemToSection(key, item);
|
|
202
204
|
const defaultValue = (0, exports.isMethod)(item) ? undefined : extractDefaultValue(item);
|
|
203
205
|
const type = (0, exports.isMethod)(item) || (section !== 'inputs' && section !== 'properties')
|
|
204
|
-
? { name: 'void' }
|
|
206
|
+
? { name: 'other', value: 'void' }
|
|
205
207
|
: (0, exports.extractType)(item, defaultValue);
|
|
206
208
|
const action = section === 'outputs' ? { action: item.name } : {};
|
|
207
209
|
const argType = {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.sourceDecorator = exports.skipSourceRender = void 0;
|
|
4
|
-
const
|
|
4
|
+
const preview_api_1 = require("@storybook/preview-api");
|
|
5
5
|
const docs_tools_1 = require("@storybook/docs-tools");
|
|
6
6
|
const renderer_1 = require("../../renderer");
|
|
7
7
|
const skipSourceRender = (context) => {
|
|
@@ -25,11 +25,11 @@ const sourceDecorator = (storyFn, context) => {
|
|
|
25
25
|
if ((0, exports.skipSourceRender)(context)) {
|
|
26
26
|
return story;
|
|
27
27
|
}
|
|
28
|
-
const channel =
|
|
28
|
+
const channel = preview_api_1.addons.getChannel();
|
|
29
29
|
const { props, template, userDefinedTemplate } = story;
|
|
30
30
|
const { component, argTypes } = context;
|
|
31
31
|
let toEmit;
|
|
32
|
-
(0,
|
|
32
|
+
(0, preview_api_1.useEffect)(() => {
|
|
33
33
|
if (toEmit) {
|
|
34
34
|
channel.emit(docs_tools_1.SNIPPET_RENDERED, context.id, toEmit, 'angular');
|
|
35
35
|
}
|
package/dist/client/render.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RenderContext, ArgsStoryFn } from '@storybook/types';
|
|
2
2
|
import { AngularRenderer } from './types';
|
|
3
3
|
import { RendererFactory } from './angular-beta/RendererFactory';
|
|
4
4
|
export declare const rendererFactory: RendererFactory;
|
|
5
5
|
export declare const render: ArgsStoryFn<AngularRenderer>;
|
|
6
|
-
export declare function renderToCanvas({ storyFn, showMain, forceRemount, storyContext: { parameters, component }, id, }:
|
|
6
|
+
export declare function renderToCanvas({ storyFn, showMain, forceRemount, storyContext: { parameters, component }, id, }: RenderContext<AngularRenderer>, element: HTMLElement): Promise<void>;
|
|
@@ -28,10 +28,8 @@ describe('framework-preset-angular-cli', () => {
|
|
|
28
28
|
options = {};
|
|
29
29
|
});
|
|
30
30
|
describe('without angular.json', () => {
|
|
31
|
-
let consoleErrorSpy;
|
|
32
31
|
beforeEach(() => {
|
|
33
32
|
initMockWorkspace('');
|
|
34
|
-
consoleErrorSpy = jest.spyOn(console, 'error').mockImplementation();
|
|
35
33
|
});
|
|
36
34
|
it('should return webpack base config and display log error', async () => {
|
|
37
35
|
const webpackBaseConfig = newWebpackConfiguration();
|
|
@@ -336,10 +334,6 @@ describe('framework-preset-angular-cli', () => {
|
|
|
336
334
|
it('should set webpack "module.rules"', async () => {
|
|
337
335
|
const baseWebpackConfig = newWebpackConfiguration();
|
|
338
336
|
const webpackFinalConfig = await (0, framework_preset_angular_cli_1.webpackFinal)(baseWebpackConfig, options);
|
|
339
|
-
const stylePaths = [
|
|
340
|
-
path_1.default.join(workspaceRoot, 'src', 'styles.css'),
|
|
341
|
-
path_1.default.join(workspaceRoot, 'src', 'styles.scss'),
|
|
342
|
-
];
|
|
343
337
|
const expectedRules = [
|
|
344
338
|
{
|
|
345
339
|
oneOf: [
|
|
@@ -417,10 +411,6 @@ describe('framework-preset-angular-cli', () => {
|
|
|
417
411
|
it('should set webpack "module.rules"', async () => {
|
|
418
412
|
const baseWebpackConfig = newWebpackConfiguration();
|
|
419
413
|
const webpackFinalConfig = await (0, framework_preset_angular_cli_1.webpackFinal)(baseWebpackConfig, options);
|
|
420
|
-
const stylePaths = [
|
|
421
|
-
path_1.default.join(workspaceRoot, 'src', 'styles.css'),
|
|
422
|
-
path_1.default.join(workspaceRoot, 'src', 'styles.scss'),
|
|
423
|
-
];
|
|
424
414
|
const expectedRules = [
|
|
425
415
|
{
|
|
426
416
|
oneOf: [
|
|
@@ -679,8 +669,8 @@ const newWebpackConfiguration = (transformer = (c) => c) => {
|
|
|
679
669
|
modules: ['node_modules'],
|
|
680
670
|
mainFields: ['browser', 'main'],
|
|
681
671
|
alias: {
|
|
682
|
-
'@storybook/
|
|
683
|
-
'@storybook/api': '/Users/joe/storybook/lib/api',
|
|
672
|
+
'@storybook/preview-api': '/Users/joe/storybook/lib/addons',
|
|
673
|
+
'@storybook/manager-api': '/Users/joe/storybook/lib/api',
|
|
684
674
|
'@storybook/channels': '/Users/joe/storybook/lib/channels',
|
|
685
675
|
'@storybook/channel-postmessage': '/Users/joe/storybook/lib/channel-postmessage',
|
|
686
676
|
'@storybook/components': '/Users/joe/storybook/ui/components',
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@storybook/angular",
|
|
3
|
-
"version": "7.0.0-alpha.
|
|
3
|
+
"version": "7.0.0-alpha.55",
|
|
4
4
|
"description": "Storybook for Angular: Develop Angular components in isolation with hot reloading.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"storybook",
|
|
@@ -34,19 +34,18 @@
|
|
|
34
34
|
"prep": "rimraf dist && ../../../scripts/node_modules/.bin/tsc --project tsconfig.build.json && echo \"Preventing passing flags to tsc\""
|
|
35
35
|
},
|
|
36
36
|
"dependencies": {
|
|
37
|
-
"@storybook/
|
|
38
|
-
"@storybook/
|
|
39
|
-
"@storybook/
|
|
40
|
-
"@storybook/
|
|
41
|
-
"@storybook/core-
|
|
42
|
-
"@storybook/core-
|
|
43
|
-
"@storybook/core-
|
|
44
|
-
"@storybook/
|
|
45
|
-
"@storybook/
|
|
46
|
-
"@storybook/
|
|
47
|
-
"@storybook/
|
|
48
|
-
"@storybook/
|
|
49
|
-
"@storybook/types": "7.0.0-alpha.53",
|
|
37
|
+
"@storybook/builder-webpack5": "7.0.0-alpha.55",
|
|
38
|
+
"@storybook/client-logger": "7.0.0-alpha.55",
|
|
39
|
+
"@storybook/core-client": "7.0.0-alpha.55",
|
|
40
|
+
"@storybook/core-common": "7.0.0-alpha.55",
|
|
41
|
+
"@storybook/core-events": "7.0.0-alpha.55",
|
|
42
|
+
"@storybook/core-server": "7.0.0-alpha.55",
|
|
43
|
+
"@storybook/core-webpack": "7.0.0-alpha.55",
|
|
44
|
+
"@storybook/docs-tools": "7.0.0-alpha.55",
|
|
45
|
+
"@storybook/manager-api": "7.0.0-alpha.55",
|
|
46
|
+
"@storybook/node-logger": "7.0.0-alpha.55",
|
|
47
|
+
"@storybook/preview-api": "7.0.0-alpha.55",
|
|
48
|
+
"@storybook/types": "7.0.0-alpha.55",
|
|
50
49
|
"@types/node": "^16.0.0",
|
|
51
50
|
"@types/react": "^16.14.34",
|
|
52
51
|
"@types/react-dom": "^16.9.14",
|
|
@@ -59,7 +58,7 @@
|
|
|
59
58
|
"react-dom": "^16.14.0",
|
|
60
59
|
"read-pkg-up": "^7.0.1",
|
|
61
60
|
"semver": "^7.3.7",
|
|
62
|
-
"telejson": "^
|
|
61
|
+
"telejson": "^7.0.3",
|
|
63
62
|
"ts-dedent": "^2.0.0",
|
|
64
63
|
"tsconfig-paths-webpack-plugin": "^3.5.2",
|
|
65
64
|
"util-deprecate": "^1.0.2",
|
|
@@ -83,7 +82,7 @@
|
|
|
83
82
|
"cross-spawn": "^7.0.3",
|
|
84
83
|
"jest": "^29.3.1",
|
|
85
84
|
"jest-preset-angular": "^12.0.0",
|
|
86
|
-
"jest-specific-snapshot": "^
|
|
85
|
+
"jest-specific-snapshot": "^7.0.0",
|
|
87
86
|
"rimraf": "^3.0.2",
|
|
88
87
|
"tmp": "^0.2.1",
|
|
89
88
|
"typescript": "^4.9.3",
|
|
@@ -123,5 +122,5 @@
|
|
|
123
122
|
"access": "public"
|
|
124
123
|
},
|
|
125
124
|
"builders": "dist/builders/builders.json",
|
|
126
|
-
"gitHead": "
|
|
125
|
+
"gitHead": "55cd2ab63d1f897de59e2471d2f916f7d2c13546"
|
|
127
126
|
}
|