UNPKG

1.22 kBJavaScriptView Raw
1/**
2 * use `angular.isNumber` instead of `typeof` comparisons
3 *
4 * You should use the angular.isNumber method instead of the default JavaScript implementation (typeof 3 === "[object Number]").
5 *
6 * @version 0.1.0
7 * @category angularWrapper
8 * @sinceAngularVersion 1.x
9 */
10'use strict';
11
12var utils = require('./utils/utils');
13
14module.exports = {
15 meta: {
16 schema: []
17 },
18 create: function(context) {
19 function recordError(node, origin) {
20 if (node.type === 'Literal' && (node.value === 'number' || node.value === '[object Number]')) {
21 context.report(origin, 'You should use the angular.isNumber method', {});
22 }
23 }
24
25
26 return {
27
28 BinaryExpression: function(node) {
29 if (node.operator === '===' || node.operator === '!==') {
30 if (utils.isTypeOfStatement(node.left) || utils.isToStringStatement(node.left)) {
31 recordError(node.right, node);
32 } else if (utils.isTypeOfStatement(node.right) || utils.isToStringStatement(node.right)) {
33 recordError(node.left, node);
34 }
35 }
36 }
37 };
38 }
39};