mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-26 11:07:48 +00:00 
			
		
		
		
	fix(storybook): use type-only imports in generated stories (#15654)
This commit is contained in:
		
							parent
							
								
									15685be4cc
								
							
						
					
					
						commit
						aa1cc2f817
					
				
					 1 changed files with 53 additions and 8 deletions
				
			
		|  | @ -17,8 +17,52 @@ interface SatisfiesExpression extends estree.BaseExpression { | |||
| 	reference: estree.Identifier; | ||||
| } | ||||
| 
 | ||||
| interface ImportDeclaration extends estree.ImportDeclaration { | ||||
| 	kind?: 'type'; | ||||
| } | ||||
| 
 | ||||
| const generator = { | ||||
| 	...GENERATOR, | ||||
| 	ImportDeclaration(node: ImportDeclaration, state: State) { | ||||
| 		state.write('import '); | ||||
| 		if (node.kind === 'type') state.write('type '); | ||||
| 		const { specifiers } = node; | ||||
| 		if (specifiers.length > 0) { | ||||
| 			let i = 0; | ||||
| 			for (; i < specifiers.length; i++) { | ||||
| 				if (i > 0) { | ||||
| 					state.write(', '); | ||||
| 				} | ||||
| 				const specifier = specifiers[i]!; | ||||
| 				if (specifier.type === 'ImportDefaultSpecifier') { | ||||
| 					state.write(specifier.local.name, specifier); | ||||
| 				} else if (specifier.type === 'ImportNamespaceSpecifier') { | ||||
| 					state.write(`* as ${specifier.local.name}`, specifier); | ||||
| 				} else { | ||||
| 					break; | ||||
| 				} | ||||
| 			} | ||||
| 			if (i < specifiers.length) { | ||||
| 				state.write('{'); | ||||
| 				for (; i < specifiers.length; i++) { | ||||
| 					const specifier = specifiers[i]! as estree.ImportSpecifier; | ||||
| 					const { name } = specifier.imported as estree.Identifier; | ||||
| 					state.write(name, specifier); | ||||
| 					if (name !== specifier.local.name) { | ||||
| 						state.write(` as ${specifier.local.name}`); | ||||
| 					} | ||||
| 					if (i < specifiers.length - 1) { | ||||
| 						state.write(', '); | ||||
| 					} | ||||
| 				} | ||||
| 				state.write('}'); | ||||
| 			} | ||||
| 			state.write(' from '); | ||||
| 		} | ||||
| 		this.Literal(node.source, state); | ||||
| 
 | ||||
| 		state.write(';'); | ||||
| 	}, | ||||
| 	SatisfiesExpression(node: SatisfiesExpression, state: State) { | ||||
| 		switch (node.expression.type) { | ||||
| 			case 'ArrowFunctionExpression': { | ||||
|  | @ -155,7 +199,8 @@ function toStories(component: string): Promise<string> { | |||
| 									/> as estree.ImportSpecifier, | ||||
| 								]), | ||||
| 					]} | ||||
| 				/> as estree.ImportDeclaration, | ||||
| 					kind={'type'} | ||||
| 				/> as ImportDeclaration, | ||||
| 				...(hasMsw | ||||
| 					? [ | ||||
| 							<import-declaration | ||||
|  | @ -165,7 +210,7 @@ function toStories(component: string): Promise<string> { | |||
| 										local={<identifier name='msw' /> as estree.Identifier} | ||||
| 									/> as estree.ImportNamespaceSpecifier, | ||||
| 								]} | ||||
| 							/> as estree.ImportDeclaration, | ||||
| 							/> as ImportDeclaration, | ||||
| 						] | ||||
| 					: []), | ||||
| 				...(hasImplStories | ||||
|  | @ -176,7 +221,7 @@ function toStories(component: string): Promise<string> { | |||
| 								specifiers={[ | ||||
| 									<import-default-specifier local={identifier} /> as estree.ImportDefaultSpecifier, | ||||
| 								]} | ||||
| 							/> as estree.ImportDeclaration, | ||||
| 							/> as ImportDeclaration, | ||||
| 						]), | ||||
| 				...(hasMetaStories | ||||
| 					? [ | ||||
|  | @ -187,7 +232,7 @@ function toStories(component: string): Promise<string> { | |||
| 										local={<identifier name='storiesMeta' /> as estree.Identifier} | ||||
| 									/> as estree.ImportNamespaceSpecifier, | ||||
| 								]} | ||||
| 							/> as estree.ImportDeclaration, | ||||
| 							/> as ImportDeclaration, | ||||
| 						] | ||||
| 					: []), | ||||
| 				<variable-declaration | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue