Files
AbelBirdNest-Stock/docs/project-spec/walet-frontend-structure.md

408 lines
7.7 KiB
Markdown

# Frontend Structure Sistem Inventory Walet
## 1. Tujuan
Dokumen ini menjelaskan struktur frontend yang disarankan untuk aplikasi inventory sarang burung walet berbasis lot, traceability, sorting, partial allocation, dan QR/barcode workflow.
Target utamanya:
- mudah dibangun bertahap
- mudah dipahami tim frontend
- mobile-friendly untuk flow gudang
- scalable untuk modul traceability dan reporting
## 2. Rekomendasi Stack
- Next.js / React
- TypeScript
- Tailwind CSS
- shadcn/ui atau komponen serupa
- TanStack Query untuk server state
- Zustand atau Redux Toolkit untuk local workflow state yang kompleks
- React Hook Form + Zod untuk form
- Data table component untuk list/listing besar
- QR scanner berbasis camera API di mobile web
## 3. Struktur Folder Tingkat Atas
```text
src/
app/
components/
features/
lib/
hooks/
services/
types/
store/
utils/
config/
```
## 4. Struktur app/routes
```text
src/app/
login/
page.tsx
dashboard/
page.tsx
suppliers/
page.tsx
new/page.tsx
[id]/page.tsx
[id]/bank/page.tsx
customers/
page.tsx
new/page.tsx
[id]/page.tsx
[id]/bank/page.tsx
item-types/
page.tsx
item-grades/
page.tsx
warehouses/
page.tsx
[id]/page.tsx
purchases/
page.tsx
new/page.tsx
[id]/page.tsx
[id]/edit/page.tsx
receipts/
page.tsx
new/page.tsx
[id]/page.tsx
lots/
page.tsx
[id]/page.tsx
[id]/trace/page.tsx
sorting/
page.tsx
new/page.tsx
[id]/page.tsx
regrade/
new/page.tsx
sales/
page.tsx
new/page.tsx
[id]/page.tsx
[id]/allocation/page.tsx
[id]/picking/page.tsx
adjustments/
page.tsx
new/page.tsx
returns/
sales/page.tsx
purchase/page.tsx
barcode/
scan/page.tsx
lookup/page.tsx
reports/
stock-summary/page.tsx
stock-lots/page.tsx
purchases/page.tsx
sales/page.tsx
margins/page.tsx
shrinkage/page.tsx
traceability/page.tsx
settings/
page.tsx
```
## 5. Struktur Features
Setiap domain besar sebaiknya punya feature sendiri.
```text
src/features/
auth/
dashboard/
suppliers/
customers/
item-types/
item-grades/
warehouses/
purchases/
receipts/
lots/
sorting/
regrade/
sales/
allocations/
adjustments/
returns/
barcode/
reports/
```
## 6. Contoh Isi Tiap Feature
Catatan domain tambahan:
- feature suppliers dan customers perlu mendukung field `bank_name` dan `bank_account_number`
- halaman detail supplier/customer sebaiknya punya section informasi pembayaran
Contoh feature purchases:
```text
src/features/purchases/
api/
get-purchases.ts
get-purchase-detail.ts
create-purchase.ts
update-purchase.ts
components/
purchase-form.tsx
purchase-line-table.tsx
purchase-status-badge.tsx
purchase-filter.tsx
hooks/
use-purchase-form.ts
use-purchases-query.ts
schemas/
purchase.schema.ts
types/
purchase.type.ts
```
Contoh feature sales:
```text
src/features/sales/
api/
get-sales.ts
get-sales-detail.ts
create-sales.ts
allocate-sales.ts
confirm-picking.ts
components/
sales-form.tsx
sales-line-table.tsx
allocation-panel.tsx
picking-panel.tsx
sales-summary-card.tsx
hooks/
use-sales-form.ts
use-allocation.ts
use-picking.ts
schemas/
sales.schema.ts
types/
sales.type.ts
```
## 7. Shared Components
```text
src/components/
ui/
layout/
app-shell.tsx
sidebar.tsx
topbar.tsx
mobile-nav.tsx
tables/
data-table.tsx
table-toolbar.tsx
forms/
form-field.tsx
number-input.tsx
date-picker.tsx
select-async.tsx
status/
status-badge.tsx
stock-badge.tsx
cards/
metric-card.tsx
lot-card.tsx
dialogs/
confirm-dialog.tsx
allocation-dialog.tsx
trace-dialog.tsx
scanners/
qr-scanner.tsx
barcode-input.tsx
```
## 8. Services Layer
Pisahkan akses API dari komponen.
```text
src/services/
api-client.ts
auth.service.ts
supplier.service.ts
purchase.service.ts
receipt.service.ts
lot.service.ts
sorting.service.ts
sales.service.ts
adjustment.service.ts
report.service.ts
```
## 9. Types Layer
```text
src/types/
api.ts
auth.ts
supplier.ts
customer.ts
item.ts
warehouse.ts
purchase.ts
receipt.ts
lot.ts
sorting.ts
sales.ts
report.ts
```
## 10. State Management
### Server state
Gunakan TanStack Query untuk:
- fetch list
- detail view
- mutation create/update
- invalidate cache
### Local workflow state
Gunakan Zustand/Redux untuk flow kompleks seperti:
- sales allocation draft
- picking workflow
- sorting result draft
- scanner temporary state
## 11. Halaman Paling Kritis
### A. Stock Lot List
Kebutuhan:
- filter kuat
- table cepat
- klik ke lot detail
- status warna
### B. Lot Detail
Kebutuhan:
- identitas lot jelas
- parent-child relation
- movement timeline
- link ke sales/purchase/receipt
- aksi cepat hold/release/regrade/transfer
### C. Allocation Screen
Kebutuhan:
- sales line summary di atas
- list lot tersedia
- qty allocation editor
- auto allocate FIFO
- kalkulasi total costing real-time
- validasi total qty
### D. Picking Screen
Kebutuhan:
- scan QR
- tampil lot teralokasi
- input qty picked aktual
- error warning jika beda dari alokasi
### E. Barcode Lookup Screen
Kebutuhan:
- buka cepat dari scan
- tampil ringkas tapi informatif
- tombol ke lot detail
## 12. Layout dan UX
### Desktop
Cocok untuk:
- dashboard
- purchasing
- reports
- stock table besar
### Mobile
Cocok untuk:
- scanning
- receiving
- picking
- transfer lot
- quick lot lookup
Saran:
- gunakan responsive layout, bukan dua app terpisah dulu
- fokus mobile-first pada layar operasional gudang
## 13. Form Strategy
### Gunakan form section
Untuk form besar seperti purchase, receipt, sales:
- header section
- detail lines section
- summary section
- actions footer sticky
### Untuk line items
Gunakan editable table atau repeater row.
## 14. Component Priorities MVP
Bangun komponen inti dulu:
- app shell
- data table
- form field library
- status badge
- QR scanner
- allocation panel
- movement timeline
- lot summary card
## 15. Flow Antar Halaman
### Purchase to Receipt
Purchase List -> Purchase Detail -> Create Receipt -> Receipt Detail -> Generate Lots -> Lot Detail
### Lot to Sorting
Lot List -> Lot Detail -> Create Sorting -> Sorting Result -> Child Lot Detail
### Sales Flow
Sales List -> Create Sales -> Allocation Screen -> Picking Screen -> Sales Detail
### Scan Flow
Scan Page -> Lookup Result -> Lot Detail / Picking / Transfer
## 16. Permissions UI
### Owner
- read mostly all
- no heavy transactional edit by default
### Purchasing
- purchase pages
### Warehouse
- receipt, lots, transfer, adjustment, barcode
### QC
- sorting, regrade
### Sales
- sales, allocation, picking
UI harus hide action sesuai role.
## 17. Frontend API Integration Pattern
Untuk tiap feature:
- query key per list/detail
- mutation untuk create/update/action
- central error handler
- loading skeleton untuk page utama
- toast notification untuk success/error
## 18. Frontend Deliverable yang Bisa Lanjut Dibuat
Dari struktur ini, next bisa diturunkan menjadi:
- route map detail
- component tree per halaman
- page-by-page wireframe detail
- UI kit token
- frontend task breakdown per sprint
## 19. Rekomendasi Eksekusi
Urutan frontend yang paling masuk akal:
1. layout + auth
2. master data basic pages
3. purchase & receipt
4. stock lot & lot detail
5. sales & allocation
6. sorting & regrade
7. scanner flow
8. reports
## 20. Kesimpulan
Frontend sistem walet ini sebaiknya dibangun modular per feature, dengan lot detail dan allocation flow sebagai pusat desain. Fokus utama harus pada kecepatan operasional gudang dan kejelasan traceability, bukan sekadar tampilan tabel stok biasa.