From d210be88a9bccdc1c98d466c5dacbf14d7528711 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期五, 09 十二月 2022 14:52:45 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/common/web/BaseController.java |   67 +++++++++++++++++++++++++++++++--
 1 files changed, 63 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/zy/common/web/BaseController.java b/src/main/java/com/zy/common/web/BaseController.java
index c206865..a61e965 100644
--- a/src/main/java/com/zy/common/web/BaseController.java
+++ b/src/main/java/com/zy/common/web/BaseController.java
@@ -1,5 +1,6 @@
 package com.zy.common.web;
 
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.annotations.TableField;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.baomidou.mybatisplus.plugins.Page;
@@ -7,6 +8,8 @@
 import com.core.common.Cools;
 import com.core.controller.AbstractBaseController;
 import com.core.exception.CoolException;
+import com.zy.asrs.entity.Tag;
+import com.zy.asrs.service.TagService;
 import com.zy.system.entity.User;
 import com.zy.system.service.UserService;
 import io.swagger.annotations.ApiModelProperty;
@@ -22,10 +25,14 @@
  */
 public class BaseController extends AbstractBaseController {
 
+    protected static final String RANGE_TIME_LINK = " - ";
+
     @Autowired
     protected HttpServletRequest request;
     @Autowired
     private UserService userService;
+    @Autowired
+    private TagService tagService;
 
     protected Long getUserId(){
         return Long.parseLong(String.valueOf(request.getAttribute("userId")));
@@ -49,13 +56,50 @@
         return "";
     }
 
-    protected <T> Page<T> toPage(Integer pageNumber, Integer pageSize, Map<String, Object> param){
+    protected Tag getOriginTag(){
+        return tagService.getTop();
+    }
+
+    /**
+     * 鍒嗛〉缁勮
+     * @param pageNumber
+     * @param pageSize
+     * @param map
+     * @param cls
+     * @param <T>
+     * @return
+     */
+    protected <T> Page<T> toPage(Integer pageNumber, Integer pageSize, Map<String, Object> map, Class<T> cls){
+        // 鍒嗛〉绱㈠紩鍜屽崟椤垫暟閲忕粍瑁�
         pageNumber = Optional.ofNullable(pageNumber).orElse(1);
         pageSize = Optional.ofNullable(pageSize).orElse(10);
         Page<T> page = new Page<>(pageNumber, pageSize);
-        param.put("pageNumber", pageNumber);
-        param.put("pageSize", pageSize);
-        page.setCondition(param);
+        map.put("pageNumber", pageNumber);
+        map.put("pageSize", pageSize);
+
+        // 鍏ㄥ瓧娈垫ā绯婃悳绱� todo
+        if (!Cools.isEmpty(map.get("condition"))) {
+            Set<String> columns = new HashSet<>();
+            for (Field field : Cools.getAllFields(cls)){
+                if (Modifier.isFinal(field.getModifiers())
+                        || Modifier.isStatic(field.getModifiers())
+                        || Modifier.isTransient(field.getModifiers())){
+                    continue;
+                }
+                String column = null;
+                if (field.isAnnotationPresent(TableField.class)) {
+                    column = field.getAnnotation(TableField.class).value();
+                }
+                if (Cools.isEmpty(column)) {
+                    column = field.getName();
+                }
+                if (!map.keySet().contains(column)) {
+                    columns.add(column);
+                }
+            }
+            columns.forEach(col->map.put(col, map.get("condition")));
+        }
+        page.setCondition(map);
         return page;
     }
 
@@ -99,4 +143,19 @@
             wrapper.like(columns.get(i), condition);
         }
     }
+
+    public static boolean isJSON(String str) {
+        if (Cools.isEmpty(str)) {
+            return false;
+        } else {
+            str = str.trim();
+            if (str.startsWith("{") && str.endsWith("}")) {
+                return true;
+            } else if (str.startsWith("[") && str.endsWith("]")) {
+                return true;
+            } else {
+                return false;
+            }
+        }
+    }
 }

--
Gitblit v1.9.1