From 381d0465a589a1862e9d79394619ae4bcc04350b Mon Sep 17 00:00:00 2001
From: lizijie <lzjiiie@163.com>
Date: Wed, 07 Apr 2021 08:39:51 +0800
Subject: [PATCH] 角色功能修改

---
 screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java |  151 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 151 insertions(+), 0 deletions(-)

diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java
index 67846e8..a262230 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/ManageRoleServiceImpl.java
@@ -1,13 +1,26 @@
 package com.moral.api.service.impl;
 
+import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.moral.api.entity.ManageAccountRole;
+import com.moral.api.entity.ManageMenu;
 import com.moral.api.entity.ManageRole;
+import com.moral.api.mapper.ManageAccountRoleMapper;
 import com.moral.api.mapper.ManageRoleMapper;
+import com.moral.api.mapper.ManageRoleMenuMapper;
 import com.moral.api.service.ManageRoleService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.moral.constant.Constants;
+import com.moral.constant.ResponseCodeEnum;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.domain.Page;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.StringUtils;
 
 import javax.annotation.Resource;
+import java.text.SimpleDateFormat;
+import java.util.*;
 
 /**
  * <p>
@@ -28,4 +41,142 @@
             return null;
         return null;
     }
+
+    @Autowired(required = false)
+    private ManageRoleMapper manageRoleMapper;
+
+    @Autowired(required = false)
+    private ManageRoleMenuMapper manageRoleMenuMapper;
+
+    @Autowired(required = false)
+    private ManageAccountRoleMapper manageAccountRoleMapper;
+
+    @Override
+    @Transactional
+    public Map<String,Object> getAllWithPagingQuery(Map map) {
+        Map<String,Object> resultMap = new HashMap<>();
+        int current = Integer.parseInt(map.get("current").toString());
+        int size = Integer.parseInt(map.get("size").toString());
+        com.baomidou.mybatisplus.extension.plugins.pagination.Page<ManageRole> page = new com.baomidou.mybatisplus.extension.plugins.pagination.Page<>(current, size);
+        QueryWrapper<ManageRole> wrapper = new QueryWrapper();
+        wrapper.eq("is_delete",0);
+        wrapper.orderByDesc("create_time");
+        com.baomidou.mybatisplus.extension.plugins.pagination.Page resultpage = manageRoleMapper.selectPage(page,wrapper);
+        List<ManageRole> manageRoles = resultpage.getRecords();
+        SimpleDateFormat SDF = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+        List<Map<String,Object>> manageRolesList = new ArrayList<>();
+        for (ManageRole manageRole:manageRoles) {
+            Map manageRoleMap = JSON.parseObject(JSON.toJSONString(manageRole),Map.class);
+            String createTime = SDF.format(manageRole.getCreateTime());
+            String updateTime = SDF.format(manageRole.getUpdateTime());
+            manageRoleMap.put("createTime",createTime);
+            manageRoleMap.put("updateTime",updateTime);
+            manageRolesList.add(manageRoleMap);
+        }
+        resultMap.put("manageRoles",manageRolesList);
+        int totalNumber = manageRoleMapper.selectCount(wrapper);
+        resultMap.put("totalNumber",totalNumber);
+        resultMap.put("current",current);
+        int totalPageNumber = totalNumber/size;
+        if(totalNumber%size != 0){
+            totalPageNumber += 1;
+        }
+        resultMap.put("totalPageNumber",totalPageNumber);
+        return resultMap;
+    }
+
+    @Override
+    @Transactional
+    public Map<String,Object> insertOne(ManageRole manageRole,List list) {
+        Map<String,Object> resultMap = new HashMap<>();
+        if (manageRole.getName()==null){
+            resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
+            resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+            return resultMap;
+        }
+        if (manageRoleMapper.getManageRoleByName(manageRole.getName()) != null){
+            resultMap.put("code",ResponseCodeEnum.ROLE_IS_EXPIRE.getCode());
+            resultMap.put("msg",ResponseCodeEnum.ROLE_IS_EXPIRE.getMsg());
+        }else {
+            manageRoleMapper.insertOne(manageRole);
+            resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
+            resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
+        }
+        Integer code = Integer.parseInt(resultMap.get("code").toString());
+        if (code.equals(ResponseCodeEnum.SUCCESS.getCode())){
+            ManageRole manageRoleIns = manageRoleMapper.getManageRoleByName(manageRole.getName());
+            int role_id = manageRoleIns.getId();
+            List insertList = new ArrayList();
+            for (Object temp: list) {
+                Map<String,Integer> insertMap = new HashMap<>();
+                insertMap.put("role_id",role_id);
+                insertMap.put("menu_id",Integer.parseInt(temp.toString()));
+                insertList.add(insertMap);
+            }
+            manageRoleMenuMapper.insertBatch(insertList);
+        }
+        return resultMap;
+    }
+
+    @Override
+    @Transactional
+    public Map<String,Object> updateManageRole(Map map) {
+        Map<String,Object> resultMap = new HashMap<>();
+        if (!map.containsKey("id")){
+            resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
+            resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+            return resultMap;
+        }
+        if (manageRoleMapper.getManageRoleById(Integer.parseInt(map.get("id").toString())) == null){
+            resultMap.put("code",ResponseCodeEnum.ROLE_IS_NULL.getCode());
+            resultMap.put("msg",ResponseCodeEnum.ROLE_IS_NULL.getMsg());
+        }else {
+            manageRoleMapper.updateManageRoleById(map);
+            resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
+            resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
+        }
+        return resultMap;
+    }
+
+    @Override
+    @Transactional
+    public List<ManageRole> getManageRoleByNameFuzzy(Map map) {
+        com.baomidou.mybatisplus.extension.plugins.pagination.Page<ManageRole> page = new com.baomidou.mybatisplus.extension.plugins.pagination.Page<>(Integer.parseInt(map.get("current").toString()), Integer.parseInt(map.get("size").toString()));
+        QueryWrapper<ManageRole> wrapper = new QueryWrapper();
+        wrapper.eq("is_delete",0);
+        wrapper.like("name",map.get("name"));
+        com.baomidou.mybatisplus.extension.plugins.pagination.Page resultpage = manageRoleMapper.selectPage(page,wrapper);
+        List<ManageRole> manageRoles = resultpage.getRecords();
+        return manageRoles;
+    }
+
+    @Override
+    public Map<String, Object> deleteManageRole(Map map) {
+        Map<String,Object> resultMap = new HashMap<>();
+        if (!map.containsKey("id")){
+            resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
+            resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+            return resultMap;
+        }
+        if (manageRoleMapper.getManageRoleById(Integer.parseInt(map.get("id").toString())) == null){
+            resultMap.put("code",ResponseCodeEnum.ROLE_IS_NULL.getCode());
+            resultMap.put("msg",ResponseCodeEnum.ROLE_IS_NULL.getMsg());
+        }else {
+            ManageRole manageRole = new ManageRole();
+            manageRole.setId(Integer.parseInt(map.get("id").toString()));
+            manageRole.setIsDelete(Constants.DELETE);
+            Map deleteMap = new HashMap();
+            deleteMap.put("id",Integer.parseInt(map.get("id").toString()));
+            deleteMap.put("is_delete",1);
+            manageRoleMapper.updateManageRoleById(deleteMap);
+            ManageAccountRole manageAccountRole = new ManageAccountRole();
+            manageAccountRole.setIsDelete("1");
+            QueryWrapper<ManageAccountRole> wrapper = new QueryWrapper();
+            wrapper.eq("role_id",Integer.parseInt(map.get("id").toString()));
+            manageAccountRoleMapper.update(manageAccountRole,wrapper);
+            resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
+            resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
+        }
+        return resultMap;
+    }
 }

--
Gitblit v1.8.0