website refactor
This commit is contained in:
71
apps/website/eslint-rules/filename-rules.js
Normal file
71
apps/website/eslint-rules/filename-rules.js
Normal file
@@ -0,0 +1,71 @@
|
||||
/**
|
||||
* ESLint rules for Filename Rules
|
||||
*
|
||||
* Enforces correct file naming conventions
|
||||
*/
|
||||
|
||||
module.exports = {
|
||||
// Rule 1: Presenter filename must match class name
|
||||
'presenter-filename-must-match-class': {
|
||||
meta: {
|
||||
type: 'problem',
|
||||
docs: {
|
||||
description: 'Enforce presenter filename matches class name',
|
||||
category: 'Filename',
|
||||
},
|
||||
messages: {
|
||||
message: 'Presenter filename must match class name (e.g., FooPresenter.ts contains class FooPresenter)',
|
||||
},
|
||||
},
|
||||
create(context) {
|
||||
return {
|
||||
ClassDeclaration(node) {
|
||||
const filename = context.getFilename();
|
||||
if (filename.includes('/lib/presenters/') && filename.endsWith('.ts')) {
|
||||
const expectedClassName = filename.split('/').pop().replace('.ts', '');
|
||||
const actualClassName = node.id?.name;
|
||||
|
||||
if (actualClassName && actualClassName !== expectedClassName) {
|
||||
context.report({
|
||||
node,
|
||||
messageId: 'message',
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
};
|
||||
},
|
||||
},
|
||||
|
||||
// Rule 2: Service filename must match function name
|
||||
'service-filename-must-match-function': {
|
||||
meta: {
|
||||
type: 'problem',
|
||||
docs: {
|
||||
description: 'Enforce service filename matches function name',
|
||||
category: 'Filename',
|
||||
},
|
||||
messages: {
|
||||
message: 'Service filename must match function name (e.g., getUser.ts contains function getUser)',
|
||||
},
|
||||
},
|
||||
create(context) {
|
||||
return {
|
||||
FunctionDeclaration(node) {
|
||||
const filename = context.getFilename();
|
||||
if (filename.includes('/lib/services/') && filename.endsWith('.ts')) {
|
||||
const expectedFunctionName = filename.split('/').pop().replace('.ts', '');
|
||||
const actualFunctionName = node.id?.name;
|
||||
|
||||
if (actualFunctionName && actualFunctionName !== expectedFunctionName) {
|
||||
context.report({
|
||||
node,
|
||||
messageId: 'message',
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
};
|
||||
},
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user