uni-ticket-system/node_modules/@dcloudio/uni-app-vite/dist/nvue/plugins/appCss.js
2023-12-05 10:11:10 +08:00

133 lines
4.8 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.createRollupError = exports.uniAppCssPlugin = exports.APP_CSS_JS = void 0;
const fs_extra_1 = __importDefault(require("fs-extra"));
const uni_cli_shared_1 = require("@dcloudio/uni-cli-shared");
exports.APP_CSS_JS = './app.css.js';
function uniAppCssPlugin() {
const inputDir = process.env.UNI_INPUT_DIR;
const appVueFilename = (0, uni_cli_shared_1.resolveAppVue)(inputDir);
return {
name: 'uni:app-nvue-app-style',
// 提前到 @vite/plugin-vue 之前执行,因为在 nvue 编译时,仅 import 了 App.vue 的 styles这样导致 descriptor
// 一直使用的是上一次的plugin-vue 会在 transformMain 中生成新的 descriptor故不再交由 plugin-vue 来 load
// 而是当前插件直接处理
enforce: 'pre',
resolveId(id) {
if (id === exports.APP_CSS_JS) {
return exports.APP_CSS_JS;
}
},
load(id) {
if (id === exports.APP_CSS_JS) {
return genAppStylesCode(appVueFilename, this);
}
const { filename, query } = (0, uni_cli_shared_1.parseVueRequest)(id);
if (query.vue && query.type === 'style' && appVueFilename === filename) {
const descriptor = createAppDescriptor(filename, this);
const block = descriptor.styles[query.index];
if (block) {
return {
code: block.content,
map: '',
};
}
}
},
};
}
exports.uniAppCssPlugin = uniAppCssPlugin;
const defaultAppStylesCode = `exports.styles = []`;
async function genAppStylesCode(filename, pluginContext) {
pluginContext.addWatchFile(filename);
const descriptor = createAppDescriptor(filename, pluginContext);
if (!descriptor.styles.length) {
return defaultAppStylesCode;
}
let stylesCode = ``;
const styleVars = [];
for (let i = 0; i < descriptor.styles.length; i++) {
const style = descriptor.styles[i];
const src = style.src || descriptor.filename;
const attrsQuery = attrsToQuery(style.attrs, 'css');
const srcQuery = style.src ? `&src=${descriptor.id}` : ``;
const query = `?vue&type=style&index=${i}${srcQuery}&inline`;
const styleRequest = src + query + attrsQuery;
stylesCode += `\nimport _style_${i} from ${JSON.stringify(styleRequest)}`;
styleVars.push(`_style_${i}`);
}
return `
${stylesCode}
exports.styles = [${styleVars.join(',')}]
`;
}
function readAppCode(filename) {
if (!fs_extra_1.default.existsSync(filename)) {
return ``;
}
const source = fs_extra_1.default.readFileSync(filename, 'utf8');
if (source.includes('#endif')) {
return (0, uni_cli_shared_1.preNVueJs)((0, uni_cli_shared_1.preNVueHtml)(source));
}
return source;
}
let appDescriptor;
function createAppDescriptor(filename, pluginContext) {
const source = readAppCode(filename);
const id = (0, uni_cli_shared_1.hash)(source);
if (!appDescriptor || appDescriptor.id !== id) {
const { descriptor, errors } = require('@vue/compiler-sfc').parse(source, {
filename,
});
descriptor.id = id;
if (errors.length) {
errors.forEach((error) => pluginContext.error(createRollupError(filename, error)));
}
appDescriptor = descriptor;
}
return appDescriptor;
}
function createRollupError(id, error) {
const { message, name, stack } = error;
const rollupError = {
id,
plugin: 'vue',
message,
name,
stack,
};
if ('code' in error && error.loc) {
rollupError.loc = {
file: id,
line: error.loc.start.line,
column: error.loc.start.column,
};
}
return rollupError;
}
exports.createRollupError = createRollupError;
// these are built-in query parameters so should be ignored
// if the user happen to add them as attrs
const ignoreList = ['id', 'index', 'src', 'type', 'lang', 'module'];
function attrsToQuery(attrs, langFallback, forceLangFallback = false) {
let query = ``;
for (const name in attrs) {
const value = attrs[name];
if (!ignoreList.includes(name)) {
query += `&${encodeURIComponent(name)}${value ? `=${encodeURIComponent(value)}` : ``}`;
}
}
if (langFallback || attrs.lang) {
query +=
`lang` in attrs
? forceLangFallback
? `&lang.${langFallback}`
: `&lang.${attrs.lang}`
: `&lang.${langFallback}`;
}
return query;
}