2020-08-25 23:57:08 +00:00
|
|
|
const svgElementAttributes = require('svg-element-attributes')
|
|
|
|
|
|
|
|
const attributeCalls = /^(get|has|set|remove)Attribute$/
|
|
|
|
const validAttributeName = /^[a-z][a-z0-9-]*$/
|
|
|
|
|
|
|
|
// these are common SVG attributes that *must* have the correct case to work
|
|
|
|
const camelCaseAttributes = Object.values(svgElementAttributes)
|
|
|
|
.reduce((all, elementAttrs) => all.concat(elementAttrs), [])
|
|
|
|
.filter(name => !validAttributeName.test(name))
|
|
|
|
|
|
|
|
const validSVGAttributeSet = new Set(camelCaseAttributes)
|
|
|
|
|
|
|
|
// lowercase variants of camelCase SVG attributes are probably an error
|
|
|
|
const invalidSVGAttributeSet = new Set(camelCaseAttributes.map(name => name.toLowerCase()))
|
|
|
|
|
|
|
|
function isValidAttribute(name) {
|
|
|
|
return validSVGAttributeSet.has(name) || (validAttributeName.test(name) && !invalidSVGAttributeSet.has(name))
|
|
|
|
}
|
|
|
|
|
2022-11-10 10:43:16 +00:00
|
|
|
module.exports = {
|
|
|
|
meta: {
|
|
|
|
type: 'problem',
|
|
|
|
docs: {
|
|
|
|
description: 'disallow wrong usage of attribute names',
|
|
|
|
url: require('../url')(module)
|
|
|
|
},
|
|
|
|
fixable: 'code',
|
|
|
|
schema: []
|
|
|
|
},
|
|
|
|
create(context) {
|
|
|
|
return {
|
|
|
|
CallExpression(node) {
|
|
|
|
if (!node.callee.property) return
|
|
|
|
|
|
|
|
const calleeName = node.callee.property.name
|
|
|
|
if (!attributeCalls.test(calleeName)) return
|
|
|
|
|
|
|
|
const attributeNameNode = node.arguments[0]
|
|
|
|
if (!attributeNameNode) return
|
|
|
|
|
|
|
|
if (!isValidAttribute(attributeNameNode.value)) {
|
|
|
|
context.report({
|
|
|
|
node: attributeNameNode,
|
|
|
|
message: 'Attributes should be lowercase and hyphen separated, or part of the SVG whitelist.',
|
|
|
|
fix(fixer) {
|
|
|
|
return fixer.replaceText(attributeNameNode, `'${attributeNameNode.value.toLowerCase()}'`)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2020-08-25 23:57:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|