From 99184878caf9f772093f80a093c9be1fe65ee027 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期一, 26 八月 2024 15:42:41 +0800
Subject: [PATCH] 店铺模块

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/TShopService.java            |   22 ++++
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysUserServiceImpl.java |   25 ++++
 ruoyi-system/src/main/java/com/ruoyi/system/query/TShopQuery.java                |   27 +++++
 ruoyi-system/src/main/java/com/ruoyi/system/mapper/TShopMapper.java              |   14 ++
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TShopServiceImpl.java   |   13 ++
 ruoyi-system/src/main/java/com/ruoyi/system/service/ISysUserService.java         |   13 ++
 ruoyi-system/src/main/java/com/ruoyi/system/vo/TShopVO.java                      |   12 ++
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TShopController.java      |  106 ++++++++++++++++++++
 ruoyi-system/src/main/java/com/ruoyi/system/dto/TShopDTO.java                    |   15 +++
 ruoyi-system/src/main/java/com/ruoyi/system/domain/TShop.java                    |   12 ++
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TOrderMealController.java |    6 +
 ruoyi-system/src/main/resources/mapper/system/TShopMapper.xml                    |   29 +++++
 12 files changed, 289 insertions(+), 5 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TOrderMealController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TOrderMealController.java
index f84c963..378416c 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TOrderMealController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TOrderMealController.java
@@ -73,5 +73,11 @@
         return AjaxResult.success();
     }
 
+    @ApiOperation( value = "餐饮数据生成")
+    @PostMapping(value = "/dataGenerator")
+    public AjaxResult<String> dataGenerator(@Validated @RequestBody CheckoutDTO dto) {
+        orderMealService.checkout(dto);
+        return AjaxResult.success();
+    }
 }
 
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TShopController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TShopController.java
index 85b893f..220d113 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TShopController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TShopController.java
@@ -1,8 +1,22 @@
 package com.ruoyi.web.controller.api;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.core.domain.AjaxResult;
+import com.ruoyi.common.core.domain.entity.SysUser;
+import com.ruoyi.system.domain.TShop;
+import com.ruoyi.system.dto.TShopDTO;
+import com.ruoyi.system.query.TShopQuery;
+import com.ruoyi.system.service.ISysUserService;
+import com.ruoyi.system.service.TShopService;
+import com.ruoyi.system.vo.TShopVO;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+import java.util.Objects;
 
 /**
  * <p>
@@ -12,9 +26,97 @@
  * @author xiaochen
  * @since 2024-08-14
  */
+@Api(tags = "店铺信息")
 @RestController
 @RequestMapping("/t-shop")
 public class TShopController {
 
+    private final TShopService shopService;
+    private final ISysUserService userService;
+
+    @Autowired
+    public TShopController(TShopService shopService, ISysUserService userService) {
+        this.shopService = shopService;
+        this.userService = userService;
+    }
+
+    /**
+     * 查询店铺信息分页列表
+     */
+    @ApiOperation( value = "查询店铺信息分页列表")
+    @PostMapping(value = "/pageList")
+    public AjaxResult<PageInfo<TShopVO>> pageList(@RequestBody TShopQuery query) {
+        return AjaxResult.success(shopService.pageList(query));
+    }
+
+    /**
+     * 添加店铺信息
+     */
+    @ApiOperation( value = "添加店铺信息")
+    @PostMapping(value = "/add")
+    public AjaxResult<String> add(@RequestBody TShopDTO dto) {
+        shopService.save(dto);
+        // 添加账号
+        userService.addAccount(dto);
+        return AjaxResult.success();
+    }
+
+    /**
+     * 编辑店铺信息
+     */
+    @ApiOperation( value = "编辑店铺信息")
+    @PostMapping(value = "/edit")
+    public AjaxResult<String> edit(@RequestBody TShopDTO dto) {
+        shopService.updateById(dto);
+        userService.updateAccount(dto);
+        return AjaxResult.success();
+    }
+
+    /**
+     * 查看店铺信息详情
+     */
+    @ApiOperation( value = "查看店铺信息详情")
+    @GetMapping(value = "/getDetailById")
+    public AjaxResult<TShop> getDetailById(@RequestParam("id") Long id) {
+        return AjaxResult.success(shopService.getById(id));
+    }
+
+    /**
+     * 删除店铺信息
+     */
+    @ApiOperation( value = "删除店铺信息")
+    @DeleteMapping(value = "/deleteById")
+    public AjaxResult<Boolean> deleteById(@RequestParam("id") Long id) {
+        TShop shop = shopService.getById(id);
+        // 查询账号
+        SysUser sysUser = userService.selectUserByUserName(shop.getAccount());
+        if(Objects.nonNull(sysUser)){
+            userService.deleteUserById(sysUser.getUserId());
+        }
+        return AjaxResult.success(shopService.removeById(id));
+    }
+
+    /**
+     * 启用禁用店铺
+     */
+    @ApiOperation( value = "启用禁用店铺")
+    @GetMapping(value = "/updateStatus")
+    public AjaxResult<Boolean> updateStatus(@RequestParam(value = "id") Integer id,
+                                            @RequestParam(value = "status") Integer status) {
+        TShop shop = shopService.getById(id);
+        shop.setStatus(status);
+        shopService.updateById(shop);
+        SysUser sysUser = userService.selectUserByUserName(shop.getAccount());
+        if(Objects.nonNull(sysUser)){
+            if(status == 1){
+                sysUser.setStatus("0");
+            }else {
+                sysUser.setStatus("1");
+            }
+            userService.updateUser(sysUser);
+        }
+        return AjaxResult.success();
+    }
+
 }
 
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/domain/TShop.java b/ruoyi-system/src/main/java/com/ruoyi/system/domain/TShop.java
index 4b7875b..6b49a0f 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/domain/TShop.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/domain/TShop.java
@@ -37,6 +37,10 @@
     @TableField("shopName")
     private String shopName;
 
+    @ApiModelProperty(value = "店铺负责人")
+    @TableField("shopHead")
+    private String shopHead;
+
     @ApiModelProperty(value = "店铺样式")
     @TableField("shopStyle")
     private String shopStyle;
@@ -53,4 +57,12 @@
     @TableField("businessLicense")
     private String businessLicense;
 
+    @ApiModelProperty(value = "状态 1=启用 0=禁用")
+    @TableField("status")
+    private Integer status;
+
+    @ApiModelProperty(value = "账号")
+    @TableField("account")
+    private String account;
+
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/TShopDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/TShopDTO.java
new file mode 100644
index 0000000..aee2a41
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/TShopDTO.java
@@ -0,0 +1,15 @@
+package com.ruoyi.system.dto;
+
+import com.ruoyi.system.domain.TShop;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "店铺信息dto")
+public class TShopDTO extends TShop {
+
+    @ApiModelProperty(value = "密码")
+    private String password;
+
+}
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TShopMapper.java b/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TShopMapper.java
index de3f0a1..434038a 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TShopMapper.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TShopMapper.java
@@ -1,7 +1,13 @@
 package com.ruoyi.system.mapper;
 
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.domain.TShop;
+import com.ruoyi.system.query.TShopQuery;
+import com.ruoyi.system.vo.TShopVO;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
 
 /**
  * <p>
@@ -13,4 +19,12 @@
  */
 public interface TShopMapper extends BaseMapper<TShop> {
 
+    /**
+     * 分页查询店铺信息
+     * @param query
+     * @param pageInfo
+     * @return
+     */
+    List<TShopVO> pageList(@Param("query") TShopQuery query, @Param("pageInfo")PageInfo<TShopVO> pageInfo);
+
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/query/TShopQuery.java b/ruoyi-system/src/main/java/com/ruoyi/system/query/TShopQuery.java
new file mode 100644
index 0000000..aea983d
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/query/TShopQuery.java
@@ -0,0 +1,27 @@
+package com.ruoyi.system.query;
+
+import com.ruoyi.common.core.domain.BasePage;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "店铺查询")
+public class TShopQuery extends BasePage {
+
+    @ApiModelProperty(value = "店铺类型 1=餐饮 2=货物销售")
+    private Integer shopType;
+
+    @ApiModelProperty(value = "店铺名称")
+    private String shopName;
+
+    @ApiModelProperty(value = "店铺负责人")
+    private String shopHead;
+
+    @ApiModelProperty(value = "账号")
+    private String account;
+
+    @ApiModelProperty(value = "状态 1=启用 0=禁用")
+    private Integer status;
+
+}
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysUserService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysUserService.java
index 4dd0046..aa629d7 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysUserService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysUserService.java
@@ -4,6 +4,7 @@
 
 import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.common.core.domain.entity.SysUser;
+import com.ruoyi.system.dto.TShopDTO;
 import com.ruoyi.system.query.SysUserQuery;
 import com.ruoyi.system.vo.SysUserVO;
 
@@ -261,4 +262,16 @@
     void updatePassword(Long id, String s);
 
     long selectIdByPhone(String phonenumber);
+
+    /**
+     * 添加账号信息
+     * @param dto
+     */
+    void addAccount(TShopDTO dto);
+
+    /**
+     * 修改账号信息
+     * @param dto
+     */
+    void updateAccount(TShopDTO dto);
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/TShopService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/TShopService.java
index cb6f432..b813d5a 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/TShopService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/TShopService.java
@@ -1,7 +1,11 @@
 package com.ruoyi.system.service;
 
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.domain.TShop;
+import com.ruoyi.system.dto.TShopDTO;
+import com.ruoyi.system.query.TShopQuery;
+import com.ruoyi.system.vo.TShopVO;
 
 /**
  * <p>
@@ -13,4 +17,22 @@
  */
 public interface TShopService extends IService<TShop> {
 
+    /**
+     * 查询店铺信息分页列表
+     * @param query
+     * @return
+     */
+    PageInfo<TShopVO> pageList(TShopQuery query);
+
+    /**
+     * 添加店铺信息
+     * @param dto
+     */
+    void add(TShopDTO dto);
+
+    /**
+     * 编辑店铺信息
+     * @param dto
+     */
+    void edit(TShopDTO dto);
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysUserServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysUserServiceImpl.java
index 7e34a04..4db6ccd 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysUserServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysUserServiceImpl.java
@@ -7,6 +7,7 @@
 import javax.validation.Validator;
 
 import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.system.dto.TShopDTO;
 import com.ruoyi.system.query.SysUserQuery;
 import com.ruoyi.system.vo.SysUserVO;
 import org.slf4j.Logger;
@@ -475,8 +476,6 @@
     {
         // 删除用户与角色关联
         userRoleMapper.deleteUserRoleByUserId(userId);
-        // 删除用户与岗位表
-        userPostMapper.deleteUserPostByUserId(userId);
         return userMapper.deleteUserById(userId);
     }
 
@@ -642,6 +641,28 @@
         return userMapper.selectIdByPhone(phonenumber);
     }
 
+    @Override
+    public void addAccount(TShopDTO dto) {
+        SysUser sysUser = new SysUser();
+        sysUser.setUserName(dto.getAccount());
+        sysUser.setNickName(dto.getShopHead());
+        sysUser.setPassword(SecurityUtils.encryptPassword(dto.getPassword()));
+        this.insertUser(sysUser);
+        // TODO 自动绑定角色
+    }
+
+    @Override
+    public void updateAccount(TShopDTO dto) {
+        SysUser sysUser = this.selectUserByUserName(dto.getAccount());
+        if(Objects.isNull(sysUser)){
+            throw new ServiceException("未查询到该账号");
+        }
+        sysUser.setUserName(dto.getAccount());
+        sysUser.setNickName(dto.getShopHead());
+        sysUser.setPassword(SecurityUtils.encryptPassword(dto.getPassword()));
+        this.updateUser(sysUser);
+    }
+
 //    @Override
 //    public UserInfoVo userInfo(Long userId) {
 //        return userMapper.userInfo(userId);
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TShopServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TShopServiceImpl.java
index ff9c8dc..ef10c0c 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TShopServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TShopServiceImpl.java
@@ -1,10 +1,16 @@
 package com.ruoyi.system.service.impl;
 
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.domain.TShop;
 import com.ruoyi.system.mapper.TShopMapper;
+import com.ruoyi.system.query.TShopQuery;
 import com.ruoyi.system.service.TShopService;
+import com.ruoyi.system.vo.TGoodsVO;
+import com.ruoyi.system.vo.TShopVO;
 import org.springframework.stereotype.Service;
+
+import java.util.List;
 
 /**
  * <p>
@@ -17,4 +23,11 @@
 @Service
 public class TShopServiceImpl extends ServiceImpl<TShopMapper, TShop> implements TShopService {
 
+    @Override
+    public PageInfo<TShopVO> pageList(TShopQuery query) {
+        PageInfo<TShopVO> pageInfo = new PageInfo<>(query.getPageNum(),query.getPageSize());
+        List<TShopVO> list = this.baseMapper.pageList(query,pageInfo);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/vo/TShopVO.java b/ruoyi-system/src/main/java/com/ruoyi/system/vo/TShopVO.java
new file mode 100644
index 0000000..d886f2f
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/vo/TShopVO.java
@@ -0,0 +1,12 @@
+package com.ruoyi.system.vo;
+
+import com.ruoyi.system.domain.TShop;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "店铺返回VO")
+public class TShopVO extends TShop {
+
+}
diff --git a/ruoyi-system/src/main/resources/mapper/system/TShopMapper.xml b/ruoyi-system/src/main/resources/mapper/system/TShopMapper.xml
index 17feca4..a7d99bc 100644
--- a/ruoyi-system/src/main/resources/mapper/system/TShopMapper.xml
+++ b/ruoyi-system/src/main/resources/mapper/system/TShopMapper.xml
@@ -7,10 +7,13 @@
         <id column="id" property="id" />
         <result column="shopType" property="shopType" />
         <result column="shopName" property="shopName" />
+        <result column="shopHead" property="shopHead" />
         <result column="shopStyle" property="shopStyle" />
         <result column="systemName" property="systemName" />
         <result column="systemLogo" property="systemLogo" />
         <result column="businessLicense" property="businessLicense" />
+        <result column="status" property="status" />
+        <result column="account" property="account" />
         <result column="createTime" property="createTime" />
         <result column="updateTime" property="updateTime" />
         <result column="disabled" property="disabled" />
@@ -20,7 +23,31 @@
 
     <!-- 通用查询结果列 -->
     <sql id="Base_Column_List">
-        id, shopType, shopName, shopStyle, systemName, systemLogo, businessLicense, createTime, updateTime, disabled, createBy, updateBy
+        id, shopType, shopName,shopHead, shopStyle, systemName, systemLogo, businessLicense,status,account, createTime, updateTime, disabled, createBy, updateBy
     </sql>
+    <select id="pageList" resultType="com.ruoyi.system.vo.TShopVO">
+        select id, shopType, shopName,shopHead, shopStyle, systemName, systemLogo, businessLicense,
+        status,account, createTime, updateTime, disabled, createBy, updateBy
+        from t_shop ts
+        <where>
+            <if test="query.shopType != null">
+                AND shopType = #{query.shopType}
+            </if>
+            <if test="query.shopName != null and query.shopName != ''">
+                AND shopName LIKE concat('%',#{query.shopName},'%')
+            </if>
+            <if test="query.shopHead != null and query.shopHead != ''">
+                AND shopHead LIKE concat('%',#{query.shopHead},'%')
+            </if>
+            <if test="query.account != null and query.account != ''">
+                AND account LIKE concat('%',#{query.account},'%')
+            </if>
+            <if test="query.status != null">
+                AND status = #{query.status}
+            </if>
+            AND disabled = ${@com.ruoyi.common.enums.DisabledEnum@NO.getCode()}
+        </where>
+        ORDER BY createTime DESC
+    </select>
 
 </mapper>

--
Gitblit v1.7.1