mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-02 03:59:01 +08:00
37 lines
1.1 KiB
TypeScript
37 lines
1.1 KiB
TypeScript
|
import { globSync } from 'glob';
|
||
|
import path from 'path';
|
||
|
import React from 'react';
|
||
|
|
||
|
type StyleFn = (prefix?: string) => void;
|
||
|
|
||
|
export const styleFiles = globSync(
|
||
|
path.join(
|
||
|
process.cwd(),
|
||
|
'components/!(version|config-provider|icon|auto-complete|col|row|time-picker)/style/index.?(ts|tsx)',
|
||
|
),
|
||
|
);
|
||
|
|
||
|
export const generateCssinjs = ({ key, beforeRender, render }: any) => {
|
||
|
styleFiles.forEach(async (file) => {
|
||
|
const pathArr = file.split('/');
|
||
|
const styleIndex = pathArr.lastIndexOf('style');
|
||
|
const componentName = pathArr[styleIndex - 1];
|
||
|
let useStyle: StyleFn = () => {};
|
||
|
if (file.includes('grid')) {
|
||
|
const { useColStyle, useRowStyle } = await import(file);
|
||
|
useStyle = (prefixCls: string) => {
|
||
|
useRowStyle(prefixCls);
|
||
|
useColStyle(prefixCls);
|
||
|
};
|
||
|
} else {
|
||
|
useStyle = (await import(file)).default;
|
||
|
}
|
||
|
const Component: React.FC = () => {
|
||
|
useStyle(`${key}-${componentName}`);
|
||
|
return React.createElement('div');
|
||
|
};
|
||
|
beforeRender?.(componentName);
|
||
|
render?.(Component);
|
||
|
});
|
||
|
};
|