123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480 |
- package org.jeecg.modules.system.controller;
- import com.alibaba.fastjson.JSON;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.baomidou.mybatisplus.core.metadata.IPage;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import lombok.extern.slf4j.Slf4j;
- import org.apache.commons.lang.StringUtils;
- import org.apache.shiro.SecurityUtils;
- import org.jeecg.common.api.vo.Result;
- import org.jeecg.common.system.query.QueryGenerator;
- import org.jeecg.common.system.vo.DictModel;
- import org.jeecg.common.system.vo.LoginUser;
- import org.jeecg.common.util.oConvertUtils;
- import org.jeecg.modules.system.entity.SysCategory;
- import org.jeecg.modules.system.model.TreeSelectModel;
- import org.jeecg.modules.system.service.ISysCategoryService;
- import org.jeecgframework.poi.excel.ExcelImportUtil;
- import org.jeecgframework.poi.excel.def.NormalExcelConstants;
- import org.jeecgframework.poi.excel.entity.ExportParams;
- import org.jeecgframework.poi.excel.entity.ImportParams;
- import org.jeecgframework.poi.excel.view.JeecgEntityExcelView;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.*;
- import org.springframework.web.multipart.MultipartFile;
- import org.springframework.web.multipart.MultipartHttpServletRequest;
- import org.springframework.web.servlet.ModelAndView;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import java.io.IOException;
- import java.util.*;
- import java.util.stream.Collectors;
- /**
- * @Description: 分类字典
- * @Author: jeecg-boot
- * @Date: 2019-05-29
- * @Version: V1.0
- */
- @RestController
- @RequestMapping("/sys/category")
- @Slf4j
- public class SysCategoryController {
- @Autowired
- private ISysCategoryService sysCategoryService;
-
- /**
- * 分页列表查询
- * @param sysCategory
- * @param pageNo
- * @param pageSize
- * @param req
- * @return
- */
- @GetMapping(value = "/rootList")
- public Result<IPage<SysCategory>> queryPageList(SysCategory sysCategory,
- @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
- @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
- HttpServletRequest req) {
- if(oConvertUtils.isEmpty(sysCategory.getPid())){
- sysCategory.setPid("0");
- }
- Result<IPage<SysCategory>> result = new Result<IPage<SysCategory>>();
-
- //--author:os_chengtgen---date:20190804 -----for: 分类字典页面显示错误,issues:377--------start
- //QueryWrapper<SysCategory> queryWrapper = QueryGenerator.initQueryWrapper(sysCategory, req.getParameterMap());
- QueryWrapper<SysCategory> queryWrapper = new QueryWrapper<SysCategory>();
- queryWrapper.eq("pid", sysCategory.getPid());
- //--author:os_chengtgen---date:20190804 -----for: 分类字典页面显示错误,issues:377--------end
- Page<SysCategory> page = new Page<SysCategory>(pageNo, pageSize);
- IPage<SysCategory> pageList = sysCategoryService.page(page, queryWrapper);
- result.setSuccess(true);
- result.setResult(pageList);
- return result;
- }
-
- @GetMapping(value = "/childList")
- public Result<List<SysCategory>> queryPageList(SysCategory sysCategory,HttpServletRequest req) {
- Result<List<SysCategory>> result = new Result<List<SysCategory>>();
- QueryWrapper<SysCategory> queryWrapper = QueryGenerator.initQueryWrapper(sysCategory, req.getParameterMap());
- List<SysCategory> list = sysCategoryService.list(queryWrapper);
- result.setSuccess(true);
- result.setResult(list);
- return result;
- }
-
-
- /**
- * 添加
- * @param sysCategory
- * @return
- */
- @PostMapping(value = "/add")
- public Result<SysCategory> add(@RequestBody SysCategory sysCategory) {
- Result<SysCategory> result = new Result<SysCategory>();
- try {
- sysCategoryService.addSysCategory(sysCategory);
- result.success("添加成功!");
- } catch (Exception e) {
- log.error(e.getMessage(),e);
- result.error500("操作失败");
- }
- return result;
- }
-
- /**
- * 编辑
- * @param sysCategory
- * @return
- */
- @PostMapping(value = "/edit")
- public Result<SysCategory> edit(@RequestBody SysCategory sysCategory) {
- Result<SysCategory> result = new Result<SysCategory>();
- SysCategory sysCategoryEntity = sysCategoryService.getById(sysCategory.getId());
- if(sysCategoryEntity==null) {
- result.error500("未找到对应实体");
- }else {
- sysCategoryService.updateSysCategory(sysCategory);
- result.success("修改成功!");
- }
- return result;
- }
-
- /**
- * 通过id删除
- * @param id
- * @return
- */
- @PostMapping(value = "/delete")
- public Result<SysCategory> delete(@RequestParam(name="id",required=true) String id) {
- Result<SysCategory> result = new Result<SysCategory>();
- SysCategory sysCategory = sysCategoryService.getById(id);
- if(sysCategory==null) {
- result.error500("未找到对应实体");
- }else {
- this.sysCategoryService.deleteSysCategory(id);
- result.success("删除成功!");
- }
-
- return result;
- }
-
- /**
- * 批量删除
- * @param ids
- * @return
- */
- @PostMapping(value = "/deleteBatch")
- public Result<SysCategory> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
- Result<SysCategory> result = new Result<SysCategory>();
- if(ids==null || "".equals(ids.trim())) {
- result.error500("参数不识别!");
- }else {
- this.sysCategoryService.deleteSysCategory(ids);
- result.success("删除成功!");
- }
- return result;
- }
-
- /**
- * 通过id查询
- * @param id
- * @return
- */
- @GetMapping(value = "/queryById")
- public Result<SysCategory> queryById(@RequestParam(name="id",required=true) String id) {
- Result<SysCategory> result = new Result<SysCategory>();
- SysCategory sysCategory = sysCategoryService.getById(id);
- if(sysCategory==null) {
- result.error500("未找到对应实体");
- }else {
- result.setResult(sysCategory);
- result.setSuccess(true);
- }
- return result;
- }
- /**
- * 导出excel
- *
- * @param request
- */
- @RequestMapping(value = "/exportXls")
- public ModelAndView exportXls(HttpServletRequest request, SysCategory sysCategory) {
- // Step.1 组装查询条件查询数据
- QueryWrapper<SysCategory> queryWrapper = QueryGenerator.initQueryWrapper(sysCategory, request.getParameterMap());
- List<SysCategory> pageList = sysCategoryService.list(queryWrapper);
- // Step.2 AutoPoi 导出Excel
- ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());
- // 过滤选中数据
- String selections = request.getParameter("selections");
- if(oConvertUtils.isEmpty(selections)) {
- mv.addObject(NormalExcelConstants.DATA_LIST, pageList);
- }else {
- List<String> selectionList = Arrays.asList(selections.split(","));
- List<SysCategory> exportList = pageList.stream().filter(item -> selectionList.contains(item.getId())).collect(Collectors.toList());
- mv.addObject(NormalExcelConstants.DATA_LIST, exportList);
- }
- //导出文件名称
- mv.addObject(NormalExcelConstants.FILE_NAME, "分类字典列表");
- mv.addObject(NormalExcelConstants.CLASS, SysCategory.class);
- LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal();
- mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("分类字典列表数据", "导出人:"+user.getRealname(), "导出信息"));
- return mv;
- }
- /**
- * 通过excel导入数据
- *
- * @param request
- * @param response
- * @return
- */
- @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
- public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
- MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
- Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();
- for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {
- MultipartFile file = entity.getValue();// 获取上传文件对象
- ImportParams params = new ImportParams();
- params.setTitleRows(2);
- params.setHeadRows(1);
- params.setNeedSave(true);
- try {
- List<SysCategory> listSysCategorys = ExcelImportUtil.importExcel(file.getInputStream(), SysCategory.class, params);
- //按照编码长度排序
- Collections.sort(listSysCategorys);
- log.info("排序后的list====>",listSysCategorys);
- for (SysCategory sysCategoryExcel : listSysCategorys) {
- String code = sysCategoryExcel.getCode();
- if(code.length()>3){
- String pCode = sysCategoryExcel.getCode().substring(0,code.length()-3);
- log.info("pCode====>",pCode);
- String pId=sysCategoryService.queryIdByCode(pCode);
- log.info("pId====>",pId);
- if(StringUtils.isNotBlank(pId)){
- sysCategoryExcel.setPid(pId);
- }
- }else{
- sysCategoryExcel.setPid("0");
- }
- sysCategoryService.save(sysCategoryExcel);
- }
- return Result.ok("文件导入成功!数据行数:" + listSysCategorys.size());
- } catch (Exception e) {
- log.error(e.getMessage(), e);
- return Result.error("文件导入失败:"+e.getMessage());
- } finally {
- try {
- file.getInputStream().close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
- return Result.error("文件导入失败!");
- }
-
-
-
- /**
- * 加载单个数据 用于回显
- */
- @RequestMapping(value = "/loadOne", method = RequestMethod.GET)
- public Result<SysCategory> loadOne(@RequestParam(name="field") String field,@RequestParam(name="val") String val) {
- Result<SysCategory> result = new Result<SysCategory>();
- try {
-
- QueryWrapper<SysCategory> query = new QueryWrapper<SysCategory>();
- query.eq(field, val);
- List<SysCategory> ls = this.sysCategoryService.list(query);
- if(ls==null || ls.size()==0) {
- result.setMessage("查询无果");
- result.setSuccess(false);
- }else if(ls.size()>1) {
- result.setMessage("查询数据异常,["+field+"]存在多个值:"+val);
- result.setSuccess(false);
- }else {
- result.setSuccess(true);
- result.setResult(ls.get(0));
- }
- } catch (Exception e) {
- e.printStackTrace();
- result.setMessage(e.getMessage());
- result.setSuccess(false);
- }
- return result;
- }
-
- /**
- * 加载节点的子数据
- */
- @RequestMapping(value = "/loadTreeChildren", method = RequestMethod.GET)
- public Result<List<TreeSelectModel>> loadTreeChildren(@RequestParam(name="pid") String pid) {
- Result<List<TreeSelectModel>> result = new Result<List<TreeSelectModel>>();
- try {
- List<TreeSelectModel> ls = this.sysCategoryService.queryListByPid(pid);
- result.setResult(ls);
- result.setSuccess(true);
- } catch (Exception e) {
- e.printStackTrace();
- result.setMessage(e.getMessage());
- result.setSuccess(false);
- }
- return result;
- }
-
- /**
- * 加载一级节点/如果是同步 则所有数据
- */
- @RequestMapping(value = "/loadTreeRoot", method = RequestMethod.GET)
- public Result<List<TreeSelectModel>> loadTreeRoot(@RequestParam(name="async") Boolean async,@RequestParam(name="pcode") String pcode) {
- Result<List<TreeSelectModel>> result = new Result<List<TreeSelectModel>>();
- try {
- List<TreeSelectModel> ls = this.sysCategoryService.queryListByCode(pcode);
- if(!async) {
- loadAllCategoryChildren(ls);
- }
- result.setResult(ls);
- result.setSuccess(true);
- } catch (Exception e) {
- e.printStackTrace();
- result.setMessage(e.getMessage());
- result.setSuccess(false);
- }
- return result;
- }
-
- /**
- * 递归求子节点 同步加载用到
- */
- private void loadAllCategoryChildren(List<TreeSelectModel> ls) {
- for (TreeSelectModel tsm : ls) {
- List<TreeSelectModel> temp = this.sysCategoryService.queryListByPid(tsm.getKey());
- if(temp!=null && temp.size()>0) {
- tsm.setChildren(temp);
- loadAllCategoryChildren(temp);
- }
- }
- }
- /**
- * 校验编码
- * @param pid
- * @param code
- * @return
- */
- @GetMapping(value = "/checkCode")
- public Result<?> checkCode(@RequestParam(name="pid",required = false) String pid,@RequestParam(name="code",required = false) String code) {
- if(oConvertUtils.isEmpty(code)){
- return Result.error("错误,类型编码为空!");
- }
- if(oConvertUtils.isEmpty(pid)){
- return Result.ok();
- }
- SysCategory parent = this.sysCategoryService.getById(pid);
- if(code.startsWith(parent.getCode())){
- return Result.ok();
- }else{
- return Result.error("编码不符合规范,须以\""+parent.getCode()+"\"开头!");
- }
- }
- /**
- * 分类字典树控件 加载节点
- * @param pid
- * @param pcode
- * @param condition
- * @return
- */
- @RequestMapping(value = "/loadTreeData", method = RequestMethod.GET)
- 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) {
- Result<List<TreeSelectModel>> result = new Result<List<TreeSelectModel>>();
- //pid如果传值了 就忽略pcode的作用
- if(oConvertUtils.isEmpty(pid)){
- if(oConvertUtils.isEmpty(pcode)){
- result.setSuccess(false);
- result.setMessage("加载分类字典树参数有误.[null]!");
- return result;
- }else{
- if(ISysCategoryService.ROOT_PID_VALUE.equals(pcode)){
- pid = ISysCategoryService.ROOT_PID_VALUE;
- }else{
- pid = this.sysCategoryService.queryIdByCode(pcode);
- }
- if(oConvertUtils.isEmpty(pid)){
- result.setSuccess(false);
- result.setMessage("加载分类字典树参数有误.[code]!");
- return result;
- }
- }
- }
- Map<String, String> query = null;
- if(oConvertUtils.isNotEmpty(condition)) {
- query = JSON.parseObject(condition, Map.class);
- }
- List<TreeSelectModel> ls = sysCategoryService.queryListByPid(pid,query);
- result.setSuccess(true);
- result.setResult(ls);
- return result;
- }
- /**
- * 分类字典控件数据回显[表单页面]
- *
- * @param ids
- * @param delNotExist 是否移除不存在的项,默认为true,设为false如果某个key不存在数据库中,则直接返回key本身
- * @return
- */
- @RequestMapping(value = "/loadDictItem", method = RequestMethod.GET)
- public Result<List<String>> loadDictItem(@RequestParam(name = "ids") String ids, @RequestParam(name = "delNotExist", required = false, defaultValue = "true") boolean delNotExist) {
- Result<List<String>> result = new Result<>();
- // 非空判断
- if (StringUtils.isBlank(ids)) {
- result.setSuccess(false);
- result.setMessage("ids 不能为空");
- return result;
- }
- // 查询数据
- List<String> textList = sysCategoryService.loadDictItem(ids, delNotExist);
- result.setSuccess(true);
- result.setResult(textList);
- return result;
- }
- /**
- * [列表页面]加载分类字典数据 用于值的替换
- * @param code
- * @return
- */
- @RequestMapping(value = "/loadAllData", method = RequestMethod.GET)
- public Result<List<DictModel>> loadAllData(@RequestParam(name="code",required = true) String code) {
- Result<List<DictModel>> result = new Result<List<DictModel>>();
- LambdaQueryWrapper<SysCategory> query = new LambdaQueryWrapper<SysCategory>();
- if(oConvertUtils.isNotEmpty(code) && !"0".equals(code)){
- query.likeRight(SysCategory::getCode,code);
- }
- List<SysCategory> list = this.sysCategoryService.list(query);
- if(list==null || list.size()==0) {
- result.setMessage("无数据,参数有误.[code]");
- result.setSuccess(false);
- return result;
- }
- List<DictModel> rdList = new ArrayList<DictModel>();
- for (SysCategory c : list) {
- rdList.add(new DictModel(c.getId(),c.getName()));
- }
- result.setSuccess(true);
- result.setResult(rdList);
- return result;
- }
- /**
- * 根据父级id批量查询子节点
- * @param parentIds
- * @return
- */
- @GetMapping("/getChildListBatch")
- public Result getChildListBatch(@RequestParam("parentIds") String parentIds) {
- try {
- QueryWrapper<SysCategory> queryWrapper = new QueryWrapper<>();
- List<String> parentIdList = Arrays.asList(parentIds.split(","));
- queryWrapper.in("pid", parentIdList);
- List<SysCategory> list = sysCategoryService.list(queryWrapper);
- IPage<SysCategory> pageList = new Page<>(1, 10, list.size());
- pageList.setRecords(list);
- return Result.OK(pageList);
- } catch (Exception e) {
- log.error(e.getMessage(), e);
- return Result.error("批量查询子节点失败:" + e.getMessage());
- }
- }
- }
|