🚀 Feat(Core): Migración oficial y total B a Supabase (Auth, DB, APIs) + Eliminación de Backend Python y Fixes Firebase + Soporte Vite Vercel

This commit is contained in:
2026-02-25 21:01:18 -05:00
parent 87752d8214
commit 7cd97365f2
17 changed files with 868 additions and 241 deletions

View File

@ -3,7 +3,7 @@ import { ref } from 'vue'
import { useRouter } from 'vue-router'
import { authService } from '@/services/authService'
import { analyticsService } from '@/services/analyticsService'
import { signInWithGoogle } from '@/firebaseConfig'
import { supabase } from '@/supabase'
import { useAuthStore } from '@/stores/auth'
const emit = defineEmits(['toggle', 'success'])
@ -33,39 +33,26 @@ const handleRegister = async () => {
email: cleanEmail,
password: cleanPass
})
console.log('Registro exitoso en backend:', regResponse)
console.log('Registro exitoso en Supabase:', regResponse)
analyticsService.logEvent({
event_name: 'sign_up',
properties: { method: 'email' }
})
// Iniciar sesión automáticamente después del registro
console.log('Iniciando sesión automática...')
const response = await authService.login({
email: cleanEmail,
password: cleanPass
})
console.log('Login automático exitoso:', response)
authStore.login(response.access_token, response.role, response.full_name)
await authStore.login(cleanEmail, cleanPass)
successMessage.value = '¡Cuenta creada con éxito!'
// Redirigir casi de inmediato
setTimeout(() => {
navigateByUserRole(response.role)
}, 1000)
const r = authStore.role || 'PASSENGER'
navigateByUserRole(r)
}, 1500)
} catch (error: any) {
console.error('Error detallado de registro:', error)
if (error.response) {
errorMessage.value = `Error del servidor (${error.response.status}): ${error.response.data?.detail || 'Error desconocido'}`
} else if (error.request) {
errorMessage.value = 'No se recibió respuesta del servidor. ¿Backend caído?'
} else {
errorMessage.value = `Error: ${error.message}`
}
errorMessage.value = `Error: ${error.message || 'Error desconocido'}`
} finally {
isLoading.value = false
}
@ -85,31 +72,17 @@ const handleGoogleRegister = async () => {
console.log('Iniciando Google Register...')
try {
const { token } = await signInWithGoogle()
console.log('Firebase token obtenido:', token ? 'SI' : 'NO (Redirecting...)')
if (token) {
const response = await authService.googleLogin(token)
console.log('Backend Google login/register exitoso:', response)
analyticsService.logEvent({
event_name: 'sign_up',
properties: { method: 'google' }
})
authStore.login(response.access_token, response.role, response.full_name)
// Navigate based on actual role from backend
navigateByUserRole(response.role)
}
const { error } = await supabase.auth.signInWithOAuth({
provider: 'google',
options: {
redirectTo: window.location.origin
}
})
if (error) throw error
// Redirect happens automatically
} catch (error: any) {
console.error('Error Google Register:', error)
if (error.response?.data?.detail) {
errorMessage.value = `Error: ${error.response.data.detail}`
} else {
errorMessage.value = `Error con Google: ${error.message || 'Intenta de nuevo'}`
}
errorMessage.value = `Error con Google: ${error.message || 'Intenta de nuevo'}`
} finally {
isLoading.value = false
}
@ -129,7 +102,7 @@ const handleGoogleRegister = async () => {
<!-- Formulario -->
<template v-else>
<!-- Google
<!-- Google -->
<button
type="button"
class="google-btn"
@ -145,7 +118,6 @@ const handleGoogleRegister = async () => {
<span class="divider-text">o con correo</span>
<span class="divider-line"></span>
</div>
-->
<form @submit.prevent="handleRegister">