package com.zy.crm.system.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.Cools; import com.core.common.DateUtils; import com.core.common.R; import com.core.domain.KeyValueVo; import com.core.exception.CoolException; import com.zy.crm.common.web.BaseController; import com.zy.crm.manager.service.CstmrService; import com.zy.crm.system.entity.Role; import com.zy.crm.system.entity.User; import com.zy.crm.system.service.RoleService; import com.zy.crm.system.service.UserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import java.util.*; @RestController public class UserController extends BaseController { @Autowired private UserService userService; @Autowired private RoleService roleService; @Autowired private CstmrService cstmrService; @RequestMapping(value = "/user/{id}/auth") @ManagerAuth public R get(@PathVariable("id") Long id) { return R.ok(userService.selectById(String.valueOf(id))); } @RequestMapping(value = "/user/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 param){ excludeTrash(param); EntityWrapper wrapper = new EntityWrapper<>(); convert(param, wrapper); wrapper.orderBy("id", false); Long hostId = getHostId(); if (null != hostId) { wrapper.eq("host_id", hostId); } if (9527 == getUserId()) { return R.ok(userService.selectPage(new Page<>(curr, limit), wrapper)); } Long roleId = getUser().getRoleId(); Role role = roleService.selectById(roleId); Long leaderId = role.getLeader(); if (null != leaderId) { List leaderIds = new ArrayList<>(); leaderIds.add(role.getId()); while (leaderId != null) { Role leader = roleService.selectById(leaderId); leaderIds.add(leader.getId()); leaderId = leader.getLeader(); } wrapper.notIn("role_id", leaderIds); } return R.ok(userService.selectPage(new Page<>(curr, limit), wrapper)); } @RequestMapping(value = "/user/page/auth") @ManagerAuth public R page(@RequestParam(defaultValue = "1")Integer curr, @RequestParam(defaultValue = "10")Integer limit, @RequestParam(required = false)String orderByField, @RequestParam(required = false)String orderByType, @RequestParam Map param){ Object deptId = param.get("dept_id"); if (Cools.isEmpty(deptId)) { deptId = getOriginDept().getId(); } return R.ok(userService.getPage(new Page<>(curr, limit) , getHostId() , String.valueOf(deptId) , param.get("username") , param.get("mobile")) ); } private void convert(Map map, EntityWrapper wrapper){ for (Map.Entry 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 = "/user/add/auth") @ManagerAuth(memo = "系统用户添加") public R add(User user) { user.setNickname(user.getUsername()); if (userService.selectCount(new EntityWrapper().eq("mobile", user.getMobile()))>0) { return R.error("手机号已存在"); } user.setHostId(getHostId()); user.setStatus(1); user.setCreateTime(new Date()); user.setPassword("827ccb0eea8a706c4c34a16891f84e7b"); //添加用户时,默认密码 12345 userService.insert(user); return R.ok(); } @RequestMapping(value = "/user/update/auth") @ManagerAuth(memo = "系统用户修改") @Transactional public R update(User user){ if (Cools.isEmpty(user) || null==user.getId()){ return R.error(); } if (userService.selectCount(new EntityWrapper().ne("id", user.getId()).eq("username", user.getUsername())) > 0) { return R.error("账号已存在"); } User one = userService.selectById(user.getId()); if (!one.getDeptId().equals(user.getDeptId())) { // todo: 修改关联数据的deptId字段 cstmrService.updateDeptIdByUserId(user.getId(), user.getDeptId()); } user.setNickname(user.getUsername()); if (!userService.updateById(user)) { throw new CoolException("修改用户失败"); } return R.ok(); } @RequestMapping(value = "/user/delete/auth") @ManagerAuth @Transactional public R deleteBatch(@RequestParam(value = "ids[]") Long[] ids){ if (Cools.isEmpty((Object) ids)){ return R.error(); } for (Long id : ids){ if (!userService.deleteById(id)) { throw new CoolException("服务器错误,请联系管理员"); } } return R.ok(); } @RequestMapping(value = "/user/export/auth") @ManagerAuth(memo = "系统用户导出") public R export(@RequestBody JSONObject param){ List fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); EntityWrapper wrapper = new EntityWrapper<>(); Map map = excludeTrash(param.getJSONObject("user")); convert(map, wrapper); List list = userService.selectList(wrapper); return R.ok(exportSupport(list, fields)); } @RequestMapping(value = "/userQuery/auth") @ManagerAuth public R query(String condition) { EntityWrapper wrapper = new EntityWrapper<>(); wrapper.like("username", condition); Page page = userService.selectPage(new Page<>(0, 10), wrapper); List> result = new ArrayList<>(); for (User user : page.getRecords()){ Map map = new HashMap<>(); map.put("id", user.getId()); map.put("value", user.getNickname()); result.add(map); } return R.ok(result); } /*************************************** xm-select ***********************************************/ // xm-select 搜索商品列表 @RequestMapping("/user/all/get/kv") @ManagerAuth public R getUserDataKV(@RequestParam(required = false) String condition) { Wrapper wrapper = new EntityWrapper() .andNew().like("username", condition).or().like("nickname", condition) .orderBy("create_time", false); List users = userService.selectPage(new Page<>(1, 30), wrapper).getRecords(); List valueVos = new ArrayList<>(); for (User user : users) { KeyValueVo vo = new KeyValueVo(); vo.setName(user.getNickname()); vo.setValue(user.getId()); valueVos.add(vo); } return R.ok().add(valueVos); } }