mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-04 19:01:05 +08:00
Refactor: Move SBType to ClientAPI
This commit is contained in:
parent
d2c0375a2f
commit
8720ca6111
@ -1,7 +1,7 @@
|
|||||||
import mapValues from 'lodash/mapValues';
|
import mapValues from 'lodash/mapValues';
|
||||||
import { ArgTypes, ArgType } from '@storybook/addons';
|
import { ArgTypes, ArgType } from '@storybook/addons';
|
||||||
import { Control } from '@storybook/components';
|
import { Control } from '@storybook/components';
|
||||||
import { SBEnumType } from '../../lib/sbtypes';
|
import { SBEnumType } from '@storybook/client-api';
|
||||||
|
|
||||||
const inferControl = (argType: ArgType): Control => {
|
const inferControl = (argType: ArgType): Control => {
|
||||||
const { type } = argType;
|
const { type } = argType;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import mapValues from 'lodash/mapValues';
|
import mapValues from 'lodash/mapValues';
|
||||||
import { ArgTypes } from '@storybook/api';
|
import { ArgTypes } from '@storybook/api';
|
||||||
import { SBType } from '../../lib/sbtypes';
|
import { SBType } from '@storybook/client-api';
|
||||||
|
|
||||||
const normalizeType = (type: SBType | string) => (typeof type === 'string' ? { name: type } : type);
|
const normalizeType = (type: SBType | string) => (typeof type === 'string' ? { name: type } : type);
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ const typescriptFixtures = [
|
|||||||
const typescriptStories = storiesOf('ArgTypes/TypeScript', module);
|
const typescriptStories = storiesOf('ArgTypes/TypeScript', module);
|
||||||
typescriptFixtures.forEach((fixture) => {
|
typescriptFixtures.forEach((fixture) => {
|
||||||
// eslint-disable-next-line import/no-dynamic-require, global-require, no-shadow
|
// eslint-disable-next-line import/no-dynamic-require, global-require, no-shadow
|
||||||
const { Component } = require(`../../lib/sbtypes/__testfixtures__/typescript/${fixture}`);
|
const { Component } = require(`../../lib/convert/__testfixtures__/typescript/${fixture}`);
|
||||||
typescriptStories.add(fixture, () => <ArgsStory component={Component} />);
|
typescriptStories.add(fixture, () => <ArgsStory component={Component} />);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -69,7 +69,7 @@ const proptypesFixtures = ['arrays', 'enums', 'misc', 'objects', 'react', 'scala
|
|||||||
const proptypesStories = storiesOf('ArgTypes/PropTypes', module);
|
const proptypesStories = storiesOf('ArgTypes/PropTypes', module);
|
||||||
proptypesFixtures.forEach((fixture) => {
|
proptypesFixtures.forEach((fixture) => {
|
||||||
// eslint-disable-next-line import/no-dynamic-require, global-require, no-shadow
|
// eslint-disable-next-line import/no-dynamic-require, global-require, no-shadow
|
||||||
const { Component } = require(`../../lib/sbtypes/__testfixtures__/proptypes/${fixture}`);
|
const { Component } = require(`../../lib/convert/__testfixtures__/proptypes/${fixture}`);
|
||||||
proptypesStories.add(fixture, () => <ArgsStory component={Component} />);
|
proptypesStories.add(fixture, () => <ArgsStory component={Component} />);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import { ArgTypes } from '@storybook/api';
|
import { ArgTypes } from '@storybook/api';
|
||||||
import { ArgTypesExtractor, hasDocgen, extractComponentProps } from '../../lib/docgen';
|
import { ArgTypesExtractor, hasDocgen, extractComponentProps } from '../../lib/docgen';
|
||||||
import { convert } from '../../lib/sbtypes';
|
import { convert } from '../../lib/convert';
|
||||||
import { trimQuotes } from '../../lib/sbtypes/utils';
|
import { trimQuotes } from '../../lib/convert/utils';
|
||||||
|
|
||||||
const SECTIONS = ['props', 'events', 'slots'];
|
const SECTIONS = ['props', 'events', 'slots'];
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@ import { transformSync } from '@babel/core';
|
|||||||
import requireFromString from 'require-from-string';
|
import requireFromString from 'require-from-string';
|
||||||
import fs from 'fs';
|
import fs from 'fs';
|
||||||
|
|
||||||
import { convert } from './convert';
|
import { convert } from './index';
|
||||||
import { normalizeNewlines } from '../utils';
|
import { normalizeNewlines } from '../utils';
|
||||||
|
|
||||||
expect.addSnapshotSerializer({
|
expect.addSnapshotSerializer({
|
@ -1,7 +1,7 @@
|
|||||||
/* eslint-disable no-case-declarations */
|
/* eslint-disable no-case-declarations */
|
||||||
import mapValues from 'lodash/mapValues';
|
import mapValues from 'lodash/mapValues';
|
||||||
|
import { SBType } from '@storybook/client-api';
|
||||||
import { PTType } from './types';
|
import { PTType } from './types';
|
||||||
import { SBType } from '../types';
|
|
||||||
import { trimQuotes } from '../utils';
|
import { trimQuotes } from '../utils';
|
||||||
|
|
||||||
const SIGNATURE_REGEXP = /^\(.*\) => /;
|
const SIGNATURE_REGEXP = /^\(.*\) => /;
|
@ -1,6 +1,6 @@
|
|||||||
/* eslint-disable no-case-declarations */
|
/* eslint-disable no-case-declarations */
|
||||||
|
import { SBType } from '@storybook/client-api';
|
||||||
import { TSType, TSSigType } from './types';
|
import { TSType, TSSigType } from './types';
|
||||||
import { SBType } from '../types';
|
|
||||||
|
|
||||||
const convertSig = (type: TSSigType) => {
|
const convertSig = (type: TSSigType) => {
|
||||||
switch (type.type) {
|
switch (type.type) {
|
@ -5,7 +5,7 @@ import { createSummaryValue } from '../utils';
|
|||||||
import { createFlowPropDef } from './flow/createPropDef';
|
import { createFlowPropDef } from './flow/createPropDef';
|
||||||
import { isDefaultValueBlacklisted } from './utils/defaultValue';
|
import { isDefaultValueBlacklisted } from './utils/defaultValue';
|
||||||
import { createTsPropDef } from './typeScript/createPropDef';
|
import { createTsPropDef } from './typeScript/createPropDef';
|
||||||
import { convert } from '../sbtypes';
|
import { convert } from '../convert';
|
||||||
|
|
||||||
export type PropDefFactory = (
|
export type PropDefFactory = (
|
||||||
propName: string,
|
propName: string,
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
interface SBBaseType {
|
|
||||||
required?: boolean;
|
|
||||||
raw?: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export type SBScalarType = SBBaseType & {
|
|
||||||
name: 'boolean' | 'string' | 'number' | 'function';
|
|
||||||
};
|
|
||||||
|
|
||||||
export type SBArrayType = SBBaseType & {
|
|
||||||
name: 'array';
|
|
||||||
value: SBType;
|
|
||||||
};
|
|
||||||
export type SBObjectType = SBBaseType & {
|
|
||||||
name: 'object';
|
|
||||||
value: Record<string, SBType>;
|
|
||||||
};
|
|
||||||
export type SBEnumType = SBBaseType & {
|
|
||||||
name: 'enum';
|
|
||||||
value: (string | number)[];
|
|
||||||
};
|
|
||||||
export type SBIntersectionType = SBBaseType & {
|
|
||||||
name: 'intersection';
|
|
||||||
value: SBType[];
|
|
||||||
};
|
|
||||||
export type SBUnionType = SBBaseType & {
|
|
||||||
name: 'union';
|
|
||||||
value: SBType[];
|
|
||||||
};
|
|
||||||
export type SBOtherType = SBBaseType & {
|
|
||||||
name: 'other';
|
|
||||||
value: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
export type SBType =
|
|
||||||
| SBScalarType
|
|
||||||
| SBEnumType
|
|
||||||
| SBArrayType
|
|
||||||
| SBObjectType
|
|
||||||
| SBIntersectionType
|
|
||||||
| SBUnionType
|
|
||||||
| SBOtherType;
|
|
@ -1,2 +0,0 @@
|
|||||||
export * from './convert';
|
|
||||||
export * from './types';
|
|
@ -1,12 +1,7 @@
|
|||||||
import mapValues from 'lodash/mapValues';
|
import mapValues from 'lodash/mapValues';
|
||||||
import { ArgTypesEnhancer } from './types';
|
import { SBType, ArgTypesEnhancer } from './types';
|
||||||
import { combineParameters } from './parameters';
|
import { combineParameters } from './parameters';
|
||||||
|
|
||||||
type SBType = {
|
|
||||||
name: string;
|
|
||||||
value?: string | SBType | SBType[] | Record<string, SBType>;
|
|
||||||
};
|
|
||||||
|
|
||||||
const inferType = (value?: any): SBType => {
|
const inferType = (value?: any): SBType => {
|
||||||
const type = typeof value;
|
const type = typeof value;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
|
@ -104,3 +104,46 @@ export type RenderContext = StoreItem & {
|
|||||||
showError: (error: { title: string; description: string }) => void;
|
showError: (error: { title: string; description: string }) => void;
|
||||||
showException: (err: Error) => void;
|
showException: (err: Error) => void;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
interface SBBaseType {
|
||||||
|
required?: boolean;
|
||||||
|
raw?: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export type SBScalarType = SBBaseType & {
|
||||||
|
name: 'boolean' | 'string' | 'number' | 'function';
|
||||||
|
};
|
||||||
|
|
||||||
|
export type SBArrayType = SBBaseType & {
|
||||||
|
name: 'array';
|
||||||
|
value: SBType;
|
||||||
|
};
|
||||||
|
export type SBObjectType = SBBaseType & {
|
||||||
|
name: 'object';
|
||||||
|
value: Record<string, SBType>;
|
||||||
|
};
|
||||||
|
export type SBEnumType = SBBaseType & {
|
||||||
|
name: 'enum';
|
||||||
|
value: (string | number)[];
|
||||||
|
};
|
||||||
|
export type SBIntersectionType = SBBaseType & {
|
||||||
|
name: 'intersection';
|
||||||
|
value: SBType[];
|
||||||
|
};
|
||||||
|
export type SBUnionType = SBBaseType & {
|
||||||
|
name: 'union';
|
||||||
|
value: SBType[];
|
||||||
|
};
|
||||||
|
export type SBOtherType = SBBaseType & {
|
||||||
|
name: 'other';
|
||||||
|
value: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
export type SBType =
|
||||||
|
| SBScalarType
|
||||||
|
| SBEnumType
|
||||||
|
| SBArrayType
|
||||||
|
| SBObjectType
|
||||||
|
| SBIntersectionType
|
||||||
|
| SBUnionType
|
||||||
|
| SBOtherType;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user