164 lines
6.3 KiB
Dart
164 lines
6.3 KiB
Dart
import 'package:get/get.dart';
|
|
import 'package:kaer_with_panels/app/common/app_run_data.dart';
|
|
import 'package:kaer_with_panels/app/widgets/dialogs/kr_dialog.dart';
|
|
import 'package:kaer_with_panels/app/routes/app_pages.dart';
|
|
import 'package:kaer_with_panels/app/utils/kr_log_util.dart';
|
|
import 'package:kaer_with_panels/app/localization/app_translations.dart';
|
|
import 'dart:io';
|
|
import 'package:path_provider/path_provider.dart';
|
|
|
|
/// 订阅导航工具类
|
|
/// 用于统一处理订阅相关的导航逻辑
|
|
class KRSubscribeNavigationUtil {
|
|
/// 导航到购买会员页面
|
|
/// 如果是设备登录用户,会先提示需要绑定账号,然后跳转到登录页面
|
|
/// 如果是普通用户,直接跳转到购买会员页面
|
|
///
|
|
/// [tag] 调用来源标签,用于日志记录
|
|
static void navigateToPurchase({String tag = 'Subscribe'}) {
|
|
print('🔔 [NavigationUtil] ========== navigateToPurchase 被调用 ==========');
|
|
print('🔔 [NavigationUtil] Tag: $tag');
|
|
print('🔔 [NavigationUtil] 当前时间: ${DateTime.now()}');
|
|
|
|
// 🔧 先获取关键信息并打印
|
|
final appRunData = KRAppRunData.getInstance();
|
|
final isDeviceLogin = appRunData.isDeviceLogin();
|
|
final account = appRunData.kr_account.value;
|
|
|
|
print('🔔 [NavigationUtil] 账号: $account');
|
|
print('🔔 [NavigationUtil] 是否设备登录: $isDeviceLogin');
|
|
|
|
KRLogUtil.kr_i('=== 订阅按钮点击 ===', tag: tag);
|
|
KRLogUtil.kr_i('账号: $account', tag: tag);
|
|
KRLogUtil.kr_i('是否设备登录: $isDeviceLogin', tag: tag);
|
|
|
|
// 🔧 文件写入改为非阻塞,放在后面
|
|
Future(() async {
|
|
try {
|
|
final dir = await getApplicationDocumentsDirectory();
|
|
final debugFile = File('${dir.path}/NAVIGATION_DEBUG.txt');
|
|
await debugFile.writeAsString(
|
|
'=' * 60 + '\n'
|
|
'🔔 navigateToPurchase 被调用!\n'
|
|
'时间: ${DateTime.now()}\n'
|
|
'来源: $tag\n'
|
|
'账号: $account\n'
|
|
'是否设备登录: $isDeviceLogin\n'
|
|
'版本标识: Android15_Fix_v5\n'
|
|
'=' * 60 + '\n',
|
|
mode: FileMode.append,
|
|
);
|
|
} catch (e) {
|
|
print('🔔 [NavigationUtil] ❌ 写入导航日志失败: $e');
|
|
}
|
|
});
|
|
|
|
if (isDeviceLogin) {
|
|
// 设备登录用户需要绑定账号
|
|
print('🔔 [NavigationUtil] ⚠️ 检测到设备登录,将显示绑定提示对话框');
|
|
KRLogUtil.kr_i('检测到设备登录,显示绑定提示', tag: tag);
|
|
|
|
// 🔧 记录显示对话框
|
|
Future(() async {
|
|
try {
|
|
final dir = await getApplicationDocumentsDirectory();
|
|
final debugFile = File('${dir.path}/NAVIGATION_DEBUG.txt');
|
|
await debugFile.writeAsString(
|
|
'⚠️ 用户是设备登录,显示绑定提示对话框\n'
|
|
'时间: ${DateTime.now()}\n'
|
|
'-' * 60 + '\n',
|
|
mode: FileMode.append,
|
|
);
|
|
} catch (e) { /* 忽略 */ }
|
|
});
|
|
|
|
KRDialog.show(
|
|
title: AppTranslations.kr_dialog.deviceLoginBindingTitle,
|
|
message: AppTranslations.kr_dialog.deviceLoginBindingMessage,
|
|
confirmText: AppTranslations.kr_dialog.kr_ok,
|
|
cancelText: AppTranslations.kr_dialog.kr_cancel,
|
|
onConfirm: () {
|
|
Get.back(); // 关闭对话框
|
|
// 等待对话框完全关闭后再跳转到登录页面
|
|
Future.delayed(const Duration(milliseconds: 300), () {
|
|
Get.toNamed(Routes.MR_LOGIN);
|
|
});
|
|
},
|
|
onCancel: () => Get.back(),
|
|
);
|
|
} else {
|
|
// 正常流程 - 跳转到购买页面
|
|
print('🔔 [NavigationUtil] ✅ 普通用户,准备跳转到购买页面');
|
|
KRLogUtil.kr_i('普通用户,跳转到购买页面', tag: tag);
|
|
|
|
// 🔧 立即记录准备跳转
|
|
Future(() async {
|
|
try {
|
|
final dir = await getApplicationDocumentsDirectory();
|
|
final debugFile = File('${dir.path}/NAVIGATION_DEBUG.txt');
|
|
await debugFile.writeAsString(
|
|
'✅ 普通用户,准备调用 Get.toNamed\n'
|
|
'路由: ${Routes.KR_PURCHASE_MEMBERSHIP}\n'
|
|
'时间: ${DateTime.now()}\n'
|
|
'-' * 60 + '\n',
|
|
mode: FileMode.append,
|
|
);
|
|
} catch (e) { /* 忽略 */ }
|
|
});
|
|
|
|
try {
|
|
// 🔧 添加加载保护,避免页面跳转时卡死
|
|
print('🔔 [NavigationUtil] 📍 步骤1: 正在调用 Get.toNamed(${Routes.KR_PURCHASE_MEMBERSHIP})...');
|
|
final result = Get.toNamed(Routes.KR_PURCHASE_MEMBERSHIP);
|
|
print('🔔 [NavigationUtil] 📍 步骤2: Get.toNamed 调用完成,返回值: $result');
|
|
|
|
// 🔧 文件写入改为非阻塞
|
|
Future(() async {
|
|
try {
|
|
final dir = await getApplicationDocumentsDirectory();
|
|
final debugFile = File('${dir.path}/NAVIGATION_DEBUG.txt');
|
|
await debugFile.writeAsString(
|
|
'✅ Get.toNamed 执行完成\n'
|
|
'路由: ${Routes.KR_PURCHASE_MEMBERSHIP}\n'
|
|
'返回值: $result\n'
|
|
'时间: ${DateTime.now()}\n'
|
|
'-' * 60 + '\n',
|
|
mode: FileMode.append,
|
|
);
|
|
} catch (e) {
|
|
print('🔔 [NavigationUtil] ❌ 写入跳转完成日志失败: $e');
|
|
}
|
|
});
|
|
} catch (e) {
|
|
KRLogUtil.kr_e('跳转购买页面失败: $e', tag: tag);
|
|
print('🔔 [NavigationUtil] ❌❌❌ 跳转异常: $e');
|
|
|
|
// 🔧 文件写入改为非阻塞
|
|
Future(() async {
|
|
try {
|
|
final dir = await getApplicationDocumentsDirectory();
|
|
final debugFile = File('${dir.path}/NAVIGATION_DEBUG.txt');
|
|
await debugFile.writeAsString(
|
|
'❌ Get.toNamed 执行失败\n'
|
|
'异常: $e\n'
|
|
'时间: ${DateTime.now()}\n'
|
|
'-' * 60 + '\n',
|
|
mode: FileMode.append,
|
|
);
|
|
} catch (e) {
|
|
print('🔔 [NavigationUtil] ❌ 写入跳转失败日志失败: $e');
|
|
}
|
|
});
|
|
|
|
// 如果跳转失败,显示错误提示
|
|
KRDialog.show(
|
|
title: AppTranslations.kr_dialog.error,
|
|
message: AppTranslations.kr_home.checkNetwork,
|
|
confirmText: AppTranslations.kr_dialog.kr_ok,
|
|
onConfirm: () => Get.back(),
|
|
);
|
|
}
|
|
}
|
|
}
|
|
}
|