From 9671a5baaebe1b3bce04dba485d4e7435e1aed03 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Wed, 13 Dec 2023 14:46:28 +0800
Subject: [PATCH] 微信小程序配置

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java |  162 ++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 132 insertions(+), 30 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java
index ed4476f..e2adb67 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java
@@ -46,6 +46,7 @@
     private final MallProductSellMapper mallProductSellMapper;
     private final MallProductSellRecordMapper mallProductSellRecordMapper;
     private final MallProductBuyRecordMapper mallProductBuyRecordMapper;
+    private final MallMemberSpeakMapper mallMemberSpeakMapper;
 
     @Override
     public List<ApiMallProductNftVo> productNFTList() {
@@ -281,21 +282,23 @@
         BigDecimal nftFeePercent = ObjectUtil.isEmpty(nftFeeDic) ? new BigDecimal(20) : new BigDecimal(nftFeeDic.getValue());
         nftFeePercent = nftFeePercent.divide(new BigDecimal(100),4,BigDecimal.ROUND_DOWN);
         BigDecimal nftFee = nftCnt.multiply(nftFeePercent);
-        BigDecimal nftCntAva = nftCnt.subtract(nftFee);
-
         DataDictionaryCustom fcmPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
                 DataDictionaryEnum.FCM_PRICE.getType(),
                 DataDictionaryEnum.FCM_PRICE.getCode());
         BigDecimal fcmPrice = ObjectUtil.isEmpty(fcmPriceDic) ? new BigDecimal(2) : new BigDecimal(fcmPriceDic.getValue());
         BigDecimal fcmFeeCnt = nftFee.divide(fcmPrice, 2, BigDecimal.ROUND_DOWN);
+        if(BigDecimal.ZERO.compareTo(mallMemberAmount.getTrendsNft()) >= 0
+            || fcmFeeCnt.compareTo(mallMemberAmount.getFcmCntAva()) > 0){
+            throw new FebsException("手续费不足");
+        }
 
         String orderNo = MallUtils.getOrderNum("NFT");
         MallProductSell mallProductSell = new MallProductSell();
         mallProductSell.setMemberId(memberId);
         mallProductSell.setOrderNo(orderNo);
         mallProductSell.setNftTotal(nftCnt);
-        mallProductSell.setNftCnt(nftCntAva);
-        mallProductSell.setNftCntAva(nftCntAva);
+        mallProductSell.setNftCnt(nftCnt);
+        mallProductSell.setNftCntAva(nftCnt);
         mallProductSell.setNftFee(nftFee);
         mallProductSell.setFcmFee(fcmFeeCnt);
         mallProductSell.setState(ProductEnum.PRODUCT_SELL_ON_GOING.getValue());
@@ -309,7 +312,7 @@
         mallMemberAmountMapper.updateFcmCntAvaById(mallMemberAmountFcm);
 
         MallMemberAmount mallMemberAmountFrozenNFT = mallMemberAmountMapper.selectByMemberId(memberId);
-        mallMemberAmountFrozenNFT.setFrozenNft(mallMemberAmountFrozenNFT.getFrozenNft().add(nftCntAva));
+        mallMemberAmountFrozenNFT.setFrozenNft(mallMemberAmountFrozenNFT.getFrozenNft().add(nftCnt));
         mallMemberAmountMapper.updateFrozenNftById(mallMemberAmountFrozenNFT);
         iMallMoneyFlowService.addMoneyFlow(
                 memberId,
@@ -327,15 +330,6 @@
                 mallMember.getId(),
                 FlowTypeNewEnum.FCM_COIN.getValue(),
                 MoneyFlowTypeNewEnum.NFT_OUT_FEE_FCM.getDescrition());
-        iMallMoneyFlowService.addMoneyFlow(
-                memberId,
-                nftFee.negate(),
-                MoneyFlowTypeNewEnum.NFT_OUT_FEE.getValue(),
-                orderNo,
-                mallMember.getId(),
-                FlowTypeNewEnum.NFT.getValue(),
-                MoneyFlowTypeNewEnum.NFT_OUT_FEE.getDescrition());
-
         agentProducer.sendFcmNFTExchangeMsg(fcmFeeCnt.toString());
         return new FebsResponse().success();
     }
@@ -369,24 +363,41 @@
         );
         DateTime endTime = DateUtil.parseTime(endTimeDic.getValue());
         if(nowTime.compareTo(startTime) >= 0 && nowTime.compareTo(endTime) <= 0){
-            //买单
-            if(2 == orderType){
-                IPage<ApiOrderListVo> page = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
-                IPage<ApiOrderListVo> apiOrderListVoIPageBuy = mallProductBuyMapper.selectListInPage(page, apiOrderListDto);
-                if(CollUtil.isNotEmpty(apiOrderListVoIPageBuy.getRecords())){
-                    for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageBuy.getRecords()){
-                        objects.add(apiOrderListVo);
-                    }
+//            //买单
+//            if(2 == orderType){
+//                IPage<ApiOrderListVo> page = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+//                IPage<ApiOrderListVo> apiOrderListVoIPageBuy = mallProductBuyMapper.selectListInPage(page, apiOrderListDto);
+//                if(CollUtil.isNotEmpty(apiOrderListVoIPageBuy.getRecords())){
+//                    for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageBuy.getRecords()){
+//                        objects.add(apiOrderListVo);
+//                    }
+//                }
+//            }
+//            //卖单
+//            if(1 == orderType){
+//                IPage<ApiOrderListVo> page = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+//                IPage<ApiOrderListVo> apiOrderListVoIPageSell = mallProductSellMapper.selectListInPage(page, apiOrderListDto);
+//                if(CollUtil.isNotEmpty(apiOrderListVoIPageSell.getRecords())){
+//                    for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageSell.getRecords()){
+//                        objects.add(apiOrderListVo);
+//                    }
+//                }
+//            }
+
+            IPage<ApiOrderListVo> pageBuy = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+            IPage<ApiOrderListVo> apiOrderListVoIPageBuy = mallProductBuyMapper.selectListInPage(pageBuy, apiOrderListDto);
+            if(CollUtil.isNotEmpty(apiOrderListVoIPageBuy.getRecords())){
+                for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageBuy.getRecords()){
+                    objects.add(apiOrderListVo);
                 }
             }
-            //卖单
-            if(1 == orderType){
-                IPage<ApiOrderListVo> page = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
-                IPage<ApiOrderListVo> apiOrderListVoIPageSell = mallProductSellMapper.selectListInPage(page, apiOrderListDto);
-                if(CollUtil.isNotEmpty(apiOrderListVoIPageSell.getRecords())){
-                    for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageSell.getRecords()){
-                        objects.add(apiOrderListVo);
-                    }
+
+
+            IPage<ApiOrderListVo> pageSell = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+            IPage<ApiOrderListVo> apiOrderListVoIPageSell = mallProductSellMapper.selectListInPage(pageSell, apiOrderListDto);
+            if(CollUtil.isNotEmpty(apiOrderListVoIPageSell.getRecords())){
+                for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageSell.getRecords()){
+                    objects.add(apiOrderListVo);
                 }
             }
         }
@@ -554,4 +565,95 @@
         }
         return false;
     }
+
+    @Override
+    public FebsResponse orderSellComplain(ApiOrderSellComplainDto apiOrderSellComplainDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        Long sellRecordId = apiOrderSellComplainDto.getSellRecordId();
+        Integer orderType = apiOrderSellComplainDto.getOrderType();
+        String buyOrderNo = null;
+        if(orderType == 1){
+
+            MallProductSellRecord mallProductSellRecord = mallProductSellRecordMapper.selectById(sellRecordId);
+            if(ObjectUtil.isEmpty(mallProductSellRecord)){
+                throw new FebsException("记录不存在");
+            }
+            MallProductBuyRecord mallProductBuyRecord = mallProductBuyRecordMapper.selectById(mallProductSellRecord.getBuyRecordId());
+            if(ObjectUtil.isEmpty(mallProductBuyRecord)){
+                throw new FebsException("记录不存在");
+            }
+
+            mallProductBuyRecord.setState(ProductEnum.PRODUCT_MATE_STATE_COMPLAIN.getValue());
+            mallProductBuyRecordMapper.updateById(mallProductBuyRecord);
+
+            mallProductSellRecord.setState(ProductEnum.PRODUCT_MATE_STATE_COMPLAIN.getValue());
+            mallProductSellRecordMapper.updateById(mallProductSellRecord);
+            buyOrderNo = mallProductBuyRecord.getBuyOrderNo();
+        }
+        if(orderType == 2){
+            MallProductBuyRecord mallProductBuyRecord = mallProductBuyRecordMapper.selectById(sellRecordId);
+            if(ObjectUtil.isEmpty(mallProductBuyRecord)){
+                throw new FebsException("记录不存在");
+            }
+
+            MallProductSellRecord mallProductSellRecord = mallProductSellRecordMapper.selectById(mallProductBuyRecord.getSellRecordId());
+            if(ObjectUtil.isEmpty(mallProductSellRecord)){
+                throw new FebsException("记录不存在");
+            }
+
+
+            mallProductBuyRecord.setState(ProductEnum.PRODUCT_MATE_STATE_COMPLAIN.getValue());
+            mallProductBuyRecordMapper.updateById(mallProductBuyRecord);
+
+            mallProductSellRecord.setState(ProductEnum.PRODUCT_MATE_STATE_COMPLAIN.getValue());
+            mallProductSellRecordMapper.updateById(mallProductSellRecord);
+            buyOrderNo = mallProductBuyRecord.getBuyOrderNo();
+
+        }
+
+        MallMemberSpeak mallMemberSpeak = new MallMemberSpeak();
+        mallMemberSpeak.setMemberId(memberId);
+        mallMemberSpeak.setState(ProductEnum.SPEAK_NO_DEAL.getValue());
+        String description = apiOrderSellComplainDto.getDescription();
+        mallMemberSpeak.setDescription("编号:"+buyOrderNo+","+description);
+        mallMemberSpeakMapper.insert(mallMemberSpeak);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse orderRecordList(ApiOrderRecordListDto apiOrderListDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        List<ApiOrderRecordListVo> objects = new ArrayList<>();
+        apiOrderListDto.setMemberId(memberId);
+        DateTime nowTime = DateUtil.parseTime(DateUtil.formatTime(DateUtil.date()));
+        DataDictionaryCustom startTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_START_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_START_TIME.getCode()
+        );
+        DateTime startTime = DateUtil.parseTime(startTimeDic.getValue());
+        DataDictionaryCustom endTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_END_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_END_TIME.getCode()
+        );
+        DateTime endTime = DateUtil.parseTime(endTimeDic.getValue());
+        if(nowTime.compareTo(startTime) >= 0 && nowTime.compareTo(endTime) <= 0){
+            IPage<ApiOrderRecordListVo> pageBuy = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+            IPage<ApiOrderRecordListVo> apiOrderListVoIPageBuy = mallProductBuyRecordMapper.selectListInPage(pageBuy, apiOrderListDto);
+            if(CollUtil.isNotEmpty(apiOrderListVoIPageBuy.getRecords())){
+                for(ApiOrderRecordListVo apiOrderListVo : apiOrderListVoIPageBuy.getRecords()){
+                    objects.add(apiOrderListVo);
+                }
+            }
+
+            IPage<ApiOrderRecordListVo> pageSell = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+            IPage<ApiOrderRecordListVo> apiOrderListVoIPageSell = mallProductSellRecordMapper.selectListInPage(pageSell, apiOrderListDto);
+            if(CollUtil.isNotEmpty(apiOrderListVoIPageSell.getRecords())){
+                for(ApiOrderRecordListVo apiOrderListVo : apiOrderListVoIPageSell.getRecords()){
+                    objects.add(apiOrderListVo);
+                }
+            }
+        }
+
+        return new FebsResponse().success().data(objects);
+    }
 }

--
Gitblit v1.9.1