From 792a61970f657c9053cfc193080342a8a400c161 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 22 六月 2020 11:04:46 +0800
Subject: [PATCH] 搜索栏优化

---
 src/main/java/com/zy/asrs/controller/MatCodeController.java |    2 ++
 src/main/webapp/views/matCode/matCode.html                  |    2 +-
 src/main/java/com/zy/common/web/BaseController.java         |   51 +++++++++++++++++++++++++++++++++++++++++++++++++--
 3 files changed, 52 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/MatCodeController.java b/src/main/java/com/zy/asrs/controller/MatCodeController.java
index f8f1bdf..f7e8bd8 100644
--- a/src/main/java/com/zy/asrs/controller/MatCodeController.java
+++ b/src/main/java/com/zy/asrs/controller/MatCodeController.java
@@ -50,10 +50,12 @@
                   @RequestParam(defaultValue = "10")Integer limit,
                   @RequestParam(required = false)String orderByField,
                   @RequestParam(required = false)String orderByType,
+                  @RequestParam(required = false)String condition,
                   @RequestParam Map<String, Object> param){
         excludeTrash(param);
         EntityWrapper<MatCode> wrapper = new EntityWrapper<>();
         convert(param, wrapper);
+        allLike(MatCode.class, param.keySet(), wrapper, condition);
         if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));}
         else {
             wrapper.orderBy("modi_time", false);
diff --git a/src/main/java/com/zy/common/web/BaseController.java b/src/main/java/com/zy/common/web/BaseController.java
index 69b2b34..af55b2b 100644
--- a/src/main/java/com/zy/common/web/BaseController.java
+++ b/src/main/java/com/zy/common/web/BaseController.java
@@ -1,16 +1,22 @@
 package com.zy.common.web;
 
-import com.zy.system.entity.User;
-import com.zy.system.service.UserService;
+import com.baomidou.mybatisplus.annotations.TableField;
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.BaseRes;
 import com.core.common.Cools;
 import com.core.controller.AbstractBaseController;
 import com.core.exception.CoolException;
+import com.zy.system.entity.User;
+import com.zy.system.service.UserService;
 import io.swagger.annotations.ApiModelProperty;
 import org.springframework.beans.factory.annotation.Autowired;
 
 import javax.servlet.http.HttpServletRequest;
 import java.lang.reflect.Field;
+import java.lang.reflect.Modifier;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Set;
 
 /**
  * Created by vincent on 2019-09-09
@@ -43,4 +49,45 @@
         }
         return "";
     }
+
+    /**
+     * 鍏ㄥ瓧娈垫ā绯婃悳绱�
+     * @param cls 妯″瀷绫�
+     * @param set 鎺掗櫎瀛楁闆嗗悎
+     * @param condition 鎼滅储鍐呭
+     */
+    protected <T> void allLike(Class<T> cls, Set<String> set, EntityWrapper<T> wrapper, String condition){
+        if (Cools.isEmpty(condition)) {
+            return;
+        }
+        List<String> columns = new ArrayList<>();
+        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 (!set.contains(column)) {
+                columns.add(column);
+            }
+        }
+        if (columns.isEmpty()) {
+            return;
+        }
+        for (int i=0;i<columns.size();i++){
+            if (i==0){
+                wrapper.and();
+            } else {
+                wrapper.or();
+            }
+            wrapper.like(columns.get(i), condition);
+        }
+    }
 }
diff --git a/src/main/webapp/views/matCode/matCode.html b/src/main/webapp/views/matCode/matCode.html
index e79759f..17bb232 100644
--- a/src/main/webapp/views/matCode/matCode.html
+++ b/src/main/webapp/views/matCode/matCode.html
@@ -57,7 +57,7 @@
     </div>
     <div class="layui-inline">
         <div class="layui-input-inline">
-            <input class="layui-input" type="text" name="mat_no" placeholder="璇疯緭鍏�" autocomplete="off">
+            <input class="layui-input" type="text" name="condition" placeholder="璇疯緭鍏�" autocomplete="off">
         </div>
     </div>
     <!-- 寰呮坊鍔� -->

--
Gitblit v1.9.1