Reactive is a powerful VS Code extension designed to enhance the development experience for React applications. Developed as part of the OSLabs program, this tool provides a comprehensive visual representation of your React component structure, making it easier to understand and navigate React projects.
- Open VS Code.
- Go to the Extensions view (
Ctrl+Shift+X
). - Search for "Reactive".
- Click Install.
- Open a React project in VS Code.
- Access the Reactive from the VS Code sidebar.
- Click on components in the tree to collapse.
- Click on State within component node to open State details
Learn how to get started with Reactive through these video guides:
How to Download ReactiveThis video walks you through downloading and using the Reactive VS Code extension: https://www.youtube.com/watch?v=KttJvc9F2a8
How to Make a vsix file and use it: https://www.youtube.com/watch?v=pF-JJ7jmMp4
- Component Tree Visualization: Procure a clear, hierarchical view of your React component structure.
- Component Type Differentiation: Easily distinguish between functional and class components.
- Language Identification: Quickly identify TypeScript and JavaScript components.
- Full App Structure: Visualize the entire structure of your React application.
- State Inspection: Identify state variables across components.
Oftentimes as applications scale, it becomes increasingly challenging to keep track of the structure of an app. As a result, this extends the amount of time it takes for new developers to understand the application landscape and makes it impractical to keep track of code migration progress.
Reactive aims to solve this problem by generating a visual representation of your app's component landscape within VS Code. This extension enables greater visibility into the architecture of the React app and is especially valuable for teams transitioning from class-based components to functional components, as well as from JavaScript to TypeScript.
We love your input! Reactive is an open-source project, and we welcome contributors of all skill levels.
# Fork and clone the repository
git clone https://github.com/your-username/reactive.git
# Install dependencies
npm install
# Start development environment
npm run dev
- Fix bugs and issues
- Add new features
- Improve documentation
- Submit feature requests
- Report bugs
- Review code
- First Time Contributors: Check out our First-Time Contributors Guide
- Ready to Code: See our Contribution Guidelines
- Looking for Tasks: Browse our good first issues
For detailed setup instructions, coding guidelines, and best practices, see our CONTRIBUTING.md.
-
Fork & Clone
# Fork the repository first on GitHub, then: git clone https://github.com/your-username/reactive.git cd reactive
-
Install Dependencies
npm install
-
Initial Build
npm run build
-
Start Development
# Watch mode for automatic rebuilds npm run watch
-
Launch Extension in Debug Mode
- Press
F5
in VS Code to open Extension Development Host - OR select Run > Start Debugging
- A new VS Code window will open with the extension loaded
- Press
-
Test the Extension
- Open a React project in the Extension Development Host
- Press
Ctrl+Shift+P
(Windows/Linux) orCmd+Shift+P
(Mac) - Type and select
Reactive: Start
- Select the highest-level component in your React application
- The component tree visualization will appear
# Start or Refresh debugger/Extension Development Host
fn F5
# Create production build
npm run build:prod
# Package extension into .vsix file
npm run package
# Test the packaged extension
# 1. In VS Code, in the Extensions view click the '...' menu (top left)
# 2. Select 'Install from VSIX...'
# 3. Choose the generated .vsix file
# 4. Press `Ctrl+Shift+P` (Windows/Linux) or `Cmd+Shift+P` (Mac)
# 5. Type and select `Reactive: Start`
# 6. Select the highest-level component in your React application
# The component tree visualization will appear
- Use VS Code's Debug Console to view extension logs
- Set breakpoints in the TypeScript files
- Use
console.log
in the webview (outputs to DevTools in Extension Development Host) - Access Extension Development Host's Developer Tools:
- Help > Toggle Developer Tools
- If the extension bla bla bla:
- Stop the extension
- Run ``
- Restart debugging (
F5
)
- If webview bla bla bla:
- Run Command ? (
Ctrl+Shift+P
) - Execute "bla bla bla"
- Run Command ? (
For detailed information about the npm scripts available in the project, their purposes, and when to use them during development, please refer to the Development Scripts Guide.
- VS Code Extension API - For extension development and VS Code integration
- React 18 - Frontend framework for the webview interface
- TypeScript/JavaScript - Primary development languages
- D3.js - For component tree visualization and dendrograms
- Webpack 5 - Module bundling for both extension and webview
- Babel - JavaScript/TypeScript compilation and React preprocessing
- ESLint - Code quality and style checking
- Mocha - Testing framework
- Backend: Node.js-based VS Code extension (TypeScript/JavaScript)
- Frontend: React-based webview (TypeScript/JavaScript)
- Parser: Custom React component parser using Babel
reactive/
├── src/ # Source code
│ ├── server/ # Extension backend (TS/JS)
│ ├── webview/ # React frontend (TS/JS)
│ └── test/ # Test suites
├── dist/ # Frontend production builds
└── out/ # Backend builds (dev/prod) & frontend dev builds
Name | Role | GitHub | |
---|---|---|---|
Colin Rooney | Software Engineer | @12mv2 | [email protected] |
Micah Zeigler | Software Engineer | @MZiegler96 | [email protected] |
Susana Lam | Software Engineer | @susanalam | [email protected] |
If you encounter any issues or have feature requests, please file an issue on our GitHub repository Reactive, https://github.com/oslabs-beta/reactive.
React Visualizer is a project developed through OSLabs, a nonprofit tech accelerator focused on advancing open-source software and fostering innovation in the tech industry. OSLabs is dedicated to supporting engineers and leaders building high-impact, collaborative open-source tools.
OSLabs' Mission: OSLabs is devoted to furthering open-source innovation by supporting engineering talent in creating developer tools that contribute to the software engineering community and industry as a whole.
For more information about OSLabs:
- Visit: OSLabs Website
- Email: [email protected]
- Phone: (601) 207-4517
- Engineering Fellowship: A paid 6-month program where engineers create and oversee open-source dev tool projects.
- Beta Program: A 3-month initiative where participants receive mentorship to build their open-source skills.
- Hackathons: Co-hosted hackathons with open-source-focused organizations.
This project was developed as part of the OSLabs program. We'd like to thank OSLabs for their support and resources.
Happy coding with Reactive!