mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-07 03:41:06 +08:00
Increasese max summary length and add a special max length for func
This commit is contained in:
parent
8561e7b95a
commit
c476ab6497
@ -22,6 +22,8 @@ import {
|
|||||||
InspectionArray,
|
InspectionArray,
|
||||||
} from '../lib/inspection';
|
} from '../lib/inspection';
|
||||||
|
|
||||||
|
const MAX_FUNC_LENGTH = 150;
|
||||||
|
|
||||||
enum PropTypesType {
|
enum PropTypesType {
|
||||||
CUSTOM = 'custom',
|
CUSTOM = 'custom',
|
||||||
ANY = 'any',
|
ANY = 'any',
|
||||||
@ -146,7 +148,7 @@ function generateTypeFromString(value: string, originalTypeName: string): TypeDe
|
|||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
short = getCaptionForInspectionType(type);
|
short = getCaptionForInspectionType(type);
|
||||||
compact = value;
|
compact = splitIntoLines(value).length === 1 ? value : null;
|
||||||
full = value;
|
full = value;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -384,7 +386,7 @@ export function createType(extractedProp: ExtractedProp): PropType {
|
|||||||
let summary = short;
|
let summary = short;
|
||||||
const detail = full;
|
const detail = full;
|
||||||
|
|
||||||
if (!isTooLongForTypeSummary(full)) {
|
if (full.length < MAX_FUNC_LENGTH) {
|
||||||
summary = full;
|
summary = full;
|
||||||
} else if (!isNil(compact)) {
|
} else if (!isNil(compact)) {
|
||||||
summary = compact;
|
summary = compact;
|
||||||
|
@ -161,7 +161,7 @@ describe('enhancePropTypesProp', () => {
|
|||||||
type: {
|
type: {
|
||||||
name: 'custom',
|
name: 'custom',
|
||||||
raw:
|
raw:
|
||||||
'<div>Hello world from Montreal, Quebec, Canada!!!!!!!!!!!!!!!!!!!!!!!!!!!!!</div>',
|
'<div>Hello world from Montreal, Quebec, Canada!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!</div>',
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -170,7 +170,7 @@ describe('enhancePropTypesProp', () => {
|
|||||||
expect(type.summary).toBe('element');
|
expect(type.summary).toBe('element');
|
||||||
|
|
||||||
const expectedDetail =
|
const expectedDetail =
|
||||||
'<div>Hello world from Montreal, Quebec, Canada!!!!!!!!!!!!!!!!!!!!!!!!!!!!!</div>';
|
'<div>Hello world from Montreal, Quebec, Canada!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!</div>';
|
||||||
|
|
||||||
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
||||||
});
|
});
|
||||||
@ -303,7 +303,15 @@ describe('enhancePropTypesProp', () => {
|
|||||||
name: 'string',
|
name: 'string',
|
||||||
required: false,
|
required: false,
|
||||||
},
|
},
|
||||||
anotherAnother: {
|
another2: {
|
||||||
|
name: 'string',
|
||||||
|
required: false,
|
||||||
|
},
|
||||||
|
another3: {
|
||||||
|
name: 'string',
|
||||||
|
required: false,
|
||||||
|
},
|
||||||
|
another4: {
|
||||||
name: 'string',
|
name: 'string',
|
||||||
required: false,
|
required: false,
|
||||||
},
|
},
|
||||||
@ -319,7 +327,9 @@ describe('enhancePropTypesProp', () => {
|
|||||||
foo: string,
|
foo: string,
|
||||||
bar: string,
|
bar: string,
|
||||||
another: string,
|
another: string,
|
||||||
anotherAnother: string
|
another2: string,
|
||||||
|
another3: string,
|
||||||
|
another4: string
|
||||||
}`;
|
}`;
|
||||||
|
|
||||||
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
||||||
@ -382,7 +392,8 @@ describe('enhancePropTypesProp', () => {
|
|||||||
computed: true,
|
computed: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: '{\n foo: PropTypes.string,\n bar: PropTypes.string,\n}',
|
value:
|
||||||
|
'{\n foo: PropTypes.string,\n bar: PropTypes.string,\n hey: PropTypes.string,\n ho: PropTypes.string,\n}',
|
||||||
computed: true,
|
computed: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@ -398,7 +409,9 @@ describe('enhancePropTypesProp', () => {
|
|||||||
value: string
|
value: string
|
||||||
} | {
|
} | {
|
||||||
foo: string,
|
foo: string,
|
||||||
bar: string
|
bar: string,
|
||||||
|
hey: string,
|
||||||
|
ho: string
|
||||||
}`;
|
}`;
|
||||||
|
|
||||||
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
||||||
@ -799,7 +812,7 @@ describe('enhancePropTypesProp', () => {
|
|||||||
value: {
|
value: {
|
||||||
name: 'custom',
|
name: 'custom',
|
||||||
raw:
|
raw:
|
||||||
'{\n text: PropTypes.string.isRequired,\n value: PropTypes.string.isRequired,\n another: PropTypes.string.isRequired,\n anotherAnother: PropTypes.string.isRequired,\n}',
|
'{\n text: PropTypes.string.isRequired,\n value: PropTypes.string.isRequired,\n another: PropTypes.string.isRequired,\n another2: PropTypes.string.isRequired,\n another3: PropTypes.string.isRequired,\n another4: PropTypes.string.isRequired,\n}',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
@ -812,7 +825,9 @@ describe('enhancePropTypesProp', () => {
|
|||||||
text: string,
|
text: string,
|
||||||
value: string,
|
value: string,
|
||||||
another: string,
|
another: string,
|
||||||
anotherAnother: string
|
another2: string,
|
||||||
|
another3: string,
|
||||||
|
another4: string
|
||||||
}]`;
|
}]`;
|
||||||
|
|
||||||
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
||||||
@ -875,7 +890,15 @@ describe('enhancePropTypesProp', () => {
|
|||||||
name: 'string',
|
name: 'string',
|
||||||
required: false,
|
required: false,
|
||||||
},
|
},
|
||||||
anotherAnother: {
|
another2: {
|
||||||
|
name: 'string',
|
||||||
|
required: false,
|
||||||
|
},
|
||||||
|
another3: {
|
||||||
|
name: 'string',
|
||||||
|
required: false,
|
||||||
|
},
|
||||||
|
another4: {
|
||||||
name: 'string',
|
name: 'string',
|
||||||
required: false,
|
required: false,
|
||||||
},
|
},
|
||||||
@ -892,7 +915,9 @@ describe('enhancePropTypesProp', () => {
|
|||||||
foo: string,
|
foo: string,
|
||||||
bar: string,
|
bar: string,
|
||||||
another: string,
|
another: string,
|
||||||
anotherAnother: string
|
another2: string,
|
||||||
|
another3: string,
|
||||||
|
another4: string
|
||||||
}]`;
|
}]`;
|
||||||
|
|
||||||
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
expect(type.detail.replace(/\s/g, '')).toBe(expectedDetail.replace(/\s/g, ''));
|
||||||
|
@ -98,7 +98,7 @@ describe('type', () => {
|
|||||||
name: 'signature',
|
name: 'signature',
|
||||||
type: 'object',
|
type: 'object',
|
||||||
raw:
|
raw:
|
||||||
'{ (x: string): void, prop1: string, prop2: string, prop3: string, prop4: string, prop5: string }',
|
'{ (x: string): void, prop1: string, prop2: string, prop3: string, prop4: string, prop5: string, prop6: string, prop7: string, prop8: string }',
|
||||||
signature: {
|
signature: {
|
||||||
properties: [
|
properties: [
|
||||||
{
|
{
|
||||||
@ -136,6 +136,34 @@ describe('type', () => {
|
|||||||
required: true,
|
required: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
key: 'prop5',
|
||||||
|
value: {
|
||||||
|
name: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'prop6',
|
||||||
|
value: {
|
||||||
|
name: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'prop7',
|
||||||
|
value: {
|
||||||
|
name: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'prop8',
|
||||||
|
value: {
|
||||||
|
name: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
],
|
],
|
||||||
constructor: {
|
constructor: {
|
||||||
name: 'signature',
|
name: 'signature',
|
||||||
@ -163,7 +191,7 @@ describe('type', () => {
|
|||||||
|
|
||||||
expect(type.summary).toBe('object');
|
expect(type.summary).toBe('object');
|
||||||
expect(type.detail).toBe(
|
expect(type.detail).toBe(
|
||||||
'{ (x: string): void, prop1: string, prop2: string, prop3: string, prop4: string, prop5: string }'
|
'{ (x: string): void, prop1: string, prop2: string, prop3: string, prop4: string, prop5: string, prop6: string, prop7: string, prop8: string }'
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { PropSummaryValue } from '@storybook/components';
|
import { PropSummaryValue } from '@storybook/components';
|
||||||
|
|
||||||
export const MAX_TYPE_SUMMARY_LENGTH = 70;
|
export const MAX_TYPE_SUMMARY_LENGTH = 90;
|
||||||
export const MAX_DEFALUT_VALUE_SUMMARY_LENGTH = 50;
|
export const MAX_DEFALUT_VALUE_SUMMARY_LENGTH = 50;
|
||||||
|
|
||||||
export function isTooLongForTypeSummary(value: string): boolean {
|
export function isTooLongForTypeSummary(value: string): boolean {
|
||||||
|
@ -129,6 +129,17 @@ PropTypesProps.propTypes = {
|
|||||||
* @returns {ComplexObject} - Returns a complex object.
|
* @returns {ComplexObject} - Returns a complex object.
|
||||||
*/
|
*/
|
||||||
funcWithJsDoc: PropTypes.func,
|
funcWithJsDoc: PropTypes.func,
|
||||||
|
/**
|
||||||
|
* @param {string} foo - A foo value.
|
||||||
|
* @param {number} bar - A bar value.
|
||||||
|
* @param {number} bar1 - A bar value.
|
||||||
|
* @param {number} bar2 - A bar value.
|
||||||
|
* @param {number} bar3 - A bar value.
|
||||||
|
* @param {number} bar4 - A bar value.
|
||||||
|
* @param {number} bar5 - A bar value.
|
||||||
|
* @returns {ComplexObject} - Returns a complex object.
|
||||||
|
*/
|
||||||
|
semiLongFuncWithJsDoc: PropTypes.func,
|
||||||
/**
|
/**
|
||||||
* @param {string} foo - A foo value.
|
* @param {string} foo - A foo value.
|
||||||
* @param {number} bar - A bar value.
|
* @param {number} bar - A bar value.
|
||||||
@ -138,6 +149,10 @@ PropTypesProps.propTypes = {
|
|||||||
* @param {number} bar4 - A bar value.
|
* @param {number} bar4 - A bar value.
|
||||||
* @param {number} bar5 - A bar value.
|
* @param {number} bar5 - A bar value.
|
||||||
* @param {number} bar6 - A bar value.
|
* @param {number} bar6 - A bar value.
|
||||||
|
* @param {number} bar7 - A bar value.
|
||||||
|
* @param {number} bar8 - A bar value.
|
||||||
|
* @param {number} bar9 - A bar value.
|
||||||
|
* @param {number} bar10 - A bar value.
|
||||||
* @returns {ComplexObject} - Returns a complex object.
|
* @returns {ComplexObject} - Returns a complex object.
|
||||||
*/
|
*/
|
||||||
veryLongFuncWithJsDoc: PropTypes.func,
|
veryLongFuncWithJsDoc: PropTypes.func,
|
||||||
@ -314,6 +329,16 @@ PropTypesProps.propTypes = {
|
|||||||
shapeShort: PropTypes.shape({
|
shapeShort: PropTypes.shape({
|
||||||
foo: string,
|
foo: string,
|
||||||
}),
|
}),
|
||||||
|
shapeLong: PropTypes.shape({
|
||||||
|
foo: string,
|
||||||
|
prop1: string,
|
||||||
|
prop2: string,
|
||||||
|
prop3: string,
|
||||||
|
prop4: string,
|
||||||
|
prop5: string,
|
||||||
|
prop6: string,
|
||||||
|
prop7: string,
|
||||||
|
}),
|
||||||
/**
|
/**
|
||||||
* propType for shape with nested arrayOf
|
* propType for shape with nested arrayOf
|
||||||
*
|
*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user