saveinmed/frontend
2026-02-26 18:39:05 -03:00
..
e2e feat: resolve react-icons dependency, add frontend e2e and backend tests 2026-02-26 18:27:02 -03:00
src Merge branch 'dev' of https://github.com/rede5/saveinmed into dev 2026-02-26 18:39:05 -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: resolve react-icons dependency, add frontend e2e and backend tests 2026-02-26 18:27:02 -03:00
playwright.config.ts feat: resolve react-icons dependency, add frontend e2e and backend tests 2026-02-26 18:27:02 -03:00
pnpm-lock.yaml feat: resolve react-icons dependency, add frontend e2e and backend tests 2026-02-26 18:27:02 -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