keyboard_controller.dart 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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/keyboard_repository.dart';
  8. import 'package:keyboard/module/keyboard_manage/keyboard_manage_page.dart';
  9. import 'package:keyboard/module/store/store_page.dart';
  10. import '../../data/api/response/keyboard_love_index_response.dart';
  11. import '../../utils/atmob_log.dart';
  12. import '../profile/profile_page.dart';
  13. @injectable
  14. class KeyBoardController extends BaseController {
  15. final tag = "KeyBoardController";
  16. final KeyboardRepository keyboardRepository;
  17. KeyboardHomeInfoResponse? get homeInfo => keyboardRepository.homeInfo.value;
  18. Rxn<KeyboardLoveIndexResponse> get loveIndex =>
  19. keyboardRepository.homeLoveIndex;
  20. static const int countdownTime = 10 * 60 * 100;
  21. final RxInt timeLeft = countdownTime.obs;
  22. Timer? _timer;
  23. final RxBool isShowBanner = true.obs;
  24. // 各项指标数据
  25. KeyBoardController(this.keyboardRepository);
  26. @override
  27. void onInit() {
  28. super.onInit();
  29. startCountdown();
  30. }
  31. void clickVip() {
  32. StorePage.start();
  33. }
  34. void clickIntimacyAnalyze() {
  35. debugPrint("click intimacy analyze");
  36. }
  37. void clickScreenshotReply() {
  38. debugPrint("click screenshot reply");
  39. }
  40. void clickEasyReply() {
  41. debugPrint("click easy reply");
  42. }
  43. void clickGoKeyboardManage() {
  44. KeyboardManagePage.start();
  45. }
  46. void clickCloseBanner() {
  47. isShowBanner.value = false;
  48. debugPrint("click close banner");
  49. }
  50. void clickAvatar(bool isUser) {
  51. debugPrint("click avatar");
  52. if (!isUser) {
  53. ProfilePage.start();
  54. }
  55. }
  56. void startCountdown() {
  57. _timer = Timer.periodic(const Duration(milliseconds: 10), (timer) {
  58. if (timeLeft.value > 0) {
  59. timeLeft.value--;
  60. } else {
  61. timer.cancel();
  62. }
  63. });
  64. }
  65. @override
  66. void onClose() {
  67. super.onClose();
  68. _timer?.cancel();
  69. }
  70. String get formattedTime {
  71. final totalMillis = timeLeft.value * 10;
  72. final duration = Duration(milliseconds: totalMillis);
  73. final minutes = duration.inMinutes.toString().padLeft(2, '0');
  74. final seconds = (duration.inSeconds % 60).toString().padLeft(2, '0');
  75. final milliseconds = ((duration.inMilliseconds % 1000) ~/ 10)
  76. .toString()
  77. .padLeft(2, '0');
  78. return "$minutes:$seconds:$milliseconds";
  79. }
  80. }