Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@sentry/babel-plugin-component-annotate

getsentry6.8mMIT3.0.0TypeScript support: included

A Babel plugin that annotates frontend components with additional data to enrich the experience in Sentry

Sentry, React, bundler, plugin, babel, component, annotate

readme

Sentry

Sentry Babel Component Annotate Plugin

npm version npm dm npm dt

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:

Installation

Using npm:

npm install @sentry/babel-plugin-component-annotate --save-dev

Using yarn:

yarn add @sentry/babel-plugin-component-annotate --dev

Using pnpm:

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

// 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:

// 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

changelog

Changelog

Unreleased

  • "You know what they say ‘Fool me once, strike one, but fool me twice… strike three.’" — Michael Scott

3.1.0

  • feat(webpack): Gate forced process exit behind experimental flag (#663)

3.0.0

Breaking Changes

  • Injected code will now use let, which was added in ES6 (ES2015). This means that ES6 is the minimum JavaScript version that the Sentry bundler plugins support.

  • Deprecated options have been removed:

    • deleteFilesAfterUpload - Use filesToDeleteAfterUpload instead
    • bundleSizeOptimizations.excludePerformanceMonitoring - Use bundleSizeOptimizations.excludeTracing instead
    • _experiments.moduleMetadata - Use moduleMetadata instead
    • cleanArtifacts - Did not do anything

List of Changes

  • fix!: Wrap injected code in block-statement to contain scope (#646)
  • chore!: Remove deprecated options (#654)
  • feat(logger): Use console methods respective to log level (#652)
  • fix(webpack): Ensure process exits when done (#653)
  • fix: Use correct replacement matcher for bundleSizeOptimizations.excludeTracing (#644)

Work in this release contributed by @jdelStrother. Thank you for your contribution!

2.23.0

  • chore(deps): bump nanoid from 3.3.6 to 3.3.8 (#641)
  • feat(core): Detect Railway release name (#639)
  • feat(core): Write module injections to globalThis (#636)
  • feat(react-component-annotate): Allow skipping annotations on specified components (#617)
  • ref(core): Rename release management plugin name (#647)

Work in this release contributed by @conor-ob. Thank you for your contribution!

2.22.7

  • deps: Bump @sentry/cli to 2.39.1 and require specific version (#632)
  • feat(telemetry): Record if plugin is run in CI (#627)

2.22.6

  • fix(core): Use sha256 instead of md5 to generate uuids from string (#619)

2.22.5

  • fix: Ignore stderr output from git command (#613)
  • feat: Update Sentry telemetry to v8 (#604)
  • deps: Update @sentry/cli to 2.36.1 (#609)

2.22.4

  • feat(react-component-annotate): Handle function body returning a ternary (#598)
  • fix: Allow injection plugins to apply to files with query parameters and fragments in their name (#597)

Work in this release contributed by @Thristhart. Thank you for your contribution!

2.22.3

  • fix(core): Always instantiate global Error class in injected code snippets (#594)

2.22.2

  • fix: Disable debug ID injection when sourcemaps.disable is set (#589)

2.22.1

  • fix: Use sourcemaps.disable to disable debug ID upload instead of legacy upload (#587)
  • fix: Escape release string in injection snippet (#585)

2.22.0

  • deps: Bump @sentry/cli to 2.33.1 (#581)
  • feat: Add bundleSizeOptimizations.excludeTracing option as alias to deprecated bundleSizeOptimizations.excludePerformanceMonitoring (#582)
  • fix(vite-plugin): Ensure post order of sentry-vite-release-injection-plugin to avoid breaking @rollup/plugin-commonjs step (#578)

2.21.1

  • fix: Do not delete files before all upload tasks executed (#572)

Work in this release contributed by @tyouzu1. Thank you for your contribution!

2.21.0

  • fix: Use sequential and post order for vite artifact deletion (#568)
  • feat: Add option to disable sourcemaps (#561)

Work in this release contributed by @tyouzu1. Thank you for your contribution!

2.20.1

  • feat(telemetry): Collect whether applicationKey is set (#559)
  • fix: Wait for tasks depending on sourcemaps before deleting (#557)

2.20.0

  • feat: Export esbuild plugin as default (#555)

2.19.0

  • feat: Don't use word "error" in log message about telemetry (#548)
  • feat(core): Detect releases from more providers (#549)
  • fix: Always delete files when sourcemaps.filesToDeleteAfterUpload is set (#547)
  • fix(vite): Fix environment variable loading issue for Windows (#545)

Work in this release contributed by @Rassilion, and @mateusz-daniluk-xtb. Thank you for your contributions!

2.18.0

  • feat: Add applicationKey option to identify application code from within the SDK (#540)
  • feat: Allow passing of meta-framework as telemetry data (#539)
  • feat: Promote experimental moduleMetadata option to stable (#538)
  • fix(esbuild): Invert warning about bundle: true (#542)

2.17.0

  • feat: Deprecate and noop cleanArtifacts (#525)
  • feat: Support Heroku env vars when inferring release name (#517)
  • fix(docs): Update pnpm install commands (#516)
  • misc(esbuild): Log warning when attempting to inject debug IDs with esbuild bundle option active (#526)

Work in this release contributed by @et84121, and @duailibe. Thank you for your contributions!

2.16.1

  • fix: Create word-based fidelity source mapping for code transformations (#513)
  • fix: Also match .cjs and .mjs files when finding files to upload in rollup-based bundlers (#509)

2.16.0

  • feat(core): Add loggerPrefixOverride meta option (#506)

2.15.0

  • feat: Make options argument optional (#502)
  • ref(annotate): Turn disabled message to debug log (#504)

2.14.3

  • deps(core): Unpin @babel/core, find-up, and glob (#496)

Work in this release contributed by @allanlewis. Thank you for your contribution!

2.14.2

  • feat(core): Bundle in Sentry SDK deps (#487)

2.14.1

  • fix(core): Stop .env files from being picked up (#486)
  • feat(core): Add telemetry for React component annotations (#482)

2.14.0

  • ref(component-annotate): Use default export (#478)

2.13.0

  • ref(component-annotate): Conform to Babel plugin naming conventions

2.12.0

  • ref(component-annotate): Prefix plugin name with babel

2.11.0

  • feat(core): Include component name annotation plugin with all bundler plugins except esbuild (#469)
  • feat(component-annotate): Introduce new plugin to annotate frontend components at build-time (#468)

2.10.3

  • fix(core): Safely flush telemetry

2.10.2

  • deps(core): Bump @sentry/cli to ^2.22.3 (#451)

2.10.1

  • chore: bump @sentry/cli dependency to 2.21.4 (#440)

2.10.0

  • feat: deprecate excludeReplayCanvas config (#436)
  • feat: Add excludeReplayWorker to bundleSizeOptimizations (#433)

2.9.0

  • feat: Allow to configure bundleSizeOptimizations (#428)
  • fix(core): Don't abort source map location guessing when the reference is a URL (#424)
  • fix(core): Widen detection of source maps with .cjs.map and .mjs.map (#422)

2.8.0

  • build(core): Bump Sentry CLI to v2.21.2 (#415)
  • feat: Detect release name for Bitbucket pipelines (#404)
  • feat: Detect release name for Flightcontrol (#411)
  • fix(core): Move git revision to a separate function (#399)
  • fix(esbuild): Don't inject debug IDs into injected modules (#417)

Work in this release contributed by @hoslmelq, @mjomble, and @aquacash5. Thank you for your contributions!

2.7.1

  • docs: Point to org auth token page (#393)
  • fix(webpack): Add default fallback to webpack import (#395)
  • fix: Save results of rewriteSourcesHook (#390)

Work in this release contributed by @adonskoy. Thank you for your contribution!

2.7.0

  • feat: Add module metadata injection for esbuild (#381)
  • feat: Add module metadata injection for vite and rollup (#380)
  • ref: Emit high resolution source-maps with magic-string (#383)
  • ref: Run upload preparation with maximum concurrency (#379)

2.6.2

  • fix: Fix regex in source map locating heuristic via sourceMappingURL (#376)
  • fix: Make sourceMappingURL heuristic more resilient (#378)

Thanks to @tomyam1 for identifying and pinpointing a bug that was hard to spot!

2.6.1

  • fix: Don't crash on failed delete after upload (#373)

2.6.0

  • deps: Bump sentry-cli to 2.20.1 (#355)
  • feat: Allow ommiting org when using organization auth token (#368)
  • ref: Make asset detection more robust (#369)

2.5.0

  • deps: Bump and unpin Sentry SDK deps (#353)
  • docs: Remove misleading documentation (#339)
  • feat: Add experimental module metadata injection (#334)
  • fix: Fix 'identifiy' typo in log messages (#341)

Work in this release contributed by @chunfeilung. Thank you for your contribution!

2.4.0

  • docs: Update instructions to install Vite plugin via pnpm (#331)
  • docs: Update minimum supported Node.js version to 14 (#327)
  • feat: Add configuration via .env.sentry-build-plugin file (#333)
  • ref: Use full git SHA for release name (#330)

Work in this release contributed by @ffxsam and @emilsivervik. Thank you for your contributions!

2.3.0

  • feat(webpack): Generate deterministic debug IDs (#321)
  • feat: Add filesToDeleteAfterUpload alias for deleteFilesAfterUpload (#313)
  • feat: Sort globbed files to ensure deterministic bundle IDs (#318)
  • fix(esbuild): Don't override user code with proxy module (#322)
  • fix(esbuild): Fix debug ID generation (#325)
  • fix: Use SENTRY_RELEASE environment variable to set release.name option (#317)

Work in this release contributed by @smbroadley. Thank you for your contribution!

2.2.2

  • fix(esbuild): Don't use namespace for esbuild proxy resolving (#311)
  • fix: Update commentUseStrictRegex to be lazy instead of greedy (#309)

Work in this release contributed by @jdk2pq. Thank you for your contribution!

2.2.1

  • fix(esbuild): Inject different debug IDs into different output bundles (#301)
  • fix(webpack): Set minimum webpack 4 peer dep to 4.40.0 (#290)
  • fix: Use magic-string appendLeft instead of replace (#303)
  • ref: Improve log message when sourcemap cannot be found (#287)

2.2.0

  • ref(core): Make better use of Sentry (#246)
  • ref(webpack): Use webpack peer dependency (#273)

Work in this release was made possible with help from @wojtekmaj and @dobladov. Thank you for your contributions!

2.1.0

  • docs: Add removal of configFile option to migration guide (#266)
  • feat: Auto detect build artifacts (#257)
  • fix(core): Ignore query and hash in filepaths for release injection (#272)
  • fix(esbuild): Use absolute path for virtual file resolving (#269)
  • fix: Don't show log message if telemetry is disabled (#267)
  • fix: Use automatic release name detection for release injection (#271)

2.0.0

Version 2.0.0 marks the official release of the @sentry/vite-plugin, @sentry/esbuild-plugin and @sentry/rollup-plugin packages. They are now considered stable.

For the @sentry/webpack-plugin this is a major release with breaking changes. Please refer to the migration guide for instructions on how to upgrade.

  • feat(core): Add deleteFilesAfterUpload option (#244)
  • feat(core): Implements rewrite sources for debug ID upload (#243)
  • fix(core): Account for undefined release name values (#251)
  • fix(webpack): Inject different debug IDs for different bundles (#242)
  • ref(core): Add new options type for future use (#216)
  • ref(core): Extract debug ID injection into separate plugins (#230)
  • ref(core): Extract debug ID sourcemap upload into a separate plugin (#231)
  • ref(core): Extract release injection into separate plugins (#218)
  • ref(core): Extract release management into a separate plugin (#232)
  • ref(core): Extract telemetry into a separate plugin (#234)
  • ref(core): Switch to v2 options (#237)
  • ref(core): Use debug ID as filename for upload (#247)
  • ref(core): Use factory function to create individual plugins (#229)
  • ref: Remove injectReleasesMap option (#236)

0.7.2

  • fix(core): Use createRequire to not use built-in require in ESM (#212)

0.7.1

  • fix(core): Fix vite complaining about CJS import of webpack-sources (#210)

0.7.0

This release introduces the sourcemaps option. This option switches to a new system of handling source maps in Sentry.

While the old system is still available via the include option, the recommended way forward is the sourcemaps option.

You can configure the sourcemaps option as follows:

plugin({
  org: "Your organization",
  project: "Your project",
  authToken: "Your auth token",

  sourcemaps: {
    // Specify the directory containing build artifacts
    assets: "./dist/**",
  },
});
  • feat(esbuild): Add debug ID injection for esbuild (#202)
  • feat: Promote debug ID uploading to stable via sourcemaps option (#204)
  • fix(core): Also do debug ID injection for .cjs files (#203)
  • fix: Add typing exports to packages (#208)

0.6.1

  • ref: Run upload preparation with maximum concurrency (#382)

0.6.0

  • feat(webpack): Add debug ID injection to the webpack plugin (#198)
  • fix(core): Don't exclude release injection module (#200)
  • ref(core): Don't interact with Sentry in watch-mode (#199)

Work in this release contributed by @hakubo. Thank you for your contribution!

0.5.1

  • fix(core): Skip all transformations for 3rd party modules

0.5.0

  • feat(core): Add injectRelease and uploadSourceMaps options (#190)
  • feat(core): Add experimental debug ID based source map upload to Rollup and Vite plugins (#192)
  • feat(core): Import release injection code from each module (#188)
  • feat: Add _experiments.injectBuildInformation option (#176)
  • feat: Add sentryCliBinaryExists function (#171)

Work in this release contributed by @alexandresoro and @dcyou. Thank you for your contributions!

0.4.0

This release contains breaking changes. Please refer to the migration guide on how to update from version 0.3.x to 0.4.x.

  • deps(core): Bump unplugin version (#164)
  • ref(core): Only inject release into entrypoints per default (#166) (BREAKING)
  • ref: Remove customHeader option (#167) (BREAKING)
  • ref: Turn default exports into named exports (#165) (BREAKING)

Work in this release contributed by @manniL. Thank you for your contribution!

0.3.0

Note: This release bumps the @sentry/cli dependency from version 1.x to version 2.x.

  • feat(core): Add headers option (#153)

Work in this release contributed by @robertcepa. Thank you for your contribution!

0.2.4

  • build(core): Update magic-string due to deprecated dependency (#146)
  • ref(core): Send project as dist in telemetry (#148)

Work in this release contributed by @jperelli. Thank you for your contribution!

0.2.3

  • fix: Exclude node_modules from release injection (#143)

0.2.2

  • feat(core): Remove server_name from telemetry events (#135)
  • fix: Add definitions in package.json for ESM resolution (#141)
  • fix(core): Finish spans when CLI commands fail (#136)
  • ref(core): Decouple breadcrumb usage from logger (#138)
  • ref(core): Don't record stack traces for telemetry (#137)

0.2.1

  • fix(core): Fix telemetry option logic (#128)
  • fix(core): Normalize id and releaseInjectionTargets in transformInclude (#132)

0.2.0

This release replaces the entries option with releaseInjectionTargets which is a breaking change from previous versions. For more information, take a look at the migration guide.

  • feat: Replace entries option with releaseInjectionTargets (#123)

0.1.0

With this release, the Sentry bundler plugins support all features of the standalone Sentry Webpack plugin. Please note that breaking changes might still be introduced.

  • Re-added Sentry CLI to the project (#85). The bundler plugins use Sentry CLI to create releases and upload sourcemaps
  • Added missing Release creation steps
    • feat(core): Add setCommits (#96)
    • feat(core): Add deploy command (#97)
  • Added validation of plugin options (#104)
  • Refined telemetry option to only send events to Sentry for projects uploading source maps to Sentry's SaaS instance (#99). For self-hosted Sentry servers, nothing will be sent to Sentry.
  • Updated README.md files with examples and option descriptions for each bundler plugin (#117)

Link to Full Changelog

0.0.1-alpha.0

This release marks the first release of the Sentry bundler blugins. This is still a heavy work in progress and a lot of things are still missing and subject to change

  • Initial release