keyboard_controller.dart 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. import 'dart:async';
  2. import 'package:flutter/widgets.dart';
  3. import 'package:get/get.dart';
  4. import 'package:injectable/injectable.dart';
  5. import 'package:keyboard/base/base_controller.dart';
  6. import 'package:keyboard/data/api/response/keyboard_home_info_response.dart';
  7. import 'package:keyboard/data/repository/account_repository.dart';
  8. import 'package:keyboard/data/repository/keyboard_repository.dart';
  9. import 'package:keyboard/module/intimacy_analyse/enums/intimacy_analyse_tab.dart';
  10. import 'package:keyboard/module/keyboard_manage/keyboard_manage_page.dart';
  11. import 'package:keyboard/module/store/new_discount/new_discount_page.dart';
  12. import 'package:keyboard/module/store/store_page.dart';
  13. import 'package:keyboard/module/user_profile/user_profile_page.dart';
  14. import '../../data/api/response/keyboard_love_index_response.dart';
  15. import '../../data/bean/member_info.dart';
  16. import '../../utils/keyboard_tutorial_util.dart';
  17. import '../intimacy_analyse/intimacy_analyse_page.dart';
  18. import '../intimacy_scale/intimacy_scale_page.dart';
  19. import '../keyboard_guide/keyboard_guide_page.dart';
  20. import '../profile/profile_page.dart';
  21. @injectable
  22. class KeyBoardController extends BaseController {
  23. final tag = "KeyBoardController";
  24. final KeyboardRepository keyboardRepository;
  25. final AccountRepository accountRepository;
  26. KeyboardHomeInfoResponse? get homeInfo => keyboardRepository.homeInfo.value;
  27. MemberInfo? get memberInfo => accountRepository.memberStatusInfo.value;
  28. bool get isLogin => accountRepository.isLogin.value;
  29. Rxn<KeyboardLoveIndexResponse> get loveIndex =>
  30. keyboardRepository.homeLoveIndex;
  31. static const int countdownTime = 10 * 60 * 100;
  32. final RxInt timeLeft = countdownTime.obs;
  33. Timer? _timer;
  34. final RxBool isShowBanner = true.obs;
  35. // 各项指标数据
  36. KeyBoardController(this.keyboardRepository, this.accountRepository);
  37. @override
  38. void onInit() {
  39. super.onInit();
  40. // 初始判断一次
  41. _updateBannerState();
  42. // 实时监听登录状态变化
  43. ever(accountRepository.isLogin, (_) {
  44. _updateBannerState();
  45. });
  46. // 实时监听会员信息变化
  47. ever(accountRepository.memberStatusInfo, (_) {
  48. _updateBannerState();
  49. });
  50. }
  51. /// 根据当前登录状态 & 会员信息更新 banner显示逻辑
  52. void _updateBannerState() {
  53. if (isLogin && (memberInfo?.isMember == true)) {
  54. isShowBanner.value = false;
  55. _timer?.cancel(); // 停止倒计时
  56. } else {
  57. if (isShowBanner.value == false) {
  58. isShowBanner.value = true;
  59. }
  60. if (_timer == null || !_timer!.isActive) {
  61. startCountdown();
  62. }
  63. }
  64. }
  65. void clickVip() {
  66. StorePage.start();
  67. }
  68. void clickIntimacyAnalyze() {
  69. debugPrint("click intimacy analyze");
  70. IntimacyAnalysePage.start(tab: IntimacyAnalyseTab.intimacyAnalyseReport);
  71. }
  72. void clickScreenshotReply() {
  73. debugPrint("click screenshot reply");
  74. IntimacyAnalysePage.start(
  75. tab: IntimacyAnalyseTab.intimacyAnalyseScreenshotReply,
  76. );
  77. }
  78. void clickEasyReply() {
  79. KeyboardTutorialUtil.start();
  80. debugPrint("click easy reply");
  81. }
  82. void clickGoKeyboardManage() {
  83. KeyboardManagePage.start();
  84. }
  85. void clickCloseBanner() {
  86. isShowBanner.value = false;
  87. debugPrint("click close banner");
  88. }
  89. void clickAvatar(bool isUser) {
  90. debugPrint("click avatar");
  91. if (!isUser) {
  92. ProfilePage.start();
  93. } else {
  94. UserProfilePage.start();
  95. }
  96. }
  97. void clickBanner() {
  98. debugPrint("click banner");
  99. NewDiscountPage.start();
  100. }
  101. void clickLovePercentage() {
  102. IntimacyScalePage.start();
  103. }
  104. void startCountdown() {
  105. _timer = Timer.periodic(const Duration(milliseconds: 10), (timer) {
  106. if (timeLeft.value > 0) {
  107. timeLeft.value--;
  108. } else {
  109. isShowBanner.value = false;
  110. timer.cancel();
  111. }
  112. });
  113. }
  114. @override
  115. void onClose() {
  116. super.onClose();
  117. _timer?.cancel();
  118. }
  119. String get formattedTime {
  120. final totalMillis = timeLeft.value * 10;
  121. final duration = Duration(milliseconds: totalMillis);
  122. final minutes = duration.inMinutes.toString().padLeft(2, '0');
  123. final seconds = (duration.inSeconds % 60).toString().padLeft(2, '0');
  124. final milliseconds = ((duration.inMilliseconds % 1000) ~/ 10)
  125. .toString()
  126. .padLeft(2, '0');
  127. return "$minutes:$seconds:$milliseconds";
  128. }
  129. }