新增套餐

This commit is contained in:
bunny 2024-01-08 22:53:45 +08:00
parent de3cbdf97e
commit e9bdc8baeb
9 changed files with 112 additions and 20 deletions

View File

@ -2,6 +2,7 @@ package com.sky.dto;
import com.sky.entity.SetmealDish; import com.sky.entity.SetmealDish;
import lombok.Data; import lombok.Data;
import java.io.Serializable; import java.io.Serializable;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.ArrayList; import java.util.ArrayList;
@ -11,25 +12,18 @@ import java.util.List;
public class SetmealDTO implements Serializable { public class SetmealDTO implements Serializable {
private Long id; private Long id;
// 分类id // 分类id
private Long categoryId; private Long categoryId;
// 套餐名称 // 套餐名称
private String name; private String name;
// 套餐价格 // 套餐价格
private BigDecimal price; private BigDecimal price;
// 状态 0:停用 1:启用 // 状态 0:停用 1:启用
private Integer status; private Integer status;
// 描述信息 // 描述信息
private String description; private String description;
// 图片 // 图片
private String image; private String image;
// 套餐菜品关系 // 套餐菜品关系
private List<SetmealDish> setmealDishes = new ArrayList<>(); private List<SetmealDish> setmealDishes = new ArrayList<>();

View File

@ -104,6 +104,7 @@ public class CategoryController {
@GetMapping("/list") @GetMapping("/list")
@ApiOperation("根据类型查询分类") @ApiOperation("根据类型查询分类")
public Result<List<Category>> list(Integer type) { public Result<List<Category>> list(Integer type) {
log.info("根据类型查询分类 type:{}", type);
List<Category> list = categoryService.list(type); List<Category> list = categoryService.list(type);
return Result.success(list); return Result.success(list);
} }

View File

@ -1,9 +1,36 @@
package com.sky.controller.admin; package com.sky.controller.admin;
import com.sky.dto.SetmealDTO;
import com.sky.result.Result;
import com.sky.service.SetmealService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController @RestController
@RequestMapping("/admin/setmeal")
@Api(tags = "套餐相关接口")
@Slf4j @Slf4j
public class SetmealController { public class SetmealController {
@Resource
private SetmealService setmealService;
/**
* 新增套餐
*
* @param setmealDTO SetmealDTO
* @return Result<String>
*/
@ApiOperation("新增套餐")
@PostMapping()
public Result<String> save(@RequestBody SetmealDTO setmealDTO) {
setmealService.saveWithDish(setmealDTO);
return Result.success();
}
} }

View File

@ -2,6 +2,7 @@ package com.sky.mapper;
import com.sky.annotation.AutoFill; import com.sky.annotation.AutoFill;
import com.sky.entity.Setmeal; import com.sky.entity.Setmeal;
import com.sky.entity.SetmealDish;
import com.sky.enumeration.OperationType; import com.sky.enumeration.OperationType;
import com.sky.vo.DishItemVO; import com.sky.vo.DishItemVO;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
@ -33,4 +34,11 @@ public interface SetMealDishMapper {
*/ */
@AutoFill(OperationType.UPDATE) @AutoFill(OperationType.UPDATE)
void update(Setmeal setmeal); void update(Setmeal setmeal);
/**
* 保存套餐和菜品的关联关系
*
* @param setmealDishes List<SetmealDish>
*/
void insertBatch(List<SetmealDish> setmealDishes);
} }

View File

@ -1,9 +1,10 @@
package com.sky.mapper; package com.sky.mapper;
import com.sky.annotation.AutoFill;
import com.sky.entity.Setmeal; import com.sky.entity.Setmeal;
import com.sky.enumeration.OperationType;
import com.sky.vo.DishItemVO; import com.sky.vo.DishItemVO;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import java.util.List; import java.util.List;
@ -11,6 +12,7 @@ import java.util.List;
public interface SetmealMapper { public interface SetmealMapper {
/** /**
* 根据分类id查询套餐的数量 * 根据分类id查询套餐的数量
*
* @param id Long * @param id Long
* @return Integer * @return Integer
*/ */
@ -18,6 +20,7 @@ public interface SetmealMapper {
/** /**
* 动态条件查询套餐 * 动态条件查询套餐
*
* @param setmeal Setmeal * @param setmeal Setmeal
* @return List<Setmeal> * @return List<Setmeal>
*/ */
@ -25,8 +28,17 @@ public interface SetmealMapper {
/** /**
* 根据套餐id查询菜品选项 * 根据套餐id查询菜品选项
*
* @param setmealId * @param setmealId
* @return * @return
*/ */
List<DishItemVO> getDishItemBySetmealId(Long setmealId); List<DishItemVO> getDishItemBySetmealId(Long setmealId);
/**
* 向套餐表插入数据
*
* @param setmeal Setmeal
*/
@AutoFill(OperationType.INSERT)
void insert(Setmeal setmeal);
} }

View File

@ -1,27 +1,34 @@
package com.sky.service; package com.sky.service;
import com.sky.dto.SetmealDTO; import com.sky.dto.SetmealDTO;
import com.sky.dto.SetmealPageQueryDTO;
import com.sky.entity.Setmeal; import com.sky.entity.Setmeal;
import com.sky.result.PageResult;
import com.sky.vo.DishItemVO; import com.sky.vo.DishItemVO;
import com.sky.vo.SetmealVO;
import java.util.List; import java.util.List;
public interface SetmealService { public interface SetmealService {
/** /**
* 条件查询 * 条件查询
* @param setmeal *
* @return * @param setmeal Setmeal
* @return List<Setmeal>
*/ */
List<Setmeal> list(Setmeal setmeal); List<Setmeal> list(Setmeal setmeal);
/** /**
* 根据id查询菜品选项 * 根据id查询菜品选项
*
* @param id * @param id
* @return * @return
*/ */
List<DishItemVO> getDishItemById(Long id); List<DishItemVO> getDishItemById(Long id);
/**
* 新增套餐同时需要保存套餐和菜品的关联关系
*
* @param setmealDTO SetmealDTO
*/
void saveWithDish(SetmealDTO setmealDTO);
} }

View File

@ -1,12 +1,15 @@
package com.sky.service.impl; package com.sky.service.impl;
import com.sky.dto.SetmealDTO;
import com.sky.entity.Setmeal; import com.sky.entity.Setmeal;
import com.sky.entity.SetmealDish;
import com.sky.mapper.DishMapper; import com.sky.mapper.DishMapper;
import com.sky.mapper.SetMealDishMapper; import com.sky.mapper.SetMealDishMapper;
import com.sky.mapper.SetmealMapper; import com.sky.mapper.SetmealMapper;
import com.sky.service.SetmealService; import com.sky.service.SetmealService;
import com.sky.vo.DishItemVO; import com.sky.vo.DishItemVO;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import javax.annotation.Resource; import javax.annotation.Resource;
@ -45,4 +48,26 @@ public class SetmealServiceImpl implements SetmealService {
public List<DishItemVO> getDishItemById(Long id) { public List<DishItemVO> getDishItemById(Long id) {
return setmealMapper.getDishItemBySetmealId(id); return setmealMapper.getDishItemBySetmealId(id);
} }
/**
* 新增套餐同时需要保存套餐和菜品的关联关系
*
* @param setmealDTO SetmealDTO
*/
@Override
public void saveWithDish(SetmealDTO setmealDTO) {
Setmeal setmeal = new Setmeal();
BeanUtils.copyProperties(setmealDTO, setmeal);
// 向套餐表插入数据
setmealMapper.insert(setmeal);
// 获取生成的套餐id
Long setmealId = setmeal.getId();
List<SetmealDish> setmealDishes = setmealDTO.getSetmealDishes();
setmealDishes.forEach(setmealDish -> {
setmealDish.setSetmealId(setmealId);
});
// 保存套餐和菜品的关联关系
setmealDishMapper.insertBatch(setmealDishes);
}
} }

View File

@ -2,6 +2,16 @@
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.sky.mapper.SetMealDishMapper"> <mapper namespace="com.sky.mapper.SetMealDishMapper">
<!-- 保存套餐和菜品的关联关系 -->
<insert id="insertBatch" parameterType="list">
insert into setmeal_dish
(setmeal_id,dish_id,name,price,copies)
values
<foreach collection="setmealDishes" item="sd" separator=",">
(#{sd.setmealId},#{sd.dishId},#{sd.name},#{sd.price},#{sd.copies})
</foreach>
</insert>
<!-- 菜品起售停售 --> <!-- 菜品起售停售 -->
<update id="update" parameterType="Setmeal"> <update id="update" parameterType="Setmeal">
update setmeal update setmeal

View File

@ -2,6 +2,14 @@
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.sky.mapper.SetmealMapper"> <mapper namespace="com.sky.mapper.SetmealMapper">
<!-- 向套餐表插入数据 -->
<insert id="insert" parameterType="Setmeal" useGeneratedKeys="true" keyProperty="id">
insert into setmeal
(category_id, name, price, status, description, image, create_time, update_time, create_user, update_user)
values (#{categoryId}, #{name}, #{price}, #{status}, #{description}, #{image}, #{createTime}, #{updateTime},
#{createUser}, #{updateUser})
</insert>
<!-- 根据分类id查询套餐的数量 --> <!-- 根据分类id查询套餐的数量 -->
<select id="countByCategoryId" resultType="java.lang.Integer"> <select id="countByCategoryId" resultType="java.lang.Integer">
select count(id) select count(id)