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.pojoSe.SeActiveCard; import com.dy.pipIrrGlobal.pojoSe.SeClientCard; import com.dy.pipIrrGlobal.voBa.VoAreaCode; import com.dy.pipIrrGlobal.voSe.VoActiveCard; 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 io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Parameter; 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; @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", consumes = MediaType.APPLICATION_JSON_VALUE) @SsoAop() public BaseResponse>> getActiveCards(@RequestBody @Parameter(description = "查询form表单json数据", required = true) QueryVo vo){ try { QueryResultVo> res = activeCardSv.getActiveCards(vo); return BaseResponseUtils.buildSuccess(res); } catch (Exception e) { log.error("获取开卡记录异常", e); return BaseResponseUtils.buildException(e.getMessage()) ; } } @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 add_active(@RequestBody @Parameter(description = "form表单json数据", required = true) @Valid DtoActiveCard po, @Parameter(hidden = true) 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("该农户行政区划异常,请联系系统管理员"); } 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; /** * 根据行政区划串(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("水卡编号已满,请联系系统管理员"); } cardNum = cardNum.substring(0, 12) + String.format("%04d", number); } else { cardNum = areaCode + "0001"; } /** * cardId 水卡编号(插入记录后生成) * cardAddr 水卡地址(仅仅写入,无业务) * clientNum 农户编号 * cardCost 卡片费用 * amount 充值金额 * reissueAmount 补卡金额,补卡时使用 * paymentId 支付方式编号 * remarks 备注 * operator 操作人编号 * activeTime 开卡时间 */ //Long cardId = 0L; String cardAddr = po.getCardAddr(); //Long clientId = po.getClientId(); String clientNum = po.getClientNum(); Integer cardCost = po.getCardCost(); Float amount = po.getAmount(); Long paymentId = po.getPaymentId(); String remarks = po.getRemarks(); Long operator = po.getOperator(); Date createTime = new Date(); /** * 添加农户卡记录 */ SeClientCard seClientCard = new SeClientCard(); seClientCard.setCardaddr(cardAddr); //seClientCard.setClientid(clientId); seClientCard.setCardnum(cardNum); seClientCard.setClientnum(clientNum); seClientCard.setMoney(0.0); 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("开卡失败-农户卡写入异常"); } /** * 添加开卡记录 */ 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("开卡失败-开卡记录写入异常"); } /** * 如果操作人员开卡时输入了充值金额,则开卡后调用充值功能 */ po.setCardNum(cardNum); if(amount != null && amount > 0) { DtoRecharge dtoRecharge = RechargeDtoMapper.INSTANCT.po2vo(po); dtoRecharge.setMoney(0f); dtoRecharge.setGift(0f); dtoRecharge.setPrice(0f); BaseResponse job = rechargeCtrl.addRecharge(dtoRecharge); if(!job.getCode().equals("0001")) { return BaseResponseUtils.buildFail("开卡成功,但充值失败"); } } return BaseResponseUtils.buildSuccess(cardNum) ; } @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 add_reissue(@RequestBody @Parameter(description = "form表单json数据", required = true) @Valid DtoActiveCard po, @Parameter(hidden = true) BindingResult bindingResult){ if(bindingResult != null && bindingResult.hasErrors()){ return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); } /** * cardId 水卡编号(非传入参数,由cardNum反查,更新水卡表用) * cardNum 水卡编号 * clientNum 农户编号(非传入参数,由cardNum反查,添加补卡使用) * cardCost 卡片费用 * reissueAmount 补卡金额,补卡时使用 * paymentId 支付方式编号 * remarks 备注 * operator 操作人编号 * activeTime 补卡时间 */ Long cardId = 0L; String cardNum = po.getCardNum(); //String clientNum = po.getClientNum(); String clientNum = ""; Integer cardCost = po.getCardCost(); Double 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("卡号错误,该卡不存在"); } cardId = Long.parseLong(map.get("cardId").toString()); clientNum = map.get("clientNum").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("补卡失败-农户卡修改异常"); } /** * 添加补卡记录 */ 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.REPLACE.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("补卡失败-补卡记录写入异常"); } return BaseResponseUtils.buildSuccess(true) ; } }