| | |
| | | import com.doumee.biz.system.SystemDictDataBiz; |
| | | import com.doumee.core.constants.ResponseStatus; |
| | | import com.doumee.core.exception.BusinessException; |
| | | import com.doumee.core.model.LoginUserInfo; |
| | | import com.doumee.core.model.PageData; |
| | | import com.doumee.core.model.PageWrap; |
| | | import com.doumee.core.utils.Constants; |
| | |
| | | import com.doumee.core.utils.Utils; |
| | | import com.doumee.dao.business.*; |
| | | import com.doumee.dao.business.model.*; |
| | | import com.doumee.dao.system.model.SystemUser; |
| | | import com.doumee.dao.web.dto.MultiFileDTO; |
| | | import com.doumee.dao.web.request.DealIntegralRequest; |
| | | import com.doumee.dao.web.request.WithdrawApplyRequest; |
| | |
| | | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.github.yulichang.wrapper.MPJLambdaWrapper; |
| | | import lombok.With; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.apache.shiro.SecurityUtils; |
| | | import org.bouncycastle.cert.dane.DANEEntry; |
| | | import org.checkerframework.checker.units.qual.A; |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.data.redis.core.RedisTemplate; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.util.CollectionUtils; |
| | | |
| | | import java.math.BigDecimal; |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | |
| | | withdrawRecordMapper.deleteBatchIds(ids); |
| | | } |
| | | |
| | | /** |
| | | * 打款审核 |
| | | * @param withdrawRecord 实体对象 |
| | | */ |
| | | @Override |
| | | @Transactional |
| | | public void updateById(WithdrawRecord withdrawRecord) { |
| | | withdrawRecordMapper.updateById(withdrawRecord); |
| | | } |
| | | LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); |
| | | if(!Constants.equalsObject(withdrawRecord.getStatus(),Constants.ONE) |
| | | && !Constants.equalsObject(withdrawRecord.getStatus(),Constants.TWO)){ |
| | | throw new BusinessException(ResponseStatus.BAD_REQUEST); |
| | | } |
| | | WithdrawRecord model = withdrawRecordMapper.selectById(withdrawRecord.getId()); |
| | | if(model == null || Constants.equalsObject(model.getIsdeleted(),Constants.ONE)){ |
| | | throw new BusinessException(ResponseStatus.DATA_EMPTY); |
| | | } |
| | | if(!Constants.equalsObject(model.getStatus(),Constants.ZERO)){ |
| | | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"对不起,该申请已审批,请尝试刷新页面查看"); |
| | | } |
| | | |
| | | Date date = new Date(); |
| | | model.setPayBank(withdrawRecord.getPayBank()); |
| | | model.setEditor(user.getId()); |
| | | model.setEditDate(date); |
| | | model.setAuditRemark(withdrawRecord.getAuditRemark()); |
| | | model.setAuditTime(date); |
| | | model.setAuditUser(user.getId()); |
| | | model.setStatus(withdrawRecord.getStatus()); |
| | | model.setPayBank(withdrawRecord.getPayBank()); |
| | | withdrawRecordMapper.updateById(model); |
| | | dealBatchMultiFiles(model,withdrawRecord.getPayFileList()); |
| | | } |
| | | public void dealBatchMultiFiles(WithdrawRecord model, List<Multifile> fileList ) { |
| | | //清空原有的 |
| | | if(fileList!=null && fileList.size()>0){ |
| | | List<Multifile> multifileList = new ArrayList<>(); |
| | | fileList.stream().forEach(s -> { |
| | | if(StringUtils.isNotBlank(s.getFileurl())){ |
| | | s.setIsdeleted(Constants.ZERO); |
| | | s.setCreator(model.getAuditUser()); |
| | | s.setCreateDate(model.getAuditTime()); |
| | | s.setObjId(model.getId()); |
| | | s.setType(Constants.ZERO); |
| | | s.setObjType(Constants.MultiFile.TRANSFER_FILE.getKey()); |
| | | multifileList.add(s); |
| | | } |
| | | }); |
| | | if(multifileList.size()>0){ |
| | | multifileMapper.insert(multifileList); |
| | | } |
| | | } |
| | | } |
| | | @Override |
| | | public void updateByIdInBatch(List<WithdrawRecord> withdrawRecords) { |
| | | if (CollectionUtils.isEmpty(withdrawRecords)) { |
| | |
| | | |
| | | @Override |
| | | public WithdrawRecord findById(Integer id) { |
| | | WithdrawRecord withdrawRecord = withdrawRecordMapper.selectById(id); |
| | | if (Objects.isNull(withdrawRecord)) { |
| | | MPJLambdaWrapper<WithdrawRecord> queryWrapper = new MPJLambdaWrapper<WithdrawRecord>() |
| | | .selectAll(WithdrawRecord.class) |
| | | .selectAs(SystemUser::getRealname,WithdrawRecord::getAuditUserName) |
| | | .selectAs(Shop::getName,WithdrawRecord::getShopName) |
| | | .selectAs(Shop::getCode,WithdrawRecord::getShopCode) |
| | | .leftJoin(Shop.class,Shop::getId,WithdrawRecord::getMemberId) |
| | | .leftJoin(SystemUser.class,SystemUser::getId,WithdrawRecord::getAuditUser) |
| | | .eq(WithdrawRecord::getId,id) |
| | | .eq(WithdrawRecord::getIsdeleted,Constants.ZERO); |
| | | WithdrawRecord withdrawRecord = withdrawRecordMapper.selectJoinOne(WithdrawRecord.class,queryWrapper); |
| | | if (Objects.isNull(withdrawRecord) ) { |
| | | throw new BusinessException(ResponseStatus.DATA_EMPTY); |
| | | } |
| | | MemberBank memberBank = memberBankMapper.selectById(withdrawRecord.getBankId()); |
| | | if(Objects.nonNull(memberBank)){ |
| | | withdrawRecord.setBankName(memberBank.getBankName()); |
| | | } |
| | | if(!Constants.equalsInteger(withdrawRecord.getStatus(), Constants.ZERO)){ |
| | | String path = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode() + |
| | |
| | | List<Multifile> filelist = multifileMapper.selectList(new QueryWrapper<>(queryfile)); |
| | | if(filelist !=null && filelist.size()>0){ |
| | | for (Multifile multifile:filelist) { |
| | | multifile.setFileFullUrl(path + multifile.getFileurl()); |
| | | if(StringUtils.isNotBlank(multifile.getFileurl())){ |
| | | multifile.setFileFullUrl(path + multifile.getFileurl()); |
| | | } |
| | | } |
| | | withdrawRecord.setPayFileList(filelist); |
| | | } |
| | |
| | | @Override |
| | | public PageData<WithdrawRecord> findPage(PageWrap<WithdrawRecord> pageWrap) { |
| | | IPage<WithdrawRecord> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); |
| | | QueryWrapper<WithdrawRecord> queryWrapper = new QueryWrapper<>(); |
| | | MPJLambdaWrapper<WithdrawRecord> queryWrapper = new MPJLambdaWrapper<WithdrawRecord>() |
| | | .selectAll(WithdrawRecord.class) |
| | | .selectAs(Shop::getName,WithdrawRecord::getShopName) |
| | | .selectAs(Shop::getCode,WithdrawRecord::getShopCode) |
| | | .leftJoin(Shop.class,Shop::getId,WithdrawRecord::getMemberId); |
| | | Utils.MP.blankToNull(pageWrap.getModel()); |
| | | pageWrap.getModel().setIsdeleted(Constants.ZERO); |
| | | if (pageWrap.getModel().getId() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getId, pageWrap.getModel().getId()); |
| | | queryWrapper.eq(WithdrawRecord::getId, pageWrap.getModel().getId()); |
| | | } |
| | | if (pageWrap.getModel().getCreator() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getCreator, pageWrap.getModel().getCreator()); |
| | | queryWrapper.eq(WithdrawRecord::getCreator, pageWrap.getModel().getCreator()); |
| | | } |
| | | if (pageWrap.getModel().getCreateDate() != null) { |
| | | queryWrapper.lambda().ge(WithdrawRecord::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); |
| | | queryWrapper.lambda().le(WithdrawRecord::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); |
| | | queryWrapper.ge(WithdrawRecord::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); |
| | | queryWrapper.le(WithdrawRecord::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); |
| | | } |
| | | if (pageWrap.getModel().getEditor() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getEditor, pageWrap.getModel().getEditor()); |
| | | queryWrapper.eq(WithdrawRecord::getEditor, pageWrap.getModel().getEditor()); |
| | | } |
| | | if (pageWrap.getModel().getEditDate() != null) { |
| | | queryWrapper.lambda().ge(WithdrawRecord::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); |
| | | queryWrapper.lambda().le(WithdrawRecord::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); |
| | | queryWrapper.ge(WithdrawRecord::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); |
| | | queryWrapper.le(WithdrawRecord::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); |
| | | } |
| | | if (pageWrap.getModel().getIsdeleted() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getIsdeleted, pageWrap.getModel().getIsdeleted()); |
| | | queryWrapper.eq(WithdrawRecord::getIsdeleted, pageWrap.getModel().getIsdeleted()); |
| | | } |
| | | if (pageWrap.getModel().getRemark() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getRemark, pageWrap.getModel().getRemark()); |
| | | queryWrapper.eq(WithdrawRecord::getRemark, pageWrap.getModel().getRemark()); |
| | | } |
| | | if (pageWrap.getModel().getMemberId() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getMemberId, pageWrap.getModel().getMemberId()); |
| | | queryWrapper.eq(WithdrawRecord::getMemberId, pageWrap.getModel().getMemberId()); |
| | | } |
| | | if (pageWrap.getModel().getCode() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getCode, pageWrap.getModel().getCode()); |
| | | queryWrapper.eq(WithdrawRecord::getCode, pageWrap.getModel().getCode()); |
| | | } |
| | | if (pageWrap.getModel().getBankId() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getBankId, pageWrap.getModel().getBankId()); |
| | | queryWrapper.eq(WithdrawRecord::getBankId, pageWrap.getModel().getBankId()); |
| | | } |
| | | if (pageWrap.getModel().getStatus() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getStatus, pageWrap.getModel().getStatus()); |
| | | queryWrapper.eq(WithdrawRecord::getStatus, pageWrap.getModel().getStatus()); |
| | | } |
| | | if (pageWrap.getModel().getAuditUser() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getAuditUser, pageWrap.getModel().getAuditUser()); |
| | | queryWrapper.eq(WithdrawRecord::getAuditUser, pageWrap.getModel().getAuditUser()); |
| | | } |
| | | if (pageWrap.getModel().getAuditTime() != null) { |
| | | queryWrapper.lambda().ge(WithdrawRecord::getAuditTime, Utils.Date.getStart(pageWrap.getModel().getAuditTime())); |
| | | queryWrapper.lambda().le(WithdrawRecord::getAuditTime, Utils.Date.getEnd(pageWrap.getModel().getAuditTime())); |
| | | queryWrapper.ge(WithdrawRecord::getAuditTime, Utils.Date.getStart(pageWrap.getModel().getAuditTime())); |
| | | queryWrapper.le(WithdrawRecord::getAuditTime, Utils.Date.getEnd(pageWrap.getModel().getAuditTime())); |
| | | } |
| | | if (pageWrap.getModel().getAuditRemark() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getAuditRemark, pageWrap.getModel().getAuditRemark()); |
| | | queryWrapper.eq(WithdrawRecord::getAuditRemark, pageWrap.getModel().getAuditRemark()); |
| | | } |
| | | if (pageWrap.getModel().getPayBank() != null) { |
| | | queryWrapper.lambda().eq(WithdrawRecord::getPayBank, pageWrap.getModel().getPayBank()); |
| | | queryWrapper.eq(WithdrawRecord::getPayBank, pageWrap.getModel().getPayBank()); |
| | | } |
| | | for(PageWrap.SortData sortData: pageWrap.getSorts()) { |
| | | if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { |
| | | queryWrapper.orderByDesc(sortData.getProperty()); |
| | | } else { |
| | | queryWrapper.orderByAsc(sortData.getProperty()); |
| | | queryWrapper.ge(pageWrap.getModel().getStarttime() != null,WithdrawRecord::getCreateDate, pageWrap.getModel().getStarttime()); |
| | | queryWrapper.le(pageWrap.getModel().getEndtime() != null,WithdrawRecord::getCreateDate, pageWrap.getModel().getEndtime()); |
| | | queryWrapper.like(pageWrap.getModel().getShopName() != null,Shop::getName, pageWrap.getModel().getShopName()); |
| | | queryWrapper.orderByDesc(WithdrawRecord::getCreateDate); |
| | | |
| | | PageData<WithdrawRecord> rr = PageData.from(withdrawRecordMapper.selectJoinPage(page,WithdrawRecord.class, queryWrapper)); |
| | | if(pageWrap.getPage() == 1){ |
| | | //如果查询第一页,做经销商销售信息统计业务查询 |
| | | WithdrawRecord count = withdrawRecordMapper.selectJoinOne(WithdrawRecord.class,new MPJLambdaWrapper<WithdrawRecord>() |
| | | .selectSum(WithdrawRecord::getAmount) |
| | | .leftJoin(Shop.class,Shop::getId,WithdrawRecord::getMemberId) |
| | | .ge(pageWrap.getModel().getStarttime() != null,WithdrawRecord::getCreateDate, pageWrap.getModel().getStarttime()) |
| | | .le(pageWrap.getModel().getEndtime() != null,WithdrawRecord::getCreateDate, pageWrap.getModel().getEndtime()) |
| | | .like(pageWrap.getModel().getShopName() != null,Shop::getName, pageWrap.getModel().getShopName()) |
| | | .eq(WithdrawRecord::getIsdeleted,Constants.ZERO) |
| | | .eq(pageWrap.getModel().getStatus()!=null,WithdrawRecord::getStatus,pageWrap.getModel().getStatus()) |
| | | ); |
| | | if(count == null){ |
| | | count = new WithdrawRecord(); |
| | | } |
| | | count.setAmount(Constants.formatBigdecimal4Float(count.getAmount())); |
| | | rr.setCountData(count); |
| | | } |
| | | return PageData.from(withdrawRecordMapper.selectPage(page, queryWrapper)); |
| | | |
| | | return rr; |
| | | } |
| | | |
| | | |
| | |
| | | throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"商户余额不足"); |
| | | } |
| | | |
| | | MemberBank memberBank = memberBankMapper.selectById(request.getBankId()); |
| | | if(Objects.isNull(memberBank)){ |
| | | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到收款银行信息"); |
| | | } |
| | | WithdrawRecord withdrawRecord = new WithdrawRecord(); |
| | | withdrawRecord.setCreateDate(new Date()); |
| | | withdrawRecord.setIsdeleted(Constants.ZERO); |
| | |
| | | withdrawRecord.setMemberId(request.getMemberId()); |
| | | withdrawRecord.setCode(this.getNextInCode()); |
| | | withdrawRecord.setStatus(Constants.ZERO); |
| | | withdrawRecord.setBankName(memberBank.getBankName()); |
| | | withdrawRecord.setName(memberBank.getName()); |
| | | withdrawRecord.setBankAccount(memberBank.getBankAccount()); |
| | | withdrawRecordMapper.insert(withdrawRecord); |
| | | |
| | | DealIntegralRequest dealIntegralRequest = new DealIntegralRequest(); |