# Hydra Project Rules ## Logging - **Always use `logger` instead of `console` for logging** in both main and renderer processes - In main process: `import { logger } from "@main/services";` - In renderer process: `import { logger } from "@renderer/logger";` - Replace all instances of: - `console.log()` → `logger.log()` - `console.error()` → `logger.error()` - `console.warn()` → `logger.warn()` - `console.info()` → `logger.info()` - `console.debug()` → `logger.debug()` - Do not use `console` for any logging purposes ## Internationalization (i18n) - All user-facing strings must be translated using i18next - Use the `useTranslation` hook in React components: `const { t } = useTranslation("namespace");` - Add new translation keys to `src/locales/en/translation.json` - Never hardcode English strings in the UI code - Placeholder text in form fields must also be translated ## Code Style - Use ESLint and Prettier for code formatting - Follow TypeScript strict mode conventions - Use async/await instead of promises when possible - Prefer named exports over default exports for utilities and services ## ESLint Issues - **Always try to fix ESLint errors properly before disabling rules** - When encountering ESLint errors, explore these solutions in order: 1. **Fix the code to comply with the rule** (e.g., add missing required elements, fix accessibility issues) 2. **Use minimal markup to satisfy the rule** (e.g., add empty `` elements for videos without captions, add `role` attributes) 3. **Only disable the rule as a last resort** when no reasonable solution exists - When disabling a rule, always include a comment explaining why it's necessary - Examples of proper fixes: - For `jsx-a11y/media-has-caption`: Add `` even if no captions are available - For `jsx-a11y/alt-text`: Add meaningful alt text or `alt=""` for decorative images - For accessibility rules: Add appropriate ARIA attributes rather than disabling ## TypeScript Array Syntax - **Always use `T[]` syntax instead of `Array`** for array types - Prefer: `string[]`, `number[]`, `MyType[]` - Avoid: `Array`, `Array`, `Array` - This applies to all type annotations, type assertions, and generic type parameters ## Comments - Keep comments concise and purposeful; avoid verbose explanations. - Focus on the "why" or non-obvious context, not restating the code. - Prefer self-explanatory naming and structure over excessive comments. - Do not comment every line or obvious behavior; remove stale comments. - Use docblocks only where they add value (public APIs, complex logic).