ordinarthur 8d3bab6a89 feat: scaffold frontend monorepo + first /login screen
Monorepo Turborepo (pnpm workspaces) avec 3 packages :

- apps/web : SPA React 19 + Vite 8 + Tailwind v4 (CSS-first)
  • TanStack Router (file-based, auto code-splitting), Query, Form
  • Radix primitives bruts + CVA + clsx + tailwind-merge
  • MSW pour mocker l'API tant qu'Adonis n'est pas branché
  • Polices Bricolage Grotesque + Inter self-hostées via fontsource
  • Tokens marque (rubis, cream, ink) exposés via @theme
  • Primitives maison : Gem, Brand, Eyebrow, Button, Input, Field
  • Route /login full flow : TanStack Form + Zod + mutation Query

- apps/api : Adonis 7 (kit api, scaffold via create-adonisjs)
  • Auth access tokens (Bearer) — cf. ADR-017
  • Tuyau core déjà câblé pour la génération de types
  • Routes /api/v1/auth/{signup,login} + /api/v1/account/{profile,logout}
  • Minimal — uniquement le pont front ↔ back

- packages/shared : types TS + schemas Zod + constantes
  • Source unique de vérité partagée api ↔ web
  • Domaines : User, Org, Auth, Client, Invoice, Plan

Tooling racine : Turbo, ESLint v9 flat, Prettier, husky, lint-staged.

CLAUDE.md et docs/decisions.md mis à jour avec ADR-014 à ADR-018
(stack, monorepo, PG existant, Bearer tokens, MinIO existant)
et le pointeur vers docs/tech/architecture.md.

Logo Rubis déplacé de landing/assets/ vers /assets/ (source unique
réutilisée par la landing et l'app).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-06 10:10:48 +02:00

47 lines
1.2 KiB
TypeScript

/**
* Constantes métier partagées entre l'API et le SPA.
* Une seule source de vérité — pas de duplication.
*/
/** 1 rubis = 10 minutes libérées (cf. CLAUDE.md, glossaire) */
export const MINUTES_PER_RUBIS = 10;
/** Statuts possibles d'une facture (cf. architecture.md §5) */
export const INVOICE_STATUSES = [
"pending",
"awaiting_user_confirmation",
"in_relance",
"paid",
"litigation",
"cancelled",
] as const;
/** Tonalité d'un email de relance — du plus doux au plus ferme. */
export const RELANCE_TONES = ["amical", "courtois", "ferme", "mise_en_demeure"] as const;
/** Plans pré-fournis par défaut (cf. produit.md) */
export const DEFAULT_PLAN_SLUGS = [
"standard-30j",
"rapide-15j",
"patient-60j",
"ferme-7j",
] as const;
/** Volumes mensuels de facturation pour l'onboarding (chips) */
export const MONTHLY_VOLUME_BUCKETS = [
"moins-10",
"10-50",
"50-100",
"100-200",
"plus-200",
] as const;
/** Formats de fichier acceptés à l'import */
export const ACCEPTED_INVOICE_MIME_TYPES = [
"application/pdf",
"image/png",
"image/jpeg",
] as const;
export const MAX_INVOICE_FILE_SIZE_BYTES = 10 * 1024 * 1024; // 10 Mo