TakeSuccessFragment.java 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. package com.emato.ich.fragment;
  2. import android.os.Bundle;
  3. import android.os.CountDownTimer;
  4. import android.util.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.api.ICSPClient;
  15. import com.emato.ich.api.ICSPResponseCodeEnum;
  16. import com.emato.ich.api.SystemConfigConstant;
  17. import com.emato.ich.databinding.FragmentTakeSuccessBinding;
  18. import com.emato.ich.entity.vo.ResponseData;
  19. import com.emato.ich.entity.vo.TakeParcelVo;
  20. import com.emato.ich.local.LocalStorage;
  21. import com.emato.ich.utils.BaseUtils;
  22. import com.fasterxml.jackson.core.JsonProcessingException;
  23. import com.fasterxml.jackson.core.type.TypeReference;
  24. import com.fasterxml.jackson.databind.ObjectMapper;
  25. import com.google.android.material.snackbar.Snackbar;
  26. import org.jetbrains.annotations.NotNull;
  27. import java.io.IOException;
  28. import okhttp3.Call;
  29. import okhttp3.Callback;
  30. import okhttp3.Response;
  31. public class TakeSuccessFragment extends Fragment {
  32. private static final String TAG = TakeSuccessFragment.class.getName();
  33. private FragmentTakeSuccessBinding binding;
  34. @Nullable
  35. @org.jetbrains.annotations.Nullable
  36. @Override
  37. public View onCreateView(@NonNull @NotNull LayoutInflater inflater, @Nullable @org.jetbrains.annotations.Nullable ViewGroup container, @Nullable @org.jetbrains.annotations.Nullable Bundle savedInstanceState) {
  38. binding = FragmentTakeSuccessBinding.inflate(inflater, container, false);
  39. return binding.getRoot();
  40. }
  41. public void onViewCreated(@NonNull View view, Bundle savedInstanceState) {
  42. binding.continueTakeBtn.setOnClickListener(view1 -> NavHostFragment.findNavController(TakeSuccessFragment.this)
  43. .navigate(R.id.action_takeSuccessFragment_to_takeCodeFragment));
  44. binding.returnMainBtn.setOnClickListener(view1 -> NavHostFragment.findNavController(TakeSuccessFragment.this)
  45. .navigate(R.id.action_takeSuccessFragment_to_mainFragment));
  46. try {
  47. MainActivity activity = (MainActivity) getActivity();
  48. String s = activity.getConfigMap().get(SystemConfigConstant.cabinet_take_object_reopen_time);
  49. // 倒计时
  50. int i = Integer.parseInt(s);
  51. CountDownTimer timer = new CountDownTimer(i * 1000, 1000) {
  52. @Override
  53. public void onTick(long millisUntilFinished) {
  54. binding.openCabinetCountDownHint.setText(String.format("倒计时%s秒,只有一次机会,超时后不可开门!", (millisUntilFinished / 1000)));
  55. }
  56. @Override
  57. public void onFinish() {
  58. binding.openCabinetCountDownHint.setText("已超时,不可开门!");
  59. binding.reOpenCabinetBtn.setEnabled(false);
  60. }
  61. };
  62. timer.start();
  63. } catch (RuntimeException e) {
  64. Log.e(TAG, "onViewCreated: 倒计时未知异常! ", e);
  65. }
  66. binding.reOpenCabinetBtn.setOnClickListener(view1 -> {
  67. binding.reOpenCabinetBtn.setEnabled(false);
  68. // TODO 取件逻辑
  69. String takeParcelCode = null;
  70. MainActivity activity = null;
  71. try {
  72. activity = (MainActivity) getActivity();
  73. Bundle bundle = activity.getBundleMap().get(TakeCodeFragment.class.getName());
  74. takeParcelCode = bundle.getString("takeParcelCode");
  75. } catch (RuntimeException e) {
  76. Log.e(TAG, "onViewCreated: 获取TakeCodeFragment传值TakeSuccessFragment失败! ", e);
  77. }
  78. TakeParcelVo takeParcelVo = new TakeParcelVo();
  79. takeParcelVo.setClientId(BaseUtils.getClientId());
  80. takeParcelVo.setPickUp(takeParcelCode);
  81. takeParcelVo.setReopen("1");
  82. MainActivity finalActivity = activity;
  83. ICSPClient.takeParcel(LocalStorage.getInstance().getSession().getToken(), takeParcelVo, new Callback() {
  84. @Override
  85. public void onFailure(@NotNull Call call, @NotNull IOException e) {
  86. // TODO 取件接口请求失败逻辑处理
  87. Snackbar.make(view, "取件失败!网络异常!", Snackbar.LENGTH_LONG).show();
  88. Log.e(TAG, "onFailure: 取件请求失败!", e);
  89. }
  90. @Override
  91. public void onResponse(@NotNull Call call, @NotNull Response response) throws IOException {
  92. // TODO 返回锁板和锁id, 开柜门
  93. getActivity().runOnUiThread(() -> {
  94. String parseResponse = ICSPClient.isSuccessfulAndParseResponse(response);
  95. try {
  96. ObjectMapper objectMapper = new ObjectMapper();
  97. ResponseData responseData = null;
  98. try {
  99. responseData = objectMapper.readValue(parseResponse, new TypeReference<ResponseData>() {
  100. });
  101. ICSPResponseCodeEnum.responseHint(view1, responseData);
  102. } catch (JsonProcessingException e) {
  103. Log.e(TAG, "onResponse: 解析取件开门响应信息失败! ", e);
  104. } catch (RuntimeException e) {
  105. Log.e(TAG, "onResponse: 未知错误! ", e);
  106. Snackbar.make(view1, "未知错误!", Snackbar.LENGTH_LONG).show();
  107. }
  108. if (null != responseData && responseData.getCode().equals(ICSPResponseCodeEnum.OK.getCode())) {
  109. // 开门
  110. Log.i(TAG, "onResponse: 取件成功! ");
  111. Snackbar.make(view1, "取件成功!", Snackbar.LENGTH_LONG).show();
  112. finalActivity.getBundleMap().remove(TakeCodeFragment.class.getName());
  113. } else {
  114. ICSPResponseCodeEnum.responseHint(view1, responseData);
  115. }
  116. } catch (RuntimeException e) {
  117. Log.e(TAG, "onResponse: 取件失败! ", e);
  118. Snackbar.make(view1, "取件失败!", Snackbar.LENGTH_LONG).show();
  119. }
  120. });
  121. }
  122. });
  123. });
  124. }
  125. @Override
  126. public void onDestroy() {
  127. super.onDestroy();
  128. binding = null;
  129. }
  130. }