UNPKG

eslint-plugin-ember

Version:
74 lines (62 loc) 2.05 kB
'use strict'; const ember = require('../utils/ember'); const utils = require('../utils/utils'); //---------------------------------------------- // Don’t use .on() for component lifecycle events. //---------------------------------------------- module.exports = { meta: { docs: { description: 'Prevents usage of `on` to call lifecycle hooks in components', category: 'Best Practices', recommended: true, url: 'https://github.com/ember-cli/eslint-plugin-ember/tree/master/docs/rules/no-on-calls-in-components.md' }, fixable: null, // or "code" or "whitespace" }, create(context) { const message = 'Don\'t use .on() for component lifecycle events.'; const lifecycleHooks = ['init', 'didUpdateAttrs', 'didReceiveAttrs', 'willUpdate', 'willRender', 'didInsertElement', 'didUpdate', 'didRender', 'willDestroyElement', 'willClearRender', 'didDestroyElement' ]; const filePath = context.getFilename(); const isOnCall = function (node) { const value = node.value; const callee = value.callee; const args = utils.parseArgs(value); return utils.isCallExpression(value) && lifecycleHooks.indexOf(args[0]) > -1 && ( (utils.isIdentifier(callee) && callee.name === 'on') || ( utils.isMemberExpression(callee) && utils.isIdentifier(callee.object) && callee.object.name === 'Ember' && utils.isIdentifier(callee.property) && callee.property.name === 'on' ) ); }; const report = function (node) { context.report(node, message); }; return { CallExpression(node) { if (!ember.isEmberComponent(node, filePath)) return; const propertiesWithOnCalls = ember.getModuleProperties(node).filter(isOnCall); if (propertiesWithOnCalls.length) { propertiesWithOnCalls.forEach((property) => { report(property.value); }); } }, }; } };