main.dart 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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 'package:turquessa_mesas_hoster/mvvm/views/home/carrito/carrito_screen.dart';
  6. import 'package:turquessa_mesas_hoster/mvvm/views/home/perfil/perfil_screen.dart';
  7. import 'package:turquessa_mesas_hoster/mvvm/views/home/producto/producto_screen.dart';
  8. import 'dart:io';
  9. import 'core/models/models.dart';
  10. import 'core/services/services.dart';
  11. import 'mvvm/views/home/home_screen.dart';
  12. import 'mvvm/views/login/login_screen.dart';
  13. import '/utils/themes.dart';
  14. import 'mvvm/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. Database? db = await DatabaseService().db;
  25. final repositoryFactory = SQLiteRepositoryFactory(db!);
  26. // 3) Obtener el repositorio de Mesa
  27. final mesaRepository = repositoryFactory.getRepository<Mesa>(
  28. tableName: 'Mesa',
  29. fromMap: Mesa.fromMap,
  30. toMap: (m) => m.toMap(),
  31. );
  32. final categoriaRepository =
  33. repositoryFactory.getRepository<CategoriaProducto>(
  34. tableName: 'CategoriaProducto',
  35. fromMap: CategoriaProducto.fromMap,
  36. toMap: (m) => m.toMap(),
  37. );
  38. final productoRepository = repositoryFactory.getRepository<Producto>(
  39. tableName: 'Producto',
  40. fromMap: Producto.fromMap,
  41. toMap: (m) => m.toMap(),
  42. );
  43. SystemChrome.setPreferredOrientations([
  44. DeviceOrientation.portraitDown,
  45. DeviceOrientation.portraitUp,
  46. ]).then((_) {
  47. runApp(MultiProvider(providers: [
  48. ChangeNotifierProvider(create: (_) => LoginViewModel()),
  49. ChangeNotifierProvider(create: (_) => SucursalViewModel()),
  50. ChangeNotifierProvider(create: (_) => PermisoViewModel()),
  51. ChangeNotifierProvider(create: (_) => UsuarioViewModel()),
  52. ChangeNotifierProvider(create: (_) => ProductoViewModel()),
  53. ChangeNotifierProvider(
  54. create: (_) => HomeViewModel(
  55. categoriaRepository: categoriaRepository,
  56. productoRepository: productoRepository)),
  57. ChangeNotifierProvider(
  58. create: (_) => MesaViewModel(mesaRepository: mesaRepository)),
  59. ChangeNotifierProvider(create: (_) => CategoriaProductoViewModel()),
  60. // Agrega aquí cualquier otro provider que necesites
  61. ], child: const MyApp()));
  62. });
  63. }
  64. class MyApp extends StatelessWidget {
  65. const MyApp({super.key});
  66. @override
  67. Widget build(BuildContext context) {
  68. return MaterialApp(
  69. locale: const Locale("en", "ES"),
  70. debugShowCheckedModeBanner: false,
  71. title: 'Turquessa',
  72. theme: AppTheme.lightTheme,
  73. initialRoute: 'home',
  74. routes: {
  75. 'login': (context) => const LoginScreen(),
  76. 'home': (context) => const HomeScreen(),
  77. 'producto': (context) =>
  78. ProductScreen(product: Product.staticSandwich()),
  79. 'carrito': (context) => const CarritoScreen(),
  80. 'perfil': (context) => const PerfilScreen(),
  81. },
  82. );
  83. }
  84. }