From b1e207a90d3f395973b4cd1eee92dbcbbafd6e78 Mon Sep 17 00:00:00 2001 From: 101captain <237651143@qq.com> Date: 星期五, 14 一月 2022 14:57:35 +0800 Subject: [PATCH] jsapi支付修改 --- springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java | 256 ++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 250 insertions(+), 6 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java index 25c3a82..db83cb2 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java @@ -1,10 +1,23 @@ package com.panzhihua.service_community.service.impl; import static java.util.Objects.isNull; +import static java.util.Objects.nonNull; +import static org.apache.commons.lang3.StringUtils.isNotEmpty; + +import java.util.ArrayList; +import java.util.Date; +import java.util.List; +import java.util.Random; import javax.annotation.Resource; -import com.panzhihua.common.model.vos.community.microCommercialStreet.TopStatisticsVO; +import com.panzhihua.common.model.vos.community.microCommercialStreet.McsCouponVO; +import com.panzhihua.common.utlis.Snowflake; +import com.panzhihua.service_community.dao.McsEvaluateDAO; +import com.panzhihua.service_community.entity.McsCoupon; +import com.panzhihua.service_community.util.NearbyUtil; +import com.panzhihua.service_community.util.QRCodeUtil; +import com.spatial4j.core.shape.Rectangle; import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; @@ -18,13 +31,15 @@ import com.panzhihua.common.model.dtos.community.microCommercialStreet.SetShelfForGameDTO; import com.panzhihua.common.model.vos.R; import com.panzhihua.common.model.vos.community.microCommercialStreet.McsGameVO; +import com.panzhihua.common.model.vos.community.microCommercialStreet.TopStatisticsVO; +import com.panzhihua.common.utlis.DateUtils; +import com.panzhihua.service_community.dao.McsCouponDAO; import com.panzhihua.service_community.dao.McsGameDAO; import com.panzhihua.service_community.dao.McsMerchantDAO; import com.panzhihua.service_community.entity.McsGame; import com.panzhihua.service_community.entity.McsMerchant; import com.panzhihua.service_community.service.McsGameService; - -import java.util.Date; +import org.springframework.transaction.annotation.Transactional; /** * (McsGame)表服务实现类 @@ -37,6 +52,10 @@ @Resource private McsMerchantDAO mcsMerchantDAO; + @Resource + private McsCouponDAO mcsCouponDAO; + @Resource + private McsEvaluateDAO mcsEvaluateDAO; /** * 分页查询戳戳游戏 @@ -58,6 +77,7 @@ * @return */ @Override + @Transactional(rollbackFor = Exception.class) public R setPopularForGame(SetPopularForGameDTO setPopularForGameDTO) { McsGame mcsGame = this.baseMapper.selectById(setPopularForGameDTO.getGameId()); if (isNull(mcsGame)) { @@ -66,6 +86,11 @@ Integer type = setPopularForGameDTO.getType(); if (type.equals(1)) { //设为热门 + List<McsGame> popularGames = this.baseMapper.selectList(new QueryWrapper<McsGame>().lambda().eq(McsGame::getIsPopular, true)); + if (nonNull(popularGames) && !popularGames.isEmpty()) { + popularGames.forEach(e -> e.setIsPopular(false)); + this.updateBatchById(popularGames); + } mcsGame.setIsPopular(true); } else if (type.equals(2)) { //取消热门 @@ -158,9 +183,11 @@ return R.fail("缺少分配方式"); } if (isNull(coins)) { - return R.fail("未设置戳戳币总额"); + return R.fail("未设置戳戳币额度"); } - mcsGame.setSurplusCoins(mcsGameDTO.getCoins()); + if (allocation.equals(1)) { + mcsGame.setSurplusCoins(mcsGameDTO.getCoins()); + } } else if (type.equals(2)) { //2.体验游戏 Integer awardType = mcsGameDTO.getAwardType(); @@ -201,10 +228,13 @@ return R.fail("缺少分配方式"); } if (isNull(coins)) { - return R.fail("未设置戳戳币总额"); + return R.fail("未设置戳戳币额度"); } Integer beforeCoins = mcsGame.getCoins(); Integer beforeSurplusCoins = mcsGame.getSurplusCoins(); + if (isNull(beforeSurplusCoins)) { + beforeSurplusCoins = beforeCoins; + } Integer beforeUsedCoins = beforeCoins - beforeSurplusCoins; Integer surplusCoins = coins - beforeUsedCoins; if (surplusCoins < 0) { @@ -299,6 +329,10 @@ } TopStatisticsVO topStatisticsVO = new TopStatisticsVO(); topStatisticsVO.setExpireAt(mcsMerchant.getExpireAt()); + if (nonNull(mcsMerchant.getExpireAt())) { + int surplusLitDays = DateUtils.differentDays(new Date(), mcsMerchant.getExpireAt()); + topStatisticsVO.setSurplusLitDays(surplusLitDays > 0 ? surplusLitDays : 0); + } Integer appliedCount = this.baseMapper.selectAppliedCount(mcsMerchant.getId()); topStatisticsVO.setAppliedTotal(appliedCount); Integer verifiedCount = this.baseMapper.selectVerifiedCount(mcsMerchant.getId()); @@ -310,4 +344,214 @@ topStatisticsVO.setIdleTotal(idleTotal > 0 ? idleTotal : 0); return R.ok(topStatisticsVO); } + + /** + * 戳戳卷领取 + * @param gameId + * @param userId + * @return + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R applyMcsCoupon(Long gameId, Long userId) { + McsGame mcsGame = this.baseMapper.selectById(gameId); + if (isNull(mcsGame) || mcsGame.getIsDel()) { + return R.fail("游戏已下架"); + } + Integer userAppliedCount = mcsCouponDAO.selectCount(new QueryWrapper<McsCoupon>().lambda().eq(McsCoupon::getGameId, gameId).eq(McsCoupon::getUserId, userId)); + if (userAppliedCount > 0) { + return R.fail("请勿重复领取"); + } + Integer surplusCoupons = mcsGame.getSurplusCoupons(); + if (surplusCoupons <= 0) { + return R.fail("抢光了"); + } + McsCoupon mcsCoupon = new McsCoupon(); + Long snowflakeId = Snowflake.getId(); + mcsCoupon.setId(snowflakeId); + mcsCoupon.setGameId(gameId); + mcsCoupon.setUserId(userId); + mcsCoupon.setQrCode(QRCodeUtil.getBase64QRCode(snowflakeId.toString())); + Integer type = mcsGame.getType(); + if (type.equals(1)) { + //戳戳币游戏 + Integer allocation = mcsGame.getAllocation(); + if (allocation.equals(1)) { + //随机分配 + Integer surplusCoins = mcsGame.getSurplusCoins(); + Integer coin = getRandomCoins(surplusCoins, mcsGame.getSurplusCoupons()); + mcsCoupon.setCoin(coin); + mcsCoupon.setAward("戳戳币:" + coin); + mcsGame.setSurplusCoins(surplusCoins - coin); + } else { + //固定值 + mcsCoupon.setCoin(mcsGame.getCoins()); + mcsCoupon.setAward("戳戳币:" + mcsGame.getCoins()); + } + } else { + //体验游戏 + Integer awardType = mcsGame.getAwardType(); + if (awardType.equals(1)) { + mcsCoupon.setAward("免费产品"); + } else { + mcsCoupon.setAward("免费服务"); + } + } + int num = mcsCouponDAO.insert(mcsCoupon); + if (num > 0) { + mcsGame.setSurplusCoupons(surplusCoupons - 1); + this.baseMapper.updateById(mcsGame); + McsCouponVO mcsCouponVO = new McsCouponVO(); + mcsCouponVO.setId(snowflakeId); + mcsCouponVO.setIsVerified(false); + mcsCouponVO.setQrCode(mcsCoupon.getQrCode()); + mcsCouponVO.setAward(mcsCoupon.getAward()); + return R.ok(mcsCouponVO); + } + return R.fail("领取失败,请重试"); + } + + /** + * h5分页查询戳戳游戏 + * @param pageMcsGameDTO + * @return + */ + @Override + public R pageH5McsGame(PageMcsGameDTO pageMcsGameDTO) { + Page page = new Page<>(); + page.setSize(pageMcsGameDTO.getPageSize()); + page.setCurrent(pageMcsGameDTO.getPageNum()); + String lat = pageMcsGameDTO.getLat(); + String lon = pageMcsGameDTO.getLon(); + Integer distance = pageMcsGameDTO.getDistance(); + IPage<McsGameVO> mcsGames; + if (isNotEmpty(lat) && isNotEmpty(lon) && nonNull(distance)) { + Rectangle rectangle = new NearbyUtil().getRectangle(pageMcsGameDTO.getDistance(), + Double.parseDouble(pageMcsGameDTO.getLon()), Double.parseDouble(pageMcsGameDTO.getLat())); + mcsGames = this.baseMapper.pageH5McsGame(page, rectangle.getMinX(), rectangle.getMaxX(), + rectangle.getMinY(), rectangle.getMaxY(), pageMcsGameDTO); + } else { + mcsGames = this.baseMapper.pageH5McsGame(page, null, null, null, null, pageMcsGameDTO); + } + + return R.ok(mcsGames); + } + + /** + * 游戏详情 + * @param gameId + * @return + */ + @Override + public R getMcsGame(Long gameId) { + McsGameVO mcsGameVO = this.baseMapper.selectDetailById(gameId); + Integer gameCount = this.baseMapper.selectCount(new QueryWrapper<McsGame>().lambda() + .eq(McsGame::getMerchantId, mcsGameVO.getMerchantId()).eq(McsGame::getStatus, McsGame.Status.jxz).eq(McsGame::getIsDel, false)); + mcsGameVO.setGameCount(gameCount); + return R.ok(mcsGameVO); + } + + public static void main(String[] args) { + int total = 500; + int people = 10; + for (int i = 1;i <= 10; i++) { + Integer decrease = getRandomCoins(total, people); + total -= decrease; + people --; + System.out.println("第:" + i + "个人领取到:" + decrease + "戳戳币,总数还剩下:" + total); + } + } + + public static Integer getRandomCoins(int totalCoins, int peopleTotal) { + List<Integer> list = new ArrayList<>(peopleTotal); + if (peopleTotal == 1) { + return totalCoins; + } + Random random = new Random(); + // 平均分配 + int average = totalCoins / peopleTotal; + int max = (int) Math.floor(totalCoins * 0.6); + int min = (int) Math.floor(average * 0.5); + float thresh = 0.95F; + int rest = totalCoins - average * peopleTotal; + for (int i = 0; i < peopleTotal; i++) { + if (i < rest) { + list.add(average + 1); + } else { + list.add(average); + } + } + // 根据阀值进行数据随机处理 + int randOfRange = 0; + int randRom = 0; + int nextIndex = 0; + int nextValue = 0; + //多余 + int surplus = 0; + //缺少 + int lack = 0; + for (int i = 0; i < peopleTotal - 1; i++) { + nextIndex = i + 1; + int itemThis = list.get(i); + int itemNext = list.get(nextIndex); + boolean isLt = itemThis < itemNext; + int rangeThis = isLt ? max - itemThis : itemThis - min; + int rangeNext = isLt ? itemNext - min : max - itemNext; + int rangeFinal = (int) Math.ceil(thresh * (Math.min(rangeThis, rangeNext) + 1)); + randOfRange = random.nextInt(rangeFinal); + randRom = isLt ? 1 : -1; + int iValue = list.get(i) + randRom * randOfRange; + nextValue = list.get(nextIndex) + randRom * randOfRange * -1; + if (iValue > max) { + surplus += (iValue - max); + list.set(i, max); + } else if (iValue < min) { + list.set(i, min); + lack += (min - iValue); + } else { + list.set(i, iValue); + } + list.set(nextIndex, nextValue); + } + if (nextValue > max) { + surplus += (nextValue - max); + list.set(nextIndex, max); + } + if (nextValue < min) { + lack += (min - nextValue); + list.set(nextIndex, min); + } + if (surplus - lack > 0) { + //分少了 给低于max的凑到max + for (int i = 0; i < list.size(); i++) { + int value = list.get(i); + if (value < max) { + int tmp = max - value; + if (surplus >= tmp) { + surplus -= tmp; + list.set(i, max); + } else { + list.set(i, value + surplus); + return list.get(random.nextInt(list.size() - 1)); + } + } + } + } else if (lack - surplus > 0) { + //分多了 给超过高于min的人凑到min + for (int i = 0; i < list.size(); i++) { + int value = list.get(i); + if (value > min) { + int tmp = value - min; + if (lack >= tmp) { + lack -= tmp; + list.set(i, min); + } else { + list.set(i, min + tmp - lack); + return list.get(random.nextInt(list.size() - 1)); + } + } + } + } + return list.get(random.nextInt(list.size() - 1)); + } } -- Gitblit v1.7.1