perf: otimizar dashboard com indexes, cache e consolidação de queries (v1.3.0)

- Adicionar indexes compostos em lancamentos para queries frequentes
- Eliminar ~20 JOINs com pagadores via helper cacheado getAdminPagadorId()
- Consolidar queries: income-expense-balance (12→1), payment-status (2→1), categories (4→2)
- Adicionar cache cross-request via unstable_cache com tag-based invalidation
- Limitar scan de métricas a 24 meses
- Deduplicar auth session por request via React.cache()

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
Felipe Coutinho
2026-02-06 12:24:15 +00:00
parent 21fac52e28
commit 6f5c41a4cf
45 changed files with 3589 additions and 1219 deletions

View File

@@ -1,6 +1,6 @@
{
"name": "opensheets",
"version": "1.2.6",
"version": "1.3.0",
"private": true,
"scripts": {
"dev": "next dev --turbopack",
@@ -27,8 +27,8 @@
"docker:rebuild": "docker compose up --build --force-recreate"
},
"dependencies": {
"@ai-sdk/anthropic": "^3.0.35",
"@ai-sdk/google": "^3.0.20",
"@ai-sdk/anthropic": "^3.0.37",
"@ai-sdk/google": "^3.0.21",
"@ai-sdk/openai": "^3.0.25",
"@dnd-kit/core": "^6.3.1",
"@dnd-kit/sortable": "^10.0.0",
@@ -59,7 +59,7 @@
"@tanstack/react-table": "8.21.3",
"@vercel/analytics": "^1.6.1",
"@vercel/speed-insights": "^1.3.1",
"ai": "^6.0.67",
"ai": "^6.0.73",
"babel-plugin-react-compiler": "^1.0.0",
"better-auth": "1.4.18",
"class-variance-authority": "0.7.1",
@@ -67,7 +67,7 @@
"cmdk": "^1.1.1",
"date-fns": "^4.1.0",
"drizzle-orm": "0.45.1",
"jspdf": "^4.0.0",
"jspdf": "^4.1.0",
"jspdf-autotable": "^5.0.7",
"next": "16.1.6",
"next-themes": "0.4.6",
@@ -84,13 +84,13 @@
"zod": "4.3.6"
},
"devDependencies": {
"@biomejs/biome": "2.3.13",
"@biomejs/biome": "2.3.14",
"@tailwindcss/postcss": "4.1.18",
"@types/node": "25.1.0",
"@types/node": "25.2.1",
"@types/pg": "^8.16.0",
"@types/react": "19.2.10",
"@types/react": "19.2.13",
"@types/react-dom": "19.2.3",
"dotenv": "^17.2.3",
"dotenv": "^17.2.4",
"drizzle-kit": "0.31.8",
"tailwindcss": "4.1.18",
"tsx": "4.21.0",