@sentry/babel-plugin-component-annotate
Version:
A Babel plugin that annotates frontend components with additional data to enrich the experience in Sentry
96 lines (66 loc) • 3.25 kB
Markdown
<p align="center">
<a href="https://sentry.io/?utm_source=github&utm_medium=logo" target="_blank">
<img src="https://sentry-brand.storage.googleapis.com/sentry-wordmark-dark-280x84.png" alt="Sentry" width="280" height="84">
</a>
</p>
# Sentry Babel Component Annotate Plugin
[](https://www.npmjs.com/package/@sentry/babel-plugin-component-annotate)
[](https://www.npmjs.com/package/@sentry/babel-plugin-component-annotate)
[](https://www.npmjs.com/package/@babel-plugin-component-annotate)
A Babel plugin that automatically annotates your output DOM with their respective frontend component names.
This will unlock the capability to search for Replays in Sentry by component name, as well as see component names in breadcrumbs and performance monitoring.
Please note that your Sentry JavaScript SDK version must be at least `7.91.0` to take advantage of these features.
Currently, this plugin only works with React, and will exclusively parse `.jsx` and `.tsx` files.
### Note
This plugin comes included in Sentry's bundler plugins, alongside many other features to improve your Sentry workflow.
It can be downloaded individually, but it is recommended that you install the bundler plugins for your respective bundler, and enable this feature through the config object.
Check out the supported bundler plugin packages for installation instructions:
- [Rollup](https://www.npmjs.com/package/@sentry/rollup-plugin)
- [Vite](https://www.npmjs.com/package/@sentry/vite-plugin)
- [Webpack](https://www.npmjs.com/package/@sentry/webpack-plugin)
- esbuild: Not currently supported
## Installation
Using npm:
```bash
npm install @sentry/babel-plugin-component-annotate --save-dev
```
Using yarn:
```bash
yarn add @sentry/babel-plugin-component-annotate --dev
```
Using pnpm:
```bash
pnpm add @sentry/babel-plugin-component-annotate --save-dev
```
## Options
### `ignoredComponents`
Type: `string[]`
A list of strings representing the names of components to ignore. The plugin will not apply `data-sentry` annotations on the DOM element for these components.
## Example
```js
// babel.config.js
{
// ... other config above ...
plugins: [
// Put this plugin before any other plugins you have that transform JSX code
// The options are set by providing an object as the second element in the array, but not required
['@sentry/babel-plugin-component-annotate', {ignoredComponents: ['Foo', 'Bar']}]
],
}
```
Or alternatively, configure the plugin by directly importing it:
```js
// babel.config.js
import componentNameAnnotatePlugin from '@sentry/babel-plugin-component-annotate';
{
// ... other config above ...
plugins: [
// Put this plugin before any other plugins you have that transform JSX code
[componentNameAnnotatePlugin]
],
}
```
## More information
- [Sentry Documentation](https://docs.sentry.io/quickstart/)
- [Sentry Discord](https://discord.gg/Ww9hbqr)
- [Sentry Stackoverflow](http://stackoverflow.com/questions/tagged/sentry)