| package com.zy.acs.manager.common.domain; | 
|   | 
| import com.baomidou.mybatisplus.annotation.TableField; | 
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
| import com.baomidou.mybatisplus.core.metadata.OrderItem; | 
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
| import com.zy.acs.common.utils.Utils; | 
| import com.zy.acs.framework.common.Cools; | 
| import com.zy.acs.framework.common.DateUtils; | 
|   | 
| import java.lang.reflect.Field; | 
| import java.lang.reflect.Modifier; | 
| import java.util.ArrayList; | 
| import java.util.Date; | 
| import java.util.List; | 
| import java.util.Map; | 
| import java.util.function.Consumer; | 
|   | 
| /** | 
|  * Created by vincent on 2/13/2024 | 
|  */ | 
| public class PageParam<T, U extends BaseParam> extends Page<T> { | 
|   | 
|     private static final long serialVersionUID = 1L; | 
|     public static final String ORDER_DESC_VALUE = "desc"; | 
|   | 
|     private final U where; | 
|   | 
|     /** | 
|      * 是否把字段名称驼峰转下划线 | 
|      */ | 
|     private final boolean isToUnderlineCase; | 
|   | 
|     private final Class<T> cls; | 
|   | 
|     public PageParam() { | 
|         this(null); | 
|     } | 
|   | 
|     public PageParam(U where) { | 
|         this(where, true); | 
|     } | 
|   | 
|     public PageParam(U where, Class<T> cls) { | 
|         this(where, true, cls); | 
|     } | 
|   | 
|     public PageParam(U where, boolean isToUnderlineCase) { | 
|         this(where, isToUnderlineCase, null); | 
|     } | 
|   | 
|     public PageParam(U where, boolean isToUnderlineCase, Class<T> cls) { | 
|         super(); | 
|         this.where = where; | 
|         this.isToUnderlineCase = isToUnderlineCase; | 
|         this.cls = cls; | 
|         if (where != null) { | 
|             if (where.getCurrent() != null) { | 
|                 setCurrent(where.getCurrent()); | 
|             } | 
|             if (where.getPageSize() != null) { | 
|                 setSize(where.getPageSize()); | 
|             } | 
|         } | 
|   | 
|     } | 
|   | 
|     public QueryWrapper<T> buildWrapper(boolean like) { | 
|         return this.buildWrapper(like, null, "create_time"); | 
|     } | 
|   | 
|     public QueryWrapper<T> buildWrapper(boolean like, String timeField) { | 
|         return this.buildWrapper(like, null, timeField); | 
|     } | 
|   | 
|     @SuppressWarnings("all") | 
|     public QueryWrapper<T> buildWrapper(boolean like, Consumer<QueryWrapper<T>> consumer, String timeField) { | 
|         QueryWrapper<T> queryWrapper = new QueryWrapper<>(); | 
|         Map<String, Object> map = where.getMap(); | 
|         for (String key : map.keySet()) { | 
|             Object val = map.get(key); | 
|   | 
|             if (key.contains("Range")) { | 
|                 ArrayList<String> list = null; | 
|                 if (val instanceof ArrayList) { | 
|                     list = (ArrayList<String>) val; | 
|                 } | 
|                 if (null != list) { | 
|                     key = key.replaceAll("Range", ""); | 
|                     if (this.isToUnderlineCase) { | 
|                         key = Utils.toSymbolCase(key, '_'); | 
|                     } | 
|                     queryWrapper.ge(key, DateUtils.convert(list.get(0))); | 
|                     queryWrapper.le(key, DateUtils.convert(list.get(1))); | 
|                 } | 
|             } else { | 
|                 if (this.isToUnderlineCase) { | 
|                     key = Utils.toSymbolCase(key, '_'); | 
|                 } | 
|                 if (like) { | 
|                     queryWrapper.like(key, val); | 
|                 } else { | 
|                     queryWrapper.eq(key, val); | 
|                 } | 
|             } | 
|         } | 
|   | 
|         if (null != consumer) { | 
|             consumer.accept(queryWrapper); | 
|         } | 
|   | 
|         if (!Cools.isEmpty(where.getTimeStart())) { | 
|             Date timeStart = DateUtils.convert(String.valueOf(where.getTimeStart()), DateUtils.yyyyMMdd_F); | 
|             queryWrapper.ge(timeField, timeStart); | 
|   | 
|         } | 
|         if (!Cools.isEmpty(where.getTimeEnd())) { | 
|             Date timeStart = DateUtils.convert(String.valueOf(where.getTimeEnd()), DateUtils.yyyyMMdd_F); | 
|             queryWrapper.le(timeField, timeStart); | 
|         } | 
|   | 
|         if (!Cools.isEmpty(where.getOrderBy())) { | 
|             if (sortIsSQL(where.getOrderBy())) { | 
|                 setOrders(parseOrderSQL(where.getOrderBy())); | 
|             } | 
|         } else { | 
| //            queryWrapper.orderByDesc("create_time"); | 
|         } | 
|   | 
|         if (!Cools.isEmpty(where.getCondition()) && !Cools.isEmpty(cls)) { | 
|             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; | 
|                 } | 
|   | 
|                 if (field.isAnnotationPresent(TableField.class)){ | 
|                     TableField annotation = field.getAnnotation(TableField.class); | 
|                     if (!annotation.exist()) { | 
|                         continue; | 
|                     } | 
|                 } | 
|   | 
|                 String column =  Utils.toSymbolCase(field.getName(), '_'); | 
|                 columns.add(column); | 
|             } | 
|             if (!columns.isEmpty()) { | 
|                 for (int i=0;i<columns.size();i++){ | 
|                     String column = columns.get(i); | 
|                     String condition = where.getCondition(); | 
|   | 
|                     if (i == 0) { | 
|                         queryWrapper.and(wrapper -> wrapper.like(column, condition)); | 
|                     } else { | 
|                         queryWrapper.or().like(column, condition); | 
|                     } | 
|                 } | 
|             } | 
|         } | 
|         return queryWrapper; | 
|     } | 
|   | 
|     private boolean sortIsSQL(String sort) { | 
|         return sort != null && (sort.contains(",") || sort.trim().contains(" ")); | 
|     } | 
|   | 
|     private List<OrderItem> parseOrderSQL(String orderSQL) { | 
|         List<OrderItem> orders = new ArrayList<>(); | 
|         if (!Cools.isEmpty(orderSQL)) { | 
|             for (String item : orderSQL.split(",")) { | 
|                 String[] temp = item.trim().split(" "); | 
|                 if (!temp[0].isEmpty()) { | 
|                     String column = this.isToUnderlineCase ? Utils.toSymbolCase(temp[0], '_') : temp[0]; | 
|                     boolean asc = temp.length == 1 || !temp[temp.length - 1].toLowerCase().equals(ORDER_DESC_VALUE); | 
|                     orders.add(new OrderItem(column, asc)); | 
|                 } | 
|             } | 
|         } | 
|         return orders; | 
|     } | 
|   | 
|     public Map<String, Object> checkoutMap() { | 
|         Map<String, Object> map = where.getMap(); | 
|         if (!Cools.isEmpty(where.getOrderBy())) { | 
|             map.put("orderBy", where.getOrderBy()); | 
|         } | 
|         if (!Cools.isEmpty(where.getTimeStart())) { | 
|             map.put("timeStart", DateUtils.convert(String.valueOf(where.getTimeStart()), DateUtils.yyyyMMdd_F)); | 
|         } | 
|         if (!Cools.isEmpty(where.getTimeEnd())) { | 
|             map.put("timeEnd", DateUtils.convert(String.valueOf(where.getTimeEnd()), DateUtils.yyyyMMdd_F)); | 
|         } | 
|         if (!Cools.isEmpty(where.getCondition())) { | 
|             map.put("condition", where.getCondition()); | 
|         } | 
|         return map; | 
|     } | 
|   | 
| } |