|
@@ -1,35 +1,38 @@
|
|
|
package com.ruoyi.project.pssr.controller;
|
|
|
|
|
|
-import java.math.BigDecimal;
|
|
|
-import java.util.*;
|
|
|
-
|
|
|
+import com.ruoyi.common.utils.DateUtils;
|
|
|
+import com.ruoyi.common.utils.poi.ExcelUtil;
|
|
|
+import com.ruoyi.framework.aspectj.lang.annotation.Log;
|
|
|
+import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
|
|
|
+import com.ruoyi.framework.web.controller.BaseController;
|
|
|
+import com.ruoyi.framework.web.domain.AjaxResult;
|
|
|
+import com.ruoyi.framework.web.page.TableDataInfo;
|
|
|
+import com.ruoyi.project.pssr.domain.TPssrAirtight;
|
|
|
import com.ruoyi.project.pssr.domain.TPssrApprove;
|
|
|
-import com.ruoyi.project.pssr.domain.TPssrCleaning;
|
|
|
import com.ruoyi.project.pssr.domain.TPssrSubcontent;
|
|
|
+import com.ruoyi.project.pssr.service.ITPssrAirtightService;
|
|
|
import com.ruoyi.project.pssr.service.ITPssrApproveService;
|
|
|
import com.ruoyi.project.pssr.service.ITPssrSubcontentService;
|
|
|
import org.activiti.engine.ProcessEngine;
|
|
|
import org.activiti.engine.ProcessEngines;
|
|
|
import org.activiti.engine.TaskService;
|
|
|
import org.activiti.engine.task.Task;
|
|
|
-import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
+import org.apache.poi.ss.usermodel.Cell;
|
|
|
+import org.apache.poi.ss.usermodel.CellStyle;
|
|
|
+import org.apache.poi.ss.usermodel.Row;
|
|
|
+import org.apache.poi.ss.usermodel.Sheet;
|
|
|
+import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
|
|
+import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
-import org.springframework.web.bind.annotation.GetMapping;
|
|
|
-import org.springframework.web.bind.annotation.PostMapping;
|
|
|
-import org.springframework.web.bind.annotation.PutMapping;
|
|
|
-import org.springframework.web.bind.annotation.DeleteMapping;
|
|
|
-import org.springframework.web.bind.annotation.PathVariable;
|
|
|
-import org.springframework.web.bind.annotation.RequestBody;
|
|
|
-import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
-import org.springframework.web.bind.annotation.RestController;
|
|
|
-import com.ruoyi.framework.aspectj.lang.annotation.Log;
|
|
|
-import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
|
|
|
-import com.ruoyi.project.pssr.domain.TPssrAirtight;
|
|
|
-import com.ruoyi.project.pssr.service.ITPssrAirtightService;
|
|
|
-import com.ruoyi.framework.web.controller.BaseController;
|
|
|
-import com.ruoyi.framework.web.domain.AjaxResult;
|
|
|
-import com.ruoyi.common.utils.poi.ExcelUtil;
|
|
|
-import com.ruoyi.framework.web.page.TableDataInfo;
|
|
|
+import org.springframework.security.access.prepost.PreAuthorize;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import java.io.FileOutputStream;
|
|
|
+import java.io.IOException;
|
|
|
+import java.io.InputStream;
|
|
|
+import java.io.OutputStream;
|
|
|
+import java.math.BigDecimal;
|
|
|
+import java.util.*;
|
|
|
|
|
|
/**
|
|
|
* 气密Controller
|
|
@@ -39,8 +42,7 @@ import com.ruoyi.framework.web.page.TableDataInfo;
|
|
|
*/
|
|
|
@RestController
|
|
|
@RequestMapping("/pssr/airtight")
|
|
|
-public class TPssrAirtightController extends BaseController
|
|
|
-{
|
|
|
+public class TPssrAirtightController extends BaseController {
|
|
|
@Autowired
|
|
|
private ITPssrAirtightService tPssrAirtightService;
|
|
|
|
|
@@ -55,8 +57,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
*/
|
|
|
@PreAuthorize("@ss.hasPermi('pssr:airtight:list')")
|
|
|
@GetMapping("/list")
|
|
|
- public TableDataInfo list(TPssrAirtight tPssrAirtight)
|
|
|
- {
|
|
|
+ public TableDataInfo list(TPssrAirtight tPssrAirtight) {
|
|
|
startPage();
|
|
|
List<TPssrAirtight> list = tPssrAirtightService.selectTPssrAirtightList(tPssrAirtight);
|
|
|
return getDataTable(list);
|
|
@@ -68,11 +69,9 @@ public class TPssrAirtightController extends BaseController
|
|
|
@PreAuthorize("@ss.hasPermi('pssr:airtight:export')")
|
|
|
@Log(title = "气密", businessType = BusinessType.EXPORT)
|
|
|
@GetMapping("/export")
|
|
|
- public AjaxResult export(TPssrAirtight tPssrAirtight)
|
|
|
- {
|
|
|
+ public AjaxResult export(TPssrAirtight tPssrAirtight) {
|
|
|
List<TPssrAirtight> list = tPssrAirtightService.selectTPssrAirtightList(tPssrAirtight);
|
|
|
- ExcelUtil<TPssrAirtight> util = new ExcelUtil<TPssrAirtight>(TPssrAirtight.class);
|
|
|
- return util.exportExcel(list, "airtight");
|
|
|
+ return AjaxResult.success(exportTmpl(list));
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -80,8 +79,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
*/
|
|
|
@PreAuthorize("@ss.hasPermi('pssr:airtight:query')")
|
|
|
@GetMapping(value = "/{id}")
|
|
|
- public AjaxResult getInfo(@PathVariable("id") Long id)
|
|
|
- {
|
|
|
+ public AjaxResult getInfo(@PathVariable("id") Long id) {
|
|
|
return AjaxResult.success(tPssrAirtightService.selectTPssrAirtightById(id));
|
|
|
}
|
|
|
|
|
@@ -91,8 +89,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
@PreAuthorize("@ss.hasPermi('pssr:airtight:add')")
|
|
|
@Log(title = "气密", businessType = BusinessType.INSERT)
|
|
|
@PostMapping
|
|
|
- public AjaxResult add(@RequestBody TPssrAirtight tPssrAirtight)
|
|
|
- {
|
|
|
+ public AjaxResult add(@RequestBody TPssrAirtight tPssrAirtight) {
|
|
|
tPssrAirtight.setApproveStatus(0L);
|
|
|
try {
|
|
|
String initialPressure = tPssrAirtight.getInitialPressure();//初始压力
|
|
@@ -100,9 +97,9 @@ public class TPssrAirtightController extends BaseController
|
|
|
//泄漏率=(初始压力-最终压力)/初始压力*100%
|
|
|
BigDecimal leakageRate = new BigDecimal(initialPressure).subtract(new BigDecimal(finalPressure)).divide(new BigDecimal(initialPressure), 2, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal(100));
|
|
|
tPssrAirtight.setLeakageRate(String.valueOf(leakageRate.doubleValue()));//设置泄漏率
|
|
|
- if(leakageRate.compareTo(new BigDecimal(tPssrAirtight.getStandard()))<=0){//判断是否满足标准
|
|
|
+ if (leakageRate.compareTo(new BigDecimal(tPssrAirtight.getStandard())) <= 0) {//判断是否满足标准
|
|
|
tPssrAirtight.setUptoStandard("是");
|
|
|
- }else {
|
|
|
+ } else {
|
|
|
tPssrAirtight.setUptoStandard("否");
|
|
|
}
|
|
|
} catch (Exception e) {
|
|
@@ -117,8 +114,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
@PreAuthorize("@ss.hasPermi('pssr:airtight:edit')")
|
|
|
@Log(title = "气密", businessType = BusinessType.UPDATE)
|
|
|
@PutMapping
|
|
|
- public AjaxResult edit(@RequestBody TPssrAirtight tPssrAirtight)
|
|
|
- {
|
|
|
+ public AjaxResult edit(@RequestBody TPssrAirtight tPssrAirtight) {
|
|
|
|
|
|
try {
|
|
|
String initialPressure = tPssrAirtight.getInitialPressure();//初始压力
|
|
@@ -126,9 +122,9 @@ public class TPssrAirtightController extends BaseController
|
|
|
//泄漏率=(初始压力-最终压力)/初始压力*100%
|
|
|
BigDecimal leakageRate = new BigDecimal(initialPressure).subtract(new BigDecimal(finalPressure)).divide(new BigDecimal(initialPressure), 2, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal(100));
|
|
|
tPssrAirtight.setLeakageRate(String.valueOf(leakageRate.doubleValue()));//设置泄漏率
|
|
|
- if(leakageRate.compareTo(new BigDecimal(tPssrAirtight.getStandard()))<=0){//判断是否满足标准
|
|
|
+ if (leakageRate.compareTo(new BigDecimal(tPssrAirtight.getStandard())) <= 0) {//判断是否满足标准
|
|
|
tPssrAirtight.setUptoStandard("是");
|
|
|
- }else {
|
|
|
+ } else {
|
|
|
tPssrAirtight.setUptoStandard("否");
|
|
|
}
|
|
|
} catch (Exception e) {
|
|
@@ -142,9 +138,8 @@ public class TPssrAirtightController extends BaseController
|
|
|
*/
|
|
|
@PreAuthorize("@ss.hasPermi('pssr:airtight:remove')")
|
|
|
@Log(title = "气密", businessType = BusinessType.DELETE)
|
|
|
- @DeleteMapping("/{ids}")
|
|
|
- public AjaxResult remove(@PathVariable Long[] ids)
|
|
|
- {
|
|
|
+ @DeleteMapping("/{ids}")
|
|
|
+ public AjaxResult remove(@PathVariable Long[] ids) {
|
|
|
return toAjax(tPssrAirtightService.deleteTPssrAirtightByIds(ids));
|
|
|
}
|
|
|
|
|
@@ -174,7 +169,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
for (Long id : tPssrAirtight.getIds()) {
|
|
|
TPssrAirtight item = tPssrAirtightService.selectTPssrAirtightById(id);
|
|
|
item.setApproveStatus(approveStatus);
|
|
|
- if (item.getConfirmationDate()==null && queryStatus==3) {
|
|
|
+ if (item.getConfirmationDate() == null && queryStatus == 3) {
|
|
|
item.setConfirmationDate(date);
|
|
|
}
|
|
|
tPssrAirtightService.updateTPssrAirtight(item);
|
|
@@ -184,7 +179,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
lock.setSubId(tPssrAirtight.getSubId());
|
|
|
lock.setApproveStatus(queryStatus);
|
|
|
for (TPssrAirtight item : tPssrAirtightService.selectTPssrAirtightList(lock)) {
|
|
|
- if (item.getConfirmationDate()==null && queryStatus==3) {
|
|
|
+ if (item.getConfirmationDate() == null && queryStatus == 3) {
|
|
|
item.setConfirmationDate(date);
|
|
|
}
|
|
|
item.setApproveStatus(approveStatus);
|
|
@@ -208,7 +203,7 @@ public class TPssrAirtightController extends BaseController
|
|
|
}
|
|
|
|
|
|
//无待审批任务结束当前用户流程
|
|
|
-
|
|
|
+
|
|
|
// 因为流程关系所以approve一定会有且只有一条数据
|
|
|
TPssrApprove tPssrApprove = tPssrApproveService.selectTPssrApproveBySubId(tPssrAirtight.getSubId());
|
|
|
TPssrApproveController.handleConfirmApprove(tPssrApprove, getUserId().toString());
|
|
@@ -285,4 +280,67 @@ public class TPssrAirtightController extends BaseController
|
|
|
}
|
|
|
return AjaxResult.error();
|
|
|
}
|
|
|
+
|
|
|
+ public String exportTmpl(List<TPssrAirtight> list) {
|
|
|
+ OutputStream out = null;
|
|
|
+ String filename =null;
|
|
|
+ try {
|
|
|
+ String tempUrl = "static/word/pssr/qm.xlsx"; // 模板文件
|
|
|
+ InputStream is = null;
|
|
|
+ is = Thread.currentThread().getContextClassLoader().getResourceAsStream(tempUrl);
|
|
|
+ XSSFWorkbook wb1 = null;
|
|
|
+ wb1 = new XSSFWorkbook(is);
|
|
|
+ SXSSFWorkbook wb = new SXSSFWorkbook(wb1, 1000);
|
|
|
+
|
|
|
+ Sheet sheet;
|
|
|
+ if (wb instanceof SXSSFWorkbook) {
|
|
|
+ SXSSFWorkbook sxssfWorkbook = (SXSSFWorkbook) wb;
|
|
|
+ sheet = sxssfWorkbook.getXSSFWorkbook().getSheetAt(0);
|
|
|
+ } else {
|
|
|
+ sheet = wb.getSheetAt(0);
|
|
|
+ }
|
|
|
+
|
|
|
+ //填充数据
|
|
|
+ int rowIndex = 3;
|
|
|
+ int num = 1;
|
|
|
+
|
|
|
+ Row originalRow = sheet.getRow(3);
|
|
|
+ Cell originalcell = originalRow.getCell(0);
|
|
|
+ // 获取单元格样式
|
|
|
+ CellStyle originalStyle = originalcell.getCellStyle();
|
|
|
+
|
|
|
+ for (TPssrAirtight t : list ) {
|
|
|
+ Row row = sheet.createRow(rowIndex);
|
|
|
+ row.createCell(0).setCellValue(num);
|
|
|
+ row.createCell(1).setCellValue(t.getUnit());
|
|
|
+ row.createCell(2).setCellValue(t.getSystemName());
|
|
|
+ row.createCell(3).setCellValue(t.getAirtightMedium());
|
|
|
+ row.createCell(4).setCellValue(t.getAirtightPressure());
|
|
|
+ row.createCell(5).setCellValue(t.getInitialPressure());
|
|
|
+ row.createCell(6).setCellValue(t.getFinalPressure());
|
|
|
+ row.createCell(7).setCellValue(t.getStandard());
|
|
|
+ row.createCell(8).setCellValue(t.getUptoStandard());
|
|
|
+ row.createCell(9).setCellValue(t.getConfirm1Name());
|
|
|
+ row.createCell(10).setCellValue(t.getConfirm2Name());
|
|
|
+ row.createCell(11).setCellValue(DateUtils.dateTime(t.getConfirmationDate()));
|
|
|
+ row.createCell(12).setCellValue(t.getRemarks());
|
|
|
+
|
|
|
+
|
|
|
+ //渲染样式
|
|
|
+ for (int i = 0; i < 13; i++) {
|
|
|
+ row.getCell(i).setCellStyle(originalStyle);
|
|
|
+ }
|
|
|
+ num++;
|
|
|
+ rowIndex++;
|
|
|
+ }
|
|
|
+ filename = ExcelUtil.encodingFilename("Airtight");
|
|
|
+ out = new FileOutputStream(ExcelUtil.getAbsoluteFile(filename));
|
|
|
+ wb.write(out);
|
|
|
+ wb.close();
|
|
|
+
|
|
|
+ } catch (IOException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ return filename;
|
|
|
+ }
|
|
|
}
|