saveinmed/frontend
2026-02-26 16:30:59 -03:00
..
src Merge: mudanças locais + remotas do branch dev 2026-02-26 16:30:59 -03:00
.env.example feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
.gitignore feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
deno.lock feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
Dockerfile feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
index.html feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
MARKETPLACE.md feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
package.json feat(ui): padronizar paleta #0F4C81 e estrutura em múltiplas telas 2026-02-26 15:56:03 -03:00
pnpm-lock.yaml feat(ui): padronizar paleta #0F4C81 e estrutura em múltiplas telas 2026-02-26 15:56:03 -03:00
postcss.config.cjs feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
README.md chore: remove legacy services and restructure monorepo 2026-02-25 16:51:34 -03:00
tailwind.config.ts feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00
tsconfig.json chore: remove legacy services and restructure monorepo 2026-02-25 16:51:34 -03:00
tsconfig.node.json chore: remove legacy services and restructure monorepo 2026-02-25 16:51:34 -03:00
vite.config.ts chore: remove legacy services and restructure monorepo 2026-02-25 16:51:34 -03:00
vitest.config.ts feat(company): adiciona melhorias de geolocalização e documentos 2026-02-20 19:31:24 -03:00

Frontend — SaveInMed Marketplace

React + Vite + TypeScript + Tailwind CSS

Estrutura de src/

src/
├── assets/         → Logo, imagens estáticas
├── components/     → Componentes reutilizáveis
├── context/        → React Context (auth, tema) — estado global estável
├── hooks/          → Custom hooks
├── layouts/        → Layouts de página (Shell, DashboardLayout)
├── pages/          → Páginas organizadas por contexto e perfil
│     ├── auth/           → Login
│     ├── marketplace/    → Search, Cart, Checkout, Orders, OrderDetails
│     └── dashboard/
│           ├── admin/    → Painel administrativo (role admin)
│           ├── seller/   → Inventário, Produtos, Carteira, Equipe
│           ├── employee/ → Dashboard do colaborador
│           ├── delivery/ → Dashboard do entregador
│           ├── Company.tsx
│           └── MyProfile.tsx
├── services/       → Clientes HTTP por domínio
├── stores/         → Zustand (carrinho, filtros, UI global)
├── types/          → Tipos TypeScript compartilhados
└── utils/          → format, jwt, logger

Importações absolutas

Utilize o alias @/ (aponta para src/):

// ✅ Correto
import { useAuth } from '@/context/AuthContext'

// ❌ Evitar (quebra ao mover o arquivo)
import { useAuth } from '../../context/AuthContext'

Gerenciamento de estado

Estado Estratégia
Auth (JWT, user) Context API (AuthContext)
Tema claro/escuro Context API (ThemeContext)
Carrinho Zustand (cartStore)
Filtros de busca Zustand / usePersistentFilters
Estado UI local useState no componente

Regra: Context apenas para auth e tema. Tudo mais vai para Zustand.

Scripts

pnpm dev      # Dev server (proxy → :8214)
pnpm build    # Build produção
pnpm test     # Testes (Vitest)
pnpm lint     # ESLint