package com.dy.pipIrrSell.activeCard; 
 | 
  
 | 
import com.dy.common.aop.SsoAop; 
 | 
import com.dy.common.webUtil.BaseResponse; 
 | 
import com.dy.common.webUtil.BaseResponseUtils; 
 | 
import com.dy.common.webUtil.QueryResultVo; 
 | 
import com.dy.common.webUtil.ResultCodeMsg; 
 | 
import com.dy.pipIrrGlobal.daoBa.BaSettingsMapper; 
 | 
import com.dy.pipIrrGlobal.pojoSe.SeActiveCard; 
 | 
import com.dy.pipIrrGlobal.pojoSe.SeClientCard; 
 | 
import com.dy.pipIrrGlobal.voSe.VoActiveCard; 
 | 
import com.dy.pipIrrSell.cardOperate.enums.OperateTypeENUM; 
 | 
import com.dy.pipIrrSell.clientCard.CardStateENUM; 
 | 
import com.dy.pipIrrSell.clientCard.ClientCardSv; 
 | 
import com.dy.pipIrrSell.clientCard.LastOperateENUM; 
 | 
import com.dy.pipIrrSell.recharge.DtoRecharge; 
 | 
import com.dy.pipIrrSell.recharge.RechargeCtrl; 
 | 
import com.dy.pipIrrSell.recharge.RechargeSv; 
 | 
import com.dy.pipIrrSell.result.SellResultCode; 
 | 
import io.swagger.v3.oas.annotations.Operation; 
 | 
import io.swagger.v3.oas.annotations.media.Content; 
 | 
import io.swagger.v3.oas.annotations.media.Schema; 
 | 
import io.swagger.v3.oas.annotations.responses.ApiResponse; 
 | 
import io.swagger.v3.oas.annotations.responses.ApiResponses; 
 | 
import io.swagger.v3.oas.annotations.tags.Tag; 
 | 
import jakarta.validation.Valid; 
 | 
import lombok.RequiredArgsConstructor; 
 | 
import lombok.extern.slf4j.Slf4j; 
 | 
import org.springframework.http.MediaType; 
 | 
import org.springframework.transaction.annotation.Transactional; 
 | 
import org.springframework.validation.BindingResult; 
 | 
import org.springframework.web.bind.annotation.*; 
 | 
  
 | 
import java.util.*; 
 | 
  
 | 
/** 
 | 
 * @author ZhuBaoMin 
 | 
 * @date 2023/12/5 20:06 
 | 
 * @LastEditTime 2023/12/5 20:06 
 | 
 * @Description 
 | 
 */ 
 | 
  
 | 
@Slf4j 
 | 
@Tag(name = "开卡管理", description = "开卡操作") 
 | 
@RestController 
 | 
@RequestMapping(path="activecard") 
 | 
@RequiredArgsConstructor 
 | 
public class ActiveCardCtrl { 
 | 
    private final ActiveCardSv activeCardSv; 
 | 
    private final ClientCardSv clientCardSv; 
 | 
    private final RechargeCtrl rechargeCtrl; 
 | 
    private final RechargeSv rechargeSv; 
 | 
    private final BaSettingsMapper baSettingsMapper; 
 | 
  
 | 
  
 | 
    //@Value("${projectCode.ym}") 
 | 
    //private Integer projectCode; 
 | 
  
 | 
    /** 
 | 
     * 获取开卡记录 
 | 
     * @param vo 
 | 
     * @return 
 | 
     */ 
 | 
    @Operation(summary = "获得一页开卡记录", description = "返回一页开卡数据") 
 | 
    @ApiResponses(value = { 
 | 
            @ApiResponse( 
 | 
                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, 
 | 
                    description = "返回一页开卡数据(BaseResponse.content:QueryResultVo[{}])", 
 | 
                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, 
 | 
                            schema = @Schema(implementation = VoActiveCard.class))} 
 | 
            ) 
 | 
    }) 
 | 
    @GetMapping(path = "/getActiveCards") 
 | 
    @SsoAop() 
 | 
    public BaseResponse<QueryResultVo<List<VoActiveCard>>> getActiveCards(QueryVo vo){ 
 | 
        try { 
 | 
            QueryResultVo<List<VoActiveCard>> res = activeCardSv.getActiveCards(vo); 
 | 
            return BaseResponseUtils.buildSuccess(res); 
 | 
        } catch (Exception e) { 
 | 
            log.error("获取开卡记录异常", e); 
 | 
            return BaseResponseUtils.buildException(e.getMessage()) ; 
 | 
        } 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 开卡操作 
 | 
     * @param po 
 | 
     * @param bindingResult 
 | 
     * @return 
 | 
     */ 
 | 
    @Operation(summary = "开卡", description = "新开农户卡") 
 | 
    @ApiResponses(value = { 
 | 
            @ApiResponse( 
 | 
                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, 
 | 
                    description = "操作结果:true:成功,false:失败(BaseResponse.content)", 
 | 
                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, 
 | 
                            schema = @Schema(implementation = Boolean.class))} 
 | 
            ) 
 | 
    }) 
 | 
    @PostMapping(path = "add_active", consumes = MediaType.APPLICATION_JSON_VALUE) 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> add_active(@RequestBody @Valid DtoActiveCard po, BindingResult bindingResult){ 
 | 
        if(bindingResult != null && bindingResult.hasErrors()){ 
 | 
            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); 
 | 
        } 
 | 
  
 | 
        /** 
 | 
         * 获取5级行政区划串areaCode 
 | 
         * provinceId   省级区划代码 
 | 
         * cityId       市级区划代码 
 | 
         * countryId    县级区划代码 
 | 
         * townId       镇级区划代码 
 | 
         * villageId    村级区划代码 
 | 
         */ 
 | 
        //VoAreaCode voAreaCode = activeCardSv.getAreaCodeByNum(po.getClientNum()); 
 | 
        //if(voAreaCode == null) { 
 | 
        //    return BaseResponseUtils.buildFail(SellResultCode.AREA_CODE_MISTAKE.getMessage()); 
 | 
        //} 
 | 
        //String provinceId = voAreaCode.getProvinceId(); 
 | 
        //String cityId = voAreaCode.getCityId(); 
 | 
        //String countryId = voAreaCode.getCountryId(); 
 | 
        //String townId = voAreaCode.getTownId(); 
 | 
        //String villageId = voAreaCode.getVillageId(); 
 | 
        //String areaCode = provinceId + cityId + countryId + townId + villageId; 
 | 
  
 | 
        String areaCode = String.valueOf(activeCardSv.getAreaCodeByNum(po.getClientNum())); 
 | 
  
 | 
        /** 
 | 
         * 根据行政区划串(areaCode)在水卡表中针对水卡编号(cardNum)进行模糊查询 
 | 
         * 如果4位顺序号已经达到最大值,提示用户联系系统管理员 
 | 
         * 如果4位顺序号未达到最大值,则加1 
 | 
         * cardNum为新的卡号 
 | 
         */ 
 | 
        String cardNum = Optional.ofNullable(activeCardSv.getCardNumOfMax(areaCode)).orElse(""); 
 | 
        if(cardNum != null && cardNum.trim().length() > 0) { 
 | 
            Integer number = Integer.parseInt(cardNum.substring(12)); 
 | 
            number = number + 1; 
 | 
            if(number > 9999) { 
 | 
                return BaseResponseUtils.buildFail(SellResultCode.CARD_NUMBER_OVERRUN.getMessage()); 
 | 
            } 
 | 
            cardNum = cardNum.substring(0, 12) + String.format("%04d", number); 
 | 
        } else { 
 | 
            cardNum = areaCode + "0001"; 
 | 
        } 
 | 
  
 | 
  
 | 
        /** 
 | 
         * cardAddr         水卡地址(仅仅写入,无业务) 
 | 
         * clientNum        农户编号 
 | 
         * cardCost         卡片费用 
 | 
         * amount           充值金额 
 | 
         * reissueAmount    补卡金额,补卡时使用 
 | 
         * paymentId        支付方式编号 
 | 
         * remarks          备注 
 | 
         * operator         操作人编号 
 | 
         * activeTime       开卡时间 
 | 
         */ 
 | 
        String cardAddr = po.getCardAddr(); 
 | 
        String clientNum = po.getClientNum(); 
 | 
        //Long clientId = po.getClientId(); 
 | 
  
 | 
        Integer cardCost = po.getCardCost(); 
 | 
        Float amount = po.getAmount(); 
 | 
        Long paymentId = po.getPaymentId(); 
 | 
        String remarks = po.getRemarks(); 
 | 
        Long operator = po.getOperator(); 
 | 
        Date createTime = new Date(); 
 | 
  
 | 
        /** 
 | 
         * 根据农户编号获取农户ID 
 | 
         */ 
 | 
        Long clientId = activeCardSv.getClientIdByNum(clientNum); 
 | 
  
 | 
        /** 
 | 
         * 添加农户卡记录 
 | 
         */ 
 | 
        SeClientCard seClientCard = new SeClientCard(); 
 | 
        seClientCard.setCardaddr(cardAddr); 
 | 
        seClientCard.setCardnum(cardNum); 
 | 
        //seClientCard.setClientnum(clientNum); 
 | 
        seClientCard.setClientid(clientId); 
 | 
        seClientCard.setMoney(0f); 
 | 
        seClientCard.setState(CardStateENUM.NORMAL.getCode()); 
 | 
        seClientCard.setCreatedt(createTime); 
 | 
        seClientCard.setLastoper(LastOperateENUM.ACTIVE.getCode()); 
 | 
  
 | 
        Long cardId = Optional.ofNullable(clientCardSv.add(seClientCard)).orElse(0L) ; 
 | 
        if(cardId == 0) { 
 | 
            return BaseResponseUtils.buildFail(SellResultCode.ACTIVE_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage()); 
 | 
        } 
 | 
  
 | 
        /** 
 | 
         * 添加开卡记录 
 | 
         */ 
 | 
        SeActiveCard activeCard = new SeActiveCard(); 
 | 
        //activeCard.setCardnum(cardNum); 
 | 
        //activeCard.setClientnum(clientNum); 
 | 
  
 | 
        activeCard.setCardid(cardId); 
 | 
        activeCard.setClientid(clientId); 
 | 
        activeCard.setCardcost(cardCost); 
 | 
        activeCard.setPaymentid(paymentId); 
 | 
        activeCard.setOperatetype(OperateTypeENUM.ACTIVE.getCode()); 
 | 
        activeCard.setRemarks(remarks); 
 | 
        activeCard.setOperator(operator); 
 | 
        activeCard.setOperatedt(createTime); 
 | 
        Long rec = Optional.ofNullable(activeCardSv.add(activeCard)).orElse(0L); 
 | 
        if(rec == 0) { 
 | 
            return BaseResponseUtils.buildFail(SellResultCode.ACTIVE_FAIL_WRITE_ACTIVE_CARD_ERROR.getMessage()); 
 | 
        } 
 | 
  
 | 
        /** 
 | 
         * 如果操作人员开卡时输入了充值金额,则开卡后调用充值功能 
 | 
         */ 
 | 
        po.setCardNum(Long.parseLong(cardNum)); 
 | 
        if(amount != null && amount > 0) { 
 | 
            po.setClientId(clientId); 
 | 
            DtoRecharge dtoRecharge = RechargeDtoMapper.INSTANCT.po2vo(po); 
 | 
            dtoRecharge.setMoney(0f); 
 | 
            dtoRecharge.setGift(0f); 
 | 
            dtoRecharge.setPrice(0f); 
 | 
            BaseResponse<Boolean> job = rechargeCtrl.addRecharge(dtoRecharge); 
 | 
            if(!job.getCode().equals("0001")) { 
 | 
                return BaseResponseUtils.buildFail(SellResultCode.ACTIVE_FAIL_RECHARGE_EXCEPTION.getMessage()); 
 | 
            } 
 | 
        } 
 | 
  
 | 
        Map map = new HashMap(); 
 | 
        if(amount != null && amount > 0) { 
 | 
            Long rechargeId = rechargeSv.selectIdByCardId(cardId); 
 | 
            map.put("orderNumber",rechargeId+"");//返回充值ID 
 | 
        }else { 
 | 
            map.put("orderNumber",rec+"");//返回开卡ID 
 | 
        } 
 | 
        String projectNo = baSettingsMapper.getItemValue("projectNo"); 
 | 
        Integer projectNo1 = Integer.valueOf(projectNo); 
 | 
        String projectNo3 = String.format("%02x", projectNo1); 
 | 
        map.put("projectNo", projectNo3); 
 | 
        map.put("cardNum", cardNum); 
 | 
        return BaseResponseUtils.buildSuccess(map) ; 
 | 
    } 
 | 
  
 | 
    @Operation(summary = "补卡", description = "补卡") 
 | 
    @ApiResponses(value = { 
 | 
            @ApiResponse( 
 | 
                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE, 
 | 
                    description = "操作结果:true:成功,false:失败(BaseResponse.content)", 
 | 
                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE, 
 | 
                            schema = @Schema(implementation = Boolean.class))} 
 | 
            ) 
 | 
    }) 
 | 
    @PostMapping(path = "add_reissue", consumes = MediaType.APPLICATION_JSON_VALUE) 
 | 
    @Transactional(rollbackFor = Exception.class) 
 | 
    @SsoAop() 
 | 
    public BaseResponse<Boolean> add_reissue(@RequestBody @Valid DtoActiveCard po, BindingResult bindingResult){ 
 | 
        if(bindingResult != null && bindingResult.hasErrors()){ 
 | 
            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); 
 | 
        } 
 | 
  
 | 
        /** 
 | 
         * cardId           水卡编号(非传入参数,由cardNum反查,更新水卡表用) 
 | 
         * cardNum          水卡编号 
 | 
         //* clientNum        农户编号(非传入参数,由cardNum反查,添加补卡使用) 
 | 
         * clientId         农户ID(非传入参数,由cardNum反查,添加补卡使用) 
 | 
         * cardCost         卡片费用 
 | 
         * reissueAmount    补卡金额,补卡时使用 
 | 
         * paymentId        支付方式编号 
 | 
         * remarks          备注 
 | 
         * operator         操作人编号 
 | 
         * activeTime       补卡时间 
 | 
         */ 
 | 
        Long cardId = 0L; 
 | 
        Long cardNum = po.getCardNum(); 
 | 
        //String clientNum = ""; 
 | 
        Long clientId = 0L; 
 | 
        Integer cardCost = po.getCardCost(); 
 | 
        Float reissueAmount = po.getReissueAmount(); 
 | 
        Long paymentId = po.getPaymentId(); 
 | 
        String remarks = po.getRemarks(); 
 | 
        Long operator = po.getOperator(); 
 | 
        Date replaceTime = new Date(); 
 | 
  
 | 
        /** 
 | 
         * 依据水卡编号获取水卡表主键及农户编号 
 | 
         */ 
 | 
        Map map = Optional.ofNullable(clientCardSv.getCardIdAndClientNum(cardNum)).orElse(new HashMap()); 
 | 
        if(map == null || map.size() <= 0) { 
 | 
            return BaseResponseUtils.buildFail(SellResultCode.CARD_NUMBER_ERROR.getMessage()); 
 | 
        } 
 | 
        cardId = Long.parseLong(map.get("cardId").toString()); 
 | 
        //clientNum = map.get("clientNum").toString(); 
 | 
        clientId = Long.parseLong(map.get("clientId").toString()); 
 | 
  
 | 
        /** 
 | 
         * 修改农户卡信息: 
 | 
         *      补卡时间 
 | 
         *      最后操作类型-2 
 | 
         */ 
 | 
        SeClientCard seClientCard = new SeClientCard(); 
 | 
        seClientCard.setId(cardId); 
 | 
        seClientCard.setReplacedt(replaceTime); 
 | 
        seClientCard.setLastoper(LastOperateENUM.REPLACE.getCode()); 
 | 
        Integer rec_updateClientCard = Optional.ofNullable(clientCardSv.UpdateClientCard(seClientCard)).orElse(0); 
 | 
        if(rec_updateClientCard == 0) { 
 | 
            return BaseResponseUtils.buildFail(SellResultCode.REPLACE_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage()); 
 | 
        } 
 | 
  
 | 
        /** 
 | 
         * 添加补卡记录 
 | 
         */ 
 | 
        SeActiveCard activeCard = new SeActiveCard(); 
 | 
        //activeCard.setCardnum(cardNum); 
 | 
        //activeCard.setClientnum(clientNum); 
 | 
        activeCard.setCardid(cardId); 
 | 
        activeCard.setClientid(clientId); 
 | 
        activeCard.setCardcost(cardCost); 
 | 
        activeCard.setPaymentid(paymentId); 
 | 
        activeCard.setReissueamount(reissueAmount); 
 | 
        activeCard.setOperatetype(OperateTypeENUM.REISSUE.getCode()); 
 | 
        activeCard.setRemarks(remarks); 
 | 
        activeCard.setOperator(operator); 
 | 
        activeCard.setOperatedt(replaceTime); 
 | 
        Long rec = Optional.ofNullable(activeCardSv.add(activeCard)).orElse(0L); 
 | 
        if(rec == 0) { 
 | 
            return BaseResponseUtils.buildFail(SellResultCode.REPLACE_FAIL_WRITE_RECHARGE_ERROR.getMessage()); 
 | 
        } 
 | 
  
 | 
        return BaseResponseUtils.buildSuccess(true) ; 
 | 
    } 
 | 
} 
 |