ExpressDeliveryFragment.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. package com.emato.ich.fragment;
  2. import android.os.Bundle;
  3. import android.os.CountDownTimer;
  4. import android.text.Editable;
  5. import android.view.LayoutInflater;
  6. import android.view.View;
  7. import android.view.ViewGroup;
  8. import android.widget.TextView;
  9. import androidx.annotation.NonNull;
  10. import androidx.annotation.Nullable;
  11. import androidx.fragment.app.Fragment;
  12. import com.emato.ich.MainActivity;
  13. import com.emato.ich.R;
  14. import com.emato.ich.api.ICSPClient;
  15. import com.emato.ich.contant.ICSPConstant;
  16. import com.emato.ich.contant.SystemConfigConstant;
  17. import com.emato.ich.databinding.FragmentExpressDeliveryBinding;
  18. import com.emato.ich.entity.vo.PreparedOrderResponseVo;
  19. import com.emato.ich.entity.vo.PreparedOrderVo;
  20. import com.emato.ich.entity.vo.ResponseData;
  21. import com.emato.ich.local.LocalStorage;
  22. import com.emato.ich.utils.BaseUtils;
  23. import com.emato.ich.utils.ButtonUtils;
  24. import com.emato.ich.utils.JacksonUtils;
  25. import com.emato.ich.utils.Log;
  26. import com.emato.ich.utils.LoggingUtils;
  27. import com.emato.ich.utils.NavUtils;
  28. import com.emato.ich.utils.StringUtils;
  29. import com.emato.ich.utils.TimeOutUtils;
  30. import com.emato.ich.utils.ToastUtils;
  31. import com.fasterxml.jackson.core.JsonProcessingException;
  32. import com.fasterxml.jackson.core.type.TypeReference;
  33. import com.fasterxml.jackson.databind.ObjectMapper;
  34. import org.jetbrains.annotations.NotNull;
  35. import java.io.IOException;
  36. import okhttp3.Call;
  37. import okhttp3.Callback;
  38. import okhttp3.Response;
  39. /**
  40. * 寄送投递页面
  41. */
  42. public class ExpressDeliveryFragment extends Fragment {
  43. private static final String TAG = ExpressDeliveryFragment.class.getName();
  44. private FragmentExpressDeliveryBinding binding;
  45. private CountDownTimer timer;
  46. private long start;
  47. private PreparedOrderResponseVo data;
  48. @Nullable
  49. @org.jetbrains.annotations.Nullable
  50. @Override
  51. public View onCreateView(@NonNull @NotNull LayoutInflater inflater, @Nullable @org.jetbrains.annotations.Nullable ViewGroup container, @Nullable @org.jetbrains.annotations.Nullable Bundle savedInstanceState) {
  52. start = System.currentTimeMillis();
  53. binding = FragmentExpressDeliveryBinding.inflate(inflater, container, false);
  54. return binding.getRoot();
  55. }
  56. public void onViewCreated(@NonNull View view, Bundle savedInstanceState) {
  57. long end = System.currentTimeMillis();
  58. Log.i(TAG, TAG + "页面渲染速度为" + (end - start) + "ms。");
  59. super.onViewCreated(view, savedInstanceState);
  60. // ColorConstant.setButtonColor(binding.returnBtn, ColorConstant.RETURN_BUTTON_BG_COLOR);
  61. try {
  62. MainActivity activity = ((MainActivity) getActivity());
  63. timer = TimeOutUtils.timeout(activity, ExpressDeliveryFragment.this, binding.timeout, 60);
  64. timer.start();
  65. } catch (Exception e) {
  66. Log.e(TAG, "onViewCreated: 倒计时出现异常! ", e);
  67. LoggingUtils.sendErrorLog("业务异常: 取件页面倒计时出现异常! ", e);
  68. }
  69. Bundle arguments = null;
  70. String sectionType = null;
  71. MainActivity activity = (MainActivity) getActivity();
  72. String url = activity.getConfigMap().get(SystemConfigConstant.cabinet_take_object_qrcode_url);
  73. arguments = activity.getBundleMap().get(ChooseCabinetFragment.class.getName());
  74. // 需要先跳转选柜子的页面后才能走这里
  75. sectionType = arguments.getString("section_type");
  76. /* if (getActivity() != null && activity.getConfigMap().size() > 0 && !StringUtils.isNullOrEmpty(url)) {
  77. // todo:这里可改为从后端获取寄件二维码图片
  78. ICSPClient.getWeChatMPImage(url, new Callback() {
  79. @Override
  80. public void onFailure(@NotNull Call call, @NotNull IOException e) {
  81. Log.e(TAG, "onFailure: 请求寄件二维码图片错误! 网络异常! ", e);
  82. LoggingUtils.sendErrorLog("业务异常: 请求寄件二维码图片错误! 网络异常!", e);
  83. }
  84. @Override
  85. public void onResponse(@NotNull Call call, @NotNull Response response) throws IOException {
  86. getActivity().runOnUiThread(() -> {
  87. try {
  88. InputStream is = response.body().byteStream();
  89. final Drawable d = Drawable.createFromStream(is, "src");
  90. binding.expressDeliveryQrCodeImage.setBackground(d);
  91. is.close();
  92. } catch (Exception e) {
  93. Log.e(TAG, "onResponse: 设置图片异常! ", e);
  94. LoggingUtils.sendErrorLog("业务异常: 设置图片异常! ", e);
  95. }
  96. });
  97. }
  98. });
  99. }*/
  100. binding.returnBtn.setOnClickListener(view1 -> {
  101. if (ButtonUtils.isFastClick()) {
  102. return;
  103. }
  104. if (null != timer) {
  105. timer.cancel();
  106. }
  107. NavUtils.navigate(this, R.id.action_expressDeliveryFragment_to_mainFragment);
  108. });
  109. // TODO 设置键盘塞值和处理确认按钮
  110. String finalSectionType = sectionType;
  111. binding.keyBoard.inputButtonConfirm.setOnClickListener(v -> {
  112. if (ButtonUtils.isFastClick()) {
  113. return;
  114. }
  115. // 点击确定按钮 获取到editTextDeliveryCode 的值 然后调用icsp判断投递码是否存在接口,在回调方法中判断是成功
  116. // 若成功则跳转页面到选择柜子类型的页面,
  117. // 在选择柜子类型页面判断如果是投递码投递跳转过来的 则调用投递码下单接口
  118. if(StringUtils.isNullOrEmpty(binding.editTextDeliveryCode.getText().toString())){
  119. ToastUtils.make(getContext(), "请求服务器失败!网络异常!");
  120. }else {
  121. Bundle bundle = new Bundle();
  122. // 验证完 预下单
  123. PreparedOrderVo preparedOrderVo = new PreparedOrderVo();
  124. preparedOrderVo.setClientId(BaseUtils.getClientId());
  125. preparedOrderVo.setDeliveryCode(binding.editTextDeliveryCode.getText().toString());
  126. preparedOrderVo.setLockerType(finalSectionType);
  127. // 预下单
  128. ICSPClient.preparedOrder(preparedOrderVo, new Callback() {
  129. @Override
  130. public void onFailure(@NotNull Call call, @NotNull IOException e) {
  131. // TODO 预下单调用失败
  132. ToastUtils.make(getContext(), "请求服务器失败!网络异常!");
  133. Log.e(TAG, "onFailure: 预下单失败! call: " + call.timeout().toString(), e);
  134. LoggingUtils.sendErrorLog("业务异常: 预下单失败! call: " + call.timeout().toString(), e);
  135. }
  136. @Override
  137. public void onResponse(@NotNull Call call, @NotNull Response response) {
  138. ((MainActivity) getActivity()).runOnUiThread(() -> {
  139. try {
  140. String responseStr = ICSPClient.isSuccessfulAndParseResponse(response);
  141. if (!StringUtils.isNullOrEmpty(responseStr)) {
  142. ObjectMapper objectMapper = JacksonUtils.objectmapper;
  143. ResponseData<PreparedOrderResponseVo> responseData = objectMapper.readValue(responseStr, new TypeReference<ResponseData<PreparedOrderResponseVo>>() {
  144. });
  145. data = responseData.getData();
  146. // 响应信息
  147. if (responseData.getCode().equals(ICSPConstant.OK)) {
  148. bundle.putString("preparedOrderResponse", objectMapper.writeValueAsString(data));
  149. bundle.putString("editTextDeliveryCode", binding.editTextDeliveryCode.getText().toString());
  150. bundle.putString("sectionType", finalSectionType);
  151. bundle.putString("takeNo", binding.editTextDeliveryCode.getText().toString());
  152. // 跳转到确认投递
  153. try {
  154. MainActivity activity = (MainActivity) getActivity();
  155. activity.getBundleMap().put(ExpressDeliveryFragment.class.getName(), bundle);
  156. } catch (RuntimeException e) {
  157. Log.e(TAG, "onResponse: InputInfoFragment页面获取SendInfoConfirmFragment传值错误! ", e);
  158. LoggingUtils.sendErrorLog("业务异常: InputInfoFragment页面获取SendInfoConfirmFragment传值错误! ", e);
  159. }
  160. if (null != timer) {
  161. timer.cancel();
  162. }
  163. NavUtils.navigate(ExpressDeliveryFragment.this, R.id.action_expressDeliveryFragment_to_sendInfoConfirmFragment);
  164. }
  165. Log.i(TAG, "onResponse: ICSP返回码: " + responseData.getCode() + ", 返回信息: " + responseData.getMsg());
  166. ToastUtils.make(getContext(), responseData.getMsg());
  167. } else {
  168. ToastUtils.make(getContext(), "服务器异常!请稍后重试!");
  169. }
  170. } catch (JsonProcessingException e) {
  171. Log.e(TAG, "onResponse: 预下单转换成JSON出错! ", e);
  172. LoggingUtils.sendErrorLog("业务异常: 预下单转换成JSON出错! ", e);
  173. } catch (RuntimeException e) {
  174. Log.e(TAG, "onResponse: 预下单失败! ", e);
  175. LoggingUtils.sendErrorLog("业务异常: 预下单失败! ", e);
  176. }
  177. });
  178. }
  179. });
  180. }
  181. });
  182. // 输入投递码
  183. binding.editTextDeliveryCode.requestFocus();
  184. binding.keyBoard.inputButton0.setOnClickListener(v -> {
  185. int length = binding.editTextDeliveryCode.getText().length();
  186. if (length >= 6) {
  187. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  188. return;
  189. }
  190. int start = binding.editTextDeliveryCode.getSelectionStart();
  191. binding.editTextDeliveryCode.getText().insert(start, "0");
  192. });
  193. binding.keyBoard.inputButton1.setOnClickListener(v -> {
  194. int length = binding.editTextDeliveryCode.getText().length();
  195. if (length >= 6) {
  196. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  197. return;
  198. }
  199. int start = binding.editTextDeliveryCode.getSelectionStart();
  200. binding.editTextDeliveryCode.getText().insert(start, "1");
  201. });
  202. binding.keyBoard.inputButton2.setOnClickListener(v -> {
  203. int length = binding.editTextDeliveryCode.getText().length();
  204. if (length >= 6) {
  205. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  206. return;
  207. }
  208. int start = binding.editTextDeliveryCode.getSelectionStart();
  209. binding.editTextDeliveryCode.getText().insert(start, "2");
  210. });
  211. binding.keyBoard.inputButton3.setOnClickListener(v -> {
  212. int length = binding.editTextDeliveryCode.getText().length();
  213. if (length >= 6) {
  214. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  215. return;
  216. }
  217. int start = binding.editTextDeliveryCode.getSelectionStart();
  218. binding.editTextDeliveryCode.getText().insert(start, "3");
  219. });
  220. binding.keyBoard.inputButton4.setOnClickListener(v -> {
  221. int length = binding.editTextDeliveryCode.getText().length();
  222. if (length >= 6) {
  223. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  224. return;
  225. }
  226. int start = binding.editTextDeliveryCode.getSelectionStart();
  227. binding.editTextDeliveryCode.getText().insert(start, "4");
  228. });
  229. binding.keyBoard.inputButton5.setOnClickListener(v -> {
  230. int length = binding.editTextDeliveryCode.getText().length();
  231. if (length >= 6) {
  232. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  233. return;
  234. }
  235. int start = binding.editTextDeliveryCode.getSelectionStart();
  236. binding.editTextDeliveryCode.getText().insert(start, "5");
  237. });
  238. binding.keyBoard.inputButton6.setOnClickListener(v -> {
  239. int length = binding.editTextDeliveryCode.getText().length();
  240. if (length >= 6) {
  241. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  242. return;
  243. }
  244. int start = binding.editTextDeliveryCode.getSelectionStart();
  245. binding.editTextDeliveryCode.getText().insert(start, "6");
  246. });
  247. binding.keyBoard.inputButton7.setOnClickListener(v -> {
  248. int length = binding.editTextDeliveryCode.getText().length();
  249. if (length >= 6) {
  250. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  251. return;
  252. }
  253. int start = binding.editTextDeliveryCode.getSelectionStart();
  254. binding.editTextDeliveryCode.getText().insert(start, "7");
  255. });
  256. binding.keyBoard.inputButton8.setOnClickListener(v -> {
  257. int length = binding.editTextDeliveryCode.getText().length();
  258. if (length >= 6) {
  259. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  260. return;
  261. }
  262. int start = binding.editTextDeliveryCode.getSelectionStart();
  263. binding.editTextDeliveryCode.getText().insert(start, "8");
  264. });
  265. binding.keyBoard.inputButton9.setOnClickListener(v -> {
  266. int length = binding.editTextDeliveryCode.getText().length();
  267. if (length >= 6) {
  268. ToastUtils.make(getContext(), "投递码不能超过6位! ");
  269. return;
  270. }
  271. int start = binding.editTextDeliveryCode.getSelectionStart();
  272. binding.editTextDeliveryCode.getText().insert(start, "9");
  273. });
  274. binding.keyBoard.inputButtonCancel.setOnClickListener(v -> {
  275. Editable text = binding.editTextDeliveryCode.getText();
  276. int start = binding.editTextDeliveryCode.getSelectionStart();
  277. if (text.length() > 0) {
  278. if (start > 0) {
  279. text.delete(start - 1, start);
  280. }
  281. binding.editTextDeliveryCode.setText(text, TextView.BufferType.EDITABLE);
  282. binding.editTextDeliveryCode.setSelection(start - 1 < 0 ? text.length() : start - 1);
  283. }
  284. });
  285. // 长按删除
  286. binding.keyBoard.inputButtonCancel.setOnLongClickListener(v -> {
  287. binding.editTextDeliveryCode.getText().clear();
  288. return false;
  289. });
  290. }
  291. @Override
  292. public void onDestroy() {
  293. if (timer != null) {
  294. timer.cancel();
  295. timer = null;
  296. }
  297. super.onDestroy();
  298. binding = null;
  299. Log.i(TAG, TAG + "被销毁。。。");
  300. }
  301. }