UNPKG

eslint-plugin-vue

Version:

Official ESLint plugin for Vue.js

119 lines (116 loc) 3.66 kB
'use strict'; const require_rolldown_runtime = require('../_virtual/rolldown_runtime.js'); const require_index = require('../utils/index.js'); const require_regexp$1 = require('../utils/regexp.js'); //#region lib/rules/no-restricted-class.js /** * @fileoverview Forbid certain classes from being used * @author Tao Bojlen */ var require_no_restricted_class = /* @__PURE__ */ require_rolldown_runtime.__commonJSMin(((exports, module) => { const utils = require_index.default; const regexp = require_regexp$1.default; /** * Report a forbidden class * @param {string} className * @param {*} node * @param {RuleContext} context * @param {(name: string) => boolean} isForbiddenClass */ const reportForbiddenClass = (className, node, context, isForbiddenClass) => { if (isForbiddenClass(className)) { const loc = node.value ? node.value.loc : node.loc; context.report({ node, loc, messageId: "forbiddenClass", data: { class: className } }); } }; /** * @param {Expression} node * @param {boolean} [textOnly] * @returns {IterableIterator<{ className:string, reportNode: ESNode }>} */ function* extractClassNames(node, textOnly) { if (node.type === "Literal") { yield* `${node.value}`.split(/\s+/).map((className) => ({ className, reportNode: node })); return; } if (node.type === "TemplateLiteral") { for (const templateElement of node.quasis) yield* templateElement.value.cooked.split(/\s+/).map((className) => ({ className, reportNode: templateElement })); for (const expr of node.expressions) yield* extractClassNames(expr, true); return; } if (node.type === "BinaryExpression") { if (node.operator !== "+") return; yield* extractClassNames(node.left, true); yield* extractClassNames(node.right, true); return; } if (textOnly) return; if (node.type === "ObjectExpression") { for (const prop of node.properties) { if (prop.type !== "Property") continue; const classNames = utils.getStaticPropertyName(prop); if (!classNames) continue; yield* classNames.split(/\s+/).map((className) => ({ className, reportNode: prop.key })); } return; } if (node.type === "ArrayExpression") { for (const element of node.elements) { if (element == null) continue; if (element.type === "SpreadElement") continue; yield* extractClassNames(element); } return; } } module.exports = { meta: { type: "problem", docs: { description: "disallow specific classes in Vue components", url: "https://eslint.vuejs.org/rules/no-restricted-class.html", categories: void 0 }, fixable: null, schema: { type: "array", items: { type: "string" } }, messages: { forbiddenClass: "'{{class}}' class is not allowed." } }, create(context) { const { options = [] } = context; const isForbiddenClass = regexp.toRegExpGroupMatcher(options); return utils.defineTemplateBodyVisitor(context, { "VAttribute[directive=false][key.name=\"class\"][value!=null]"(node) { for (const className of node.value.value.split(/\s+/)) reportForbiddenClass(className, node, context, isForbiddenClass); }, "VAttribute[directive=true][key.name.name='bind'][key.argument.name='class'] > VExpressionContainer.value"(node) { if (!node.expression) return; for (const { className, reportNode } of extractClassNames(node.expression)) reportForbiddenClass(className, reportNode, context, isForbiddenClass); } }); } }; })); //#endregion Object.defineProperty(exports, 'default', { enumerable: true, get: function () { return require_no_restricted_class(); } });