/* eslint-disable import/no-unresolved,no-console,global-require,import/no-dynamic-require */ const chalk = require('chalk'); const React = require('react'); const ReactDOMServer = require('react-dom/server'); const glob = require('glob'); const path = require('path'); const { StyleProvider, logicalPropertiesLinter, legacyNotSelectorLinter, parentSelectorLinter, } = require('@ant-design/cssinjs'); console.log(chalk.green(`🔥 Checking CSS-in-JS...`)); let errorCount = 0; const originError = console.error; console.error = (msg) => { if (msg.includes('Warning: [Ant Design CSS-in-JS]')) { errorCount += 1; console.log(chalk.red(`❌ `), msg.slice(msg.indexOf('Error in')).replace(/\s+/g, ' ')); } else { originError(msg); } }; const EmptyElement = React.createElement('div'); const styleFiles = glob.sync( path.join( process.cwd(), 'components/!(version|config-provider|icon|locale-provider|auto-complete|col|row|time-picker|)/style/index.?(ts|tsx)', ), ); styleFiles.forEach((file) => { let useStyle = () => {}; if (file.includes('grid')) { const { useColStyle, useRowStyle } = require(file); useStyle = () => { useRowStyle(); useColStyle(); }; } else { useStyle = require(file).default; } const Component = () => { useStyle('check'); return EmptyElement; }; ReactDOMServer.renderToString( React.createElement( StyleProvider, { linters: [logicalPropertiesLinter, legacyNotSelectorLinter, parentSelectorLinter] }, React.createElement(Component), ), ); }); if (errorCount > 0) { console.log(chalk.red(`❌ CSS-in-JS check failed with ${errorCount} errors.`)); process.exit(1); } else { console.log(chalk.green(`✅ CSS-in-JS check passed.`)); }