@refly/arco-vite-plugin-react
Version:
For Vite build, load Arco Design styles on demand
115 lines • 4.86 kB
JavaScript
;
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