@akinon/eslint-plugin-projectzero 1.64.0 → 1.65.0
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/CHANGELOG.md +6 -0
- package/configs/core.ts +1 -0
- package/dist/configs/core.js +1 -0
- package/dist/rules/case-warning.js +32 -0
- package/dist/rules/index.js +2 -0
- package/package.json +1 -1
- package/rules/case-warning.ts +39 -0
- package/rules/index.ts +2 -0
package/CHANGELOG.md
CHANGED
package/configs/core.ts
CHANGED
|
@@ -9,6 +9,7 @@ export default {
|
|
|
9
9
|
'@akinon/projectzero/meta-data-import': 'error',
|
|
10
10
|
'@akinon/projectzero/urls-without-slash': 'error',
|
|
11
11
|
'@akinon/projectzero/invalid-imports': 'error',
|
|
12
|
+
'@akinon/projectzero/case-warning': 'warn',
|
|
12
13
|
'@akinon/projectzero/check-sentry-options': 'error',
|
|
13
14
|
'@akinon/projectzero/check-menu-depth': 'error',
|
|
14
15
|
'no-restricted-syntax': [
|
package/dist/configs/core.js
CHANGED
|
@@ -11,6 +11,7 @@ exports.default = {
|
|
|
11
11
|
'@akinon/projectzero/meta-data-import': 'error',
|
|
12
12
|
'@akinon/projectzero/urls-without-slash': 'error',
|
|
13
13
|
'@akinon/projectzero/invalid-imports': 'error',
|
|
14
|
+
'@akinon/projectzero/case-warning': 'warn',
|
|
14
15
|
'@akinon/projectzero/check-sentry-options': 'error',
|
|
15
16
|
'@akinon/projectzero/check-menu-depth': 'error',
|
|
16
17
|
'no-restricted-syntax': [
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const utils_1 = require("@typescript-eslint/utils");
|
|
4
|
+
exports.default = utils_1.ESLintUtils.RuleCreator.withoutDocs({
|
|
5
|
+
create(context) {
|
|
6
|
+
return {
|
|
7
|
+
CallExpression(node) {
|
|
8
|
+
if (node.callee.type === 'MemberExpression' &&
|
|
9
|
+
node.callee.property.type === 'Identifier' &&
|
|
10
|
+
(node.callee.property.name === 'toLocaleUpperCase' ||
|
|
11
|
+
node.callee.property.name === 'toLocaleLowerCase')) {
|
|
12
|
+
const args = node.arguments;
|
|
13
|
+
if (args.length === 0) {
|
|
14
|
+
context.report({
|
|
15
|
+
node,
|
|
16
|
+
messageId: 'noLocale'
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
},
|
|
23
|
+
meta: {
|
|
24
|
+
messages: {
|
|
25
|
+
noLocale: 'toLocaleUpperCase() or toLocaleLowerCase() should specify a locale for consistent behavior across different environments.'
|
|
26
|
+
},
|
|
27
|
+
type: 'problem',
|
|
28
|
+
fixable: 'code',
|
|
29
|
+
schema: []
|
|
30
|
+
},
|
|
31
|
+
defaultOptions: []
|
|
32
|
+
});
|
package/dist/rules/index.js
CHANGED
|
@@ -14,6 +14,7 @@ const meta_data_import_1 = __importDefault(require("./meta-data-import"));
|
|
|
14
14
|
const check_middleware_order_1 = __importDefault(require("./check-middleware-order"));
|
|
15
15
|
const urls_without_slash_1 = __importDefault(require("./urls-without-slash"));
|
|
16
16
|
const invalid_imports_1 = __importDefault(require("./invalid-imports"));
|
|
17
|
+
const case_warning_1 = __importDefault(require("./case-warning"));
|
|
17
18
|
const check_sentry_options_1 = __importDefault(require("./check-sentry-options"));
|
|
18
19
|
const check_menu_depth_1 = __importDefault(require("./check-menu-depth"));
|
|
19
20
|
const rules = {
|
|
@@ -27,6 +28,7 @@ const rules = {
|
|
|
27
28
|
'check-middleware-order': check_middleware_order_1.default,
|
|
28
29
|
'urls-without-slash': urls_without_slash_1.default,
|
|
29
30
|
'invalid-imports': invalid_imports_1.default,
|
|
31
|
+
'case-warning': case_warning_1.default,
|
|
30
32
|
'check-sentry-options': check_sentry_options_1.default,
|
|
31
33
|
'check-menu-depth': check_menu_depth_1.default
|
|
32
34
|
};
|
package/package.json
CHANGED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { ESLintUtils } from '@typescript-eslint/utils';
|
|
2
|
+
import { TSESTree } from '@typescript-eslint/types';
|
|
3
|
+
|
|
4
|
+
type MessageIds = 'noLocale';
|
|
5
|
+
type Options = readonly [];
|
|
6
|
+
|
|
7
|
+
export default ESLintUtils.RuleCreator.withoutDocs<Options, MessageIds>({
|
|
8
|
+
create(context) {
|
|
9
|
+
return {
|
|
10
|
+
CallExpression(node: TSESTree.CallExpression) {
|
|
11
|
+
if (
|
|
12
|
+
node.callee.type === 'MemberExpression' &&
|
|
13
|
+
node.callee.property.type === 'Identifier' &&
|
|
14
|
+
(node.callee.property.name === 'toLocaleUpperCase' ||
|
|
15
|
+
node.callee.property.name === 'toLocaleLowerCase')
|
|
16
|
+
) {
|
|
17
|
+
const args = node.arguments;
|
|
18
|
+
|
|
19
|
+
if (args.length === 0) {
|
|
20
|
+
context.report({
|
|
21
|
+
node,
|
|
22
|
+
messageId: 'noLocale'
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
},
|
|
29
|
+
meta: {
|
|
30
|
+
messages: {
|
|
31
|
+
noLocale:
|
|
32
|
+
'toLocaleUpperCase() or toLocaleLowerCase() should specify a locale for consistent behavior across different environments.'
|
|
33
|
+
},
|
|
34
|
+
type: 'problem',
|
|
35
|
+
fixable: 'code',
|
|
36
|
+
schema: []
|
|
37
|
+
},
|
|
38
|
+
defaultOptions: []
|
|
39
|
+
});
|
package/rules/index.ts
CHANGED
|
@@ -8,6 +8,7 @@ import metaDataImport from './meta-data-import';
|
|
|
8
8
|
import checkMiddlewareOrder from './check-middleware-order';
|
|
9
9
|
import urlsWithoutSlash from './urls-without-slash';
|
|
10
10
|
import invalidImports from './invalid-imports';
|
|
11
|
+
import caseWarning from './case-warning';
|
|
11
12
|
import checkSentryOptions from './check-sentry-options';
|
|
12
13
|
import checkMenuDepth from './check-menu-depth';
|
|
13
14
|
|
|
@@ -22,6 +23,7 @@ const rules = {
|
|
|
22
23
|
'check-middleware-order': checkMiddlewareOrder,
|
|
23
24
|
'urls-without-slash': urlsWithoutSlash,
|
|
24
25
|
'invalid-imports': invalidImports,
|
|
26
|
+
'case-warning': caseWarning,
|
|
25
27
|
'check-sentry-options': checkSentryOptions,
|
|
26
28
|
'check-menu-depth': checkMenuDepth
|
|
27
29
|
};
|