From 9a2399d1a0003d1f2935720474b325639454178d Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期二, 10 六月 2025 17:25:25 +0800 Subject: [PATCH] feat(general): 新增卡片操作类型并优化写卡逻辑 --- generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt | 117 ++++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 81 insertions(+), 36 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 74bb8e9..3c9910b 100644 --- a/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt +++ b/generallibrary/src/main/java/com/dayu/general/activity/NfcWreatActivity.kt @@ -9,6 +9,7 @@ import com.dayu.general.bean.card.ClearCard import com.dayu.general.bean.card.UserCard import com.dayu.general.tool.CardCommon +import com.dayu.general.tool.CardOperationType import com.dayu.general.databinding.ActivityNfcWriteGeBinding import com.dayu.general.net.ApiManager import com.dayu.general.net.BaseResponse @@ -17,6 +18,7 @@ import com.dayu.general.dao.BaseDaoSingleton import com.tencent.bugly.crashreport.CrashReport import kotlinx.coroutines.launch +import java.lang.StringBuilder /** * @author: zuo @@ -28,7 +30,13 @@ var cardType = "" var orderId = "" var cardAddr = "" + var cardFee = 0 + + //璁㈠崟缂栧彿 + var orderNumber = "" private lateinit var userCard: UserCard + private var operationTypeCode = -1; + private var operationType: CardOperationType? = null override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) @@ -44,18 +52,44 @@ cardType = intent?.getStringExtra("cardType") ?: "" orderId = intent?.getStringExtra("orderId") ?: "" cardAddr = intent?.getStringExtra("cardAddr") ?: "" - if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.TIRAMISU) { - userCard = intent?.getSerializableExtra("userCard", UserCard::class.java)!! - } else { - userCard = (intent?.getSerializableExtra("userCard") as? UserCard)!! + operationTypeCode = intent?.getIntExtra("operationTypeCode", -1) ?: -1 + operationType = CardOperationType.fromCode(operationTypeCode) + if (intent?.hasExtra("cardFee") == true) { + cardFee = intent?.getIntExtra("cardFee", 0) ?: 0 } + if (intent?.hasExtra("userCard") == true) { + if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.TIRAMISU) { + userCard = intent?.getSerializableExtra("userCard", UserCard::class.java)!! + } else { + userCard = (intent?.getSerializableExtra("userCard") as? UserCard)!! + } - if (cardType.isNotEmpty()) { - when (cardType) { - CardCommon.CLEAN_CARD_TYPE -> { + } + if (operationTypeCode != -1) { + when (operationType) { + CardOperationType.CleanCard -> { binding?.cardData?.text = "娓呴浂鍗″啓鍗�" } + CardOperationType.OpenCard -> { + var textData = StringBuilder() + textData.append("鐢ㄦ埛寮�鍗n") + if (cardFee != 0) { + textData.append("宸ユ湰璐癸細" + cardFee + "鍏僜n") + } + if (userCard.balance != 0) { + textData.append("鍏呭�奸噾棰濓細" + userCard.balance + "鍏�") + } + + binding?.cardData?.text = textData.toString() + } + + CardOperationType.CancelCard -> TODO() + CardOperationType.CheckCard -> TODO() + CardOperationType.DeductCard -> TODO() + CardOperationType.Recharge -> TODO() + CardOperationType.ReplaceCard -> TODO() + null -> TODO() } } @@ -64,41 +98,55 @@ override fun onNfcBack(intent: Intent) { val nfcReadHelper = NfcReadHelper.getInstance(intent, this) - val cardNumber = nfcReadHelper.getCardNumberNoClose() + // 浣跨敤姝e父鐨刧etCardNumber()鏂规硶锛屽畠浼氳嚜鍔ㄥ叧闂繛鎺� + val cardNumber = nfcReadHelper.getCardNumber() + if (cardNumber.isNotEmpty() && cardNumber == cardAddr) { val nfcWreatHelper = NfcWreatHelper.getInstance(intent, this) - when (cardType) { - CardCommon.CLEAN_CARD_TYPE -> { + when (operationType) { + CardOperationType.CleanCard -> { var clearCard = ClearCard() nfcWreatHelper.writeData(clearCard.getZeroBytes(), 7, 0) { success, message -> - if (success) { - postCardData(cardType, cardAddr, "") - // 鍐欏崱鎴愬姛鍚庢洿鏂版暟鎹簱涓殑isCardWritten鐘舵�� - updateCardWrittenStatus(cardAddr) - ToastUtil.show("鍐欏崱鎴愬姛!") - // 澶勭悊鍐欏崱鎴愬姛鐨勬儏鍐� - } else { - // 澶勭悊鍐欏崱澶辫触鐨勬儏鍐� - ToastUtil.show(message) + // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢� + runOnUiThread { + if (success) { + postCardData(cardType, cardAddr) + // 鍐欏崱鎴愬姛鍚庢洿鏂版暟鎹簱涓殑isCardWritten鐘舵�� + updateCardWrittenStatus(cardAddr) + ToastUtil.show("鍐欏崱鎴愬姛!") + // 澶勭悊鍐欏崱鎴愬姛鐨勬儏鍐� + } else { + // 澶勭悊鍐欏崱澶辫触鐨勬儏鍐� + ToastUtil.show(message) + } } } } - CardCommon.USER_CARD_TYPE_1 -> { - binding?.cardData?.text = "鍐欑敤鎴峰崱" + CardOperationType.OpenCard -> { nfcWreatHelper.writeUserDataAsync(userCard, object : NFCCallBack { override fun isSusses(flag: Boolean, msg: String?) { - if (flag) { - // 鍐欏崱鎴愬姛鍚庢洿鏂版暟鎹簱涓殑isCardWritten鐘舵�� - updateCardWrittenStatus(cardAddr) - ToastUtil.show("鍐欏崱鎴愬姛!") - } else { - ToastUtil.show("鍐欏崱澶辫触: ${msg ?: "鏈煡閿欒"}") + // 纭繚Toast鍦ㄤ富绾跨▼涓皟鐢� + runOnUiThread { + if (flag) { + // 鍐欏崱鎴愬姛鍚庢洿鏂版暟鎹簱涓殑isCardWritten鐘舵�� + updateCardWrittenStatus(cardAddr) + ToastUtil.show("鍐欏崱鎴愬姛!") + } else { + ToastUtil.show("鍐欏崱澶辫触: ${msg ?: "鏈煡閿欒"}") + } } } }) } + + CardOperationType.CancelCard -> TODO() + CardOperationType.CheckCard -> TODO() + CardOperationType.DeductCard -> TODO() + CardOperationType.Recharge -> TODO() + CardOperationType.ReplaceCard -> TODO() + null -> TODO() } } else { ToastUtil.show("鍗$墖閿欒锛屽綋鍓嶅埛鐨勫崱涓庡垰鍒氱殑鍗′笉涓�鑷�") @@ -113,7 +161,7 @@ try { val cardRegistrationDao = BaseDaoSingleton.getInstance(this@NfcWreatActivity) .cardRegistrationDao() - + // 鏍规嵁鍗″彿鏌ユ壘CardRegistrationBean璁板綍 val cardRegistration = cardRegistrationDao.getByCardNumber(cardNumber) if (cardRegistration != null) { @@ -130,7 +178,7 @@ } } - fun postCardData(cardType: String, cardAddr: String, remark: String) { + fun postCardData(cardType: String, cardAddr: String) { when (cardType) { CardCommon.CHECK_CARD -> { binding?.cardData?.text = "鍐欑敤鎴峰崱" @@ -142,17 +190,14 @@ map["cardAddr"] = cardAddr } - if (cardType.isNotEmpty()) { -// map["cardType"] = cardType - map["operateType"] = "1" - } - if (remark.isNotEmpty()) { - map["remarks"] = remark + map["operateType"] = operationTypeCode + if (orderNumber.isNotEmpty()) { + map["orderNumber"] = orderNumber } // 浣跨敤姝g‘鐨勭被鍨嬪弬鏁� ApiManager.getInstance().requestPostLoading( this, - "/sell/card/call_back", + "terminal/card/termCallBack", String::class.java, map, object : SubscriberListener<BaseResponse<String>>() { -- Gitblit v1.8.0