init
This commit is contained in:
@@ -47,11 +47,6 @@ public class ActivityShopController extends BaseController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取相亲会详细信息
|
|
||||||
*
|
|
||||||
* @param id 主键
|
|
||||||
*/
|
|
||||||
@SaCheckPermission("xq:activityShop:query")
|
@SaCheckPermission("xq:activityShop:query")
|
||||||
@GetMapping("/{id}")
|
@GetMapping("/{id}")
|
||||||
public R<ActivityShop> getInfo(@NotNull(message = "主键不能为空")
|
public R<ActivityShop> getInfo(@NotNull(message = "主键不能为空")
|
||||||
@@ -59,26 +54,31 @@ public class ActivityShopController extends BaseController {
|
|||||||
return R.ok(activityShopService.getById(id));
|
return R.ok(activityShopService.getById(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 新增相亲会
|
|
||||||
*/
|
|
||||||
@SaCheckPermission("xq:activityShop:add")
|
@SaCheckPermission("xq:activityShop:add")
|
||||||
@Log(title = "相亲会", businessType = BusinessType.INSERT)
|
@Log(title = "相亲会", businessType = BusinessType.INSERT)
|
||||||
@RepeatSubmit()
|
@RepeatSubmit()
|
||||||
@PostMapping()
|
@PostMapping()
|
||||||
public R<Void> add(@Validated(AddGroup.class) @RequestBody ActivityShop bo) {
|
public R<Void> add(@Validated(AddGroup.class) @RequestBody ActivityShop bo) {
|
||||||
return toAjax(activityShopService.save(bo));
|
activityShopService.saveData(bo);
|
||||||
|
return R.ok();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 修改相亲会
|
|
||||||
*/
|
|
||||||
@SaCheckPermission("xq:activityShop:edit")
|
@SaCheckPermission("xq:activityShop:edit")
|
||||||
@Log(title = "相亲会", businessType = BusinessType.UPDATE)
|
@Log(title = "相亲会", businessType = BusinessType.UPDATE)
|
||||||
@RepeatSubmit()
|
@RepeatSubmit()
|
||||||
@PutMapping()
|
@PutMapping()
|
||||||
public R<Void> edit(@Validated(EditGroup.class) @RequestBody ActivityShop bo) {
|
public R<Void> edit(@Validated(EditGroup.class) @RequestBody ActivityShop bo) {
|
||||||
return toAjax(activityShopService.updateById(bo));
|
activityShopService.updateData(bo);
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
@SaCheckPermission("xq:activityShop:edit")
|
||||||
|
@Log(title = "相亲会人数调整", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit()
|
||||||
|
@PutMapping("/user")
|
||||||
|
public R<Void> editUser(@Validated(EditGroup.class) @RequestBody ActivityShop bo) {
|
||||||
|
activityShopService.updateDataUser(bo);
|
||||||
|
return R.ok();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -9,15 +9,16 @@ import com.ruoyi.common.core.domain.R;
|
|||||||
import com.ruoyi.common.enums.BusinessType;
|
import com.ruoyi.common.enums.BusinessType;
|
||||||
import com.ruoyi.common.helper.LoginHelper;
|
import com.ruoyi.common.helper.LoginHelper;
|
||||||
import com.ruoyi.common.utils.StringUtils;
|
import com.ruoyi.common.utils.StringUtils;
|
||||||
|
import com.ruoyi.xq.domain.ActivityOrder;
|
||||||
import com.ruoyi.xq.dto.app.activity.ActivityShopAppInfo;
|
import com.ruoyi.xq.dto.app.activity.ActivityShopAppInfo;
|
||||||
import com.ruoyi.xq.dto.app.activity.ActivityShopAppList;
|
import com.ruoyi.xq.dto.app.activity.ActivityShopAppList;
|
||||||
|
import com.ruoyi.xq.dto.app.activity.CreateOrderReq;
|
||||||
import com.ruoyi.xq.dto.app.common.IdReq;
|
import com.ruoyi.xq.dto.app.common.IdReq;
|
||||||
import com.ruoyi.xq.dto.app.im.ImMessageDTO;
|
import com.ruoyi.xq.dto.app.pay.OrderCreateVo;
|
||||||
import com.ruoyi.xq.dto.app.im.ImResp;
|
import com.ruoyi.xq.service.ActivityOrderService;
|
||||||
import com.ruoyi.xq.service.ActivityShopService;
|
import com.ruoyi.xq.service.ActivityShopService;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
import jdk.nashorn.internal.ir.annotations.Ignore;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
@@ -26,10 +27,12 @@ import org.springframework.web.bind.annotation.*;
|
|||||||
@RestController
|
@RestController
|
||||||
@Tag(name = "相亲会相关接口")
|
@Tag(name = "相亲会相关接口")
|
||||||
@RequestMapping("/xq/activity/matchmaking")
|
@RequestMapping("/xq/activity/matchmaking")
|
||||||
public class MatchmakingEventController {
|
public class ActivityMatchmakingController {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private ActivityShopService activityShopService;
|
private ActivityShopService activityShopService;
|
||||||
|
@Autowired
|
||||||
|
private ActivityOrderService activityOrderService;
|
||||||
|
|
||||||
@GetMapping("/page")
|
@GetMapping("/page")
|
||||||
@Operation(summary = "相亲会列表-分页")
|
@Operation(summary = "相亲会列表-分页")
|
||||||
@@ -60,4 +63,18 @@ public class MatchmakingEventController {
|
|||||||
return R.ok();
|
return R.ok();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/create/order")
|
||||||
|
@Operation(summary = "创建相亲会订单")
|
||||||
|
@Log(title = "创建相亲会订单", businessType = BusinessType.OTHER)
|
||||||
|
public R<OrderCreateVo> createOrder(@RequestBody CreateOrderReq req){
|
||||||
|
Long userId = LoginHelper.getUserId();
|
||||||
|
req.setUserId(userId);
|
||||||
|
ActivityOrder order = activityOrderService.createOrder(req);
|
||||||
|
OrderCreateVo result = new OrderCreateVo();
|
||||||
|
result.setPrice(order.getPrice());
|
||||||
|
result.setOrderNo(order.getOrderNo());
|
||||||
|
result.setOrderName(order.getOrderName());
|
||||||
|
return R.ok(result);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
package com.ruoyi.xq.dto.app.activity;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class CreateOrderReq {
|
||||||
|
|
||||||
|
@Schema(description = "相亲会ID")
|
||||||
|
private Long activityId;
|
||||||
|
|
||||||
|
@Schema(description = "手机号")
|
||||||
|
private String mobile;
|
||||||
|
|
||||||
|
@Schema(description = "价格")
|
||||||
|
private BigDecimal price;
|
||||||
|
|
||||||
|
@Schema(hidden = true)
|
||||||
|
private Long userId;
|
||||||
|
}
|
||||||
@@ -7,4 +7,5 @@ public class MinUser {
|
|||||||
private Long id;
|
private Long id;
|
||||||
private String usercode;
|
private String usercode;
|
||||||
private String nickname;
|
private String nickname;
|
||||||
|
private Integer gender;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ public enum OrderTypeEnum {
|
|||||||
WITHDRAW("W"),
|
WITHDRAW("W"),
|
||||||
WX_TRANS("X"),
|
WX_TRANS("X"),
|
||||||
AUTH_ORDER("A"),
|
AUTH_ORDER("A"),
|
||||||
|
ACTIVITY_MATCHMAKING("M"),
|
||||||
;
|
;
|
||||||
|
|
||||||
private final String type;
|
private final String type;
|
||||||
|
|||||||
@@ -6,7 +6,8 @@ import lombok.Getter;
|
|||||||
public enum TraceIdEnum {
|
public enum TraceIdEnum {
|
||||||
WITHDRAW("WT","提现"),
|
WITHDRAW("WT","提现"),
|
||||||
VIP("VT","VIP"),
|
VIP("VT","VIP"),
|
||||||
WX_TRANS("XT","微信"),
|
WX_TRANS("XT","微信交换"),
|
||||||
|
ACTIVITY_MATCHMAKING("AM","相亲会"),
|
||||||
;
|
;
|
||||||
private final String code;
|
private final String code;
|
||||||
private final String text;
|
private final String text;
|
||||||
|
|||||||
@@ -2,6 +2,8 @@ package com.ruoyi.xq.service;
|
|||||||
|
|
||||||
import com.baomidou.mybatisplus.extension.service.IService;
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
import com.ruoyi.xq.domain.ActivityOrder;
|
import com.ruoyi.xq.domain.ActivityOrder;
|
||||||
|
import com.ruoyi.xq.dto.app.activity.CreateOrderReq;
|
||||||
|
import com.ruoyi.xq.dto.app.pay.OrderCreateVo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 相亲会订单Service接口
|
* 相亲会订单Service接口
|
||||||
@@ -11,4 +13,5 @@ import com.ruoyi.xq.domain.ActivityOrder;
|
|||||||
*/
|
*/
|
||||||
public interface ActivityOrderService extends IService<ActivityOrder> {
|
public interface ActivityOrderService extends IService<ActivityOrder> {
|
||||||
|
|
||||||
|
ActivityOrder createOrder(CreateOrderReq req);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,4 +24,9 @@ public interface ActivityShopService extends IService<ActivityShop> {
|
|||||||
|
|
||||||
JoinResp join(Long userId, Long activityId);
|
JoinResp join(Long userId, Long activityId);
|
||||||
|
|
||||||
|
void saveData(ActivityShop bo);
|
||||||
|
|
||||||
|
void updateData(ActivityShop bo);
|
||||||
|
|
||||||
|
void updateDataUser(ActivityShop bo);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,29 @@
|
|||||||
package com.ruoyi.xq.service.impl;
|
package com.ruoyi.xq.service.impl;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.ruoyi.common.exception.ServiceException;
|
||||||
|
import com.ruoyi.common.utils.StringUtils;
|
||||||
import com.ruoyi.xq.domain.ActivityOrder;
|
import com.ruoyi.xq.domain.ActivityOrder;
|
||||||
|
import com.ruoyi.xq.domain.ActivityShop;
|
||||||
|
import com.ruoyi.xq.dto.app.activity.CreateOrderReq;
|
||||||
|
import com.ruoyi.xq.dto.app.pay.OrderCreateVo;
|
||||||
|
import com.ruoyi.xq.dto.common.user.MinUser;
|
||||||
|
import com.ruoyi.xq.enums.common.OrderTypeEnum;
|
||||||
|
import com.ruoyi.xq.enums.common.TraceIdEnum;
|
||||||
|
import com.ruoyi.xq.enums.pay.PayStatusEnum;
|
||||||
|
import com.ruoyi.xq.enums.userinfo.UserGenderEnum;
|
||||||
|
import com.ruoyi.xq.manager.OrderNoUtil;
|
||||||
|
import com.ruoyi.xq.manager.TraceIdManager;
|
||||||
import com.ruoyi.xq.mapper.ActivityOrderMapper;
|
import com.ruoyi.xq.mapper.ActivityOrderMapper;
|
||||||
import com.ruoyi.xq.service.ActivityOrderService;
|
import com.ruoyi.xq.service.ActivityOrderService;
|
||||||
|
import com.ruoyi.xq.service.ActivityShopService;
|
||||||
|
import com.ruoyi.xq.service.UserService;
|
||||||
|
import org.checkerframework.checker.units.qual.A;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 相亲会订单Service业务层处理
|
* 相亲会订单Service业务层处理
|
||||||
*
|
*
|
||||||
@@ -15,4 +33,45 @@ import org.springframework.stereotype.Service;
|
|||||||
@Service
|
@Service
|
||||||
public class ActivityOrderServiceImpl extends ServiceImpl<ActivityOrderMapper,ActivityOrder> implements ActivityOrderService {
|
public class ActivityOrderServiceImpl extends ServiceImpl<ActivityOrderMapper,ActivityOrder> implements ActivityOrderService {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ActivityShopService activityShopService;
|
||||||
|
@Autowired
|
||||||
|
private UserService userService;
|
||||||
|
@Override
|
||||||
|
public ActivityOrder createOrder(CreateOrderReq req) {
|
||||||
|
ActivityShop activityShop = activityShopService.getById(req.getActivityId());
|
||||||
|
if(activityShop == null){
|
||||||
|
throw new ServiceException("相亲会不存在");
|
||||||
|
}
|
||||||
|
if(StringUtils.isNotEmpty(req.getMobile())){
|
||||||
|
throw new ServiceException("请填写手机号");
|
||||||
|
}
|
||||||
|
MinUser minUser = userService.getMinUserById(req.getUserId());
|
||||||
|
if(minUser== null){
|
||||||
|
throw new ServiceException("用户不存在");
|
||||||
|
}
|
||||||
|
BigDecimal price = null;
|
||||||
|
if(UserGenderEnum.MAN.getCode().equals(minUser.getGender())){
|
||||||
|
price = activityShop.getJoinManPrice();
|
||||||
|
}else if(UserGenderEnum.MAN.getCode().equals(minUser.getGender())){
|
||||||
|
price = activityShop.getJoinWomenPrice();
|
||||||
|
}else{
|
||||||
|
throw new ServiceException("用户异常");
|
||||||
|
}
|
||||||
|
String orderNo = OrderNoUtil.gen(OrderTypeEnum.ACTIVITY_MATCHMAKING);
|
||||||
|
String traceId = TraceIdManager.gen(TraceIdEnum.ACTIVITY_MATCHMAKING);
|
||||||
|
ActivityOrder order = new ActivityOrder();
|
||||||
|
order.setUserId(minUser.getId());
|
||||||
|
order.setUsercode(minUser.getUsercode());
|
||||||
|
order.setBody("报名相亲会");
|
||||||
|
order.setPrice(price);
|
||||||
|
order.setTraceId(traceId);
|
||||||
|
order.setActivityId(activityShop.getId());
|
||||||
|
order.setActivityTitle(activityShop.getActivityTitle());
|
||||||
|
order.setOrderName("报名相亲会");
|
||||||
|
order.setOrderNo(orderNo);
|
||||||
|
order.setPayStatus(PayStatusEnum.READY_PAY.getCode());
|
||||||
|
this.save(order);
|
||||||
|
return order;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import com.ruoyi.common.core.domain.PageQuery;
|
|||||||
import com.ruoyi.common.exception.ServiceException;
|
import com.ruoyi.common.exception.ServiceException;
|
||||||
import com.ruoyi.common.utils.StringUtils;
|
import com.ruoyi.common.utils.StringUtils;
|
||||||
import com.ruoyi.xq.domain.ActivityShop;
|
import com.ruoyi.xq.domain.ActivityShop;
|
||||||
|
import com.ruoyi.xq.domain.AreaCode;
|
||||||
import com.ruoyi.xq.domain.User;
|
import com.ruoyi.xq.domain.User;
|
||||||
import com.ruoyi.xq.domain.UserAuth;
|
import com.ruoyi.xq.domain.UserAuth;
|
||||||
import com.ruoyi.xq.dto.app.activity.ActivityShopAppInfo;
|
import com.ruoyi.xq.dto.app.activity.ActivityShopAppInfo;
|
||||||
@@ -17,6 +18,7 @@ import com.ruoyi.xq.enums.common.AuditEnum;
|
|||||||
import com.ruoyi.xq.enums.userinfo.UserGenderEnum;
|
import com.ruoyi.xq.enums.userinfo.UserGenderEnum;
|
||||||
import com.ruoyi.xq.mapper.ActivityShopMapper;
|
import com.ruoyi.xq.mapper.ActivityShopMapper;
|
||||||
import com.ruoyi.xq.service.ActivityShopService;
|
import com.ruoyi.xq.service.ActivityShopService;
|
||||||
|
import com.ruoyi.xq.service.AreaCodeService;
|
||||||
import com.ruoyi.xq.service.UserAuthService;
|
import com.ruoyi.xq.service.UserAuthService;
|
||||||
import com.ruoyi.xq.service.UserService;
|
import com.ruoyi.xq.service.UserService;
|
||||||
import org.apache.commons.lang3.BooleanUtils;
|
import org.apache.commons.lang3.BooleanUtils;
|
||||||
@@ -172,4 +174,42 @@ public class ActivityShopServiceImpl extends ServiceImpl<ActivityShopMapper,Acti
|
|||||||
resp.setFailText("加入失败");
|
resp.setFailText("加入失败");
|
||||||
return resp;
|
return resp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private AreaCodeService areaCodeService;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void saveData(ActivityShop bo) {
|
||||||
|
if(bo.getStartTime().isAfter(bo.getEndTime())){
|
||||||
|
throw new ServiceException("开始时间不能大于结束时间");
|
||||||
|
}
|
||||||
|
AreaCode areaCode = areaCodeService.getById(bo.getCityCode());
|
||||||
|
bo.setCityName(areaCode.getName());
|
||||||
|
this.save(bo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateData(ActivityShop bo) {
|
||||||
|
if(bo.getStartTime().isAfter(bo.getEndTime())){
|
||||||
|
throw new ServiceException("开始时间不能大于结束时间");
|
||||||
|
}
|
||||||
|
AreaCode areaCode = areaCodeService.getById(bo.getCityCode());
|
||||||
|
bo.setCityName(areaCode.getName());
|
||||||
|
bo.setCreateTime(null);
|
||||||
|
bo.setUpdateTime(null);
|
||||||
|
bo.setHandManNum(null);
|
||||||
|
bo.setHandWomenNum(null);
|
||||||
|
bo.setJoinManNum(null);
|
||||||
|
bo.setJoinWomenNum(null);
|
||||||
|
this.updateById(bo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateDataUser(ActivityShop bo) {
|
||||||
|
ActivityShop shop = new ActivityShop();
|
||||||
|
shop.setId(bo.getId());
|
||||||
|
shop.setHandWomenNum(bo.getHandWomenNum());
|
||||||
|
shop.setHandManNum(bo.getHandManNum());
|
||||||
|
this.updateById(bo);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -107,7 +107,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
order by t4.last_login_time desc
|
order by t4.last_login_time desc
|
||||||
</select>
|
</select>
|
||||||
<select id="getMinUserById" resultType="com.ruoyi.xq.dto.common.user.MinUser">
|
<select id="getMinUserById" resultType="com.ruoyi.xq.dto.common.user.MinUser">
|
||||||
select t1.id,t1.usercode,t1.nickname
|
select t1.id,t1.usercode,t1.nickname,t1.gender
|
||||||
from xq_user t1
|
from xq_user t1
|
||||||
where t1.id = #{userId}
|
where t1.id = #{userId}
|
||||||
</select>
|
</select>
|
||||||
|
|||||||
Reference in New Issue
Block a user