Files
intaleq/lib/app_bindings.dart

69 lines
3.4 KiB
Dart

import 'package:get/get.dart';
import 'package:Intaleq/controller/auth/login_controller.dart';
import 'package:Intaleq/controller/firebase/firbase_messge.dart';
import 'package:Intaleq/controller/firebase/local_notification.dart';
import 'package:Intaleq/controller/home/deep_link_controller.dart';
import 'package:Intaleq/controller/local/local_controller.dart';
import 'package:Intaleq/controller/functions/tts.dart';
import 'package:Intaleq/controller/voice_call_controller.dart';
import 'package:Intaleq/controller/home/map/map_socket_controller.dart';
import 'package:Intaleq/controller/home/map/map_engine_controller.dart';
import 'package:Intaleq/controller/home/map/location_search_controller.dart';
import 'package:Intaleq/controller/home/map/nearby_drivers_controller.dart';
import 'package:Intaleq/controller/home/map/ride_lifecycle_controller.dart';
import 'package:Intaleq/controller/home/map/ui_interactions_controller.dart';
import 'package:Intaleq/controller/home/menu_controller.dart';
import 'package:Intaleq/controller/functions/crud.dart';
import 'package:Intaleq/controller/home/points_for_rider_controller.dart';
/// This is the central dependency injection file for the app.
/// It uses GetX Bindings to make the app start faster and manage memory better.
class AppBindings extends Bindings {
@override
void dependencies() {
// --- [Type 1: Permanent Controllers] ---
// Use Get.put() for controllers that need to be available immediately and ALWAYS.
// They are created right away and never destroyed.
// LocaleController is needed instantly to set the app's theme and language.
Get.put(LocaleController());
// DeepLinkController must always be listening for incoming links.
// `permanent: true` ensures it survives `Get.offAll()`.
Get.put(DeepLinkController(), permanent: true);
// --- [Type 2: Lazy Loaded "Phoenix" Controllers] ---
// Use Get.lazyPut() for controllers that are heavy or not needed immediately.
// They are only created in memory the first time `Get.find()` is called.
// `fenix: true` is the key: it allows the controller to be "reborn" after being
// destroyed (e.g., by Get.offAll), preserving its state and functionality.
// LoginController is only needed during the login process on the splash screen.
Get.lazyPut(() => LoginController(), fenix: true);
// NotificationController is initialized on the splash screen, but might be needed later.
Get.lazyPut(() => NotificationController(), fenix: true);
// FirebaseMessagesController is also initialized on splash, but must persist its token and listeners.
Get.lazyPut(() => FirebaseMessagesController(), fenix: true);
// TextToSpeechController for global accessibility
Get.lazyPut(() => TextToSpeechController(), fenix: true);
// VoiceCallController for WebRTC calls
Get.lazyPut(() => VoiceCallController(), fenix: true);
// Map & Ride controllers registered globally to prevent route-disposal race conditions.
Get.put(MapSocketController(), permanent: true);
Get.put(MapEngineController(), permanent: true);
Get.put(LocationSearchController(), permanent: true);
Get.put(NearbyDriversController(), permanent: true);
Get.put(RideLifecycleController(), permanent: true);
Get.put(UiInteractionsController(), permanent: true);
Get.put(MyMenuController(), permanent: true);
Get.put(CRUD(), permanent: true);
Get.put(WayPointController(), permanent: true);
}
}