You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

62 lines
1.4 KiB

/**
* @fileoverview Prevents duplication of field names.
* @author Armano
*/
'use strict'
const utils = require('../utils')
/**
* @typedef {import('../utils').GroupName} GroupName
*/
/** @type {GroupName[]} */
const GROUP_NAMES = ['props', 'computed', 'data', 'methods', 'setup']
module.exports = {
meta: {
type: 'problem',
docs: {
description: 'disallow duplication of field names',
categories: ['vue3-essential', 'essential'],
url: 'https://eslint.vuejs.org/rules/no-dupe-keys.html'
},
fixable: null, // or "code" or "whitespace"
schema: [
{
type: 'object',
properties: {
groups: {
type: 'array'
}
},
additionalProperties: false
}
]
},
/** @param {RuleContext} context */
create(context) {
const options = context.options[0] || {}
const groups = new Set([...GROUP_NAMES, ...(options.groups || [])])
return utils.executeOnVue(context, (obj) => {
/** @type {Set<string>} */
const usedNames = new Set()
const properties = utils.iterateProperties(obj, groups)
for (const o of properties) {
if (usedNames.has(o.name)) {
context.report({
node: o.node,
message: "Duplicated key '{{name}}'.",
data: {
name: o.name
}
})
}
usedNames.add(o.name)
}
})
}
}