From 5edfd12deb166302708857515a833d1471a0f208 Mon Sep 17 00:00:00 2001
From: zuoxiao <lf_zuo@163.com>
Date: 星期三, 25 六月 2025 16:15:23 +0800
Subject: [PATCH] feat(database): 增加管理卡相关功能并优化数据库结构- 新增 ManagerCardBean 数据类用于管理卡信息 - 在 AppDataBase 中添加 ManagerCardDao 接口 - 实现管理卡的数据库迁移策略 - 优化支付方式 ID 类型,从 Long改为 String - 重构更新写卡和上报状态的逻辑,支持管理卡和用户卡

---
 generallibrary/src/main/java/com/dayu/general/activity/RechargeDetailActivity.kt |   91 ++++++++++++++++++++++++++++-----------------
 1 files changed, 57 insertions(+), 34 deletions(-)

diff --git a/generallibrary/src/main/java/com/dayu/general/activity/RechargeDetailActivity.kt b/generallibrary/src/main/java/com/dayu/general/activity/RechargeDetailActivity.kt
index d8d053a..3ec2878 100644
--- a/generallibrary/src/main/java/com/dayu/general/activity/RechargeDetailActivity.kt
+++ b/generallibrary/src/main/java/com/dayu/general/activity/RechargeDetailActivity.kt
@@ -12,6 +12,7 @@
 import android.widget.Toast
 import androidx.appcompat.app.AppCompatActivity
 import com.dayu.baselibrary.net.subscribers.SubscriberListener
+import com.dayu.baselibrary.utils.MornyUtil
 import com.dayu.baselibrary.utils.ToastUtil
 import com.dayu.baselibrary.view.TitleBar
 import com.dayu.general.BaseApplication
@@ -25,6 +26,7 @@
 import com.dayu.general.databinding.ActivityRechargeDetailBinding
 import com.dayu.general.net.ApiManager
 import com.dayu.general.net.BaseResponse
+import com.dayu.general.tool.CardCommon.Companion.USER_CARD_TYPE_1
 import com.dayu.general.tool.CardOperationType
 
 class RechargeDetailActivity : AppCompatActivity() {
@@ -36,7 +38,7 @@
 
     // 鏀粯鏂瑰紡鐩稿叧灞炴��
     private var paymentMethod: String = "鐜伴噾"
-    private var paymentId: Long = 0
+    private var paymentId: String = ""
     private var paymentMethodList: List<PaymentMethod> = listOf()
 
     companion object {
@@ -44,7 +46,12 @@
         private const val EXTRA_CARD_ADDRESS = "extra_card_address"
         private const val EXTRA_USER_CARD = "extra_user_card"
 
-        fun start(context: Context, cardInfo: CardInfoResult?, cardAddress: String?, userCard: UserCard?) {
+        fun start(
+            context: Context,
+            cardInfo: CardInfoResult?,
+            cardAddress: String?,
+            userCard: UserCard?
+        ) {
             val intent = Intent(context, RechargeDetailActivity::class.java)
             intent.putExtra(EXTRA_CARD_INFO, cardInfo)
             intent.putExtra(EXTRA_CARD_ADDRESS, cardAddress)
@@ -85,7 +92,7 @@
             // 澶勭悊鍏呭�奸�昏緫
             handleRecharge()
         }
-        
+
         // 璁剧疆閲戦杈撳叆闄愬埗
         setupAmountInputLimit(binding.rechargeMorny)
         setupAmountInputLimit(binding.rechargeWater)
@@ -97,13 +104,13 @@
     private fun setupAmountInputLimit(editText: EditText) {
         editText.addTextChangedListener(object : TextWatcher {
             override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {}
-            
+
             override fun onTextChanged(s: CharSequence?, start: Int, before: Int, count: Int) {}
-            
+
             override fun afterTextChanged(s: Editable?) {
                 val text = s.toString()
                 if (text.isEmpty()) return
-                
+
                 // 妫�鏌ユ槸鍚﹀寘鍚皬鏁扮偣
                 if (text.contains(".")) {
                     val parts = text.split(".")
@@ -119,7 +126,7 @@
                         }
                     }
                 }
-                
+
                 // 闃叉杈撳叆澶氫釜灏忔暟鐐�
                 val dotCount = text.count { it == '.' }
                 if (dotCount > 1) {
@@ -129,7 +136,7 @@
                     editText.setSelection(newText.length)
                     editText.addTextChangedListener(this)
                 }
-                
+
                 // 闃叉浠ュ皬鏁扮偣寮�澶�
                 if (text.startsWith(".")) {
                     editText.removeTextChangedListener(this)
@@ -147,14 +154,14 @@
     private fun getPaymentMethods() {
         ApiManager.getInstance().requestGetLoading(
             this,
-            "sell/paymentmethod/get",
-            PaymentMethodResponse::class.java,
+            "terminal/paymentmethod/get",
+            Array<PaymentMethod>::class.java,
             null,
-            object : SubscriberListener<BaseResponse<PaymentMethodResponse>>() {
-                override fun onNext(response: BaseResponse<PaymentMethodResponse>) {
+            object : SubscriberListener<BaseResponse<Array<PaymentMethod>>>() {
+                override fun onNext(response: BaseResponse<Array<PaymentMethod>>) {
                     if (response.success) {
-                        // 鑾峰彇鏀粯鏂瑰紡鍒楄〃
-                        val paymentMethods = response.content?.obj ?: listOf()
+                        // 鑾峰彇鏀粯鏂瑰紡鍒楄〃锛岀幇鍦╟ontent鐩存帴鏄疨aymentMethod鏁扮粍
+                        val paymentMethods = response.content?.toList() ?: listOf()
                         if (paymentMethods.isNotEmpty()) {
                             paymentMethodList = paymentMethods
                             // 鏇存柊鏀粯鏂瑰紡鏄剧ず
@@ -248,9 +255,9 @@
             binding.redInitCode.text = cardAddress ?: ""
             binding.userName.text = info.userName ?: ""
             binding.redCardNum.text = info.cardNum ?: ""
-            
+
             // 浣跨敤鐢ㄦ埛鍗′腑鐨勪綑棰濇樉绀�
-            val balance = userCard?.let { 
+            val balance = userCard?.let {
                 // 灏嗗垎杞崲涓哄厓锛屼繚鐣欎袱浣嶅皬鏁�
                 String.format("%.2f", it.balance / 100.0)
             } ?: run {
@@ -260,7 +267,7 @@
             binding.redRemainderBlance.text = "$balance 鍏�"
 
             // 璁剧疆鍗$姸鎬佸拰瀵瑰簲棰滆壊
-            val cardStatus = when (info.status) {
+            val cardStatus = when (info.state) {
                 1 -> "姝e父"
                 2 -> "鎸傚け"
                 3 -> "閿佸畾"
@@ -270,7 +277,7 @@
             binding.redStatu.text = cardStatus
 
             // 鏍规嵁鍗$姸鎬佽缃笉鍚岄鑹�
-            val statusColor = when (info.status) {
+            val statusColor = when (info.state) {
                 1 -> android.graphics.Color.parseColor("#4CAF50") // 缁胯壊-姝e父
                 2 -> android.graphics.Color.parseColor("#FF9800") // 姗欒壊-鎸傚け
                 3 -> android.graphics.Color.parseColor("#F44336") // 绾㈣壊-閿佸畾
@@ -315,6 +322,25 @@
             0.0
         }
 
+        // 鑾峰彇褰撳墠浣欓锛堣浆鎹负鍏冿級
+        val currentBalance = userCard?.let {
+            // 灏嗗垎杞崲涓哄厓
+            it.balance / 100.0
+        } ?: run {
+            // 濡傛灉鐢ㄦ埛鍗′负绌猴紝鍒欎娇鐢ㄦ湇鍔″櫒杩斿洖鐨勪綑棰�
+            cardInfo?.balance ?: 0.0
+        }
+
+        // 璁$畻鍏呭�煎悗鐨勬�讳綑棰�
+        val totalAmountAfterRecharge = currentBalance + rechargeAmount + bonusAmount
+
+        // 妫�鏌ユ槸鍚﹁秴杩囨渶澶т綑棰濋檺鍒�9999.99鍏�
+        if (totalAmountAfterRecharge > 9999.99) {
+            val maxRechargeAmount = 9999.99 - currentBalance
+            ToastUtil.show("鍏呭�煎け璐ワ細鍏呭�煎悗浣欓涓嶈兘瓒呰繃9999.99鍏僜n褰撳墠浣欓锛�${String.format("%.2f", currentBalance)}鍏僜n鏈�澶氬彲鍏呭�硷細${String.format("%.2f", maxRechargeAmount)}鍏�")
+            return
+        }
+
         // 璋冪敤鍏呭�兼帴鍙�
         callRechargeApi(rechargeAmount, bonusAmount)
     }
@@ -339,7 +365,7 @@
             money = String.format("%.0f", rechargeAmount),
             amount = String.format("%.0f", bonusAmount),
             gift = String.format("%.0f", bonusAmount),
-            paymentId = paymentId.toString(),
+            paymentId = paymentId,
             price = String.format("%.2f", currentWaterPrice), // 浣跨敤缁熶竴鑾峰彇鐨勬按浠�
             remarks = "鍏呭��",
             operator = BaseApplication.userId // 榛樿鎿嶄綔鍛業D锛屽彲浠ユ牴鎹疄闄呮儏鍐佃皟鏁�
@@ -388,40 +414,37 @@
     /**
      * 鍚姩鍐欏崱鐣岄潰
      */
-    private fun startWriteCardActivity(rechargeResult: RechargeResult, rechargeAmount: Double, bonusAmount: Double) {
+    private fun startWriteCardActivity(
+        rechargeResult: RechargeResult,
+        rechargeAmount: Double,
+        bonusAmount: Double
+    ) {
         try {
             // 鍒涘缓UserCard瀵硅薄鐢ㄤ簬鍐欏崱
             val userCard = UserCard().apply {
                 // 璁剧疆鐢ㄦ埛鍗′俊鎭�
                 cardInfo?.let { info ->
-                    userCode = info.cardNum ?: ""
-                    balance = ((rechargeAmount + bonusAmount) * 100).toInt() // 杞崲涓哄垎
+                    balance = MornyUtil.changeY2F(rechargeResult.balance)
                 }
-                
+
                 // 璁剧疆鍏朵粬蹇呰淇℃伅
                 projectCode = rechargeResult.projectNo
-                waterPrice = rechargeResult.waterPrice.toFloat()
+                waterPrice = MornyUtil.changeY2F(rechargeResult.waterPrice.toString())
                 rechargeDate = java.util.Calendar.getInstance()
             }
 
             // 鍚姩鍐欏崱Activity
             val intent = Intent(this, NfcWreatActivity::class.java).apply {
-                putExtra("cardType", "USER_CARD") // 鐢ㄦ埛鍗$被鍨�
+                putExtra("cardType", USER_CARD_TYPE_1) // 鐢ㄦ埛鍗$被鍨�
                 putExtra("cardAddr", cardAddress)
                 putExtra("operationTypeCode", CardOperationType.Recharge.code)
                 putExtra("orderNumber", rechargeResult.orderNo)
                 putExtra("userCard", userCard)
+                putExtra("rechargeAmount", rechargeAmount) // 浼犻�掑厖鍊奸噾棰�
+                putExtra("bonusAmount", bonusAmount) // 浼犻�掕禒閫侀噾棰�
             }
-            
             startActivity(intent)
-            
-            // 鏄剧ず鎴愬姛淇℃伅
-            val formattedRecharge = String.format("%.2f", rechargeAmount)
-            val formattedBonus = String.format("%.2f", bonusAmount)
-            val formattedTotal = String.format("%.2f", rechargeAmount + bonusAmount)
-            
-            ToastUtil.show("鍏呭�艰鍗曞垱寤烘垚鍔焅n璁㈠崟鍙�: ${rechargeResult.orderNo}\n鍏呭�奸噾棰�: ${formattedRecharge}鍏僜n璧犻�侀噾棰�: ${formattedBonus}鍏僜n鎬婚噾棰�: ${formattedTotal}鍏僜n璇疯创鍗¤繘琛屽啓鍗℃搷浣�")
-            
+            finish()
         } catch (e: Exception) {
             ToastUtil.show("鍚姩鍐欏崱鐣岄潰澶辫触: ${e.message}")
         }

--
Gitblit v1.8.0