Merge branch 'feature/mall_product' of http://117.33.142.185:3000/zenghuapei/cyywl_server into feature/mall_product
commit
ec8c740a3b
|
@ -1,9 +1,11 @@
|
||||||
package cn.iocoder.yudao.module.shop.response.order;
|
package cn.iocoder.yudao.module.shop.response.order;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import lombok.experimental.Accessors;
|
import lombok.experimental.Accessors;
|
||||||
|
import org.springframework.format.annotation.DateTimeFormat;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
|
@ -85,6 +87,8 @@ public class StoreOrderDetailInfoResponse implements Serializable {
|
||||||
private String payType;
|
private String payType;
|
||||||
|
|
||||||
@Schema(description = "创建时间")
|
@Schema(description = "创建时间")
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||||
|
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||||
private Date createTime;
|
private Date createTime;
|
||||||
|
|
||||||
@Schema(description = "订单状态(0:待发货;1:待收货;2:已收货,待评价;3:已完成;)")
|
@Schema(description = "订单状态(0:待发货;1:待收货;2:已收货,待评价;3:已完成;)")
|
||||||
|
|
|
@ -52,6 +52,8 @@ import cn.iocoder.yudao.module.shop.utils.RedisUtil;
|
||||||
import cn.iocoder.yudao.module.shop.vo.order.LogisticsResultVo;
|
import cn.iocoder.yudao.module.shop.vo.order.LogisticsResultVo;
|
||||||
import cn.iocoder.yudao.module.shop.vo.order.StoreDateRangeSqlPram;
|
import cn.iocoder.yudao.module.shop.vo.order.StoreDateRangeSqlPram;
|
||||||
import cn.iocoder.yudao.module.shop.vo.order.StoreOrderInfoOldVo;
|
import cn.iocoder.yudao.module.shop.vo.order.StoreOrderInfoOldVo;
|
||||||
|
import cn.iocoder.yudao.module.system.api.dept.DeptApi;
|
||||||
|
import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
||||||
import com.alipay.api.AlipayApiException;
|
import com.alipay.api.AlipayApiException;
|
||||||
import com.alipay.api.internal.util.AlipaySignature;
|
import com.alipay.api.internal.util.AlipaySignature;
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
@ -147,6 +149,8 @@ public class StoreOrderServiceImpl extends ServiceImpl<StoreOrderMapper, StoreOr
|
||||||
@Autowired
|
@Autowired
|
||||||
private WxMpService wxMpService;
|
private WxMpService wxMpService;
|
||||||
|
|
||||||
|
private DeptApi deptApi;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 列表(PC)
|
* 列表(PC)
|
||||||
*
|
*
|
||||||
|
@ -1360,6 +1364,12 @@ public class StoreOrderServiceImpl extends ServiceImpl<StoreOrderMapper, StoreOr
|
||||||
|
|
||||||
private RechargeOrderDO initializeOrder(OrderContentRequest request, String code, MemberUserRespDTO user, PromoterDTO promoterDTO) {
|
private RechargeOrderDO initializeOrder(OrderContentRequest request, String code, MemberUserRespDTO user, PromoterDTO promoterDTO) {
|
||||||
Long tenantId = TenantContextHolder.getTenantId();
|
Long tenantId = TenantContextHolder.getTenantId();
|
||||||
|
Long deptId = promoterDTO.getDeptId();
|
||||||
|
if(deptId==null){
|
||||||
|
DeptRespDTO deptRespDTO = deptApi.findParentDept(tenantId);
|
||||||
|
deptId = deptRespDTO.getId();
|
||||||
|
}
|
||||||
|
|
||||||
RechargeOrderDO orderDO = new RechargeOrderDO();
|
RechargeOrderDO orderDO = new RechargeOrderDO();
|
||||||
List<OrderContentRequest.OrderInfo> orderInfos = request.getOrderInfos();
|
List<OrderContentRequest.OrderInfo> orderInfos = request.getOrderInfos();
|
||||||
orderDO.setOrderId(code);
|
orderDO.setOrderId(code);
|
||||||
|
|
|
@ -107,21 +107,16 @@ public class RechargeGearServiceImpl implements RechargeGearService {
|
||||||
List<RechargeGearDO> rechargeGearDOS = rechargeGearMapper.selectList(Wrappers.<RechargeGearDO>lambdaQuery()
|
List<RechargeGearDO> rechargeGearDOS = rechargeGearMapper.selectList(Wrappers.<RechargeGearDO>lambdaQuery()
|
||||||
.eq(RechargeGearDO::getDeleted, 0));
|
.eq(RechargeGearDO::getDeleted, 0));
|
||||||
List<RechargeGearRespVO> rechargeGearRespVOS = RechargeGearConvert.INSTANCE.convertList(rechargeGearDOS);
|
List<RechargeGearRespVO> rechargeGearRespVOS = RechargeGearConvert.INSTANCE.convertList(rechargeGearDOS);
|
||||||
RechargeOrderDO orderDO = orderMapper.selectOne(Wrappers.<RechargeOrderDO>lambdaQuery().eq(RechargeOrderDO::getUid, loginUser.getId())
|
List<PhoneRecordDO> infoDOS = phoneRecordMapper.selectList(Wrappers.<PhoneRecordDO>lambdaQuery().eq(PhoneRecordDO::getUserId, loginUser.getId()));
|
||||||
.eq(RechargeOrderDO::getPaid,1)
|
Map<Long, List<PhoneRecordDO>> collect = infoDOS.stream().collect(Collectors.groupingBy(PhoneRecordDO::getRechargeGearId));
|
||||||
.last("LIMIT 1"));
|
rechargeGearRespVOS.forEach(vo -> {
|
||||||
if (Objects.nonNull(orderDO)) {
|
List<PhoneRecordDO> infoDOS1 = collect.get(vo.getId());
|
||||||
List<PhoneRecordDO> infoDOS = phoneRecordMapper.selectList(Wrappers.<PhoneRecordDO>lambdaQuery().eq(PhoneRecordDO::getRechargeOrderId, orderDO.getId()));
|
if (!CollectionUtils.isEmpty(infoDOS1)) {
|
||||||
Map<Long, List<PhoneRecordDO>> collect = infoDOS.stream().collect(Collectors.groupingBy(PhoneRecordDO::getRechargeGearId));
|
vo.setIsExist("1");
|
||||||
rechargeGearRespVOS.forEach(vo -> {
|
} else {
|
||||||
List<PhoneRecordDO> infoDOS1 = collect.get(vo.getId());
|
vo.setIsExist("0");
|
||||||
if (!CollectionUtils.isEmpty(infoDOS1)) {
|
}
|
||||||
vo.setIsExist("1");
|
});
|
||||||
} else {
|
|
||||||
vo.setIsExist("0");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return rechargeGearRespVOS;
|
return rechargeGearRespVOS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,21 +125,16 @@ public class RechargeGearServiceImpl implements RechargeGearService {
|
||||||
List<RechargeGearDO> rechargeGearDOS = rechargeGearMapper.selectList(Wrappers.<RechargeGearDO>lambdaQuery()
|
List<RechargeGearDO> rechargeGearDOS = rechargeGearMapper.selectList(Wrappers.<RechargeGearDO>lambdaQuery()
|
||||||
.eq(RechargeGearDO::getDeleted, 0));
|
.eq(RechargeGearDO::getDeleted, 0));
|
||||||
List<RechargeGearRespVO> rechargeGearRespVOS = RechargeGearConvert.INSTANCE.convertList(rechargeGearDOS);
|
List<RechargeGearRespVO> rechargeGearRespVOS = RechargeGearConvert.INSTANCE.convertList(rechargeGearDOS);
|
||||||
RechargeOrderDO orderDO = orderMapper.selectOne(Wrappers.<RechargeOrderDO>lambdaQuery().eq(RechargeOrderDO::getUserPhone, phone)
|
List<PhoneRecordDO> infoDOS = phoneRecordMapper.selectList(Wrappers.<PhoneRecordDO>lambdaQuery().eq(PhoneRecordDO::getPhone, phone));
|
||||||
.eq(RechargeOrderDO::getPaid,1)
|
Map<Long, List<PhoneRecordDO>> collect = infoDOS.stream().collect(Collectors.groupingBy(PhoneRecordDO::getRechargeGearId));
|
||||||
.last("LIMIT 1"));
|
rechargeGearRespVOS.forEach(vo -> {
|
||||||
if (Objects.nonNull(orderDO)) {
|
List<PhoneRecordDO> infoDOS1 = collect.get(vo.getId());
|
||||||
List<PhoneRecordDO> infoDOS = phoneRecordMapper.selectList(Wrappers.<PhoneRecordDO>lambdaQuery().eq(PhoneRecordDO::getRechargeOrderId, orderDO.getId()));
|
if (!CollectionUtils.isEmpty(infoDOS1)) {
|
||||||
Map<Long, List<PhoneRecordDO>> collect = infoDOS.stream().collect(Collectors.groupingBy(PhoneRecordDO::getRechargeGearId));
|
vo.setIsExist("1");
|
||||||
rechargeGearRespVOS.forEach(vo -> {
|
} else {
|
||||||
List<PhoneRecordDO> infoDOS1 = collect.get(vo.getId());
|
vo.setIsExist("0");
|
||||||
if (!CollectionUtils.isEmpty(infoDOS1)) {
|
}
|
||||||
vo.setIsExist("1");
|
});
|
||||||
} else {
|
|
||||||
vo.setIsExist("0");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return rechargeGearRespVOS;
|
return rechargeGearRespVOS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
left join system_dept d on d.id = a.dept_id
|
left join system_dept d on d.id = a.dept_id
|
||||||
<include refid="baseWhere">
|
<include refid="baseWhere">
|
||||||
</include>
|
</include>
|
||||||
|
order by a.pay_time desc
|
||||||
</select>
|
</select>
|
||||||
<select id="findListPage" resultType="cn.iocoder.yudao.module.shop.controller.admin.recharge.vo.RechargeOrderRespVO">
|
<select id="findListPage" resultType="cn.iocoder.yudao.module.shop.controller.admin.recharge.vo.RechargeOrderRespVO">
|
||||||
select
|
select
|
||||||
|
|
|
@ -116,7 +116,7 @@ public class AppUserController {
|
||||||
List<UserSpreadBannerVO> list = new ArrayList<>();
|
List<UserSpreadBannerVO> list = new ArrayList<>();
|
||||||
UserSpreadBannerVO userSpreadBannerVO = new UserSpreadBannerVO();
|
UserSpreadBannerVO userSpreadBannerVO = new UserSpreadBannerVO();
|
||||||
userSpreadBannerVO.setId(1);
|
userSpreadBannerVO.setId(1);
|
||||||
userSpreadBannerVO.setPic("http://192.168.1.147:48080/admin-api/infra/file/4/get/431efea27162d536d35f7b3c0b844ede98a6ba58f4fd72ac7181e7ee5ebae77a.jpg");
|
userSpreadBannerVO.setPic("http://image.cyywl.top/431efea27162d536d35f7b3c0b844ede98a6ba58f4fd72ac7181e7ee5ebae77a.jpg");
|
||||||
userSpreadBannerVO.setTitle("推广背景图");
|
userSpreadBannerVO.setTitle("推广背景图");
|
||||||
list.add(userSpreadBannerVO);
|
list.add(userSpreadBannerVO);
|
||||||
return CommonResult.success(list);
|
return CommonResult.success(list);
|
||||||
|
|
|
@ -48,6 +48,18 @@ public interface DeptApi {
|
||||||
*/
|
*/
|
||||||
void validateDeptList(Collection<Long> ids);
|
void validateDeptList(Collection<Long> ids);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <pre>
|
||||||
|
* <b>findParentDept</b>
|
||||||
|
* <b>Description:查询当前租户根节点</b>
|
||||||
|
* <b>@author:</b> zenghuapei
|
||||||
|
* <b>@date:</b> 2023/5/23 09:38
|
||||||
|
* @param :
|
||||||
|
* @return
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
DeptRespDTO findParentDept(Long tenantId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获得指定编号的部门 Map
|
* 获得指定编号的部门 Map
|
||||||
*
|
*
|
||||||
|
|
|
@ -38,6 +38,22 @@ public class DeptApiImpl implements DeptApi {
|
||||||
List<DeptDO> depts = deptService.getDeptList(new DeptListReqVO());
|
List<DeptDO> depts = deptService.getDeptList(new DeptListReqVO());
|
||||||
return DeptConvert.INSTANCE.convertList03(depts);
|
return DeptConvert.INSTANCE.convertList03(depts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <pre>
|
||||||
|
* <b>findParentDept</b>
|
||||||
|
* <b>Description:查询当前租户根节点</b>
|
||||||
|
* <b>@author:</b> zenghuapei
|
||||||
|
* <b>@date:</b> 2023/5/23 09:38
|
||||||
|
* @return
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public DeptRespDTO findParentDept(Long tenantId) {
|
||||||
|
DeptDO deptDO = deptService.findParentDept(tenantId );
|
||||||
|
return DeptConvert.INSTANCE.convert03(deptDO);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void validateDeptList(Collection<Long> ids) {
|
public void validateDeptList(Collection<Long> ids) {
|
||||||
deptService.validateDeptList(ids);
|
deptService.validateDeptList(ids);
|
||||||
|
|
|
@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.system.service.dept;
|
||||||
|
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
|
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
|
||||||
|
import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptCreateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptCreateReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptListReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptListReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptUpdateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptUpdateReqVO;
|
||||||
|
@ -54,6 +55,18 @@ public interface DeptService {
|
||||||
*/
|
*/
|
||||||
List<DeptDO> getDeptList(DeptListReqVO reqVO);
|
List<DeptDO> getDeptList(DeptListReqVO reqVO);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <pre>
|
||||||
|
* <b>findParentDept</b>
|
||||||
|
* <b>Description:查询根节点</b>
|
||||||
|
* <b>@author:</b> zenghuapei
|
||||||
|
* <b>@date:</b> 2023/5/23 09:40
|
||||||
|
* @param tenantId:
|
||||||
|
* @return
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
DeptDO findParentDept(Long tenantId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获得所有子部门,从缓存中
|
* 获得所有子部门,从缓存中
|
||||||
*
|
*
|
||||||
|
|
|
@ -4,6 +4,7 @@ import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
|
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
|
||||||
import cn.iocoder.yudao.framework.tenant.core.context.TenantContextHolder;
|
import cn.iocoder.yudao.framework.tenant.core.context.TenantContextHolder;
|
||||||
import cn.iocoder.yudao.framework.tenant.core.util.TenantUtils;
|
import cn.iocoder.yudao.framework.tenant.core.util.TenantUtils;
|
||||||
|
import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptCreateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptCreateReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptListReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptListReqVO;
|
||||||
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptUpdateReqVO;
|
import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptUpdateReqVO;
|
||||||
|
@ -13,6 +14,7 @@ import cn.iocoder.yudao.module.system.dal.mysql.dept.DeptMapper;
|
||||||
import cn.iocoder.yudao.module.system.enums.dept.DeptIdEnum;
|
import cn.iocoder.yudao.module.system.enums.dept.DeptIdEnum;
|
||||||
import cn.iocoder.yudao.module.system.mq.producer.dept.DeptProducer;
|
import cn.iocoder.yudao.module.system.mq.producer.dept.DeptProducer;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import com.google.common.collect.ImmutableMultimap;
|
import com.google.common.collect.ImmutableMultimap;
|
||||||
import com.google.common.collect.Multimap;
|
import com.google.common.collect.Multimap;
|
||||||
|
@ -152,6 +154,26 @@ public class DeptServiceImpl implements DeptService {
|
||||||
return deptMapper.selectList(reqVO);
|
return deptMapper.selectList(reqVO);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <pre>
|
||||||
|
* <b>findParentDept</b>
|
||||||
|
* <b>Description:查询根节点</b>
|
||||||
|
* <b>@author:</b> zenghuapei
|
||||||
|
* <b>@date:</b> 2023/5/23 09:40
|
||||||
|
* @param tenantId :
|
||||||
|
* @return
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public DeptDO findParentDept(Long tenantId) {
|
||||||
|
List<DeptDO> deptDOs = deptMapper.selectList(Wrappers.lambdaQuery(DeptDO.class).eq(DeptDO::getParentId,DeptIdEnum.ROOT.getId()).eq(DeptDO::getTenantId,tenantId));
|
||||||
|
if(deptDOs!=null && deptDOs.size() > 0){
|
||||||
|
return deptDOs.get(0);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<DeptDO> getDeptListByParentIdFromCache(Long parentId, boolean recursive) {
|
public List<DeptDO> getDeptListByParentIdFromCache(Long parentId, boolean recursive) {
|
||||||
if (parentId == null) {
|
if (parentId == null) {
|
||||||
|
|
|
@ -151,8 +151,8 @@ wx: # 参见 https://github.com/Wechat-Group/WxJava/blob/develop/spring-boot-sta
|
||||||
database: 16 # 数据库索引
|
database: 16 # 数据库索引
|
||||||
password: cyywl123.. # 密码,建议生产环境开启
|
password: cyywl123.. # 密码,建议生产环境开启
|
||||||
# 公众号配置(必填)
|
# 公众号配置(必填)
|
||||||
app-id: wx041349c6f39b268b
|
app-id: wx7e503d9cded34c07
|
||||||
secret: 5abee519483bc9f8cb37ce280e814bd0
|
secret: 31883ca14e2cbac8610d30f8f945ee47
|
||||||
# 存储配置,解决 AccessToken 的跨节点的共享
|
# 存储配置,解决 AccessToken 的跨节点的共享
|
||||||
config-storage:
|
config-storage:
|
||||||
type: RedisTemplate # 采用 RedisTemplate 操作 Redis,会自动从 Spring 中获取
|
type: RedisTemplate # 采用 RedisTemplate 操作 Redis,会自动从 Spring 中获取
|
||||||
|
@ -168,16 +168,16 @@ wx: # 参见 https://github.com/Wechat-Group/WxJava/blob/develop/spring-boot-sta
|
||||||
pay:
|
pay:
|
||||||
one:
|
one:
|
||||||
enabled: true
|
enabled: true
|
||||||
app-id: wxb1826c88da21d81e
|
app-id: wx7e503d9cded34c07
|
||||||
mch-id: 1641993417
|
mch-id: 1641073271
|
||||||
mch-key: qdn2I7Cmx4JeiKOt2CDjiu6UHgLTsOsM
|
mch-key: qdn2I7Cmx4JeiKOt2CDjiu6UHgLTsOsM
|
||||||
apiv3-key: cyywl666666cyywl888888cyywl66666
|
apiv3-key: cyywl123456cyywl654321cyywl12345
|
||||||
private-cert-path: classpath:/1/apiclient_cert.pem
|
private-cert-path: classpath:/1/apiclient_cert.pem
|
||||||
private-key-path: classpath:/1/apiclient_key.pem
|
private-key-path: classpath:/1/apiclient_key.pem
|
||||||
key-path: classpath:/1/apiclient_cert.p12
|
key-path: classpath:/1/apiclient_cert.p12
|
||||||
cert-serial-no: 58FDB503F92B6C0E258C9940BB726C2BF6022E56
|
cert-serial-no: 7F76A4ADC52CA0B440C4E5698F8A5CD1633A0FCD
|
||||||
notify-url: http://api.cyywl.top/app-api/pay/wxpay/pay_notify
|
notify-url: http://api.cyywl.top/admin-api/notify/wxpay/pay_notify
|
||||||
refund-notify-url: http://api.cyywl.top/app-api/pay/wxpay/refund_notify
|
refund-notify-url: http://api.cyywl.top/admin-api/notify/wxpay/refund_notify
|
||||||
two:
|
two:
|
||||||
enabled: true
|
enabled: true
|
||||||
app-id: wxb1826c88da21d81e
|
app-id: wxb1826c88da21d81e
|
||||||
|
|
Loading…
Reference in New Issue