优化邀请码在不登录的时候要求客户去登录

This commit is contained in:
Rust 2025-10-22 22:17:06 +08:00
parent 17ea51b583
commit f1a8dfe4e7
5 changed files with 110 additions and 17 deletions

View File

@ -201,6 +201,7 @@
"myInviteCode": "My Invite Code",
"inviteCodeCopied": "Invite code copied to clipboard",
"close": "Close",
"pleaseLoginFirst": "Please login first to view invitation code",
"saveQRCode": "Save QR Code",
"qrCodeSaved": "QR Code saved",
"copiedToClipboard": "Copied to clipboard",

View File

@ -264,6 +264,7 @@
"myInviteCode": "我的邀请码",
"inviteCodeCopied": "邀请码已复制到剪贴板",
"close": "关闭",
"pleaseLoginFirst": "请先登录后查看邀请码",
"saveQRCode": "保存二维码",
"qrCodeSaved": "二维码已保存",
"copiedToClipboard": "已复制到剪贴板",

View File

@ -653,6 +653,9 @@ class AppTranslationsInvite {
///
String get close => 'invite.close'.tr;
///
String get pleaseLoginFirst => 'invite.pleaseLoginFirst'.tr;
}
class AppTranslationsMessage {

View File

@ -13,6 +13,7 @@ import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:kaer_with_panels/app/widgets/kr_app_text_style.dart';
import 'package:kaer_with_panels/app/modules/kr_main/controllers/kr_main_controller.dart';
import 'package:easy_refresh/easy_refresh.dart';
import 'package:kaer_with_panels/app/widgets/dialogs/kr_dialog.dart';
///
class KRInviteProgress {
@ -47,13 +48,22 @@ class KRInviteController extends GetxController {
final count = 0.obs;
final EasyRefreshController refreshController = EasyRefreshController();
//
bool _hasShownDialog = false;
@override
void onInit() {
super.onInit();
ever(KRAppRunData.getInstance().kr_isLogin, (value) {
if (value) {
final appRunData = KRAppRunData.getInstance();
//
ever(appRunData.kr_isLogin, (value) {
//
if (value && !appRunData.isDeviceLogin()) {
_kr_fetchUserInfo();
_kr_fetchAffiliateCount();
_hasShownDialog = false; //
} else {
kr_progress.value = KRInviteProgress(
pending: 0,
@ -66,12 +76,68 @@ class KRInviteController extends GetxController {
kr_referCode.value = '';
}
});
if (KRAppRunData.getInstance().kr_isLogin.value) {
//
if (appRunData.kr_isLogin.value && !appRunData.isDeviceLogin()) {
_kr_fetchUserInfo();
_kr_fetchAffiliateCount();
}
}
///
void kr_onPageEnter() {
final appRunData = KRAppRunData.getInstance();
final isDeviceLogin = appRunData.isDeviceLogin();
KRLogUtil.kr_i('📄 [InviteController] 页面进入', tag: 'InviteController');
KRLogUtil.kr_i(' - kr_isLogin: ${appRunData.kr_isLogin.value}', tag: 'InviteController');
KRLogUtil.kr_i(' - isDeviceLogin: $isDeviceLogin', tag: 'InviteController');
KRLogUtil.kr_i(' - _hasShownDialog: $_hasShownDialog', tag: 'InviteController');
//
if ((!appRunData.kr_isLogin.value || isDeviceLogin) && !_hasShownDialog) {
_hasShownDialog = true; //
KRLogUtil.kr_i('🔒 [InviteController] 未登录或设备登录,显示绑定提示对话框', tag: 'InviteController');
//
Future.delayed(const Duration(milliseconds: 100), () {
KRLogUtil.kr_i('💬 [InviteController] 准备显示对话框...', tag: 'InviteController');
try {
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: () {
KRLogUtil.kr_i('✅ [InviteController] 用户点击确定,跳转到登录页', tag: 'InviteController');
Get.back(); //
//
Future.delayed(const Duration(milliseconds: 300), () {
//
Get.find<KRMainController>().kr_setPage(0);
Future.delayed(const Duration(milliseconds: 100), () {
Get.toNamed(Routes.MR_LOGIN);
});
});
},
onCancel: () {
KRLogUtil.kr_i('❌ [InviteController] 用户点击取消,返回首页', tag: 'InviteController');
Get.back(); //
//
Future.delayed(const Duration(milliseconds: 100), () {
Get.find<KRMainController>().kr_setPage(0);
});
},
);
KRLogUtil.kr_i('✅ [InviteController] 对话框已显示', tag: 'InviteController');
} catch (e) {
KRLogUtil.kr_e('❌ [InviteController] 显示对话框失败: $e', tag: 'InviteController');
}
});
}
}
// kr_getUserInfo
// AppRunData
Future<void> _kr_fetchUserInfo() async {
@ -105,7 +171,9 @@ class KRInviteController extends GetxController {
}
Future<bool> kr_checkLoginStatus() async {
return KRAppRunData.getInstance().kr_isLogin.value;
final appRunData = KRAppRunData.getInstance();
//
return appRunData.kr_isLogin.value && !appRunData.isDeviceLogin();
}
///
@ -306,11 +374,13 @@ class KRInviteController extends GetxController {
}
Future<void> kr_onRefresh() async {
if (!KRAppRunData.getInstance().kr_isLogin.value) {
final appRunData = KRAppRunData.getInstance();
//
if (!appRunData.kr_isLogin.value || appRunData.isDeviceLogin()) {
refreshController.finishRefresh();
return;
}
try {
await _kr_fetchUserInfo();
await _kr_fetchAffiliateCount();

View File

@ -2,6 +2,7 @@ import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:kaer_with_panels/app/common/app_config.dart';
import 'package:kaer_with_panels/app/common/app_run_data.dart';
import 'package:kaer_with_panels/app/localization/app_translations.dart';
import 'package:kaer_with_panels/app/widgets/kr_app_text_style.dart';
import 'package:kaer_with_panels/app/widgets/kr_local_image.dart';
@ -48,16 +49,32 @@ class KRInviteView extends GetView<KRInviteController> {
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Theme.of(context).primaryColor,
body: EasyRefresh(
controller: controller.refreshController,
onRefresh: controller.kr_onRefresh,
header: DeliveryHeader(
triggerOffset: 50.0,
springRebound: true,
),
child: CustomScrollView(
physics: const BouncingScrollPhysics(),
slivers: [
body: Obx(() {
// 使 Obx
final appRunData = KRAppRunData.getInstance();
final isDeviceLogin = appRunData.isDeviceLogin();
final isLoggedIn = appRunData.kr_isLogin.value && !isDeviceLogin;
if (!isLoggedIn) {
//
// 使 WidgetsBinding
WidgetsBinding.instance.addPostFrameCallback((_) {
controller.kr_onPageEnter();
});
return Container(); //
}
//
return EasyRefresh(
controller: controller.refreshController,
onRefresh: controller.kr_onRefresh,
header: DeliveryHeader(
triggerOffset: 50.0,
springRebound: true,
),
child: CustomScrollView(
physics: const BouncingScrollPhysics(),
slivers: [
SliverAppBar(
expandedHeight: 150.w,
floating: false,
@ -140,7 +157,8 @@ class KRInviteView extends GetView<KRInviteController> {
),
],
),
),
);
}), // Obx
);
}