25-10-2/1

This commit is contained in:
Hamza-Ayed
2025-10-02 01:20:16 +03:00
parent 7595be8067
commit c48627a175
342 changed files with 15825 additions and 14862 deletions

View File

@@ -36,8 +36,8 @@ import 'splash_screen_page.dart';
final box = GetStorage();
final storage = FlutterSecureStorage();
// final PaymobPayment paymobPayment = PaymobPayment();
final PaymobPayment paymobPayment = PaymobPayment();
final PaymobPaymentWallet paymobPaymentWallet = PaymobPaymentWallet();
// final PaymobPayment paymobPayment = PaymobPayment();
// final PaymobPaymentWallet paymobPaymentWallet = PaymobPaymentWallet();
DbSql sql = DbSql.instance;
// EncryptionHelper encryptionHelper = EncryptionHelper.instance;
@@ -48,121 +48,246 @@ Future<void> backgroundMessageHandler(RemoteMessage message) async {
FirebaseMessagesController().fireBaseTitles(message);
}
void main() async {
WidgetsFlutterBinding.ensureInitialized();
WakelockPlus.enable();
void main() {
// ⚠️ لا تستدعِ ensureInitialized هنا خارج الزون
await GetStorage.init();
// --- إضافة جديدة: تهيئة وحدة التحكم في الروابط العميقة ---
Get.put(DeepLinkController(), permanent: true);
// ----------------------------------------------------
final AppInitializer initializer = AppInitializer();
runZonedGuarded(() async {
// 1) أنشئ الـ Binding في نفس الـ Zone
WidgetsFlutterBinding.ensureInitialized();
await initializer.initializeApp();
await EncryptionHelper.initialize();
NotificationController notificationController =
Get.put(NotificationController());
Stripe.publishableKey = AK.publishableKey;
// if (box.read(BoxName.driverID) != null) {}
if (Platform.isAndroid || Platform.isIOS) {
await Firebase.initializeApp(
options: DefaultFirebaseOptions.currentPlatform,
);
await FirebaseMessagesController().requestFirebaseMessagingPermission();
FirebaseMessaging.onBackgroundMessage(backgroundMessageHandler);
List<Future> initializationTasks = [
FirebaseMessagesController().getNotificationSettings(),
FirebaseMessagesController().getToken(),
];
// cameras = await availableCameras();
await Future.wait(initializationTasks);
SystemChrome.setPreferredOrientations([
DeviceOrientation.portraitUp,
DeviceOrientation.portraitDown,
]);
}
await notificationController.initNotifications();
// Generate a random index to pick a message
final random = Random();
final randomMessage = messages[random.nextInt(messages.length)];
// Schedule the notification with the random message
notificationController.scheduleNotificationsForSevenDays(
randomMessage.split(':')[0],
randomMessage.split(':')[1],
"tone1",
);
// final encryptionHelper = await EncryptionHelper.initialize();
final QuickActions quickActions = QuickActions();
quickActions.initialize((String shortcutType) {
// print('Activated shortcut: $shortcutType');
if (shortcutType == 'share_app') {
Get.toNamed('/shareApp');
} else if (shortcutType == 'wallet') {
Get.toNamed('/wallet');
} else if (shortcutType == 'profile') {
Get.toNamed('/profile');
} else if (shortcutType == 'contact_support') {
Get.toNamed('/contactSupport');
// 2) تهيئات خفيفة فقط قبل runApp
await GetStorage.init();
if (Platform.isAndroid || Platform.isIOS) {
await Firebase.initializeApp(
options: DefaultFirebaseOptions.currentPlatform);
FirebaseMessaging.onBackgroundMessage(backgroundMessageHandler);
await SystemChrome.setPreferredOrientations([
DeviceOrientation.portraitUp,
DeviceOrientation.portraitDown,
]);
}
});
quickActions.setShortcutItems(<ShortcutItem>[
ShortcutItem(
type: 'share_app',
localizedTitle: 'Share App'.tr,
icon: 'icon_share',
),
ShortcutItem(
type: 'wallet',
localizedTitle: 'Wallet'.tr,
icon: 'icon_wallet',
),
ShortcutItem(
type: 'profile',
localizedTitle: 'Profile'.tr,
icon: 'icon_user',
),
ShortcutItem(
type: 'contact_support',
localizedTitle: 'Contact Support'.tr,
icon: 'icon_support',
),
]);
Stripe.publishableKey = AK.publishableKey;
Get.put(DeepLinkController(), permanent: true);
runZonedGuarded<Future<void>>(() async {
// 3) شغّل التطبيق فوراً
runApp(const MyApp());
// 4) بعد أول إطار: التهيئات الثقيلة
WidgetsBinding.instance.addPostFrameCallback((_) async {
// لا Wakelock عالمي — فعّله فقط أثناء الرحلة
await WakelockPlus.enable();
final AppInitializer initializer = AppInitializer();
await initializer.initializeApp();
await EncryptionHelper.initialize();
final notificationController = Get.put(NotificationController());
await notificationController.initNotifications();
// أجّل طلب صلاحيات/توكن FCM
final fcm = FirebaseMessagesController();
await fcm.requestFirebaseMessagingPermission();
await fcm.getNotificationSettings();
await fcm.getToken();
// Generate a random index to pick a message
// Generate and schedule passenger daily notifications safely
try {
// 1) تأكد أن القائمة موجودة وغير فارغة
final List<String> msgs = passengerMessages ?? const [];
if (msgs.isEmpty) {
// fallback افتراضي إذا ما في رسائل
const fallbackTitle = 'Intaleq';
const fallbackBody = 'مرحباً بك! تابع رحلاتك بأمان مع انطلق.';
notificationController.scheduleNotificationsForSevenDays(
fallbackTitle,
fallbackBody,
"tone1",
);
} else {
// 2) اختَر عنصرًا عشوائيًا بأمان
final rnd = Random();
final idx = rnd.nextInt(msgs.length); // msgs.length > 0 أكيد
final raw = msgs[idx];
// 3) افصل العنوان/النص بأمان حتى لو ما في ':'
final parts = raw.split(':');
final title = parts.isNotEmpty ? parts.first.trim() : 'Intaleq';
final body = parts.length > 1
? parts.sublist(1).join(':').trim() // يحافظ على أي ':' إضافية
: 'مرحباً بك! تابع رحلاتك بأمان مع انطلق.';
// 4) جدولة الإشعارات
notificationController.scheduleNotificationsForSevenDays(
title.isEmpty ? 'Intaleq' : title,
body.isEmpty ? 'مرحباً بك! تابع رحلاتك بأمان مع انطلق.' : body,
"tone1",
);
}
} catch (e, st) {
// لا تعطل التشغيل بسبب إشعار اختياري
CRUD.addError('notif_init: $e', st.toString(), 'main');
}
final QuickActions quickActions = QuickActions();
quickActions.initialize((String shortcutType) {
// print('Activated shortcut: $shortcutType');
if (shortcutType == 'share_app') {
Get.toNamed('/shareApp');
} else if (shortcutType == 'wallet') {
Get.toNamed('/wallet');
} else if (shortcutType == 'profile') {
Get.toNamed('/profile');
} else if (shortcutType == 'contact_support') {
Get.toNamed('/contactSupport');
}
});
quickActions.setShortcutItems(<ShortcutItem>[
ShortcutItem(
type: 'share_app',
localizedTitle: 'Share App'.tr,
icon: 'icon_share',
),
ShortcutItem(
type: 'wallet',
localizedTitle: 'Wallet'.tr,
icon: 'icon_wallet',
),
ShortcutItem(
type: 'profile',
localizedTitle: 'Profile'.tr,
icon: 'icon_user',
),
ShortcutItem(
type: 'contact_support',
localizedTitle: 'Contact Support'.tr,
icon: 'icon_support',
),
]);
});
}, (error, stack) {
// ==== START: ERROR FILTER ====
String errorString = error.toString();
// Print all errors to the local debug console for development
print("Caught Dart error: $error");
print(stack);
// We will check if the error contains keywords for errors we want to ignore.
// If it's one of them, we will NOT send it to the server.
bool isIgnoredError = errorString.contains('PERMISSION_DENIED') ||
errorString.contains('FormatException') ||
errorString.contains('Null check operator used on a null value');
if (!isIgnoredError) {
// Only send the error to the server if it's not in our ignore list.
CRUD.addError(error.toString(), stack.toString(), 'main');
} else {
print("Ignoring error and not sending to server: $errorString");
}
// ==== END: ERROR FILTER ====
// بديل آمن للتجميع
final s = error.toString();
final ignored = s.contains('PERMISSION_DENIED') ||
s.contains('FormatException') ||
s.contains('Null check operator used on a null value');
if (!ignored) CRUD.addError(s, stack.toString(), 'main');
});
}
} // void main() async {
// WidgetsFlutterBinding.ensureInitialized();
// WakelockPlus.enable();
// await GetStorage.init();
// // --- إضافة جديدة: تهيئة وحدة التحكم في الروابط العميقة ---
// Get.put(DeepLinkController(), permanent: true);
// // ----------------------------------------------------
// final AppInitializer initializer = AppInitializer();
// await initializer.initializeApp();
// await EncryptionHelper.initialize();
// NotificationController notificationController =
// Get.put(NotificationController());
// // Stripe.publishableKey = AK.publishableKey;
// // if (box.read(BoxName.driverID) != null) {}
// if (Platform.isAndroid || Platform.isIOS) {
// await Firebase.initializeApp(
// options: DefaultFirebaseOptions.currentPlatform,
// );
// await FirebaseMessagesController().requestFirebaseMessagingPermission();
// FirebaseMessaging.onBackgroundMessage(backgroundMessageHandler);
// List<Future> initializationTasks = [
// FirebaseMessagesController().getNotificationSettings(),
// FirebaseMessagesController().getToken(),
// ];
// // cameras = await availableCameras();
// await Future.wait(initializationTasks);
// SystemChrome.setPreferredOrientations([
// DeviceOrientation.portraitUp,
// DeviceOrientation.portraitDown,
// ]);
// }
// await notificationController.initNotifications();
// // Generate a random index to pick a message
// final random = Random();
// final randomMessage = messages[random.nextInt(messages.length)];
// // Schedule the notification with the random message
// notificationController.scheduleNotificationsForSevenDays(
// randomMessage.split(':')[0],
// randomMessage.split(':')[1],
// "tone1",
// );
// final QuickActions quickActions = QuickActions();
// quickActions.initialize((String shortcutType) {
// // print('Activated shortcut: $shortcutType');
// if (shortcutType == 'share_app') {
// Get.toNamed('/shareApp');
// } else if (shortcutType == 'wallet') {
// Get.toNamed('/wallet');
// } else if (shortcutType == 'profile') {
// Get.toNamed('/profile');
// } else if (shortcutType == 'contact_support') {
// Get.toNamed('/contactSupport');
// }
// });
// quickActions.setShortcutItems(<ShortcutItem>[
// ShortcutItem(
// type: 'share_app',
// localizedTitle: 'Share App'.tr,
// icon: 'icon_share',
// ),
// ShortcutItem(
// type: 'wallet',
// localizedTitle: 'Wallet'.tr,
// icon: 'icon_wallet',
// ),
// ShortcutItem(
// type: 'profile',
// localizedTitle: 'Profile'.tr,
// icon: 'icon_user',
// ),
// ShortcutItem(
// type: 'contact_support',
// localizedTitle: 'Contact Support'.tr,
// icon: 'icon_support',
// ),
// ]);
// runZonedGuarded<Future<void>>(() async {
// runApp(const MyApp());
// }, (error, stack) {
// // ==== START: ERROR FILTER ====
// String errorString = error.toString();
// // Print all errors to the local debug console for development
// print("Caught Dart error: $error");
// print(stack);
// // We will check if the error contains keywords for errors we want to ignore.
// // If it's one of them, we will NOT send it to the server.
// bool isIgnoredError = errorString.contains('PERMISSION_DENIED') ||
// errorString.contains('FormatException') ||
// errorString.contains('Null check operator used on a null value');
// if (!isIgnoredError) {
// // Only send the error to the server if it's not in our ignore list.
// CRUD.addError(error.toString(), stack.toString(), 'main');
// } else {
// print("Ignoring error and not sending to server: $errorString");
// }
// // ==== END: ERROR FILTER ====
// });
// }
class MyApp extends StatelessWidget {
const MyApp({super.key});