7630daee92ab5e5b6f522131bf03be754297d186.svn-base 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480
  1. package org.jeecg.modules.system.controller;
  2. import com.alibaba.fastjson.JSON;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.baomidou.mybatisplus.core.metadata.IPage;
  6. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  7. import lombok.extern.slf4j.Slf4j;
  8. import org.apache.commons.lang.StringUtils;
  9. import org.apache.shiro.SecurityUtils;
  10. import org.jeecg.common.api.vo.Result;
  11. import org.jeecg.common.system.query.QueryGenerator;
  12. import org.jeecg.common.system.vo.DictModel;
  13. import org.jeecg.common.system.vo.LoginUser;
  14. import org.jeecg.common.util.oConvertUtils;
  15. import org.jeecg.modules.system.entity.SysCategory;
  16. import org.jeecg.modules.system.model.TreeSelectModel;
  17. import org.jeecg.modules.system.service.ISysCategoryService;
  18. import org.jeecgframework.poi.excel.ExcelImportUtil;
  19. import org.jeecgframework.poi.excel.def.NormalExcelConstants;
  20. import org.jeecgframework.poi.excel.entity.ExportParams;
  21. import org.jeecgframework.poi.excel.entity.ImportParams;
  22. import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
  23. import org.springframework.beans.factory.annotation.Autowired;
  24. import org.springframework.web.bind.annotation.*;
  25. import org.springframework.web.multipart.MultipartFile;
  26. import org.springframework.web.multipart.MultipartHttpServletRequest;
  27. import org.springframework.web.servlet.ModelAndView;
  28. import javax.servlet.http.HttpServletRequest;
  29. import javax.servlet.http.HttpServletResponse;
  30. import java.io.IOException;
  31. import java.util.*;
  32. import java.util.stream.Collectors;
  33. /**
  34. * @Description: 分类字典
  35. * @Author: jeecg-boot
  36. * @Date: 2019-05-29
  37. * @Version: V1.0
  38. */
  39. @RestController
  40. @RequestMapping("/sys/category")
  41. @Slf4j
  42. public class SysCategoryController {
  43. @Autowired
  44. private ISysCategoryService sysCategoryService;
  45. /**
  46. * 分页列表查询
  47. * @param sysCategory
  48. * @param pageNo
  49. * @param pageSize
  50. * @param req
  51. * @return
  52. */
  53. @GetMapping(value = "/rootList")
  54. public Result<IPage<SysCategory>> queryPageList(SysCategory sysCategory,
  55. @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
  56. @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
  57. HttpServletRequest req) {
  58. if(oConvertUtils.isEmpty(sysCategory.getPid())){
  59. sysCategory.setPid("0");
  60. }
  61. Result<IPage<SysCategory>> result = new Result<IPage<SysCategory>>();
  62. //--author:os_chengtgen---date:20190804 -----for: 分类字典页面显示错误,issues:377--------start
  63. //QueryWrapper<SysCategory> queryWrapper = QueryGenerator.initQueryWrapper(sysCategory, req.getParameterMap());
  64. QueryWrapper<SysCategory> queryWrapper = new QueryWrapper<SysCategory>();
  65. queryWrapper.eq("pid", sysCategory.getPid());
  66. //--author:os_chengtgen---date:20190804 -----for: 分类字典页面显示错误,issues:377--------end
  67. Page<SysCategory> page = new Page<SysCategory>(pageNo, pageSize);
  68. IPage<SysCategory> pageList = sysCategoryService.page(page, queryWrapper);
  69. result.setSuccess(true);
  70. result.setResult(pageList);
  71. return result;
  72. }
  73. @GetMapping(value = "/childList")
  74. public Result<List<SysCategory>> queryPageList(SysCategory sysCategory,HttpServletRequest req) {
  75. Result<List<SysCategory>> result = new Result<List<SysCategory>>();
  76. QueryWrapper<SysCategory> queryWrapper = QueryGenerator.initQueryWrapper(sysCategory, req.getParameterMap());
  77. List<SysCategory> list = sysCategoryService.list(queryWrapper);
  78. result.setSuccess(true);
  79. result.setResult(list);
  80. return result;
  81. }
  82. /**
  83. * 添加
  84. * @param sysCategory
  85. * @return
  86. */
  87. @PostMapping(value = "/add")
  88. public Result<SysCategory> add(@RequestBody SysCategory sysCategory) {
  89. Result<SysCategory> result = new Result<SysCategory>();
  90. try {
  91. sysCategoryService.addSysCategory(sysCategory);
  92. result.success("添加成功!");
  93. } catch (Exception e) {
  94. log.error(e.getMessage(),e);
  95. result.error500("操作失败");
  96. }
  97. return result;
  98. }
  99. /**
  100. * 编辑
  101. * @param sysCategory
  102. * @return
  103. */
  104. @PostMapping(value = "/edit")
  105. public Result<SysCategory> edit(@RequestBody SysCategory sysCategory) {
  106. Result<SysCategory> result = new Result<SysCategory>();
  107. SysCategory sysCategoryEntity = sysCategoryService.getById(sysCategory.getId());
  108. if(sysCategoryEntity==null) {
  109. result.error500("未找到对应实体");
  110. }else {
  111. sysCategoryService.updateSysCategory(sysCategory);
  112. result.success("修改成功!");
  113. }
  114. return result;
  115. }
  116. /**
  117. * 通过id删除
  118. * @param id
  119. * @return
  120. */
  121. @PostMapping(value = "/delete")
  122. public Result<SysCategory> delete(@RequestParam(name="id",required=true) String id) {
  123. Result<SysCategory> result = new Result<SysCategory>();
  124. SysCategory sysCategory = sysCategoryService.getById(id);
  125. if(sysCategory==null) {
  126. result.error500("未找到对应实体");
  127. }else {
  128. this.sysCategoryService.deleteSysCategory(id);
  129. result.success("删除成功!");
  130. }
  131. return result;
  132. }
  133. /**
  134. * 批量删除
  135. * @param ids
  136. * @return
  137. */
  138. @PostMapping(value = "/deleteBatch")
  139. public Result<SysCategory> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
  140. Result<SysCategory> result = new Result<SysCategory>();
  141. if(ids==null || "".equals(ids.trim())) {
  142. result.error500("参数不识别!");
  143. }else {
  144. this.sysCategoryService.deleteSysCategory(ids);
  145. result.success("删除成功!");
  146. }
  147. return result;
  148. }
  149. /**
  150. * 通过id查询
  151. * @param id
  152. * @return
  153. */
  154. @GetMapping(value = "/queryById")
  155. public Result<SysCategory> queryById(@RequestParam(name="id",required=true) String id) {
  156. Result<SysCategory> result = new Result<SysCategory>();
  157. SysCategory sysCategory = sysCategoryService.getById(id);
  158. if(sysCategory==null) {
  159. result.error500("未找到对应实体");
  160. }else {
  161. result.setResult(sysCategory);
  162. result.setSuccess(true);
  163. }
  164. return result;
  165. }
  166. /**
  167. * 导出excel
  168. *
  169. * @param request
  170. */
  171. @RequestMapping(value = "/exportXls")
  172. public ModelAndView exportXls(HttpServletRequest request, SysCategory sysCategory) {
  173. // Step.1 组装查询条件查询数据
  174. QueryWrapper<SysCategory> queryWrapper = QueryGenerator.initQueryWrapper(sysCategory, request.getParameterMap());
  175. List<SysCategory> pageList = sysCategoryService.list(queryWrapper);
  176. // Step.2 AutoPoi 导出Excel
  177. ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
  178. // 过滤选中数据
  179. String selections = request.getParameter("selections");
  180. if(oConvertUtils.isEmpty(selections)) {
  181. mv.addObject(NormalExcelConstants.DATA_LIST, pageList);
  182. }else {
  183. List<String> selectionList = Arrays.asList(selections.split(","));
  184. List<SysCategory> exportList = pageList.stream().filter(item -> selectionList.contains(item.getId())).collect(Collectors.toList());
  185. mv.addObject(NormalExcelConstants.DATA_LIST, exportList);
  186. }
  187. //导出文件名称
  188. mv.addObject(NormalExcelConstants.FILE_NAME, "分类字典列表");
  189. mv.addObject(NormalExcelConstants.CLASS, SysCategory.class);
  190. LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal();
  191. mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("分类字典列表数据", "导出人:"+user.getRealname(), "导出信息"));
  192. return mv;
  193. }
  194. /**
  195. * 通过excel导入数据
  196. *
  197. * @param request
  198. * @param response
  199. * @return
  200. */
  201. @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
  202. public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
  203. MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
  204. Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
  205. for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
  206. MultipartFile file = entity.getValue();// 获取上传文件对象
  207. ImportParams params = new ImportParams();
  208. params.setTitleRows(2);
  209. params.setHeadRows(1);
  210. params.setNeedSave(true);
  211. try {
  212. List<SysCategory> listSysCategorys = ExcelImportUtil.importExcel(file.getInputStream(), SysCategory.class, params);
  213. //按照编码长度排序
  214. Collections.sort(listSysCategorys);
  215. log.info("排序后的list====>",listSysCategorys);
  216. for (SysCategory sysCategoryExcel : listSysCategorys) {
  217. String code = sysCategoryExcel.getCode();
  218. if(code.length()>3){
  219. String pCode = sysCategoryExcel.getCode().substring(0,code.length()-3);
  220. log.info("pCode====>",pCode);
  221. String pId=sysCategoryService.queryIdByCode(pCode);
  222. log.info("pId====>",pId);
  223. if(StringUtils.isNotBlank(pId)){
  224. sysCategoryExcel.setPid(pId);
  225. }
  226. }else{
  227. sysCategoryExcel.setPid("0");
  228. }
  229. sysCategoryService.save(sysCategoryExcel);
  230. }
  231. return Result.ok("文件导入成功!数据行数:" + listSysCategorys.size());
  232. } catch (Exception e) {
  233. log.error(e.getMessage(), e);
  234. return Result.error("文件导入失败:"+e.getMessage());
  235. } finally {
  236. try {
  237. file.getInputStream().close();
  238. } catch (IOException e) {
  239. e.printStackTrace();
  240. }
  241. }
  242. }
  243. return Result.error("文件导入失败!");
  244. }
  245. /**
  246. * 加载单个数据 用于回显
  247. */
  248. @RequestMapping(value = "/loadOne", method = RequestMethod.GET)
  249. public Result<SysCategory> loadOne(@RequestParam(name="field") String field,@RequestParam(name="val") String val) {
  250. Result<SysCategory> result = new Result<SysCategory>();
  251. try {
  252. QueryWrapper<SysCategory> query = new QueryWrapper<SysCategory>();
  253. query.eq(field, val);
  254. List<SysCategory> ls = this.sysCategoryService.list(query);
  255. if(ls==null || ls.size()==0) {
  256. result.setMessage("查询无果");
  257. result.setSuccess(false);
  258. }else if(ls.size()>1) {
  259. result.setMessage("查询数据异常,["+field+"]存在多个值:"+val);
  260. result.setSuccess(false);
  261. }else {
  262. result.setSuccess(true);
  263. result.setResult(ls.get(0));
  264. }
  265. } catch (Exception e) {
  266. e.printStackTrace();
  267. result.setMessage(e.getMessage());
  268. result.setSuccess(false);
  269. }
  270. return result;
  271. }
  272. /**
  273. * 加载节点的子数据
  274. */
  275. @RequestMapping(value = "/loadTreeChildren", method = RequestMethod.GET)
  276. public Result<List<TreeSelectModel>> loadTreeChildren(@RequestParam(name="pid") String pid) {
  277. Result<List<TreeSelectModel>> result = new Result<List<TreeSelectModel>>();
  278. try {
  279. List<TreeSelectModel> ls = this.sysCategoryService.queryListByPid(pid);
  280. result.setResult(ls);
  281. result.setSuccess(true);
  282. } catch (Exception e) {
  283. e.printStackTrace();
  284. result.setMessage(e.getMessage());
  285. result.setSuccess(false);
  286. }
  287. return result;
  288. }
  289. /**
  290. * 加载一级节点/如果是同步 则所有数据
  291. */
  292. @RequestMapping(value = "/loadTreeRoot", method = RequestMethod.GET)
  293. public Result<List<TreeSelectModel>> loadTreeRoot(@RequestParam(name="async") Boolean async,@RequestParam(name="pcode") String pcode) {
  294. Result<List<TreeSelectModel>> result = new Result<List<TreeSelectModel>>();
  295. try {
  296. List<TreeSelectModel> ls = this.sysCategoryService.queryListByCode(pcode);
  297. if(!async) {
  298. loadAllCategoryChildren(ls);
  299. }
  300. result.setResult(ls);
  301. result.setSuccess(true);
  302. } catch (Exception e) {
  303. e.printStackTrace();
  304. result.setMessage(e.getMessage());
  305. result.setSuccess(false);
  306. }
  307. return result;
  308. }
  309. /**
  310. * 递归求子节点 同步加载用到
  311. */
  312. private void loadAllCategoryChildren(List<TreeSelectModel> ls) {
  313. for (TreeSelectModel tsm : ls) {
  314. List<TreeSelectModel> temp = this.sysCategoryService.queryListByPid(tsm.getKey());
  315. if(temp!=null && temp.size()>0) {
  316. tsm.setChildren(temp);
  317. loadAllCategoryChildren(temp);
  318. }
  319. }
  320. }
  321. /**
  322. * 校验编码
  323. * @param pid
  324. * @param code
  325. * @return
  326. */
  327. @GetMapping(value = "/checkCode")
  328. public Result<?> checkCode(@RequestParam(name="pid",required = false) String pid,@RequestParam(name="code",required = false) String code) {
  329. if(oConvertUtils.isEmpty(code)){
  330. return Result.error("错误,类型编码为空!");
  331. }
  332. if(oConvertUtils.isEmpty(pid)){
  333. return Result.ok();
  334. }
  335. SysCategory parent = this.sysCategoryService.getById(pid);
  336. if(code.startsWith(parent.getCode())){
  337. return Result.ok();
  338. }else{
  339. return Result.error("编码不符合规范,须以\""+parent.getCode()+"\"开头!");
  340. }
  341. }
  342. /**
  343. * 分类字典树控件 加载节点
  344. * @param pid
  345. * @param pcode
  346. * @param condition
  347. * @return
  348. */
  349. @RequestMapping(value = "/loadTreeData", method = RequestMethod.GET)
  350. public Result<List<TreeSelectModel>> loadDict(@RequestParam(name="pid",required = false) String pid,@RequestParam(name="pcode",required = false) String pcode, @RequestParam(name="condition",required = false) String condition) {
  351. Result<List<TreeSelectModel>> result = new Result<List<TreeSelectModel>>();
  352. //pid如果传值了 就忽略pcode的作用
  353. if(oConvertUtils.isEmpty(pid)){
  354. if(oConvertUtils.isEmpty(pcode)){
  355. result.setSuccess(false);
  356. result.setMessage("加载分类字典树参数有误.[null]!");
  357. return result;
  358. }else{
  359. if(ISysCategoryService.ROOT_PID_VALUE.equals(pcode)){
  360. pid = ISysCategoryService.ROOT_PID_VALUE;
  361. }else{
  362. pid = this.sysCategoryService.queryIdByCode(pcode);
  363. }
  364. if(oConvertUtils.isEmpty(pid)){
  365. result.setSuccess(false);
  366. result.setMessage("加载分类字典树参数有误.[code]!");
  367. return result;
  368. }
  369. }
  370. }
  371. Map<String, String> query = null;
  372. if(oConvertUtils.isNotEmpty(condition)) {
  373. query = JSON.parseObject(condition, Map.class);
  374. }
  375. List<TreeSelectModel> ls = sysCategoryService.queryListByPid(pid,query);
  376. result.setSuccess(true);
  377. result.setResult(ls);
  378. return result;
  379. }
  380. /**
  381. * 分类字典控件数据回显[表单页面]
  382. *
  383. * @param ids
  384. * @param delNotExist 是否移除不存在的项,默认为true,设为false如果某个key不存在数据库中,则直接返回key本身
  385. * @return
  386. */
  387. @RequestMapping(value = "/loadDictItem", method = RequestMethod.GET)
  388. public Result<List<String>> loadDictItem(@RequestParam(name = "ids") String ids, @RequestParam(name = "delNotExist", required = false, defaultValue = "true") boolean delNotExist) {
  389. Result<List<String>> result = new Result<>();
  390. // 非空判断
  391. if (StringUtils.isBlank(ids)) {
  392. result.setSuccess(false);
  393. result.setMessage("ids 不能为空");
  394. return result;
  395. }
  396. // 查询数据
  397. List<String> textList = sysCategoryService.loadDictItem(ids, delNotExist);
  398. result.setSuccess(true);
  399. result.setResult(textList);
  400. return result;
  401. }
  402. /**
  403. * [列表页面]加载分类字典数据 用于值的替换
  404. * @param code
  405. * @return
  406. */
  407. @RequestMapping(value = "/loadAllData", method = RequestMethod.GET)
  408. public Result<List<DictModel>> loadAllData(@RequestParam(name="code",required = true) String code) {
  409. Result<List<DictModel>> result = new Result<List<DictModel>>();
  410. LambdaQueryWrapper<SysCategory> query = new LambdaQueryWrapper<SysCategory>();
  411. if(oConvertUtils.isNotEmpty(code) && !"0".equals(code)){
  412. query.likeRight(SysCategory::getCode,code);
  413. }
  414. List<SysCategory> list = this.sysCategoryService.list(query);
  415. if(list==null || list.size()==0) {
  416. result.setMessage("无数据,参数有误.[code]");
  417. result.setSuccess(false);
  418. return result;
  419. }
  420. List<DictModel> rdList = new ArrayList<DictModel>();
  421. for (SysCategory c : list) {
  422. rdList.add(new DictModel(c.getId(),c.getName()));
  423. }
  424. result.setSuccess(true);
  425. result.setResult(rdList);
  426. return result;
  427. }
  428. /**
  429. * 根据父级id批量查询子节点
  430. * @param parentIds
  431. * @return
  432. */
  433. @GetMapping("/getChildListBatch")
  434. public Result getChildListBatch(@RequestParam("parentIds") String parentIds) {
  435. try {
  436. QueryWrapper<SysCategory> queryWrapper = new QueryWrapper<>();
  437. List<String> parentIdList = Arrays.asList(parentIds.split(","));
  438. queryWrapper.in("pid", parentIdList);
  439. List<SysCategory> list = sysCategoryService.list(queryWrapper);
  440. IPage<SysCategory> pageList = new Page<>(1, 10, list.size());
  441. pageList.setRecords(list);
  442. return Result.OK(pageList);
  443. } catch (Exception e) {
  444. log.error(e.getMessage(), e);
  445. return Result.error("批量查询子节点失败:" + e.getMessage());
  446. }
  447. }
  448. }