| package com.zy.crm.manager.controller; | 
|   | 
| import com.alibaba.fastjson.JSONObject; | 
| import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
| import com.baomidou.mybatisplus.mapper.Wrapper; | 
| import com.baomidou.mybatisplus.plugins.Page; | 
| import com.core.annotations.ManagerAuth; | 
| import com.core.common.BaseRes; | 
| import com.core.common.Cools; | 
| import com.core.common.DateUtils; | 
| import com.core.common.R; | 
| import com.zy.crm.common.web.BaseController; | 
| import com.zy.crm.manager.entity.ProcessPermissions; | 
| import com.zy.crm.manager.service.ProcessPermissionsService; | 
| import com.zy.crm.system.entity.User; | 
| import com.zy.crm.system.service.UserService; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.web.bind.annotation.*; | 
|   | 
| import java.util.ArrayList; | 
| import java.util.HashMap; | 
| import java.util.List; | 
| import java.util.Map; | 
|   | 
| @RestController | 
| public class ProcessPermissionsController extends BaseController { | 
|   | 
|     @Autowired | 
|     private ProcessPermissionsService processPermissionsService; | 
|     @Autowired | 
|     private UserService userService; | 
|   | 
|     @RequestMapping(value = "/processPermissions/{id}/auth") | 
|     @ManagerAuth | 
|     public R get(@PathVariable("id") String id) { | 
|         return R.ok(processPermissionsService.selectById(String.valueOf(id))); | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissions/list/auth") | 
|     @ManagerAuth | 
|     public R list(@RequestParam(defaultValue = "1")Integer curr, | 
|                   @RequestParam(defaultValue = "10")Integer limit, | 
|                   @RequestParam(required = false)String orderByField, | 
|                   @RequestParam(required = false)String orderByType, | 
|                   @RequestParam Map<String, Object> param){ | 
|         EntityWrapper<ProcessPermissions> wrapper = new EntityWrapper<>(); | 
|         excludeTrash(param); | 
|         convert(param, wrapper); | 
|         if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} | 
|         return R.ok(processPermissionsService.selectPage(new Page<>(curr, limit), wrapper)); | 
|     } | 
|   | 
|     private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ | 
|         for (Map.Entry<String, Object> entry : map.entrySet()){ | 
|             String val = String.valueOf(entry.getValue()); | 
|             if (val.contains(RANGE_TIME_LINK)){ | 
|                 String[] dates = val.split(RANGE_TIME_LINK); | 
|                 wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); | 
|                 wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); | 
|             } else { | 
|                 wrapper.like(entry.getKey(), val); | 
|             } | 
|         } | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissions/add/auth") | 
|     @ManagerAuth | 
|     public R add(ProcessPermissions processPermissions) { | 
|         int count = processPermissionsService.selectCount(new EntityWrapper<ProcessPermissions>().eq("process_memo", processPermissions.getProcessMemo()).eq("process", processPermissions.getProcess())); | 
|         if (count>0){ | 
|             return R.error("权限类型:"+processPermissions.getProcessMemo$()+"、权限节点:"+processPermissions.getProcess()+"已存在"); | 
|         } | 
|         User user = userService.selectOne(new EntityWrapper<User>().eq("username", processPermissions.getUserName())); | 
|         processPermissions.setUserId(user.getId()); | 
|         processPermissionsService.insert(processPermissions); | 
|         return R.ok(); | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissions/update/auth") | 
|     @ManagerAuth | 
|     public R update(ProcessPermissions processPermissions){ | 
|         if (Cools.isEmpty(processPermissions) || null==processPermissions.getId()){ | 
|             return R.error(); | 
|         } | 
|         int count = processPermissionsService.selectCount(new EntityWrapper<ProcessPermissions>() | 
|                 .eq("process_memo", processPermissions.getProcessMemo()).eq("process", processPermissions.getProcess()).ne("id",processPermissions.getId())); | 
|         if (count>0){ | 
|             return R.error("权限类型:"+processPermissions.getProcessMemo$()+"、权限节点:"+processPermissions.getProcess()+"已存在"); | 
|         } | 
|         User user = userService.selectOne(new EntityWrapper<User>().eq("username", processPermissions.getUserName())); | 
|         processPermissions.setUserId(user.getId()); | 
|         processPermissionsService.updateById(processPermissions); | 
|         return R.ok(); | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissions/delete/auth") | 
|     @ManagerAuth | 
|     public R delete(@RequestParam(value="ids[]") Long[] ids){ | 
|          for (Long id : ids){ | 
|             processPermissionsService.deleteById(id); | 
|         } | 
|         return R.ok(); | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissions/export/auth") | 
|     @ManagerAuth | 
|     public R export(@RequestBody JSONObject param){ | 
|         EntityWrapper<ProcessPermissions> wrapper = new EntityWrapper<>(); | 
|         List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); | 
|         Map<String, Object> map = excludeTrash(param.getJSONObject("processPermissions")); | 
|         convert(map, wrapper); | 
|         List<ProcessPermissions> list = processPermissionsService.selectList(wrapper); | 
|         return R.ok(exportSupport(list, fields)); | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissionsQuery/auth") | 
|     @ManagerAuth | 
|     public R query(String condition) { | 
|         EntityWrapper<ProcessPermissions> wrapper = new EntityWrapper<>(); | 
|         wrapper.like("id", condition); | 
|         Page<ProcessPermissions> page = processPermissionsService.selectPage(new Page<>(0, 10), wrapper); | 
|         List<Map<String, Object>> result = new ArrayList<>(); | 
|         for (ProcessPermissions processPermissions : page.getRecords()){ | 
|             Map<String, Object> map = new HashMap<>(); | 
|             map.put("id", processPermissions.getId()); | 
|             map.put("value", processPermissions.getId()); | 
|             result.add(map); | 
|         } | 
|         return R.ok(result); | 
|     } | 
|   | 
|     @RequestMapping(value = "/processPermissions/check/column/auth") | 
|     @ManagerAuth | 
|     public R query(@RequestBody JSONObject param) { | 
|         Wrapper<ProcessPermissions> wrapper = new EntityWrapper<ProcessPermissions>().eq(humpToLine(String.valueOf(param.get("key"))), param.get("val")); | 
|         if (null != processPermissionsService.selectOne(wrapper)){ | 
|             return R.parse(BaseRes.REPEAT).add(getComment(ProcessPermissions.class, String.valueOf(param.get("key")))); | 
|         } | 
|         return R.ok(); | 
|     } | 
|   | 
| } |