From c8aee7b9bfd79cfd741d7e5692520f4f51a31a86 Mon Sep 17 00:00:00 2001
From: kimi <kimi42345@gmail.com>
Date: 星期一, 18 五月 2020 18:30:01 +0800
Subject: [PATCH] bak  修改 获取版本数据前

---
 src/main/java/com/highdatas/mdm/controller/MaintainFieldController.java |  106 +++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 103 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/highdatas/mdm/controller/MaintainFieldController.java b/src/main/java/com/highdatas/mdm/controller/MaintainFieldController.java
index 151b11f..f2c023b 100644
--- a/src/main/java/com/highdatas/mdm/controller/MaintainFieldController.java
+++ b/src/main/java/com/highdatas/mdm/controller/MaintainFieldController.java
@@ -1,10 +1,29 @@
 package com.highdatas.mdm.controller;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.highdatas.mdm.entity.Maintain;
+import com.highdatas.mdm.entity.MaintainField;
+import com.highdatas.mdm.entity.MenuMapping;
+import com.highdatas.mdm.mapper.TableInfoMapper;
+import com.highdatas.mdm.pojo.CodeMsg;
+import com.highdatas.mdm.pojo.Result;
+import com.highdatas.mdm.service.IMaintainFieldService;
+import com.highdatas.mdm.service.IMaintainService;
+import com.highdatas.mdm.service.IMenuMappingService;
+import com.highdatas.mdm.service.ISysFieldService;
+import com.highdatas.mdm.util.Constant;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
 
-import org.springframework.stereotype.Controller;
-import org.springframework.web.bind.annotation.RestController;
+import java.text.MessageFormat;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Set;
 
 /**
  * <p>
@@ -17,5 +36,86 @@
 @RestController
 @RequestMapping("/maintainField")
 public class MaintainFieldController {
+    @Autowired
+    IMaintainService maintainService;
+    @Autowired
+    IMaintainFieldService maintainFieldService;
+    @Autowired
+    ISysFieldService fieldService;
+    @Autowired
+    TableInfoMapper tableInfoMapper;
+    @Autowired
+    IMenuMappingService menuMappingService;
+
+    @RequestMapping(value = "/getMaintainListByMenu/{menuId}", method = RequestMethod.GET)
+    public Result getMaintainListByTable(@PathVariable String menuId)  {
+        MenuMapping menuMapping = menuMappingService.selectOne(new EntityWrapper<MenuMapping>().eq("menu_id", menuId).orderBy("create_time"));
+        if (menuMapping == null){
+            return Result.error(CodeMsg.ERROR_PARAMS_NOT_MATHED);
+        }
+        String tableName = menuMapping.getTableName();
+
+        JSONArray array = maintainFieldService.getMaintainListByTable(tableName);
+        return Result.success(array);
+    }
+
+    @RequestMapping(value = "/getMaintainListByMaintainField/{id}", method = RequestMethod.GET)
+    public Result getMaintainListByMaintainField(@PathVariable String id, @RequestParam String tableName)  {
+        List<Maintain> maintainList = maintainFieldService.getMaintainListByMaintainField(id, tableName);
+        return Result.success(maintainList);
+    }
+
+    @RequestMapping(value = "/getMaintainListByTable/{tableName}", method = RequestMethod.GET)
+    public Result deleteModel(@PathVariable String tableName)  {
+        List<MaintainField> maintainFieldList = maintainFieldService.selectList(new EntityWrapper<MaintainField>().eq("table_name", tableName).orderBy("order_no"));
+        int preOrderNo = -1;
+        HashMap<String, List<Maintain>> resultMap = new HashMap<>();
+        if (maintainFieldList.size() == 0) {
+            List<Maintain> maintainList = maintainService.selectList(new EntityWrapper<Maintain>().orderBy("order_no"));
+            resultMap.put(Constant.Default, maintainList);
+            return Result.success(resultMap);
+        }
+        for (MaintainField maintainField : maintainFieldList) {
+            String maintainId = maintainField.getMaintainId();
+            if (StringUtils.isEmpty(maintainId)) {
+                continue;
+            }
+            Maintain maintain = maintainService.selectById(maintainId);
+            if (maintain == null) {
+                continue;
+            }
+            Integer orderNo = maintain.getOrderNo();
+            List<Maintain> maintainList = maintainService.selectList(new EntityWrapper<Maintain>().ge("order_no", preOrderNo).le("order_no", orderNo));
+            resultMap.put(maintainField.getId(), maintainList);
+            preOrderNo = orderNo;
+        }
+        Set<String> keySet = resultMap.keySet();
+        JSONArray array = new JSONArray();
+        for (String s : keySet) {
+            List<Maintain> maintainList = resultMap.get(s);
+            Maintain max = maintainList.stream().max(new Comparator<Maintain>() {
+                @Override
+                public int compare(Maintain o1, Maintain o2) {
+                    return o1.getOrderNo() - o2.getOrderNo();
+                }
+            }).get();
+            Maintain min = maintainList.stream().min(new Comparator<Maintain>() {
+                @Override
+                public int compare(Maintain o1, Maintain o2) {
+                    return o1.getOrderNo() - o2.getOrderNo();
+                }
+            }).get();
+            JSONObject object = new JSONObject();
+            object.fluentPut("maintainFieldId", s);
+            object.fluentPut("version", MessageFormat.format(Constant.extent, min.getVersion(), max.getVersion()));
+
+            array.add(object);
+        }
+        return Result.success(array);
+    }
+
+
+
+
 
 }

--
Gitblit v1.8.0