Zapal DX (Developer Experience) - opinionated and simple set of code quality tools' configurations, rule sets and utilities, to make your life easier.
Used by Zapal internally, but open-sourced for everyone to use.
Tools for which configurations are provided:
- Prettier (
>=3 <4
) - ESLint (
>=9 <10
) - TypeScript (
>=4.8.0 <6
) - Commitlint (
>=19 <20
)
P.S.: The configurations by default may not suit your needs. You can extend them or override them with your own configurations.
IMPORTANT: This package is not contains a tools itself as dependencies, only a set of configurations.
# pnpm
pnpm add -D @zapal/dx
# npm
npm i -D @zapal/dx
# yarn
yarn add -D @zapal/dx
All the configurations are available as named exports and default export (the base configurations) from the package subdirectories.
Separate directory for each tool's configurations:
- Prettier:
@zapal/dx/prettier
- ESLint:
@zapal/dx/eslint
- TypeScript:
@zapal/dx/typescript
- Commitlint:
@zapal/dx/commitlint
IMPORTANT: There is no exports from the root of the package, only from the subdirectories.
Prettier configurations use prettier-plugin-packagejson
and @ianvs/prettier-plugin-sort-imports
plugins by default.
prettier-plugin-packagejson
is used to formatpackage.json
files and does not require any additional configuration.@ianvs/prettier-plugin-sort-imports
is used to sort imports in TS/JS/React/Vue/Svelte files. It may require an additional configuration to provide the best development experience. Check the plugin's documentation for more information.
The default configuration for @ianvs/prettier-plugin-sort-imports
is:
{
"importOrderTypeScriptVersion": "5.0.0",
"importOrder": [
"<BUILTIN_MODULES>",
"^(@zapal)(/.*)$",
"<THIRD_PARTY_MODULES>",
"",
"^[.]",
"",
"^(?!.*[.]css$)[./].*$",
".css$"
]
}
Using the default configuration:
// package.json
{
"prettier": "@zapal/dx/prettier"
}
// .prettierrc.js or .prettierrc.mjs
export { default } from '@zapal/dx/prettier'
// .prettierrc.js or .prettierrc.mjs
export { sveltePrettierConfig as default } from '@zapal/dx/prettier'
Using the configuration with some custom options:
// .prettierrc.js or .prettierrc.mjs
import { defaultPrettierConfig } from '@zapal/dx/prettier'
export default {
...defaultPrettierConfig,
semi: false,
}
Principle is the same as for Prettier.
// package.json
{
"eslintConfig": "@zapal/dx/eslint"
}
// eslint.config.js or eslint.config.mjs
export { default } from '@zapal/dx/eslint'
Available exports:
@zapal/dx/typescript
- default configuration@zapal/dx/typescript/next
- configuration for Next.js, extending the default configuration@zapal/dx/typescript/svelte
- configuration for Svelte-based projects, extending the default configuration
Using the default configuration:
// tsconfig.json
{
"extends": "@zapal/dx/typescript"
}
Using the configuration for Next.js, for example:
// tsconfig.json
{
"extends": "@zapal/dx/typescript/next"
}
IMPORTANT: Unfortunately, the commitlint
requires you to install extended dependencies directly in your project. Use
devDependencies
for that.
Here is the list of the required devDependencies
for the configurations:
- Default -
@commitlint/config-conventional
- PNPM Workspace scopes -
@commitlint/config-conventional
and@commitlint/config-pnpm-scopes
Using the default configuration:
// .commitlintrc.json
{
"extends": ["@zapal/dx/commitlint"]
}
// commitlint.config.js or commitlint.config.mjs
export { default } from '@zapal/dx/commitlint'
Using the configuration with configuration for PNPM Workspace based scopes:
// commitlint.config.js or commitlint.config.mjs
export { pnpmWorkspaceScopesCommitlintConfig as default } from '@zapal/dx/commitlint'