All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.mingsoft.mdiy.action.DictAction Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (c) 2012-present 铭软科技(mingsoft.net)
 * 本软件及相关文档文件(以下简称“软件”)的版权归 铭软科技 所有
 * 遵循 铭软科技《服务协议》中的《保密条款》
 */




package net.mingsoft.mdiy.action;

import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import net.mingsoft.base.entity.ResultData;
import net.mingsoft.basic.annotation.LogAnn;
import net.mingsoft.basic.bean.EUListBean;
import net.mingsoft.basic.constant.e.BusinessTypeEnum;
import net.mingsoft.basic.util.BasicUtil;
import net.mingsoft.basic.util.StringUtil;
import net.mingsoft.mdiy.biz.IDictBiz;
import net.mingsoft.mdiy.entity.DictEntity;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.*;
import springfox.documentation.annotations.ApiIgnore;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

/**
 * 字典表管理控制层
 *
 * @author 铭飞开发团队
 * @version 版本号:1
* 创建日期:2017-8-12 14:22:36
* 历史修订:2022-1-25 新增 importJson() 方法 */ @Api(tags={"后端-自定义模块接口"}) @Controller @RequestMapping("/${ms.manager.path}/mdiy/dict") public class DictAction extends BaseAction { /** * 注入字典表业务层 */ @Autowired private IDictBiz dictBiz; /** * 返回主界面index */ @ApiIgnore @GetMapping("/index") public String index(HttpServletResponse response, HttpServletRequest request) { return "/mdiy/dict/index"; } /** * 返回编辑界面dict_form */ @ApiIgnore @GetMapping("/form") public String form(@ModelAttribute DictEntity dict, HttpServletResponse response, HttpServletRequest request, @ApiIgnore ModelMap model) { return "/mdiy/dict/form"; } @ApiOperation(value = "导入自定义字典") @LogAnn(title = "导入自定义字典", businessType = BusinessTypeEnum.INSERT) @PostMapping("/importJson") @ResponseBody @RequiresPermissions("mdiy:dict:importJson") public ResultData importJson(@RequestBody List dictEntities, HttpServletResponse response, HttpServletRequest request, BindingResult result) { //验证list的值是否合法 if (CollUtil.isEmpty(dictEntities)) { return ResultData.build().error("json格式不匹配"); } List list = dictBiz.list(); List dictEntityList = dictEntities.stream() .filter(dictEntity -> !list.contains(dictEntity)) .map(dictEntity -> { dictEntity.setId(null); return dictEntity; }).collect(Collectors.toList()); if(CollUtil.isNotEmpty(dictEntityList)){ dictBiz.saveBatch(dictEntityList, dictEntityList.size()); } return ResultData.build().success(); } /** * 查询字典表列表 * * @param dict 字典表实体 * dict参数包含字段信息参考:
* dictValue 数据值
* dictLabel 标签名
* dictType 类型
* dictDescription 描述
* dictSort 排序(升序)
* createBy 创建者
* createDate 创建时间
* updateBy 更新者
* updateDate 更新时间
* dictRemarks 备注信息
* del 删除标记
*
返回

*
[
* {
* dictValue: 数据值
* dictLabel: 标签名
* dictType: 类型
* dictDescription: 描述
* dictSort: 排序(升序)
* createBy: 创建者
* createDate: 创建时间
* updateBy: 更新者
* updateDate: 更新时间
* dictRemarks: 备注信息
* del: 删除标记
* }
* ]

*/ @ApiOperation(value = "查询字典表列表接口") @ApiImplicitParams({ @ApiImplicitParam(name = "dictType", value = "类型", required = false, paramType = "query"), @ApiImplicitParam(name = "dictLabel", value = "标签名", required = false, paramType = "query"), @ApiImplicitParam(name = "dictValue", value = "数据值", required = false, paramType = "query"), @ApiImplicitParam(name = "isChild", value = "子业务关联", required = false, paramType = "query"), }) @RequestMapping(value = "/list", method = {RequestMethod.GET, RequestMethod.POST}) @ResponseBody public ResultData list(@ModelAttribute @ApiIgnore DictEntity dict, HttpServletResponse response, HttpServletRequest request, @ApiIgnore ModelMap model) { BasicUtil.startPage(); //新增dictEnable字典状态字段,子业务默认只查询启用状态的字典数据 //自定义字典管理页面查询全部 //为了减少代码管理页面传入dictEnable参数来判断是否查询全部 if (dict.getDictEnable() == null) { dict.setDictEnable(true); } else { dict.setDictEnable(null); } List dictList = dictBiz.query(dict); return ResultData.build().success(new EUListBean(dictList, (int) BasicUtil.endPage(dictList).getTotal())); } @ApiOperation(value = "根据子业务类型获取所有字典类型") @ApiImplicitParams({ @ApiImplicitParam(name = "isChild", value = "子业务关联", required = false, paramType = "query"), }) @GetMapping("/dictType") @ResponseBody public ResultData dictType(@ModelAttribute @ApiIgnore DictEntity dict, HttpServletResponse response, HttpServletRequest request, @ApiIgnore ModelMap model) { BasicUtil.startPage(); QueryWrapper dictEntityQueryWrapper = new QueryWrapper<>(); //使用min(),获取每个分类最小时间,按分类最早创建时间排序 // sql适配, 规范group by的使用 dictEntityQueryWrapper.select("dict_type,min(CREATE_DATE) as min_create_time"); dictEntityQueryWrapper.groupBy("dict_type"); dictEntityQueryWrapper.orderByDesc("min_create_time"); List dictList = dictBiz.list(dictEntityQueryWrapper); return ResultData.build().success(new EUListBean(dictList, (int) BasicUtil.endPage(dictList).getTotal())); } @ApiOperation(value = "根据字典类型获取字典,可支持多个类型用英文逗号隔开") @ApiImplicitParams({ @ApiImplicitParam(name = "dictType", value = "字典类型", required = true, paramType = "query"), @ApiImplicitParam(name = "isChild", value = "子业务关联", required = false, paramType = "query"), }) @GetMapping("/dictList") @ResponseBody public ResultData dictList(@ModelAttribute @ApiIgnore DictEntity dict, HttpServletResponse response, HttpServletRequest request, @ApiIgnore ModelMap model) { if (StringUtils.isEmpty(dict.getDictType())) { return ResultData.build().error(getResString("err.error", this.getResString("dict.type"))); } String[] types = dict.getDictType().split(","); DictEntity _dict = new DictEntity(); _dict.setIsChild(dict.getIsChild()); List list = new ArrayList(); for (String type : types) { _dict.setDictType(type); list.add(dictBiz.query(_dict)); } return ResultData.build().success(list); } /** * 获取字典表 * * @param dict 字典表实体 * dict参数包含字段信息参考:
* dictValue 数据值
* dictLabel 标签名
* dictType 类型
* dictDescription 描述
* dictSort 排序(升序)
* createBy 创建者
* createDate 创建时间
* updateBy 更新者
* updateDate 更新时间
* dictRemarks 备注信息
* del 删除标记
*
返回

*
{
* dictValue: 数据值
* dictLabel: 标签名
* dictType: 类型
* dictDescription: 描述
* dictSort: 排序(升序)
* createBy: 创建者
* createDate: 创建时间
* updateBy: 更新者
* updateDate: 更新时间
* dictRemarks: 备注信息
* del: 删除标记
* }

*/ @ApiOperation(value = "获取字典详情接口") @ApiImplicitParam(name = "id", value = "字典编号", required = true, paramType = "query") @GetMapping("/get") @ResponseBody public ResultData get(@ModelAttribute @ApiIgnore DictEntity dict, HttpServletResponse response, HttpServletRequest request, @ApiIgnore ModelMap model) { if (StringUtils.isBlank(dict.getId())) { return ResultData.build().error(getResString("err.error", this.getResString("dict.id"))); } DictEntity _dict = dictBiz.getById(dict.getId()); return ResultData.build().success(_dict); } /** * 保存字典表实体 * * @param dict 字典表实体 * dict参数包含字段信息参考:
* dictValue 数据值
* dictLabel 标签名
* dictType 类型
* dictDescription 描述
* dictSort 排序(升序)
* createBy 创建者
* createDate 创建时间
* updateBy 更新者
* updateDate 更新时间
* dictRemarks 备注信息
* del 删除标记
*
返回

*
{
* dictValue: 数据值
* dictLabel: 标签名
* dictType: 类型
* dictDescription: 描述
* dictSort: 排序(升序)
* createBy: 创建者
* createDate: 创建时间
* updateBy: 更新者
* updateDate: 更新时间
* dictRemarks: 备注信息
* del: 删除标记
* }

*/ @ApiOperation(value = "保存字典接口") @ApiImplicitParams({ @ApiImplicitParam(name = "dictLabel", value = "标签名", required = true, paramType = "query"), @ApiImplicitParam(name = "dictType", value = "类型", required = true, paramType = "query"), @ApiImplicitParam(name = "dictValue", value = "数据值", required = false, paramType = "query"), @ApiImplicitParam(name = "dictDescription", value = "描述", required = false, paramType = "query"), @ApiImplicitParam(name = "dictSort", value = "排序(升序)", required = false, paramType = "query"), @ApiImplicitParam(name = "isChild", value = "子业务关联", required = false, paramType = "query"), @ApiImplicitParam(name = "dictRemarks", value = "备注信息", required = false, paramType = "query") }) @LogAnn(title = "保存字典接口", businessType = BusinessTypeEnum.INSERT) @PostMapping("/save") @ResponseBody @RequiresPermissions("mdiy:dict:save") public ResultData save(@ModelAttribute @ApiIgnore DictEntity dict, HttpServletResponse response, HttpServletRequest request) { // type和lable不能为重复 if (dictBiz.getByTypeAndLabelAndValue(dict.getDictType(), dict.getDictLabel(), null) != null) { return ResultData.build().error(getResString("diy.dict.type.and.label.repeat")); } // type和value不能为重复 if (dictBiz.getByTypeAndLabelAndValue(dict.getDictType(), null, dict.getDictValue()) != null) { return ResultData.build().error(getResString("diy.dict.type.and.value.repeat")); } dictBiz.saveEntity(dict); if (StringUtil.isBlank(dict.getDictValue())) { dict.setDictValue(dict.getId()); dictBiz.updateEntity(dict); } return ResultData.build().success(); } /** * @param dicts 字典表实体 * dict参数包含字段信息参考:
* id:id,id=1,2,3,4 * 批量删除字典表 *
返回

*
{code:"错误编码",
* result:"true|false",
* resultMsg:"错误信息"
* }
*/ @ApiOperation(value = "批量删除字典") @LogAnn(title = "批量删除字典", businessType = BusinessTypeEnum.DELETE) @PostMapping("/delete") @ResponseBody @RequiresPermissions("mdiy:dict:del") public ResultData delete(@RequestBody List dicts, HttpServletResponse response, HttpServletRequest request) { int[] ids = new int[dicts.size()]; for (int i = 0; i < dicts.size(); i++) { ids[i] = Integer.parseInt(dicts.get(i).getId()); } dictBiz.delete(ids); return ResultData.build().success(); } /** * 更新字典表信息字典表 * * @param dict 字典表实体 * dict参数包含字段信息参考:
* dictValue 数据值
* dictLabel 标签名
* dictType 类型
* dictDescription 描述
* dictSort 排序(升序)
* createBy 创建者
* createDate 创建时间
* updateBy 更新者
* updateDate 更新时间
* dictRemarks 备注信息
* del 删除标记
*
返回

*
{
* dictValue: 数据值
* dictLabel: 标签名
* dictType: 类型
* dictDescription: 描述
* dictSort: 排序(升序)
* createBy: 创建者
* createDate: 创建时间
* updateBy: 更新者
* updateDate: 更新时间
* dictRemarks: 备注信息
* del: 删除标记
* }

*/ @ApiOperation(value = "更新字典信息接口") @ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "字典编号", required = true, paramType = "query"), @ApiImplicitParam(name = "dictLabel", value = "标签名", required = true, paramType = "query"), @ApiImplicitParam(name = "dictType", value = "类型", required = true, paramType = "query"), @ApiImplicitParam(name = "dictValue", value = "数据值", required = false, paramType = "query"), @ApiImplicitParam(name = "dictDescription", value = "描述", required = false, paramType = "query"), @ApiImplicitParam(name = "dictSort", value = "排序(升序)", required = false, paramType = "query"), @ApiImplicitParam(name = "isChild", value = "子业务关联", required = false, paramType = "query"), @ApiImplicitParam(name = "dictRemarks", value = "备注信息", required = false, paramType = "query") }) @LogAnn(title = "更新字典信息接口", businessType = BusinessTypeEnum.UPDATE) @PostMapping("/update") @ResponseBody @RequiresPermissions("mdiy:dict:update") public ResultData update(@ModelAttribute @ApiIgnore DictEntity dict, HttpServletResponse response, HttpServletRequest request) { DictEntity _dict = dictBiz.getByTypeAndLabelAndValue(dict.getDictType(), dict.getDictLabel(), null); // type和lable不能为重复 if (_dict != null) { if (!_dict.getId().equals(dict.getId())) { return ResultData.build().error(getResString("diy.dict.type.and.label.repeat")); } } // type和value不能为重复 DictEntity _dict2 = dictBiz.getByTypeAndLabelAndValue(dict.getDictType(), null, dict.getDictValue()); if (_dict2 != null) { if (!_dict2.getId().equals(dict.getId())) { return ResultData.build().error(getResString("diy.dict.type.and.value.repeat")); } } if (StringUtils.isBlank(dict.getDictValue())) { dict.setDictValue(null); } dictBiz.updateEntity(dict); return ResultData.build().success(); } @ApiOperation(value = "刷新字典缓存接口") @PostMapping("/updateCache") @RequiresPermissions("mdiy:dict:update") @ResponseBody public ResultData updateCache(HttpServletResponse response, HttpServletRequest request, @ApiIgnore ModelMap model) { dictBiz.updateCache(); return ResultData.build().success(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy