Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mdx-js/eslint-mdx
ESLint Parser/Plugin for MDX
https://github.com/mdx-js/eslint-mdx
eslint eslint-mdx eslint-parser eslint-plugin eslint-plugin-mdx mdx
Last synced: 7 days ago
JSON representation
ESLint Parser/Plugin for MDX
- Host: GitHub
- URL: https://github.com/mdx-js/eslint-mdx
- Owner: mdx-js
- License: mit
- Created: 2019-07-29T05:26:12.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2025-01-30T12:29:25.000Z (21 days ago)
- Last Synced: 2025-02-11T10:04:57.100Z (9 days ago)
- Topics: eslint, eslint-mdx, eslint-parser, eslint-plugin, eslint-plugin-mdx, mdx
- Language: TypeScript
- Homepage: https://npmjs.org/eslint-plugin-mdx
- Size: 7.75 MB
- Stars: 277
- Watchers: 8
- Forks: 32
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/f9aa7/f9aa79a25528eb10cc7a3337da7d571a0ffd9303" alt="GitHub Actions"](https://github.com/mdx-js/eslint-mdx/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/6414d/6414d8452f27ec38581a82211463ed9bb73c6cc1" alt="Codecov"](https://codecov.io/gh/mdx-js/eslint-mdx)
[data:image/s3,"s3://crabby-images/7c465/7c4654c5f9ac4cf746b914214131c95fcbe76a85" alt="type-coverage"](https://github.com/plantain-00/type-coverage)
[data:image/s3,"s3://crabby-images/44ae1/44ae1ff8142a60b51e9c59747430abe99d15a599" alt="GitHub release"](https://github.com/mdx-js/eslint-mdx/releases)[data:image/s3,"s3://crabby-images/4f9fb/4f9fb7bddef4aee10d3581e5e06a32347ce7dfcd" alt="Renovate enabled"](https://renovatebot.com)
[data:image/s3,"s3://crabby-images/33024/330245df9cf7f4a14c3603a1aac1c22d7fcf2cd9" alt="Conventional Commits"](https://conventionalcommits.org)
[data:image/s3,"s3://crabby-images/66d2a/66d2aa6f1e0afe66f640aa4ac2de0141d66555dc" alt="code style: prettier"](https://github.com/prettier/prettier)
[data:image/s3,"s3://crabby-images/12617/126172d20221c4cf1a332c8493b375c9dbcdc185" alt="changesets"](https://github.com/changesets/changesets)> [ESLint][] Parser/Plugin for [MDX][], helps you lint all ES syntaxes.
> Linting `code` blocks can be enabled with `mdx/code-blocks` setting too!
> Work perfectly with `eslint-plugin-import`, `eslint-plugin-prettier` or any other eslint plugins.
> And also can be integrated with [remark-lint][] plugins to lint markdown syntaxes.## TOC
- [VSCode Extension](#vscode-extension)
- [Packages](#packages)
- [Install](#install)
- [Notice](#notice)
- [Usage](#usage)
- [Classic](#classic)
- [Flat Config](#flat-config)
- [Parser Options](#parser-options)
- [Parser API](#parser-api)
- [`MDXCode`](#mdxcode)
- [`MDXHeading`](#mdxheading)
- [Typings](#typings)
- [Rules](#rules)
- [mdx/remark](#mdxremark)
- [Prettier Integration](#prettier-integration)
- [Sponsors](#sponsors)
- [Backers](#backers)
- [Changelog](#changelog)
- [License](#license)## VSCode Extension
[data:image/s3,"s3://crabby-images/8a0a1/8a0a18ae10b5fea0d408ac657d1267384cb1093e" alt="Visual Studio Marketplace Version"](https://marketplace.visualstudio.com/items?itemName=unifiedjs.vscode-mdx)
[VSCode MDX][]: Integrates with [VSCode ESLint][], syntaxes highlighting and error reporting.
## Packages
This repository is a monorepo managed by [changesets][] what means we actually publish several packages to npm from same codebase, including:
| Package | Description | Version |
| -------------------------------------------------- | ---------------------------------------------- | ------------------------------------------------------------------------------------------------------------- |
| [`eslint-mdx`](/packages/eslint-mdx) | ESLint Parser for MDX | [data:image/s3,"s3://crabby-images/14b38/14b383e2c4daf69fff88dbdec2e265a1f2e63669" alt="npm"](https://www.npmjs.com/package/eslint-mdx) |
| [`eslint-plugin-mdx`](/packages/eslint-plugin-mdx) | ESLint Plugin, Configuration and Rules for MDX | [data:image/s3,"s3://crabby-images/57c86/57c86ebdb5bc28d3df9d3d1089eaf8342d0350c7" alt="npm"](https://www.npmjs.com/package/eslint-plugin-mdx) |## Install
```sh
# yarn
yarn add -D eslint-plugin-mdx# npm
npm i -D eslint-plugin-mdx
```## Notice
If you're using multi languages, `js/jsx/ts/tsx/vue`, etc for example, you'd better to always use [`overrides`](https://eslint.org/docs/user-guide/configuring/configuration-files#how-do-overrides-work) feature of ESLint, because configs may be overridden by following configs.
See [#251](https://github.com/mdx-js/eslint-mdx/issues/251#issuecomment-736139224) for more details.
## Usage
### Classic
`.eslintrc` file:
```jsonc
{
"extends": ["plugin:mdx/recommended"],
// optional, if you want to lint code blocks at the same time
"settings": {
"mdx/code-blocks": true,
// optional, if you want to disable language mapper, set it to `false`
// if you want to override the default language mapper inside, you can provide your own
"mdx/language-mapper": {}
}
}
```### Flat Config
`eslint.config.js` file:
```js
import * as mdx from 'eslint-plugin-mdx'export default [
{
...mdx.flat,
// optional, if you want to lint code blocks at the same
processor: mdx.createRemarkProcessor({
lintCodeBlocks: true,
// optional, if you want to disable language mapper, set it to `false`
// if you want to override the default language mapper inside, you can provide your own
languageMapper: {},
}),
},
{
...mdx.flatCodeBlocks,
rules: {
...mdx.flatCodeBlocks.rules,
// if you want to override some rules for code blocks
'no-var': 'error',
'prefer-const': 'error',
},
},
]
```Then, make sure ESLint knows to run on `.md` or `.mdx` files:
```sh
eslint . --ext js,md,mdx
```## Parser Options
1. `extensions` (`string | string[]`): `eslint-mdx` will only resolve `.mdx` files by default, if you want to resolve other extensions as like `.mdx`, you can use this option.
2. `markdownExtensions` (`string | string[]`): `eslint-mdx` will only treat `.md` files as plain markdown by default, and will lint them via remark plugins. If you want to resolve other extensions as like `.md`, you can use this option.
3. `ignoreRemarkConfig` (`boolean`): Ignore the `remark` configuration defined in the project.
## Parser API
### `MDXCode`
A new `MDXCode` estree node type is exported from `eslint-mdx` which represents code blocks in `mdx` like the following:
````mdx
```js
export function foo() {
return 'bar'
}
```
````See also
### `MDXHeading`
A new `MDXHeading` estree node type is exported from `eslint-mdx` which represents markdown heading in `mdx` like the following:
```mdx
# Here's a text gradient short code!
```See also
### Typings
```ts
import type { BaseNode } from 'estree'
import type { JSXElement } from 'estree-jsx'export interface MDXCode extends BaseNode {
type: 'MDXCode'
value: string
lang?: string | null
meta?: string | null
}export type HeadingDepth = 1 | 2 | 3 | 4 | 5 | 6
export interface MDXHeading extends BaseNode {
type: 'MDXHeading'
depth: HeadingDepth
children: JSXElement['children']
}
```## Rules
### mdx/remark
_possible fixable depends on your remark plugins_:
Integration with [remark-lint][] plugins, it will read [remark's configuration](https://github.com/remarkjs/remark/tree/master/packages/remark-cli#remark-cli) automatically via [unified-engine][]. But `.remarkignore` will not be respected, you should use `.eslintignore` instead.
If you want to disable or change severity of some related rules, it won't work by setting rules in eslint config like `'remark-lint-no-duplicate-headings': 0`, you should change your remark config instead like following:
```jsonc
{
"plugins": [
"@1stg/remark-config",
// change to error severity, notice `[]` is required
["lint-no-duplicate-headings", [2]],
// disable following plugin
[
"lint-no-multiple-toplevel-headings",
[0] // or false
]
]
}
```## Prettier Integration
If you're using [remark-lint][] feature with [Prettier][] both together, you can try [remark-preset-prettier][] which helps you to _turn off all rules that are unnecessary or might conflict with [Prettier][]_.
```json
{
"plugins": [
"preset-lint-consistent",
"preset-lint-recommended",
"preset-lint-markdown-style-guide",
"preset-prettier"
]
}
```## Sponsors
| 1stG | RxTS | UnTS |
| ---------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------- |
| [data:image/s3,"s3://crabby-images/adc9b/adc9b275256c64dbe5465f478e033a0ea1b2e128" alt="1stG Open Collective backers and sponsors"](https://opencollective.com/1stG) | [data:image/s3,"s3://crabby-images/b87e5/b87e51754fa34c1228625c9959f2bc3aeb2afee6" alt="RxTS Open Collective backers and sponsors"](https://opencollective.com/rxts) | [data:image/s3,"s3://crabby-images/6a2db/6a2db9c093038461f071c151993d546e5f946694" alt="UnTS Open Collective backers and sponsors"](https://opencollective.com/unts) |[data:image/s3,"s3://crabby-images/d50f8/d50f8ed8fbcdc858d8950c9ea967cb6828e89eef" alt="unified Open Collective backers and sponsors"](https://opencollective.com/unified)
## Backers
[data:image/s3,"s3://crabby-images/dd7a7/dd7a7fa09a4d825ad3d45a007d107b56c8438c95" alt="Backers"](https://github.com/sponsors/JounQin)
| 1stG | RxTS | UnTS |
| -------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------- |
| [data:image/s3,"s3://crabby-images/89c3f/89c3fef0a65c570e0d29fcd693d5e9f30caffdea" alt="1stG Open Collective backers and sponsors"](https://opencollective.com/1stG) | [data:image/s3,"s3://crabby-images/a2070/a207047efa76b17ecc32da45dd663515c8508cd4" alt="RxTS Open Collective backers and sponsors"](https://opencollective.com/rxts) | [data:image/s3,"s3://crabby-images/43262/43262bb44d28eb519f997f97c61eddda02304783" alt="UnTS Open Collective backers and sponsors"](https://opencollective.com/unts) |[data:image/s3,"s3://crabby-images/81d12/81d124451a8838af9056b6a40216759061d45e5e" alt="unified Open Collective backers and sponsors"](https://opencollective.com/unified)
## Changelog
Detailed changes for each release are documented in [CHANGELOG.md](./CHANGELOG.md).
## License
[MIT][] © [JounQin][]@[1stG.me][]
[1stg.me]: https://www.1stg.me
[changesets]: https://github.com/changesets/changesets
[eslint]: https://eslint.org
[jounqin]: https://github.com/JounQin
[mdx]: https://github.com/mdx-js/mdx
[mit]: http://opensource.org/licenses/MIT
[prettier]: https://prettier.io
[remark-lint]: https://github.com/remarkjs/remark-lint
[remark-preset-prettier]: https://github.com/un-ts/remark-preset-prettier
[unified-engine]: https://github.com/unifiedjs/unified-engine
[vscode eslint]: https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint
[vscode mdx]: https://github.com/mdx-js/mdx-analyzer/tree/main/packages/vscode-mdx