|  |  |  | 
|---|
|  |  |  | package com.dy.pipIrrSell.cardOperate; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONArray; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.dy.common.webUtil.BaseResponse; | 
|---|
|  |  |  | import com.dy.common.webUtil.BaseResponseUtils; | 
|---|
|  |  |  | import com.dy.common.webUtil.QueryResultVo; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoSe.SeCardOperateMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoSe.SeClientCardMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoSe.SeClientMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoSe.SeCardOperate; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoSe.SeClientCard; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoBa.BaSettingsMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoRm.RmOpenCloseValveHistoryMapper; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.daoSe.*; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoSe.*; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voRm.VoExpend; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.voSe.*; | 
|---|
|  |  |  | import com.dy.pipIrrSell.cardOperate.dto.DtoRecharge; | 
|---|
|  |  |  | import com.dy.pipIrrSell.cardOperate.enums.OperateTypeENUM; | 
|---|
|  |  |  | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.apache.dubbo.common.utils.PojoUtils; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Value; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.text.ParseException; | 
|---|
|  |  |  | import java.text.SimpleDateFormat; | 
|---|
|  |  |  | import java.text.DecimalFormat; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ClientCardSv clientCardSv; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SeGeneralMapper seGeneralMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BaSettingsMapper baSettingsMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SeManagerCardMapper seManagerCardMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SePaymentMethodMapper sePaymentMethodMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SeRechargeHistoryMapper seRechargeHistoryMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private RmOpenCloseValveHistoryMapper rmOpenCloseValveHistoryMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Value("${project.projectNo}") | 
|---|
|  |  |  | private Integer projectNo; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 添加开卡记录 | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param clientNum 农户编号 | 
|---|
|  |  |  | * @return 5级行政区划代码 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Long getAreaCodeByNum(String clientNum) { | 
|---|
|  |  |  | return seClientMapper.getAreaCodeByNum(clientNum); | 
|---|
|  |  |  | public String getAreaCodeByNum(String clientNum) { | 
|---|
|  |  |  | Long areaCode = seClientMapper.getAreaCodeByNum(clientNum); | 
|---|
|  |  |  | if (areaCode == null) { | 
|---|
|  |  |  | return ""; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return String.valueOf(areaCode); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | public Long getAreaCodeById(Long clientId) { | 
|---|
|  |  |  | return seClientMapper.getAreaCodeById(clientId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据行政区划串模块查询水卡编号,开卡使用 | 
|---|
|  |  |  | * @param areaCode | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | String getCardNumOfMax(String areaCode) { | 
|---|
|  |  |  | public String getCardNumOfMax(String areaCode) { | 
|---|
|  |  |  | return seClientCardMapper.getCardNumOfMax(areaCode); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据行政区划串模糊查询管理卡编号,创建管理卡使用 | 
|---|
|  |  |  | * @param areaCode | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public String getManagerCardNumOfMax(String areaCode) { | 
|---|
|  |  |  | return seManagerCardMapper.getManagerCardNumOfMax(areaCode); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 创建管理卡 | 
|---|
|  |  |  | * @param po | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Long addManagerCard(SeManagerCard po) { | 
|---|
|  |  |  | seManagerCardMapper.insert(po); | 
|---|
|  |  |  | return po.getId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 添加充值记录 | 
|---|
|  |  |  | * 修改农户信息、添加充值记录 | 
|---|
|  |  |  | * 修改农户信息、添加水卡操作记录、添加充值记录 | 
|---|
|  |  |  | * @param po | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Long cardId = 0L; | 
|---|
|  |  |  | Long clientId = 0L; | 
|---|
|  |  |  | String cardNum = po.getCardNum(); | 
|---|
|  |  |  | Long cardNum = po.getCardNum(); | 
|---|
|  |  |  | Float money = po.getMoney(); | 
|---|
|  |  |  | Float amount = po.getAmount(); | 
|---|
|  |  |  | Float gift = po.getGift(); | 
|---|
|  |  |  | 
|---|
|  |  |  | Long operator = po.getOperator(); | 
|---|
|  |  |  | Date rechargeTime = new Date(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 验证水卡状态是否支持当前操作 | 
|---|
|  |  |  | String stateName = Optional.ofNullable(clientCardSv.getCardStateByCardNum(cardNum)).orElse(""); | 
|---|
|  |  |  | if(stateName.length() == 0 || !stateName.equals("正常")) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(stateName + ", " + SellResultCode.THE_CARD_NOT_SUPPORT_THIS_OPERATION.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 依据水卡编号获取水卡表主键及农户编号 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | Map map = Optional.ofNullable(clientCardSv.getCardIdAndClientNum(cardNum)).orElse(new HashMap()); | 
|---|
|  |  |  | if(map == null || map.size() <= 0) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(SellResultCode.CARD_NUMBER_MISTAKE.getMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(SellResultCode.CARD_NUMBER_MISTAKE.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | cardId = Long.parseLong(map.get("cardId").toString()); | 
|---|
|  |  |  | clientId = Long.parseLong(map.get("clientId").toString()); | 
|---|
|  |  |  | 
|---|
|  |  |  | *      补卡时间 | 
|---|
|  |  |  | *      最后操作类型-2 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 根据支付方式ID获取支付方式名称 | 
|---|
|  |  |  | SePaymentMethod sePaymentMethod = sePaymentMethodMapper.selectByPrimaryKey(paymentId); | 
|---|
|  |  |  | String paymentName = sePaymentMethod.getName(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | SeClientCard seClientCard = new SeClientCard(); | 
|---|
|  |  |  | seClientCard.setId(cardId); | 
|---|
|  |  |  | seClientCard.setMoney(afterRecharge); | 
|---|
|  |  |  | seClientCard.setRechargedt(rechargeTime); | 
|---|
|  |  |  | //if(paymentName != null && paymentName.equals("换卡")) { | 
|---|
|  |  |  | //    seClientCard.setLastoper(LastOperateENUM.CHANGE_RECHARGE.getCode ()); | 
|---|
|  |  |  | //}else { | 
|---|
|  |  |  | //    seClientCard.setLastoper(LastOperateENUM.RECHARGE.getCode ()); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | seClientCard.setLastoper(LastOperateENUM.RECHARGE.getCode ()); | 
|---|
|  |  |  | Integer rec_updateClientCard = Optional.ofNullable(clientCardSv.UpdateClientCard(seClientCard)).orElse(0); | 
|---|
|  |  |  | if(rec_updateClientCard == 0) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(SellResultCode.RECHARGE_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(SellResultCode.RECHARGE_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 添加充值记录 | 
|---|
|  |  |  | * 添加水卡充值操作记录 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | SeCardOperate seCardOperate = new SeCardOperate(); | 
|---|
|  |  |  | seCardOperate.setCardId(cardId); | 
|---|
|  |  |  | 
|---|
|  |  |  | seCardOperate.setMoney(money); | 
|---|
|  |  |  | seCardOperate.setTradeAmount(amount); | 
|---|
|  |  |  | seCardOperate.setGift(gift); | 
|---|
|  |  |  | //if(paymentName != null && paymentName.equals("换卡")) { | 
|---|
|  |  |  | //    seCardOperate.setOperateType(OperateTypeENUM.CHANGE_RECHARGE.getCode()); | 
|---|
|  |  |  | //}else { | 
|---|
|  |  |  | //    seCardOperate.setOperateType(OperateTypeENUM.RECHARGE.getCode()); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | seCardOperate.setOperateType(OperateTypeENUM.RECHARGE.getCode()); | 
|---|
|  |  |  | seCardOperate.setPaymentId(paymentId); | 
|---|
|  |  |  | seCardOperate.setPrice(price); | 
|---|
|  |  |  | 
|---|
|  |  |  | seCardOperateMapper.insert(seCardOperate); | 
|---|
|  |  |  | Long rec = Optional.ofNullable(seCardOperate.getId()).orElse(0L); | 
|---|
|  |  |  | if(rec == 0) { | 
|---|
|  |  |  | return BaseResponseUtils.buildFail(SellResultCode.REPLACE_FAIL_WRITE_RECHARGE_ERROR.getMessage()); | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(SellResultCode.RECHARGE_FAIL_WRITE_RECHARGE_ERROR.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(true) ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 添加充值历史记录 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | SeRechargeHistory seRechargeHistory = new SeRechargeHistory(); | 
|---|
|  |  |  | seRechargeHistory.setCardid(cardId); | 
|---|
|  |  |  | seRechargeHistory.setClientid(clientId); | 
|---|
|  |  |  | seRechargeHistory.setMoney(money); | 
|---|
|  |  |  | seRechargeHistory.setAmount(amount); | 
|---|
|  |  |  | seRechargeHistory.setGift(gift); | 
|---|
|  |  |  | seRechargeHistory.setAfterrecharge(afterRecharge); | 
|---|
|  |  |  | seRechargeHistory.setPaymentid(paymentId); | 
|---|
|  |  |  | seRechargeHistory.setPrice(price); | 
|---|
|  |  |  | seRechargeHistory.setRemarks(remarks); | 
|---|
|  |  |  | seRechargeHistory.setOperator(operator); | 
|---|
|  |  |  | seRechargeHistory.setOperatedt(rechargeTime); | 
|---|
|  |  |  | seRechargeHistoryMapper.insert(seRechargeHistory); | 
|---|
|  |  |  | Long rec_seRechargeHistory = Optional.ofNullable(seRechargeHistory.getId()).orElse(0L); | 
|---|
|  |  |  | if(rec_seRechargeHistory == 0) { | 
|---|
|  |  |  | return BaseResponseUtils.buildErrorMsg(SellResultCode.RECHARGE_FAIL_WRITE_RECHARGE_HISTORY_ERROR.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map map_response = new HashMap(); | 
|---|
|  |  |  | map_response.put("projectNo", String.format("%02x", projectNo)); | 
|---|
|  |  |  | map_response.put("orderNumber", rec); | 
|---|
|  |  |  | map_response.put("cardNum", cardNum); | 
|---|
|  |  |  | return BaseResponseUtils.buildSuccess(map_response) ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据指定条件获取充值记录 | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoRecharge>> getRecharges(QoRecharge queryVo) { | 
|---|
|  |  |  | //完善查询充值记录的起止时间 | 
|---|
|  |  |  | String rechargeTimeStart = queryVo.rechargeTimeStart; | 
|---|
|  |  |  | String rechargeTimeStop = queryVo.rechargeTimeStop; | 
|---|
|  |  |  | if(rechargeTimeStart != null) { | 
|---|
|  |  |  | rechargeTimeStart = rechargeTimeStart + " 00:00:00"; | 
|---|
|  |  |  | queryVo.setRechargeTimeStart(rechargeTimeStart); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(rechargeTimeStop != null) { | 
|---|
|  |  |  | rechargeTimeStop = rechargeTimeStop + " 23:59:59"; | 
|---|
|  |  |  | queryVo.setRechargeTimeStop(rechargeTimeStop); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //String rechargeTimeStart = queryVo.rechargeTimeStart; | 
|---|
|  |  |  | //String rechargeTimeStop = queryVo.rechargeTimeStop; | 
|---|
|  |  |  | //if(rechargeTimeStart != null) { | 
|---|
|  |  |  | //    rechargeTimeStart = rechargeTimeStart + " 00:00:00"; | 
|---|
|  |  |  | //    queryVo.setRechargeTimeStart(rechargeTimeStart); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | //if(rechargeTimeStop != null) { | 
|---|
|  |  |  | //    rechargeTimeStop = rechargeTimeStop + " 23:59:59"; | 
|---|
|  |  |  | //    queryVo.setRechargeTimeStop(rechargeTimeStop); | 
|---|
|  |  |  | //} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getRecordCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoRecharge>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | Integer pageCurr = 0; | 
|---|
|  |  |  | Integer pageSize = 10000; | 
|---|
|  |  |  | rsVo.pageCurr = 1; | 
|---|
|  |  |  | rsVo.pageSize = 10000; | 
|---|
|  |  |  | if(queryVo.pageSize != null && queryVo.pageCurr != null) { | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr; | 
|---|
|  |  |  | pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | pageCurr = (Integer.parseInt(params.get("pageCurr").toString()) - 1) * Integer.parseInt(params.get("pageSize").toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | params.put("pageCurr", pageCurr); | 
|---|
|  |  |  | params.put("pageSize", pageSize); | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getRecharges(params); | 
|---|
|  |  |  | return rsVo ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取充值记录,管理平台充值列表使用,APP未使用 | 
|---|
|  |  |  | * @param queryVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoRechargeNew>> getRechargesNew(QoRecharge queryVo) { | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getRechargesCountNew(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoRechargeNew>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getRechargesNew(params); | 
|---|
|  |  |  | return rsVo ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取返还记录,管理平台充值列表使用 | 
|---|
|  |  |  | * @param queryVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoRefund>> getRefunds(QoRecharge queryVo) { | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getRefundsCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoRefund>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getRefunds(params); | 
|---|
|  |  |  | return rsVo ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取水卡消费记录,管理平台使用 | 
|---|
|  |  |  | * @param queryVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoExpend>> getExpends(QoRecharge queryVo) { | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = rmOpenCloseValveHistoryMapper.getExpendsCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoExpend>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = rmOpenCloseValveHistoryMapper.getExpends(params); | 
|---|
|  |  |  | return rsVo ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据指定条件获取交易记录 | 
|---|
|  |  |  | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Map getTransactions(QoTransaction vo){ | 
|---|
|  |  |  | DecimalFormat df = new DecimalFormat("0.00"); | 
|---|
|  |  |  | // 补齐查询时间 | 
|---|
|  |  |  | String operateTimeStart = vo.operateTimeStart; | 
|---|
|  |  |  | String operateTimeStop = vo.operateTimeStop; | 
|---|
|  |  |  | 
|---|
|  |  |  | // 生成查询参数 | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(vo) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取汇总的购水金额、购卡金额 | 
|---|
|  |  |  | Float waterCost = 0f; | 
|---|
|  |  |  | Float cardCost = 0f; | 
|---|
|  |  |  | Map map_sum = Optional.ofNullable(seCardOperateMapper.getTransactionSums(params)).orElse(new HashMap()); | 
|---|
|  |  |  | if(map_sum.size() > 0) { | 
|---|
|  |  |  | waterCost = Float.parseFloat(map_sum.get("waterCost").toString()); | 
|---|
|  |  |  | cardCost = Float.parseFloat(map_sum.get("cardCost").toString()); | 
|---|
|  |  |  | // 获取符合条件的记录数 | 
|---|
|  |  |  | Long itemTotal = Optional.ofNullable(seCardOperateMapper.getTransactionRecordCount(params)).orElse(0L); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoTradeDetails>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = vo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = vo.pageCurr ; | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getTransactions(params); | 
|---|
|  |  |  | List<VoTradeDetails> list = rsVo.obj; | 
|---|
|  |  |  | if(list.size() == 0) { | 
|---|
|  |  |  | return new HashMap(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取符合条件的记录数 | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getTransactionRecordCount(params); | 
|---|
|  |  |  | // 遍历交易明细记录,汇总购水金额、购卡金额 | 
|---|
|  |  |  | Double totalWaterCost = 0.0; | 
|---|
|  |  |  | Double totalCardCost = 0.0; | 
|---|
|  |  |  | Double totalGift = 0.0; | 
|---|
|  |  |  | Double totalRefund = 0.0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer pageSize = vo.getPageSize(); | 
|---|
|  |  |  | // 计算总页数 | 
|---|
|  |  |  | Integer pageTotal ; | 
|---|
|  |  |  | pageTotal = (int)Math.ceil((itemTotal==null?0.0D:itemTotal.doubleValue())/pageSize); | 
|---|
|  |  |  | JSONArray array= JSONArray.parseArray(JSON.toJSONString(list)); | 
|---|
|  |  |  | for(int i = 0; i < array.size(); i++) { | 
|---|
|  |  |  | JSONObject job = array.getJSONObject(i); | 
|---|
|  |  |  | Double waterCost = Optional.ofNullable(job.getDouble("waterCost")).orElse(0.0); | 
|---|
|  |  |  | Double cardCost = Optional.ofNullable(job.getDouble("cardCost")).orElse(0.0); | 
|---|
|  |  |  | Double gift = Optional.ofNullable(job.getDouble("gift")).orElse(0.0); | 
|---|
|  |  |  | Double refundAmount = Optional.ofNullable(job.getDouble("refundAmount")).orElse(0.0); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 根据当前页码及每页数量计算偏移量 | 
|---|
|  |  |  | Integer pageCurr = (Integer.parseInt(params.get("pageCurr").toString()) - 1) * Integer.parseInt(params.get("pageSize").toString()); | 
|---|
|  |  |  | params.put("pageCurr", pageCurr); | 
|---|
|  |  |  | totalWaterCost = totalWaterCost + waterCost; | 
|---|
|  |  |  | totalCardCost = totalCardCost + cardCost; | 
|---|
|  |  |  | totalGift = totalGift + gift; | 
|---|
|  |  |  | totalRefund = totalRefund + refundAmount; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<VoTransaction> lit = seCardOperateMapper.getTransactions(params); | 
|---|
|  |  |  | Map map_record = new HashMap(); | 
|---|
|  |  |  | map_record.put("itemTotal", itemTotal); | 
|---|
|  |  |  | map_record.put("pageCurr", vo.pageCurr); | 
|---|
|  |  |  | map_record.put("pageSize", pageSize); | 
|---|
|  |  |  | map_record.put("pageTotal", pageTotal); | 
|---|
|  |  |  | map_record.put("list", lit); | 
|---|
|  |  |  | map_record.put("list", rsVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map map_result = new HashMap(); | 
|---|
|  |  |  | map_result.put("waterCost", waterCost); | 
|---|
|  |  |  | map_result.put("cardCost", cardCost); | 
|---|
|  |  |  | map_result.put("waterCost", df.format(totalWaterCost)); | 
|---|
|  |  |  | map_result.put("cardCost", df.format(totalCardCost)); | 
|---|
|  |  |  | map_result.put("gift", df.format(totalGift)); | 
|---|
|  |  |  | map_result.put("refund", df.format(totalRefund)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | map_result.put("records", map_record); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return map_result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取交易统计记录 | 
|---|
|  |  |  | * 1.交易统计记录 | 
|---|
|  |  |  | * 2.笔数合计、实收金额合计、赠送金额合计 | 
|---|
|  |  |  | * 3.每一天、各种支付方式实收金额合计 | 
|---|
|  |  |  | * @param vo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Map getTransactionStatistics(QoTransactionStatistics vo) throws ParseException { | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 遍历查询日期,取出每天三种支付方式(现金、扫码、转账)实收金额 | 
|---|
|  |  |  | * 每天一个对象 | 
|---|
|  |  |  | * 对象组成JSONArray添加到返回对象中 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); | 
|---|
|  |  |  | Date startDate = dateFormat.parse(vo.getOperateTimeStart()); | 
|---|
|  |  |  | Date stopDate = dateFormat.parse(vo.getOperateTimeStop()); | 
|---|
|  |  |  | Calendar calendar = Calendar.getInstance(); | 
|---|
|  |  |  | calendar.setTime(startDate); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONArray array_paymentSums = new JSONArray(); | 
|---|
|  |  |  | while (calendar.getTime().before(stopDate) || calendar.getTime().equals(stopDate)) { | 
|---|
|  |  |  | String tradeDate = dateFormat.format(calendar.getTime()) ; | 
|---|
|  |  |  | Float receivedCash = Optional.ofNullable(seCardOperateMapper.getPaymentSums(tradeDate ,1L)).orElse(0f); | 
|---|
|  |  |  | Float receivedQRCode = Optional.ofNullable(seCardOperateMapper.getPaymentSums(tradeDate,2L)).orElse(0f); | 
|---|
|  |  |  | Float receivedTransfer = Optional.ofNullable(seCardOperateMapper.getPaymentSums(tradeDate, 3L)).orElse(0f); | 
|---|
|  |  |  | JSONObject job = new JSONObject(); | 
|---|
|  |  |  | job.put("tradeDate", tradeDate); | 
|---|
|  |  |  | job.put("receivedCash", receivedCash); | 
|---|
|  |  |  | job.put("receivedQRCode", receivedQRCode); | 
|---|
|  |  |  | job.put("receivedTransfer", receivedTransfer); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | array_paymentSums.add(job); | 
|---|
|  |  |  | calendar.add(Calendar.DAY_OF_MONTH, 1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 补齐查询时间 | 
|---|
|  |  |  | String operateTimeStart = vo.operateTimeStart; | 
|---|
|  |  |  | String operateTimeStop = vo.operateTimeStop; | 
|---|
|  |  |  | if(operateTimeStart != null) { | 
|---|
|  |  |  | operateTimeStart = operateTimeStart + " 00:00:00"; | 
|---|
|  |  |  | vo.setOperateTimeStart(operateTimeStart); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(operateTimeStop != null) { | 
|---|
|  |  |  | operateTimeStop = operateTimeStop + " 23:59:59"; | 
|---|
|  |  |  | vo.setOperateTimeStop(operateTimeStop); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 生成查询参数 | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(vo) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //获取笔数合计、实收金额合计、赠送金额合计 | 
|---|
|  |  |  | Integer totalCount = 0; | 
|---|
|  |  |  | Float totalReceived = 0f; | 
|---|
|  |  |  | Float totalGift = 0f; | 
|---|
|  |  |  | Map map_sum = Optional.ofNullable(seCardOperateMapper.getTransactionStatisticsSums(params)).orElse(new HashMap()); | 
|---|
|  |  |  | if(map_sum.size() > 0) { | 
|---|
|  |  |  | totalCount = Integer.parseInt(map_sum.get("totalCount").toString()); | 
|---|
|  |  |  | totalReceived = Float.parseFloat(map_sum.get("totalReceived").toString()); | 
|---|
|  |  |  | totalGift = Float.parseFloat(map_sum.get("totalGift").toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取符合条件的记录数 | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getTransactionStatisticsRecordCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer pageSize = vo.getPageSize(); | 
|---|
|  |  |  | // 计算总页数 | 
|---|
|  |  |  | Integer pageTotal ; | 
|---|
|  |  |  | pageTotal = (int)Math.ceil((itemTotal==null?0.0D:itemTotal.doubleValue())/pageSize); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 根据当前页码及每页数量计算偏移量 | 
|---|
|  |  |  | Integer pageCurr = (Integer.parseInt(params.get("pageCurr").toString()) - 1) * Integer.parseInt(params.get("pageSize").toString()); | 
|---|
|  |  |  | params.put("pageCurr", pageCurr); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<VoTransactionStatistics> list = seCardOperateMapper.getTransactionStatistics(params); | 
|---|
|  |  |  | Map map_record = new HashMap(); | 
|---|
|  |  |  | map_record.put("itemTotal", itemTotal); | 
|---|
|  |  |  | map_record.put("pageCurr", vo.pageCurr); | 
|---|
|  |  |  | map_record.put("pageSize", pageSize); | 
|---|
|  |  |  | map_record.put("pageTotal", pageTotal); | 
|---|
|  |  |  | map_record.put("list", list); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map map_result = new HashMap(); | 
|---|
|  |  |  | map_result.put("totalCount", totalCount); | 
|---|
|  |  |  | map_result.put("totalReceived", totalReceived); | 
|---|
|  |  |  | map_result.put("totalGift", totalGift); | 
|---|
|  |  |  | map_result.put("records", map_record); | 
|---|
|  |  |  | map_result.put("paymentSums", array_paymentSums); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return map_result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param queryVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoActiveCardNew>> getActiveCards(QoActiveCard queryVo) { | 
|---|
|  |  |  | public QueryResultVo<List<VoActiveCard>> getActiveCards(QoActiveCard queryVo) { | 
|---|
|  |  |  | //完善查询充值记录的起止时间 | 
|---|
|  |  |  | String activeTimeStart = queryVo.activeTimeStart; | 
|---|
|  |  |  | String activeTimeStop = queryVo.activeTimeStop; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getActiveCardRecordCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoActiveCardNew>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | Integer pageCurr = 0; | 
|---|
|  |  |  | Integer pageSize = 10000; | 
|---|
|  |  |  | rsVo.pageCurr = 1; | 
|---|
|  |  |  | rsVo.pageSize = 10000; | 
|---|
|  |  |  | if(queryVo.pageSize != null && queryVo.pageCurr != null) { | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr; | 
|---|
|  |  |  | pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | pageCurr = (Integer.parseInt(params.get("pageCurr").toString()) - 1) * Integer.parseInt(params.get("pageSize").toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | params.put("pageCurr", pageCurr); | 
|---|
|  |  |  | params.put("pageSize", pageSize); | 
|---|
|  |  |  | QueryResultVo<List<VoActiveCard>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getActiveCards(params); | 
|---|
|  |  |  | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getReissueCardRecordCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoReissueCard>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | Integer pageCurr = 0; | 
|---|
|  |  |  | Integer pageSize = 10000; | 
|---|
|  |  |  | rsVo.pageCurr = 1; | 
|---|
|  |  |  | rsVo.pageSize = 10000; | 
|---|
|  |  |  | if(queryVo.pageSize != null && queryVo.pageCurr != null) { | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr; | 
|---|
|  |  |  | pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | pageCurr = (Integer.parseInt(params.get("pageCurr").toString()) - 1) * Integer.parseInt(params.get("pageSize").toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | params.put("pageCurr", pageCurr); | 
|---|
|  |  |  | params.put("pageSize", pageSize); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getReissueCards(params); | 
|---|
|  |  |  | return rsVo ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据指定条件获取通用操作记录 | 
|---|
|  |  |  | * @param queryVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public QueryResultVo<List<VoOperate>> getCommonOperations(QoCommonOperate queryVo) { | 
|---|
|  |  |  | //完善查询充值记录的起止时间 | 
|---|
|  |  |  | String timeStart = queryVo.getTimeStart(); | 
|---|
|  |  |  | String timeStop = queryVo.getTimeStop(); | 
|---|
|  |  |  | if(timeStart != null) { | 
|---|
|  |  |  | timeStart = timeStart + " 00:00:00"; | 
|---|
|  |  |  | queryVo.setTimeStart(timeStart); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(timeStop != null) { | 
|---|
|  |  |  | timeStop = timeStop + " 23:59:59"; | 
|---|
|  |  |  | queryVo.setTimeStop(timeStop); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = Optional.ofNullable(seCardOperateMapper.getCommonOperationRecordCount(params)).orElse(0L); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoOperate>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | rsVo.obj = seCardOperateMapper.getCommonOperations(params); | 
|---|
|  |  |  | return rsVo ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据指定条件获取收据列表 | 
|---|
|  |  |  | * @param queryVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Map getReceipts(QoReceipt queryVo) { | 
|---|
|  |  |  | if (queryVo.getTimeStart() != null && queryVo.getTimeStart() != ""){ | 
|---|
|  |  |  | queryVo.setTimeStart(queryVo.getTimeStart() + " 00:00:00"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (queryVo.getTimeStop() != null && queryVo.getTimeStop() != ""){ | 
|---|
|  |  |  | queryVo.setTimeStop(queryVo.getTimeStop() + " 23:59:59"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DecimalFormat df = new DecimalFormat("#.00"); | 
|---|
|  |  |  | Double totalAmount = Optional.ofNullable(seCardOperateMapper.getTotalAmount(params)).orElse(0.0); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Long itemTotal = seCardOperateMapper.getReceiptsRecordCount(params); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | QueryResultVo<List<VoReceipt>> rsVo = new QueryResultVo<>() ; | 
|---|
|  |  |  | rsVo.pageSize = queryVo.pageSize ; | 
|---|
|  |  |  | rsVo.pageCurr = queryVo.pageCurr ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | rsVo.calculateAndSet(itemTotal, params); | 
|---|
|  |  |  | //rsVo.obj = seCardOperateMapper.getReceipts(params); | 
|---|
|  |  |  | //return rsVo ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<VoReceipt> list = seCardOperateMapper.getReceipts(params); | 
|---|
|  |  |  | Map map_record = new HashMap(); | 
|---|
|  |  |  | map_record.put("itemTotal", rsVo.itemTotal); | 
|---|
|  |  |  | map_record.put("pageCurr", rsVo.pageCurr); | 
|---|
|  |  |  | map_record.put("pageSize", rsVo.pageSize); | 
|---|
|  |  |  | map_record.put("pageTotal", rsVo.pageTotal); | 
|---|
|  |  |  | map_record.put("list", list); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map map_result = new HashMap(); | 
|---|
|  |  |  | map_result.put("totalAmount", df.format(totalAmount)); | 
|---|
|  |  |  | map_result.put("records", map_record); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return map_result; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 判断指定水卡是否为挂失状态且无补卡记录 | 
|---|
|  |  |  | * @param cardNum 水卡编号 | 
|---|
|  |  |  | * @return 是否已挂失未补卡 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Boolean isLostAndUnreplaced(Long cardNum) { | 
|---|
|  |  |  | Integer lostCount = seClientCardMapper.getLostCount(cardNum); | 
|---|
|  |  |  | Integer replacedCount = seClientCardMapper.getReplacedCount(cardNum); | 
|---|
|  |  |  | if(lostCount > 0 && replacedCount == 0) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 修改农户水卡 | 
|---|
|  |  |  | * @param po | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Integer updateClientCard(SeClientCard po) { | 
|---|
|  |  |  | return seClientCardMapper.updateByPrimaryKeySelective(po); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取项目编号 | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public String getProjectNo() { | 
|---|
|  |  |  | return baSettingsMapper.getItemValue("projectNo"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据水卡编号获取其挂失时退款金额(补卡时判断使用) | 
|---|
|  |  |  | * @param cardNum | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Double getTradeAmountByCardNo(Long cardNum) { | 
|---|
|  |  |  | return seCardOperateMapper.getTradeAmountByCardNo(cardNum); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据水卡地址判断该卡是否可以开卡 | 
|---|
|  |  |  | * @param cardAddr | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public Boolean canActiveCard(String cardAddr) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 指定水卡地址的水卡数量 | 
|---|
|  |  |  | Long cardCount = Optional.ofNullable(seClientCardMapper.getCountByCardAddr(cardAddr)).orElse(0L); | 
|---|
|  |  |  | if(cardCount == 0) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 指定水卡地址且正常状态或挂失状态的水卡数量 | 
|---|
|  |  |  | cardCount = Optional.ofNullable(seClientCardMapper.getCountByCardAddrAndState(cardAddr)).orElse(0L); | 
|---|
|  |  |  | if(cardCount == 0) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|