website refactor
This commit is contained in:
@@ -88,7 +88,8 @@
|
||||
"gridpilot-rules/template-no-global-objects": "error",
|
||||
"gridpilot-rules/template-no-mutation-props": "error",
|
||||
"gridpilot-rules/template-no-unsafe-html": "error",
|
||||
"gridpilot-rules/component-no-data-manipulation": "error"
|
||||
"gridpilot-rules/component-no-data-manipulation": "error",
|
||||
"gridpilot-rules/no-hardcoded-routes": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
@@ -144,7 +145,9 @@
|
||||
"gridpilot-rules/page-query-must-use-builders": "error",
|
||||
"gridpilot-rules/single-export-per-file": "error",
|
||||
"gridpilot-rules/filename-matches-export": "error",
|
||||
"gridpilot-rules/clean-error-handling": "error"
|
||||
"gridpilot-rules/clean-error-handling": "error",
|
||||
"gridpilot-rules/no-hardcoded-routes": "error",
|
||||
"gridpilot-rules/no-hardcoded-search-params": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
@@ -217,6 +220,48 @@
|
||||
"gridpilot-rules/lib-no-next-imports": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
"files": [
|
||||
"app/**/*.tsx",
|
||||
"app/**/*.ts"
|
||||
],
|
||||
"rules": {
|
||||
"gridpilot-rules/no-raw-html-in-app": "error",
|
||||
"gridpilot-rules/no-nextjs-imports-in-ui": "error",
|
||||
"gridpilot-rules/no-hardcoded-routes": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
"files": [
|
||||
"app/**/actions.ts",
|
||||
"app/**/actions/*.ts"
|
||||
],
|
||||
"rules": {
|
||||
"gridpilot-rules/no-hardcoded-routes": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
"files": [
|
||||
"ui/**/*.tsx",
|
||||
"ui/**/*.ts"
|
||||
],
|
||||
"rules": {
|
||||
"gridpilot-rules/ui-element-purity": "error",
|
||||
"gridpilot-rules/no-nextjs-imports-in-ui": "error",
|
||||
"gridpilot-rules/component-classification": "warn"
|
||||
}
|
||||
},
|
||||
{
|
||||
"files": [
|
||||
"components/**/*.tsx",
|
||||
"components/**/*.ts"
|
||||
],
|
||||
"rules": {
|
||||
"gridpilot-rules/no-nextjs-imports-in-ui": "error",
|
||||
"gridpilot-rules/component-classification": "warn",
|
||||
"gridpilot-rules/no-hardcoded-routes": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
"files": [
|
||||
"lib/services/**/*.ts"
|
||||
@@ -226,7 +271,16 @@
|
||||
"gridpilot-rules/services-must-be-marked": "error",
|
||||
"gridpilot-rules/services-must-be-pure": "error",
|
||||
"gridpilot-rules/services-no-external-api": "error",
|
||||
"gridpilot-rules/services-no-instantiation": "error"
|
||||
"gridpilot-rules/services-implement-contract": "error",
|
||||
"gridpilot-rules/no-hardcoded-routes": "error"
|
||||
}
|
||||
},
|
||||
{
|
||||
"files": [
|
||||
"lib/mutations/**/*.ts"
|
||||
],
|
||||
"rules": {
|
||||
"gridpilot-rules/no-hardcoded-routes": "error"
|
||||
}
|
||||
}
|
||||
],
|
||||
@@ -265,7 +319,8 @@
|
||||
"react-hooks/rules-of-hooks": "error",
|
||||
"react/no-unescaped-entities": "error",
|
||||
"unused-imports/no-unused-imports": "off",
|
||||
"unused-imports/no-unused-vars": "off"
|
||||
"unused-imports/no-unused-vars": "off",
|
||||
"gridpilot-rules/no-index-files": "error"
|
||||
},
|
||||
"settings": {
|
||||
"boundaries/elements": [
|
||||
|
||||
@@ -148,6 +148,9 @@ module.exports = {
|
||||
// Route Configuration Rules
|
||||
'no-hardcoded-routes': require('./no-hardcoded-routes'),
|
||||
'no-hardcoded-search-params': require('./no-hardcoded-search-params'),
|
||||
|
||||
// Architecture Rules
|
||||
'no-index-files': require('./no-index-files'),
|
||||
},
|
||||
|
||||
// Configurations for different use cases
|
||||
|
||||
45
apps/website/eslint-rules/no-index-files.js
Normal file
45
apps/website/eslint-rules/no-index-files.js
Normal file
@@ -0,0 +1,45 @@
|
||||
/**
|
||||
* @file no-index-files.js
|
||||
* Bans index.ts/index.tsx files - they hide dependencies and make code harder to navigate
|
||||
*/
|
||||
|
||||
module.exports = {
|
||||
meta: {
|
||||
type: 'problem',
|
||||
docs: {
|
||||
description: 'Ban index.ts/index.tsx files - use explicit imports instead',
|
||||
category: 'Best Practices',
|
||||
recommended: true,
|
||||
},
|
||||
fixable: null,
|
||||
schema: [],
|
||||
messages: {
|
||||
indexFile: 'Index files are banned. Use explicit imports and barrel exports. Example: Instead of "import { foo } from "./", use "import { foo } from "./foo" and export from "./foo" explicitly.',
|
||||
},
|
||||
},
|
||||
|
||||
create(context) {
|
||||
const filename = context.getFilename();
|
||||
|
||||
// Check if file is named index.ts or index.tsx
|
||||
const isIndexFile = /(^|\/|\\)index\.(ts|tsx)$/.test(filename);
|
||||
|
||||
// Allow index files in root directories that are required by framework
|
||||
const allowedPaths = [
|
||||
'apps/website/app/index.ts', // Next.js app router entry
|
||||
'apps/website/pages/index.tsx', // Next.js pages router entry
|
||||
'apps/website/src/index.ts', // Common entry point
|
||||
'apps/website/index.ts', // Root entry
|
||||
];
|
||||
|
||||
if (isIndexFile && !allowedPaths.some(path => filename.endsWith(path))) {
|
||||
context.report({
|
||||
node: null, // Report on the file level
|
||||
loc: { line: 1, column: 0 },
|
||||
messageId: 'indexFile',
|
||||
});
|
||||
}
|
||||
|
||||
return {};
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user