main.dart 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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/Recojer_screen.dart';
  6. import 'package:turquessa_mesas_hoster/mvvm/views/home/carrito/carrito_screen.dart';
  7. import 'package:turquessa_mesas_hoster/mvvm/views/home/perfil/perfil_screen.dart';
  8. import 'package:turquessa_mesas_hoster/mvvm/views/home/producto/producto_screen.dart';
  9. import 'dart:io';
  10. import 'core/models/models.dart';
  11. import 'core/services/services.dart';
  12. import 'mvvm/views/home/home_screen.dart';
  13. import 'mvvm/views/login/login_screen.dart';
  14. import '/utils/themes.dart';
  15. import 'mvvm/viewmodels/viewmodels.dart';
  16. import 'package:timezone/data/latest.dart' as tzdata;
  17. void main() async {
  18. WidgetsFlutterBinding.ensureInitialized();
  19. tzdata.initializeTimeZones();
  20. // Inicialización de la base de datos para plataformas de escritorio con FFI
  21. if (Platform.isWindows || Platform.isLinux) {
  22. sqfliteFfiInit();
  23. databaseFactory = databaseFactoryFfi;
  24. }
  25. Database? db = await DatabaseService().db;
  26. final repositoryFactory = SQLiteRepositoryFactory(db!);
  27. // 3) Obtener el repositorio de Mesa
  28. final mesaRepository = repositoryFactory.getRepository<Mesa>(
  29. tableName: 'Mesa',
  30. fromMap: Mesa.fromMap,
  31. toMap: (m) => m.toMap(),
  32. );
  33. final categoriaRepository =
  34. repositoryFactory.getRepository<CategoriaProducto>(
  35. tableName: 'CategoriaProducto',
  36. fromMap: CategoriaProducto.fromMap,
  37. toMap: (m) => m.toMap(),
  38. );
  39. final productoRepository = repositoryFactory.getRepository<Producto>(
  40. tableName: 'Producto',
  41. fromMap: Producto.fromMap,
  42. toMap: (m) => m.toMap(),
  43. );
  44. SystemChrome.setPreferredOrientations([
  45. DeviceOrientation.portraitDown,
  46. DeviceOrientation.portraitUp,
  47. ]).then((_) {
  48. runApp(MultiProvider(providers: [
  49. ChangeNotifierProvider(create: (_) => LoginViewModel()),
  50. ChangeNotifierProvider(create: (_) => SucursalViewModel()),
  51. ChangeNotifierProvider(create: (_) => PermisoViewModel()),
  52. ChangeNotifierProvider(create: (_) => UsuarioViewModel()),
  53. ChangeNotifierProvider(create: (_) => ProductoViewModel()),
  54. ChangeNotifierProvider(
  55. create: (_) => HomeViewModel(
  56. categoriaRepository: categoriaRepository,
  57. productoRepository: productoRepository)),
  58. ChangeNotifierProvider(
  59. create: (_) => MesaViewModel(mesaRepository: mesaRepository)),
  60. ChangeNotifierProvider(create: (_) => CategoriaProductoViewModel()),
  61. // Agrega aquí cualquier otro provider que necesites
  62. ], child: const MyApp()));
  63. });
  64. }
  65. class MyApp extends StatelessWidget {
  66. const MyApp({super.key});
  67. @override
  68. Widget build(BuildContext context) {
  69. return MaterialApp(
  70. locale: const Locale("en", "ES"),
  71. debugShowCheckedModeBanner: false,
  72. title: 'Turquessa',
  73. // darkTheme: AppTheme.darkTheme,
  74. theme: AppTheme.lightTheme,
  75. // themeMode: ThemeMode.system,
  76. initialRoute: 'home',
  77. routes: {
  78. 'login': (context) => const LoginScreen(),
  79. 'home': (context) => const HomeScreen(),
  80. 'producto': (context) =>
  81. ProductScreen(product: Product.staticSandwich()),
  82. 'carrito': (context) => const CarritoScreen(),
  83. 'perfil': (context) => const PerfilScreen(),
  84. 'Recojer': (context) => const RecojerScreen(),
  85. },
  86. );
  87. }
  88. }