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