eslint-plugin-big-react-app-plugin 0.1.6 → 0.1.7
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/.history/lib/rules/public-api-imports_20251029144637.js +74 -0
- package/.history/lib/rules/public-api-imports_20251029144640.js +75 -0
- package/.history/lib/rules/public-api-imports_20251029144926.js +76 -0
- package/.history/lib/rules/public-api-imports_20251029144953.js +76 -0
- package/.history/lib/rules/public-api-imports_20251029145009.js +76 -0
- package/.history/lib/rules/public-api-imports_20251029145022.js +76 -0
- package/.history/lib/rules/public-api-imports_20251029145049.js +76 -0
- package/.history/package_20251029164755.json +33 -0
- package/.history/tests/lib/rules/path-checker_19851026131459.js +44 -0
- package/.history/tests/lib/rules/path-checker_20251029145043.js +44 -0
- package/.history/tests/lib/rules/path-checker_20251029145120.js +44 -0
- package/.history/tests/lib/rules/path-checker_20251029145122.js +44 -0
- package/.history/tests/lib/rules/path-checker_20251029145130.js +44 -0
- package/.history/tests/lib/rules/path-checker_20251029145140.js +44 -0
- package/.history/tests/lib/rules/public-api-imports_20251028164324.js +87 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145051.js +87 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145116.js +87 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145250.js +87 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145328.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145415.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145417.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029145434.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029150710.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029150715.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029150734.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029150749.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029153345.js +96 -0
- package/.history/tests/lib/rules/public-api-imports_20251029153548.js +96 -0
- package/lib/rules/public-api-imports.js +3 -2
- package/package.json +1 -1
- package/tests/lib/rules/path-checker.js +32 -32
- package/tests/lib/rules/public-api-imports.js +25 -16
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
module.exports = {
|
|
5
|
+
meta: {
|
|
6
|
+
type: null,
|
|
7
|
+
docs: {
|
|
8
|
+
description: "description",
|
|
9
|
+
category: "Fill me in",
|
|
10
|
+
recommended: false,
|
|
11
|
+
url: null,
|
|
12
|
+
},
|
|
13
|
+
fixable: null,
|
|
14
|
+
schema: [
|
|
15
|
+
{
|
|
16
|
+
type: 'object',
|
|
17
|
+
properties: {
|
|
18
|
+
alias: {
|
|
19
|
+
type: 'string'
|
|
20
|
+
},
|
|
21
|
+
testFilesPatterns: {
|
|
22
|
+
type: 'array'
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
],
|
|
27
|
+
},
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
create(context) {
|
|
31
|
+
const checkingLayers = {
|
|
32
|
+
"entities":"entities",
|
|
33
|
+
"features":"features",
|
|
34
|
+
"pages":"pages",
|
|
35
|
+
"widgets":"widgets",
|
|
36
|
+
}
|
|
37
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
38
|
+
return {
|
|
39
|
+
ImportDeclaration(node) {
|
|
40
|
+
// example app/entities/Article
|
|
41
|
+
const value = node.source.value;
|
|
42
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
43
|
+
//если путь относительный то выходим
|
|
44
|
+
if(isPathRelative(importTo)){
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
48
|
+
const segments = importTo.split('/')
|
|
49
|
+
const layer = segments[0]//получаем слой
|
|
50
|
+
// проверяем что есть слой из массива
|
|
51
|
+
|
|
52
|
+
//[enteties, article, testing]
|
|
53
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
54
|
+
|
|
55
|
+
if(!checkingLayers[layer]){
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
59
|
+
|
|
60
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
61
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
if(isTestingPublicApi){
|
|
65
|
+
const currentFilePath = context.getFilename();
|
|
66
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
67
|
+
if(!isCurrentFileTesting){
|
|
68
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
},
|
|
74
|
+
};
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
const path = require("path");
|
|
5
|
+
module.exports = {
|
|
6
|
+
meta: {
|
|
7
|
+
type: null,
|
|
8
|
+
docs: {
|
|
9
|
+
description: "description",
|
|
10
|
+
category: "Fill me in",
|
|
11
|
+
recommended: false,
|
|
12
|
+
url: null,
|
|
13
|
+
},
|
|
14
|
+
fixable: null,
|
|
15
|
+
schema: [
|
|
16
|
+
{
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
alias: {
|
|
20
|
+
type: 'string'
|
|
21
|
+
},
|
|
22
|
+
testFilesPatterns: {
|
|
23
|
+
type: 'array'
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
create(context) {
|
|
32
|
+
const checkingLayers = {
|
|
33
|
+
"entities":"entities",
|
|
34
|
+
"features":"features",
|
|
35
|
+
"pages":"pages",
|
|
36
|
+
"widgets":"widgets",
|
|
37
|
+
}
|
|
38
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
39
|
+
return {
|
|
40
|
+
ImportDeclaration(node) {
|
|
41
|
+
// example app/entities/Article
|
|
42
|
+
const value = node.source.value;
|
|
43
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
44
|
+
//если путь относительный то выходим
|
|
45
|
+
if(isPathRelative(importTo)){
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
49
|
+
const segments = importTo.split('/')
|
|
50
|
+
const layer = segments[0]//получаем слой
|
|
51
|
+
// проверяем что есть слой из массива
|
|
52
|
+
|
|
53
|
+
//[enteties, article, testing]
|
|
54
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
55
|
+
|
|
56
|
+
if(!checkingLayers[layer]){
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
60
|
+
|
|
61
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
62
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if(isTestingPublicApi){
|
|
66
|
+
const currentFilePath = context.getFilename();
|
|
67
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
68
|
+
if(!isCurrentFileTesting){
|
|
69
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
},
|
|
75
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
const path = require("path");
|
|
5
|
+
module.exports = {
|
|
6
|
+
meta: {
|
|
7
|
+
type: null,
|
|
8
|
+
docs: {
|
|
9
|
+
description: "description",
|
|
10
|
+
category: "Fill me in",
|
|
11
|
+
recommended: false,
|
|
12
|
+
url: null,
|
|
13
|
+
},
|
|
14
|
+
fixable: null,
|
|
15
|
+
schema: [
|
|
16
|
+
{
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
alias: {
|
|
20
|
+
type: 'string'
|
|
21
|
+
},
|
|
22
|
+
testFilesPatterns: {
|
|
23
|
+
type: 'array'
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
create(context) {
|
|
32
|
+
const checkingLayers = {
|
|
33
|
+
"entities":"entities",
|
|
34
|
+
"features":"features",
|
|
35
|
+
"pages":"pages",
|
|
36
|
+
"widgets":"widgets",
|
|
37
|
+
}
|
|
38
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
39
|
+
return {
|
|
40
|
+
ImportDeclaration(node) {
|
|
41
|
+
// example app/entities/Article
|
|
42
|
+
const value = node.source.value;
|
|
43
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
44
|
+
//если путь относительный то выходим
|
|
45
|
+
if(isPathRelative(importTo)){
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
49
|
+
const segments = importTo.split('/')
|
|
50
|
+
const layer = segments[0]//получаем слой
|
|
51
|
+
// проверяем что есть слой из массива
|
|
52
|
+
|
|
53
|
+
//[enteties, article, testing]
|
|
54
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
55
|
+
|
|
56
|
+
if(!checkingLayers[layer]){
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
60
|
+
|
|
61
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
62
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if(isTestingPublicApi){
|
|
66
|
+
const currentFilePath = context.getFilename();
|
|
67
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
68
|
+
console.log("Работает")
|
|
69
|
+
if(!isCurrentFileTesting){
|
|
70
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
},
|
|
76
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
const path = require("path");
|
|
5
|
+
module.exports = {
|
|
6
|
+
meta: {
|
|
7
|
+
type: null,
|
|
8
|
+
docs: {
|
|
9
|
+
description: "description",
|
|
10
|
+
category: "Fill me in",
|
|
11
|
+
recommended: false,
|
|
12
|
+
url: null,
|
|
13
|
+
},
|
|
14
|
+
fixable: null,
|
|
15
|
+
schema: [
|
|
16
|
+
{
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
alias: {
|
|
20
|
+
type: 'string'
|
|
21
|
+
},
|
|
22
|
+
testFilesPatterns: {
|
|
23
|
+
type: 'array'
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
create(context) {
|
|
32
|
+
const checkingLayers = {
|
|
33
|
+
"entities":"entities",
|
|
34
|
+
"features":"features",
|
|
35
|
+
"pages":"pages",
|
|
36
|
+
"widgets":"widgets",
|
|
37
|
+
}
|
|
38
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
39
|
+
return {
|
|
40
|
+
ImportDeclaration(node) {
|
|
41
|
+
// example app/entities/Article
|
|
42
|
+
const value = node.source.value;
|
|
43
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
44
|
+
//если путь относительный то выходим
|
|
45
|
+
if(isPathRelative(importTo)){
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
49
|
+
const segments = importTo.split('/')
|
|
50
|
+
const layer = segments[0]//получаем слой
|
|
51
|
+
// проверяем что есть слой из массива
|
|
52
|
+
|
|
53
|
+
//[enteties, article, testing]
|
|
54
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
55
|
+
|
|
56
|
+
if(!checkingLayers[layer]){
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
60
|
+
|
|
61
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
62
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if(isTestingPublicApi){
|
|
66
|
+
const currentFilePath = context.getFilename();
|
|
67
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
68
|
+
if(!isCurrentFileTesting){
|
|
69
|
+
console.log("Работает")
|
|
70
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
},
|
|
76
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
const path = require("path");
|
|
5
|
+
module.exports = {
|
|
6
|
+
meta: {
|
|
7
|
+
type: null,
|
|
8
|
+
docs: {
|
|
9
|
+
description: "description",
|
|
10
|
+
category: "Fill me in",
|
|
11
|
+
recommended: false,
|
|
12
|
+
url: null,
|
|
13
|
+
},
|
|
14
|
+
fixable: null,
|
|
15
|
+
schema: [
|
|
16
|
+
{
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
alias: {
|
|
20
|
+
type: 'string'
|
|
21
|
+
},
|
|
22
|
+
testFilesPatterns: {
|
|
23
|
+
type: 'array'
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
create(context) {
|
|
32
|
+
const checkingLayers = {
|
|
33
|
+
"entities":"entities",
|
|
34
|
+
"features":"features",
|
|
35
|
+
"pages":"pages",
|
|
36
|
+
"widgets":"widgets",
|
|
37
|
+
}
|
|
38
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
39
|
+
return {
|
|
40
|
+
ImportDeclaration(node) {
|
|
41
|
+
// example app/entities/Article
|
|
42
|
+
const value = node.source.value;
|
|
43
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
44
|
+
//если путь относительный то выходим
|
|
45
|
+
if(isPathRelative(importTo)){
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
49
|
+
const segments = importTo.split('/')
|
|
50
|
+
const layer = segments[0]//получаем слой
|
|
51
|
+
console.log("Работает")
|
|
52
|
+
// проверяем что есть слой из массива
|
|
53
|
+
|
|
54
|
+
//[enteties, article, testing]
|
|
55
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
56
|
+
|
|
57
|
+
if(!checkingLayers[layer]){
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
61
|
+
|
|
62
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
63
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
if(isTestingPublicApi){
|
|
67
|
+
const currentFilePath = context.getFilename();
|
|
68
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
69
|
+
if(!isCurrentFileTesting){
|
|
70
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
},
|
|
76
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
const path = require("path");
|
|
5
|
+
module.exports = {
|
|
6
|
+
meta: {
|
|
7
|
+
type: null,
|
|
8
|
+
docs: {
|
|
9
|
+
description: "description",
|
|
10
|
+
category: "Fill me in",
|
|
11
|
+
recommended: false,
|
|
12
|
+
url: null,
|
|
13
|
+
},
|
|
14
|
+
fixable: null,
|
|
15
|
+
schema: [
|
|
16
|
+
{
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
alias: {
|
|
20
|
+
type: 'string'
|
|
21
|
+
},
|
|
22
|
+
testFilesPatterns: {
|
|
23
|
+
type: 'array'
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
create(context) {
|
|
32
|
+
const checkingLayers = {
|
|
33
|
+
"entities":"entities",
|
|
34
|
+
"features":"features",
|
|
35
|
+
"pages":"pages",
|
|
36
|
+
"widgets":"widgets",
|
|
37
|
+
}
|
|
38
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
39
|
+
return {
|
|
40
|
+
ImportDeclaration(node) {
|
|
41
|
+
// example app/entities/Article
|
|
42
|
+
const value = node.source.value;
|
|
43
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
44
|
+
//если путь относительный то выходим
|
|
45
|
+
if(isPathRelative(importTo)){
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
49
|
+
const segments = importTo.split('/')
|
|
50
|
+
const layer = segments[0]//получаем слой
|
|
51
|
+
// проверяем что есть слой из массива
|
|
52
|
+
|
|
53
|
+
//[enteties, article, testing]
|
|
54
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
55
|
+
|
|
56
|
+
if(!checkingLayers[layer]){
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
60
|
+
|
|
61
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
62
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if(isTestingPublicApi){
|
|
66
|
+
console.log("Работает")
|
|
67
|
+
const currentFilePath = context.getFilename();
|
|
68
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
69
|
+
if(!isCurrentFileTesting){
|
|
70
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
},
|
|
76
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const micromatch = require("micromatch");
|
|
3
|
+
const {isPathRelative} = require("../helpers")
|
|
4
|
+
const path = require("path");
|
|
5
|
+
module.exports = {
|
|
6
|
+
meta: {
|
|
7
|
+
type: null,
|
|
8
|
+
docs: {
|
|
9
|
+
description: "description",
|
|
10
|
+
category: "Fill me in",
|
|
11
|
+
recommended: false,
|
|
12
|
+
url: null,
|
|
13
|
+
},
|
|
14
|
+
fixable: null,
|
|
15
|
+
schema: [
|
|
16
|
+
{
|
|
17
|
+
type: 'object',
|
|
18
|
+
properties: {
|
|
19
|
+
alias: {
|
|
20
|
+
type: 'string'
|
|
21
|
+
},
|
|
22
|
+
testFilesPatterns: {
|
|
23
|
+
type: 'array'
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
create(context) {
|
|
32
|
+
const checkingLayers = {
|
|
33
|
+
"entities":"entities",
|
|
34
|
+
"features":"features",
|
|
35
|
+
"pages":"pages",
|
|
36
|
+
"widgets":"widgets",
|
|
37
|
+
}
|
|
38
|
+
const {alias='', testFilesPatterns=[]} = context.options[0] ?? {};
|
|
39
|
+
return {
|
|
40
|
+
ImportDeclaration(node) {
|
|
41
|
+
// example app/entities/Article
|
|
42
|
+
const value = node.source.value;
|
|
43
|
+
const importTo = alias ? value.replace(`${alias}/`, "") : value;
|
|
44
|
+
//если путь относительный то выходим
|
|
45
|
+
if(isPathRelative(importTo)){
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
//[enteties, article, ... далее еще что-то может быть]
|
|
49
|
+
const segments = importTo.split('/')
|
|
50
|
+
const layer = segments[0]//получаем слой
|
|
51
|
+
// проверяем что есть слой из массива
|
|
52
|
+
|
|
53
|
+
//[enteties, article, testing]
|
|
54
|
+
const isTestingPublicApi = segments[2] === 'testing' && segments.length < 4;
|
|
55
|
+
|
|
56
|
+
if(!checkingLayers[layer]){
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const isImportNotFromPublicApi = segments.length > 2;
|
|
60
|
+
|
|
61
|
+
if(isImportNotFromPublicApi && !isTestingPublicApi ) {
|
|
62
|
+
context.report({node: node, message: 'Абсолютный импорт разрешен только из Public API (index.ts)'});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if(isTestingPublicApi){
|
|
66
|
+
console.log("Работает")
|
|
67
|
+
const currentFilePath = context.getFilename();
|
|
68
|
+
const isCurrentFileTesting = testFilesPatterns.some(pattern=>micromatch.isMatch(currentFilePath, pattern))
|
|
69
|
+
if(!isCurrentFileTesting){
|
|
70
|
+
context.report({node: node, message: 'Тестовые данные необходимо импортировать из publicApi/testing.ts'});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
},
|
|
76
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "eslint-plugin-big-react-app-plugin",
|
|
3
|
+
"version": "0.1.7",
|
|
4
|
+
"description": "plugin for prod proj",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"eslint",
|
|
7
|
+
"eslintplugin",
|
|
8
|
+
"eslint-plugin"
|
|
9
|
+
],
|
|
10
|
+
"author": "Vasilii",
|
|
11
|
+
"main": "lib/index.js",
|
|
12
|
+
"scripts": {
|
|
13
|
+
"lint": "eslint .",
|
|
14
|
+
"test": "mocha tests --recursive"
|
|
15
|
+
},
|
|
16
|
+
"dependencies": {
|
|
17
|
+
"micromatch": "^4.0.5",
|
|
18
|
+
"requireindex": "^1.2.0"
|
|
19
|
+
},
|
|
20
|
+
"devDependencies": {
|
|
21
|
+
"eslint": "^8.0.1",
|
|
22
|
+
"eslint-plugin-eslint-plugin": "^4.0.1",
|
|
23
|
+
"eslint-plugin-node": "^11.1.0",
|
|
24
|
+
"mocha": "^9.1.3"
|
|
25
|
+
},
|
|
26
|
+
"engines": {
|
|
27
|
+
"node": "12.x || 14.x || >= 16"
|
|
28
|
+
},
|
|
29
|
+
"peerDependencies": {
|
|
30
|
+
"eslint": ">=6"
|
|
31
|
+
},
|
|
32
|
+
"license": "ISC"
|
|
33
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview feature sliced relative path checker
|
|
3
|
+
* @author Vasilii
|
|
4
|
+
*/
|
|
5
|
+
"use strict";
|
|
6
|
+
|
|
7
|
+
//------------------------------------------------------------------------------
|
|
8
|
+
// Requirements
|
|
9
|
+
//------------------------------------------------------------------------------
|
|
10
|
+
|
|
11
|
+
const rule = require("../../../lib/rules/path-checker"),
|
|
12
|
+
RuleTester = require("eslint").RuleTester;
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
//------------------------------------------------------------------------------
|
|
16
|
+
// Tests
|
|
17
|
+
//------------------------------------------------------------------------------
|
|
18
|
+
|
|
19
|
+
const ruleTester = new RuleTester({
|
|
20
|
+
parserOptions:{ecmaVersion:6, sourceType:'module'}
|
|
21
|
+
});
|
|
22
|
+
ruleTester.run("path-checker", rule, {
|
|
23
|
+
valid: [
|
|
24
|
+
{
|
|
25
|
+
code: "import { HStack } from '../../../Stack/HStack/HStack'",
|
|
26
|
+
filename:'C:\\Users\\ADMIN\\Documents\\GitHub\\ulbi\big-react-app\\src\\shared\\ui\\Popups\\ui\\ListBox\\ListBox.tsx',
|
|
27
|
+
errors: [],
|
|
28
|
+
},
|
|
29
|
+
],
|
|
30
|
+
|
|
31
|
+
invalid: [
|
|
32
|
+
{
|
|
33
|
+
code: "import { HStack } from 'shared/ui/Stack/index'",
|
|
34
|
+
filename:'C:\\Users\\ADMIN\\Documents\\GitHub\\ulbi\big-react-app\\src\\shared\\ui\\Popups\\ui\\ListBox\\ListBox.tsx',
|
|
35
|
+
errors: [{ message: "В рамках одного слайса все пути должны быть относительными" }],
|
|
36
|
+
options:[
|
|
37
|
+
{
|
|
38
|
+
alias:'@'
|
|
39
|
+
}
|
|
40
|
+
]
|
|
41
|
+
},
|
|
42
|
+
|
|
43
|
+
],
|
|
44
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview feature sliced relative path checker
|
|
3
|
+
* @author Vasilii
|
|
4
|
+
*/
|
|
5
|
+
"use strict";
|
|
6
|
+
|
|
7
|
+
//------------------------------------------------------------------------------
|
|
8
|
+
// Requirements
|
|
9
|
+
//------------------------------------------------------------------------------
|
|
10
|
+
|
|
11
|
+
const rule = require("../../../lib/rules/path-checker"),
|
|
12
|
+
RuleTester = require("eslint").RuleTester;
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
//------------------------------------------------------------------------------
|
|
16
|
+
// Tests
|
|
17
|
+
//------------------------------------------------------------------------------
|
|
18
|
+
|
|
19
|
+
const ruleTester = new RuleTester({
|
|
20
|
+
parserOptions:{ecmaVersion:6, sourceType:'module'}
|
|
21
|
+
});
|
|
22
|
+
ruleTester.run("path-checker", rule, {
|
|
23
|
+
// valid: [
|
|
24
|
+
// {
|
|
25
|
+
// code: "import { HStack } from '../../../Stack/HStack/HStack'",
|
|
26
|
+
// filename:'C:\\Users\\ADMIN\\Documents\\GitHub\\ulbi\big-react-app\\src\\shared\\ui\\Popups\\ui\\ListBox\\ListBox.tsx',
|
|
27
|
+
// errors: [],
|
|
28
|
+
// },
|
|
29
|
+
// ],
|
|
30
|
+
|
|
31
|
+
invalid: [
|
|
32
|
+
{
|
|
33
|
+
code: "import { HStack } from 'shared/ui/Stack/index'",
|
|
34
|
+
filename:'C:\\Users\\ADMIN\\Documents\\GitHub\\ulbi\big-react-app\\src\\shared\\ui\\Popups\\ui\\ListBox\\ListBox.tsx',
|
|
35
|
+
errors: [{ message: "В рамках одного слайса все пути должны быть относительными" }],
|
|
36
|
+
options:[
|
|
37
|
+
{
|
|
38
|
+
alias:'@'
|
|
39
|
+
}
|
|
40
|
+
]
|
|
41
|
+
},
|
|
42
|
+
|
|
43
|
+
],
|
|
44
|
+
});
|