0
0

SendSuccessFragment.java 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package com.emato.ich.fragment;
  2. import android.os.Bundle;
  3. import android.os.CountDownTimer;
  4. import com.emato.ich.utils.Log;
  5. import android.view.LayoutInflater;
  6. import android.view.View;
  7. import android.view.ViewGroup;
  8. import androidx.annotation.NonNull;
  9. import androidx.annotation.Nullable;
  10. import androidx.fragment.app.Fragment;
  11. import androidx.navigation.fragment.NavHostFragment;
  12. import com.emato.ich.MainActivity;
  13. import com.emato.ich.R;
  14. import com.emato.ich.databinding.FragmentSendSuccessBinding;
  15. import com.emato.ich.local.LocalStorage;
  16. import com.emato.ich.utils.ButtonUtils;
  17. import com.emato.ich.utils.LoggingUtils;
  18. import com.emato.ich.utils.TimeOutUtils;
  19. import org.jetbrains.annotations.NotNull;
  20. /**
  21. * 投递成功页面
  22. */
  23. public class SendSuccessFragment extends Fragment {
  24. private static final String TAG = SendSuccessFragment.class.getName();
  25. private FragmentSendSuccessBinding binding;
  26. private CountDownTimer timer;
  27. @Nullable
  28. @org.jetbrains.annotations.Nullable
  29. @Override
  30. public View onCreateView(@NonNull @NotNull LayoutInflater inflater, @Nullable @org.jetbrains.annotations.Nullable ViewGroup container, @Nullable @org.jetbrains.annotations.Nullable Bundle savedInstanceState) {
  31. binding = FragmentSendSuccessBinding.inflate(inflater, container, false);
  32. return binding.getRoot();
  33. }
  34. public void onViewCreated(@NonNull @NotNull View view, @Nullable @org.jetbrains.annotations.Nullable Bundle savedInstanceState) {
  35. // ColorConstant.setButtonColor(binding.returnMainBtn, ColorConstant.RETURN_BUTTON_BG_COLOR);
  36. try {
  37. MainActivity activity = ((MainActivity) getActivity());
  38. timer = TimeOutUtils.timeout(activity, SendSuccessFragment.this, binding.timeout, 60);
  39. timer.start();
  40. } catch (Exception e) {
  41. Log.e(TAG, "onViewCreated: 倒计时出现异常! ", e);
  42. LoggingUtils.sendErrorLog("业务异常: 投递成功页面倒计时出现异常! ", e);
  43. }
  44. // 继续投递
  45. binding.continueSendBtn.setOnClickListener(view1 -> {
  46. if (ButtonUtils.isFastClick()) {
  47. return;
  48. }
  49. timer.cancel();
  50. // 继续投递重新计算异常处理次数
  51. LocalStorage.getInstance().getSession().setException(true);
  52. NavHostFragment.findNavController(SendSuccessFragment.this)
  53. .navigate(R.id.action_sendSuccessFragment_to_chooseCabinetFragment);
  54. });
  55. // 退出账号
  56. binding.exitAccountBtn.setOnClickListener(view1 -> {
  57. if (ButtonUtils.isFastClick()) {
  58. return;
  59. }
  60. // 清空Session
  61. MainActivity activity = (MainActivity) getActivity();
  62. LocalStorage.getInstance().cleanSession(activity);
  63. timer.cancel();
  64. NavHostFragment.findNavController(SendSuccessFragment.this)
  65. .navigate(R.id.action_sendSuccessFragment_to_mainFragment);
  66. });
  67. binding.returnMainBtn.setOnClickListener(view1 -> {
  68. if (ButtonUtils.isFastClick()) {
  69. return;
  70. }
  71. timer.cancel();
  72. MainActivity activity = (MainActivity) getActivity();
  73. LocalStorage.getInstance().cleanSession(activity);
  74. NavHostFragment.findNavController(SendSuccessFragment.this)
  75. .navigate(R.id.action_sendSuccessFragment_to_mainFragment);
  76. });
  77. }
  78. @Override
  79. public void onDestroy() {
  80. if (timer != null) {
  81. timer.cancel();
  82. timer = null;
  83. }
  84. super.onDestroy();
  85. binding = null;
  86. }
  87. }