mirror of
https://github.com/twentyhq/twenty
synced 2026-04-21 13:37:22 +00:00
## Summary Moves the custom ESLint rules from `tools/eslint-rules` to `packages/twenty-eslint-rules` for better organization within the monorepo packages structure. ## Changes - Move `eslint-rules` from `tools/` to `packages/twenty-eslint-rules` - Use `loadWorkspaceRules` from `@nx/eslint-plugin` to load custom rules - Update all ESLint configs to use the `twenty/` rule prefix instead of `@nx/workspace-` - Update `project.json`, `jest.config.mjs` with new paths - Update `package.json` workspaces and `nx.json` cache inputs - Update Dockerfile reference ## Technical Details The custom ESLint rules are now loaded using Nx's `loadWorkspaceRules` utility which: - Handles TypeScript transpilation automatically - Allows loading workspace rules from any directory - Provides a cleaner approach than the previous `@nx/workspace-` convention ## Testing - Verified all 17 custom ESLint rules load correctly from the new location - Verified linting works on dependent packages (twenty-front, twenty-server, etc.)
36 lines
731 B
TypeScript
36 lines
731 B
TypeScript
import { TSESLint } from '@typescript-eslint/utils';
|
|
|
|
import { rule, RULE_NAME } from './styled-components-prefixed-with-styled';
|
|
|
|
const ruleTester = new TSESLint.RuleTester({
|
|
parser: require.resolve('@typescript-eslint/parser'),
|
|
});
|
|
|
|
ruleTester.run(RULE_NAME, rule, {
|
|
valid: [
|
|
{
|
|
code: 'const StyledButton = styled.button``;',
|
|
},
|
|
{
|
|
code: 'const StyledComponent = styled.div``;',
|
|
},
|
|
],
|
|
invalid: [
|
|
{
|
|
code: 'const Button = styled.button``;',
|
|
errors: [
|
|
{
|
|
messageId: 'noStyledPrefix',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
code: 'const Component = styled.div``;',
|
|
errors: [
|
|
{
|
|
messageId: 'noStyledPrefix',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
});
|