From 1bc1acff2127d61b359800096ad5b904370d9176 Mon Sep 17 00:00:00 2001
From: zuojincheng <lf_zuo@163.com>
Date: 星期三, 26 三月 2025 09:25:47 +0800
Subject: [PATCH] refactor(nfc): 重构 NFC 读写助手类

---
 generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt |  105 ++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 88 insertions(+), 17 deletions(-)

diff --git a/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt b/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
index 45d5bba..cd60f9c 100644
--- a/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
+++ b/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
@@ -1,20 +1,27 @@
-package com.dayu.general.activity
+    package com.dayu.general.activity
 
 import android.content.Intent
 import android.os.Bundle
+import com.dayu.baselibrary.net.subscribers.SubscriberListener
+import com.dayu.baselibrary.utils.ToastUtil
+import com.dayu.general.bean.card.ClearCard
 import com.dayu.general.tool.CardCommon
 import com.dayu.general.databinding.ActivityNfcWriteGeBinding
+import com.dayu.general.net.ApiManager
+import com.dayu.general.net.BaseResponse
+import com.dayu.general.tool.NfcReadHelper
+import com.dayu.general.tool.NfcWreatHelper
 
 /**
  * @author: zuo
  * @date: 2021/3/30
  * @description:鍐欏崱鐣岄潰
  */
-class NfcWreatActivity:BaseNfcActivity() {
-
-    var binding:ActivityNfcWriteGeBinding? = null
-
+class NfcWreatActivity : BaseNfcActivity() {
+    var binding: ActivityNfcWriteGeBinding? = null
     var cardType = ""
+    var orderId = ""
+    var cardAddr = ""
 
     override fun onCreate(savedInstanceState: Bundle?) {
         super.onCreate(savedInstanceState)
@@ -26,25 +33,89 @@
     /**
      * 鑾峰彇鏁版嵁
      */
-    private fun getInitData(){
-        cardType= intent?.getStringExtra("cardType")?:""
+    private fun getInitData() {
+        cardType = intent?.getStringExtra("cardType") ?: ""
+        orderId = intent?.getStringExtra("orderId") ?: ""
+        cardAddr = intent?.getStringExtra("cardAddr") ?: ""
+        if (cardType.isNotEmpty()) {
+            when (cardType) {
+                CardCommon.CLEAN_CARD_TYPE -> {
+                    binding?.cardData?.text = "娓呴浂鍗″啓鍗�"
+                }
+
+            }
+        }
+
     }
 
-    private fun setTextData(){
-        when(cardType){
-            CardCommon.CHECK_CARD->{
-                binding?.cardData?.text = "鍐欑敤鎴峰崱"
-            }
 
+    override fun onNfcBack(intent: Intent) {
+        val nfcReadHelper = NfcReadHelper.getInstance(intent, this)
+        val cardNumber = nfcReadHelper.getCardNumberNoClose()
+        if (cardNumber.isNotEmpty() && cardNumber == cardAddr) {
+            val nfcWreatHelper = NfcWreatHelper.getInstance(intent, this)
+            when (cardType) {
+                CardCommon.CLEAN_CARD_TYPE -> {
+                    var clearCard = ClearCard()
+                    nfcWreatHelper.writeData(clearCard.getZeroBytes(), 7, 0) { success, message ->
+                        if (success) {
+                            postCardData(cardType, cardAddr, "")
+                            ToastUtil.show("鍐欏崱鎴愬姛!")
+                            // 澶勭悊鍐欏崱鎴愬姛鐨勬儏鍐�
+                        } else {
+                            // 澶勭悊鍐欏崱澶辫触鐨勬儏鍐�
+                            ToastUtil.show(message)
+                        }
+                    }
+                }
+            }
+        } else {
+            ToastUtil.show("鍗$墖閿欒锛屽綋鍓嶅埛鐨勫崱涓庡垰鍒氱殑鍗′笉涓�鑷�")
         }
     }
-    override fun onNfcBack(intent: Intent?) {
-        TODO("Not yet implemented")
-        when(cardType){
-            CardCommon.CHECK_CARD->{
+
+    fun postCardData(cardType: String, cardAddr: String, remark: String) {
+        when (cardType) {
+            CardCommon.CHECK_CARD -> {
                 binding?.cardData?.text = "鍐欑敤鎴峰崱"
             }
-
         }
+        val map = mutableMapOf<String, Any>()
+
+        if (cardAddr.isNotEmpty()) {
+            map["cardAddr"] = cardAddr
+        }
+
+        if (cardType.isNotEmpty()) {
+//            map["cardType"] = cardType
+            map["cardType"] = "5"
+        }
+        if (remark.isNotEmpty()) {
+            map["remarks"] = remark
+        }
+        // 浣跨敤姝g‘鐨勭被鍨嬪弬鏁�
+        ApiManager.getInstance().requestPostLoading(
+            this,
+            "/sell/card/call_back",
+            String::class.java,
+            map,
+            object : SubscriberListener<BaseResponse<String>>() {
+                override fun onNext(t: BaseResponse<String>) {
+                    if (t.success) {
+                        this@NfcWreatActivity.finish()
+                    } else {
+                        // 澶勭悊鎼滅储澶辫触鐨勬儏鍐�
+                        ToastUtil.show(t.msg)
+                    }
+                }
+
+                override fun onError(e: Throwable?) {
+                    super.onError(e)
+                    ToastUtil.show("鎼滅储澶辫触: ${e?.message ?: "鏈煡閿欒"}")
+                }
+            }
+        )
     }
+
+
 }
\ No newline at end of file

--
Gitblit v1.8.0