mirror of
https://github.com/Significant-Gravitas/AutoGPT.git
synced 2026-02-11 15:25:16 -05:00
This PR integrates React Query DevTools and ESLint rules to improve the
development workflow and enforce best practices for data fetching.
### Changes:
- **React Query DevTools:**
- Added the `@tanstack/react-query-devtools` package.
- DevTools are enabled by default in the development environment.
- They can be disabled by setting
`NEXT_PUBLIC_REACT_QUERY_DEVTOOL=false` in your environment variables.
- **ESLint Rules:**
- Integrated `@tanstack/eslint-plugin-query` to enforce best practices
and catch common errors in React Query usage.
- **Configuration:**
- Added the `NEXT_PUBLIC_REACT_QUERY_DEVTOOL` variable to the
`.env.example` file so other developers are aware of this option.
- **Documentation:**
- Updated the `README.md` with instructions on how to toggle the
DevTools using the environment variable.
Configuration Changes Checklist
- `.env.example` has been updated with the new environment variable.
### Checklist
For code changes:
- [x] I have clearly listed my changes in the PR description
- [x] I have made a test plan
- [x] I have tested my changes according to the test plan:
- [x] Run the app in development with pnpm dev.
- [x] Verified DevTools toggle with environment variables
- [x] Run pnpm lint in the frontend directory.
- [x] Confirm that linting passes on the current codebase.
### Screenshot
<img width="1512" alt="Screenshot 2025-06-19 at 6 32 22 PM"
src="https://github.com/user-attachments/assets/a3defd23-2c3d-4d20-b152-037d85e04503"
/>
---------
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
165 lines
5.5 KiB
Markdown
165 lines
5.5 KiB
Markdown
This is the frontend for AutoGPT's next generation
|
|
|
|
## 🧢 Getting Started
|
|
|
|
This project uses [**pnpm**](https://pnpm.io/) as the package manager via **corepack**. [Corepack](https://github.com/nodejs/corepack) is a Node.js tool that automatically manages package managers without requiring global installations.
|
|
|
|
### Prerequisites
|
|
|
|
Make sure you have Node.js 16.10+ installed. Corepack is included with Node.js by default.
|
|
|
|
### ⚠️ Migrating from yarn
|
|
|
|
> This project was previously using yarn1, make sure to clean up the old files if you set it up previously with yarn:
|
|
>
|
|
> ```bash
|
|
> rm -f yarn.lock && rm -rf node_modules
|
|
> ```
|
|
>
|
|
> Then follow the setup steps below.
|
|
|
|
### Setup
|
|
|
|
1. **Enable corepack** (run this once on your system):
|
|
|
|
```bash
|
|
corepack enable
|
|
```
|
|
|
|
This enables corepack to automatically manage pnpm based on the `packageManager` field in `package.json`.
|
|
|
|
2. **Install dependencies**:
|
|
|
|
```bash
|
|
pnpm i
|
|
```
|
|
|
|
3. **Start the development server**:
|
|
```bash
|
|
pnpm dev
|
|
```
|
|
|
|
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
|
|
|
|
You can start editing the page by modifying `app/page.tsx`. The page auto-updates as you edit the file.
|
|
|
|
### Subsequent Runs
|
|
|
|
For subsequent development sessions, you only need to run:
|
|
|
|
```bash
|
|
pnpm dev
|
|
```
|
|
|
|
Every time a new Front-end dependency is added by you or others, you will need to run `pnpm i` to install the new dependencies.
|
|
|
|
### Available Scripts
|
|
|
|
- `pnpm dev` - Start development server
|
|
- `pnpm build` - Build for production
|
|
- `pnpm start` - Start production server
|
|
- `pnpm lint` - Run ESLint and Prettier checks
|
|
- `pnpm format` - Format code with Prettier
|
|
- `pnpm type-check` - Run TypeScript type checking
|
|
- `pnpm test` - Run Playwright tests
|
|
- `pnpm test-ui` - Run Playwright tests with UI
|
|
|
|
This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Inter, a custom Google Font.
|
|
|
|
## 🚚 Deploy
|
|
|
|
TODO
|
|
|
|
## 📙 Storybook
|
|
|
|
Storybook is a powerful development environment for UI components. It allows you to build UI components in isolation, making it easier to develop, test, and document your components independently from your main application.
|
|
|
|
### Purpose in the Development Process
|
|
|
|
1. **Component Development**: Develop and test UI components in isolation.
|
|
2. **Visual Testing**: Easily spot visual regressions.
|
|
3. **Documentation**: Automatically document components and their props.
|
|
4. **Collaboration**: Share components with your team or stakeholders for feedback.
|
|
|
|
### How to Use Storybook
|
|
|
|
1. **Start Storybook**:
|
|
Run the following command to start the Storybook development server:
|
|
|
|
```bash
|
|
pnpm storybook
|
|
```
|
|
|
|
This will start Storybook on port 6006. Open [http://localhost:6006](http://localhost:6006) in your browser to view your component library.
|
|
|
|
2. **Build Storybook**:
|
|
To build a static version of Storybook for deployment, use:
|
|
|
|
```bash
|
|
pnpm build-storybook
|
|
```
|
|
|
|
3. **Running Storybook Tests**:
|
|
Storybook tests can be run using:
|
|
|
|
```bash
|
|
pnpm test-storybook
|
|
```
|
|
|
|
For CI environments, use:
|
|
|
|
```bash
|
|
pnpm test-storybook:ci
|
|
```
|
|
|
|
4. **Writing Stories**:
|
|
Create `.stories.tsx` files alongside your components to define different states and variations of your components.
|
|
|
|
By integrating Storybook into our development workflow, we can streamline UI development, improve component reusability, and maintain a consistent design system across the project.
|
|
|
|
## 🔭 Tech Stack
|
|
|
|
### Core Framework & Language
|
|
|
|
- [**Next.js**](https://nextjs.org/) - React framework with App Router
|
|
- [**React**](https://react.dev/) - UI library for building user interfaces
|
|
- [**TypeScript**](https://www.typescriptlang.org/) - Typed JavaScript for better developer experience
|
|
|
|
### Styling & UI Components
|
|
|
|
- [**Tailwind CSS**](https://tailwindcss.com/) - Utility-first CSS framework
|
|
- [**shadcn/ui**](https://ui.shadcn.com/) - Re-usable components built with Radix UI and Tailwind CSS
|
|
- [**Radix UI**](https://www.radix-ui.com/) - Headless UI components for accessibility
|
|
- [**Lucide React**](https://lucide.dev/guide/packages/lucide-react) - Beautiful & consistent icons
|
|
- [**Framer Motion**](https://motion.dev/) - Animation library for React
|
|
|
|
### Development & Testing
|
|
|
|
- [**Storybook**](https://storybook.js.org/) - Component development environment
|
|
- [**Playwright**](https://playwright.dev/) - End-to-end testing framework
|
|
- [**ESLint**](https://eslint.org/) - JavaScript/TypeScript linting
|
|
- [**Prettier**](https://prettier.io/) - Code formatting
|
|
|
|
### Backend & Services
|
|
|
|
- [**Supabase**](https://supabase.com/) - Backend-as-a-Service (database, auth, storage)
|
|
- [**Sentry**](https://sentry.io/) - Error monitoring and performance tracking
|
|
|
|
### Package Management
|
|
|
|
- [**pnpm**](https://pnpm.io/) - Fast, disk space efficient package manager
|
|
- [**Corepack**](https://github.com/nodejs/corepack) - Node.js package manager management
|
|
|
|
### Additional Libraries
|
|
|
|
- [**React Hook Form**](https://react-hook-form.com/) - Forms with easy validation
|
|
- [**Zod**](https://zod.dev/) - TypeScript-first schema validation
|
|
- [**React Table**](https://tanstack.com/table) - Headless table library
|
|
- [**React Flow**](https://reactflow.dev/) - Interactive node-based diagrams
|
|
- [**React Query**](https://tanstack.com/query/latest/docs/framework/react/overview) - Data fetching and caching
|
|
- [**React Query DevTools**](https://tanstack.com/query/latest/docs/framework/react/devtools) - Debugging tool for React Query
|
|
|
|
### Development Tools
|
|
|
|
- `NEXT_PUBLIC_REACT_QUERY_DEVTOOL` - Enable React Query DevTools. Set to `true` to enable.
|