From 899cb6ce779b24a659ec3515dd3fb1cd1afef7d2 Mon Sep 17 00:00:00 2001
From: zuojincheng <lf_zuo@163.com>
Date: 星期二, 24 六月 2025 14:02:46 +0800
Subject: [PATCH] feat(card): 增加区域表号卡制作功能

---
 generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt |  128 +++++++++++++++++++++++++++++++++++-------
 1 files changed, 105 insertions(+), 23 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 af6c1dc..b8bd087 100644
--- a/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
+++ b/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
@@ -41,6 +41,13 @@
     // 杩旇繕鐩稿叧淇℃伅
     private var returnAmount = 0.0
 
+    // 琛ユ墸鐩稿叧淇℃伅
+    private var deductAmount = 0.0
+
+    // 琛ュ崱鐩稿叧淇℃伅
+    private var cardCost = 0.0
+    private var reissueAmount = 0.0
+
     //璁㈠崟缂栧彿
     var orderNumber = ""
     private lateinit var userCard: UserCard
@@ -74,6 +81,13 @@
 
         // 鑾峰彇杩旇繕鐩稿叧淇℃伅
         returnAmount = intent?.getDoubleExtra("returnAmount", 0.0) ?: 0.0
+
+        // 鑾峰彇琛ユ墸鐩稿叧淇℃伅
+        deductAmount = intent?.getDoubleExtra("deductAmount", 0.0) ?: 0.0
+
+        // 鑾峰彇琛ュ崱鐩稿叧淇℃伅
+        cardCost = intent?.getDoubleExtra("cardCost", 0.0) ?: 0.0
+        reissueAmount = intent?.getDoubleExtra("reissueAmount", 0.0) ?: 0.0
 
         if (intent?.hasExtra("cardFee") == true) {
             cardFee = intent?.getIntExtra("cardFee", 0) ?: 0
@@ -148,10 +162,7 @@
                     if (userCard.balance != 0) {
                         val totalBalanceInYuan = userCard.balance / 100.0 // 杞崲涓哄厓
                         textData.append(
-                            "鍗″唴鎬讳綑棰濓細" + String.format(
-                                "%.2f",
-                                totalBalanceInYuan
-                            ) + "鍏�"
+                            "鍏呭�煎悗浣欓锛�" + MornyUtil.changeF2Y(userCard.balance)+ "鍏�"
                         )
                     }
 
@@ -174,9 +185,45 @@
                     binding?.cardData?.text = textData.toString()
                 }
 
-                CardOperationType.CheckCard -> TODO()
-                CardOperationType.DeductCard -> TODO()
-                CardOperationType.ReplaceCard -> TODO()
+                CardOperationType.DeductCard -> {
+                    var textData = StringBuilder()
+                    textData.append("琛ユ墸\n")
+                    textData.append("鍗″唴浣欓锛�" + MornyUtil.changeF2Y(userCard.balance) + "鍏僜n")
+                    textData.append("琛ユ墸閲戦锛�" + deductAmount + "鍏�")
+                    binding?.cardData?.text = textData.toString()
+                }
+
+                CardOperationType.ReplaceCard -> {
+                    var textData = StringBuilder()
+                    textData.append("琛ュ崱\n")
+                    textData.append("鍗″唴浣欓锛�" + MornyUtil.changeF2Y(userCard.balance) + "鍏僜n")
+                    if (cardCost > 0) {
+                        textData.append("宸ユ湰璐癸細" + String.format("%.2f", cardCost) + "鍏僜n")
+                    }
+                    if (reissueAmount > 0) {
+                        textData.append("琛ュ崱閲戦锛�" + String.format("%.2f", reissueAmount) + "鍏�")
+                    }
+                    binding?.cardData?.text = textData.toString()
+                }
+
+                CardOperationType.CheckCard -> {
+                    var textData = StringBuilder()
+                    textData.append("妫�鏌ュ崱鍒朵綔")
+                    binding?.cardData?.text = textData.toString()
+                }
+                
+                CardOperationType.RegionCard -> {
+                    var textData = StringBuilder()
+                    textData.append("鍖哄煙琛ㄥ彿鍗″埗浣�")
+                    binding?.cardData?.text = textData.toString()
+                }
+                
+                CardOperationType.DebugCard -> {
+                    var textData = StringBuilder()
+                    textData.append("璋冭瘯鍗″埗浣�")
+                    binding?.cardData?.text = textData.toString()
+                }
+                
                 null -> TODO()
             }
         }
@@ -193,19 +240,8 @@
             val nfcWreatHelper = NfcWreatHelper.getInstance(intent, this)
             when (operationType) {
                 CardOperationType.CleanCard -> {
-                    var clearCard = ClearCard()
-                    nfcWreatHelper.writeData(clearCard.getZeroBytes(), 7, 0) { success, message ->
-                        // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢�
-                        runOnUiThread {
-                            if (success) {
-                                postCardData(cardAddr)
-                                ToastUtil.show("鍐欏崱鎴愬姛!")
-                            } else {
-                                // 澶勭悊鍐欏崱澶辫触鐨勬儏鍐�
-                                ToastUtil.show(message)
-                            }
-                        }
-                    }
+
+
                 }
 
                 CardOperationType.OpenCard -> {
@@ -272,9 +308,54 @@
                     })
                 }
 
-                CardOperationType.CheckCard -> TODO()
-                CardOperationType.DeductCard -> TODO()
-                CardOperationType.ReplaceCard -> TODO()
+                CardOperationType.DeductCard -> {
+                    nfcWreatHelper.writeUserDataAsync(userCard, object : NFCCallBack {
+                        override fun isSusses(flag: Boolean, msg: String?) {
+                            // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢�
+                            runOnUiThread {
+                                if (flag) {
+                                    postCardData(cardAddr)
+                                } else {
+                                    ToastUtil.show("琛ユ墸鍐欏崱澶辫触: ${msg ?: "鏈煡閿欒"}")
+                                }
+                            }
+                        }
+                    })
+                }
+
+                CardOperationType.ReplaceCard -> {
+                    nfcWreatHelper.writeUserDataAsync(userCard, object : NFCCallBack {
+                        override fun isSusses(flag: Boolean, msg: String?) {
+                            // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢�
+                            runOnUiThread {
+                                if (flag) {
+                                    postCardData(cardAddr)
+                                } else {
+                                    ToastUtil.show("琛ュ崱鍐欏崱澶辫触: ${msg ?: "鏈煡閿欒"}")
+                                }
+                            }
+                        }
+                    })
+                }
+
+                CardOperationType.CheckCard -> {
+                    // 妫�鏌ュ崱鍐欏崱閫昏緫
+                    ToastUtil.show("妫�鏌ュ崱鍐欏崱鎴愬姛!")
+                    postCardData(cardAddr)
+                }
+                
+                CardOperationType.RegionCard -> {
+                    // 鍖哄煙琛ㄥ彿鍗″啓鍗¢�昏緫
+                    ToastUtil.show("鍖哄煙琛ㄥ彿鍗″啓鍗℃垚鍔�!")
+                    postCardData(cardAddr)
+                }
+                
+                CardOperationType.DebugCard -> {
+                    // 璋冭瘯鍗″啓鍗¢�昏緫
+                    ToastUtil.show("璋冭瘯鍗″啓鍗℃垚鍔�!")
+                    postCardData(cardAddr)
+                }
+                
                 null -> TODO()
             }
         } else {
@@ -305,6 +386,7 @@
                         finish()
                         Intent(this@NfcWreatActivity, CardWriteSuccessActivity::class.java).apply {
                             putExtra("cardNumber", cardNumber)
+                            putExtra("userCard", userCard)
                             putExtra("operationTypeCode", operationTypeCode)
                             startActivity(this)
                         }

--
Gitblit v1.8.0