swc-plugin-component-annotate
v1.12.0
Published
Use SWC to automatically annotate React components with data attributes for component tracking
Readme
SWC Plugin: Component Annotate 
A SWC plugin that automatically annotates React components with data attributes for component tracking and debugging.
Overview
This plugin transforms React components by adding data attributes that help with tracking and debugging. It automatically identifies React components (function components, arrow function components, and class components) and adds the following attributes:
data-component: The component name (added to root elements)data-element: The element/component name (added to non-HTML elements)data-source-file: The source filename
Features
- ✅ Function Components:
function MyComponent() { ... } - ✅ Arrow Function Components:
const MyComponent = () => { ... } - ✅ Class Components:
class MyComponent extends Component { ... } - ✅ React Fragments: Supports
Fragment,React.Fragment, and<>syntax - ✅ Nested Components: Properly handles component hierarchies
- ✅ React Native Support: Uses camelCase attributes when configured
- ✅ Configurable: Ignore specific components, annotate fragments, etc.
Installation
npm install --save-dev swc-plugin-component-annotateUsage
Basic Configuration
Add the plugin to your .swcrc configuration:
{
"jsc": {
"experimental": {
"plugins": [
["swc-plugin-component-annotate", {}]
]
}
}
}Configuration Options
{
"jsc": {
"experimental": {
"plugins": [
["swc-plugin-component-annotate", {
"native": false,
"ignored-components": ["MyIgnoredComponent"],
"component-attr": "data-sentry-component",
"element-attr": "data-sentry-element",
"source-file-attr": "data-sentry-source-file"
}]
]
}
}
}Options
native(boolean, default:false): Use React Native attribute names (camelCase)false:data-component,data-element,data-source-filetrue:dataComponent,dataElement,dataSourceFile
ignored-components(array, default:[]): List of component names to skip during annotationcomponent-attr(string, optional): Custom component attribute name (overrides default and native setting)element-attr(string, optional): Custom element attribute name (overrides default and native setting)source-file-attr(string, optional): Custom source file attribute name (overrides default and native setting)
Sentry Integration
To use Sentry-specific attribute names for compatibility with Sentry's tracking:
{
"jsc": {
"experimental": {
"plugins": [
["swc-plugin-component-annotate", {
"component-attr": "data-sentry-component",
"element-attr": "data-sentry-element",
"source-file-attr": "data-sentry-source-file"
}]
]
}
}
}This will generate attributes like:
<div data-sentry-component="MyComponent" data-sentry-source-file="MyComponent.jsx">
<CustomButton data-sentry-element="CustomButton" data-sentry-source-file="MyComponent.jsx">
Click me
</CustomButton>
</div>Examples
Input
import React from 'react';
const MyComponent = () => {
return (
<div>
<h1>Hello World</h1>
<button>Click me</button>
</div>
);
};
export default MyComponent;Output
import React from 'react';
const MyComponent = () => {
return (
<div data-component="MyComponent" data-source-file="MyComponent.jsx">
<h1>Hello World</h1>
<button>Click me</button>
</div>
);
};
export default MyComponent;Class Component Example
// Input
class MyClassComponent extends Component {
render() {
return <div><h1>Hello from class</h1></div>;
}
}
// Output
class MyClassComponent extends Component {
render() {
return <div data-component="MyClassComponent" data-source-file="MyComponent.jsx">
<h1>Hello from class</h1>
</div>;
}
}React Native Example
With "native": true:
// Output
const MyComponent = () => {
return (
<View dataComponent="MyComponent" dataSourceFile="MyComponent.jsx">
<Text>Hello World</Text>
</View>
);
};