main.dart 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. import 'package:flutter/material.dart';
  2. import 'package:flutter/services.dart';
  3. import 'package:provider/provider.dart';
  4. import 'package:sqflite_common_ffi/sqflite_ffi.dart';
  5. import 'dart:io'; // Importa esto para usar Platform.isWindows
  6. import 'services/productos_service.dart';
  7. import 'views/main/main_screen.dart';
  8. import 'views/home/home_screen.dart';
  9. import 'views/login/login_screen.dart';
  10. import 'views/perfil/perfil_screen.dart';
  11. import 'themes/themes.dart';
  12. import 'viewmodels/viewmodels.dart';
  13. import 'package:timezone/data/latest.dart' as tzdata;
  14. void main() async {
  15. WidgetsFlutterBinding.ensureInitialized();
  16. tzdata.initializeTimeZones();
  17. // Inicialización de la base de datos para plataformas de escritorio con FFI
  18. if (Platform.isWindows || Platform.isLinux) {
  19. sqfliteFfiInit();
  20. databaseFactory = databaseFactoryFfi;
  21. }
  22. final productosService = ProductosService();
  23. if (await productosService.isDatabaseEmpty()) {
  24. await productosService.fillCategoriaBD();
  25. await productosService.fillProductoBD();
  26. }
  27. SystemChrome.setPreferredOrientations([
  28. DeviceOrientation.landscapeRight,
  29. DeviceOrientation.landscapeLeft,
  30. ]).then((_) {
  31. runApp(MultiProvider(providers: [
  32. ChangeNotifierProvider(create: (_) => LoginViewModel()),
  33. ChangeNotifierProvider(create: (_) => UsuariosViewModel()),
  34. ChangeNotifierProvider(create: (_) => ProfileViewModel()),
  35. ChangeNotifierProvider(create: (_) => CategoriaProductoViewModel()),
  36. ChangeNotifierProvider(create: (_) => ProductoViewModel()),
  37. ChangeNotifierProvider(create: (_) => TopingCategoriaViewModel()),
  38. ChangeNotifierProvider(create: (_) => MediaViewModel()),
  39. ChangeNotifierProvider(create: (_) => TopingViewModel()),
  40. ChangeNotifierProvider(create: (_) => PedidoViewModel()),
  41. // Agrega aquí cualquier otro provider que necesites
  42. ], child: const MyApp()));
  43. });
  44. }
  45. class MyApp extends StatelessWidget {
  46. const MyApp({super.key});
  47. @override
  48. Widget build(BuildContext context) {
  49. return MaterialApp(
  50. locale: const Locale("en", "ES"),
  51. debugShowCheckedModeBanner: false,
  52. title: 'Yoshi Papas',
  53. theme: AppTheme.lightTheme,
  54. initialRoute: 'main',
  55. routes: {
  56. 'main': (context) => const MainScreen(),
  57. 'login': (context) => const LoginScreen(),
  58. 'home': (context) => const HomeScreen(),
  59. 'perfil': (context) => const PerfilScreen(),
  60. },
  61. );
  62. }
  63. }