2020-08-26 01:57:08 +02:00
|
|
|
const observerMap = {
|
|
|
|
scroll: 'IntersectionObserver',
|
|
|
|
resize: 'ResizeObserver'
|
|
|
|
}
|
|
|
|
module.exports = {
|
|
|
|
meta: {
|
2022-11-10 11:43:16 +01:00
|
|
|
type: 'suggestion',
|
|
|
|
docs: {
|
|
|
|
description: 'disallow poorly performing event listeners',
|
|
|
|
url: require('../url')(module)
|
|
|
|
},
|
|
|
|
schema: []
|
2020-08-26 01:57:08 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
create(context) {
|
|
|
|
return {
|
2022-11-10 11:43:16 +01:00
|
|
|
['CallExpression[callee.property.name="addEventListener"]']: function (node) {
|
2020-08-26 01:57:08 +02:00
|
|
|
const [name] = node.arguments
|
|
|
|
if (name.type !== 'Literal') return
|
|
|
|
if (!(name.value in observerMap)) return
|
|
|
|
context.report({
|
|
|
|
node,
|
|
|
|
message: `Avoid using "${name.value}" event listener. Consider using ${observerMap[name.value]} instead`
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|