This package provides ESLint rules and configurations for Hubspot Marketing WebTeam projects, supporting both Node.js backend and browser/React applications.
- Node.js Setup
- Browser/React Setup
- Stylelint Setup
- Cypress Setup
- Where to use it
- Using the Prettier Scripts
-
Install as dev dependency
npm i -D @hs-web-team/eslint-config-node@latest
-
Add to
eslint.config.jsin project root directoryimport wtConfig from '@hs-web-team/eslint-config-node'; export default [ ...wtConfig, ];
-
Extend the eslint on a project basis by adding rules to
eslint.config.jse.g.import wtConfig from '@hs-web-team/eslint-config-node'; export default [ // Add project-specific ignores here { ignores: ['dist/**'], }, // Add project-specific rules here { rules: { 'no-console': 'error', }, }, ...wtConfig, // This will include the shared rules from @hs-web-team/eslint-config-node ];
-
Install as dev dependency
npm i -D @hs-web-team/eslint-config-node@latest
-
Add to
eslint.config.jsin project root directoryimport wtBrowserConfig from '@hs-web-team/eslint-config-node/browser'; export default [ ...wtBrowserConfig, ];
-
The browser configuration includes:
- ESLint recommended rules for JavaScript
- TypeScript support with typescript-eslint
- React support with eslint-plugin-react
- React Hooks rules with eslint-plugin-react-hooks
- Accessibility rules with eslint-plugin-jsx-a11y
- Browser globals (window, document, etc.) and custom globals (jQuery, $, Invoca)
For detailed browser configuration documentation and migration guides, see examples/browser-usage.md.
This package provides shared Stylelint configuration for SCSS/CSS linting.
-
Install dependencies
npm i -D stylelint stylelint-config-standard-scss
-
Create
.stylelintrc.jsonin project root{ "extends": "@hs-web-team/eslint-config-node/.stylelintrc.json" } -
Add scripts to package.json
{ "scripts": { "stylelint:check": "stylelint '**/*.{css,scss}'", "stylelint:fix": "stylelint '**/*.{css,scss}' --fix" } }
For detailed Stylelint configuration documentation, see examples/stylelint-usage.md.
This package provides shared Cypress configuration for E2E testing.
-
Install Cypress
npm i -D cypress@15
For detailed Cypress configuration and migration documentation, see examples/cypress-usage.md.
This package provides multiple configurations:
- Node.js configuration (default export): For backend Node.js projects
- Browser configuration (
/browserexport): For browser-based projects including React applications - Stylelint configuration (
.stylelintrc.jsonexport): For SCSS/CSS linting - Cypress configuration (
cypress.configexport): For E2E testing with Cypress - Prettier configuration (
.prettierrc.jsonexport): For code formatting
Choose the appropriate configurations based on your project needs.
This package includes a utility script to automatically add Prettier configuration to your project.
-
Run the script:
node ./node_modules/@hs-web-team/eslint-config-node/bin/add-prettier-scripts.js
-
The script will:
- Add
prettier:checkandprettier:writescripts to your package.json - Install Prettier as a dev dependency if not already installed
- Create a
.prettierrc.jsfile with shared config - Create a
.prettierignorefile with sensible defaults
- Add
-
After installation, you can use the following commands:
npm run prettier:check- Check files for formatting issuesnpm run prettier:write- Automatically fix formatting issues
See MIGRATION-V2.md
See MIGRATION-V3.md