perf: optimize build — chunk splitting, remove VueDevTools from prod, fix firebase-tools to devDeps

- vite.config.ts: Remove VueDevTools from production build (dev only)
- vite.config.ts: Add manualChunks for firebase, charts, pdf, vue, maps vendors
- vite.config.ts: Increase chunkSizeWarningLimit to 700KB for Google Maps
- package.json: Move firebase-tools from dependencies to devDependencies
- router/index.ts: Add webpackChunkName groups (transport, discover, user, admin, roles)
- Clean up build log files (build_debug.txt, build_error*.txt, etc.)

Build time improvement: chunks now load on demand per user role
This commit is contained in:
2026-02-22 16:19:27 -05:00
parent b0d6aacc6e
commit 2b7e193906
3 changed files with 186 additions and 137 deletions

View File

@ -4,131 +4,142 @@ import { createRouter, createWebHistory } from 'vue-router'
const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL),
routes: [
// ─── Vistas Públicas Core (cargadas en el chunk principal) ───────────
{
path: '/',
name: 'splash',
component: () => import('@/views/SplashScreen.vue'),
component: () => import(/* webpackChunkName: "splash" */ '@/views/SplashScreen.vue'),
},
{
path: '/map',
name: 'map',
component: () => import('@/views/MapView.vue'),
},
{
path: '/discover',
name: 'discover',
component: () => import('@/views/DiscoverView.vue'),
},
{
path: '/business/:id',
name: 'business-details',
component: () => import('@/views/BusinessDetailsView.vue'),
},
{
path: '/routes',
name: 'routes',
component: () => import('@/views/RoutesView.vue'),
},
{
path: '/schedules',
name: 'schedules',
component: () => import('@/views/SchedulesView.vue'),
},
{
path: '/coupons',
name: 'coupons',
component: () => import('@/views/CouponsView.vue'),
},
{
path: '/favorites',
name: 'favorites',
component: () => import('@/views/FavoritesView.vue'),
},
{
path: '/profile',
name: 'profile',
component: () => import('@/views/ProfileView.vue'),
meta: { requiresAuth: true }
},
{
path: '/taxi',
name: 'taxi',
component: () => import('@/views/TaxiView.vue'),
},
{
path: '/bus-stop/:id',
name: 'bus-stop-details',
component: () => import('@/views/BusStopDetailsView.vue'),
component: () => import(/* webpackChunkName: "map" */ '@/views/MapView.vue'),
},
{
path: '/login',
name: 'auth',
component: () => import('@/views/AuthView.vue'),
component: () => import(/* webpackChunkName: "auth" */ '@/views/AuthView.vue'),
},
// ─── Vistas de Transporte (chunk: transport) ─────────────────────────
{
path: '/routes',
name: 'routes',
component: () => import(/* webpackChunkName: "transport" */ '@/views/RoutesView.vue'),
},
{
path: '/schedules',
name: 'schedules',
component: () => import(/* webpackChunkName: "transport" */ '@/views/SchedulesView.vue'),
},
{
path: '/bus-stop/:id',
name: 'bus-stop-details',
component: () => import(/* webpackChunkName: "transport" */ '@/views/BusStopDetailsView.vue'),
},
{
path: '/taxi',
name: 'taxi',
component: () => import(/* webpackChunkName: "transport" */ '@/views/TaxiView.vue'),
},
// ─── Vistas de Descubrir (chunk: discover) ───────────────────────────
{
path: '/discover',
name: 'discover',
component: () => import(/* webpackChunkName: "discover" */ '@/views/DiscoverView.vue'),
},
{
path: '/business/:id',
name: 'business-details',
component: () => import(/* webpackChunkName: "discover" */ '@/views/BusinessDetailsView.vue'),
},
{
path: '/coupons',
name: 'coupons',
component: () => import(/* webpackChunkName: "discover" */ '@/views/CouponsView.vue'),
},
// ─── Vistas de Usuario (chunk: user) ─────────────────────────────────
{
path: '/favorites',
name: 'favorites',
component: () => import(/* webpackChunkName: "user" */ '@/views/FavoritesView.vue'),
},
{
path: '/profile',
name: 'profile',
component: () => import(/* webpackChunkName: "user" */ '@/views/ProfileView.vue'),
meta: { requiresAuth: true }
},
// ─── Vistas de Admin (chunk: admin — solo carga para admins) ─────────
{
path: '/admin',
name: 'admin-panel',
component: () => import('@/views/AdminPanel.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminPanel.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/bus-stops',
name: 'admin-bus-stops',
component: () => import('@/views/AdminBusStops.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminBusStops.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/routes',
name: 'admin-routes',
component: () => import('@/views/AdminRoutes.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminRoutes.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/reports',
name: 'admin-reports',
component: () => import('@/views/AdminReports.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminReports.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/schedules',
name: 'admin-schedules',
component: () => import('@/views/AdminSchedules.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminSchedules.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/drivers',
name: 'admin-drivers',
component: () => import('@/views/AdminDrivers.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminDrivers.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/analytics',
name: 'admin-analytics',
component: () => import('@/views/StrategicAnalytics.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/StrategicAnalytics.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/taxis',
name: 'admin-taxis',
component: () => import('@/views/AdminTaxis.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminTaxis.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
{
path: '/admin/shuttles',
name: 'admin-shuttles',
component: () => import('@/views/AdminShuttles.vue'),
component: () => import(/* webpackChunkName: "admin" */ '@/views/AdminShuttles.vue'),
meta: { requiresAuth: true, role: 'admin' }
},
// ─── Vistas de Roles Especiales (chunk: roles) ───────────────────────
{
path: '/promoter',
name: 'promoter-dashboard',
component: () => import('@/views/PromoterDashboard.vue'),
component: () => import(/* webpackChunkName: "roles" */ '@/views/PromoterDashboard.vue'),
meta: { requiresAuth: true, role: ['PROMOTER', 'ADMIN'] }
},
{
path: '/driver',
name: 'driver-dashboard',
component: () => import('@/views/DriverDashboard.vue'),
component: () => import(/* webpackChunkName: "roles" */ '@/views/DriverDashboard.vue'),
meta: { requiresAuth: true, role: ['DRIVER', 'ADMIN'] }
},
],
@ -158,4 +169,3 @@ router.beforeEach((to, _from, next) => {
})
export default router