2020-08-25 23:57:08 +00:00
|
|
|
const passiveEventListenerNames = new Set(['touchstart', 'touchmove', 'wheel', 'mousewheel'])
|
|
|
|
|
|
|
|
const propIsPassiveTrue = prop => prop.key && prop.key.name === 'passive' && prop.value && prop.value.value === true
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
meta: {
|
2022-11-10 10:43:16 +00:00
|
|
|
type: 'suggestion',
|
|
|
|
docs: {
|
|
|
|
description: 'enforce marking high frequency event handlers as passive',
|
|
|
|
url: require('../url')(module)
|
|
|
|
},
|
|
|
|
schema: []
|
2020-08-25 23:57:08 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
create(context) {
|
|
|
|
return {
|
2022-11-10 10:43:16 +00:00
|
|
|
['CallExpression[callee.property.name="addEventListener"]']: function (node) {
|
2020-08-25 23:57:08 +00:00
|
|
|
const [name, listener, options] = node.arguments
|
|
|
|
if (!listener) return
|
|
|
|
if (name.type !== 'Literal') return
|
|
|
|
if (!passiveEventListenerNames.has(name.value)) return
|
|
|
|
if (options && options.type === 'ObjectExpression' && options.properties.some(propIsPassiveTrue)) return
|
2022-11-10 10:43:16 +00:00
|
|
|
context.report({node, message: `High Frequency Events like "${name.value}" should be \`passive: true\``})
|
2020-08-25 23:57:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|