zhangherong
2025-05-22 abe2c2fbea21d63678bc21bd77f3102a2b535973
lxzn-module-eam/src/main/java/org/jeecg/modules/eam/controller/EamPrecisionCheckDetailController.java
@@ -1,41 +1,29 @@
package org.jeecg.modules.eam.controller;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.system.query.QueryGenerator;
import org.jeecg.common.aspect.annotation.AutoLog;
import org.jeecg.common.util.oConvertUtils;
import org.jeecg.modules.eam.entity.EamPrecisionCheckDetail;
import org.jeecg.modules.eam.service.IEamPrecisionCheckDetailService;
import java.util.Date;
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.jeecg.common.system.base.controller.JeecgController;
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 com.alibaba.fastjson.JSON;
import cn.hutool.core.collection.CollectionUtil;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.parser.Feature;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.system.base.controller.JeecgController;
import org.jeecg.common.util.TranslateDictTextUtils;
import org.jeecg.modules.eam.entity.EamEquipmentPrecisionParameters;
import org.jeecg.modules.eam.entity.EamPrecisionCheckDetail;
import org.jeecg.modules.eam.service.IEamPrecisionCheckDetailService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
 /**
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
 * @Description: 设备精度检测明细
 * @Author: jeecg-boot
 * @Date:   2025-05-13
@@ -44,124 +32,40 @@
@Slf4j
@Api(tags="设备精度检测明细")
@RestController
@RequestMapping("/eam/eamPrecisionCheckDetail")
@RequestMapping("/eam/precisionCheckDetail")
public class EamPrecisionCheckDetailController extends JeecgController<EamPrecisionCheckDetail, IEamPrecisionCheckDetailService> {
   @Autowired
   private IEamPrecisionCheckDetailService eamPrecisionCheckDetailService;
   /**
    * 分页列表查询
    *
    * @param eamPrecisionCheckDetail
    * @param pageNo
    * @param pageSize
    * @param req
    * @return
    */
   @AutoLog(value = "设备精度检测明细-分页列表查询")
   @ApiOperation(value="设备精度检测明细-分页列表查询", notes="设备精度检测明细-分页列表查询")
   @GetMapping(value = "/list")
   public Result<?> queryPageList(EamPrecisionCheckDetail eamPrecisionCheckDetail,
                           @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
                           @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
                           HttpServletRequest req) {
      QueryWrapper<EamPrecisionCheckDetail> queryWrapper = QueryGenerator.initQueryWrapper(eamPrecisionCheckDetail, req.getParameterMap());
      Page<EamPrecisionCheckDetail> page = new Page<EamPrecisionCheckDetail>(pageNo, pageSize);
      IPage<EamPrecisionCheckDetail> pageList = eamPrecisionCheckDetailService.page(page, queryWrapper);
      return Result.OK(pageList);
   }
   /**
    * 添加
    *
    * @param eamPrecisionCheckDetail
    * @return
    */
   @AutoLog(value = "设备精度检测明细-添加")
   @ApiOperation(value="设备精度检测明细-添加", notes="设备精度检测明细-添加")
   @PostMapping(value = "/add")
   public Result<?> add(@RequestBody EamPrecisionCheckDetail eamPrecisionCheckDetail) {
      eamPrecisionCheckDetailService.save(eamPrecisionCheckDetail);
      return Result.OK("添加成功!");
   }
   /**
    * 编辑
    *
    * @param eamPrecisionCheckDetail
    * @return
    */
   @AutoLog(value = "设备精度检测明细-编辑")
   @ApiOperation(value="设备精度检测明细-编辑", notes="设备精度检测明细-编辑")
   @RequestMapping(value = "/edit", method = {RequestMethod.PUT,RequestMethod.POST})
   public Result<?> edit(@RequestBody EamPrecisionCheckDetail eamPrecisionCheckDetail) {
      eamPrecisionCheckDetailService.updateById(eamPrecisionCheckDetail);
      return Result.OK("编辑成功!");
   }
   /**
    * 通过id删除
    *
    * @param id
    * @return
    */
   @AutoLog(value = "设备精度检测明细-通过id删除")
   @ApiOperation(value="设备精度检测明细-通过id删除", notes="设备精度检测明细-通过id删除")
   @DeleteMapping(value = "/delete")
   public Result<?> delete(@RequestParam(name="id",required=true) String id) {
      eamPrecisionCheckDetailService.removeById(id);
      return Result.OK("删除成功!");
   }
   /**
    * 批量删除
    *
    * @param ids
    * @return
    */
   @AutoLog(value = "设备精度检测明细-批量删除")
   @ApiOperation(value="设备精度检测明细-批量删除", notes="设备精度检测明细-批量删除")
   @DeleteMapping(value = "/deleteBatch")
   public Result<?> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
      this.eamPrecisionCheckDetailService.removeByIds(Arrays.asList(ids.split(",")));
      return Result.OK("批量删除成功!");
   }
   /**
    * 通过id查询
    *
    * @param id
    * @return
    */
   @AutoLog(value = "设备精度检测明细-通过id查询")
   @ApiOperation(value="设备精度检测明细-通过id查询", notes="设备精度检测明细-通过id查询")
   @GetMapping(value = "/queryById")
   public Result<?> queryById(@RequestParam(name="id",required=true) String id) {
      EamPrecisionCheckDetail eamPrecisionCheckDetail = eamPrecisionCheckDetailService.getById(id);
      return Result.OK(eamPrecisionCheckDetail);
   }
   @Autowired
   private ObjectMapper objectMapper;
   @Autowired
   private TranslateDictTextUtils translateDictTextUtils;
  /**
   * 导出excel
   *
   * @param request
   * @param eamPrecisionCheckDetail
   */
  @RequestMapping(value = "/exportXls")
  public ModelAndView exportXls(HttpServletRequest request, EamPrecisionCheckDetail eamPrecisionCheckDetail) {
      return super.exportXls(request, eamPrecisionCheckDetail, EamPrecisionCheckDetail.class, "设备精度检测明细");
  }
  /**
   * 通过excel导入数据
   *
   * @param request
   * @param response
   * @return
   */
  @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
  public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
      return super.importExcel(request, response, EamPrecisionCheckDetail.class);
  }
   /**
    * 列表查询
    *
    * @param orderId 工单ID
    * @return
    */
   @ApiOperation(value="设备精度参数-列表查询", notes="设备精度参数-列表查询")
   @GetMapping(value = "/queryList")
   public Result<?> queryList(@RequestParam(name="orderId") String orderId) {
      List<EamPrecisionCheckDetail> list = eamPrecisionCheckDetailService.getByOrderId(orderId);
      if(CollectionUtil.isEmpty(list)) {
         return Result.OK(Collections.emptyList());
      }
      List<JSONObject> items = new ArrayList<>();
      try {
         for(EamPrecisionCheckDetail vo : list) {
            String json = objectMapper.writeValueAsString(vo);
            JSONObject item = JSONObject.parseObject(json, Feature.OrderedField);
            translateDictTextUtils.translateField("parameterId", vo.getParameterId(), item, "eam_precision_parameters,parameter_name,id");
            translateDictTextUtils.translateField("parameterCode", vo.getParameterId(), item, "eam_precision_parameters,parameter_code,id");
            items.add(item);
         }
         return Result.OK(items);
      }catch (Exception e) {
         return Result.error("数据转译失败!");
      }
   }
}