mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-06 15:31:16 +08:00
Renamed lib2 to lib
This commit is contained in:
parent
6aa96bced8
commit
0016449141
@ -2,7 +2,7 @@ import React, { FunctionComponent } from 'react';
|
|||||||
import { Description, DescriptionProps as PureDescriptionProps } from '@storybook/components';
|
import { Description, DescriptionProps as PureDescriptionProps } from '@storybook/components';
|
||||||
import { DocsContext, DocsContextProps } from './DocsContext';
|
import { DocsContext, DocsContextProps } from './DocsContext';
|
||||||
import { Component, CURRENT_SELECTION } from './shared';
|
import { Component, CURRENT_SELECTION } from './shared';
|
||||||
import { str } from '../lib2/docgen/utils';
|
import { str } from '../lib/docgen/utils';
|
||||||
|
|
||||||
export enum DescriptionType {
|
export enum DescriptionType {
|
||||||
INFO = 'info',
|
INFO = 'info',
|
||||||
|
@ -3,7 +3,7 @@ import { PropsTable, PropsTableError, PropsTableProps } from '@storybook/compone
|
|||||||
import { DocsContext, DocsContextProps } from './DocsContext';
|
import { DocsContext, DocsContextProps } from './DocsContext';
|
||||||
import { Component, CURRENT_SELECTION } from './shared';
|
import { Component, CURRENT_SELECTION } from './shared';
|
||||||
|
|
||||||
import { PropsExtractor } from '../lib/docgenUtils';
|
import { PropsExtractor } from '../lib/docgen/types';
|
||||||
import { extractProps as reactExtractProps } from '../frameworks/react/extractProps';
|
import { extractProps as reactExtractProps } from '../frameworks/react/extractProps';
|
||||||
import { extractProps as vueExtractProps } from '../frameworks/vue/extractProps';
|
import { extractProps as vueExtractProps } from '../frameworks/vue/extractProps';
|
||||||
|
|
||||||
|
@ -1 +1 @@
|
|||||||
export * from '../../lib/docgenUtils';
|
export * from '../../lib/docgen';
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
import { addParameters } from '@storybook/client-api';
|
import { addParameters } from '@storybook/client-api';
|
||||||
import { StoryFn } from '@storybook/addons';
|
import { StoryFn } from '@storybook/addons';
|
||||||
import { extractProps } from './extractProps';
|
import { extractProps } from './extractProps';
|
||||||
import { extractComponentDescription } from '../../lib2/docgen/utils';
|
import { extractComponentDescription } from '../../lib/docgen';
|
||||||
|
|
||||||
addParameters({
|
addParameters({
|
||||||
docs: {
|
docs: {
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import { isForwardRef, isMemo } from 'react-is';
|
import { isForwardRef, isMemo } from 'react-is';
|
||||||
import { PropDef } from '@storybook/components';
|
import { PropDef } from '@storybook/components';
|
||||||
import { hasDocgen } from '../../lib2/docgen/utils';
|
import { hasDocgen, extractPropsFromDocgen, PropsExtractor, TypeSystem } from '../../lib/docgen';
|
||||||
import { extractPropsFromDocgen } from '../../lib2/docgen/extractDocgenProps';
|
|
||||||
import { PropsExtractor, TypeSystem } from '../../lib2/docgen/types';
|
|
||||||
import { Component } from '../../blocks/shared';
|
import { Component } from '../../blocks/shared';
|
||||||
import { enhancePropTypesProp } from './propTypes/handleProp';
|
import { enhancePropTypesProp } from './propTypes/handleProp';
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@ function createSummaryValue(summary: string, detail: string): PropSummaryValue {
|
|||||||
return { summary, detail };
|
return { summary, detail };
|
||||||
}
|
}
|
||||||
|
|
||||||
function renderObject({ ast }: InspectionResult): PropDefaultValue {
|
function generateObject({ ast }: InspectionResult): PropDefaultValue {
|
||||||
let prettyCaption = generateCode(ast, true);
|
let prettyCaption = generateCode(ast, true);
|
||||||
|
|
||||||
// Cannot get escodegen to add a space before the last } with the compact mode settings.
|
// Cannot get escodegen to add a space before the last } with the compact mode settings.
|
||||||
@ -50,12 +50,11 @@ function renderObject({ ast }: InspectionResult): PropDefaultValue {
|
|||||||
: createSummaryValue(OBJECT_CAPTION, generateCode(ast));
|
: createSummaryValue(OBJECT_CAPTION, generateCode(ast));
|
||||||
}
|
}
|
||||||
|
|
||||||
function renderFunc({ inferedType, ast }: InspectionResult): PropDefaultValue {
|
function generateFunc({ inferedType, ast }: InspectionResult): PropDefaultValue {
|
||||||
const { identifier } = inferedType as InspectionFunction;
|
const { identifier } = inferedType as InspectionFunction;
|
||||||
|
|
||||||
if (!isNil(identifier)) {
|
if (!isNil(identifier)) {
|
||||||
return createSummaryValue(getPrettyIdentifier(inferedType), generateCode(ast));
|
return createSummaryValue(getPrettyIdentifier(inferedType), generateCode(ast));
|
||||||
// return createPropText(getPrettyIdentifier(inferedType), { title: generateCode(ast) });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const prettyCaption = generateCode(ast, true);
|
const prettyCaption = generateCode(ast, true);
|
||||||
@ -63,15 +62,14 @@ function renderFunc({ inferedType, ast }: InspectionResult): PropDefaultValue {
|
|||||||
return !isTooLongForDefaultValue(prettyCaption)
|
return !isTooLongForDefaultValue(prettyCaption)
|
||||||
? prettyCaption
|
? prettyCaption
|
||||||
: createSummaryValue(FUNCTION_CAPTION, generateCode(ast));
|
: createSummaryValue(FUNCTION_CAPTION, generateCode(ast));
|
||||||
|
|
||||||
// return !isTooLongForDefaultValue(prettyCaption)
|
|
||||||
// ? createPropText(prettyCaption)
|
|
||||||
// : createPropText(FUNCTION_CAPTION, { title: generateCode(ast) });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// All elements are JSX elements.
|
// All elements are JSX elements.
|
||||||
// JSX elements cannot are not supported by escodegen.
|
// JSX elements cannot are not supported by escodegen.
|
||||||
function renderElement(defaultValue: string, inspectionResult: InspectionResult): PropDefaultValue {
|
function generateElement(
|
||||||
|
defaultValue: string,
|
||||||
|
inspectionResult: InspectionResult
|
||||||
|
): PropDefaultValue {
|
||||||
const { inferedType } = inspectionResult;
|
const { inferedType } = inspectionResult;
|
||||||
const { identifier } = inferedType as InspectionElement;
|
const { identifier } = inferedType as InspectionElement;
|
||||||
|
|
||||||
@ -85,46 +83,34 @@ function renderElement(defaultValue: string, inspectionResult: InspectionResult)
|
|||||||
prettyIdentifier,
|
prettyIdentifier,
|
||||||
prettyIdentifier !== defaultValue ? defaultValue : undefined
|
prettyIdentifier !== defaultValue ? defaultValue : undefined
|
||||||
);
|
);
|
||||||
|
|
||||||
// return createPropText(prettyIdentifier, {
|
|
||||||
// title: prettyIdentifier !== defaultValue ? defaultValue : undefined,
|
|
||||||
// });
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return !isTooLongForDefaultValue(defaultValue)
|
return !isTooLongForDefaultValue(defaultValue)
|
||||||
? defaultValue
|
? defaultValue
|
||||||
: createSummaryValue(ELEMENT_CAPTION, defaultValue);
|
: createSummaryValue(ELEMENT_CAPTION, defaultValue);
|
||||||
|
|
||||||
// return !isTooLongForDefaultValue(defaultValue)
|
|
||||||
// ? createPropText(defaultValue)
|
|
||||||
// : createPropText(ELEMENT_CAPTION, { title: defaultValue });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function renderArray({ ast }: InspectionResult): PropDefaultValue {
|
function generateArray({ ast }: InspectionResult): PropDefaultValue {
|
||||||
const prettyCaption = generateCode(ast, true);
|
const prettyCaption = generateCode(ast, true);
|
||||||
|
|
||||||
return !isTooLongForDefaultValue(prettyCaption)
|
return !isTooLongForDefaultValue(prettyCaption)
|
||||||
? prettyCaption
|
? prettyCaption
|
||||||
: createSummaryValue(ARRAY_CAPTION, generateCode(ast));
|
: createSummaryValue(ARRAY_CAPTION, generateCode(ast));
|
||||||
|
|
||||||
// return !isTooLongForDefaultValue(prettyCaption)
|
|
||||||
// ? createPropText(prettyCaption)
|
|
||||||
// : createPropText(ARRAY_CAPTION, { title: generateCode(ast) });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function renderDefaultValue(defaultValue: string): PropDefaultValue {
|
export function createDefaultValue(defaultValue: string): PropDefaultValue {
|
||||||
const inspectionResult = inspectValue(defaultValue);
|
const inspectionResult = inspectValue(defaultValue);
|
||||||
|
|
||||||
switch (inspectionResult.inferedType.type) {
|
switch (inspectionResult.inferedType.type) {
|
||||||
case InspectionType.OBJECT:
|
case InspectionType.OBJECT:
|
||||||
return renderObject(inspectionResult);
|
return generateObject(inspectionResult);
|
||||||
case InspectionType.FUNCTION:
|
case InspectionType.FUNCTION:
|
||||||
return renderFunc(inspectionResult);
|
return generateFunc(inspectionResult);
|
||||||
case InspectionType.ELEMENT:
|
case InspectionType.ELEMENT:
|
||||||
return renderElement(defaultValue, inspectionResult);
|
return generateElement(defaultValue, inspectionResult);
|
||||||
case InspectionType.ARRAY:
|
case InspectionType.ARRAY:
|
||||||
return renderArray(inspectionResult);
|
return generateArray(inspectionResult);
|
||||||
default:
|
default:
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
@ -1,7 +1,6 @@
|
|||||||
import { isNil } from 'lodash';
|
import { isNil } from 'lodash';
|
||||||
import { PropSummaryValue, PropType } from '@storybook/components';
|
import { PropSummaryValue, PropType } from '@storybook/components';
|
||||||
import { ExtractedProp } from '../../../lib2/docgen/extractDocgenProps';
|
import { ExtractedProp, DocgenPropType } from '../../../lib/docgen';
|
||||||
import { DocgenPropType } from '../../../lib2/docgen/types';
|
|
||||||
import { inspectValue } from '../inspection/inspectValue';
|
import { inspectValue } from '../inspection/inspectValue';
|
||||||
import { generateCode } from './generateCode';
|
import { generateCode } from './generateCode';
|
||||||
import { generateFuncSignature } from './generateFuncSignature';
|
import { generateFuncSignature } from './generateFuncSignature';
|
||||||
@ -41,8 +40,6 @@ interface EnumValue {
|
|||||||
interface TypeDef {
|
interface TypeDef {
|
||||||
name: string;
|
name: string;
|
||||||
value: PropSummaryValue;
|
value: PropSummaryValue;
|
||||||
// caption: string;
|
|
||||||
// value: string;
|
|
||||||
inferedType?: InspectionType;
|
inferedType?: InspectionType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -339,7 +336,7 @@ function generateType(type: DocgenPropType, extractedProp: ExtractedProp): TypeD
|
|||||||
return createTypeDef({ name: 'unknown', summary: 'unknown' });
|
return createTypeDef({ name: 'unknown', summary: 'unknown' });
|
||||||
}
|
}
|
||||||
|
|
||||||
export function renderType(extractedProp: ExtractedProp): PropType {
|
export function createType(extractedProp: ExtractedProp): PropType {
|
||||||
const { type } = extractedProp.docgenInfo;
|
const { type } = extractedProp.docgenInfo;
|
||||||
|
|
||||||
switch (type.name) {
|
switch (type.name) {
|
@ -1,5 +1,5 @@
|
|||||||
import { generateFuncSignature } from './generateFuncSignature';
|
import { generateFuncSignature } from './generateFuncSignature';
|
||||||
import { parseJsDoc } from '../../../lib2/jsdocParser';
|
import { parseJsDoc } from '../../../lib/jsdocParser';
|
||||||
|
|
||||||
it('should return an empty string with there is no @params and @returns tags', () => {
|
it('should return an empty string with there is no @params and @returns tags', () => {
|
||||||
const result = generateFuncSignature(null, null);
|
const result = generateFuncSignature(null, null);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { isNil } from 'lodash';
|
import { isNil } from 'lodash';
|
||||||
import { ExtractedJsDocParam, ExtractedJsDocReturns } from '../../../lib2/jsdocParser';
|
import { ExtractedJsDocParam, ExtractedJsDocReturns } from '../../../lib/jsdocParser';
|
||||||
|
|
||||||
export function generateFuncSignature(
|
export function generateFuncSignature(
|
||||||
params: ExtractedJsDocParam[],
|
params: ExtractedJsDocParam[],
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
import { isNil } from 'lodash';
|
import { isNil } from 'lodash';
|
||||||
import { PropDef } from '@storybook/components';
|
import { PropDef } from '@storybook/components';
|
||||||
import { ExtractedProp } from '../../../lib2/docgen/extractDocgenProps';
|
import { ExtractedProp } from '../../../lib/docgen';
|
||||||
import { renderType } from './renderType';
|
import { createType } from './createType';
|
||||||
import { renderDefaultValue } from './renderDefaultValue';
|
import { createDefaultValue } from './createDefaultValue';
|
||||||
|
|
||||||
export function enhancePropTypesProp(extractedProp: ExtractedProp): PropDef {
|
export function enhancePropTypesProp(extractedProp: ExtractedProp): PropDef {
|
||||||
const { propDef } = extractedProp;
|
const { propDef } = extractedProp;
|
||||||
|
|
||||||
const newtype = renderType(extractedProp);
|
const newtype = createType(extractedProp);
|
||||||
if (!isNil(newtype)) {
|
if (!isNil(newtype)) {
|
||||||
propDef.type = newtype;
|
propDef.type = newtype;
|
||||||
}
|
}
|
||||||
|
|
||||||
const { defaultValue } = extractedProp.docgenInfo;
|
const { defaultValue } = extractedProp.docgenInfo;
|
||||||
if (!isNil(defaultValue)) {
|
if (!isNil(defaultValue)) {
|
||||||
const newDefaultValue = renderDefaultValue(defaultValue.value);
|
const newDefaultValue = createDefaultValue(defaultValue.value);
|
||||||
if (!isNil(newDefaultValue)) {
|
if (!isNil(newDefaultValue)) {
|
||||||
propDef.defaultValue = newDefaultValue;
|
propDef.defaultValue = newDefaultValue;
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@ import toReact from '@egoist/vue-to-react';
|
|||||||
import { StoryFn } from '@storybook/addons';
|
import { StoryFn } from '@storybook/addons';
|
||||||
import { addParameters } from '@storybook/client-api';
|
import { addParameters } from '@storybook/client-api';
|
||||||
import { extractProps } from './extractProps';
|
import { extractProps } from './extractProps';
|
||||||
import { extractComponentDescription } from '../../lib2/docgen/utils';
|
import { extractComponentDescription } from '../../lib/docgen/utils';
|
||||||
|
|
||||||
addParameters({
|
addParameters({
|
||||||
docs: {
|
docs: {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { PropDef } from '@storybook/components';
|
import { PropDef } from '@storybook/components';
|
||||||
import { PropsExtractor, extractPropsFromDocgen, hasDocgen } from '../../lib/docgenUtils';
|
import { PropsExtractor, hasDocgen, extractPropsFromDocgen } from '../../lib/docgen';
|
||||||
|
|
||||||
const SECTIONS = ['props', 'events', 'slots'];
|
const SECTIONS = ['props', 'events', 'slots'];
|
||||||
|
|
||||||
@ -9,7 +9,7 @@ export const extractProps: PropsExtractor = component => {
|
|||||||
}
|
}
|
||||||
const sections: Record<string, PropDef[]> = {};
|
const sections: Record<string, PropDef[]> = {};
|
||||||
SECTIONS.forEach(section => {
|
SECTIONS.forEach(section => {
|
||||||
sections[section] = extractPropsFromDocgen(component, section);
|
sections[section] = extractPropsFromDocgen(component, section).map(x => x.propDef);
|
||||||
});
|
});
|
||||||
return { sections };
|
return { sections };
|
||||||
};
|
};
|
||||||
|
@ -8,7 +8,7 @@ function isDefaultValueBlacklisted(value: string) {
|
|||||||
return BLACKLIST.some(x => x === value);
|
return BLACKLIST.some(x => x === value);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function renderDefaultValue(defaultValue: DocgenPropDefaultValue): PropDefaultValue {
|
export function createDefaultValue(defaultValue: DocgenPropDefaultValue): PropDefaultValue {
|
||||||
if (!isNil(defaultValue)) {
|
if (!isNil(defaultValue)) {
|
||||||
const { value } = defaultValue;
|
const { value } = defaultValue;
|
||||||
|
|
@ -2,7 +2,7 @@ import { isNil } from 'lodash';
|
|||||||
import { PropDef } from '@storybook/components';
|
import { PropDef } from '@storybook/components';
|
||||||
import { TypeSystem, DocgenInfo, DocgenType } from './types';
|
import { TypeSystem, DocgenInfo, DocgenType } from './types';
|
||||||
import { JsDocParsingResult } from '../jsdocParser';
|
import { JsDocParsingResult } from '../jsdocParser';
|
||||||
import { renderDefaultValue } from './renderDefaultValue';
|
import { createDefaultValue } from './createDefaultValue';
|
||||||
|
|
||||||
export type PropDefFactory = (
|
export type PropDefFactory = (
|
||||||
propName: string,
|
propName: string,
|
||||||
@ -18,7 +18,7 @@ function createBasicPropDef(name: string, type: DocgenType, docgenInfo: DocgenIn
|
|||||||
type: type.name,
|
type: type.name,
|
||||||
required,
|
required,
|
||||||
description,
|
description,
|
||||||
defaultValue: renderDefaultValue(defaultValue),
|
defaultValue: createDefaultValue(defaultValue),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
3
addons/docs/src/lib/docgen/index.ts
Normal file
3
addons/docs/src/lib/docgen/index.ts
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
export * from './types';
|
||||||
|
export * from './utils';
|
||||||
|
export * from './extractDocgenProps';
|
@ -1,13 +0,0 @@
|
|||||||
/* eslint-disable no-underscore-dangle */
|
|
||||||
import { PropDef, PropsTableProps } from '@storybook/components';
|
|
||||||
import { Component } from '../blocks/shared';
|
|
||||||
|
|
||||||
export type PropsExtractor = (component: Component) => PropsTableProps | null;
|
|
||||||
|
|
||||||
export type PropDefGetter = (component: Component, section: string) => PropDef[];
|
|
||||||
|
|
||||||
export const hasDocgen = (component: Component) => !!component.__docgenInfo;
|
|
||||||
|
|
||||||
export const extractPropsFromDocgen: PropDefGetter = (component, section) => {
|
|
||||||
return [];
|
|
||||||
};
|
|
Loading…
x
Reference in New Issue
Block a user