Эх сурвалжийг харах

增加常用菜单的查询

zhoux 1 жил өмнө
parent
commit
455c29afc9

+ 140 - 0
src/main/java/com/dk/oauth/entity/ComMenu.java

@@ -0,0 +1,140 @@
+package com.dk.oauth.entity;
+
+import cn.afterturn.easypoi.excel.annotation.Excel;
+import com.baomidou.mybatisplus.annotation.*;
+import java.io.Serializable;
+
+import com.dk.common.infrastructure.annotaiton.ExportTitle;
+import com.dk.common.infrastructure.handler.*;
+import com.dk.common.model.pojo.PageInfo;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import lombok.Data;
+import lombok.AllArgsConstructor;
+import lombok.NoArgsConstructor;
+import lombok.EqualsAndHashCode;
+import lombok.experimental.Accessors;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import com.alibaba.fastjson.JSONObject;
+
+import java.util.List;
+import java.time.LocalDateTime;
+
+/**
+ *  常用功能
+ */
+@Data
+@AllArgsConstructor
+@NoArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+@Accessors(chain = true)
+@ExportTitle("常用功能")
+@TableName(value = "t_mst_com_menu", autoResultMap = true,schema = "dkic_b")
+@ApiModel(value="实体类:常用功能", description="表名:t_mst_com_menu")
+public class ComMenu extends PageInfo<ComMenu> implements Serializable {
+
+    /*
+     * 数据库字段
+     */
+
+    /**
+     * 功能菜单
+     */
+    @ApiModelProperty(value = "功能菜单")
+    @TableField(typeHandler = UuidTypeHandler.class)
+    private String menuUuid;
+
+
+    /**
+     * 企业Id
+     */
+    @TableField(fill = FieldFill.INSERT)
+    @Excel(name = "企业Id")
+    @ApiModelProperty(value = "企业Id")
+    private Integer cpId;
+
+
+    /**
+     * 员工Id
+     */
+    @Excel(name = "员工Id")
+    @ApiModelProperty(value = "员工Id")
+    @TableField(typeHandler = UuidTypeHandler.class)
+    private String staffId;
+
+
+    /**
+     * 应用代码
+     */
+    @Excel(name = "应用代码")
+    @ApiModelProperty(value = "应用代码")
+    private String appCode;
+
+
+    /**
+     * 显示顺序 (【1 ~ 46655】)
+     */
+    @Excel(name = "显示顺序 (【1 ~ 46655】)")
+    @ApiModelProperty(value = "显示顺序 (【1 ~ 46655】)")
+    private Integer displayNo;
+
+
+    /**
+     * 修改时间 (触发器自动处理)
+     */
+    @Excel(name = "修改时间 (触发器自动处理)", format = "yyyy-MM-dd HH:mm:ss", width = 20)
+    @ApiModelProperty(value = "修改时间 (触发器自动处理)")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    @TableField(typeHandler = TimestampTypeHandler.class)
+    private LocalDateTime opUpdateTime;
+
+
+    /**
+     * 修改用户 (触发器自动处理)
+     */
+    @Excel(name = "修改用户 (触发器自动处理)")
+    @ApiModelProperty(value = "修改用户 (触发器自动处理)")
+    @TableField(typeHandler = UuidTypeHandler.class)
+    private String opUpdateUserId;
+
+
+    /**
+     * 数据操作应用 (触发器自动处理)
+     */
+    @Excel(name = "数据操作应用 (触发器自动处理)")
+    @ApiModelProperty(value = "数据操作应用 (触发器自动处理)")
+    private String opAppCode;
+
+
+    /**
+     * 数据时间戳 (触发器自动处理)
+     */
+    @Excel(name = "数据时间戳 (触发器自动处理)")
+    @ApiModelProperty(value = "数据时间戳 (触发器自动处理)")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    @TableField(typeHandler = TimestampTypeHandler.class)
+    private LocalDateTime opTimestamp;
+
+
+    /**
+     * 数据操作数据库用户 (触发器自动处理)
+     */
+    @Excel(name = "数据操作数据库用户 (触发器自动处理)")
+    @ApiModelProperty(value = "数据操作数据库用户 (触发器自动处理)")
+    private String opDbUser;
+
+
+    /*
+     * 相关属性
+     * @TableField(exist = false)
+     */
+
+    /*
+     * 关联属性 + 查询条件
+     * @TableField(exist = false)
+     */
+
+
+    private static final long serialVersionUID = 1L;
+
+}

+ 148 - 0
src/main/java/com/dk/oauth/entity/ComMenuResponse.java

@@ -0,0 +1,148 @@
+package com.dk.oauth.entity;
+
+import cn.afterturn.easypoi.excel.annotation.Excel;
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.dk.common.infrastructure.annotaiton.ExportTitle;
+import com.dk.common.infrastructure.handler.TimestampTypeHandler;
+import com.dk.common.infrastructure.handler.UuidTypeHandler;
+import com.dk.common.model.pojo.PageInfo;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.NoArgsConstructor;
+import lombok.experimental.Accessors;
+
+import java.io.Serializable;
+import java.time.LocalDateTime;
+
+/**
+ *  常用功能
+ */
+@Data
+@AllArgsConstructor
+@NoArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+@Accessors(chain = true)
+@ExportTitle("常用功能")
+@TableName(value = "t_mst_com_menu", autoResultMap = true)
+@ApiModel(value="实体类:常用功能", description="表名:t_mst_com_menu")
+public class ComMenuResponse extends PageInfo<ComMenuResponse> implements Serializable {
+
+    /*
+     * 数据库字段
+     */
+
+    /**
+     * 功能菜单
+     */
+    @ApiModelProperty(value = "功能菜单")
+    @TableField(typeHandler = UuidTypeHandler.class)
+    private String menuUuid;
+
+
+    /**
+     * 企业Id
+     */
+    @TableField(fill = FieldFill.INSERT)
+    @Excel(name = "企业Id")
+    @ApiModelProperty(value = "企业Id")
+    private Integer cpId;
+
+
+    /**
+     * 员工Id
+     */
+    @Excel(name = "员工Id")
+    @ApiModelProperty(value = "员工Id")
+    @TableField(typeHandler = UuidTypeHandler.class)
+    private String staffId;
+
+
+    /**
+     * 应用代码
+     */
+    @Excel(name = "应用代码")
+    @ApiModelProperty(value = "应用代码")
+    private String appCode;
+
+
+    /**
+     * 显示顺序 (【1 ~ 46655】)
+     */
+    @Excel(name = "显示顺序 (【1 ~ 46655】)")
+    @ApiModelProperty(value = "显示顺序 (【1 ~ 46655】)")
+    private Integer displayNo;
+
+
+    /**
+     * 修改时间 (触发器自动处理)
+     */
+    @Excel(name = "修改时间 (触发器自动处理)", format = "yyyy-MM-dd HH:mm:ss", width = 20)
+    @ApiModelProperty(value = "修改时间 (触发器自动处理)")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    @TableField(typeHandler = TimestampTypeHandler.class)
+    private LocalDateTime opUpdateTime;
+
+
+    /**
+     * 修改用户 (触发器自动处理)
+     */
+    @Excel(name = "修改用户 (触发器自动处理)")
+    @ApiModelProperty(value = "修改用户 (触发器自动处理)")
+    @TableField(typeHandler = UuidTypeHandler.class)
+    private String opUpdateUserId;
+
+
+    /**
+     * 数据操作应用 (触发器自动处理)
+     */
+    @Excel(name = "数据操作应用 (触发器自动处理)")
+    @ApiModelProperty(value = "数据操作应用 (触发器自动处理)")
+    private String opAppCode;
+
+
+    /**
+     * 数据时间戳 (触发器自动处理)
+     */
+    @Excel(name = "数据时间戳 (触发器自动处理)")
+    @ApiModelProperty(value = "数据时间戳 (触发器自动处理)")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    @TableField(typeHandler = TimestampTypeHandler.class)
+    private LocalDateTime opTimestamp;
+
+
+    /**
+     * 数据操作数据库用户 (触发器自动处理)
+     */
+    @Excel(name = "数据操作数据库用户 (触发器自动处理)")
+    @ApiModelProperty(value = "数据操作数据库用户 (触发器自动处理)")
+    private String opDbUser;
+
+    private String menuName;
+
+    private String objectCode;
+
+    private String objectPath;
+
+    private String objectIcon;
+
+
+    /*
+     * 相关属性
+     * @TableField(exist = false)
+     */
+
+    /*
+     * 关联属性 + 查询条件
+     * @TableField(exist = false)
+     */
+
+
+    private static final long serialVersionUID = 1L;
+
+}

+ 25 - 0
src/main/java/com/dk/oauth/mapper/ComMenuMapper.java

@@ -0,0 +1,25 @@
+package com.dk.oauth.mapper;
+
+import com.dk.common.mapper.BaseMapper;
+import com.dk.oauth.entity.ComMenu;
+import com.dk.oauth.entity.ComMenuResponse;
+import org.apache.ibatis.annotations.Param;
+import org.springframework.stereotype.Repository;
+
+import java.util.List;
+
+/**
+*  常用功能 Mapper
+*/
+@Repository
+public interface ComMenuMapper extends BaseMapper<ComMenuResponse> {
+    /**
+     * @desc   : 根据条件进行查询
+     * @author : 周兴
+     * @date   : 2024/3/29 10:42
+     */
+    List<ComMenuResponse> selectByCond(ComMenu comMenuQuery);
+
+
+}
+

+ 3 - 0
src/main/java/com/dk/oauth/service/impl/CompanyServiceImpl.java

@@ -67,6 +67,8 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper, Company> impl
     MoneyAccountMapper moneyAccountMapper;
     MoneyAccountMapper moneyAccountMapper;
     @Resource
     @Resource
     PrintLayoutMapper printLayoutMapper;
     PrintLayoutMapper printLayoutMapper;
+    @Resource
+    ComMenuMapper comMenuMapper;
     @Autowired
     @Autowired
     private CompanyConvert companyConvert;
     private CompanyConvert companyConvert;
     @Autowired
     @Autowired
@@ -390,6 +392,7 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper, Company> impl
             listGoodsCategorys.add(m);
             listGoodsCategorys.add(m);
         }
         }
         map.put("goodsCategorys",listGoodsCategorys);
         map.put("goodsCategorys",listGoodsCategorys);
+        // 常用功能
 
 
         //  打印票据
         //  打印票据
         List<PrintLayout> printLayoutResponses = printLayoutMapper.selectByCond(new PrintLayout());
         List<PrintLayout> printLayoutResponses = printLayoutMapper.selectByCond(new PrintLayout());

+ 81 - 0
src/main/resources/mapper/ComMenuMapper.xml

@@ -0,0 +1,81 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.dk.oauth.mapper.ComMenuMapper">
+
+    <!-- 通用设置 -->
+    <!-- 通用查询列 -->
+    <sql id="Base_Column_List">
+        menu_uuid
+        , cp_id, staff_id, app_code, display_no, op_update_time, op_update_user_id, op_app_code, op_timestamp, op_db_user
+    </sql>
+
+    <!-- 通用查询映射结果 -->
+    <resultMap id="BaseResultMap" type="com.dk.oauth.entity.ComMenuResponse">
+        <id column="menu_uuid" property="menuUuid" typeHandler="UuidTypeHandler"/>
+        <result column="menu_name" property="menuName"/>
+        <result column="object_code" property="objectCode"/>
+        <result column="object_path" property="objectPath"/>
+        <result column="object_icon" property="objectIcon"/>
+        <result column="cp_id" property="cpId"/>
+        <result column="staff_id" property="staffId" typeHandler="UuidTypeHandler"/>
+        <result column="app_code" property="appCode"/>
+        <result column="display_no" property="displayNo"/>
+        <result column="op_update_time" property="opUpdateTime" typeHandler="TimestampTypeHandler"/>
+        <result column="op_update_user_id" property="opUpdateUserId" typeHandler="UuidTypeHandler"/>
+        <result column="op_app_code" property="opAppCode"/>
+        <result column="op_timestamp" property="opTimestamp" typeHandler="TimestampTypeHandler"/>
+        <result column="op_db_user" property="opDbUser"/>
+    </resultMap>
+
+    <!-- 通用条件列 -->
+    <sql id="Condition">
+        <where>
+            <if test="cpId != null">
+                AND cp_id = #{cpId}
+            </if>
+            <if test="staffId != null and staffId != ''">
+                AND staff_id = #{staffId}
+            </if>
+            <if test="appCode != null and appCode != ''">
+                AND app_code = #{appCode}
+            </if>
+        </where>
+    </sql>
+
+    <sql id="idsForeach">
+        <!-- 根据主键menuUuid批量操作 -->
+        WHERE menu_uuid in
+        <foreach collection="ids" index="index" item="item" separator="," open="(" close=")">
+            #{item}
+        </foreach>
+    </sql>
+
+    <!-- 查询表t_mst_com_menu,(条件查询+分页)列表 -->
+    <select id="selectByCond" resultMap="BaseResultMap">
+        SELECT
+            sys.f_get_name_i18n ( tam.menu_name_i18n, #{i18n} ) menu_name,
+            tmcm.menu_uuid,
+            tam.object_code,
+            tam.object_path,
+            CASE WHEN tam.object_icon IS NULL THEN NULL ELSE tam.object_icon || '.png' END AS object_icon
+        FROM
+            dkic_b.t_mst_com_menu tmcm
+                INNER JOIN sys.t_app_menu tam ON tmcm.menu_uuid = tam.menu_uuid
+        WHERE
+            tmcm.staff_id = #{staffId} ::uuid
+          AND tmcm.app_code = #{appCode}
+        <if test="gradeCode != null and gradeCode != ''">
+            AND (tam.grade_codes is null or #{gradeCode} = any(tam.grade_codes))
+        </if>
+    </select>
+
+    <!-- 查询表t_mst_com_menu,(条件查询)个数 -->
+    <select id="countByCond" resultType="Long">
+        SELECT
+        count(1)
+        FROM dkic_b.t_mst_com_menu
+        <include refid="Condition"/>
+    </select>
+
+
+</mapper>