Merge branch 'bd_dev' of 47.94.45.65:angelo/java-base-app into bd_dev
This commit is contained in:
		
						commit
						d04292947c
					
				|  | @ -214,6 +214,15 @@ public interface IMemberServiceApi { | ||||||
|      */ |      */ | ||||||
|     R<Boolean> saveMember(CuMember cuMember, SaOrderExt saOrder, Boolean isPay, CuMemberAccountExt cuMemberAccountExt); |     R<Boolean> saveMember(CuMember cuMember, SaOrderExt saOrder, Boolean isPay, CuMemberAccountExt cuMemberAccountExt); | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 0元会员订单处理 | ||||||
|  |      * | ||||||
|  |      * @param cuMember | ||||||
|  |      * @param saOrder | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     R<Boolean> handleZeroMember(CuMember cuMember, SaOrderExt saOrder); | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * 处理新会员,生成主键,跟会员编号 |      * 处理新会员,生成主键,跟会员编号 | ||||||
|      * |      * | ||||||
|  |  | ||||||
|  | @ -9,11 +9,7 @@ import java.io.Serializable; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * @Description: 用户权限DTO |  * 用户权限DTO | ||||||
|  * @Author: jiang chao |  | ||||||
|  * @Time: 2023/5/22 14:37 |  | ||||||
|  * @Classname: UserAuthorityDTO |  | ||||||
|  * @PackageName: com.hzs.system.sys.dto |  | ||||||
|  */ |  */ | ||||||
| @NoArgsConstructor | @NoArgsConstructor | ||||||
| @AllArgsConstructor | @AllArgsConstructor | ||||||
|  |  | ||||||
|  | @ -97,7 +97,7 @@ public class BonusSettleFirstPurchaseHandle extends BonusSettleHandle { | ||||||
|         // 死点 或 停算收益 或 顾客 没有奖金 |         // 死点 或 停算收益 或 顾客 没有奖金 | ||||||
|         if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |         if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                 || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                 || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|             // 会员不满足计算奖金条件,跳过 |             // 会员不满足计算奖金条件,跳过 | ||||||
|             return null; |             return null; | ||||||
|         } |         } | ||||||
|  | @ -349,7 +349,7 @@ public class BonusSettleFirstPurchaseHandle extends BonusSettleHandle { | ||||||
|                     if (null == targetMemberSettleExt |                     if (null == targetMemberSettleExt | ||||||
|                             || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                             || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                             || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                             || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                             || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                             || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                         // 会员不满足计算奖金条件,跳过 |                         // 会员不满足计算奖金条件,跳过 | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     } | ||||||
|  | @ -378,7 +378,7 @@ public class BonusSettleFirstPurchaseHandle extends BonusSettleHandle { | ||||||
|                         if (targetMemberSettleExt == null |                         if (targetMemberSettleExt == null | ||||||
|                                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                                 || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                                 || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                             // 会员不满足计算奖金条件,跳过 |                             // 会员不满足计算奖金条件,跳过 | ||||||
|                             continue; |                             continue; | ||||||
|                         } |                         } | ||||||
|  | @ -438,8 +438,7 @@ public class BonusSettleFirstPurchaseHandle extends BonusSettleHandle { | ||||||
|             if (null == targetMemberSettleExt |             if (null == targetMemberSettleExt | ||||||
|                     || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                     || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                     || EGrade.START_UP.getValue() == targetMemberSettleExt.getGradeValue() |                     || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                     || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |  | ||||||
|                 // 会员不满足计算奖金条件,跳过 |                 // 会员不满足计算奖金条件,跳过 | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  | @ -604,7 +603,7 @@ public class BonusSettleFirstPurchaseHandle extends BonusSettleHandle { | ||||||
|             pkMember = targetMemberSettleExt.getPkParent(); |             pkMember = targetMemberSettleExt.getPkParent(); | ||||||
|             if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |             if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                     || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                     || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                 // 会员状态不正常 或者 停算收益 或 顾客等级 直接跳过 |                 // 会员状态不正常 或者 停算收益 或 顾客等级 直接跳过 | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  | @ -812,7 +811,7 @@ public class BonusSettleFirstPurchaseHandle extends BonusSettleHandle { | ||||||
|                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                 || ERegistrationAuthority.SERVICE.getValue() != targetMemberSettleExt.getRegisterAuthority() |                 || ERegistrationAuthority.SERVICE.getValue() != targetMemberSettleExt.getRegisterAuthority() | ||||||
|                 || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                 || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|             // 非正常会员、停算收益、不是服务中心,都不进行处理 |             // 非正常会员、停算收益、不是服务中心,都不进行处理 | ||||||
|             return null; |             return null; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -121,7 +121,7 @@ public class BonusSettleNewExpandHandle extends BonusSettleHandle { | ||||||
|                     if (null == targetMemberSettleExt |                     if (null == targetMemberSettleExt | ||||||
|                             || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                             || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                             || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                             || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                             || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                             || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                         // 会员不满足计算奖金条件,跳过 |                         // 会员不满足计算奖金条件,跳过 | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     } | ||||||
|  | @ -151,7 +151,7 @@ public class BonusSettleNewExpandHandle extends BonusSettleHandle { | ||||||
|                         if (targetMemberSettleExt == null |                         if (targetMemberSettleExt == null | ||||||
|                                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                                 || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                                 || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                             // 会员不满足计算奖金条件,跳过 |                             // 会员不满足计算奖金条件,跳过 | ||||||
|                             continue; |                             continue; | ||||||
|                         } |                         } | ||||||
|  | @ -189,8 +189,7 @@ public class BonusSettleNewExpandHandle extends BonusSettleHandle { | ||||||
|             if (targetMemberSettleExt == null |             if (targetMemberSettleExt == null | ||||||
|                     || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                     || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                     || EGrade.START_UP.getValue() == targetMemberSettleExt.getGradeValue() |                     || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                     || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |  | ||||||
|                 // 会员不满足计算奖金条件,跳过 |                 // 会员不满足计算奖金条件,跳过 | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ import cn.hutool.core.collection.CollectionUtil; | ||||||
| import com.hzs.bonus.bonus.vo.BonusRecordDetailVO; | import com.hzs.bonus.bonus.vo.BonusRecordDetailVO; | ||||||
| import com.hzs.common.core.constant.CountryConstants; | import com.hzs.common.core.constant.CountryConstants; | ||||||
| import com.hzs.common.core.constant.MagicNumberConstants; | import com.hzs.common.core.constant.MagicNumberConstants; | ||||||
|  | import com.hzs.common.core.constant.SysConstants; | ||||||
| import com.hzs.common.core.constant.msg.BonusMsgConstants; | import com.hzs.common.core.constant.msg.BonusMsgConstants; | ||||||
| import com.hzs.common.core.enums.*; | import com.hzs.common.core.enums.*; | ||||||
| import com.hzs.common.core.utils.ComputeUtil; | import com.hzs.common.core.utils.ComputeUtil; | ||||||
|  | @ -59,7 +60,7 @@ public class BonusSettlePurchaseHandle extends BonusSettleHandle { | ||||||
|             // 死点 停算 顾客 没有奖金 |             // 死点 停算 顾客 没有奖金 | ||||||
|             if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |             if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                     || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                     || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                 // 会员不满足计算奖金条件,跳过 |                 // 会员不满足计算奖金条件,跳过 | ||||||
|                 pkParent = targetMemberSettleExt.getPkParent(); |                 pkParent = targetMemberSettleExt.getPkParent(); | ||||||
|                 continue; |                 continue; | ||||||
|  | @ -159,31 +160,31 @@ public class BonusSettlePurchaseHandle extends BonusSettleHandle { | ||||||
|         return cuMemberBonusExpandList; |         return cuMemberBonusExpandList; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** | //    /** | ||||||
|      * 秒接复购量奖 | //     * 秒接复购量奖 | ||||||
|      * | //     * | ||||||
|      * @return: List<CuMemberBonusExpand> | //     * @return: List<CuMemberBonusExpand> | ||||||
|      */ | //     */ | ||||||
|     protected List<CuMemberBonusExpand> calculateRepurchaseExpandSecondBonus(Map<Long, CuMemberRiskControl> riskControlMap, String settleTableName, Map<Long, CuMemberSettleExt> cuMemberSettleExtMap, BonusConfigDTO bonusConfigDTO, | //    protected List<CuMemberBonusExpand> calculateRepurchaseExpandSecondBonus(Map<Long, CuMemberRiskControl> riskControlMap, String settleTableName, Map<Long, CuMemberSettleExt> cuMemberSettleExtMap, BonusConfigDTO bonusConfigDTO, | ||||||
|                                                                              Map<String, String> systemConfigMap, Integer period, Map<Long, CuMemberBonus> weekMemberBonusMap, | //                                                                             Map<String, String> systemConfigMap, Integer period, Map<Long, CuMemberBonus> weekMemberBonusMap, | ||||||
|                                                                              Map<Long, CuMemberBonus> cuMemberBonusMap, SaOrderExt saOrderExt, | //                                                                             Map<Long, CuMemberBonus> cuMemberBonusMap, SaOrderExt saOrderExt, | ||||||
|                                                                              List<CuMemberSettleExt> cuMemberSettleExtList, String settleDateStr, BigDecimal addTouch, BigDecimal expandRatio, Integer expandNumber) { | //                                                                             List<CuMemberSettleExt> cuMemberSettleExtList, String settleDateStr, BigDecimal addTouch, BigDecimal expandRatio, Integer expandNumber) { | ||||||
|         // 复购订单,计算复购级差,复购拓展 | //        // 复购订单,计算复购级差,复购拓展 | ||||||
|         return calculateRepurchaseExpandBonusOne(riskControlMap, settleTableName, cuMemberSettleExtMap, bonusConfigDTO, systemConfigMap, period, weekMemberBonusMap, cuMemberBonusMap, | //        return calculateRepurchaseExpandBonusOne(riskControlMap, settleTableName, cuMemberSettleExtMap, bonusConfigDTO, systemConfigMap, period, weekMemberBonusMap, cuMemberBonusMap, | ||||||
|                 saOrderExt, cuMemberSettleExtList, addTouch, expandRatio, expandNumber); | //                saOrderExt, cuMemberSettleExtList, addTouch, expandRatio, expandNumber); | ||||||
|     } | //    } | ||||||
| 
 | // | ||||||
|     /** | //    /** | ||||||
|      * 秒接复购量奖 | //     * 秒接复购量奖 | ||||||
|      * | //     * | ||||||
|      * @return: List<CuMemberBonusExpand> | //     * @return: List<CuMemberBonusExpand> | ||||||
|      */ | //     */ | ||||||
|     protected List<CuMemberBonusPush> calculateRepurchasePushSecondBonus(String settleTableName, Map<Long, CuMemberSettleExt> cuMemberSettleExtMap, BonusConfigDTO bonusConfigDTO, Integer period, | //    protected List<CuMemberBonusPush> calculateRepurchasePushSecondBonus(String settleTableName, Map<Long, CuMemberSettleExt> cuMemberSettleExtMap, BonusConfigDTO bonusConfigDTO, Integer period, | ||||||
|                                                                          Map<Long, CuMemberBonus> cuMemberBonusMap, SaOrderExt saOrderExt, | //                                                                         Map<Long, CuMemberBonus> cuMemberBonusMap, SaOrderExt saOrderExt, | ||||||
|                                                                          List<CuMemberSettleExt> cuMemberSettleExtList, String settleDateStr) { | //                                                                         List<CuMemberSettleExt> cuMemberSettleExtList, String settleDateStr) { | ||||||
|         // 根据订单获取轮次,要回写 | //        // 根据订单获取轮次,要回写 | ||||||
|         return calculateRepurchasePushBonusOne(cuMemberSettleExtMap, bonusConfigDTO, null, period, cuMemberBonusMap, saOrderExt); | //        return calculateRepurchasePushBonusOne(cuMemberSettleExtMap, bonusConfigDTO, null, period, cuMemberBonusMap, saOrderExt); | ||||||
|     } | //    } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 计算复购量奖(拓展收益) |      * 计算复购量奖(拓展收益) | ||||||
|  | @ -234,7 +235,7 @@ public class BonusSettlePurchaseHandle extends BonusSettleHandle { | ||||||
|                     if (null == targetMemberSettleExt |                     if (null == targetMemberSettleExt | ||||||
|                             || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                             || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                             || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                             || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                             || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                             || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                         // 会员不满足计算奖金条件,跳过 |                         // 会员不满足计算奖金条件,跳过 | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     } | ||||||
|  | @ -264,7 +265,7 @@ public class BonusSettlePurchaseHandle extends BonusSettleHandle { | ||||||
|                         if (null == targetMemberSettleExt |                         if (null == targetMemberSettleExt | ||||||
|                                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                                 || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                                 || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                                 || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                             // 会员不满足计算奖金条件,跳过 |                             // 会员不满足计算奖金条件,跳过 | ||||||
|                             continue; |                             continue; | ||||||
|                         } |                         } | ||||||
|  | @ -300,8 +301,7 @@ public class BonusSettlePurchaseHandle extends BonusSettleHandle { | ||||||
|             if (null == targetMemberSettleExt |             if (null == targetMemberSettleExt | ||||||
|                     || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                     || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                     || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                     || EGrade.START_UP.getValue() == targetMemberSettleExt.getGradeValue() |                     || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                     || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |  | ||||||
|                 // 会员不满足计算奖金条件,跳过 |                 // 会员不满足计算奖金条件,跳过 | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  | @ -928,7 +928,7 @@ public class BonusSettlePurchaseHandle extends BonusSettleHandle { | ||||||
|                                        BigDecimal beforeBonusCal) { |                                        BigDecimal beforeBonusCal) { | ||||||
|         if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |         if (ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                 || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                 || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |                 || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|             // 死点 停算 顾客 没有奖金,跳过 |             // 死点 停算 顾客 没有奖金,跳过 | ||||||
|             return null; |             return null; | ||||||
|         } else { |         } else { | ||||||
|  |  | ||||||
|  | @ -22,6 +22,7 @@ import com.hzs.bonus.swing.service.ICuMemberSwingNetLogService; | ||||||
| import com.hzs.common.core.config.BdConfig; | import com.hzs.common.core.config.BdConfig; | ||||||
| import com.hzs.common.core.constant.BonusFieldConstants; | import com.hzs.common.core.constant.BonusFieldConstants; | ||||||
| import com.hzs.common.core.constant.CountryConstants; | import com.hzs.common.core.constant.CountryConstants; | ||||||
|  | import com.hzs.common.core.constant.SysConstants; | ||||||
| import com.hzs.common.core.constant.TableNameConstants; | import com.hzs.common.core.constant.TableNameConstants; | ||||||
| import com.hzs.common.core.enums.*; | import com.hzs.common.core.enums.*; | ||||||
| import com.hzs.common.core.utils.ComputeUtil; | import com.hzs.common.core.utils.ComputeUtil; | ||||||
|  | @ -205,8 +206,7 @@ public class BonusSettleServiceImpl implements IBonusSettleService { | ||||||
|                 if (null == targetMemberSettleExt |                 if (null == targetMemberSettleExt | ||||||
|                         || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                         || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                         || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                         || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                         || EGrade.START_UP.getValue() == targetMemberSettleExt.getGradeValue() |                         || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                         || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |  | ||||||
|                     // 会员不满足计算条件,跳过 |                     // 会员不满足计算条件,跳过 | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|  | @ -315,8 +315,7 @@ public class BonusSettleServiceImpl implements IBonusSettleService { | ||||||
|                 if (null == targetMemberSettleExt |                 if (null == targetMemberSettleExt | ||||||
|                         || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() |                         || ECategory.NORMAL.getValue() != targetMemberSettleExt.getCategory() | ||||||
|                         || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() |                         || EAccountStatus.STOP_INCOME.getValue() == targetMemberSettleExt.getAccountStatus() | ||||||
|                         || EGrade.START_UP.getValue() == targetMemberSettleExt.getGradeValue() |                         || !SysConstants.NOT_BONUS_GRADE.contains(targetMemberSettleExt.getGradeValue())) { | ||||||
|                         || EGrade.HAI_FAN.getValue() == targetMemberSettleExt.getGradeValue()) { |  | ||||||
|                     // 会员不满足计算奖金条件,跳过 |                     // 会员不满足计算奖金条件,跳过 | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|  | @ -273,6 +273,16 @@ public class MemberServiceProvider implements IMemberServiceApi { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public R<Boolean> handleZeroMember(CuMember cuMember, SaOrderExt saOrder) { | ||||||
|  |         try { | ||||||
|  |             return R.ok(iCuMemberBusinessService.handleZeroMember(cuMember, saOrder)); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             log.error("handleZeroMember error", e); | ||||||
|  |             return R.fail(e.getMessage()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public R<CuMember> createMemberIdAndCode(CuMember cuMember, Boolean isHaiFun) { |     public R<CuMember> createMemberIdAndCode(CuMember cuMember, Boolean isHaiFun) { | ||||||
|         return R.ok(iCuMemberService.createMemberIdAndCode(cuMember, isHaiFun)); |         return R.ok(iCuMemberService.createMemberIdAndCode(cuMember, isHaiFun)); | ||||||
|  |  | ||||||
|  | @ -48,6 +48,15 @@ public interface ICuMemberBusinessService { | ||||||
|      */ |      */ | ||||||
|     Boolean saveMember(CuMember cuMember, SaOrder saOrder); |     Boolean saveMember(CuMember cuMember, SaOrder saOrder); | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 0元会员订单处理 | ||||||
|  |      * | ||||||
|  |      * @param cuMember | ||||||
|  |      * @param saOrder | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     Boolean handleZeroMember(CuMember cuMember, SaOrder saOrder); | ||||||
|  | 
 | ||||||
|     /* |     /* | ||||||
|      *  在线支付修改记录 |      *  在线支付修改记录 | ||||||
|      **/ |      **/ | ||||||
|  |  | ||||||
|  | @ -131,7 +131,6 @@ public class CuMemberBusinessServiceImpl implements ICuMemberBusinessService { | ||||||
|     ITOnlinePaymentServiceApi itOnlinePaymentServiceApi; |     ITOnlinePaymentServiceApi itOnlinePaymentServiceApi; | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Transactional(rollbackFor = Exception.class) |  | ||||||
|     public void updateCuMember(CuMember cuMember) { |     public void updateCuMember(CuMember cuMember) { | ||||||
|         redisService.lockKeyMany(CacheConstants.UPD_MEMBER + cuMember.getMemberCode()); |         redisService.lockKeyMany(CacheConstants.UPD_MEMBER + cuMember.getMemberCode()); | ||||||
|         try { |         try { | ||||||
|  | @ -330,6 +329,25 @@ public class CuMemberBusinessServiceImpl implements ICuMemberBusinessService { | ||||||
|         return Boolean.TRUE; |         return Boolean.TRUE; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     @Transactional(rollbackFor = Exception.class) | ||||||
|  |     public Boolean handleZeroMember(CuMember cuMember, SaOrder saOrder) { | ||||||
|  |         // 更新会员信息 | ||||||
|  |         updateCuMember(cuMember); | ||||||
|  |         // 会员升级记录 | ||||||
|  |         saveMemberRecords(cuMember, saOrder); | ||||||
|  | 
 | ||||||
|  |         // 代表在线支付,在线支付先插入一条充值信息 | ||||||
|  |         CuMemberAccountExt cuMemberAccountExt = insertMemberRecharge(saOrder); | ||||||
|  |         // 扣款信息 | ||||||
|  |         insertMemberTrade(saOrder, cuMemberAccountExt); | ||||||
|  | 
 | ||||||
|  |         // 解锁 安置位置 | ||||||
|  |         redisService.unlock(CacheConstants.POSITION + cuMember.getPkPlaceParent() + cuMember.getPlaceDept()); | ||||||
|  |         // 扣除可用量 | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Transactional(rollbackFor = Exception.class) |     @Transactional(rollbackFor = Exception.class) | ||||||
|     public Boolean saveMemberOnLineTrade(CuMember cuMember, SaOrder saOrder, CuMemberAccountExt cuMemberAccountExt) { |     public Boolean saveMemberOnLineTrade(CuMember cuMember, SaOrder saOrder, CuMemberAccountExt cuMemberAccountExt) { | ||||||
|  |  | ||||||
|  | @ -1,22 +1,23 @@ | ||||||
| package com.hzs.member.share.controller.api; | package com.hzs.member.share.controller.api; | ||||||
| 
 | 
 | ||||||
| import cn.hutool.core.codec.Base64Decoder; | import cn.hutool.core.codec.Base64Decoder; | ||||||
|  | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
| import com.hzs.common.core.annotation.RepeatSubmitSimple; | import com.hzs.common.core.annotation.RepeatSubmitSimple; | ||||||
| import com.hzs.common.core.config.BdConfig; | import com.hzs.common.core.config.BdConfig; | ||||||
| import com.hzs.common.core.constant.CacheConstants; | import com.hzs.common.core.constant.CacheConstants; | ||||||
| import com.hzs.common.core.constant.CountryConstants; | import com.hzs.common.core.constant.CountryConstants; | ||||||
|  | import com.hzs.common.core.constant.msg.MemberMsgConstants; | ||||||
| import com.hzs.common.core.domain.R; | import com.hzs.common.core.domain.R; | ||||||
| import com.hzs.common.core.enums.ECategory; | import com.hzs.common.core.enums.*; | ||||||
| import com.hzs.common.core.enums.EDelFlag; |  | ||||||
| import com.hzs.common.core.enums.EShareType; |  | ||||||
| import com.hzs.common.core.enums.ESystemConfig; |  | ||||||
| import com.hzs.common.core.service.RedisService; | import com.hzs.common.core.service.RedisService; | ||||||
| import com.hzs.common.core.utils.sign.Base64Util; | import com.hzs.common.core.utils.sign.Base64Util; | ||||||
| import com.hzs.common.core.utils.uuid.IdUtils; | import com.hzs.common.core.utils.uuid.IdUtils; | ||||||
| import com.hzs.common.core.web.domain.AjaxResult; | import com.hzs.common.core.web.domain.AjaxResult; | ||||||
| import com.hzs.common.domain.member.base.CuMember; | import com.hzs.common.domain.member.base.CuMember; | ||||||
|  | import com.hzs.common.domain.member.ext.CuMemberExt; | ||||||
| import com.hzs.common.security.utils.SecurityUtils; | import com.hzs.common.security.utils.SecurityUtils; | ||||||
|  | import com.hzs.common.util.TransactionUtils; | ||||||
| import com.hzs.member.base.service.ICuMemberService; | import com.hzs.member.base.service.ICuMemberService; | ||||||
| import com.hzs.member.base.vo.MemberShare; | import com.hzs.member.base.vo.MemberShare; | ||||||
| import com.hzs.member.share.param.ShareRegisterParam; | import com.hzs.member.share.param.ShareRegisterParam; | ||||||
|  | @ -30,6 +31,7 @@ import org.springframework.web.bind.annotation.*; | ||||||
| 
 | 
 | ||||||
| import javax.validation.Valid; | import javax.validation.Valid; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
|  | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| import java.util.concurrent.TimeUnit; | import java.util.concurrent.TimeUnit; | ||||||
| 
 | 
 | ||||||
|  | @ -54,12 +56,17 @@ public class ApiShareController { | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 获取188分享码(H5) |      * 获取188分享码(H5) | ||||||
|      * |  | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/fans-code-h5") |     @GetMapping("/fans-code-h5") | ||||||
|     public AjaxResult fansCodeH5() { |     public AjaxResult fansCodeH5() { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SecurityUtils.getUserId(); | ||||||
|  | 
 | ||||||
|  |         // 0元会员不涌进行分享 | ||||||
|  |         CuMemberExt cuMemberExt = iCuMemberService.getMemberById(userId); | ||||||
|  |         if (null == cuMemberExt.getPkPlaceParent()) { | ||||||
|  |             return AjaxResult.error("当前会员无权进行个人推广"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         // 188注册分享人就是自己 |         // 188注册分享人就是自己 | ||||||
|         R<String> resultR = iShareServiceApi.queryShareCode(ShareServiceDTO.builder() |         R<String> resultR = iShareServiceApi.queryShareCode(ShareServiceDTO.builder() | ||||||
|                 .eShareType(EShareType.FANS) |                 .eShareType(EShareType.FANS) | ||||||
|  | @ -85,7 +92,6 @@ public class ApiShareController { | ||||||
|      * 分享查询推荐人编号 -- 不需要登录 |      * 分享查询推荐人编号 -- 不需要登录 | ||||||
|      * |      * | ||||||
|      * @param parentCode 推荐人(加密) |      * @param parentCode 推荐人(加密) | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/find-share-code/{parentCode}") |     @GetMapping("/find-share-code/{parentCode}") | ||||||
|     public AjaxResult findShareCode(@PathVariable("parentCode") String parentCode) { |     public AjaxResult findShareCode(@PathVariable("parentCode") String parentCode) { | ||||||
|  | @ -100,7 +106,6 @@ public class ApiShareController { | ||||||
|      * 分享注册 -- 不需要登录 |      * 分享注册 -- 不需要登录 | ||||||
|      * |      * | ||||||
|      * @param registerParam 分享注册入参 |      * @param registerParam 分享注册入参 | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     @RepeatSubmitSimple |     @RepeatSubmitSimple | ||||||
|     @PostMapping("/share-register") |     @PostMapping("/share-register") | ||||||
|  | @ -116,16 +121,21 @@ public class ApiShareController { | ||||||
|         } |         } | ||||||
|         registerParam.setParentMember(parentMember); |         registerParam.setParentMember(parentMember); | ||||||
| 
 | 
 | ||||||
|         // 手机号注册次数 |  | ||||||
|         String value = iSystemConfigServiceApi.getBonusSystemConfig(CountryConstants.CHINA_COUNTRY, ESystemConfig.REGISTER_NUMBER.getKey()).getData(); |         String value = iSystemConfigServiceApi.getBonusSystemConfig(CountryConstants.CHINA_COUNTRY, ESystemConfig.REGISTER_NUMBER.getKey()).getData(); | ||||||
|         int phoneCount = iCuMemberService.count(Wrappers.<CuMember>lambdaQuery() |         List<CuMember> memberList = iCuMemberService.list(Wrappers.<CuMember>lambdaQuery() | ||||||
|                 .eq(CuMember::getPhone, registerParam.getPhone()) |                 .eq(CuMember::getPhone, registerParam.getPhone()) | ||||||
|                 .eq(CuMember::getDelFlag, EDelFlag.UN_DELETE.getValue()) |                 .eq(CuMember::getDelFlag, EDelFlag.UN_DELETE.getValue()) | ||||||
|                 .eq(CuMember::getCategory, ECategory.NORMAL.getValue()) |                 .eq(CuMember::getCategory, ECategory.NORMAL.getValue()) | ||||||
|         ); |         ); | ||||||
|         if (phoneCount > Integer.parseInt(value)) { |         // 手机号注册次数 | ||||||
|             return AjaxResult.error("会员信息已存在"); |         if (memberList.size() >= Integer.parseInt(value)) { | ||||||
|  |             return AjaxResult.error(MemberMsgConstants.SYSTEM_REGISTER_COUNT); | ||||||
|         } |         } | ||||||
|  |         // 一个手机号只能有一个姓名 | ||||||
|  |         if (!memberList.stream().allMatch(cuMember -> registerParam.getMemberName().equals(cuMember.getMemberName()))) { | ||||||
|  |             return AjaxResult.error(MemberMsgConstants.PHONE_ALREADY_REGISTER); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|         CuMember newCuMember = iCuMemberService.shareRegisterMember(registerParam); |         CuMember newCuMember = iCuMemberService.shareRegisterMember(registerParam); | ||||||
|         if (null != newCuMember) { |         if (null != newCuMember) { | ||||||
|  |  | ||||||
|  | @ -35,8 +35,6 @@ import com.hzs.system.base.ICountryServiceApi; | ||||||
| import com.hzs.system.base.ISystemConfigServiceApi; | import com.hzs.system.base.ISystemConfigServiceApi; | ||||||
| import com.hzs.system.config.IGradeServiceApi; | import com.hzs.system.config.IGradeServiceApi; | ||||||
| import com.hzs.system.config.dto.GradeDTO; | import com.hzs.system.config.dto.GradeDTO; | ||||||
| import com.hzs.system.sys.IUserServiceApi; |  | ||||||
| import com.hzs.system.sys.dto.UserAuthorityDTO; |  | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.apache.dubbo.config.annotation.DubboReference; | import org.apache.dubbo.config.annotation.DubboReference; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | @ -69,20 +67,11 @@ public class ApiMemberStructureController extends BaseController { | ||||||
|     @DubboReference |     @DubboReference | ||||||
|     IGradeServiceApi iGradeServiceApi; |     IGradeServiceApi iGradeServiceApi; | ||||||
|     @DubboReference |     @DubboReference | ||||||
|     IUserServiceApi iUserServiceApi; |  | ||||||
|     @DubboReference |  | ||||||
|     ICountryServiceApi iCountryServiceApi; |     ICountryServiceApi iCountryServiceApi; | ||||||
|     @DubboReference |     @DubboReference | ||||||
|     ISystemConfigServiceApi systemConfigServiceApi; |     ISystemConfigServiceApi systemConfigServiceApi; | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * @param build |  | ||||||
|      * @return |  | ||||||
|      */ |  | ||||||
|     public List<Tree<String>> setTreeList(List<Tree<String>> build, Integer numberOfPlies, Map<Integer, BdCountry> allCountryData) { |     public List<Tree<String>> setTreeList(List<Tree<String>> build, Integer numberOfPlies, Map<Integer, BdCountry> allCountryData) { | ||||||
| //        Integer pkCountry = SecurityUtils.getPkCountry(); |  | ||||||
| //        String nationalFlag1 = allCountryData.get(pkCountry).getNationalFlag1(); |  | ||||||
| //        String nationalFlag2 = allCountryData.get(pkCountry).getNationalFlag2(); |  | ||||||
|         for (Tree<String> stringTree : build) { |         for (Tree<String> stringTree : build) { | ||||||
|             Integer level = (Integer) stringTree.get("level"); |             Integer level = (Integer) stringTree.get("level"); | ||||||
|             if (level < (numberOfPlies - 1)) { |             if (level < (numberOfPlies - 1)) { | ||||||
|  | @ -280,9 +269,6 @@ public class ApiMemberStructureController extends BaseController { | ||||||
|     public AjaxResult azFramework() { |     public AjaxResult azFramework() { | ||||||
|         Integer level = 1; |         Integer level = 1; | ||||||
|         List<Tree<String>> result = null; |         List<Tree<String>> result = null; | ||||||
|         // 体系 |  | ||||||
|         UserAuthorityDTO userAuthorityDTO = iUserServiceApi.getUserAuthority(SecurityUtils.getUserId()).getData(); |  | ||||||
|         List<Integer> vertexIdList = userAuthorityDTO.getVertexIdList(); |  | ||||||
|         Date date = new Date(); |         Date date = new Date(); | ||||||
|         String time = DateUtils.parseDateToStr(DateUtils.YYYY_MM_DD, date); |         String time = DateUtils.parseDateToStr(DateUtils.YYYY_MM_DD, date); | ||||||
|         LocalDate beforeLocalDate = DateUtils.getStringToLocalDate(time).minus(1, ChronoUnit.DAYS); |         LocalDate beforeLocalDate = DateUtils.getStringToLocalDate(time).minus(1, ChronoUnit.DAYS); | ||||||
|  | @ -293,68 +279,7 @@ public class ApiMemberStructureController extends BaseController { | ||||||
|         if (csPeriod != null) { |         if (csPeriod != null) { | ||||||
|             period = csPeriod.getPkId(); |             period = csPeriod.getPkId(); | ||||||
|         } |         } | ||||||
|         // 查询当天 (秒结) | 
 | ||||||
| //        if (settleDate != null |  | ||||||
| //                && DateUtils.parseDateToFormat(DateUtils.YYYY_MM_DD, settleDate).equals(DateUtils.parseDateToFormat(DateUtils.YYYY_MM_DD, new Date()))) { |  | ||||||
|         if (1 == 2) { |  | ||||||
|             // 会员结算秒结表 |  | ||||||
|             String settleTableName = TableNameConstants.CU_MEMBER_SECOND + period; |  | ||||||
|             // 查询所有用户表数据 id |  | ||||||
|             // 查询秒结 表 如果 秒结表 没有则去 历史表 |  | ||||||
|             Integer tableNumber = iCuMemberTreeService.queryExistOracleTable(settleTableName); |  | ||||||
|             if (tableNumber != null && tableNumber == 1) { |  | ||||||
|                 List<CuMemberSettleExt> cuMemberSettleExts; |  | ||||||
|                 // 查询今日会员表是否有值 |  | ||||||
|                 Long treeMemberCount = iCuMemberTreeService.selectByselectByTreeMemberCount(settleTableName, pkMember); |  | ||||||
|                 if (treeMemberCount > 0) { |  | ||||||
|                     //表格存在 |  | ||||||
|                     cuMemberSettleExts = iCuMemberTreeService.selectByTreeMemberList(pkMember, settleTableName, level, vertexIdList); |  | ||||||
|                 } else { |  | ||||||
|                     DateTime dateTime = DateUtil.offsetDay(DateUtils.currentDate(), -1); |  | ||||||
|                     time = DateUtils.parseDateToStr(DateUtils.YYYY_MM_DD, dateTime); |  | ||||||
|                     csPeriod = iCuMemberSettlePeriodService.getCuMemberSettlePeriodByDate(time); |  | ||||||
|                     if (csPeriod != null) { |  | ||||||
|                         period = csPeriod.getPkId(); |  | ||||||
|                     } |  | ||||||
|                     settleTableName = TableNameConstants.CU_MEMBER_SETTLE + period; |  | ||||||
|                     cuMemberSettleExts = iCuMemberTreeService.selectByTreeMemberList(pkMember, settleTableName, level, vertexIdList); |  | ||||||
|                 } |  | ||||||
|                 // 查询顶点 |  | ||||||
|                 CuMemberSettleExt memberSettleExt = iCuMemberTreeService.queryCuMemberTreeByPkMemberTable(settleTableName, pkMember); |  | ||||||
|                 if (MemberConstants.GJ30720200CODE.equals(memberSettleExt.getParentMemberCode())) { |  | ||||||
|                     memberSettleExt.setParentMemberCode(memberSettleExt.getMemberCode()); |  | ||||||
|                 } |  | ||||||
|                 memberSettleExt.setLevel(0); |  | ||||||
|                 // 添加自身 |  | ||||||
|                 cuMemberSettleExts.add(memberSettleExt); |  | ||||||
|                 List<Tree<String>> build = iCuMemberService.systemAzSetListTree(cuMemberSettleExts, memberSettleExt); |  | ||||||
|                 // 安置架构 无点位 追加空点位 |  | ||||||
|                 R<Map<Integer, BdCountry>> allCountryMap = iCountryServiceApi.getAllCountryMap(); |  | ||||||
|                 Map<Integer, BdCountry> allCountryData = allCountryMap.getData(); |  | ||||||
|                 result = setTreeList(build, level, allCountryData); |  | ||||||
|             } else { |  | ||||||
|                 // 查询表格是否存在 |  | ||||||
|                 tableNumber = iCuMemberTreeService.queryExistOracleTable(settleTableName); |  | ||||||
|                 if (tableNumber == null) { |  | ||||||
|                     settleTableName = null; |  | ||||||
|                 } |  | ||||||
|                 // 查询顶点 |  | ||||||
|                 CuMemberSettleExt memberSettleExt = iCuMemberTreeService.queryCuMemberTreeByPkMemberTable(settleTableName, pkMember); |  | ||||||
|                 if (MemberConstants.GJ30720200CODE.equals(memberSettleExt.getParentMemberCode())) { |  | ||||||
|                     memberSettleExt.setParentMemberCode(memberSettleExt.getMemberCode()); |  | ||||||
|                 } |  | ||||||
|                 memberSettleExt.setLevel(0); |  | ||||||
|                 //查询下级 |  | ||||||
|                 List<CuMemberSettleExt> list = iCuMemberTreeService.queryCuMemberTreePlaceParentHistoryTable(settleTableName, pkMember, new ArrayList<>(), level); |  | ||||||
|                 // 无法查询到自身 所有单独查询自身并且添加 |  | ||||||
|                 list.add(memberSettleExt); |  | ||||||
|                 List<Tree<String>> build = iCuMemberService.systemAzSetListTree(list, memberSettleExt); |  | ||||||
|                 // 安置架构 无点位 追加空点位 |  | ||||||
|                 R<Map<Integer, BdCountry>> allCountryMap = iCountryServiceApi.getAllCountryMap(); |  | ||||||
|                 Map<Integer, BdCountry> allCountryData = allCountryMap.getData(); |  | ||||||
|                 result = setTreeList(build, level, allCountryData); |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|         // 查询 历史 |         // 查询 历史 | ||||||
|         String settleTableName = TableNameConstants.CU_MEMBER_SETTLE + period; |         String settleTableName = TableNameConstants.CU_MEMBER_SETTLE + period; | ||||||
|         Integer tableNumber = iCuMemberTreeService.queryExistOracleTable(settleTableName); |         Integer tableNumber = iCuMemberTreeService.queryExistOracleTable(settleTableName); | ||||||
|  | @ -362,6 +287,10 @@ public class ApiMemberStructureController extends BaseController { | ||||||
|             // 表示表格存在 |             // 表示表格存在 | ||||||
|             // 查询顶点 |             // 查询顶点 | ||||||
|             CuMemberSettleExt memberSettleExt = iCuMemberTreeService.queryCuMemberTreeByPkMemberTable(settleTableName, pkMember); |             CuMemberSettleExt memberSettleExt = iCuMemberTreeService.queryCuMemberTreeByPkMemberTable(settleTableName, pkMember); | ||||||
|  |             if (null == memberSettleExt.getPkPlaceParent()) { | ||||||
|  |                 // 0元会员 | ||||||
|  |                 return AjaxResult.success(); | ||||||
|  |             } | ||||||
|             if (MemberConstants.GJ30720200CODE.equals(memberSettleExt.getParentMemberCode())) { |             if (MemberConstants.GJ30720200CODE.equals(memberSettleExt.getParentMemberCode())) { | ||||||
|                 memberSettleExt.setParentMemberCode(memberSettleExt.getMemberCode()); |                 memberSettleExt.setParentMemberCode(memberSettleExt.getMemberCode()); | ||||||
|             } |             } | ||||||
|  | @ -376,7 +305,7 @@ public class ApiMemberStructureController extends BaseController { | ||||||
|             Map<Integer, BdCountry> allCountryData = allCountryMap.getData(); |             Map<Integer, BdCountry> allCountryData = allCountryMap.getData(); | ||||||
|             result = setTreeList(build, level, allCountryData); |             result = setTreeList(build, level, allCountryData); | ||||||
|         } |         } | ||||||
|         } | 
 | ||||||
|         BdBonusExpand bdBonusExpand = systemConfigServiceApi.getBdBonusExpand().getData(); |         BdBonusExpand bdBonusExpand = systemConfigServiceApi.getBdBonusExpand().getData(); | ||||||
|         assert result != null; |         assert result != null; | ||||||
|         String leftFirstSurplusStr = result.get(0).get("leftFirstSurplus").toString(); |         String leftFirstSurplusStr = result.get(0).get("leftFirstSurplus").toString(); | ||||||
|  |  | ||||||
|  | @ -109,7 +109,7 @@ public interface IActivityService { | ||||||
|      * @param recommendParam |      * @param recommendParam | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     Boolean onLinePetition(AcRecommendParam recommendParam); |     String onLinePetition(AcRecommendParam recommendParam); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 活动签呈审核通过 |      * 活动签呈审核通过 | ||||||
|  |  | ||||||
|  | @ -631,7 +631,8 @@ public class ActivityServiceImpl implements IActivityService { | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public Boolean onLinePetition(AcRecommendParam recommendParam) { |     public String onLinePetition(AcRecommendParam recommendParam) { | ||||||
|  |         log.info("旅游活动新增参数{}",JSONUtil.toJsonStr(recommendParam)); | ||||||
|         //业务单号 |         //业务单号 | ||||||
|         String code = CommonUtil.createSerialNumber(EOrderPrefix.ACTIVITY_CODE.getValue()); |         String code = CommonUtil.createSerialNumber(EOrderPrefix.ACTIVITY_CODE.getValue()); | ||||||
|         EApprovalBusiness approvalBusiness = null; |         EApprovalBusiness approvalBusiness = null; | ||||||
|  | @ -643,7 +644,40 @@ public class ActivityServiceImpl implements IActivityService { | ||||||
|             approvalBusiness = EApprovalBusiness.TOURISM_DELETE; |             approvalBusiness = EApprovalBusiness.TOURISM_DELETE; | ||||||
|         } |         } | ||||||
|         recommendParam.getActivityParam().setBusinessCode(code); |         recommendParam.getActivityParam().setBusinessCode(code); | ||||||
|         Boolean b = submitApproval(recommendParam, approvalBusiness); |         Integer controlType = recommendParam.getControlType(); | ||||||
|  |         if (controlType.equals(EControlType.SAVE.getValue())) { | ||||||
|  |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|  |             activityParam.setPkCountry(recommendParam.getPkCountry()); | ||||||
|  |             activityParam.setPkCreator(recommendParam.getPkMember()); | ||||||
|  |             activityParam.setActType(EActType.TOURISM.getValue()); | ||||||
|  | 
 | ||||||
|  |             // 增加基础配置 | ||||||
|  |             AcBaseConfig baseConfig = saveBaseConfig(activityParam); | ||||||
|  |             // 目标群体配置 | ||||||
|  |             saveGoalMemberConfig(activityParam, baseConfig); | ||||||
|  |         } else if (controlType.equals(EControlType.MODIFY.getValue())) { | ||||||
|  |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|  |             activityParam.setActType(EActType.TOURISM.getValue()); | ||||||
|  |             activityParam.setPkCountry(recommendParam.getPkCountry()); | ||||||
|  |             activityParam.setPkCreator(recommendParam.getPkMember()); | ||||||
|  |             //目标用户群删除 | ||||||
|  |             LambdaQueryWrapper<AcGoalMemberConfig> qe = new LambdaQueryWrapper<>(); | ||||||
|  |             qe.eq(AcGoalMemberConfig::getPkBaseId, activityParam.getPkId()); | ||||||
|  |             goalMemberConfigService.remove(qe); | ||||||
|  |             // 增加基础配置 | ||||||
|  |             AcBaseConfig baseConfig = BeanUtil.copyProperties(activityParam, AcBaseConfig.class); | ||||||
|  |             baseConfigService.updateById(baseConfig); | ||||||
|  |             // 目标群体配置 | ||||||
|  |             saveGoalMemberConfig(activityParam, baseConfig); | ||||||
|  |         } else if (controlType.equals(EControlType.DELETE.getValue())) { | ||||||
|  |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|  |             //目标用户群删除 | ||||||
|  |             LambdaQueryWrapper<AcGoalMemberConfig> qe = new LambdaQueryWrapper<>(); | ||||||
|  |             qe.eq(AcGoalMemberConfig::getPkBaseId, activityParam.getPkId()); | ||||||
|  |             goalMemberConfigService.remove(qe); | ||||||
|  |             baseConfigService.removeById(activityParam.getPkId()); | ||||||
|  |             drawGiftConfigService.removeDrawGiftConfig(activityParam.getPkId().intValue()); | ||||||
|  |         } | ||||||
|         //日志 |         //日志 | ||||||
|         ActivityParam activityParam = recommendParam.getActivityParam(); |         ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|         activityParam.setPkCountry(SecurityUtils.getPkCountry()); |         activityParam.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|  | @ -651,7 +685,7 @@ public class ActivityServiceImpl implements IActivityService { | ||||||
|         activityParam.setActType(EActType.TOURISM.getValue()); |         activityParam.setActType(EActType.TOURISM.getValue()); | ||||||
|         activityParam.setBusinessCode(recommendParam.getActivityParam().getBusinessCode()); |         activityParam.setBusinessCode(recommendParam.getActivityParam().getBusinessCode()); | ||||||
|         this.createBaseConfigLog(activityParam, new StringBuffer(), null, approvalBusiness.getValue(), false); |         this.createBaseConfigLog(activityParam, new StringBuffer(), null, approvalBusiness.getValue(), false); | ||||||
|         return b; |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -130,14 +130,12 @@ public class AcConsumeRuleConfigServiceImpl extends ServiceImpl<AcConsumeRuleCon | ||||||
|             activityParam.setPkCreator(loginUser.getUserId()); |             activityParam.setPkCreator(loginUser.getUserId()); | ||||||
|             activityParam.setActType(EActType.CONSUMPTION_GIFT.getValue()); |             activityParam.setActType(EActType.CONSUMPTION_GIFT.getValue()); | ||||||
|             iActivityService.saveConsumptionGift(activityParam); |             iActivityService.saveConsumptionGift(activityParam); | ||||||
|             return null; |  | ||||||
|         } else if (recommendParam.getControlType().equals(EControlType.MODIFY.getValue())) { |         } else if (recommendParam.getControlType().equals(EControlType.MODIFY.getValue())) { | ||||||
|             ActivityParam activityParam = recommendParam.getActivityParam(); |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|             activityParam.setPkCountry(loginUser.getDataCountry()); |             activityParam.setPkCountry(loginUser.getDataCountry()); | ||||||
|             activityParam.setPkCreator(loginUser.getUserId()); |             activityParam.setPkCreator(loginUser.getUserId()); | ||||||
|             activityParam.setActType(EActType.CONSUMPTION_GIFT.getValue()); |             activityParam.setActType(EActType.CONSUMPTION_GIFT.getValue()); | ||||||
|             iActivityService.updateConsumptionGift(activityParam); |             iActivityService.updateConsumptionGift(activityParam); | ||||||
|             return null; |  | ||||||
|         } else if (recommendParam.getControlType().equals(EControlType.DELETE.getValue())) { |         } else if (recommendParam.getControlType().equals(EControlType.DELETE.getValue())) { | ||||||
|             ActivityParam activityParam = recommendParam.getActivityParam(); |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|             Long pkId = activityParam.getPkId(); |             Long pkId = activityParam.getPkId(); | ||||||
|  |  | ||||||
|  | @ -106,7 +106,6 @@ public class AcMemberConsumeRuleServiceImpl extends ServiceImpl<AcMemberConsumeR | ||||||
|             activityParam.setActType(EActType.MEMBER_CONSUMPTION.getValue()); |             activityParam.setActType(EActType.MEMBER_CONSUMPTION.getValue()); | ||||||
|             memberConsumeRuleVo.setActivityParam(activityParam); |             memberConsumeRuleVo.setActivityParam(activityParam); | ||||||
|             saveMemberConsumeRule(memberConsumeRuleVo); |             saveMemberConsumeRule(memberConsumeRuleVo); | ||||||
|             return null; |  | ||||||
|         } else if (memberConsumeRuleVo.getControlType().equals(EControlType.MODIFY.getValue())) { |         } else if (memberConsumeRuleVo.getControlType().equals(EControlType.MODIFY.getValue())) { | ||||||
|             ActivityParam activityParam = memberConsumeRuleVo.getActivityParam(); |             ActivityParam activityParam = memberConsumeRuleVo.getActivityParam(); | ||||||
|             activityParam.setPkCountry(loginUser.getDataCountry()); |             activityParam.setPkCountry(loginUser.getDataCountry()); | ||||||
|  | @ -114,7 +113,6 @@ public class AcMemberConsumeRuleServiceImpl extends ServiceImpl<AcMemberConsumeR | ||||||
|             activityParam.setActType(EActType.MEMBER_CONSUMPTION.getValue()); |             activityParam.setActType(EActType.MEMBER_CONSUMPTION.getValue()); | ||||||
|             memberConsumeRuleVo.setActivityParam(activityParam); |             memberConsumeRuleVo.setActivityParam(activityParam); | ||||||
|             updateConsumptionGift(memberConsumeRuleVo); |             updateConsumptionGift(memberConsumeRuleVo); | ||||||
|             return null; |  | ||||||
|         }else if (memberConsumeRuleVo.getControlType().equals(EControlType.DELETE.getValue())) { |         }else if (memberConsumeRuleVo.getControlType().equals(EControlType.DELETE.getValue())) { | ||||||
|             ActivityParam activityParam = memberConsumeRuleVo.getActivityParam(); |             ActivityParam activityParam = memberConsumeRuleVo.getActivityParam(); | ||||||
|             Long pkId = activityParam.getPkId(); |             Long pkId = activityParam.getPkId(); | ||||||
|  |  | ||||||
|  | @ -86,7 +86,7 @@ public class AcDrawGiftRuleConfigController extends BaseController { | ||||||
|      * @return AjaxResult |      * @return AjaxResult | ||||||
|      */ |      */ | ||||||
|     @Log(module = EOperationModule.AC_RECOMMEEND_CONFIG, method = EOperationMethod.INSERT, remark = "抽奖在线配置") |     @Log(module = EOperationModule.AC_RECOMMEEND_CONFIG, method = EOperationMethod.INSERT, remark = "抽奖在线配置") | ||||||
|     @PostMapping("/online-petition") |     @PostMapping("/submit") | ||||||
|     public AjaxResult onLinePetition(@RequestBody AcRecommendParam recommendParam) { |     public AjaxResult onLinePetition(@RequestBody AcRecommendParam recommendParam) { | ||||||
|         if (recommendParam.getActivityParam().getDrawGiftConfigList() != null) { |         if (recommendParam.getActivityParam().getDrawGiftConfigList() != null) { | ||||||
|             for (AcDrawGiftRuleConfigVo acDrawGiftRuleConfigVo : recommendParam.getActivityParam().getDrawGiftConfigList()) { |             for (AcDrawGiftRuleConfigVo acDrawGiftRuleConfigVo : recommendParam.getActivityParam().getDrawGiftConfigList()) { | ||||||
|  | @ -99,7 +99,11 @@ public class AcDrawGiftRuleConfigController extends BaseController { | ||||||
|         recommendParam.setPkCountry(SecurityUtils.getPkCountry()); |         recommendParam.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         recommendParam.setPkMember(SecurityUtils.getUserId()); |         recommendParam.setPkMember(SecurityUtils.getUserId()); | ||||||
|         recommendParam.setLoginUser(userTokenService.getLoginUser()); |         recommendParam.setLoginUser(userTokenService.getLoginUser()); | ||||||
|         return toAjax(drawGiftConfigService.onLinePetition(recommendParam)); |         String str = drawGiftConfigService.onLinePetition(recommendParam); | ||||||
|  |         if (str != null) { | ||||||
|  |             return AjaxResult.error(str); | ||||||
|  |         } | ||||||
|  |         return AjaxResult.success(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -62,5 +62,5 @@ public interface IAcDrawGiftRuleConfigService extends IService<AcDrawGiftRuleCon | ||||||
|      * @param recommendParam |      * @param recommendParam | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     Boolean onLinePetition(AcRecommendParam recommendParam); |     String onLinePetition(AcRecommendParam recommendParam); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -29,10 +29,12 @@ import com.hzs.common.domain.activity.base.AcPickUpConfig; | ||||||
| import com.hzs.common.domain.activity.draw.AcDrawGiftRuleConfig; | import com.hzs.common.domain.activity.draw.AcDrawGiftRuleConfig; | ||||||
| import com.hzs.common.domain.activity.draw.AcDrawRuleConfig; | import com.hzs.common.domain.activity.draw.AcDrawRuleConfig; | ||||||
| import com.hzs.common.domain.activity.draw.ext.AcDrawGiftRuleConfigExt; | import com.hzs.common.domain.activity.draw.ext.AcDrawGiftRuleConfigExt; | ||||||
|  | import com.hzs.common.security.utils.SecurityUtils; | ||||||
| import com.hzs.system.sys.IApprovalServiceApi; | import com.hzs.system.sys.IApprovalServiceApi; | ||||||
| import com.hzs.system.sys.dto.ApprovalBusinessResultDTO; | import com.hzs.system.sys.dto.ApprovalBusinessResultDTO; | ||||||
| import com.hzs.system.sys.dto.ApprovalSubmitDTO; | import com.hzs.system.sys.dto.ApprovalSubmitDTO; | ||||||
| import com.hzs.system.sys.dto.LoginUser; | import com.hzs.system.sys.dto.LoginUser; | ||||||
|  | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.apache.dubbo.config.annotation.DubboReference; | import org.apache.dubbo.config.annotation.DubboReference; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  | @ -47,6 +49,7 @@ import java.util.List; | ||||||
|  * @since 2023-04-21 |  * @since 2023-04-21 | ||||||
|  */ |  */ | ||||||
| @Service | @Service | ||||||
|  | @Slf4j | ||||||
| public class AcDrawGiftRuleConfigServiceImpl extends ServiceImpl<AcDrawGiftRuleConfigMapper, AcDrawGiftRuleConfig> implements IAcDrawGiftRuleConfigService { | public class AcDrawGiftRuleConfigServiceImpl extends ServiceImpl<AcDrawGiftRuleConfigMapper, AcDrawGiftRuleConfig> implements IAcDrawGiftRuleConfigService { | ||||||
| 
 | 
 | ||||||
|     @Autowired |     @Autowired | ||||||
|  | @ -181,7 +184,9 @@ public class AcDrawGiftRuleConfigServiceImpl extends ServiceImpl<AcDrawGiftRuleC | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public Boolean onLinePetition(AcRecommendParam recommendParam) { |     @Transactional(rollbackFor = Exception.class) | ||||||
|  |     public String onLinePetition(AcRecommendParam recommendParam) { | ||||||
|  |         log.info("抽奖配置入参{}",JSONUtil.toJsonStr(recommendParam)); | ||||||
|         EApprovalBusiness approvalBusiness = null; |         EApprovalBusiness approvalBusiness = null; | ||||||
|         if (recommendParam.getControlType().equals(EControlType.SAVE.getValue())) { |         if (recommendParam.getControlType().equals(EControlType.SAVE.getValue())) { | ||||||
|             approvalBusiness = EApprovalBusiness.LOTTERY_DRAW_ADD; |             approvalBusiness = EApprovalBusiness.LOTTERY_DRAW_ADD; | ||||||
|  | @ -190,8 +195,31 @@ public class AcDrawGiftRuleConfigServiceImpl extends ServiceImpl<AcDrawGiftRuleC | ||||||
|         } else if (recommendParam.getControlType().equals(EControlType.DELETE.getValue())) { |         } else if (recommendParam.getControlType().equals(EControlType.DELETE.getValue())) { | ||||||
|             approvalBusiness = EApprovalBusiness.LOTTERY_DRAW_REMOVE; |             approvalBusiness = EApprovalBusiness.LOTTERY_DRAW_REMOVE; | ||||||
|         } |         } | ||||||
|  |         Integer controlType = recommendParam.getControlType(); | ||||||
|  |         if (controlType.equals(EControlType.SAVE.getValue())) { | ||||||
|  |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|  |             activityParam.setPkCountry(recommendParam.getPkCountry()); | ||||||
|  |             activityParam.setPkCreator(recommendParam.getPkMember()); | ||||||
|  |             activityParam.setActType(EActType.LOTTERY_DRAW.getValue()); | ||||||
|  |             iActivityService.saveRaffleActivity(activityParam); | ||||||
|  |         } else if (controlType.equals(EControlType.MODIFY.getValue())) { | ||||||
|  |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|  |             activityParam.setActType(EActType.LOTTERY_DRAW.getValue()); | ||||||
|  |             activityParam.setPkCountry(recommendParam.getPkCountry()); | ||||||
|  |             activityParam.setPkCreator(recommendParam.getPkMember()); | ||||||
|  |             drawGiftConfigService.updateDrawGiftConfig(activityParam); | ||||||
|  |         } else if (controlType.equals(EControlType.DELETE.getValue())) { | ||||||
|  |             drawGiftConfigService.removeDrawGiftConfig(recommendParam.getActivityParam().getPkBaseId().intValue()); | ||||||
|  |         } | ||||||
|  |         // 日志 | ||||||
|  |         ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|  |         activityParam.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|  |         activityParam.setPkCreator(SecurityUtils.getUserId()); | ||||||
|  |         activityParam.setActType(EActType.CONSUMPTION_GIFT.getValue()); | ||||||
| 
 | 
 | ||||||
|         return submitApproval(recommendParam, approvalBusiness); |         //日志 | ||||||
|  |         iActivityService.createBaseConfigLog(activityParam, new StringBuffer(), null, approvalBusiness.getValue(), false); | ||||||
|  |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -44,12 +44,16 @@ public class AcRecommendConfigController extends BaseController { | ||||||
|      * @return AjaxResult |      * @return AjaxResult | ||||||
|      */ |      */ | ||||||
|     @Log(module = EOperationModule.AC_RECOMMEEND_CONFIG, business = EOperationBusiness.AC_RECOMMEEND_CONFIG, method = EOperationMethod.INSERT, remark = "在线签呈") |     @Log(module = EOperationModule.AC_RECOMMEEND_CONFIG, business = EOperationBusiness.AC_RECOMMEEND_CONFIG, method = EOperationMethod.INSERT, remark = "在线签呈") | ||||||
|     @PostMapping("/online-petition") |     @PostMapping("/submit") | ||||||
|     public AjaxResult onLinePetition(@RequestBody AcRecommendParam recommendParam) { |     public AjaxResult onLinePetition(@RequestBody AcRecommendParam recommendParam) { | ||||||
|         recommendParam.setPkCountry(SecurityUtils.getPkCountry()); |         recommendParam.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         recommendParam.setPkMember(SecurityUtils.getUserId()); |         recommendParam.setPkMember(SecurityUtils.getUserId()); | ||||||
|         recommendParam.setLoginUser(userTokenService.getLoginUser()); |         recommendParam.setLoginUser(userTokenService.getLoginUser()); | ||||||
|         return toAjax(acRepurCouponsRuleConfigService.onLinePetition(recommendParam)); |         String str = acRepurCouponsRuleConfigService.onLinePetition(recommendParam); | ||||||
|  |         if (str != null) { | ||||||
|  |             return AjaxResult.error(str); | ||||||
|  |         } | ||||||
|  |         return AjaxResult.success(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -21,7 +21,7 @@ public interface IAcRepurCouponsRuleConfigService extends IService<AcRepurCoupon | ||||||
|      * @param recommendParam |      * @param recommendParam | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     Boolean onLinePetition(AcRecommendParam recommendParam); |     String onLinePetition(AcRecommendParam recommendParam); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 查看详情 |      * 查看详情 | ||||||
|  |  | ||||||
|  | @ -96,7 +96,8 @@ public class AcRepurCouponsRuleConfigServiceImpl extends ServiceImpl<AcRepurCoup | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Transactional(rollbackFor = Exception.class) |     @Transactional(rollbackFor = Exception.class) | ||||||
|     public Boolean onLinePetition(AcRecommendParam recommendParam) { |     public String onLinePetition(AcRecommendParam recommendParam) { | ||||||
|  |         log.info("直推参数{}",JSONUtil.toJsonStr(recommendParam)); | ||||||
|         EApprovalBusiness approvalBusiness = EApprovalBusiness.DIRECT_PUSH_GIFT; |         EApprovalBusiness approvalBusiness = EApprovalBusiness.DIRECT_PUSH_GIFT; | ||||||
|         //根据产品ID查询产品名称 |         //根据产品ID查询产品名称 | ||||||
|         List<AcRecommendUpgradeVO> recommendUpgradeList = recommendParam.getRecommendUpgradeList(); |         List<AcRecommendUpgradeVO> recommendUpgradeList = recommendParam.getRecommendUpgradeList(); | ||||||
|  | @ -113,12 +114,20 @@ public class AcRepurCouponsRuleConfigServiceImpl extends ServiceImpl<AcRepurCoup | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         Integer controlType = recommendParam.getControlType(); | ||||||
|  |         if (controlType.equals(EControlType.SAVE.getValue())) { | ||||||
|  |             return saveRecommendData(recommendParam); | ||||||
|  |         } else if (controlType.equals(EControlType.MODIFY.getValue())) { | ||||||
|  |             deleteRecommendData(recommendParam); | ||||||
|  |             return saveRecommendData(recommendParam); | ||||||
|  |         } else { | ||||||
|  |             deleteRecommendData(recommendParam); | ||||||
|  |         } | ||||||
|         //业务单号 |         //业务单号 | ||||||
|         String businessCode = CommonUtil.createSerialNumber(EOrderPrefix.ACTIVITY_CODE.getValue()); |         String businessCode = CommonUtil.createSerialNumber(EOrderPrefix.ACTIVITY_CODE.getValue()); | ||||||
|         //提交审批 |         //日志 | ||||||
|         Boolean result = submitApproval(recommendParam, approvalBusiness, businessCode); |  | ||||||
|         packageRecommendOperationLog(recommendParam, approvalBusiness, businessCode); |         packageRecommendOperationLog(recommendParam, approvalBusiness, businessCode); | ||||||
|         return result; |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -60,12 +60,16 @@ public class AcTourismController extends BaseController { | ||||||
|      * @return AjaxResult |      * @return AjaxResult | ||||||
|      */ |      */ | ||||||
|     @Log(module = EOperationModule.AC_TOURISM_CONFIG, business = EOperationBusiness.AC_TOURISM_CONFIG, method = EOperationMethod.INSERT, remark = "在线签呈") |     @Log(module = EOperationModule.AC_TOURISM_CONFIG, business = EOperationBusiness.AC_TOURISM_CONFIG, method = EOperationMethod.INSERT, remark = "在线签呈") | ||||||
|     @PostMapping("/online-petition") |     @PostMapping("/submit") | ||||||
|     public AjaxResult onLinePetition(@RequestBody AcRecommendParam recommendParam) { |     public AjaxResult onLinePetition(@RequestBody AcRecommendParam recommendParam) { | ||||||
|         recommendParam.setPkCountry(SecurityUtils.getPkCountry()); |         recommendParam.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         recommendParam.setPkMember(SecurityUtils.getUserId()); |         recommendParam.setPkMember(SecurityUtils.getUserId()); | ||||||
|         recommendParam.setLoginUser(userTokenService.getLoginUser()); |         recommendParam.setLoginUser(userTokenService.getLoginUser()); | ||||||
|         return toAjax(activityService.onLinePetition(recommendParam)); |         String str = activityService.onLinePetition(recommendParam); | ||||||
|  |         if (str != null) { | ||||||
|  |             return AjaxResult.error(str); | ||||||
|  |         } | ||||||
|  |         return AjaxResult.success(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -133,14 +133,12 @@ public class AcWaresRuleConfigServiceImpl extends ServiceImpl<AcWaresRuleConfigM | ||||||
|             activityParam.setPkCreator(loginUser.getUserId()); |             activityParam.setPkCreator(loginUser.getUserId()); | ||||||
|             activityParam.setActType(EActType.PRODUCT_GIFT.getValue()); |             activityParam.setActType(EActType.PRODUCT_GIFT.getValue()); | ||||||
|             iActivityService.saveActivity(activityParam); |             iActivityService.saveActivity(activityParam); | ||||||
|             return null; |  | ||||||
|         } else if (recommendParam.getControlType().equals(EControlType.MODIFY.getValue())) { |         } else if (recommendParam.getControlType().equals(EControlType.MODIFY.getValue())) { | ||||||
|             ActivityParam activityParam = recommendParam.getActivityParam(); |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|             activityParam.setPkCountry(loginUser.getDataCountry()); |             activityParam.setPkCountry(loginUser.getDataCountry()); | ||||||
|             activityParam.setPkCreator(loginUser.getUserId()); |             activityParam.setPkCreator(loginUser.getUserId()); | ||||||
|             activityParam.setActType(EActType.PRODUCT_GIFT.getValue()); |             activityParam.setActType(EActType.PRODUCT_GIFT.getValue()); | ||||||
|             waresRuleConfigService.updateWaresRuleConfig(activityParam); |             waresRuleConfigService.updateWaresRuleConfig(activityParam); | ||||||
|             return null; |  | ||||||
|         } else if (recommendParam.getControlType().equals(EControlType.DELETE.getValue())) { |         } else if (recommendParam.getControlType().equals(EControlType.DELETE.getValue())) { | ||||||
|             ActivityParam activityParam = recommendParam.getActivityParam(); |             ActivityParam activityParam = recommendParam.getActivityParam(); | ||||||
|             Long pkId = activityParam.getPkId(); |             Long pkId = activityParam.getPkId(); | ||||||
|  |  | ||||||
|  | @ -33,8 +33,6 @@ import com.hzs.sale.shopping.vo.ProductGroup; | ||||||
| import com.hzs.sale.shopping.vo.ShoppingCartRedis; | import com.hzs.sale.shopping.vo.ShoppingCartRedis; | ||||||
| import com.hzs.sale.shopping.vo.ShoppingCartVO; | import com.hzs.sale.shopping.vo.ShoppingCartVO; | ||||||
| import com.hzs.system.base.IAreaServiceApi; | import com.hzs.system.base.IAreaServiceApi; | ||||||
| import com.hzs.system.base.ICurrencyServiceApi; |  | ||||||
| import com.hzs.system.base.dto.CurrencyDTO; |  | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.apache.dubbo.config.annotation.DubboReference; | import org.apache.dubbo.config.annotation.DubboReference; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | @ -49,8 +47,6 @@ public abstract class ParentOrderController extends BaseController { | ||||||
|     @DubboReference |     @DubboReference | ||||||
|     IAreaServiceApi iAreaServiceApi; |     IAreaServiceApi iAreaServiceApi; | ||||||
|     @DubboReference |     @DubboReference | ||||||
|     ICurrencyServiceApi iCurrencyServiceApi; |  | ||||||
|     @DubboReference |  | ||||||
|     IMemberServiceApi iMemberServiceApi; |     IMemberServiceApi iMemberServiceApi; | ||||||
| 
 | 
 | ||||||
|     @Autowired |     @Autowired | ||||||
|  | @ -257,25 +253,23 @@ public abstract class ParentOrderController extends BaseController { | ||||||
|         if (parentMember == null) { |         if (parentMember == null) { | ||||||
|             return AjaxResult.error(TransactionUtils.getContent(MemberMsgConstants.PARENT_NOT_EXISTS)); |             return AjaxResult.error(TransactionUtils.getContent(MemberMsgConstants.PARENT_NOT_EXISTS)); | ||||||
|         } |         } | ||||||
|         orderParam.setParent(CommonUtil.getMemberCode(parentMember.getMemberCode(), parentMember.getServiceCode())); |         if (null == parentMember.getPkPlaceParent()) { | ||||||
|         if (SecurityUtils.getUserId().equals(parentMember.getPkId())) { |             return AjaxResult.error("当前推荐编号不能成为推荐人"); | ||||||
|             orderParam.setParentName(parentMember.getMemberName()); |  | ||||||
|         } else { |  | ||||||
|             orderParam.setParentName(CommonUtil.getMemberName(parentMember.getPkVertex(), parentMember.getMemberName(), parentMember.getNickName())); |  | ||||||
|         } |         } | ||||||
|  |         orderParam.setParent(CommonUtil.getMemberCode(parentMember.getMemberCode(), parentMember.getServiceCode())); | ||||||
|  |         orderParam.setParentName(parentMember.getMemberName()); | ||||||
| 
 | 
 | ||||||
|         CuMember placeMember = getCuMemberByCode(orderParam.getPlaceParent()); |         CuMember placeMember = getCuMemberByCode(orderParam.getPlaceParent()); | ||||||
|         if (placeMember == null) { |         if (placeMember == null) { | ||||||
|             return AjaxResult.error(TransactionUtils.getContent(MemberMsgConstants.PLACE_PARENT_NOT_EXISTS)); |             return AjaxResult.error(TransactionUtils.getContent(MemberMsgConstants.PLACE_PARENT_NOT_EXISTS)); | ||||||
|         } |         } | ||||||
|         orderParam.setPlaceParentId(placeMember.getPkId()); |         if (null == placeMember.getPkPlaceParent()) { | ||||||
|         orderParam.setPlaceParent(CommonUtil.getMemberCode(placeMember.getMemberCode(), placeMember.getServiceCode())); |             return AjaxResult.error("当前安置编号不能成为安置人"); | ||||||
| 
 |  | ||||||
|         if (SecurityUtils.getUserId().equals(placeMember.getPkId())) { |  | ||||||
|             orderParam.setPlaceParentName(placeMember.getMemberName()); |  | ||||||
|         } else { |  | ||||||
|             orderParam.setPlaceParentName(CommonUtil.getMemberName(placeMember.getPkVertex(), placeMember.getMemberName(), placeMember.getNickName())); |  | ||||||
|         } |         } | ||||||
|  |         orderParam.setPlaceParentId(placeMember.getPkId()); | ||||||
|  |         orderParam.setPlaceParent(placeMember.getMemberCode()); | ||||||
|  |         orderParam.setPlaceParentName(placeMember.getMemberName()); | ||||||
|  | 
 | ||||||
|         // 当安置人跟安置位置都有值是需要验证 需要验证安置位置 |         // 当安置人跟安置位置都有值是需要验证 需要验证安置位置 | ||||||
|         if (orderParam.getPlaceDept() != null && orderParam.getPlaceDept() > 0) { |         if (orderParam.getPlaceDept() != null && orderParam.getPlaceDept() > 0) { | ||||||
|             // 安置人在推荐人伞下,含自己。 推荐人在报单中心伞下,含自己,在推荐那边验证 |             // 安置人在推荐人伞下,含自己。 推荐人在报单中心伞下,含自己,在推荐那边验证 | ||||||
|  | @ -551,17 +545,7 @@ public abstract class ParentOrderController extends BaseController { | ||||||
|     protected OrderReturn getOrderReturn(SaOrder saOrder, OrderParam orderParam) { |     protected OrderReturn getOrderReturn(SaOrder saOrder, OrderParam orderParam) { | ||||||
|         // 封装订单信息 |         // 封装订单信息 | ||||||
|         long maxPayTime = iSaOrderService.getIsToBePayTime(orderParam.getPkSettleCountry(), saOrder.getOrderType()); |         long maxPayTime = iSaOrderService.getIsToBePayTime(orderParam.getPkSettleCountry(), saOrder.getOrderType()); | ||||||
|         // 剩余支付秒数 |  | ||||||
|         //查询带关闭参数 |  | ||||||
|         // 获取行政区划map |  | ||||||
|         Integer pkLoginCountry = orderParam.getPkLoginSettleCountry(); |  | ||||||
|         BigDecimal orderAmount = saOrder.getOrderAmount(); |         BigDecimal orderAmount = saOrder.getOrderAmount(); | ||||||
|         if (!Objects.equals(pkLoginCountry, saOrder.getPkCountry())) { |  | ||||||
|             // 结算国当地币 转美金  美金登录当地币 |  | ||||||
|             CurrencyDTO loginCountryCurrency = iCurrencyServiceApi.getCurrency(pkLoginCountry).getData(); |  | ||||||
|             CurrencyDTO settleCountryCurrency = iCurrencyServiceApi.getCurrency(saOrder.getPkCountry()).getData(); |  | ||||||
|             orderAmount = ComputeUtil.computeMultiply(ComputeUtil.computeDivide(orderAmount, settleCountryCurrency.getInExchangeRate()), loginCountryCurrency.getInExchangeRate()); |  | ||||||
|         } |  | ||||||
|         Map<Integer, String> areaMap = iAreaServiceApi.getAreaMap(orderParam.getPkSettleCountry()).getData(); |         Map<Integer, String> areaMap = iAreaServiceApi.getAreaMap(orderParam.getPkSettleCountry()).getData(); | ||||||
|         OrderReturn orderReturn = OrderReturn.builder() |         OrderReturn orderReturn = OrderReturn.builder() | ||||||
|                 .orderCode(saOrder.getOrderCode()) |                 .orderCode(saOrder.getOrderCode()) | ||||||
|  | @ -635,7 +619,7 @@ public abstract class ParentOrderController extends BaseController { | ||||||
|             return AjaxResult.error(SaOrderMsgConstants.TERMINATED_NOT_DECLARATION); |             return AjaxResult.error(SaOrderMsgConstants.TERMINATED_NOT_DECLARATION); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return AjaxResult.success(); |         return AjaxResult.success(cuMember); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -12,6 +12,8 @@ import com.hzs.common.core.constant.msg.SaOrderMsgConstants; | ||||||
| import com.hzs.common.core.domain.R; | import com.hzs.common.core.domain.R; | ||||||
| import com.hzs.common.core.enums.EDelivery; | import com.hzs.common.core.enums.EDelivery; | ||||||
| import com.hzs.common.core.enums.EOrderType; | import com.hzs.common.core.enums.EOrderType; | ||||||
|  | import com.hzs.common.core.enums.EOrderTypeExtend; | ||||||
|  | import com.hzs.common.core.enums.ESpecialArea; | ||||||
| import com.hzs.common.core.utils.CommonUtil; | import com.hzs.common.core.utils.CommonUtil; | ||||||
| import com.hzs.common.core.utils.StringUtils; | import com.hzs.common.core.utils.StringUtils; | ||||||
| import com.hzs.common.core.web.domain.AjaxResult; | import com.hzs.common.core.web.domain.AjaxResult; | ||||||
|  | @ -72,16 +74,26 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
|         initSecurityOrderParam(orderParam); |         initSecurityOrderParam(orderParam); | ||||||
|         // 验证必输项 |         // 验证必输项 | ||||||
|         if (null == source |         if (null == source | ||||||
|                 || validateFieldNotNull(orderParam, orderParam.getValidConfirmField()) |  | ||||||
|                 || !checkRecMsgBoolean(orderParam)) { |                 || !checkRecMsgBoolean(orderParam)) { | ||||||
|             return AjaxResult.error(MemberMsgConstants.REQUIRED_NOT_EMPTY); |             return AjaxResult.error(MemberMsgConstants.REQUIRED_NOT_EMPTY); | ||||||
|         } |         } | ||||||
|         orderParam.setSource(source); |         orderParam.setSource(source); | ||||||
|  |         // 0元会员专区处理 | ||||||
|  |         if (ESpecialArea.MEMBER_AREA.getValue() == orderParam.getSpecialArea()) { | ||||||
|  |             orderParam.setOrderTypeExtend(EOrderTypeExtend.REG_REP.getValue()); | ||||||
|  |             orderParam.setSpecialArea(ESpecialArea.getMemberArea(orderParam.getSpecialArea())); | ||||||
|  |         } else { | ||||||
|  |             // 校验安置位置 | ||||||
|  |             if (validateFieldNotNull(orderParam, orderParam.getValidConfirmField())) { | ||||||
|  |                 return AjaxResult.error(MemberMsgConstants.REQUIRED_NOT_EMPTY); | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             AjaxResult result = validateSaveMember(orderParam); |             AjaxResult result = validateSaveMember(orderParam); | ||||||
|             if ((Integer) result.get(AjaxResult.CODE_TAG) == HttpStatus.ERROR) { |             if ((Integer) result.get(AjaxResult.CODE_TAG) == HttpStatus.ERROR) { | ||||||
|                 return result; |                 return result; | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         // 购物车中的商品相关信息 |         // 购物车中的商品相关信息 | ||||||
|         convertShoppingCarToSku(orderParam); |         convertShoppingCarToSku(orderParam); | ||||||
|         if (getOrderService().confirmRegSaOrderByOrderParam(orderParam)) { |         if (getOrderService().confirmRegSaOrderByOrderParam(orderParam)) { | ||||||
|  | @ -296,6 +308,9 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
|             return AjaxResult.error(SaOrderMsgConstants.SPECIAL_AREA_NOT_EMPTY); |             return AjaxResult.error(SaOrderMsgConstants.SPECIAL_AREA_NOT_EMPTY); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         // 0元会员专区处理 | ||||||
|  |         orderParam.setSpecialArea(ESpecialArea.getMemberArea(orderParam.getSpecialArea())); | ||||||
|  | 
 | ||||||
|         if ((checkRecPostageMsgBoolean(orderParam) && orderParam.getDeliveryWay() == EDelivery.FAST_MAIL.getValue())) { |         if ((checkRecPostageMsgBoolean(orderParam) && orderParam.getDeliveryWay() == EDelivery.FAST_MAIL.getValue())) { | ||||||
|             // 验证必输项,一个条件未填写都不计算邮费 |             // 验证必输项,一个条件未填写都不计算邮费 | ||||||
|             initSecurityOrderParam(orderParam); |             initSecurityOrderParam(orderParam); | ||||||
|  | @ -431,8 +446,6 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 校验会员等级, 计算会员等级 |      * 校验会员等级, 计算会员等级 | ||||||
|      * |  | ||||||
|      * @param orderParam 参数 |  | ||||||
|      */ |      */ | ||||||
|     @PostMapping("/valid-mem-level") |     @PostMapping("/valid-mem-level") | ||||||
|     public AjaxResult validateMemberLevel(@RequestBody OrderParam orderParam) { |     public AjaxResult validateMemberLevel(@RequestBody OrderParam orderParam) { | ||||||
|  | @ -443,6 +456,8 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
|                 orderParam.getOrderItemsParams().size() == 0) { |                 orderParam.getOrderItemsParams().size() == 0) { | ||||||
|             return AjaxResult.error("没有选择商品!"); |             return AjaxResult.error("没有选择商品!"); | ||||||
|         } |         } | ||||||
|  |         // 0元会员专区处理 | ||||||
|  |         orderParam.setSpecialArea(ESpecialArea.getMemberArea(orderParam.getSpecialArea())); | ||||||
|         orderParam.setCenterCodeId(SecurityUtils.getUserId()); |         orderParam.setCenterCodeId(SecurityUtils.getUserId()); | ||||||
|         convertShoppingCarToSku(orderParam); |         convertShoppingCarToSku(orderParam); | ||||||
|         // 计算等级 |         // 计算等级 | ||||||
|  | @ -472,8 +487,6 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 快速注册 |      * 快速注册 | ||||||
|      * |  | ||||||
|      * @param orderParam 参数 |  | ||||||
|      */ |      */ | ||||||
|     @PostMapping("/quick-reg") |     @PostMapping("/quick-reg") | ||||||
|     public AjaxResult quickRegistration(@RequestBody OrderParam orderParam) { |     public AjaxResult quickRegistration(@RequestBody OrderParam orderParam) { | ||||||
|  | @ -485,24 +498,14 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
|         if (StringUtils.isEmpty(orderParam.getParent())) { |         if (StringUtils.isEmpty(orderParam.getParent())) { | ||||||
|             orderParam.setParentId(SecurityUtils.getUserId()); |             orderParam.setParentId(SecurityUtils.getUserId()); | ||||||
|             parentCuMember = getOrderService().getCuMemberByKey(orderParam.getParentId()); |             parentCuMember = getOrderService().getCuMemberByKey(orderParam.getParentId()); | ||||||
|             if (SecurityUtils.getUserId().equals(orderParam.getParentId())) { |  | ||||||
|                 // 如果是自己,则不需要处理昵称 |  | ||||||
|             orderParam.setParentName(parentCuMember.getMemberName()); |             orderParam.setParentName(parentCuMember.getMemberName()); | ||||||
|             } else { |  | ||||||
|                 orderParam.setParentName(CommonUtil.getMemberName(parentCuMember.getPkVertex(), parentCuMember.getMemberName(), parentCuMember.getNickName())); |  | ||||||
|             } |  | ||||||
|         } else { |         } else { | ||||||
|             parentCuMember = getCuMemberByCode(orderParam.getParent()); |             parentCuMember = getCuMemberByCode(orderParam.getParent()); | ||||||
|             if (parentCuMember == null) { |             if (parentCuMember == null) { | ||||||
|                 return AjaxResult.error(TransactionUtils.getContent(MemberMsgConstants.PARENT_NOT_EXISTS)); |                 return AjaxResult.error(TransactionUtils.getContent(MemberMsgConstants.PARENT_NOT_EXISTS)); | ||||||
|             } |             } | ||||||
|             orderParam.setParentId(parentCuMember.getPkId()); |             orderParam.setParentId(parentCuMember.getPkId()); | ||||||
|             if (SecurityUtils.getUserId().equals(orderParam.getParentId())) { |  | ||||||
|                 // 如果是自己,则不需要处理昵称 |  | ||||||
|             orderParam.setParentName(parentCuMember.getMemberName()); |             orderParam.setParentName(parentCuMember.getMemberName()); | ||||||
|             } else { |  | ||||||
|                 orderParam.setParentName(CommonUtil.getMemberName(parentCuMember.getPkVertex(), parentCuMember.getMemberName(), parentCuMember.getNickName())); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         CuMember cuMember = CuMember.builder() |         CuMember cuMember = CuMember.builder() | ||||||
|  | @ -514,20 +517,7 @@ public class ApiRegSaOrderController extends ParentOrderController { | ||||||
|         boolean isFirst = getOrderService().validateFirstOrder(cuMember.getPkParent(), cuMember.getPkSettleCountry()); |         boolean isFirst = getOrderService().validateFirstOrder(cuMember.getPkParent(), cuMember.getPkSettleCountry()); | ||||||
|         cuMember = getOrderService().obtainLastResettleByRecommend(cuMember, Boolean.TRUE, isFirst); |         cuMember = getOrderService().obtainLastResettleByRecommend(cuMember, Boolean.TRUE, isFirst); | ||||||
| 
 | 
 | ||||||
|         String placeParentName; |         String placeParentName = cuMember.getMemberName(); | ||||||
|         if (null == cuMember.getPkPlaceParent()) { |  | ||||||
|             if (SecurityUtils.getUserId().equals(parentCuMember.getPkId())) { |  | ||||||
|                 placeParentName = cuMember.getMemberName(); |  | ||||||
|             } else { |  | ||||||
|                 placeParentName = CommonUtil.getMemberName(parentCuMember.getPkVertex(), cuMember.getMemberName(), cuMember.getNickName()); |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             if (SecurityUtils.getUserId().equals(cuMember.getPkId())) { |  | ||||||
|                 placeParentName = cuMember.getMemberName(); |  | ||||||
|             } else { |  | ||||||
|                 placeParentName = CommonUtil.getMemberName(cuMember.getPkVertex(), cuMember.getMemberName(), cuMember.getNickName()); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         return AjaxResult.success(OrderReturn.builder() |         return AjaxResult.success(OrderReturn.builder() | ||||||
|                 .isFirst(isFirst) |                 .isFirst(isFirst) | ||||||
|  |  | ||||||
|  | @ -455,16 +455,22 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|     @Transactional(rollbackFor = Exception.class) |     @Transactional(rollbackFor = Exception.class) | ||||||
|     public Boolean confirmRegSaOrderByOrderParam(OrderParam orderParam) { |     public Boolean confirmRegSaOrderByOrderParam(OrderParam orderParam) { | ||||||
|         boolean isToBePay = getIsToBePayByOrderType(orderParam.getPkSettleCountry(), orderParam.getSpecialArea()); |         boolean isToBePay = getIsToBePayByOrderType(orderParam.getPkSettleCountry(), orderParam.getSpecialArea()); | ||||||
|         CuMember cuMember = saOrderHandle.packageSaveUser(orderParam, iMemberServiceApi.queryMember(orderParam.getCenterCodeId()).getData()); | 
 | ||||||
|  |         CuMember cuMember; | ||||||
|  |         if (!EOrderTypeExtend.REG_REP.getValue().equals(orderParam.getOrderTypeExtend())) { | ||||||
|  |             // 非0元需要获取会员编号、会员主键 | ||||||
|  |             cuMember = saOrderHandle.packageSaveUser(orderParam, iMemberServiceApi.queryMember(orderParam.getCenterCodeId()).getData()); | ||||||
|             // 获取会员编号、会员主键 |             // 获取会员编号、会员主键 | ||||||
|             if (isToBePay) { |             if (isToBePay) { | ||||||
|                 cuMember = iMemberServiceApi.createMemberIdAndCode(cuMember, Boolean.FALSE).getData(); |                 cuMember = iMemberServiceApi.createMemberIdAndCode(cuMember, Boolean.FALSE).getData(); | ||||||
|         } else if ((CountryConstants.CHINA_COUNTRY.equals(orderParam.getPkSettleCountry())) && |             } else if (EOrderType.REGISTER_ORDER.getValue() == orderParam.getSpecialArea() | ||||||
|                 (EOrderType.REGISTER_ORDER.getValue() == orderParam.getSpecialArea() |                     || EOrderType.SPECIAL_REGISTER_ORDER.getValue() == orderParam.getSpecialArea()) { | ||||||
|                         || EOrderType.SPECIAL_REGISTER_ORDER.getValue() == orderParam.getSpecialArea())) { |  | ||||||
|                 // 2023.10.16按最新需求,注册订单需要在支付前需要显示会员编号 |                 // 2023.10.16按最新需求,注册订单需要在支付前需要显示会员编号 | ||||||
|                 cuMember = iMemberServiceApi.createRegisterMemberCode(cuMember).getData(); |                 cuMember = iMemberServiceApi.createRegisterMemberCode(cuMember).getData(); | ||||||
|             } |             } | ||||||
|  |         } else { | ||||||
|  |             cuMember = iMemberServiceApi.queryMember(orderParam.getCenterCodeId()).getData(); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         SaOrderExt saOrderExt = packageWholeSaOrder(orderParam, cuMember); |         SaOrderExt saOrderExt = packageWholeSaOrder(orderParam, cuMember); | ||||||
|         // 设置会员等级 |         // 设置会员等级 | ||||||
|  | @ -554,6 +560,7 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
| 
 | 
 | ||||||
|         // 验证推荐等级,判断什么级别可以推荐什么级别 |         // 验证推荐等级,判断什么级别可以推荐什么级别 | ||||||
|         if (EOrderType.REGISTER_ORDER.getValue() == saOrderExt.getOrderType()) { |         if (EOrderType.REGISTER_ORDER.getValue() == saOrderExt.getOrderType()) { | ||||||
|  |             if (!EOrderTypeExtend.REG_REP.getValue().equals(saOrderExt.getOrderTypeExtend())) { | ||||||
|                 // 判断推荐范围,验证该推荐人是否有推荐的权限 |                 // 判断推荐范围,验证该推荐人是否有推荐的权限 | ||||||
|                 CuMember parentCuMember = getCuMemberByKey(cuMember.getPkParent()); |                 CuMember parentCuMember = getCuMemberByKey(cuMember.getPkParent()); | ||||||
| 
 | 
 | ||||||
|  | @ -566,6 +573,7 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         Integer pkAwards = cuMember.getPkAwards(); |         Integer pkAwards = cuMember.getPkAwards(); | ||||||
|         cuMember.setPkRegisterGrade(gradeDTO.getPkId()); |         cuMember.setPkRegisterGrade(gradeDTO.getPkId()); | ||||||
|  | @ -803,6 +811,65 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|         return Boolean.TRUE; |         return Boolean.TRUE; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     private boolean payReyZeroOrder(SaOrderExt saOrderExt, CuMember newCuMember) { | ||||||
|  |         Date currentDateTime = DateUtils.currentDateTime(); | ||||||
|  |         newCuMember.setPayStatus(EPayStatus.PAID.getValue()); | ||||||
|  |         newCuMember.setPayTime(currentDateTime); | ||||||
|  |         newCuMember.setConsumeMoney(saOrderExt.getOrderAmount()); | ||||||
|  |         newCuMember.setConsumeAchieve(saOrderExt.getOrderAchieve()); | ||||||
|  |         // 会员续约需求,【有效期】为购买时间次年的上月最后一天 | ||||||
|  |         newCuMember.setExpireDate(DateUtils.beforeMonthLastDate(DateUtils.addYears(currentDateTime, 1))); | ||||||
|  |         // 【休止期】普通会员6个月,奖衔会员12个月(先按6个月来,后续MQ会统一处理同姓名同手机号会员) | ||||||
|  |         newCuMember.setStopDate(DateUtils.addMonths(newCuMember.getExpireDate(), 6)); | ||||||
|  | 
 | ||||||
|  |         if (null == newCuMember.getPkPlaceParent() | ||||||
|  |                 || null == newCuMember.getPlaceDept()) { | ||||||
|  |             // 当安置人和安置部门为空时,进行上树 | ||||||
|  |             CuMember cuMember = repeatTry(newCuMember, Boolean.FALSE); | ||||||
|  |             newCuMember.setPkPlaceParent(cuMember.getPkPlaceParent()); | ||||||
|  |             newCuMember.setPlaceDept(cuMember.getPlaceDept()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         saOrderExt.setOrderType(EOrderType.REPURCHASE_ORDER.getValue()); | ||||||
|  |         saOrderExt.setOrderTypeExtend(EOrderTypeExtend.REG_REP.getValue()); | ||||||
|  |         saOrderExt.setPkPlacement(newCuMember.getPkPlaceParent()); | ||||||
|  |         saOrderExt.setOrderStatus(EOrderStatus.PAY.getValue()); | ||||||
|  |         saOrderExt.setPayTime(currentDateTime); | ||||||
|  |         saOrderExt.setCreationTime(currentDateTime); | ||||||
|  |         for (SaOrderItems saOrderItems : saOrderExt.getOrderItemsList()) { | ||||||
|  |             saOrderItems.setCreationTime(saOrderExt.getCreationTime()); | ||||||
|  |             saOrderItems.setOrderStatus(EOrderStatus.PAY.getValue()); | ||||||
|  |             saOrderItems.setPkGrade(newCuMember.getPkSettleGrade()); | ||||||
|  |         } | ||||||
|  |         // 保存订单信息 | ||||||
|  |         processOrder(saOrderExt); | ||||||
|  | 
 | ||||||
|  |         // 调用其他服务保存会员信息、会员注册信息 | ||||||
|  |         R<Boolean> handleResult = iMemberServiceApi.handleZeroMember(newCuMember, saOrderExt); | ||||||
|  |         if (handleResult.isSuccess()) { | ||||||
|  |             if (!handleResult.getData()) { | ||||||
|  |                 log.error("payReyZeroOrder 保存会员失败!."); | ||||||
|  |                 throw new RuntimeException("保存会员失败!."); | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             log.error("payReyZeroOrder 保存会员失败!.,{}", handleResult.getMsg()); | ||||||
|  |             throw new RuntimeException("保存会员失败!."); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         try { | ||||||
|  |             // 同步全网产品库存 | ||||||
|  |             this.allProductSync(saOrderExt); | ||||||
|  | 
 | ||||||
|  |             log.info("生产活动消息,activity.exchange:{}", JSONUtil.toJsonStr(saOrderExt)); | ||||||
|  |             rabbitTemplate.convertAndSend(RabbitMqConstants.ACTIVITY_EXCHANGE, RabbitMqConstants.ACTIVITY_KEY, saOrderExt); | ||||||
|  |             // 推送秒结数据处理 -- 注册订单 | ||||||
|  |             rabbitTemplate.convertAndSend(RabbitMqConstants.ORDER_SECOND_EXCHANGE, RabbitMqConstants.ORDER_SECOND_KEY, saOrderExt); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             e.printStackTrace(); | ||||||
|  |         } | ||||||
|  |         return Boolean.TRUE; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * 尝试重新换位置 |      * 尝试重新换位置 | ||||||
|      * |      * | ||||||
|  | @ -1035,7 +1102,7 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|         } |         } | ||||||
|         // 封装订单信息 |         // 封装订单信息 | ||||||
|         SaOrderExt saOrderExt = saOrderHandle.packageSaveSaOrder(orderParam, cuMember, orderCode); |         SaOrderExt saOrderExt = saOrderHandle.packageSaveSaOrder(orderParam, cuMember, orderCode); | ||||||
|         if (null != orderParam.getOrderTypeExtend() && EOrderTypeExtend.REG_REP.getValue() == orderParam.getOrderTypeExtend()) { |         if (null != orderParam.getOrderTypeExtend() && EOrderTypeExtend.REG_REP.getValue().equals(orderParam.getOrderTypeExtend())) { | ||||||
|             saOrderExt.setOrderType(EOrderType.REPURCHASE_ORDER.getValue()); |             saOrderExt.setOrderType(EOrderType.REPURCHASE_ORDER.getValue()); | ||||||
|             saOrderExt.setOrderTypeExtend(orderParam.getOrderTypeExtend()); |             saOrderExt.setOrderTypeExtend(orderParam.getOrderTypeExtend()); | ||||||
|         } |         } | ||||||
|  | @ -1058,11 +1125,7 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|             saOrderExt.setOrderAssAchieve(ComputeUtil.computeAddMultiply(saOrderExt.getOrderAssAchieve(), saOrderItems.getAssAchievement(), saOrderItems.getQuantity())); |             saOrderExt.setOrderAssAchieve(ComputeUtil.computeAddMultiply(saOrderExt.getOrderAssAchieve(), saOrderItems.getAssAchievement(), saOrderItems.getQuantity())); | ||||||
|             productIdList.add(saOrderItems.getPkProduct()); |             productIdList.add(saOrderItems.getPkProduct()); | ||||||
|         }); |         }); | ||||||
| 
 |  | ||||||
|         if (CountryConstants.CHINA_COUNTRY.equals(saOrderExt.getPkCountry())) { |  | ||||||
|             // 中国金额四舍五入保留2位小数 |  | ||||||
|         saOrderExt.setOrderAmount(saOrderExt.getOrderAmount().setScale(2, RoundingMode.HALF_UP)); |         saOrderExt.setOrderAmount(saOrderExt.getOrderAmount().setScale(2, RoundingMode.HALF_UP)); | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         if (productIdList.size() > 0 && saOrderExt.getRecProvince() != null) { |         if (productIdList.size() > 0 && saOrderExt.getRecProvince() != null) { | ||||||
|             // 根据产品,先查看是否由仓库,有仓库的话修改仓库 |             // 根据产品,先查看是否由仓库,有仓库的话修改仓库 | ||||||
|  | @ -1663,8 +1726,7 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|     public boolean validateFirstOrder(Long pkParent, Integer pkCountry) { |     public boolean validateFirstOrder(Long pkParent, Integer pkCountry) { | ||||||
|         String validateFirstOrder = querySystemConfigByKey(pkCountry, ESystemConfig.FIRST_ORDER.getKey()); |         String validateFirstOrder = querySystemConfigByKey(pkCountry, ESystemConfig.FIRST_ORDER.getKey()); | ||||||
|         if (EYesNo.YES.getIntValue() == Integer.parseInt(validateFirstOrder)) { |         if (EYesNo.YES.getIntValue() == Integer.parseInt(validateFirstOrder)) { | ||||||
|             Integer count = queryCuMemberByPkMember(pkParent); |             return queryCuMemberByPkMember(pkParent) == 0; | ||||||
|             return count == 0; |  | ||||||
|         } |         } | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  | @ -1904,23 +1966,6 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|         log.info("在线支付回调接受的参数, order : {}", saOrderExt); |         log.info("在线支付回调接受的参数, order : {}", saOrderExt); | ||||||
|         saOrderExt.setPayType(EOrderPayType.ONLINE.getValue()); |         saOrderExt.setPayType(EOrderPayType.ONLINE.getValue()); | ||||||
| 
 | 
 | ||||||
| //        if (EOrderType.REGISTER_ORDER.getValue() == saOrderExt.getOrderType()) { |  | ||||||
| //            // 注册订单 |  | ||||||
| //            if (saOrderExt.getPkCreator().equals(saOrderExt.getPkMember())) { |  | ||||||
| //                // 自注册分享订单 |  | ||||||
| //                payShareSaOrder(saOrderExt); |  | ||||||
| //                return Boolean.TRUE; |  | ||||||
| //            } |  | ||||||
| //        } else if (EOrderType.REPURCHASE_ORDER.getValue() == saOrderExt.getOrderType()) { |  | ||||||
| //            // 复购订单 |  | ||||||
| //            // 判断是否消费过生成了会员 |  | ||||||
| //            CuMember cuMember = getCuMemberByKey(saOrderExt.getPkMember()); |  | ||||||
| //            if (cuMember == null) { |  | ||||||
| //                // 自注册分享订单 |  | ||||||
| //                payShareSaOrder(saOrderExt); |  | ||||||
| //                return Boolean.TRUE; |  | ||||||
| //            } |  | ||||||
| //        } |  | ||||||
|         CuMember newCuMember = null; |         CuMember newCuMember = null; | ||||||
|         if (saOrderExt.getPkMember() != null) { |         if (saOrderExt.getPkMember() != null) { | ||||||
|             newCuMember = getCuMemberByKey(saOrderExt.getPkMember()); |             newCuMember = getCuMemberByKey(saOrderExt.getPkMember()); | ||||||
|  | @ -1946,8 +1991,24 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|         } else { |         } else { | ||||||
|             // 其他订单 |             // 其他订单 | ||||||
|             if (EOrderType.REPURCHASE_ORDER.getValue() == saOrderExt.getOrderType() |             if (EOrderType.REPURCHASE_ORDER.getValue() == saOrderExt.getOrderType() | ||||||
|                     && EOrderTypeExtend.REG_REP.getValue() == saOrderExt.getOrderTypeExtend()) { |                     && EOrderTypeExtend.REG_REP.getValue().equals(saOrderExt.getOrderTypeExtend())) { | ||||||
|                 log.info("==========注册转复购=========="); |                 log.info("==========注册转复购=========="); | ||||||
|  |                 if (null != newCuMember) { | ||||||
|  |                     // 先注册0元会员,再购买注册订单,复购订单 扩展类型为 注册转复购 | ||||||
|  |                     OrderParam orderParam = redisService.getCacheObject(CacheConstants.TEMP_PARAM + pkMember + orderCode); | ||||||
|  |                     orderParam.setIsHaiFun(Boolean.TRUE); | ||||||
|  |                     orderParam.setOrderTypeExtend(saOrderExt.getOrderTypeExtend()); | ||||||
|  | 
 | ||||||
|  |                     // 会员等级使用缓存中已经计算好的 | ||||||
|  |                     newCuMember.setPkRegisterGrade(orderParam.getPkGrade()); | ||||||
|  |                     newCuMember.setPkSettleGrade(orderParam.getPkGrade()); | ||||||
|  | 
 | ||||||
|  |                     saOrderExt = packageWholeSaOrder(orderParam, newCuMember); | ||||||
|  |                     saOrderExt.setPayType(EOrderPayType.ONLINE.getValue()); | ||||||
|  |                     if (!payReyZeroOrder(saOrderExt, newCuMember)) { | ||||||
|  |                         throw new ServiceException("会员或订单处理失败"); | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|                     // 188分享订单,复购订单 扩展类型为 注册转复购 |                     // 188分享订单,复购订单 扩展类型为 注册转复购 | ||||||
|                     OrderParam orderParam = redisService.getCacheObject(CacheConstants.TEMP_PARAM + pkMember + orderCode); |                     OrderParam orderParam = redisService.getCacheObject(CacheConstants.TEMP_PARAM + pkMember + orderCode); | ||||||
|                     orderParam.setIsHaiFun(Boolean.TRUE); |                     orderParam.setIsHaiFun(Boolean.TRUE); | ||||||
|  | @ -1972,6 +2033,7 @@ public class SaOrderServiceImpl extends ServiceImpl<SaOrderMapper, SaOrder> impl | ||||||
|                         throw new RuntimeException("生成会员失败"); |                         throw new RuntimeException("生成会员失败"); | ||||||
|                     } |                     } | ||||||
|                     payRegSaOrder(saOrderExt, newCuMember, null, Boolean.TRUE); |                     payRegSaOrder(saOrderExt, newCuMember, null, Boolean.TRUE); | ||||||
|  |                 } | ||||||
|             } else { |             } else { | ||||||
|                 payRepurchaseSaOrder(saOrderExt, null); |                 payRepurchaseSaOrder(saOrderExt, null); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| package com.hzs.sale.product.controller.api; | package com.hzs.sale.product.controller.api; | ||||||
| 
 | 
 | ||||||
|  | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import cn.hutool.core.lang.tree.Tree; | import cn.hutool.core.lang.tree.Tree; | ||||||
| import cn.hutool.core.lang.tree.TreeNodeConfig; | import cn.hutool.core.lang.tree.TreeNodeConfig; | ||||||
| import cn.hutool.core.lang.tree.TreeUtil; | import cn.hutool.core.lang.tree.TreeUtil; | ||||||
|  | @ -25,24 +26,19 @@ import java.util.List; | ||||||
| public class ApiAreaClassifyController extends BaseController { | public class ApiAreaClassifyController extends BaseController { | ||||||
| 
 | 
 | ||||||
|     @Autowired |     @Autowired | ||||||
|     private IBdAreaClassifyService areaClassifyService; |     private IBdAreaClassifyService iBdAreaClassifyService; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 查询分类列表 |      * 查询分类列表 | ||||||
|      * |  | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     @GetMapping("list") |     @GetMapping("/list") | ||||||
|     public AjaxResult list(AreaClassifyParam areaClassifyParam) { |     public AjaxResult list(AreaClassifyParam areaClassifyParam) { | ||||||
|         areaClassifyParam.setEnableState(EYesNo.YES.getIntValue()); |         areaClassifyParam.setEnableState(EYesNo.YES.getIntValue()); | ||||||
|         Integer pkCountry; |         areaClassifyParam.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         if (areaClassifyParam.getPkCountry() != null) { |         List<AreaClassifyVo> list = iBdAreaClassifyService.selectByAreaClassifyList(areaClassifyParam); | ||||||
|             pkCountry = areaClassifyParam.getPkCountry(); |         if (CollectionUtil.isEmpty(list)) { | ||||||
|         } else { |             list.add(new AreaClassifyVo()); | ||||||
|             pkCountry = SecurityUtils.getPkCountry(); |  | ||||||
|         } |         } | ||||||
|         areaClassifyParam.setPkCountry(pkCountry); |  | ||||||
|         List<AreaClassifyVo> list = areaClassifyService.selectByAreaClassifyList(areaClassifyParam); |  | ||||||
|         return AjaxResult.success(list); |         return AjaxResult.success(list); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -50,25 +46,22 @@ public class ApiAreaClassifyController extends BaseController { | ||||||
|     /** |     /** | ||||||
|      * 查询第一层分类 |      * 查询第一层分类 | ||||||
|      */ |      */ | ||||||
|     @GetMapping("get-first-classify") |     @GetMapping("/get-first-classify") | ||||||
|     public AjaxResult getFirstClassify() { |     public AjaxResult getFirstClassify() { | ||||||
|         AreaClassifyParam areaClassifyParam = new AreaClassifyParam(); |         AreaClassifyParam areaClassifyParam = new AreaClassifyParam(); | ||||||
|         areaClassifyParam.setHierarchy(0); |         areaClassifyParam.setHierarchy(0); | ||||||
|         List<AreaClassifyVo> list = areaClassifyService.selectByAreaClassifyList(areaClassifyParam); |         List<AreaClassifyVo> list = iBdAreaClassifyService.selectByAreaClassifyList(areaClassifyParam); | ||||||
|         return AjaxResult.success(list); |         return AjaxResult.success(list); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 查询 |      * 查询 | ||||||
|      * |  | ||||||
|      * @param areaClassifyParam |  | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     @GetMapping("get-hierarchy-list") |     @GetMapping("/get-hierarchy-list") | ||||||
|     public AjaxResult getLevelList(AreaClassifyParam areaClassifyParam) { |     public AjaxResult getLevelList(AreaClassifyParam areaClassifyParam) { | ||||||
|         TreeNodeConfig treeNodeConfig = new TreeNodeConfig(); |         TreeNodeConfig treeNodeConfig = new TreeNodeConfig(); | ||||||
|         treeNodeConfig.setDeep(4); |         treeNodeConfig.setDeep(4); | ||||||
|         List<AreaClassifyVo> list = areaClassifyService.selectByAreaClassifyList(areaClassifyParam); |         List<AreaClassifyVo> list = iBdAreaClassifyService.selectByAreaClassifyList(areaClassifyParam); | ||||||
|         List<Tree<String>> build = TreeUtil.build(list, "0", treeNodeConfig, |         List<Tree<String>> build = TreeUtil.build(list, "0", treeNodeConfig, | ||||||
|                 (treeNode, tree) -> { |                 (treeNode, tree) -> { | ||||||
|                     tree.setId(treeNode.getPkId().toString()); |                     tree.setId(treeNode.getPkId().toString()); | ||||||
|  |  | ||||||
|  | @ -1,58 +1,42 @@ | ||||||
| package com.hzs.sale.product.controller.manage.params; | package com.hzs.sale.product.controller.manage.params; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.annotation.TableField; |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableId; |  | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| 
 | 
 | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** |  | ||||||
|  * @Description: |  | ||||||
|  * @Author: yuhui |  | ||||||
|  * @Time: 2022/11/1 14:48 |  | ||||||
|  * @Classname: AreaClassifyParam |  | ||||||
|  * @PackageName: com.hzs.sale.product.controller.manage.params |  | ||||||
|  */ |  | ||||||
| @Data | @Data | ||||||
| public class AreaClassifyParam { | public class AreaClassifyParam { | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 主键 |      * 主键 | ||||||
|      */ |      */ | ||||||
| 
 |  | ||||||
|     private Integer pkId; |     private Integer pkId; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 专区分类 |      * 专区分类 | ||||||
|      */ |      */ | ||||||
| 
 |  | ||||||
|     private String classifyName; |     private String classifyName; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 排序 |      * 排序 | ||||||
|      */ |      */ | ||||||
| 
 |  | ||||||
|     private Integer sort; |     private Integer sort; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 是否启用 |      * 是否启用 | ||||||
|      */ |      */ | ||||||
| 
 |  | ||||||
|     private Integer enableState; |     private Integer enableState; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 上级专区主键 |      * 上级专区主键 | ||||||
|      */ |      */ | ||||||
| 
 |  | ||||||
|     private Long pkParent; |     private Long pkParent; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 分类图片 |      * 分类图片 | ||||||
|      */ |      */ | ||||||
| 
 |  | ||||||
|     private String classifyImg; |     private String classifyImg; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -10,9 +10,6 @@ import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 商品分类 服务类 |  * 商品分类 服务类 | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  * @since 2022-09-05 |  | ||||||
|  */ |  */ | ||||||
| public interface IBdAreaClassifyService extends IService<BdAreaClassify> { | public interface IBdAreaClassifyService extends IService<BdAreaClassify> { | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,10 +3,7 @@ package com.hzs.sale.product.service.impl; | ||||||
| import cn.hutool.core.bean.BeanUtil; | import cn.hutool.core.bean.BeanUtil; | ||||||
| import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import com.hzs.common.core.domain.R; |  | ||||||
| import com.hzs.common.core.enums.EDelFlag; | import com.hzs.common.core.enums.EDelFlag; | ||||||
| import com.hzs.common.core.enums.ETransactionKey; |  | ||||||
| import com.hzs.common.core.enums.EYesNo; |  | ||||||
| import com.hzs.common.domain.sale.product.BdAreaClassify; | import com.hzs.common.domain.sale.product.BdAreaClassify; | ||||||
| import com.hzs.common.domain.sale.product.BdAreaClassifySpecialArea; | import com.hzs.common.domain.sale.product.BdAreaClassifySpecialArea; | ||||||
| import com.hzs.common.security.utils.SecurityUtils; | import com.hzs.common.security.utils.SecurityUtils; | ||||||
|  | @ -15,9 +12,7 @@ import com.hzs.sale.product.mapper.BdAreaClassifyMapper; | ||||||
| import com.hzs.sale.product.service.IBdAreaClassifyService; | import com.hzs.sale.product.service.IBdAreaClassifyService; | ||||||
| import com.hzs.sale.product.service.IBdAreaClassifySpecialAreaService; | import com.hzs.sale.product.service.IBdAreaClassifySpecialAreaService; | ||||||
| import com.hzs.sale.product.vo.AreaClassifyVo; | import com.hzs.sale.product.vo.AreaClassifyVo; | ||||||
| import com.hzs.system.base.ITransactionServiceApi; |  | ||||||
| import com.hzs.system.sys.dto.LoginUser; | import com.hzs.system.sys.dto.LoginUser; | ||||||
| import org.apache.dubbo.config.annotation.DubboReference; |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.transaction.annotation.Transactional; | import org.springframework.transaction.annotation.Transactional; | ||||||
|  | @ -36,8 +31,6 @@ public class BdAreaClassifyServiceImpl extends ServiceImpl<BdAreaClassifyMapper, | ||||||
|     private IBdAreaClassifyService iBdAreaClassifyService; |     private IBdAreaClassifyService iBdAreaClassifyService; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private IBdAreaClassifySpecialAreaService iBdAreaClassifySpecialAreaService; |     private IBdAreaClassifySpecialAreaService iBdAreaClassifySpecialAreaService; | ||||||
|     @DubboReference |  | ||||||
|     ITransactionServiceApi iTransactionServiceApi; |  | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     @Transactional(rollbackFor = Exception.class) |     @Transactional(rollbackFor = Exception.class) | ||||||
|  | @ -46,8 +39,6 @@ public class BdAreaClassifyServiceImpl extends ServiceImpl<BdAreaClassifyMapper, | ||||||
|         areaClassify.setPkCreator(loginUser.getUserId()); |         areaClassify.setPkCreator(loginUser.getUserId()); | ||||||
|         areaClassify.setCreationTime(new Date()); |         areaClassify.setCreationTime(new Date()); | ||||||
|         areaClassify.setPkCountry(loginUser.getDataCountry()); |         areaClassify.setPkCountry(loginUser.getDataCountry()); | ||||||
|         R<Integer> transaction = iTransactionServiceApi.createTransaction(loginUser.getDataCountry(), ETransactionKey.SPEC, areaClassify.getClassifyName(), EYesNo.NO, EYesNo.NO); |  | ||||||
|         areaClassify.setPkTransactionKey(transaction.getData()); |  | ||||||
|         baseMapper.insert(areaClassify); |         baseMapper.insert(areaClassify); | ||||||
|         List<BdAreaClassifySpecialArea> list = new ArrayList<>(); |         List<BdAreaClassifySpecialArea> list = new ArrayList<>(); | ||||||
|         if (areaClassifyParam.getSpecialAreaList() != null) { |         if (areaClassifyParam.getSpecialAreaList() != null) { | ||||||
|  | @ -73,8 +64,6 @@ public class BdAreaClassifyServiceImpl extends ServiceImpl<BdAreaClassifyMapper, | ||||||
|         BdAreaClassify areaClassify = BeanUtil.copyProperties(areaClassifyParam, BdAreaClassify.class); |         BdAreaClassify areaClassify = BeanUtil.copyProperties(areaClassifyParam, BdAreaClassify.class); | ||||||
|         areaClassify.setPkModified(loginUser.getUserId()); |         areaClassify.setPkModified(loginUser.getUserId()); | ||||||
|         areaClassify.setModifiedTime(new Date()); |         areaClassify.setModifiedTime(new Date()); | ||||||
|         R<Integer> transaction = iTransactionServiceApi.createTransaction(loginUser.getDataCountry(), ETransactionKey.SPEC, areaClassify.getClassifyName(), EYesNo.NO, EYesNo.NO); |  | ||||||
|         areaClassify.setPkTransactionKey(transaction.getData()); |  | ||||||
|         baseMapper.updateById(areaClassify); |         baseMapper.updateById(areaClassify); | ||||||
|         // 清空 中间表数据重新添加 |         // 清空 中间表数据重新添加 | ||||||
|         iBdAreaClassifySpecialAreaService.deleteByAreaClassifyPk(areaClassify.getPkId()); |         iBdAreaClassifySpecialAreaService.deleteByAreaClassifyPk(areaClassify.getPkId()); | ||||||
|  |  | ||||||
|  | @ -1,18 +1,12 @@ | ||||||
| package com.hzs.sale.product.vo; | package com.hzs.sale.product.vo; | ||||||
| 
 | 
 | ||||||
| import com.hzs.common.core.web.domain.BaseEntity; | import com.hzs.common.core.web.domain.BaseEntity; | ||||||
|  | import lombok.Builder; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.EqualsAndHashCode; | import lombok.EqualsAndHashCode; | ||||||
| 
 | 
 | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** |  | ||||||
|  * @Description: |  | ||||||
|  * @Author: yuhui |  | ||||||
|  * @Time: 2022/11/1 14:29 |  | ||||||
|  * @Classname: AreaClassifyVo |  | ||||||
|  * @PackageName: com.hzs.sale.product.vo |  | ||||||
|  */ |  | ||||||
| @EqualsAndHashCode(callSuper = true) | @EqualsAndHashCode(callSuper = true) | ||||||
| @Data | @Data | ||||||
| public class AreaClassifyVo extends BaseEntity { | public class AreaClassifyVo extends BaseEntity { | ||||||
|  |  | ||||||
|  | @ -3,6 +3,7 @@ package com.hzs.sale.shopping.controller.api; | ||||||
| import cn.hutool.core.collection.CollectionUtil; | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import cn.hutool.json.JSONUtil; | import cn.hutool.json.JSONUtil; | ||||||
| import com.hzs.common.core.constant.CacheConstants; | import com.hzs.common.core.constant.CacheConstants; | ||||||
|  | import com.hzs.common.core.enums.ESpecialArea; | ||||||
| import com.hzs.common.core.service.RedisService; | import com.hzs.common.core.service.RedisService; | ||||||
| import com.hzs.common.core.utils.StringUtils; | import com.hzs.common.core.utils.StringUtils; | ||||||
| import com.hzs.common.core.web.controller.BaseController; | import com.hzs.common.core.web.controller.BaseController; | ||||||
|  | @ -46,10 +47,11 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|         if (StringUtils.isNull(scr)) { |         if (StringUtils.isNull(scr)) { | ||||||
|             return AjaxResult.error("购物车为空"); |             return AjaxResult.error("购物车为空"); | ||||||
|         } |         } | ||||||
|         if (null == scr.getPkCountry() || scr.getPkCountry() == 0) { |  | ||||||
|         scr.setPkCountry(SecurityUtils.getPkCountry()); |         scr.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         } |         // 0元会员专区处理 | ||||||
|         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + SecurityUtils.getUserId(); |         scr.setSpecialArea(ESpecialArea.getMemberArea(scr.getSpecialArea())); | ||||||
|  | 
 | ||||||
|  |         String key = CacheConstants.SHOPPIN_GCART + scr.getPkCountry() + "_" + SecurityUtils.getUserId(); | ||||||
|         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); |         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); | ||||||
|         if (shoppingCartRedisMap == null) { |         if (shoppingCartRedisMap == null) { | ||||||
|             shoppingCartRedisMap = new HashMap<>(); |             shoppingCartRedisMap = new HashMap<>(); | ||||||
|  | @ -92,10 +94,11 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/getShopping") |     @GetMapping("/getShopping") | ||||||
|     public AjaxResult getShopping(ShoppingCartVO shoppingCartVO) { |     public AjaxResult getShopping(ShoppingCartVO shoppingCartVO) { | ||||||
|         if (shoppingCartVO.getSpecialArea() == null || shoppingCartVO.getPkCountry() == null) { |  | ||||||
|         shoppingCartVO.setPkCountry(SecurityUtils.getPkCountry()); |         shoppingCartVO.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         } |         // 0元会员专区处理 | ||||||
|         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + SecurityUtils.getUserId(); |         shoppingCartVO.setSpecialArea(ESpecialArea.getMemberArea(shoppingCartVO.getSpecialArea())); | ||||||
|  | 
 | ||||||
|  |         String key = CacheConstants.SHOPPIN_GCART + shoppingCartVO.getPkCountry() + "_" + SecurityUtils.getUserId(); | ||||||
|         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); |         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); | ||||||
|         List<ShoppingCartVO> shoppingCartOld; |         List<ShoppingCartVO> shoppingCartOld; | ||||||
|         if (shoppingCartRedisMap.containsKey(key)) { |         if (shoppingCartRedisMap.containsKey(key)) { | ||||||
|  | @ -114,10 +117,11 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/getShoppingCount") |     @GetMapping("/getShoppingCount") | ||||||
|     public AjaxResult getShoppingCount(ShoppingCartVO shoppingCartVO) { |     public AjaxResult getShoppingCount(ShoppingCartVO shoppingCartVO) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |  | ||||||
|         if (null == shoppingCartVO.getPkCountry()) { |  | ||||||
|         shoppingCartVO.setPkCountry(SecurityUtils.getPkCountry()); |         shoppingCartVO.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         } |         // 0元会员专区处理 | ||||||
|  |         shoppingCartVO.setSpecialArea(ESpecialArea.getMemberArea(shoppingCartVO.getSpecialArea())); | ||||||
|  | 
 | ||||||
|  |         Long userId = SecurityUtils.getUserId(); | ||||||
|         int count = 0; |         int count = 0; | ||||||
|         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + userId; |         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + userId; | ||||||
|         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); |         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); | ||||||
|  | @ -166,11 +170,12 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|     @GetMapping("/getAreaShoppingCount") |     @GetMapping("/getAreaShoppingCount") | ||||||
|     public AjaxResult getAreaShoppingCount(ShoppingCartVO shoppingCartVO) { |     public AjaxResult getAreaShoppingCount(ShoppingCartVO shoppingCartVO) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SecurityUtils.getUserId(); | ||||||
|         if (null == shoppingCartVO.getPkCountry()) { |  | ||||||
|         shoppingCartVO.setPkCountry(SecurityUtils.getPkCountry()); |         shoppingCartVO.setPkCountry(SecurityUtils.getPkCountry()); | ||||||
|         } |         // 0元会员专区处理 | ||||||
|  |         shoppingCartVO.setSpecialArea(ESpecialArea.getMemberArea(shoppingCartVO.getSpecialArea())); | ||||||
|  | 
 | ||||||
|         int smallCount = 0; |         int smallCount = 0; | ||||||
|         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + userId; |         String key = CacheConstants.SHOPPIN_GCART + shoppingCartVO.getPkCountry() + "_" + userId; | ||||||
|         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); |         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); | ||||||
|         if (shoppingCartRedisMap == null) { |         if (shoppingCartRedisMap == null) { | ||||||
|             shoppingCartRedisMap = new HashMap<>(); |             shoppingCartRedisMap = new HashMap<>(); | ||||||
|  | @ -235,9 +240,6 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|      */ |      */ | ||||||
|     @PostMapping("/plusReduceShopping") |     @PostMapping("/plusReduceShopping") | ||||||
|     public AjaxResult plusReduceShopping(@RequestBody ShoppingCartRedis scr) { |     public AjaxResult plusReduceShopping(@RequestBody ShoppingCartRedis scr) { | ||||||
|         if (null == scr.getPkCountry()) { |  | ||||||
|             scr.setPkCountry(SecurityUtils.getPkCountry()); |  | ||||||
|         } |  | ||||||
|         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + SecurityUtils.getUserId(); |         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + SecurityUtils.getUserId(); | ||||||
|         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); |         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); | ||||||
|         if (shoppingCartRedisMap != null) { |         if (shoppingCartRedisMap != null) { | ||||||
|  | @ -268,9 +270,9 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|      */ |      */ | ||||||
|     @PostMapping("/get-shopping-wares-detail") |     @PostMapping("/get-shopping-wares-detail") | ||||||
|     public AjaxResult getShoppingWaresDetail(@RequestBody CarWaresInfoParam scr) { |     public AjaxResult getShoppingWaresDetail(@RequestBody CarWaresInfoParam scr) { | ||||||
|         if (null == scr.getPkCountry()) { |         // 0元会员专区处理 | ||||||
|             scr.setPkCountry(SecurityUtils.getPkCountry()); |         scr.setSpecialArea(ESpecialArea.getMemberArea(scr.getSpecialArea())); | ||||||
|         } | 
 | ||||||
|         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + SecurityUtils.getUserId(); |         String key = CacheConstants.SHOPPIN_GCART + SecurityUtils.getPkCountry() + "_" + SecurityUtils.getUserId(); | ||||||
|         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); |         Map<String, Object> shoppingCartRedisMap = redisService.getCacheMap(key); | ||||||
|         CarWaresInfoVo carWaresInfoVo = new CarWaresInfoVo(); |         CarWaresInfoVo carWaresInfoVo = new CarWaresInfoVo(); | ||||||
|  | @ -308,4 +310,5 @@ public class ApiShoppingCartController extends BaseController { | ||||||
|         carWaresInfoVo.setAssAchieveAmount(assAchieveAmount); |         carWaresInfoVo.setAssAchieveAmount(assAchieveAmount); | ||||||
|         return AjaxResult.success(carWaresInfoVo); |         return AjaxResult.success(carWaresInfoVo); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -11,13 +11,10 @@ public class CarWaresInfoParam { | ||||||
|      * 专区 |      * 专区 | ||||||
|      */ |      */ | ||||||
|     private Integer specialArea; |     private Integer specialArea; | ||||||
|     /** |  | ||||||
|      * 国家(用于跨国报单) |  | ||||||
|      */ |  | ||||||
|     private Integer pkCountry; |  | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 购物车项 |      * 购物车项 | ||||||
|      */ |      */ | ||||||
|     private List<String> shoppingIds; |     private List<String> shoppingIds; | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -9,11 +9,7 @@ import java.io.Serializable; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * @Description: 购物车实体类 |  * 购物车实体类 | ||||||
|  * @Author: zhangjing |  | ||||||
|  * @Time: 2022/9/16 11:11 |  | ||||||
|  * @Classname: ShoppingCartVO |  | ||||||
|  * @PackageName: com.hzs.common.domain.sale.ext |  | ||||||
|  */ |  */ | ||||||
| @Data | @Data | ||||||
| @Builder | @Builder | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ import cn.hutool.core.bean.BeanUtil; | ||||||
| import cn.hutool.core.codec.Base64Decoder; | import cn.hutool.core.codec.Base64Decoder; | ||||||
| import cn.hutool.core.collection.CollectionUtil; | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import cn.hutool.core.date.DateUtil; | import cn.hutool.core.date.DateUtil; | ||||||
|  | import cn.hutool.core.util.ObjectUtil; | ||||||
| import com.alibaba.fastjson.JSONObject; | import com.alibaba.fastjson.JSONObject; | ||||||
| import com.alibaba.fastjson2.JSONArray; | import com.alibaba.fastjson2.JSONArray; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
|  | @ -93,23 +94,22 @@ public class ApiBdWaresController extends BaseController { | ||||||
|      * @param cuWaresParams 专区、分类 |      * @param cuWaresParams 专区、分类 | ||||||
|      */ |      */ | ||||||
|     @RequestMapping("/query-spe-wares") |     @RequestMapping("/query-spe-wares") | ||||||
|     public AjaxResult queryWaresBySpecial(@RequestBody CuWaresParams cuWaresParams) { |     public AjaxResult rqueryWaresBySpecial(@RequestBody CuWaresParams cuWaresParams) { | ||||||
|         if (null == cuWaresParams.getSpecialArea()) { |         if (null == cuWaresParams.getSpecialArea()) { | ||||||
|             return AjaxResult.error(SaOrderMsgConstants.SPECIAL_AREA_NOT_EMPTY); |             return AjaxResult.error("所属专区不能为空"); | ||||||
|         } |         } | ||||||
| 
 |         Integer pkCountry = SecurityUtils.getPkCountry(); | ||||||
|         Integer pkCountry; |  | ||||||
|         if (cuWaresParams.getPkCountry() != null) { |  | ||||||
|             pkCountry = cuWaresParams.getPkCountry(); |  | ||||||
|         } else { |  | ||||||
|             pkCountry = SecurityUtils.getPkCountry(); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // 返回数据 |         // 返回数据 | ||||||
|         List<CuWaresParams> waresParamsList = new ArrayList<>(); |         List<CuWaresParams> waresParamsList = new ArrayList<>(); | ||||||
| 
 | 
 | ||||||
|         // 查询商品列表 |         // 查询商品列表 | ||||||
|         List<BdWaresExt> bdWaresExtList = iBdWaresService.queryWaresByCondition(cuWaresParams.getSpecialArea(), cuWaresParams.getPkAreaClassify(), cuWaresParams.getWaresName(), null, null, pkCountry); |         List<BdWaresExt> bdWaresExtList; | ||||||
|  |         if (ESpecialArea.MEMBER_AREA.getValue() == cuWaresParams.getSpecialArea()) { | ||||||
|  |             // 0元注册会员专区,只查询注册专区的188商品 | ||||||
|  |             bdWaresExtList = iBdWaresService.listWaresShare(ESpecialArea.REGISTER_AREA.getValue(), EWaresType.PRODUCT_188.getValue(), CountryConstants.CHINA_COUNTRY, cuWaresParams.getWaresName()); | ||||||
|  |         } else { | ||||||
|  |             bdWaresExtList = iBdWaresService.queryWaresByCondition(cuWaresParams.getSpecialArea(), cuWaresParams.getPkAreaClassify(), cuWaresParams.getWaresName(), null, null, pkCountry); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         if (CollectionUtil.isNotEmpty(bdWaresExtList)) { |         if (CollectionUtil.isNotEmpty(bdWaresExtList)) { | ||||||
|             // 当前会员ID |             // 当前会员ID | ||||||
|  | @ -118,10 +118,6 @@ public class ApiBdWaresController extends BaseController { | ||||||
|             // 当前会员编号 |             // 当前会员编号 | ||||||
|             String memberCode = cuMember.getMemberCode(); |             String memberCode = cuMember.getMemberCode(); | ||||||
| 
 | 
 | ||||||
|             // 汇率比例 |  | ||||||
|             R<CurrencyDTO> currency = iCurrencyServiceApi.getCurrency(SecurityUtils.getPkCountry()); |  | ||||||
|             BigDecimal inExchangeRate = currency.getData().getInExchangeRate(); |  | ||||||
| 
 |  | ||||||
|             // 商品主键列表 |             // 商品主键列表 | ||||||
|             List<Integer> waresIdList = bdWaresExtList.stream().map(BdWares::getPkId).collect(Collectors.toList()); |             List<Integer> waresIdList = bdWaresExtList.stream().map(BdWares::getPkId).collect(Collectors.toList()); | ||||||
|             // 检验商品团队信息 |             // 检验商品团队信息 | ||||||
|  | @ -251,14 +247,6 @@ public class ApiBdWaresController extends BaseController { | ||||||
|                         // 零售价 |                         // 零售价 | ||||||
|                         retailPrice = retailPrice.add(bdWaresSpecsSkuExt.getRetailPrice().multiply(BigDecimal.valueOf(bdWaresSpecsSkuExt.getQuantity()))); |                         retailPrice = retailPrice.add(bdWaresSpecsSkuExt.getRetailPrice().multiply(BigDecimal.valueOf(bdWaresSpecsSkuExt.getQuantity()))); | ||||||
|                     } |                     } | ||||||
|                     if (cuWaresParams.getPkCountry() != null && !pkCountry.equals(SecurityUtils.getPkCountry())) { |  | ||||||
|                         // 当登陆人的结算国和前端结算国不一致 即为跨国报单 |  | ||||||
|                         if (!pkCountry.equals(SecurityUtils.getPkCountry())) { |  | ||||||
|                             // 跨国报单 跨国汇率 |  | ||||||
|                             R<CurrencyDTO> kgCurrency = iCurrencyServiceApi.getCurrency(pkCountry); |  | ||||||
|                             waresPrice = waresPrice.multiply(inExchangeRate).divide(kgCurrency.getData().getInExchangeRate(), 2, BigDecimal.ROUND_HALF_UP); |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 // 计算商品列表价格和业绩最小值 |                 // 计算商品列表价格和业绩最小值 | ||||||
|  | @ -269,12 +257,8 @@ public class ApiBdWaresController extends BaseController { | ||||||
|                 waresParams.setRetailPrice(retailPrice); |                 waresParams.setRetailPrice(retailPrice); | ||||||
|                 // 商品业绩计算汇率 |                 // 商品业绩计算汇率 | ||||||
|                 if (waresParams.getWaresAchieve() != null) { |                 if (waresParams.getWaresAchieve() != null) { | ||||||
|                     if (SecurityUtils.getPkCountry().equals(CountryConstants.CHINA_COUNTRY)) { |  | ||||||
|                         waresParams.setWaresAchieve(waresParams.getWaresAchieve().multiply(inExchangeRate)); |  | ||||||
|                     } else { |  | ||||||
|                     waresParams.setWaresAchieve(waresParams.getWaresAchieve()); |                     waresParams.setWaresAchieve(waresParams.getWaresAchieve()); | ||||||
|                     waresParams.setWaresPrice(waresParams.getWaresPrice()); |                     waresParams.setWaresPrice(waresParams.getWaresPrice()); | ||||||
|                     } |  | ||||||
|                 } else { |                 } else { | ||||||
|                     waresParams.setWaresAchieve(BigDecimal.ZERO); |                     waresParams.setWaresAchieve(BigDecimal.ZERO); | ||||||
|                     waresParams.setWaresPrice(BigDecimal.ZERO); |                     waresParams.setWaresPrice(BigDecimal.ZERO); | ||||||
|  | @ -295,6 +279,15 @@ public class ApiBdWaresController extends BaseController { | ||||||
|                 Integer inventory = waresExt.getInventory(); |                 Integer inventory = waresExt.getInventory(); | ||||||
|                 Integer inventoryRatio = waresExt.getInventoryRatio(); |                 Integer inventoryRatio = waresExt.getInventoryRatio(); | ||||||
|                 Integer inventoryUse = waresExt.getInventoryUse(); |                 Integer inventoryUse = waresExt.getInventoryUse(); | ||||||
|  |                 if(ObjectUtil.isEmpty(inventory)){ | ||||||
|  |                     inventory = 0; | ||||||
|  |                 } | ||||||
|  |                 if(ObjectUtil.isEmpty(inventoryUse)){ | ||||||
|  |                     inventoryUse = 0; | ||||||
|  |                 } | ||||||
|  |                 if(ObjectUtil.isEmpty(inventoryRatio)){ | ||||||
|  |                     inventoryRatio = 0; | ||||||
|  |                 } | ||||||
|                 int ratio = 100 - (int) Math.round(NumberUtil.getRatioNum(inventory, inventoryUse)); |                 int ratio = 100 - (int) Math.round(NumberUtil.getRatioNum(inventory, inventoryUse)); | ||||||
|                 if (ratio <= inventoryRatio) { |                 if (ratio <= inventoryRatio) { | ||||||
|                     waresParams.setUseRatio(true); |                     waresParams.setUseRatio(true); | ||||||
|  | @ -371,11 +364,11 @@ public class ApiBdWaresController extends BaseController { | ||||||
|      * @param pkWares |      * @param pkWares | ||||||
|      * @return |      * @return | ||||||
|      */ |      */ | ||||||
|     public ShowWaresDTO getShowWares(Integer pkWares, Long loginMember, String loginMemberCode, Map<Integer, List<BdWaresAuthority>> waresAuthorityMap) { |     public ShowWaresDTO getShowWares(Integer pkWares, Long pkMember, String memberCode, Map<Integer, List<BdWaresAuthority>> waresAuthorityMap) { | ||||||
|         ShowWaresDTO showWaresDTO = new ShowWaresDTO(); |         ShowWaresDTO showWaresDTO = new ShowWaresDTO(); | ||||||
|         showWaresDTO.setPkWares(pkWares); |         showWaresDTO.setPkWares(pkWares); | ||||||
|         showWaresDTO.setLoginMember(loginMember); |         showWaresDTO.setLoginMember(pkMember); | ||||||
|         showWaresDTO.setLoginMemberCode(loginMemberCode); |         showWaresDTO.setLoginMemberCode(memberCode); | ||||||
|         showWaresDTO.setWaresAuthorityList(waresAuthorityMap.get(pkWares)); |         showWaresDTO.setWaresAuthorityList(waresAuthorityMap.get(pkWares)); | ||||||
|         return showWaresDTO; |         return showWaresDTO; | ||||||
|     } |     } | ||||||
|  | @ -394,12 +387,8 @@ public class ApiBdWaresController extends BaseController { | ||||||
|             return AjaxResult.error(WaresMsgConstants.WARES_NUMBER_DOES_NOT_EXIST); |             return AjaxResult.error(WaresMsgConstants.WARES_NUMBER_DOES_NOT_EXIST); | ||||||
|         } |         } | ||||||
|         Long loginMemberId = SecurityUtils.getUserId(); |         Long loginMemberId = SecurityUtils.getUserId(); | ||||||
|         Integer pkCountry; |         Integer pkCountry = SecurityUtils.getPkCountry(); | ||||||
|         if (cuWaresParams.getPkCountry() == null) { | 
 | ||||||
|             pkCountry = SecurityUtils.getPkCountry(); |  | ||||||
|         } else { |  | ||||||
|             pkCountry = cuWaresParams.getPkCountry(); |  | ||||||
|         } |  | ||||||
|         cuWaresParams = iBdWaresSpecsSkuService.queryWaresSpecsSku(cuWaresParams.getSpecialArea(), cuWaresParams.getWaresCode(), loginMemberId, pkCountry); |         cuWaresParams = iBdWaresSpecsSkuService.queryWaresSpecsSku(cuWaresParams.getSpecialArea(), cuWaresParams.getWaresCode(), loginMemberId, pkCountry); | ||||||
| 
 | 
 | ||||||
|         // 预计发货时间(秒) |         // 预计发货时间(秒) | ||||||
|  | @ -486,26 +475,6 @@ public class ApiBdWaresController extends BaseController { | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/get-app-index") |     @GetMapping("/get-app-index") | ||||||
|     public AjaxResult getAppIndex() { |     public AjaxResult getAppIndex() { | ||||||
| //        Integer pkCountry = SecurityUtils.getPkCountry(); |  | ||||||
| //        Long userId = SecurityUtils.getUserId(); |  | ||||||
| //        String memberCode = SecurityUtils.getMemberCode(); |  | ||||||
| //        // 校验产品团队信息(查询所有推荐商品) |  | ||||||
| //        List<BdWaresExt> bdWaresList = iBdWaresService.queryByRecommendList(null, EYesNo.YES.getIntValue(), pkCountry, new HashMap<>()); |  | ||||||
| //        Map<Integer, Boolean> waresShowMap = new HashMap<>(); |  | ||||||
| //        if (bdWaresList.size() > 0) { |  | ||||||
| //            // 检验商品团队信息 |  | ||||||
| //            List<Integer> waresIdList = bdWaresList.stream().map(BdWares::getPkId).collect(Collectors.toList()); |  | ||||||
| //            Map<Integer, List<BdWaresAuthority>> waresAuthorityMap = iBdWaresService.getWaresAuthority(waresIdList); |  | ||||||
| //            List<ShowWaresDTO> showWaresList = bdWaresList.stream().map(we -> getShowWares(we.getPkId(), userId, memberCode, waresAuthorityMap)).collect(Collectors.toList()); |  | ||||||
| //            R<Map<Integer, Boolean>> waresShowMapDto = iMemberServiceApi.checkIsShowWares(showWaresList); |  | ||||||
| //            waresShowMap = waresShowMapDto.getData(); |  | ||||||
| //        } |  | ||||||
| //        // 查询app端首页商品展示信息 |  | ||||||
| //        RecommendWaresInfoVo recommendWaresInfoVo = iBdWaresService.queryRecommendInfo(pkCountry, memberCode, userId, waresShowMap); |  | ||||||
| //        if (recommendWaresInfoVo.getWaresVoList() != null) { |  | ||||||
| //            List<WaresVo> waresList = new ArrayList<>(recommendWaresInfoVo.getWaresVoList()); |  | ||||||
| //            recommendWaresInfoVo.setWaresVoList(waresList); |  | ||||||
| //        } |  | ||||||
|         RecommendWaresInfoVo recommendWaresInfoVo = new RecommendWaresInfoVo(); |         RecommendWaresInfoVo recommendWaresInfoVo = new RecommendWaresInfoVo(); | ||||||
|         // 查询全部的banner (登录后banner) |         // 查询全部的banner (登录后banner) | ||||||
|         R<List<AdvertBannerDTO>> advertBannerList = advertBannerServiceApi.findAll(SecurityUtils.getUserId()); |         R<List<AdvertBannerDTO>> advertBannerList = advertBannerServiceApi.findAll(SecurityUtils.getUserId()); | ||||||
|  | @ -769,7 +738,7 @@ public class ApiBdWaresController extends BaseController { | ||||||
|         List<CuWaresParams> waresParamsList = new ArrayList<>(); |         List<CuWaresParams> waresParamsList = new ArrayList<>(); | ||||||
| 
 | 
 | ||||||
|         // 查询商品列表 |         // 查询商品列表 | ||||||
|         List<BdWaresExt> bdWaresExtList = iBdWaresService.listWaresShare(param.getSpecialArea(), param.getIsMakerGift(), param.getPkCountry()); |         List<BdWaresExt> bdWaresExtList = iBdWaresService.listWaresShare(param.getSpecialArea(), param.getIsMakerGift(), param.getPkCountry(), null); | ||||||
| 
 | 
 | ||||||
|         if (CollectionUtil.isNotEmpty(bdWaresExtList)) { |         if (CollectionUtil.isNotEmpty(bdWaresExtList)) { | ||||||
|             // 商品主键列表 |             // 商品主键列表 | ||||||
|  |  | ||||||
|  | @ -49,7 +49,8 @@ public interface BdWaresMapper extends BaseMapper<BdWares> { | ||||||
|      */ |      */ | ||||||
|     List<BdWaresExt> listWaresShare(@Param("specialArea") Integer specialArea, |     List<BdWaresExt> listWaresShare(@Param("specialArea") Integer specialArea, | ||||||
|                                     @Param("isMakerGift") Integer isMakerGift, |                                     @Param("isMakerGift") Integer isMakerGift, | ||||||
|                                     @Param("pkCountry") Integer pkCountry); |                                     @Param("pkCountry") Integer pkCountry, | ||||||
|  |                                     @Param("waresName") String waresName); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 查询最末商品编号 |      * 查询最末商品编号 | ||||||
|  |  | ||||||
|  | @ -98,7 +98,7 @@ public interface IBdWaresService extends IService<BdWares> { | ||||||
|      * @param pkCountry   所属国家 |      * @param pkCountry   所属国家 | ||||||
|      * @return: List<BdWaresExt> |      * @return: List<BdWaresExt> | ||||||
|      */ |      */ | ||||||
|     List<BdWaresExt> listWaresShare(Integer specialArea, Integer isMakerGift, Integer pkCountry); |     List<BdWaresExt> listWaresShare(Integer specialArea, Integer isMakerGift, Integer pkCountry, String waresName); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 查询商品外键 |      * 查询商品外键 | ||||||
|  |  | ||||||
|  | @ -841,8 +841,8 @@ public class BdWaresServiceImpl extends ServiceImpl<BdWaresMapper, BdWares> impl | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public List<BdWaresExt> listWaresShare(Integer specialArea, Integer isMakerGift, Integer pkCountry) { |     public List<BdWaresExt> listWaresShare(Integer specialArea, Integer isMakerGift, Integer pkCountry, String waresName) { | ||||||
|         return baseMapper.listWaresShare(specialArea, isMakerGift, pkCountry); |         return baseMapper.listWaresShare(specialArea, isMakerGift, pkCountry, waresName); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|  | @ -1213,6 +1213,48 @@ public class BdWaresServiceImpl extends ServiceImpl<BdWaresMapper, BdWares> impl | ||||||
|         // 登录用户 |         // 登录用户 | ||||||
|         CuMemberExt loginMember = iMemberServiceApi.getMemberById(userId).getData(); |         CuMemberExt loginMember = iMemberServiceApi.getMemberById(userId).getData(); | ||||||
| 
 | 
 | ||||||
|  |         RecommendWaresInfoVo recommendWaresInfoVo = new RecommendWaresInfoVo(); | ||||||
|  |         // 推荐专区 | ||||||
|  |         List<RecommendSpecialAreaVo> resultList = new ArrayList<>(); | ||||||
|  | 
 | ||||||
|  |         if (null == loginMember.getPkPlaceParent()) { | ||||||
|  |             // 0元注册会员,没有上树,没有安置关系 | ||||||
|  |             // 查询商品列表 | ||||||
|  |             List<BdWaresExt> bdWaresExtList = this.listWaresShare(ESpecialArea.REGISTER_AREA.getValue(), EWaresType.PRODUCT_188.getValue(), CountryConstants.CHINA_COUNTRY, null); | ||||||
|  | 
 | ||||||
|  |             if (CollectionUtil.isNotEmpty(bdWaresExtList)) { | ||||||
|  |                 RecommendSpecialAreaVo recommendSpecialAreaVo = RecommendSpecialAreaVo.builder() | ||||||
|  |                         .specialArea(ESpecialArea.MEMBER_AREA.getValue()) | ||||||
|  |                         .specialAreaName(ESpecialArea.MEMBER_AREA.getLabel()) | ||||||
|  |                         .sort(ESpecialArea.MEMBER_AREA.getSort()) | ||||||
|  |                         .build(); | ||||||
|  |                 resultList.add(recommendSpecialAreaVo); | ||||||
|  | 
 | ||||||
|  |                 List<BdWaresExt> filterList = new ArrayList<>(); | ||||||
|  |                 for (BdWaresExt bdWaresExt : bdWaresExtList) { | ||||||
|  |                     if (filterList.size() > 2) { | ||||||
|  |                         break; | ||||||
|  |                     } else { | ||||||
|  |                         filterList.add(bdWaresExt); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 List<WaresVo> waresVoList = filterList.stream().map(wl -> { | ||||||
|  |                     WaresVo waresVo = new WaresVo(); | ||||||
|  |                     waresVo.setPkWares(wl.getPkId()); | ||||||
|  |                     waresVo.setWaresCode(wl.getWaresCode()); | ||||||
|  |                     waresVo.setWaresName(wl.getWaresName()); | ||||||
|  |                     waresVo.setWaresPrice(wl.getWaresPrice()); | ||||||
|  |                     waresVo.setCover(wl.getCover()); | ||||||
|  |                     waresVo.setCover1(wl.getCover1()); | ||||||
|  |                     waresVo.setIsSale(wl.getIsSale()); | ||||||
|  |                     waresVo.setPreSaleStatus(wl.getPreSaleStatus()); | ||||||
|  |                     waresVo.setSpecialArea(wl.getSpecialArea()); | ||||||
|  |                     return waresVo; | ||||||
|  |                 }).collect(Collectors.toList()); | ||||||
|  |                 recommendSpecialAreaVo.setWaresList(waresVoList); | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|             // 续约标记 -- 会员还有3月到期,需要能看到续约专区 |             // 续约标记 -- 会员还有3月到期,需要能看到续约专区 | ||||||
|             boolean expireFlag = false; |             boolean expireFlag = false; | ||||||
|             if (null != loginMember.getExpireDate()) { |             if (null != loginMember.getExpireDate()) { | ||||||
|  | @ -1262,9 +1304,6 @@ public class BdWaresServiceImpl extends ServiceImpl<BdWaresMapper, BdWares> impl | ||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|         RecommendWaresInfoVo recommendWaresInfoVo = new RecommendWaresInfoVo(); |  | ||||||
|         // 推荐专区 |  | ||||||
|         List<RecommendSpecialAreaVo> resultList = new ArrayList<>(); |  | ||||||
|             for (Integer specialArea : specialAreaList) { |             for (Integer specialArea : specialAreaList) { | ||||||
|                 ESpecialArea sArea = ESpecialArea.getESpecialAreaEnum(specialArea); |                 ESpecialArea sArea = ESpecialArea.getESpecialAreaEnum(specialArea); | ||||||
|                 if (sArea != null) { |                 if (sArea != null) { | ||||||
|  | @ -1283,7 +1322,7 @@ public class BdWaresServiceImpl extends ServiceImpl<BdWaresMapper, BdWares> impl | ||||||
| 
 | 
 | ||||||
|                         List<BdWaresExt> filterList = new ArrayList<>(); |                         List<BdWaresExt> filterList = new ArrayList<>(); | ||||||
|                         // 推荐商品,TODO 此处查询推荐商品,可以先全查出来在内存进行分专区处理,后续有时间可以优化 |                         // 推荐商品,TODO 此处查询推荐商品,可以先全查出来在内存进行分专区处理,后续有时间可以优化 | ||||||
|                     List<BdWaresExt> waresList = this.queryByRecommendList(specialArea, EYesNo.YES.getIntValue(), pkCountry, waresShowMap); |                         List<BdWaresExt> waresList = this.queryByRecommendList(specialArea, null, pkCountry, waresShowMap); | ||||||
|                         if (CollectionUtil.isNotEmpty(waresList)) { |                         if (CollectionUtil.isNotEmpty(waresList)) { | ||||||
|                             for (BdWaresExt waresExt : waresList) { |                             for (BdWaresExt waresExt : waresList) { | ||||||
|                                 if (waresIdSet.contains(waresExt.getPkId())) { |                                 if (waresIdSet.contains(waresExt.getPkId())) { | ||||||
|  | @ -1330,9 +1369,10 @@ public class BdWaresServiceImpl extends ServiceImpl<BdWaresMapper, BdWares> impl | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 |             //  根据专区排序(按照指定排序排序: 注冊 升级 复购) | ||||||
|         //  根据专区排序(按照指定排序排序: 注冊 升级 复购 自营 海粉 嗨粉) |  | ||||||
|             resultList.sort(Comparator.comparingInt(RecommendSpecialAreaVo::getSort)); |             resultList.sort(Comparator.comparingInt(RecommendSpecialAreaVo::getSort)); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         recommendWaresInfoVo.setRecommendSpecialAreaList(resultList); |         recommendWaresInfoVo.setRecommendSpecialAreaList(resultList); | ||||||
|         return recommendWaresInfoVo; |         return recommendWaresInfoVo; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -65,6 +65,10 @@ public class BdWaresSpecsSkuServiceImpl extends ServiceImpl<BdWaresSpecsSkuMappe | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public CuWaresParams queryWaresSpecsSku(Integer specialArea, String waresCode, Long loginMemberId, Integer pkCountry) { |     public CuWaresParams queryWaresSpecsSku(Integer specialArea, String waresCode, Long loginMemberId, Integer pkCountry) { | ||||||
|  |         // 0元会员专区处理 | ||||||
|  |         final Integer tmpArea = specialArea; | ||||||
|  |         specialArea = ESpecialArea.getMemberArea(specialArea); | ||||||
|  | 
 | ||||||
|         List<BdWaresSpecsSkuExt> bdWaresSpecsSkuExtList; |         List<BdWaresSpecsSkuExt> bdWaresSpecsSkuExtList; | ||||||
| 
 | 
 | ||||||
|         R<CuMember> memberDate = iMemberServiceApi.getMember(loginMemberId); |         R<CuMember> memberDate = iMemberServiceApi.getMember(loginMemberId); | ||||||
|  | @ -169,7 +173,7 @@ public class BdWaresSpecsSkuServiceImpl extends ServiceImpl<BdWaresSpecsSkuMappe | ||||||
|             productParams.clear(); |             productParams.clear(); | ||||||
|             productParams.addAll(productParamsResultList); |             productParams.addAll(productParamsResultList); | ||||||
|             cuWaresParams.setProductParams(productParams); |             cuWaresParams.setProductParams(productParams); | ||||||
|             cuWaresParams.setSpecialArea(specialArea); |             cuWaresParams.setSpecialArea(tmpArea); | ||||||
| 
 | 
 | ||||||
|             Integer inventory = sku.getInventory(); |             Integer inventory = sku.getInventory(); | ||||||
|             Integer inventoryRatio = sku.getInventoryRatio(); |             Integer inventoryRatio = sku.getInventoryRatio(); | ||||||
|  |  | ||||||
|  | @ -1,9 +1,15 @@ | ||||||
| package com.hzs.sale.wares.vo; | package com.hzs.sale.wares.vo; | ||||||
| 
 | 
 | ||||||
|  | import lombok.AllArgsConstructor; | ||||||
|  | import lombok.Builder; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  | import lombok.NoArgsConstructor; | ||||||
| 
 | 
 | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
|  | @Builder | ||||||
|  | @AllArgsConstructor | ||||||
|  | @NoArgsConstructor | ||||||
| @Data | @Data | ||||||
| public class RecommendSpecialAreaVo { | public class RecommendSpecialAreaVo { | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -5,7 +5,6 @@ | ||||||
|     <!-- 通用查询映射结果 --> |     <!-- 通用查询映射结果 --> | ||||||
|     <resultMap id="BaseResultMap" type="com.hzs.common.domain.sale.product.BdAreaClassify"> |     <resultMap id="BaseResultMap" type="com.hzs.common.domain.sale.product.BdAreaClassify"> | ||||||
|         <id column="PK_ID" property="pkId"/> |         <id column="PK_ID" property="pkId"/> | ||||||
| 
 |  | ||||||
|         <result column="CLASSIFY_NAME" property="classifyName"/> |         <result column="CLASSIFY_NAME" property="classifyName"/> | ||||||
|         <result column="PK_TRANSACTION_KEY" property="pkTransactionKey"/> |         <result column="PK_TRANSACTION_KEY" property="pkTransactionKey"/> | ||||||
|         <result column="SORT" property="sort"/> |         <result column="SORT" property="sort"/> | ||||||
|  | @ -20,6 +19,7 @@ | ||||||
|         <result column="PK_COUNTRY" property="pkCountry"/> |         <result column="PK_COUNTRY" property="pkCountry"/> | ||||||
|         <result column="HIERARCHY" property="hierarchy"/> |         <result column="HIERARCHY" property="hierarchy"/> | ||||||
|     </resultMap> |     </resultMap> | ||||||
|  | 
 | ||||||
|     <resultMap id="SelectResultMap" type="com.hzs.sale.product.vo.AreaClassifyVo"> |     <resultMap id="SelectResultMap" type="com.hzs.sale.product.vo.AreaClassifyVo"> | ||||||
|         <id column="PK_ID" property="pkId"/> |         <id column="PK_ID" property="pkId"/> | ||||||
|         <result column="CREATION_TIME" property="creationTime"/> |         <result column="CREATION_TIME" property="creationTime"/> | ||||||
|  | @ -32,10 +32,6 @@ | ||||||
|         <result column="parentClassifyName" property="parentClassifyName"/> |         <result column="parentClassifyName" property="parentClassifyName"/> | ||||||
|         <result column="IS_RECOMMEND" property="isRecommend"/> |         <result column="IS_RECOMMEND" property="isRecommend"/> | ||||||
|     </resultMap> |     </resultMap> | ||||||
|     <!-- 通用查询结果列 --> |  | ||||||
|     <sql id="Base_Column_List"> |  | ||||||
|         PK_ID,  CLASSIFY_NAME, PK_TRANSACTION_KEY, SORT, ENABLE_STATE, PK_PARENT, CLASSIFY_IMG, PK_CREATOR, CREATION_TIME, PK_MODIFIED, MODIFIED_TIME, DEL_FLAG, PK_COUNTRY |  | ||||||
|     </sql> |  | ||||||
| 
 | 
 | ||||||
|     <select id="selectByAreaClassifyList" resultMap="SelectResultMap"> |     <select id="selectByAreaClassifyList" resultMap="SelectResultMap"> | ||||||
|         select ac.*,pac.CLASSIFY_NAME parentClassifyName from BD_AREA_CLASSIFY ac |         select ac.*,pac.CLASSIFY_NAME parentClassifyName from BD_AREA_CLASSIFY ac | ||||||
|  | @ -52,16 +48,16 @@ | ||||||
|         </if> |         </if> | ||||||
|         <if test="specialArea != null"> |         <if test="specialArea != null"> | ||||||
|             AND ( |             AND ( | ||||||
|             (select count(csa.PK_ID)  from  BD_AREA_CLASSIFY_SPECIAL_AREA  csa where csa.SPECIAL_AREA = #{specialArea} and csa.PK_AREA_CLASSIFY = ac.PK_ID ) > 0 |             (select count(csa.PK_ID) from BD_AREA_CLASSIFY_SPECIAL_AREA csa where csa.SPECIAL_AREA = #{specialArea} and csa.PK_AREA_CLASSIFY = | ||||||
|  |             ac.PK_ID ) > 0 | ||||||
|             or |             or | ||||||
| 
 |  | ||||||
|             ( |             ( | ||||||
|             select count(t.PK_ID) |             select count(t.PK_ID) | ||||||
|             from BD_AREA_CLASSIFY t |             from BD_AREA_CLASSIFY t | ||||||
|             where  (select count(csa.PK_ID)  from  BD_AREA_CLASSIFY_SPECIAL_AREA  csa where csa.SPECIAL_AREA = #{specialArea} and csa.PK_AREA_CLASSIFY = t.PK_ID) > 0 |             where (select count(csa.PK_ID) from BD_AREA_CLASSIFY_SPECIAL_AREA csa where csa.SPECIAL_AREA = #{specialArea} and csa.PK_AREA_CLASSIFY = | ||||||
|  |             t.PK_ID) > 0 | ||||||
|             start with t.pk_id = ac.PK_ID |             start with t.pk_id = ac.PK_ID | ||||||
|             connect by t.pk_id = prior t.pk_parent |             connect by t.pk_id = prior t.pk_parent | ||||||
| 
 |  | ||||||
|             ) > 0 |             ) > 0 | ||||||
|             ) |             ) | ||||||
|         </if> |         </if> | ||||||
|  | @ -77,4 +73,5 @@ | ||||||
|         </if> |         </if> | ||||||
|         order by ac.SORT desc |         order by ac.SORT desc | ||||||
|     </select> |     </select> | ||||||
|  | 
 | ||||||
| </mapper> | </mapper> | ||||||
|  |  | ||||||
|  | @ -98,7 +98,6 @@ | ||||||
|         S_LABEL, SALES, IS_SALE, ARRIVAL_TIME, WARN_MESSAGE, |         S_LABEL, SALES, IS_SALE, ARRIVAL_TIME, WARN_MESSAGE, | ||||||
|         IS_LAND_TRANS, IS_AIR_TRANS, IS_OCEAN_TRANS, |         IS_LAND_TRANS, IS_AIR_TRANS, IS_OCEAN_TRANS, | ||||||
|         VIDEO_URL, COVER, be.maker_income, be.PK_SPECIAL_CURRENCY, |         VIDEO_URL, COVER, be.maker_income, be.PK_SPECIAL_CURRENCY, | ||||||
| 
 |  | ||||||
|         be.INVENTORY, be.INVENTORY_RATIO, be.MEMBER_LIMIT, be.MEMBER_MONTH_LIMIT, be.INVENTORY_USE |         be.INVENTORY, be.INVENTORY_RATIO, be.MEMBER_LIMIT, be.MEMBER_MONTH_LIMIT, be.INVENTORY_USE | ||||||
|         from bd_wares bw |         from bd_wares bw | ||||||
|         inner join bd_wares_extend be |         inner join bd_wares_extend be | ||||||
|  | @ -153,6 +152,7 @@ | ||||||
|         select bw.PK_COUNTRY, bw.PK_ID, be.pk_id PK_WARES_EXTEND, |         select bw.PK_COUNTRY, bw.PK_ID, be.pk_id PK_WARES_EXTEND, | ||||||
|         be.IS_MAKER_GIFT, bw.WARES_CODE, bw.WARES_NAME, |         be.IS_MAKER_GIFT, bw.WARES_CODE, bw.WARES_NAME, | ||||||
|         PK_AREA_CLASSIFY, COVER, COVER1, COVER2, |         PK_AREA_CLASSIFY, COVER, COVER1, COVER2, | ||||||
|  |         DETAILS_TYPE, | ||||||
|         bw.WARES_PRICE, bw.WARES_ACHIEVE, |         bw.WARES_PRICE, bw.WARES_ACHIEVE, | ||||||
|         SORT, SPECIAL_AREA, |         SORT, SPECIAL_AREA, | ||||||
|         IS_PUT_ON, PRE_SALE_STATUS, |         IS_PUT_ON, PRE_SALE_STATUS, | ||||||
|  | @ -176,6 +176,9 @@ | ||||||
|         <if test="pkCountry != null"> |         <if test="pkCountry != null"> | ||||||
|             and bw.pk_country = #{pkCountry} |             and bw.pk_country = #{pkCountry} | ||||||
|         </if> |         </if> | ||||||
|  |         <if test="waresName != null and waresName != ''"> | ||||||
|  |             and bw.WARES_NAME like '%' || #{waresName} || '%' | ||||||
|  |         </if> | ||||||
|         order by bw.SORT_STATUS desc , bw.sort desc, bw.WARES_PRICE ,bw.CREATION_TIME desc |         order by bw.SORT_STATUS desc , bw.sort desc, bw.WARES_PRICE ,bw.CREATION_TIME desc | ||||||
|     </select> |     </select> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,59 +1,25 @@ | ||||||
| package com.hzs.system.config.controller.api; | package com.hzs.system.config.controller.api; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |  | ||||||
| import com.hzs.common.core.constant.SystemFieldConstants; |  | ||||||
| import com.hzs.common.core.enums.EYesNo; |  | ||||||
| import com.hzs.common.core.web.domain.AjaxResult; | import com.hzs.common.core.web.domain.AjaxResult; | ||||||
| import com.hzs.common.domain.system.config.BdRegisterPage; |  | ||||||
| import com.hzs.common.security.utils.SecurityUtils; |  | ||||||
| import com.hzs.system.config.service.IBdRegisterPageService; |  | ||||||
| import com.hzs.system.config.vo.RegisterPageVO; |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; |  | ||||||
| import org.springframework.web.bind.annotation.GetMapping; | import org.springframework.web.bind.annotation.GetMapping; | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; | import org.springframework.web.bind.annotation.RequestMapping; | ||||||
| import org.springframework.web.bind.annotation.RestController; | import org.springframework.web.bind.annotation.RestController; | ||||||
| 
 | 
 | ||||||
| import java.util.ArrayList; | import java.util.Collections; | ||||||
| import java.util.List; |  | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * @Description: 前端注册页面配置控制器 |  * 前端注册页面配置控制器 | ||||||
|  * @Author: jiang chao |  | ||||||
|  * @Time: 2022/10/19 9:44 |  | ||||||
|  * @Classname: ApiBdRegisterPageController |  | ||||||
|  * @PackageName: com.hzs.system.config.controller.api |  | ||||||
|  */ |  */ | ||||||
| @RestController | @RestController | ||||||
| @RequestMapping("/api/register-page") | @RequestMapping("/api/register-page") | ||||||
| public class ApiBdRegisterPageController { | public class ApiBdRegisterPageController { | ||||||
| 
 | 
 | ||||||
|     @Autowired |  | ||||||
|     private IBdRegisterPageService iBdRegisterPageService; |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 获取菜单权限列表 |      * 获取菜单权限列表 | ||||||
|      * |  | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/list") |     @GetMapping("/list") | ||||||
|     public AjaxResult list(Integer pkCountry) { |     public AjaxResult list() { | ||||||
|         if (null == pkCountry) { |         return AjaxResult.success(Collections.emptyList()); | ||||||
|             pkCountry = SecurityUtils.getPkCountry(); |  | ||||||
|         } |  | ||||||
|         QueryWrapper<BdRegisterPage> queryWrapper = new QueryWrapper<>(); |  | ||||||
|         queryWrapper.eq(SystemFieldConstants.PK_COUNTRY, pkCountry); |  | ||||||
|         queryWrapper.eq("DISPLAY", EYesNo.YES.getIntValue()); |  | ||||||
|         queryWrapper.orderByAsc(SystemFieldConstants.PK_ID); |  | ||||||
|         List<BdRegisterPage> list = iBdRegisterPageService.list(queryWrapper); |  | ||||||
| 
 |  | ||||||
|         List<RegisterPageVO> resultList = new ArrayList<>(); |  | ||||||
|         for (BdRegisterPage bdRegisterPage : list) { |  | ||||||
|             resultList.add(RegisterPageVO.builder() |  | ||||||
|                     .field(bdRegisterPage.getField()) |  | ||||||
|                     .build()); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         return AjaxResult.success(resultList); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -5,9 +5,6 @@ import com.hzs.common.domain.system.config.BdRegisterPage; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 注册页面配置 Mapper 接口 |  * 注册页面配置 Mapper 接口 | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  * @since 2022-10-18 |  | ||||||
|  */ |  */ | ||||||
| public interface BdRegisterPageMapper extends BaseMapper<BdRegisterPage> { | public interface BdRegisterPageMapper extends BaseMapper<BdRegisterPage> { | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -7,9 +7,6 @@ import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 注册页面配置 服务类 |  * 注册页面配置 服务类 | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  * @since 2022-10-18 |  | ||||||
|  */ |  */ | ||||||
| public interface IBdRegisterPageService extends IService<BdRegisterPage> { | public interface IBdRegisterPageService extends IService<BdRegisterPage> { | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,9 +1,8 @@ | ||||||
| package com.hzs.system.config.service.impl; | package com.hzs.system.config.service.impl; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import com.hzs.common.core.constant.SystemFieldConstants; |  | ||||||
| import com.hzs.common.core.enums.EDelFlag; | import com.hzs.common.core.enums.EDelFlag; | ||||||
| import com.hzs.common.core.enums.ERegisterPage; | import com.hzs.common.core.enums.ERegisterPage; | ||||||
| import com.hzs.common.core.enums.EYesNo; | import com.hzs.common.core.enums.EYesNo; | ||||||
|  | @ -18,18 +17,15 @@ import java.util.List; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 注册页面配置 服务实现类 |  * 注册页面配置 服务实现类 | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  * @since 2022-10-18 |  | ||||||
|  */ |  */ | ||||||
| @Service | @Service | ||||||
| public class BdRegisterPageServiceImpl extends ServiceImpl<BdRegisterPageMapper, BdRegisterPage> implements IBdRegisterPageService { | public class BdRegisterPageServiceImpl extends ServiceImpl<BdRegisterPageMapper, BdRegisterPage> implements IBdRegisterPageService { | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public List<BdRegisterPage> queryList(Integer pkCountry) { |     public List<BdRegisterPage> queryList(Integer pkCountry) { | ||||||
|         QueryWrapper<BdRegisterPage> queryWrapper = new QueryWrapper<>(); |         LambdaQueryWrapper<BdRegisterPage> queryWrapper = new LambdaQueryWrapper<>(); | ||||||
|         queryWrapper.eq(SystemFieldConstants.PK_COUNTRY, pkCountry); |         queryWrapper.eq(BdRegisterPage::getPkCountry, pkCountry); | ||||||
|         queryWrapper.orderByAsc("PK_ID"); |         queryWrapper.orderByAsc(BdRegisterPage::getPkId); | ||||||
|         return baseMapper.selectList(queryWrapper); |         return baseMapper.selectList(queryWrapper); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -39,11 +35,11 @@ public class BdRegisterPageServiceImpl extends ServiceImpl<BdRegisterPageMapper, | ||||||
|         Date nowDate = new Date(); |         Date nowDate = new Date(); | ||||||
| 
 | 
 | ||||||
|         // 删除旧数据 |         // 删除旧数据 | ||||||
|         UpdateWrapper<BdRegisterPage> updateWrapper = new UpdateWrapper<>(); |         LambdaUpdateWrapper<BdRegisterPage> updateWrapper = new LambdaUpdateWrapper<>(); | ||||||
|         updateWrapper.eq(SystemFieldConstants.PK_COUNTRY, pkCountry); |         updateWrapper.eq(BdRegisterPage::getPkCountry, pkCountry); | ||||||
|         updateWrapper.set(SystemFieldConstants.DEL_FLAG, EDelFlag.DELETE.getValue()); |         updateWrapper.set(BdRegisterPage::getDelFlag, EDelFlag.DELETE.getValue()); | ||||||
|         updateWrapper.set(SystemFieldConstants.PK_MODIFIED, userId); |         updateWrapper.set(BdRegisterPage::getPkModified, userId); | ||||||
|         updateWrapper.set(SystemFieldConstants.MODIFIED_TIME, nowDate); |         updateWrapper.set(BdRegisterPage::getModifiedTime, nowDate); | ||||||
|         baseMapper.update(null, updateWrapper); |         baseMapper.update(null, updateWrapper); | ||||||
| 
 | 
 | ||||||
|         for (String field : registerPageFieldList) { |         for (String field : registerPageFieldList) { | ||||||
|  |  | ||||||
|  | @ -13,12 +13,8 @@ import org.springframework.web.bind.annotation.RestController; | ||||||
| @Slf4j | @Slf4j | ||||||
| public class ApiIdempotentController { | public class ApiIdempotentController { | ||||||
| 
 | 
 | ||||||
|     private IIdempotentService idempotentService; |  | ||||||
| 
 |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     public void setIdempotentService(IIdempotentService idempotentService) { |     private IIdempotentService idempotentService; | ||||||
|         this.idempotentService = idempotentService; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     @GetMapping("/generate") |     @GetMapping("/generate") | ||||||
|     public AjaxResult generateIdempotentToken() { |     public AjaxResult generateIdempotentToken() { | ||||||
|  |  | ||||||
|  | @ -4,11 +4,6 @@ import com.hzs.common.core.constant.CacheConstants; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 解决系统幂等性的公共方法 |  * 解决系统幂等性的公共方法 | ||||||
|  * @author: sui q |  | ||||||
|  * @time: 2022/8/27 13:46 |  | ||||||
|  * @description: |  | ||||||
|  * @classname: IIdempotentService |  | ||||||
|  * @package_name: com.hzs.system.tools.service |  | ||||||
|  */ |  */ | ||||||
| public interface IIdempotentService { | public interface IIdempotentService { | ||||||
| 
 | 
 | ||||||
|  | @ -19,33 +14,16 @@ public interface IIdempotentService { | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 生成唯一的token |      * 生成唯一的token | ||||||
|     * @Description: |  | ||||||
|     * @return: String |  | ||||||
|     * @throws |  | ||||||
|     * @Author: sui q |  | ||||||
|     * @Date: 2022/8/27 13:47 |  | ||||||
|      */ |      */ | ||||||
|     String generateToken(); |     String generateToken(); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 验证token,是否存在系统中 |      * 验证token,是否存在系统中 | ||||||
|     * @Description: |  | ||||||
|      * @param token |  | ||||||
|     * @return: Boolean |  | ||||||
|     * @throws |  | ||||||
|     * @Author: sui q |  | ||||||
|     * @Date: 2022/8/27 13:48 |  | ||||||
|      */ |      */ | ||||||
|     Boolean validateToken(String token); |     Boolean validateToken(String token); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 刷新token |      * 刷新token | ||||||
|     * @Description: |  | ||||||
|      * @param token |  | ||||||
|     * @return: void |  | ||||||
|     * @throws |  | ||||||
|     * @Author: sui q |  | ||||||
|     * @Date: 2022/8/27 13:48 |  | ||||||
|      */ |      */ | ||||||
|     void refreshToken(String token); |     void refreshToken(String token); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -12,31 +12,13 @@ import java.util.concurrent.TimeUnit; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 解决系统幂等性的公共方法的实现类 |  * 解决系统幂等性的公共方法的实现类 | ||||||
|  * @author: sui q |  | ||||||
|  * @time: 2022/8/27 13:49 |  | ||||||
|  * @description: |  | ||||||
|  * @classname: IdempotentServiceImpl |  | ||||||
|  * @package_name: com.hzs.system.tools.service.impl |  | ||||||
|  */ |  */ | ||||||
| @Service | @Service | ||||||
| public class IdempotentServiceImpl implements IIdempotentService { | public class IdempotentServiceImpl implements IIdempotentService { | ||||||
| 
 | 
 | ||||||
|  |     @Autowired | ||||||
|     private RedisService redisService; |     private RedisService redisService; | ||||||
| 
 | 
 | ||||||
|     @Autowired |  | ||||||
|     public void setRedisService(RedisService redisService) { |  | ||||||
|         this.redisService = redisService; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 生成唯一的token |  | ||||||
|      * @Description: |  | ||||||
|      * @param |  | ||||||
|      * @return: String |  | ||||||
|      * @throws |  | ||||||
|      * @Author: sui q |  | ||||||
|      * @Date: 2022/8/27 13:47 |  | ||||||
|      */ |  | ||||||
|     @Override |     @Override | ||||||
|     public String generateToken() { |     public String generateToken() { | ||||||
|         String token = IdUtils.fastSimpleUUID(); |         String token = IdUtils.fastSimpleUUID(); | ||||||
|  | @ -45,35 +27,15 @@ public class IdempotentServiceImpl implements IIdempotentService { | ||||||
|         return token; |         return token; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 验证token,是否存在系统中 |  | ||||||
|      * @Description: |  | ||||||
|      * @param token |  | ||||||
|      * @return: Boolean |  | ||||||
|      * @throws |  | ||||||
|      * @Author: sui q |  | ||||||
|      * @Date: 2022/8/27 13:48 |  | ||||||
|      */ |  | ||||||
|     @Override |     @Override | ||||||
|     public Boolean validateToken(String token) { |     public Boolean validateToken(String token) { | ||||||
|         String redisToken = redisService.getCacheObject(CacheToolsConstants.IDEMPOTENT_TOKEN + token); |         String redisToken = redisService.getCacheObject(CacheToolsConstants.IDEMPOTENT_TOKEN + token); | ||||||
|         if(StringUtils.isEmpty(redisToken) || !redisToken.equals(token)){ |         return !StringUtils.isEmpty(redisToken) && redisToken.equals(token); | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 刷新token |  | ||||||
|      * @Description: |  | ||||||
|      * @param token |  | ||||||
|      * @return: void |  | ||||||
|      * @throws |  | ||||||
|      * @Author: sui q |  | ||||||
|      * @Date: 2022/8/27 13:48 |  | ||||||
|      */ |  | ||||||
|     @Override |     @Override | ||||||
|     public void refreshToken(String token) { |     public void refreshToken(String token) { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -23,11 +23,7 @@ import javax.servlet.http.HttpServletRequest; | ||||||
| import java.lang.reflect.Method; | import java.lang.reflect.Method; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * @author: sui q |  * 防止重复提交的切面类 | ||||||
|  * @time: 2022/8/27 14:45 |  | ||||||
|  * @description:防止重复提交的切面类 |  | ||||||
|  * @classname: RepeatSubmitAspectAdvice |  | ||||||
|  * @package_name: com.hzs.common.core.aspect |  | ||||||
|  */ |  */ | ||||||
| @Aspect | @Aspect | ||||||
| @Component | @Component | ||||||
|  |  | ||||||
|  | @ -1,5 +1,10 @@ | ||||||
| package com.hzs.common.core.constant; | package com.hzs.common.core.constant; | ||||||
| 
 | 
 | ||||||
|  | import com.hzs.common.core.enums.EGrade; | ||||||
|  | 
 | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.List; | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * 系统使用常量 |  * 系统使用常量 | ||||||
|  */ |  */ | ||||||
|  | @ -34,4 +39,9 @@ public class SysConstants { | ||||||
|      */ |      */ | ||||||
|     public static final Long PK_VERTEX_1440_TEST = 347L; |     public static final Long PK_VERTEX_1440_TEST = 347L; | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 不拿奖金的等级 | ||||||
|  |      */ | ||||||
|  |     public static final List<Integer> NOT_BONUS_GRADE = Arrays.asList(EGrade.START_UP.getValue(), EGrade.HAI_FAN.getValue()); | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -57,9 +57,4 @@ public class SystemFieldConstants { | ||||||
|      */ |      */ | ||||||
|     public static final String PK_COUNTRY = "pk_country"; |     public static final String PK_COUNTRY = "pk_country"; | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 公司 |  | ||||||
|      */ |  | ||||||
|     public static final String PK_CORP = "pk_corp"; |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,11 +2,6 @@ package com.hzs.common.core.constant.msg; | ||||||
| 
 | 
 | ||||||
| public class MemberMsgConstants { | public class MemberMsgConstants { | ||||||
| 
 | 
 | ||||||
|     /** |  | ||||||
|      * 重复提交,或者没有token生成,不是正规流程进入的保存 提交token失效 -- 请求已经失效,请刷新重试! |  | ||||||
|      */ |  | ||||||
|     public static final String TOKEN_REPEAT_SUBMIT = "请求已经失效,请刷新重试!"; |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * 手机号码长度验证 -- 联系方式长度超长 |      * 手机号码长度验证 -- 联系方式长度超长 | ||||||
|      * 2024.06.21 兼容新需求,特殊账号联系方式长度不能超过30位 |      * 2024.06.21 兼容新需求,特殊账号联系方式长度不能超过30位 | ||||||
|  | @ -37,12 +32,12 @@ public class MemberMsgConstants { | ||||||
|     /** |     /** | ||||||
|      * 验证手机号是否被注册 -- 会员信息已存在! |      * 验证手机号是否被注册 -- 会员信息已存在! | ||||||
|      */ |      */ | ||||||
|     public static final String SYSTEM_REGISTER_COUNT = "会员信息已存在!"; |     public static final String SYSTEM_REGISTER_COUNT = "注册信息已超过注册次数。"; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 验证手机号是否被用户使用 -- 会员信息已注册,若有异议请及时联系在线客服! |      * 验证手机号是否被用户使用 -- 会员信息已注册,若有异议请及时联系在线客服! | ||||||
|      */ |      */ | ||||||
|     public static final String PHONE_ALREADY_REGISTER = "会员信息已注册,若有异议请及时联系在线客服!"; |     public static final String PHONE_ALREADY_REGISTER = "会员信息已注册,若有异议请及时联系客服!"; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 验证手机号是否在同一个团队 -- 注册信息已存在,请重新输入注册信息! |      * 验证手机号是否在同一个团队 -- 注册信息已存在,请重新输入注册信息! | ||||||
|  |  | ||||||
|  | @ -6,8 +6,6 @@ import lombok.Getter; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 删除标记枚举类 |  * 删除标记枚举类 | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  */ |  */ | ||||||
| @AllArgsConstructor | @AllArgsConstructor | ||||||
| @Getter | @Getter | ||||||
|  |  | ||||||
|  | @ -93,4 +93,5 @@ public enum EGrade { | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -25,7 +25,7 @@ public enum EOrderTypeExtend { | ||||||
|     /** |     /** | ||||||
|      * 实际值 |      * 实际值 | ||||||
|      */ |      */ | ||||||
|     private final int value; |     private final Integer value; | ||||||
|     /** |     /** | ||||||
|      * 显示标签 |      * 显示标签 | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|  | @ -61,6 +61,12 @@ public enum ESpecialArea { | ||||||
|      */ |      */ | ||||||
|     RENEWAL_AREA(30, "续约专区", 0, EnumsPrefixConstants.SPECIAL_AREA + 30, 30, EMenuDetail.RENEWAL_AREA.getValue()), |     RENEWAL_AREA(30, "续约专区", 0, EnumsPrefixConstants.SPECIAL_AREA + 30, 30, EMenuDetail.RENEWAL_AREA.getValue()), | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 会员专区 -- 0元注册之后,只能看到会员专区,就是注册专区的188商品 | ||||||
|  |      * SANGELXIU1 enable = 1->0 | ||||||
|  |      */ | ||||||
|  |     MEMBER_AREA(41, "会员专区", 0, EnumsPrefixConstants.SPECIAL_AREA + 41, 41, -1), | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * 自助购票 |      * 自助购票 | ||||||
|      */ |      */ | ||||||
|  | @ -115,4 +121,18 @@ public enum ESpecialArea { | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 获取会员专区,支持188的会员专区(41)返回为注册专区(1) | ||||||
|  |      * | ||||||
|  |      * @param value | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     public static Integer getMemberArea(Integer value) { | ||||||
|  |         if (null != value && value.equals(ESpecialArea.MEMBER_AREA.getValue())) { | ||||||
|  |             return ESpecialArea.REGISTER_AREA.getValue(); | ||||||
|  |         } | ||||||
|  |         return value; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,10 +2,8 @@ package com.hzs.common.domain.sale.product; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.annotation.KeySequence; | import com.baomidou.mybatisplus.annotation.KeySequence; | ||||||
| import com.baomidou.mybatisplus.annotation.TableName; | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
| import java.util.Date; |  | ||||||
| import com.baomidou.mybatisplus.annotation.TableId; | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
| import com.baomidou.mybatisplus.annotation.TableField; | import com.baomidou.mybatisplus.annotation.TableField; | ||||||
| import java.io.Serializable; |  | ||||||
| 
 | 
 | ||||||
| import com.hzs.common.core.web.domain.BaseEntity; | import com.hzs.common.core.web.domain.BaseEntity; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  | @ -13,12 +11,7 @@ import lombok.EqualsAndHashCode; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * <p> |  | ||||||
|  * 商品分类 |  * 商品分类 | ||||||
|  * </p> |  | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  * @since 2022-09-05 |  | ||||||
|  */ |  */ | ||||||
| @Data | @Data | ||||||
| @EqualsAndHashCode(callSuper = false) | @EqualsAndHashCode(callSuper = false) | ||||||
|  |  | ||||||
|  | @ -11,9 +11,6 @@ import lombok.experimental.Accessors; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 注册页面配置 |  * 注册页面配置 | ||||||
|  * |  | ||||||
|  * @author hzs |  | ||||||
|  * @since 2022-10-18 |  | ||||||
|  */ |  */ | ||||||
| @Data | @Data | ||||||
| @EqualsAndHashCode(callSuper = true) | @EqualsAndHashCode(callSuper = true) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue