| | |
| | | private MemberDao memberDao; |
| | | @Autowired |
| | | private YunDingProducter yunDingProducter; |
| | | @Autowired |
| | | private RedisUtils redisUtils; |
| | | |
| | | @Override |
| | | public Result findAllInfo() { |
| | |
| | | for(YdProductVo ydProductVo : records){ |
| | | ydProductVo.setProfitT(prifitT); |
| | | |
| | | if(ydProductVo.getTotalT().compareTo(BigDecimal.ZERO) < 1) { |
| | | if(ydProductVo.getSurplusT().compareTo(BigDecimal.ZERO) < 1) { |
| | | ydProductVo.setStatus(2); |
| | | } |
| | | } |
| | |
| | | return Result.fail("请重新选择产品"); |
| | | } |
| | | |
| | | if (quantity.compareTo(BigDecimal.valueOf(ydProductEntity.getLimitedNum())) < 1) { |
| | | return Result.fail("产品限购" + ydProductEntity.getLimitedNum()); |
| | | Integer status = ydProductEntity.getStatus(); |
| | | if(YdProductEntity.STATUE_WORK != status){ |
| | | if(YdProductEntity.STATUE_END == status){ |
| | | return Result.fail("产品已售罄"); |
| | | } |
| | | if(YdProductEntity.STATUE_READY == status){ |
| | | return Result.fail("产品未开售"); |
| | | } |
| | | } |
| | | |
| | | //限购总量 |
| | | Integer limitedNum = ydProductEntity.getLimitedNum(); |
| | | //获取目前待生效,已生效的总T数 |
| | | int quantityOwn = 0; |
| | | QueryWrapper<YdOrderEntity> powerReradyQuery = new QueryWrapper<>(); |
| | | powerReradyQuery.eq("member_id",memberId); |
| | | powerReradyQuery.eq("product_id",payProductDto.getId()); |
| | | powerReradyQuery.eq("type",YdOrderEntity.PRODUCT_ORDER); |
| | | powerReradyQuery.ne("state",YdOrderEntity.ORDER_STATE_END); |
| | | List<YdOrderEntity> powerReradyQuerys = ydOrderDao.selectList(powerReradyQuery); |
| | | if(CollUtil.isNotEmpty(powerReradyQuerys)){ |
| | | for(YdOrderEntity ydOrderEntity : powerReradyQuerys){ |
| | | quantityOwn = quantityOwn + ydOrderEntity.getQuantity(); |
| | | } |
| | | } |
| | | int quantityInt = quantity.intValue(); |
| | | if(quantityOwn + quantityInt > limitedNum){ |
| | | return Result.fail("产品限购"+limitedNum); |
| | | } |
| | | |
| | | // if (quantity.compareTo(BigDecimal.valueOf(ydProductEntity.getLimitedNum())) < 1) { |
| | | // return Result.fail("产品限购" + ydProductEntity.getLimitedNum()); |
| | | // } |
| | | BigDecimal salePrice = ydProductEntity.getSalePrice(); |
| | | //剩余产品数量 |
| | | BigDecimal surplusT = ydProductEntity.getSurplusT(); |
| | |
| | | BigDecimal totalProfitAll = BigDecimal.ZERO; |
| | | QueryWrapper<YdOrderEntity> objectQueryWrapper = new QueryWrapper<>(); |
| | | objectQueryWrapper.eq("member_id",memberId); |
| | | objectQueryWrapper.eq("type",YdOrderEntity.PRODUCT_ORDER); |
| | | List<YdOrderEntity> ydOrderEntities = ydOrderDao.selectList(objectQueryWrapper); |
| | | if(CollUtil.isNotEmpty(ydOrderEntities)){ |
| | | for(YdOrderEntity order : ydOrderEntities){ |
| | |
| | | QueryWrapper<YdOrderEntity> powerNowQuery = new QueryWrapper<>(); |
| | | powerNowQuery.eq("member_id",memberId); |
| | | powerNowQuery.eq("state",YdOrderEntity.ORDER_STATE_WORK); |
| | | powerNowQuery.eq("type",YdOrderEntity.PRODUCT_ORDER); |
| | | List<YdOrderEntity> PowerNowQuery = ydOrderDao.selectList(powerNowQuery); |
| | | if(CollUtil.isNotEmpty(PowerNowQuery)){ |
| | | for(YdOrderEntity order : PowerNowQuery){ |
| | |
| | | int powerReady = 0; |
| | | QueryWrapper<YdOrderEntity> powerReradyQuery = new QueryWrapper<>(); |
| | | powerReradyQuery.eq("member_id",memberId); |
| | | powerReradyQuery.eq("type",YdOrderEntity.PRODUCT_ORDER); |
| | | powerReradyQuery.eq("state",YdOrderEntity.ORDER_STATE_READY); |
| | | List<YdOrderEntity> PowerReradyQuery = ydOrderDao.selectList(powerReradyQuery); |
| | | if(CollUtil.isNotEmpty(PowerReradyQuery)){ |
| | | for(YdOrderEntity order : PowerReradyQuery){ |
| | | List<YdOrderEntity> powerReradyQuerys = ydOrderDao.selectList(powerReradyQuery); |
| | | if(CollUtil.isNotEmpty(powerReradyQuerys)){ |
| | | for(YdOrderEntity order : powerReradyQuerys){ |
| | | int quantity = order.getQuantity(); |
| | | powerReady = powerReady + quantity; |
| | | } |
| | |
| | | YdOrderEntity orderEntity = new YdOrderEntity(); |
| | | orderEntity.setType(YdOrderEntity.AGENT_ORDER); |
| | | orderEntity.setMemberId(memberId); |
| | | orderEntity.setProductId(id); |
| | | orderEntity.setAmount(salePrice); |
| | | ydOrderDao.insert(orderEntity); |
| | | |
| | |
| | | return Result.ok("购买成功"); |
| | | } |
| | | |
| | | @Override |
| | | public Result getXchPrice() { |
| | | log.info("获取XCH当前价"); |
| | | BigDecimal xchNewPrices = BigDecimal.ZERO; |
| | | String xchNewPrice = redisUtils.getString("XCH_NEW_PRICE"); |
| | | if(StrUtil.isNotEmpty(xchNewPrice)){ |
| | | xchNewPrices = new BigDecimal(xchNewPrice); |
| | | } |
| | | return Result.ok(xchNewPrices); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 去加减币币账户余额,减少产品的剩余数目 |