main.dart 2.8 KB

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