main.dart 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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. ChangeNotifierProvider(create: (_) => DescuentoViewModel()),
  42. ChangeNotifierProvider(create: (_) => VariableViewModel()),
  43. // Agrega aquí cualquier otro provider que necesites
  44. ], child: const MyApp()));
  45. });
  46. }
  47. class MyApp extends StatelessWidget {
  48. const MyApp({super.key});
  49. @override
  50. Widget build(BuildContext context) {
  51. return MaterialApp(
  52. locale: const Locale("en", "ES"),
  53. debugShowCheckedModeBanner: false,
  54. title: 'Yoshi Papas',
  55. theme: AppTheme.lightTheme,
  56. initialRoute: 'main',
  57. routes: {
  58. 'main': (context) => const MainScreen(),
  59. 'login': (context) => const LoginScreen(),
  60. 'home': (context) => const HomeScreen(),
  61. 'perfil': (context) => const PerfilScreen(),
  62. },
  63. );
  64. }
  65. }