feat: finalize kinerja divisi feature implementation
Co-authored-by: Qwen-Coder <qwen-coder@alibabacloud.com>
This commit is contained in:
112
QWEN.md
Normal file
112
QWEN.md
Normal file
@@ -0,0 +1,112 @@
|
||||
# Darmasaba Dashboard Noc - Project Context
|
||||
|
||||
## Project Overview
|
||||
|
||||
**Darmasaba Dashboard Noc** is a high-performance, full-stack React development template leveraging the **Bun** runtime. It features a unique "Single Port" architecture that combines a Bun/Elysia backend with a React frontend running on the same port (3000), eliminating CORS issues and proxy complexity.
|
||||
|
||||
### Key Technologies
|
||||
- **Runtime**: Bun (Fast all-in-one JS runtime)
|
||||
- **Backend**: ElysiaJS (Fast, type-safe web framework)
|
||||
- **Frontend**: React 19 (UI Library)
|
||||
- **Routing**: TanStack React Router (Type-safe routing)
|
||||
- **UI Framework**: Mantine UI (Component library)
|
||||
- **Authentication**: Better Auth (Complete auth solution)
|
||||
- **Database**: Prisma ORM (Database toolkit)
|
||||
- **Testing**: Bun Test & Playwright
|
||||
|
||||
### Architecture Highlights
|
||||
- **Single Port Architecture**: Backend (Elysia) and Frontend (Vite Middleware) run on the same port (3000)
|
||||
- **Contract-First API**: Strictly typed API using OpenAPI with automatic frontend type synchronization
|
||||
- **PWA & TWA Support**: Ready for mobile with Service Workers, Web Manifest, and Android Trusted Web Activity verification
|
||||
- **React Dev Inspector**: Alt/Option + Click to jump directly to source code in VS Code
|
||||
|
||||
## Project Structure
|
||||
|
||||
```
|
||||
├── __tests__/ # Consolidated test suite (API & E2E)
|
||||
├── generated/ # Auto-generated API types and Prisma client
|
||||
├── prisma/ # Database schema and migrations
|
||||
├── scripts/ # Internal automation scripts
|
||||
└── src/
|
||||
├── api/ # Elysia backend route modules
|
||||
├── middleware/ # Backend & Frontend middlewares
|
||||
├── routes/ # TanStack file-based frontend routes
|
||||
├── store/ # Global state (Valtio)
|
||||
├── utils/ # Shared utilities (DB, Env, API Client)
|
||||
├── frontend.tsx # React client entry point
|
||||
└── index.ts # Unified server entry point
|
||||
```
|
||||
|
||||
## Building and Running
|
||||
|
||||
### Prerequisites
|
||||
Install [Bun](https://bun.sh/) if you haven't already.
|
||||
|
||||
### Installation
|
||||
```bash
|
||||
bun install
|
||||
```
|
||||
|
||||
### Setup Environment
|
||||
```bash
|
||||
cp .env.example .env
|
||||
# Fill in your DATABASE_URL and BETTER_AUTH_SECRET
|
||||
```
|
||||
|
||||
### Database Initialization
|
||||
```bash
|
||||
bun x prisma migrate dev
|
||||
```
|
||||
|
||||
### Start Development
|
||||
```bash
|
||||
bun run dev
|
||||
```
|
||||
- **App**: `http://localhost:3000`
|
||||
- **API Docs**: `http://localhost:3000/api/docs` (Swagger)
|
||||
|
||||
## Testing Commands
|
||||
|
||||
- **Unit/Integration (API)**: `bun run test`
|
||||
- **End-to-End (Browser)**: `bun run test:e2e`
|
||||
- **Visual Dashboard**: `bun run test:ui`
|
||||
|
||||
## Development Guidelines
|
||||
|
||||
- **API Workflow**:
|
||||
1. Define schema in `src/api/*.ts`.
|
||||
2. Run `bun run gen:api` (or just start `dev` mode).
|
||||
3. Use `apiClient` in the frontend with full type safety.
|
||||
- **Styling**: Prefer Mantine components and Style Props.
|
||||
- **Code Quality**: Code is automatically formatted on save if you have the Biome extension. Manual: `bun run check`.
|
||||
|
||||
## Key Configuration Files
|
||||
|
||||
- **biome.json**: Code formatting and linting rules (uses tabs, double quotes)
|
||||
- **tailwind.config.js**: Tailwind CSS configuration with custom Darmasaba color palette
|
||||
- **tsconfig.json**: TypeScript configuration with path aliases (`@/*` maps to `./src/*`)
|
||||
- **package.json**: Contains all scripts and dependencies
|
||||
- **playwright.config.ts**: End-to-end testing configuration
|
||||
|
||||
## Notable Features
|
||||
|
||||
1. **Hot Module Replacement**: The application supports HMR for rapid development
|
||||
2. **Type Safety**: Full type safety between frontend and backend through contract-first API design
|
||||
3. **Authentication**: Built-in authentication using Better Auth
|
||||
4. **Dark/Light Theme**: Automatic theme switching with Mantine UI
|
||||
5. **Responsive Design**: Mobile-first responsive design using Tailwind CSS and Mantine
|
||||
6. **Performance Optimized**: Optimized for production with proper bundling and minification
|
||||
|
||||
## Development Scripts
|
||||
|
||||
- `dev`: Starts the development server with HMR
|
||||
- `lint`: Runs Biome linter
|
||||
- `check`: Runs Biome checker with auto-fix
|
||||
- `format`: Formats code using Biome
|
||||
- `gen:api`: Generates API types from schema
|
||||
- `test`: Runs unit/integration tests
|
||||
- `test:ui`: Runs tests with UI
|
||||
- `test:e2e`: Runs end-to-end tests
|
||||
- `build`: Builds the application for production
|
||||
- `start`: Starts the production server
|
||||
- `seed`: Seeds the database with initial data
|
||||
Reference in New Issue
Block a user