eslint-plugin-cvsdk-rules 17.1.0-alpha.3 → 18.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/index.js +3 -3
- package/build/index.js.map +1 -1
- package/build/rules/no-device-type-imports.js +7 -7
- package/build/rules/no-device-type-imports.js.map +1 -1
- package/build/rules/no-object-from-entries.js +5 -5
- package/build/rules/no-object-from-entries.js.map +1 -1
- package/build/rules/prefer-makeRequest-over-fetch.js +5 -5
- package/build/rules/prefer-makeRequest-over-fetch.js.map +1 -1
- package/build/rules/prefer-no-lodash-clone-deep.js +6 -6
- package/build/rules/prefer-no-lodash-clone-deep.js.map +1 -1
- package/build/rules/prefer-private-exposables.js +9 -10
- package/build/rules/prefer-private-exposables.js.map +1 -1
- package/build/rules/prefer-self-over-window.js +6 -6
- package/build/rules/prefer-self-over-window.js.map +1 -1
- package/build/rules/prefer-txml-over-domparser.js +6 -6
- package/build/rules/prefer-txml-over-domparser.js.map +1 -1
- package/package.json +1 -1
- package/src/rules/prefer-no-lodash-clone-deep.ts +1 -1
- package/tsconfig.json +1 -1
package/build/index.js
CHANGED
|
@@ -5,7 +5,7 @@ import { rule as noDeviceTypeImports } from './rules/no-device-type-imports.js';
|
|
|
5
5
|
import { rule as preferPrivateExposables } from './rules/prefer-private-exposables.js';
|
|
6
6
|
import { rule as preferMakeRequestOverFetch } from './rules/prefer-makeRequest-over-fetch.js';
|
|
7
7
|
import { rule as noObjectFromEntries } from './rules/no-object-from-entries.js';
|
|
8
|
-
|
|
8
|
+
const rules = {
|
|
9
9
|
'prefer-no-lodash-cloneDeep': preferNoLodashCloneDeep,
|
|
10
10
|
'prefer-self-over-window': preferSelfOverWindow,
|
|
11
11
|
'prefer-txml-over-domparser': preferTxmlOverDomParser,
|
|
@@ -14,8 +14,8 @@ var rules = {
|
|
|
14
14
|
'prefer-makeRequest-over-fetch': preferMakeRequestOverFetch,
|
|
15
15
|
'no-object-from-entries': noObjectFromEntries,
|
|
16
16
|
};
|
|
17
|
-
|
|
18
|
-
rules
|
|
17
|
+
const plugin = {
|
|
18
|
+
rules,
|
|
19
19
|
};
|
|
20
20
|
export { plugin };
|
|
21
21
|
//# sourceMappingURL=index.js.map
|
package/build/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAClF,OAAO,EAAE,IAAI,IAAI,uBAAuB,EAAE,MAAM,uCAAuC,CAAC;AACxF,OAAO,EAAE,IAAI,IAAI,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,IAAI,IAAI,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAChF,OAAO,EAAE,IAAI,IAAI,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AACvF,OAAO,EAAE,IAAI,IAAI,0BAA0B,EAAE,MAAM,0CAA0C,CAAC;AAC9F,OAAO,EAAE,IAAI,IAAI,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAEhF,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAClF,OAAO,EAAE,IAAI,IAAI,uBAAuB,EAAE,MAAM,uCAAuC,CAAC;AACxF,OAAO,EAAE,IAAI,IAAI,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,IAAI,IAAI,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAChF,OAAO,EAAE,IAAI,IAAI,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AACvF,OAAO,EAAE,IAAI,IAAI,0BAA0B,EAAE,MAAM,0CAA0C,CAAC;AAC9F,OAAO,EAAE,IAAI,IAAI,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAEhF,MAAM,KAAK,GAAG;IACV,4BAA4B,EAAE,uBAAuB;IACrD,yBAAyB,EAAE,oBAAoB;IAC/C,4BAA4B,EAAE,uBAAuB;IACrD,wBAAwB,EAAE,mBAAmB;IAC7C,2BAA2B,EAAE,uBAAuB;IACpD,+BAA+B,EAAE,0BAA0B;IAC3D,wBAAwB,EAAE,mBAAmB;CAChD,CAAC;AAEF,MAAM,MAAM,GAAG;IACX,KAAK;CACR,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,CAAC"}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
5
|
return {
|
|
6
|
-
"Program:has(ImportDeclaration[source.value='@sky-uk-ott/client-lib-js-device'] > ImportSpecifier[imported.name=DeviceType])":
|
|
6
|
+
"Program:has(ImportDeclaration[source.value='@sky-uk-ott/client-lib-js-device'] > ImportSpecifier[imported.name=DeviceType])": (node) => {
|
|
7
7
|
context.report({
|
|
8
|
-
node
|
|
8
|
+
node,
|
|
9
9
|
messageId: 'forbiddenDeviceTypeUsage',
|
|
10
10
|
});
|
|
11
11
|
},
|
|
12
12
|
// Note the unicode character here is required to match a forward slash in the import path
|
|
13
13
|
// See https://eslint.org/docs/latest/extend/selectors#known-issues
|
|
14
|
-
'Program:has(ImportDeclaration[source.value=/.*\\u002Fdevice-type/])':
|
|
14
|
+
'Program:has(ImportDeclaration[source.value=/.*\\u002Fdevice-type/])': (node) => {
|
|
15
15
|
context.report({
|
|
16
|
-
node
|
|
16
|
+
node,
|
|
17
17
|
messageId: 'forbiddenDeviceTypeUtilUsage',
|
|
18
18
|
});
|
|
19
19
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-device-type-imports.js","sourceRoot":"","sources":["../../src/rules/no-device-type-imports.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAEtE,
|
|
1
|
+
{"version":3,"file":"no-device-type-imports.js","sourceRoot":"","sources":["../../src/rules/no-device-type-imports.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAEtE,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,OAAO;YACH,6HAA6H,EAAE,CAC3H,IAAoC,EACtC,EAAE;gBACA,OAAO,CAAC,MAAM,CAAC;oBACX,IAAI;oBACJ,SAAS,EAAE,0BAA0B;iBACxC,CAAC,CAAC;YACP,CAAC;YACD,0FAA0F;YAC1F,mEAAmE;YACnE,qEAAqE,EAAE,CAAC,IAAI,EAAE,EAAE;gBAC5E,OAAO,CAAC,MAAM,CAAC;oBACX,IAAI;oBACJ,SAAS,EAAE,8BAA8B;iBAC5C,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE,wBAAwB;IAC9B,IAAI,EAAE;QACF,IAAI,EAAE;YACF,WAAW,EAAE,sCAAsC;SACtD;QACD,QAAQ,EAAE;YACN,wBAAwB,EACpB,wHAAwH;YAC5H,4BAA4B,EACxB,0IAA0I;SACjJ;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
5
|
return {
|
|
6
|
-
CallExpression
|
|
6
|
+
CallExpression(node) {
|
|
7
7
|
if (node.callee.type === 'MemberExpression' &&
|
|
8
8
|
node.callee.object.type === 'Identifier' &&
|
|
9
9
|
node.callee.object.name === 'Object' &&
|
|
10
10
|
node.callee.property.type === 'Identifier' &&
|
|
11
11
|
node.callee.property.name === 'fromEntries') {
|
|
12
12
|
context.report({
|
|
13
|
-
node
|
|
13
|
+
node,
|
|
14
14
|
messageId: 'noObjectFromEntries',
|
|
15
15
|
});
|
|
16
16
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-object-from-entries.js","sourceRoot":"","sources":["../../src/rules/no-object-from-entries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,
|
|
1
|
+
{"version":3,"file":"no-object-from-entries.js","sourceRoot":"","sources":["../../src/rules/no-object-from-entries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,OAAO;YACH,cAAc,CAAC,IAAI;gBACf,IACI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,kBAAkB;oBACvC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,YAAY;oBACxC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,QAAQ;oBACpC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,YAAY;oBAC1C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,KAAK,aAAa,EAC7C;oBACE,OAAO,CAAC,MAAM,CAAC;wBACX,IAAI;wBACJ,SAAS,EAAE,qBAAqB;qBACnC,CAAC,CAAC;iBACN;YACL,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE,wBAAwB;IAC9B,IAAI,EAAE;QACF,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,MAAM;QACf,IAAI,EAAE;YACF,WAAW,EAAE,mCAAmC;SACnD;QACD,QAAQ,EAAE;YACN,mBAAmB,EAAE,oEAAoE;SAC5F;QACD,MAAM,EAAE,EAAE;KACb;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
5
|
return {
|
|
6
|
-
CallExpression
|
|
6
|
+
CallExpression(node) {
|
|
7
7
|
if (node.callee.type === 'Identifier' && node.callee.name === 'fetch') {
|
|
8
8
|
context.report({
|
|
9
|
-
node
|
|
9
|
+
node,
|
|
10
10
|
messageId: 'preferMakeRequest',
|
|
11
11
|
});
|
|
12
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-makeRequest-over-fetch.js","sourceRoot":"","sources":["../../src/rules/prefer-makeRequest-over-fetch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,
|
|
1
|
+
{"version":3,"file":"prefer-makeRequest-over-fetch.js","sourceRoot":"","sources":["../../src/rules/prefer-makeRequest-over-fetch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,OAAO;YACH,cAAc,CAAC,IAAI;gBACf,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE;oBACnE,OAAO,CAAC,MAAM,CAAC;wBACX,IAAI;wBACJ,SAAS,EAAE,mBAAmB;qBACjC,CAAC,CAAC;iBACN;YACL,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE,+BAA+B;IACrC,IAAI,EAAE;QACF,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,MAAM;QACf,IAAI,EAAE;YACF,WAAW,EAAE,4CAA4C;SAC5D;QACD,QAAQ,EAAE;YACN,iBAAiB,EAAE,mCAAmC;SACzD;QACD,MAAM,EAAE,EAAE;KACb;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
5
|
return {
|
|
6
|
-
"Program:has(ImportDeclaration[source.value='lodash'] > ImportSpecifier[imported.name=cloneDeep]) CallExpression[callee.name=cloneDeep]":
|
|
6
|
+
"Program:has(ImportDeclaration[source.value='lodash'] > ImportSpecifier[imported.name=cloneDeep]) CallExpression[callee.name=cloneDeep]": (node) => {
|
|
7
7
|
context.report({
|
|
8
|
-
node
|
|
8
|
+
node,
|
|
9
9
|
messageId: 'forbiddenCloneDeepUsage',
|
|
10
10
|
});
|
|
11
11
|
},
|
|
@@ -17,7 +17,7 @@ export var rule = createRule({
|
|
|
17
17
|
description: 'Detect usage of Lodash cloneDeep',
|
|
18
18
|
},
|
|
19
19
|
messages: {
|
|
20
|
-
forbiddenCloneDeepUsage:
|
|
20
|
+
forbiddenCloneDeepUsage: `Prefer using rfdc over lodash.cloneDeep as it cost a lot in performance`,
|
|
21
21
|
},
|
|
22
22
|
schema: [],
|
|
23
23
|
type: 'problem',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-no-lodash-clone-deep.js","sourceRoot":"","sources":["../../src/rules/prefer-no-lodash-clone-deep.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,
|
|
1
|
+
{"version":3,"file":"prefer-no-lodash-clone-deep.js","sourceRoot":"","sources":["../../src/rules/prefer-no-lodash-clone-deep.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,OAAO;YACH,wIAAwI,EACpI,CAAC,IAAI,EAAE,EAAE;gBACL,OAAO,CAAC,MAAM,CAAC;oBACX,IAAI;oBACJ,SAAS,EAAE,yBAAyB;iBACvC,CAAC,CAAC;YACP,CAAC;SACR,CAAC;IACN,CAAC;IACD,IAAI,EAAE,4BAA4B;IAClC,IAAI,EAAE;QACF,IAAI,EAAE;YACF,WAAW,EAAE,kCAAkC;SAClD;QACD,QAAQ,EAAE;YACN,uBAAuB,EAAE,yEAAyE;SACrG;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
|
@@ -1,18 +1,17 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
_a["Program:has(".concat(selector, ")")] = function (node) {
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
|
+
const publicExposableNames = ['Ad', 'AdBreak', 'AdPosition', 'Track'];
|
|
6
|
+
const selector = publicExposableNames.map((name) => `ImportSpecifier[imported.name=${name}]`).join(', ');
|
|
7
|
+
return {
|
|
8
|
+
[`Program:has(${selector})`]: (node) => {
|
|
10
9
|
context.report({
|
|
11
|
-
node
|
|
10
|
+
node,
|
|
12
11
|
messageId: 'preferPrivateExposable',
|
|
13
12
|
});
|
|
14
13
|
},
|
|
15
|
-
|
|
14
|
+
};
|
|
16
15
|
},
|
|
17
16
|
name: 'prefer-private-exposables',
|
|
18
17
|
meta: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-private-exposables.js","sourceRoot":"","sources":["../../src/rules/prefer-private-exposables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAEtE,
|
|
1
|
+
{"version":3,"file":"prefer-private-exposables.js","sourceRoot":"","sources":["../../src/rules/prefer-private-exposables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAEtE,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,MAAM,oBAAoB,GAAG,CAAC,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC;QACtE,MAAM,QAAQ,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,iCAAiC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzG,OAAO;YACH,CAAC,eAAe,QAAQ,GAAG,CAAC,EAAE,CAAC,IAAoC,EAAE,EAAE;gBACnE,OAAO,CAAC,MAAM,CAAC;oBACX,IAAI;oBACJ,SAAS,EAAE,wBAAwB;iBACtC,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE,2BAA2B;IACjC,IAAI,EAAE;QACF,IAAI,EAAE;YACF,WAAW,EAAE,yDAAyD;SACzE;QACD,QAAQ,EAAE;YACN,sBAAsB,EAAE,0GAA0G;SACrI;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
5
|
-
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
|
+
const parserServices = ESLintUtils.getParserServices(context);
|
|
6
6
|
function reportWindowError(node) {
|
|
7
7
|
if (node.parent.type !== 'VariableDeclarator') {
|
|
8
|
-
|
|
8
|
+
const nodeType = parserServices.getTypeAtLocation(node);
|
|
9
9
|
if (Object.prototype.hasOwnProperty.call(nodeType, 'aliasSymbol')) {
|
|
10
10
|
context.report({
|
|
11
11
|
messageId: 'forbiddenWindowAccess',
|
|
12
|
-
node
|
|
12
|
+
node,
|
|
13
13
|
fix: function (fixer) {
|
|
14
14
|
return fixer.replaceText(node, 'self');
|
|
15
15
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-self-over-window.js","sourceRoot":"","sources":["../../src/rules/prefer-self-over-window.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAEtE,
|
|
1
|
+
{"version":3,"file":"prefer-self-over-window.js","sourceRoot":"","sources":["../../src/rules/prefer-self-over-window.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAiB,MAAM,0BAA0B,CAAC;AAEtE,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,MAAM,cAAc,GAAG,WAAW,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAE9D,SAAS,iBAAiB,CAAC,IAAmB;YAC1C,IAAI,IAAI,CAAC,MAAO,CAAC,IAAI,KAAK,oBAAoB,EAAE;gBAC5C,MAAM,QAAQ,GAAG,cAAc,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBACxD,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,EAAE;oBAC/D,OAAO,CAAC,MAAM,CAAC;wBACX,SAAS,EAAE,uBAAuB;wBAClC,IAAI;wBACJ,GAAG,EAAE,UAAU,KAAK;4BAChB,OAAO,KAAK,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;wBAC3C,CAAC;qBACJ,CAAC,CAAC;iBACN;aACJ;QACL,CAAC;QAED,OAAO;YACH,2BAA2B,EAAE,iBAAiB;SACjD,CAAC;IACN,CAAC;IACD,IAAI,EAAE,8BAA8B;IACpC,IAAI,EAAE;QACF,IAAI,EAAE;YACF,WAAW,EAAE,yBAAyB;SACzC;QACD,QAAQ,EAAE;YACN,qBAAqB,EAAE,0GAA0G;SACpI;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,MAAM;KAClB;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
-
|
|
3
|
-
export
|
|
4
|
-
create
|
|
2
|
+
const createRule = ESLintUtils.RuleCreator((name) => name);
|
|
3
|
+
export const rule = createRule({
|
|
4
|
+
create(context) {
|
|
5
5
|
return {
|
|
6
|
-
Identifier
|
|
6
|
+
Identifier(node) {
|
|
7
7
|
if (node.type === 'Identifier' && node.name === 'DOMParser' && node.parent.type === 'NewExpression') {
|
|
8
8
|
context.report({
|
|
9
|
-
node
|
|
9
|
+
node,
|
|
10
10
|
messageId: 'forbiddenDomParserUsage',
|
|
11
11
|
});
|
|
12
12
|
}
|
|
@@ -17,7 +17,7 @@ export var rule = createRule({
|
|
|
17
17
|
meta: {
|
|
18
18
|
docs: { description: 'Disallow DOMParser usage.' },
|
|
19
19
|
messages: {
|
|
20
|
-
forbiddenDomParserUsage:
|
|
20
|
+
forbiddenDomParserUsage: `Prefer using txml (https://www.npmjs.com/package/txml) over DOMParser as DOMParser isn't supported on ION.`,
|
|
21
21
|
},
|
|
22
22
|
schema: [],
|
|
23
23
|
type: 'problem',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-txml-over-domparser.js","sourceRoot":"","sources":["../../src/rules/prefer-txml-over-domparser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,
|
|
1
|
+
{"version":3,"file":"prefer-txml-over-domparser.js","sourceRoot":"","sources":["../../src/rules/prefer-txml-over-domparser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,MAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;IAC3B,MAAM,CAAC,OAAO;QACV,OAAO;YACH,UAAU,CAAC,IAAI;gBACX,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,eAAe,EAAE;oBACjG,OAAO,CAAC,MAAM,CAAC;wBACX,IAAI;wBACJ,SAAS,EAAE,yBAAyB;qBACvC,CAAC,CAAC;iBACN;YACL,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE,4BAA4B;IAClC,IAAI,EAAE;QACF,IAAI,EAAE,EAAE,WAAW,EAAE,2BAA2B,EAAE;QAClD,QAAQ,EAAE;YACN,uBAAuB,EAAE,4GAA4G;SACxI;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,cAAc,EAAE,EAAE;CACrB,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -20,7 +20,7 @@ export const rule = createRule({
|
|
|
20
20
|
description: 'Detect usage of Lodash cloneDeep',
|
|
21
21
|
},
|
|
22
22
|
messages: {
|
|
23
|
-
forbiddenCloneDeepUsage: `Prefer using rfdc
|
|
23
|
+
forbiddenCloneDeepUsage: `Prefer using rfdc over lodash.cloneDeep as it cost a lot in performance`,
|
|
24
24
|
},
|
|
25
25
|
schema: [],
|
|
26
26
|
type: 'problem',
|