Files
infiplot-monorepo/README.md
T
baizhi958216 caca4369aa chore: configure pnpm monorepo workspace
Signed-off-by: baizhi958216 <1475289190@qq.com>
2026-06-30 00:44:21 +08:00

35 lines
1.4 KiB
Markdown

# Infiplot Monorepo
This workspace coordinates the Infiplot web and app codebases plus shared packages.
## Layout
- `infiplot-web`: existing open-source Next.js project. Treat this directory as read-only from the monorepo layer so it can continue to be maintained as its own repository.
- `infiplot-app`: Expo / React Native app.
- `packages/types`: shared TypeScript contracts and DTOs.
- `packages/core`: shared framework-agnostic business logic.
- `packages/api-client`: typed client for the web API surface.
- `packages/ui`: cross-platform UI entry points. Keep platform-specific code behind `.web.tsx` / `.native.tsx` files.
## Commands
```sh
pnpm dev:web
pnpm dev:app
pnpm build:web
pnpm check
```
## Design Rules
The monorepo owns orchestration, shared packages, and app integration. It should not rewrite files inside `infiplot-web`; any future web changes should happen in the upstream web repository and be pulled back here.
Shared code should move in this order:
1. Types and API contracts into `packages/types`.
2. Pure business logic into `packages/core`.
3. HTTP/API access into `packages/api-client`.
4. UI primitives into `packages/ui`, with separate platform entry points when necessary.
Avoid importing directly from `infiplot-web/lib/*` in the app. Promote stable contracts into `packages/*` first, then consume those packages from both sides when the web repository is ready to adopt them upstream.