123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250 |
- package com.fuint.common.service.impl;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.toolkit.Wrappers;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.fuint.common.dto.AccountInfo;
- import com.fuint.common.dto.BalanceDto;
- import com.fuint.common.enums.StatusEnum;
- import com.fuint.common.enums.WxMessageEnum;
- import com.fuint.common.service.BalanceService;
- import com.fuint.common.service.MemberService;
- import com.fuint.common.service.WeixinService;
- import com.fuint.common.util.CommonUtil;
- import com.fuint.common.util.DateUtil;
- import com.fuint.common.util.PhoneFormatCheckUtils;
- import com.fuint.framework.annoation.OperationServiceLog;
- import com.fuint.framework.exception.BusinessCheckException;
- import com.fuint.framework.pagination.PaginationRequest;
- import com.fuint.framework.pagination.PaginationResponse;
- import com.fuint.repository.mapper.MtBalanceMapper;
- import com.fuint.repository.mapper.MtUserMapper;
- import com.fuint.repository.model.MtBalance;
- import com.fuint.repository.model.MtBanner;
- import com.fuint.repository.model.MtUser;
- import com.fuint.utils.StringUtil;
- import com.github.pagehelper.Page;
- import com.github.pagehelper.PageHelper;
- import lombok.AllArgsConstructor;
- import org.apache.commons.lang.StringUtils;
- import org.springframework.data.domain.PageImpl;
- import org.springframework.data.domain.PageRequest;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import java.math.BigDecimal;
- import java.util.*;
- /**
- * 余额管理业务实现类
- *
- * Created by FSQ
- * CopyRight https://www.fuint.cn
- */
- @Service
- @AllArgsConstructor
- public class BalanceServiceImpl extends ServiceImpl<MtBalanceMapper, MtBalance> implements BalanceService {
- private MtBalanceMapper mtBalanceMapper;
- private MtUserMapper mtUserMapper;
- /**
- * 微信相关服务接口
- * */
- private WeixinService weixinService;
- /**
- * 会员服务接口
- * */
- private MemberService memberService;
- /**
- * 分页查询余额列表
- *
- * @param paginationRequest
- * @return
- */
- @Override
- public PaginationResponse<BalanceDto> queryBalanceListByPagination(PaginationRequest paginationRequest) throws BusinessCheckException {
- LambdaQueryWrapper<MtBalance> lambdaQueryWrapper = Wrappers.lambdaQuery();
- lambdaQueryWrapper.ne(MtBalance::getStatus, StatusEnum.DISABLE.getKey());
- String description = paginationRequest.getSearchParams().get("description") == null ? "" : paginationRequest.getSearchParams().get("description").toString();
- if (StringUtils.isNotBlank(description)) {
- lambdaQueryWrapper.like(MtBalance::getDescription, description);
- }
- String status = paginationRequest.getSearchParams().get("status") == null ? "" : paginationRequest.getSearchParams().get("status").toString();
- if (StringUtils.isNotBlank(status)) {
- lambdaQueryWrapper.eq(MtBalance::getStatus, status);
- }
- String userId = paginationRequest.getSearchParams().get("userId") == null ? "" : paginationRequest.getSearchParams().get("userId").toString();
- if (StringUtils.isNotBlank(userId)) {
- lambdaQueryWrapper.eq(MtBalance::getUserId, userId);
- }
- String orderSn = paginationRequest.getSearchParams().get("orderSn") == null ? "" : paginationRequest.getSearchParams().get("orderSn").toString();
- if (StringUtils.isNotBlank(orderSn)) {
- lambdaQueryWrapper.eq(MtBalance::getOrderSn, orderSn);
- }
- String mobile = paginationRequest.getSearchParams().get("mobile") == null ? "" : paginationRequest.getSearchParams().get("mobile").toString();
- if (StringUtils.isNotBlank(mobile)) {
- lambdaQueryWrapper.eq(MtBalance::getMobile, mobile);
- }
- String merchantId = paginationRequest.getSearchParams().get("merchantId") == null ? "" : paginationRequest.getSearchParams().get("merchantId").toString();
- if (StringUtils.isNotBlank(merchantId)) {
- lambdaQueryWrapper.eq(MtBalance::getMerchantId, merchantId);
- }
- String userNo = paginationRequest.getSearchParams().get("userNo") == null ? "" : paginationRequest.getSearchParams().get("userNo").toString();
- if (StringUtil.isNotEmpty(userNo)) {
- if (StringUtil.isEmpty(merchantId)) {
- merchantId = "0";
- }
- MtUser userInfo = memberService.queryMemberByUserNo(Integer.parseInt(merchantId), userNo);
- if (userInfo != null) {
- lambdaQueryWrapper.eq(MtBalance::getUserId, userInfo.getId());
- }
- }
- String storeId = paginationRequest.getSearchParams().get("storeId") == null ? "" : paginationRequest.getSearchParams().get("storeId").toString();
- if (StringUtils.isNotBlank(storeId)) {
- lambdaQueryWrapper.eq(MtBalance::getStoreId, storeId);
- }
- lambdaQueryWrapper.orderByDesc(MtBalance::getId);
- List<MtBalance> balanceList = mtBalanceMapper.selectList(lambdaQueryWrapper);
- List<BalanceDto> dataList = new ArrayList<>();
- for (MtBalance mtBalance : balanceList) {
- MtUser userInfo = memberService.queryMemberById(mtBalance.getUserId());
- BalanceDto item = new BalanceDto();
- item.setId(mtBalance.getId());
- item.setAmount(mtBalance.getAmount());
- item.setDescription(mtBalance.getDescription());
- item.setCreateTime(mtBalance.getCreateTime());
- item.setUpdateTime(mtBalance.getUpdateTime());
- item.setUserId(mtBalance.getUserId());
- item.setUserInfo(userInfo);
- item.setOrderSn(mtBalance.getOrderSn());
- item.setStatus(mtBalance.getStatus());
- item.setOperator(mtBalance.getOperator());
- dataList.add(item);
- }
- Page<MtBanner> pageHelper = PageHelper.startPage(paginationRequest.getCurrentPage(), paginationRequest.getPageSize());
- PageRequest pageRequest = PageRequest.of(paginationRequest.getCurrentPage(), paginationRequest.getPageSize());
- PageImpl pageImpl = new PageImpl(dataList, pageRequest, pageHelper.getTotal());
- PaginationResponse<BalanceDto> paginationResponse = new PaginationResponse(pageImpl, BalanceDto.class);
- paginationResponse.setTotalPages(pageHelper.getPages());
- paginationResponse.setTotalElements(pageHelper.getTotal());
- paginationResponse.setContent(dataList);
- return paginationResponse;
- }
- /**
- * 添加余额记录
- *
- * @param mtBalance
- * @param updateBalance
- * @throws BusinessCheckException
- */
- @Override
- @Transactional(rollbackFor = Exception.class)
- @OperationServiceLog(description = "会员余额变动")
- public Boolean addBalance(MtBalance mtBalance, Boolean updateBalance) throws BusinessCheckException {
- if (mtBalance.getUserId() < 0) {
- return false;
- }
- mtBalance.setStatus(StatusEnum.ENABLED.getKey());
- mtBalance.setCreateTime(new Date());
- mtBalance.setUpdateTime(new Date());
- MtUser mtUser = mtUserMapper.selectById(mtBalance.getUserId());
- BigDecimal newAmount = mtUser.getBalance().add(mtBalance.getAmount());
- if (newAmount.compareTo(new BigDecimal("0")) < 0) {
- return false;
- }
- if (mtUser.getStoreId() != null) {
- mtBalance.setStoreId(mtUser.getStoreId());
- }
- mtBalance.setMerchantId(mtUser.getMerchantId());
- if (updateBalance) {
- mtUser.setBalance(newAmount);
- mtUserMapper.updateById(mtUser);
- }
- if (PhoneFormatCheckUtils.isChinaPhoneLegal(mtUser.getMobile())) {
- mtBalance.setMobile(mtUser.getMobile());
- }
- mtBalanceMapper.insert(mtBalance);
- // 发送小程序订阅消息
- Date nowTime = new Date();
- Date sendTime = new Date(nowTime.getTime() + 60000);
- Map<String, Object> params = new HashMap<>();
- String dateTime = DateUtil.formatDate(Calendar.getInstance().getTime(), "yyyy-MM-dd HH:mm");
- params.put("amount", mtBalance.getAmount());
- params.put("time", dateTime);
- params.put("tips", "您的余额发生了变动,请留意~");
- weixinService.sendSubscribeMessage(mtBalance.getMerchantId(), mtBalance.getUserId(), mtUser.getOpenId(), WxMessageEnum.BALANCE_CHANGE.getKey(), "pages/user/index", params, sendTime);
- return true;
- }
- /**
- * 发放余额
- *
- * @param accountInfo
- * @param userIds
- * @param amount
- * @param remark
- * @return
- */
- @Override
- @Transactional(rollbackFor = Exception.class)
- @OperationServiceLog(description = "发放余额")
- public void distribute(AccountInfo accountInfo, String object, String userIds, String amount, String remark) throws BusinessCheckException {
- if (!CommonUtil.isNumeric(amount)) {
- throw new BusinessCheckException("充值金额必须是数字");
- }
- if (!object.equals("all") && StringUtil.isEmpty(userIds)) {
- throw new BusinessCheckException("请先选择会员");
- }
- if (accountInfo.getMerchantId() == null || accountInfo.getMerchantId() < 1) {
- throw new BusinessCheckException("平台账号不能执行该操作");
- }
- BigDecimal balanceAmount = new BigDecimal(amount);
- List<Integer> userIdArr = new ArrayList<>();
- List<String> userIdList = Arrays.asList(userIds.split(","));
- if (userIdList != null && userIdList.size() > 0) {
- for (String userId : userIdList) {
- if (StringUtil.isNotEmpty(userId) && !userIdArr.contains(Integer.parseInt(userId))) {
- userIdArr.add(Integer.parseInt(userId));
- }
- }
- }
- mtUserMapper.updateUserBalance(accountInfo.getMerchantId(), userIdArr, balanceAmount);
- if (userIdArr.size() > 0) {
- for(Integer userId : userIdArr) {
- MtBalance mtBalance = new MtBalance();
- mtBalance.setAmount(new BigDecimal(amount));
- mtBalance.setUserId(userId);
- mtBalance.setMerchantId(accountInfo.getMerchantId());
- mtBalance.setDescription(remark);
- mtBalance.setOperator(accountInfo.getAccountName());
- addBalance(mtBalance, false);
- }
- }
- }
- /**
- * 获取订单余额记录
- *
- * @param orderSn
- * @return
- * */
- @Override
- public List<MtBalance> getBalanceListByOrderSn(String orderSn) {
- return mtBalanceMapper.getBalanceListByOrderSn(orderSn);
- }
- }
|