Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rodrigofontesdev/pizza
A restaurant dashboard built with React and Bun.
https://github.com/rodrigofontesdev/pizza
bun playwright postgresql react react-query study-project tailwindcss testing-library typescript vitest
Last synced: about 19 hours ago
JSON representation
A restaurant dashboard built with React and Bun.
- Host: GitHub
- URL: https://github.com/rodrigofontesdev/pizza
- Owner: rodrigofontesdev
- License: mit
- Created: 2024-05-21T13:00:56.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-07-25T21:35:22.000Z (6 months ago)
- Last Synced: 2024-11-11T06:19:57.702Z (about 2 months ago)
- Topics: bun, playwright, postgresql, react, react-query, study-project, tailwindcss, testing-library, typescript, vitest
- Language: TypeScript
- Homepage:
- Size: 228 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![cover](https://github.com/user-attachments/assets/d6b16526-c4d6-4f36-ae40-46e2c9aa34d1)
# Pizza Shop
A restaurant dashboard to track key metrics such as revenue by period, customer retention, daily and monthly orders, best-selling products, manage orders, and more.
The goal is to develop an application without using any framework, relying solely on React to integrate the front-end with a back-end via REST API.
## Prerequisites
- Bun
- Node.js
- Docker
- PostgreSQL
- Git## Getting Started
### Back-end
- Clone the repository (`git clone [email protected]:rodrigofontesdev/pizza-api.git`)
- Install dependencies (`bun install`)
- Copy .env.local.example file (`cp .env.local.example .env.local`)
- Update [Resend](https://resend.com) key on .env.local file (from `RESEND_API_KEY=""` to `RESEND_API_KEY="."`), it should work
- Run containers (`docker compose up -d`)
- Check if container is running (`docker ps`)
- Install migrations (`bun migrate`)
- Open the seed file (`/src/db/seed.ts`) and update the restaurant manager email to your own email
- Populate the database (`bun seed`)
- Run application (`bun dev`)### Front-end
- Clone the repository (`git clone [email protected]:rodrigofontesdev/pizza.git`)
- Install dependencies (`npm install`)
- Copy .env.example file (`cp .env.example .env`)
- Run application (`npm run dev`)## Features
- Create an account as restaurant manager
- Passwordless login with magic link
- Logout from account
- Update restaurant profile
- Toggle between dark and light theme
- Revenue by period
- Best-selling products
- Daily and monthly orders
- Monthly canceled orders
- Filter orders by ID, customer name or status
- Remove order filters
- Open order in details
- Manage order status
- Paginate between orders## How to Use
### Create an account
Visit the `/sign-up` route, you must be able to create an account as a restaurant manager and sign in normally on the app. However, your dashboard will remain empty.
### Sign-in with magic link
Visit the `/sign-in` route, fill in the email address that you updated in the seed file. For now, transactional email sending is still disabled, but you can obtain the magic link in the back-end console. Open the link in your browser, and you will be automatically redirected to the dashboard.
> [!NOTE]
> See how to run the API server on the [Getting Started section](#getting-started) on this document.
>
> I plan to activate transactional email sending using a tool other than Resend service.### Manage orders
Visit the `/orders` route, filter orders by status or other criteria, click on the left-side icon to see the order details or click the right-side action buttons to manage the statuses.
## How to Test
In this application unit tests are built with [Vitest](https://github.com/vitest-dev/vitest), [Testing Library](https://github.com/testing-library/react-testing-library) and [Happy Dom](https://github.com/capricorn86/happy-dom). On the other hand, E2E tests are built with [Playwright](https://github.com/microsoft/playwright) and [Mock Service Worker](https://github.com/mswjs/msw).
To run the unit tests, open the front-end console and type: `npm run test`
> [!NOTE]
> Inside the tested components you can find a file with `.spec.tsx` extension, these files are located closest as possible to the target component.To run end-to-end tests, first start the app in test mode by running `npm run dev:test` in the console. Once the app is mocked, open a new terminal and run `npx playwright test` for CI execution or `npx playwright test --ui` for the Playwright interface.
> [!NOTE]
> Inside `/src/api/mocks` you can find the mocks for the API. And inside `/test` are located the end-to-end tests.**Environment Variables**
| Key | Value | .ENV | Description |
| :------------ | :------------ | :------------ | :------------ |
| VITE_API_URL | "string" (default: `http://localhost:3333`) | | Indicates the URL from the API, in test mode should be `"/"` |
| VITE_ENABLE_API_DELAY | `true` \| `false` | | Enable or disable delay in the API, useful for simulating a non-local connection |
| API_BASE_URL | "string" (default: `http://localhost:3333`) | API | Indicates the base URL for the API |
| AUTH_REDIRECT_URL | "string" (default: `http://localhost:5173`) | API | Indicates the URL from the front-end application |
| DB_URL | "string" (default: `docker container`) | API | URL for connection with the database, can be any Postgres service from your machine |
| JWT_SECRET_KEY | "string" | API | A strong, randomly generated secret key is required for JSON Web Token security |
| RESEND_API_KEY | "string" | API | `deprecated` |## I've Learned
- Create pre-styled components with shadcn/ui
- Provide SEO metatags with React Helmet Async
- Create a theme toggle with dark and light mode (`Context API`)
- Fetch, cache, synchronize and update server state with TanStack Query (also know as React Query)
- Differences between local state, global state and HTTP state (server state)
- Authentication with JWT Cookie approach
- How and when to use optimistic interface to improve user experience
- Create unit and end-to-end tests for the front-end
- How and why to mock an API service## Built With
- React
- TypeScript
- shadcn/ui
- Tailwind CSS
- TanStack Query (React Query)
- Playwright
- Vitest
- Testing Library
- Mock Service Worker## Credits
Special thanks to [@rocketseat-education](https://github.com/rocketseat-education) for contributing to the back-end. See the original [Pizza Shop API](https://github.com/rocketseat-education/pizzashop-api).
## License
This project is licensed under the MIT License - see the [LICENSE.md](LICENSE) file for details.