Files
routie/frontend/node_modules/eslint-plugin-vue/dist/rules/no-import-compiler-macros.js
T

83 lines
2.6 KiB
JavaScript

'use strict';
const require_runtime = require('../_virtual/_rolldown/runtime.js');
const require_index = require('../utils/index.js');
//#region lib/rules/no-import-compiler-macros.js
/**
* @author Wayne Zhang
* See LICENSE file in root directory for full license.
*/
var require_no_import_compiler_macros = /* @__PURE__ */ require_runtime.__commonJSMin(((exports, module) => {
const utils = require_index.default;
const COMPILER_MACROS = new Set([
"defineProps",
"defineEmits",
"defineExpose",
"withDefaults",
"defineModel",
"defineOptions",
"defineSlots"
]);
const VUE_MODULES = new Set([
"@vue/runtime-core",
"@vue/runtime-dom",
"vue"
]);
/**
* @param {Token} node
*/
function isComma(node) {
return node.type === "Punctuator" && node.value === ",";
}
module.exports = {
meta: {
type: "problem",
docs: {
description: "disallow importing Vue compiler macros",
categories: void 0,
url: "https://eslint.vuejs.org/rules/no-import-compiler-macros.html"
},
fixable: "code",
schema: [],
messages: {
noImportCompilerMacros: "'{{name}}' is a compiler macro and doesn't need to be imported.",
onlyValidInScriptSetup: "'{{name}}' is a compiler macro and can only be used inside <script setup>."
}
},
create(context) {
const sourceCode = context.sourceCode;
return { ImportDeclaration(node) {
if (node.specifiers.length === 0 || !VUE_MODULES.has(node.source.value)) return;
for (const specifier of node.specifiers) {
if (specifier.type !== "ImportSpecifier" || !COMPILER_MACROS.has(specifier.imported.name)) continue;
context.report({
node: specifier,
messageId: utils.isScriptSetup(context) ? "noImportCompilerMacros" : "onlyValidInScriptSetup",
data: { name: specifier.imported.name },
fix: (fixer) => {
const isOnlySpecifier = node.specifiers.length === 1;
const isLastSpecifier = specifier === node.specifiers.at(-1);
if (isOnlySpecifier) return fixer.remove(node);
else if (isLastSpecifier) {
const precedingComma = sourceCode.getTokenBefore(specifier, isComma);
return fixer.removeRange([precedingComma ? precedingComma.range[0] : specifier.range[0], specifier.range[1]]);
} else {
const subsequentComma = sourceCode.getTokenAfter(specifier, isComma);
return fixer.removeRange([specifier.range[0], subsequentComma ? subsequentComma.range[1] : specifier.range[1]]);
}
}
});
}
} };
}
};
}));
//#endregion
Object.defineProperty(exports, 'default', {
enumerable: true,
get: function () {
return require_no_import_compiler_macros();
}
});