|  |  |  | 
|---|
|  |  |  | * @param serviceId | 
|---|
|  |  |  | *            交易业务id | 
|---|
|  |  |  | * @param serviceType | 
|---|
|  |  |  | *            交易业务类型(1.发布随手拍 2.发布微心愿 3.参与议事投票 4.参与志愿者活动 5.参与社区活动 6.参与党员活动 7.参与调查问卷) | 
|---|
|  |  |  | *            交易业务类型(1.发布随手拍 2.发布微心愿 3.参与议事投票 4.社区活动-居民身份参与 " + | 
|---|
|  |  |  | *             "5.社区活动-党员身份参与 6.社区活动-志愿者身份参与 7.参与调查问卷 8.取消活动 9.参与单位党员活动) | 
|---|
|  |  |  | * @param amount | 
|---|
|  |  |  | *            交易积分数量 | 
|---|
|  |  |  | * @param changeType | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class) | 
|---|
|  |  |  | public R addIntegralTradeAdmin(AddComActIntegralUserDTO integralUserDTO) { | 
|---|
|  |  |  | // 判断增加积分类型 积分任务类型(1.发布随手拍 2.发布微心愿 3.参与议事投票 4.参加居民活动 5.参加志愿者活动 6.参与党员活动 7.参与调查问卷 8.取消活动) | 
|---|
|  |  |  | // 判断增加积分类型 积分任务类型(1.发布随手拍 2.发布微心愿 3.参与议事投票 4.社区活动-居民身份参与 " + | 
|---|
|  |  |  | //            "5.社区活动-党员身份参与 6.社区活动-志愿者身份参与 7.参与调查问卷 8.取消活动 9.参与单位党员活动) | 
|---|
|  |  |  | Integer type = integralUserDTO.getIntegralType(); | 
|---|
|  |  |  | // 业务id | 
|---|
|  |  |  | Long serviceId = integralUserDTO.getServiceId(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer changeType = ComActIntegralUserTradeDO.changeType.add; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer isVolunteer = integralUserDTO.getIsVolunteer(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!type.equals(8)) { | 
|---|
|  |  |  | if (!type.equals(8) && !type.equals(4) && !type.equals(5) && !type.equals(6) && !type.equals(9)) { | 
|---|
|  |  |  | // 查询随手拍增加积分数量 | 
|---|
|  |  |  | ComActIntegralRuleDO integralRuleDO = | 
|---|
|  |  |  | comActIntegralRuleService.getOne(new QueryWrapper<ComActIntegralRuleDO>().lambda() | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 4: | 
|---|
|  |  |  | if (nonNull(isVolunteer) && isVolunteer.equals(1)) { | 
|---|
|  |  |  | identityType = 3; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | identityType = 1; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | remark.append("成功参加居民活动奖励积分"); | 
|---|
|  |  |  | ComActActivityDO actActivityDO1 = comActActivityService.getById(serviceId); | 
|---|
|  |  |  | if(actActivityDO1 != null) { | 
|---|
|  |  |  | amount = actActivityDO1.getRewardIntegral(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 5: | 
|---|
|  |  |  | if (nonNull(isVolunteer) && isVolunteer.equals(0)) { | 
|---|
|  |  |  | identityType = 1; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | identityType = 3; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | remark.append("成功参加志愿者活动奖励积分"); | 
|---|
|  |  |  | ComActActivityDO actActivityDO = comActActivityService.getById(serviceId); | 
|---|
|  |  |  | if(actActivityDO != null) { | 
|---|
|  |  |  | amount = actActivityDO.getRewardIntegral(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 6: | 
|---|
|  |  |  | identityType = 2; | 
|---|
|  |  |  | remark.append("参与党员活动"); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 7: | 
|---|
|  |  |  | // 查询调查问卷 | 
|---|
|  |  |  | ComActQuestnaireDO questnaireDO = comActQuestnaireDAO.selectById(serviceId); | 
|---|
|  |  |  | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 8: | 
|---|
|  |  |  | changeType = ComActIntegralUserTradeDO.changeType.reduce; | 
|---|
|  |  |  | if (integralUserDTO.getActivityType() == 1) { | 
|---|
|  |  |  | ComActActivityDO actActivityDO2 = comActActivityService.getById(serviceId); | 
|---|
|  |  |  | if (actActivityDO2 != null) { | 
|---|
|  |  |  | amount = -actActivityDO2.getCancelDeduct(); | 
|---|
|  |  |  | if (actActivityDO2.getVolunteerMax() != 0) { | 
|---|
|  |  |  | remark.append("取消志愿者活动扣除积分"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | remark.append("取消居民活动扣除积分"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (nonNull(isVolunteer) && isVolunteer.equals(1)) { | 
|---|
|  |  |  | identityType = 3; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | identityType = 1; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //                else { | 
|---|
|  |  |  | //                    ComPbActivityDO comPbActivityDO = comBpActivityDAO.selectById(serviceId); | 
|---|
|  |  |  | //                    if(comPbActivityDO!=null){ | 
|---|
|  |  |  | //                        amount=comPbActivityDO.getRewardIntegral(); | 
|---|
|  |  |  | //                        identityType=2; | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | amount = -integralUserDTO.getIntegral(); | 
|---|
|  |  |  | remark.append(integralUserDTO.getRemark()); | 
|---|
|  |  |  | identityType = integralUserDTO.getSignIdentity(); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 4: | 
|---|
|  |  |  | case 5: | 
|---|
|  |  |  | case 6: | 
|---|
|  |  |  | case 9: | 
|---|
|  |  |  | identityType = integralUserDTO.getSignIdentity(); | 
|---|
|  |  |  | remark.append(integralUserDTO.getRemark()); | 
|---|
|  |  |  | amount = integralUserDTO.getIntegral(); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | 
|---|
|  |  |  | integralUserDO.setIntegralVolunteer(integralVolunteerNow); | 
|---|
|  |  |  | integralUserDO.setIntegralAvailableVolunteer(addIntegral(integralUserDO.getIntegralAvailableVolunteer() + amount)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (reduceAmount > 0) { | 
|---|
|  |  |  | if (changeType == ComActIntegralUserTradeDO.changeType.reduce) { | 
|---|
|  |  |  | amount = reduceAmount; | 
|---|
|  |  |  | integralUserDO.setIntegralSum(addIntegral(integralSum + reduceAmount)); | 
|---|
|  |  |  | integralUserDO.setIntegralAvailableSum(addIntegral(integralAvailableSum + reduceAmount)); | 
|---|
|  |  |  | integralUserDO.setIntegralSum(addIntegral(integralSum - reduceAmount)); | 
|---|
|  |  |  | integralUserDO.setIntegralAvailableSum(addIntegral(integralAvailableSum - reduceAmount)); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | integralUserDO.setIntegralSum(addIntegral(integralSum + amount)); | 
|---|
|  |  |  | integralUserDO.setIntegralAvailableSum(addIntegral(integralAvailableSum + amount)); | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取积分详情 | 
|---|
|  |  |  | * @param id | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R getUserIntegralDetail(Long id) { | 
|---|
|  |  |  | return R.ok(this.baseMapper.getUserIntegralDetail(id)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private int addIntegral(int integral) { | 
|---|
|  |  |  | return integral > 0 ? integral : 0; | 
|---|
|  |  |  | } | 
|---|