import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:font_awesome_flutter/font_awesome_flutter.dart'; import 'package:go_router/go_router.dart'; import '../../providers/auth_provider.dart'; import '../../widgets/responsive_body.dart'; class LoginScreen extends ConsumerStatefulWidget { const LoginScreen({super.key}); @override ConsumerState createState() => _LoginScreenState(); } class _LoginScreenState extends ConsumerState { final _formKey = GlobalKey(); final _emailController = TextEditingController(); final _passwordController = TextEditingController(); bool _isLoading = false; @override void dispose() { _emailController.dispose(); _passwordController.dispose(); super.dispose(); } Future _handleEmailSignIn() async { if (!_formKey.currentState!.validate()) return; setState(() => _isLoading = true); final auth = ref.read(authControllerProvider); try { final response = await auth.signInWithPassword( email: _emailController.text.trim(), password: _passwordController.text, ); if (response.session != null && mounted) { context.go('/tickets'); } else if (mounted) { ScaffoldMessenger.of(context).showSnackBar( const SnackBar(content: Text('Check your email to confirm sign-in.')), ); } } on Exception catch (error) { if (mounted) { ScaffoldMessenger.of( context, ).showSnackBar(SnackBar(content: Text('Sign in failed: $error'))); } } finally { if (mounted) { setState(() => _isLoading = false); } } } Future _handleOAuthSignIn({required bool google}) async { setState(() => _isLoading = true); final auth = ref.read(authControllerProvider); final redirectTo = kIsWeb ? Uri.base.origin : null; try { if (google) { await auth.signInWithGoogle(redirectTo: redirectTo); } else { await auth.signInWithMeta(redirectTo: redirectTo); } } on Exception catch (error) { if (mounted) { ScaffoldMessenger.of( context, ).showSnackBar(SnackBar(content: Text('OAuth failed: $error'))); } } finally { if (mounted) { setState(() => _isLoading = false); } } } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: const Text('Sign In')), body: ResponsiveBody( maxWidth: 480, padding: const EdgeInsets.symmetric(vertical: 24), child: Form( key: _formKey, child: Column( mainAxisAlignment: MainAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.stretch, children: [ Center( child: Column( children: [ Image.asset('assets/tasq_ico.png', height: 72, width: 72), const SizedBox(height: 12), Text( 'TasQ', style: Theme.of(context).textTheme.headlineSmall, ), ], ), ), const SizedBox(height: 24), TextFormField( controller: _emailController, decoration: const InputDecoration(labelText: 'Email'), keyboardType: TextInputType.emailAddress, textInputAction: TextInputAction.next, validator: (value) { if (value == null || value.trim().isEmpty) { return 'Email is required.'; } return null; }, ), const SizedBox(height: 12), TextFormField( controller: _passwordController, decoration: const InputDecoration(labelText: 'Password'), obscureText: true, textInputAction: TextInputAction.done, onFieldSubmitted: (_) { if (!_isLoading) { _handleEmailSignIn(); } }, validator: (value) { if (value == null || value.isEmpty) { return 'Password is required.'; } return null; }, ), const SizedBox(height: 24), FilledButton( onPressed: _isLoading ? null : _handleEmailSignIn, child: _isLoading ? const SizedBox( height: 18, width: 18, child: CircularProgressIndicator(strokeWidth: 2), ) : const Text('Sign In'), ), const SizedBox(height: 12), OutlinedButton.icon( onPressed: _isLoading ? null : () => _handleOAuthSignIn(google: true), icon: const FaIcon(FontAwesomeIcons.google, size: 18), label: const Text('Continue with Google'), ), const SizedBox(height: 8), OutlinedButton.icon( onPressed: _isLoading ? null : () => _handleOAuthSignIn(google: false), icon: const FaIcon(FontAwesomeIcons.facebook, size: 18), label: const Text('Continue with Meta'), ), const SizedBox(height: 16), TextButton( onPressed: _isLoading ? null : () => context.go('/signup'), child: const Text('Create account'), ), ], ), ), ), ); } }