main.dart 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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';
  6. import 'mvvm/views/home/home_screen.dart';
  7. import 'mvvm/views/login/login_screen.dart';
  8. import '/utils/themes.dart';
  9. import 'mvvm/viewmodels/viewmodels.dart';
  10. import 'package:timezone/data/latest.dart' as tzdata;
  11. void main() async {
  12. WidgetsFlutterBinding.ensureInitialized();
  13. tzdata.initializeTimeZones();
  14. // Inicialización de la base de datos para plataformas de escritorio con FFI
  15. if (Platform.isWindows || Platform.isLinux) {
  16. sqfliteFfiInit();
  17. databaseFactory = databaseFactoryFfi;
  18. }
  19. SystemChrome.setPreferredOrientations([
  20. DeviceOrientation.landscapeRight,
  21. DeviceOrientation.landscapeLeft,
  22. ]).then((_) {
  23. runApp(MultiProvider(providers: [
  24. ChangeNotifierProvider(create: (_) => LoginViewModel()),
  25. ChangeNotifierProvider(create: (_) => SucursalViewModel()),
  26. ChangeNotifierProvider(create: (_) => PermisoViewModel()),
  27. ChangeNotifierProvider(create: (_) => UsuarioViewModel()),
  28. // Agrega aquí cualquier otro provider que necesites
  29. ], child: const MyApp()));
  30. });
  31. }
  32. class MyApp extends StatelessWidget {
  33. const MyApp({super.key});
  34. @override
  35. Widget build(BuildContext context) {
  36. return MaterialApp(
  37. locale: const Locale("en", "ES"),
  38. debugShowCheckedModeBanner: false,
  39. title: 'Turquessa',
  40. theme: AppTheme.lightTheme,
  41. initialRoute: 'login',
  42. routes: {
  43. 'login': (context) => const LoginScreen(),
  44. 'home': (context) => const HomeScreen(),
  45. },
  46. );
  47. }
  48. }