import 'package:flutter/material.dart'; import 'package:notas/widgets/app_title_bar.dart'; class BiometricGateScreen extends StatefulWidget { const BiometricGateScreen({ super.key, required this.isBusy, required this.onUnlockRequested, }); final bool isBusy; final Future Function() onUnlockRequested; @override State createState() => _BiometricGateScreenState(); } class _BiometricGateScreenState extends State { bool _autoRequested = false; @override void initState() { super.initState(); WidgetsBinding.instance.addPostFrameCallback((_) { if (mounted) { _requestUnlockOnce(); } }); } Future _requestUnlockOnce() async { if (_autoRequested || widget.isBusy) { return; } _autoRequested = true; await widget.onUnlockRequested(); } @override Widget build(BuildContext context) { return Scaffold( body: Container( decoration: const BoxDecoration( gradient: LinearGradient( colors: [ Color(0xFF191A1D), Color(0xFF222326), Color(0xFF101114), ], begin: Alignment.topLeft, end: Alignment.bottomRight, ), ), child: SafeArea( child: Column( children: [ const AppTitleBar(), Expanded( child: Center( child: SingleChildScrollView( padding: const EdgeInsets.all(24), child: ConstrainedBox( constraints: const BoxConstraints(maxWidth: 460), child: Container( padding: const EdgeInsets.all(24), decoration: BoxDecoration( color: const Color(0xFF1D1E20), borderRadius: BorderRadius.circular(24), border: Border.all(color: Colors.white.withValues(alpha: 0.08)), boxShadow: [ BoxShadow( color: Colors.black.withValues(alpha: 0.35), blurRadius: 30, offset: const Offset(0, 18), ), ], ), child: Column( mainAxisSize: MainAxisSize.min, crossAxisAlignment: CrossAxisAlignment.stretch, children: [ const Icon( Icons.fingerprint, size: 44, ), const SizedBox(height: 16), const Text( 'Desbloqueo biométrico', textAlign: TextAlign.center, style: TextStyle( color: Colors.white, fontSize: 28, fontWeight: FontWeight.w700, ), ), const SizedBox(height: 10), Text( 'Pon tu huella o cara para entrar a tus notas.', textAlign: TextAlign.center, style: TextStyle( color: Colors.white.withValues(alpha: 0.72), height: 1.4, ), ), const SizedBox(height: 22), FilledButton( onPressed: widget.isBusy ? null : widget.onUnlockRequested, style: FilledButton.styleFrom( padding: const EdgeInsets.symmetric(vertical: 14), ), child: widget.isBusy ? const SizedBox( width: 18, height: 18, child: CircularProgressIndicator(strokeWidth: 2), ) : const Text('Desbloquear'), ), ], ), ), ), ), ), ), ], ), ), ), ); } }