UNPKG

@refly/arco-vite-plugin-react

Version:

For Vite build, load Arco Design styles on demand

115 lines 4.86 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.transformJsFiles = exports.emptyTransformJsFiles = exports.transformCssFile = void 0; const parser = __importStar(require("@babel/parser")); const types = __importStar(require("@babel/types")); const traverse_1 = __importDefault(require("@babel/traverse")); const generator_1 = __importDefault(require("@babel/generator")); const helper_module_imports_1 = require("@babel/helper-module-imports"); const config_1 = require("./config"); const utils_1 = require("./utils"); function transformCssFile({ id, theme }) { if (theme) { const matches = (0, utils_1.pathMatch)(id, config_1.fullCssMatchers); if (matches) { const themeCode = (0, utils_1.readFileStrSync)(`${theme}/css/arco.css`); if (themeCode !== false) { return { code: themeCode, map: null, }; } } } return undefined; } exports.transformCssFile = transformCssFile; function emptyTransformJsFiles({ id, code, isDevelopment, sourceMaps, }) { if (!/\.(js|jsx|ts|tsx)$/.test(id)) { return undefined; } if (isDevelopment) { return { code, map: null, }; } const ast = parser.parse(code, { sourceType: 'module', plugins: ['jsx', 'classProperties', 'classPrivateProperties', 'classPrivateMethods'], }); return (0, generator_1.default)(ast, { sourceMaps, sourceFileName: id }); } exports.emptyTransformJsFiles = emptyTransformJsFiles; function transformJsFiles({ code, id, theme, style, isDevelopment, sourceMaps, }) { if (style === false || !/\.(js|jsx|ts|tsx)$/.test(id)) { return undefined; } const fullStyleFile = `${config_1.libraryName}/dist/css/${style === 'css' ? 'arco.css' : 'index.less'}`; // edge case && dev faster if (isDevelopment) { return { code: `${code}\nimport '${fullStyleFile}';`, map: null, }; } const ast = parser.parse(code, { sourceType: 'module', plugins: ['jsx', 'classProperties', 'classPrivateProperties', 'classPrivateMethods'], }); (0, traverse_1.default)(ast, { enter(path) { const { node } = path; // import { Button, InputNumber, TimeLine } from '@arco-design/web-react' if (types.isImportDeclaration(node)) { const { value } = node.source; if (value === config_1.libraryName) { // lazy load (css files don't support lazy load with theme) if (style !== 'css' || !theme) { node.specifiers.forEach((spec) => { if (types.isImportSpecifier(spec)) { const importedName = spec.imported.name; const stylePath = `${config_1.libraryName}/es/${importedName}/style/${style === 'css' ? 'css.js' : 'index.js'}`; if ((0, utils_1.isModExist)(stylePath)) (0, helper_module_imports_1.addSideEffect)(path, stylePath); } }); } // import full less/css bundle file else { (0, helper_module_imports_1.addSideEffect)(path, fullStyleFile); } } } }, }); return (0, generator_1.default)(ast, { sourceMaps, sourceFileName: id }); } exports.transformJsFiles = transformJsFiles; //# sourceMappingURL=transform.js.map