From a8751388c9a86ae95714a15279994d8aa426a26d Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期五, 13 六月 2025 14:59:02 +0800
Subject: [PATCH] feat(generallibrary): 优化充值功能并添加水价获取- 在 activity_recharge_detail.xml 中移除了不必要的 bold 样式- 在 EditText 中添加了金额输入限制(数字和小数点)- 在 BaseApplication 中添加了水价信息存储 - 在 MainActivity 中实现了延时获取水价的功能- 优化了 RechargeDetailActivity 中的水价检查和使用逻辑 - 在 README.md 中添加了金额格式化和水价获取的最佳实践指南

---
 generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt |   60 +++++++++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 47 insertions(+), 13 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 3c9910b..dbdc7ff 100644
--- a/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
+++ b/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt
@@ -28,7 +28,6 @@
 class NfcWreatActivity : BaseNfcActivity() {
     var binding: ActivityNfcWriteGeBinding? = null
     var cardType = ""
-    var orderId = ""
     var cardAddr = ""
     var cardFee = 0
 
@@ -50,9 +49,9 @@
      */
     private fun getInitData() {
         cardType = intent?.getStringExtra("cardType") ?: ""
-        orderId = intent?.getStringExtra("orderId") ?: ""
         cardAddr = intent?.getStringExtra("cardAddr") ?: ""
         operationTypeCode = intent?.getIntExtra("operationTypeCode", -1) ?: -1
+        orderNumber = intent?.getStringExtra("orderNumber") ?: ""
         operationType = CardOperationType.fromCode(operationTypeCode)
         if (intent?.hasExtra("cardFee") == true) {
             cardFee = intent?.getIntExtra("cardFee", 0) ?: 0
@@ -84,10 +83,21 @@
                     binding?.cardData?.text = textData.toString()
                 }
 
+                CardOperationType.Recharge -> {
+                    var textData = StringBuilder()
+                    textData.append("鐢ㄦ埛鍏呭�糪n")
+                    textData.append("璁㈠崟鍙凤細" + orderNumber + "\n")
+                    if (userCard.balance != 0) {
+                        val balanceInYuan = userCard.balance / 100.0 // 杞崲涓哄厓
+                        textData.append("鍏呭�奸噾棰濓細" + String.format("%.2f", balanceInYuan) + "鍏�")
+                    }
+
+                    binding?.cardData?.text = textData.toString()
+                }
+
                 CardOperationType.CancelCard -> TODO()
                 CardOperationType.CheckCard -> TODO()
                 CardOperationType.DeductCard -> TODO()
-                CardOperationType.Recharge -> TODO()
                 CardOperationType.ReplaceCard -> TODO()
                 null -> TODO()
             }
@@ -111,10 +121,7 @@
                         runOnUiThread {
                             if (success) {
                                 postCardData(cardType, cardAddr)
-                                // 鍐欏崱鎴愬姛鍚庢洿鏂版暟鎹簱涓殑isCardWritten鐘舵��
-                                updateCardWrittenStatus(cardAddr)
                                 ToastUtil.show("鍐欏崱鎴愬姛!")
-                                // 澶勭悊鍐欏崱鎴愬姛鐨勬儏鍐�
                             } else {
                                 // 澶勭悊鍐欏崱澶辫触鐨勬儏鍐�
                                 ToastUtil.show(message)
@@ -129,9 +136,8 @@
                             // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢�
                             runOnUiThread {
                                 if (flag) {
-                                    // 鍐欏崱鎴愬姛鍚庢洿鏂版暟鎹簱涓殑isCardWritten鐘舵��
-                                    updateCardWrittenStatus(cardAddr)
-                                    ToastUtil.show("鍐欏崱鎴愬姛!")
+                                    postCardData(cardType, cardAddr)
+
                                 } else {
                                     ToastUtil.show("鍐欏崱澶辫触: ${msg ?: "鏈煡閿欒"}")
                                 }
@@ -141,10 +147,25 @@
 
                 }
 
+                CardOperationType.Recharge -> {
+                    nfcWreatHelper.writeUserDataAsync(userCard, object : NFCCallBack {
+                        override fun isSusses(flag: Boolean, msg: String?) {
+                            // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢�
+                            runOnUiThread {
+                                if (flag) {
+                                    postCardData(cardType, cardAddr)
+                                    ToastUtil.show("鍏呭�煎啓鍗℃垚鍔�!")
+                                } else {
+                                    ToastUtil.show("鍏呭�煎啓鍗″け璐�: ${msg ?: "鏈煡閿欒"}")
+                                }
+                            }
+                        }
+                    })
+                }
+
                 CardOperationType.CancelCard -> TODO()
                 CardOperationType.CheckCard -> TODO()
                 CardOperationType.DeductCard -> TODO()
-                CardOperationType.Recharge -> TODO()
                 CardOperationType.ReplaceCard -> TODO()
                 null -> TODO()
             }
@@ -169,11 +190,23 @@
                     val updatedCardRegistration = cardRegistration.copy(isCardWritten = true)
                     // 鏇存柊鏁版嵁搴撹褰�
                     cardRegistrationDao.update(updatedCardRegistration)
+                    
+                    // 鍦ㄤ富绾跨▼涓叧闂瑼ctivity
+                    runOnUiThread {
+                        setResult(RESULT_OK)
+                        finish()
+                        Intent(this@NfcWreatActivity, CardWriteSuccessActivity::class.java).apply {
+                            putExtra("cardNumber", cardNumber)
+                            startActivity(this)
+                        }
+                    }
                 }
             } catch (e: Exception) {
                 CrashReport.postCatchedException(e)
                 e.printStackTrace()
-                ToastUtil.show("鏇存柊鍐欏崱鐘舵�佸け璐�: ${e.message}")
+                runOnUiThread {
+                    ToastUtil.show("鏇存柊鍐欏崱鐘舵�佸け璐�: ${e.message}")
+                }
             }
         }
     }
@@ -203,8 +236,9 @@
             object : SubscriberListener<BaseResponse<String>>() {
                 override fun onNext(t: BaseResponse<String>) {
                     if (t.success) {
-                        ToastUtil.show("鍐欏崱鎴愬姛")
-                        this@NfcWreatActivity.finish()
+
+                        updateCardWrittenStatus(cardAddr)
+
 
                     } else {
                         // 澶勭悊鎼滅储澶辫触鐨勬儏鍐�

--
Gitblit v1.8.0