91 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Vue
		
	
	
| import { createCache, extractStyle as extStyle, StyleProvider } from '../cssinjs';
 | |
| import * as antd from '../../components';
 | |
| import { renderToString } from 'vue/server-renderer';
 | |
| import type { CustomRender } from './interface';
 | |
| const blackList: string[] = [
 | |
|   'ConfigProvider',
 | |
|   'Grid',
 | |
|   'Tour',
 | |
|   'SelectOptGroup',
 | |
|   'SelectOption',
 | |
|   'MentionsOption',
 | |
|   'TreeNode',
 | |
|   'TreeSelectNode',
 | |
|   'LocaleProvider',
 | |
| ];
 | |
| 
 | |
| const pickerMap = {
 | |
|   MonthPicker: 'month',
 | |
|   WeekPicker: 'week',
 | |
|   QuarterPicker: 'quarter',
 | |
| };
 | |
| 
 | |
| const compChildNameMap = {
 | |
|   MenuDivider: 'Menu',
 | |
|   MenuItem: 'Menu',
 | |
|   MenuItemGroup: 'Menu',
 | |
|   SubMenu: 'Menu',
 | |
|   TableColumn: 'Table',
 | |
|   TableColumnGroup: 'Table',
 | |
|   TableSummary: 'Table',
 | |
|   TableSummaryRow: 'Table',
 | |
|   TableSummaryCell: 'Table',
 | |
|   TabPane: 'Tabs',
 | |
|   TimelineItem: 'Timeline',
 | |
| };
 | |
| 
 | |
| const defaultNode = () => (
 | |
|   <>
 | |
|     {Object.keys(antd)
 | |
|       .filter(name => !blackList.includes(name) && name[0] === name[0].toUpperCase())
 | |
|       .map(compName => {
 | |
|         const Comp = antd[compName];
 | |
|         if (compName === 'Dropdown') {
 | |
|           return (
 | |
|             <Comp key={compName} menu={{ items: [] }}>
 | |
|               <div />
 | |
|             </Comp>
 | |
|           );
 | |
|         }
 | |
|         if (compName === 'Anchor') {
 | |
|           return <Comp key={compName} items={[]} />;
 | |
|         }
 | |
|         if (compName in pickerMap) {
 | |
|           const Comp = antd['DatePicker'];
 | |
|           const type = pickerMap[compName];
 | |
|           return <Comp key={compName} picker={type} />;
 | |
|         }
 | |
|         if (compName in compChildNameMap) {
 | |
|           const ParentComp = antd[compChildNameMap[compName]];
 | |
|           return (
 | |
|             <ParentComp>
 | |
|               <Comp />
 | |
|             </ParentComp>
 | |
|           );
 | |
|         }
 | |
|         if (compName === 'QRCode' || compName === 'Segmented') {
 | |
|           return (
 | |
|             <Comp key={compName} value={''}>
 | |
|               <div />
 | |
|             </Comp>
 | |
|           );
 | |
|         }
 | |
|         return <Comp key={compName} />;
 | |
|       })}
 | |
|   </>
 | |
| );
 | |
| 
 | |
| export function extractStyle(customTheme?: CustomRender): string {
 | |
|   const cache = createCache();
 | |
|   renderToString(
 | |
|     <StyleProvider cache={cache}>
 | |
|       {customTheme ? customTheme(defaultNode()) : defaultNode()}
 | |
|     </StyleProvider>,
 | |
|   );
 | |
| 
 | |
|   // Grab style from cache
 | |
|   const styleText = extStyle(cache, true);
 | |
| 
 | |
|   return styleText;
 | |
| }
 |