From fdcfe6ef562cc3e8bbd6fcf2faedfbd9571f4490 Mon Sep 17 00:00:00 2001
From: hxb <hxb@hdlchina.com.cn>
Date: 星期一, 01 四月 2024 14:33:42 +0800
Subject: [PATCH] 解决小程序白屏的问题

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java |  137 +++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 129 insertions(+), 8 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java
index f0f7534..ef25a07 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java
@@ -45,6 +45,9 @@
     }
 
     public void clearListMessage() {
+        if (mListMessage == null) {
+            return;
+        }
         if (mListMessage.size() > 0) {
             mListMessage.clear();
         }
@@ -69,6 +72,21 @@
 
         }
         return sortList(newList);
+    }
+
+    /**
+     * 娑堟伅鍏ㄩ儴宸茶(鏈湴缂撳瓨)
+     *
+     * @param isRead 鏄惁璇诲彇(true宸茶鍙�)
+     */
+    public void setAllRead(boolean isRead) {
+        for (int i = 0; i < mListMessage.size(); i++) {
+            MessageBean messageBean = mListMessage.get(i);
+            if (messageBean == null) {
+                continue;
+            }
+            messageBean.setRead(isRead);
+        }
     }
 
 
@@ -112,6 +130,18 @@
 
         }
         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
+            unReadList.sort(new Comparator<MessageBean>() {
+                @Override
+                public int compare(MessageBean o1, MessageBean o2) {
+                    if (o1 == null && o2 == null) {
+                        return -1;
+                    }
+                    //鍊掑簭锛堥『搴� Long.compare(o2.getCreateTime(), o1.getCreateTime())锛�
+                    return Long.compare(o2.getCreateTime(), o1.getCreateTime());
+                }
+            });
+        }
+        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
             readList.sort(new Comparator<MessageBean>() {
                 @Override
                 public int compare(MessageBean o1, MessageBean o2) {
@@ -119,11 +149,10 @@
                         return -1;
                     }
                     //鍊掑簭锛堥『搴� Long.compare(o2.getCreateTime(), o1.getCreateTime())锛�
-                    return Long.compare(o1.getCreateTime(), o2.getCreateTime());
+                    return Long.compare(o2.getCreateTime(), o1.getCreateTime());
                 }
             });
         }
-
         if (unReadList.size() > 0) {
             newList.addAll(unReadList);
         }
@@ -134,7 +163,7 @@
     }
 
     public List<MessageBean> getAllMessageList() {
-        return mListMessage;
+        return sortList(mListMessage);
     }
 
 
@@ -198,9 +227,9 @@
     }
 
     /**
-     * 娣诲姞娑堟伅鍒板垪琛ㄩ噷闈�
+     * 娣诲姞娑堟伅鍒板垪琛ㄩ噷闈�(鍗曚釜鎻掑叆)
      *
-     * @param messageBean -
+     * @param messageBean 鍗曚釜
      * @param position    琛ㄧず鍔犲埌鍒楄〃鐨勪綅缃�
      */
     public void setListMessage(MessageBean messageBean, int position) {
@@ -231,7 +260,7 @@
     /**
      * 娣诲姞娑堟伅鍒板垪琛ㄩ噷闈�
      *
-     * @param list -
+     * @param list 鍒楄〃
      */
     public void setListMessage(List<MessageBean> list) {
         try {
@@ -279,9 +308,12 @@
      *
      * @param cloudCallBeak -
      */
-    public void getMessageUntreatedCount(CloudCallBeak<String> cloudCallBeak) {
+    public void getMessageUntreatedCount(String homeId, CloudCallBeak<String> cloudCallBeak) {
         String requestUrl = HttpApi.POST_Message_UntreatedCount;
         JsonObject json = new JsonObject();
+        if (!TextUtils.isEmpty(homeId)) {
+            json.addProperty("homeId", homeId);
+        }
         HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
             public void onSuccess(String str) {
@@ -413,7 +445,7 @@
     }
 
     /**
-     * 鑾峰彇鎸囧畾椤电殑鑾峰彇娑堟伅鍒楄〃
+     * 鑾峰彇鎸囧畾椤电殑鑾峰彇娑堟伅鍒楄〃(鐢ㄤ簬B绔�)
      *
      * @param pageNo           椤电爜
      * @param messageStateType all:鍏ㄩ儴,UNTREATED:鏈鐞�,PROCESSED:宸插鐞�;
@@ -457,6 +489,66 @@
 
     }
 
+    /**
+     * 鑾峰彇鎸囧畾椤电殑鑾峰彇娑堟伅鍒楄〃(鐢ㄤ簬C绔�)
+     *
+     * @param homeId                  鐢电珯id
+     * @param pageNo                  椤电爜
+     * @param messageStateType        all:鍏ㄩ儴,UNTREATED:鏈鐞�,PROCESSED:宸插鐞�;
+     * @param deviceType_filter_key   绫诲瀷锛堣澶囷紝绛夌骇锛屾椂闂达級
+     * @param deviceType_filter_value deviceType锛圛NV 锛氶�嗗彉鍣紱BMS 锛欱MS鎺у埗鐩掞紱BATTERY 锛氱數姹犲崟鍏冿級锛�
+     *                                type锛團AULT 锛氭晠闅滐紱 WARN 锛氬憡璀︼紱 EVENT 锛氫簨浠�(鎻愮ず)锛夛紱
+     *                                timeType锛圱ODAY 锛氫粖澶╋紱LAST_3_DAYS: 杩�3澶╋紱LAST_7_DAYS 锛氳繎7澶╋紱LAST_30_DAYS 锛氳繎30澶╋級锛�
+     * @param cloudCallBeak           -
+     */
+    public void getPageNoMessageList_C(String homeId, int pageNo, String messageStateType, String deviceType_filter_key, String deviceType_filter_value, String type_filter_key, String type_filter_value, String timeType_filter_key, String timeType_filter_value, CloudCallBeak<MessageListClass> cloudCallBeak) {
+        String requestUrl = HttpApi.POST_Message_List;
+        JsonObject json = new JsonObject();
+        if (!TextUtils.isEmpty(homeId)) {
+            json.addProperty("homeId", homeId);
+        }
+        if (!MessageStateType.all.equals(messageStateType)) {
+            json.addProperty("status", messageStateType);
+        }
+        if (!TextUtils.isEmpty(deviceType_filter_key) && !TextUtils.isEmpty(deviceType_filter_value)) {
+            json.addProperty(deviceType_filter_key, deviceType_filter_value);
+        }
+        if (!TextUtils.isEmpty(type_filter_key) && !TextUtils.isEmpty(type_filter_value)) {
+            json.addProperty(type_filter_key, type_filter_value);
+        }
+        if (!TextUtils.isEmpty(timeType_filter_key) && !TextUtils.isEmpty(timeType_filter_value)) {
+            json.addProperty(timeType_filter_key, timeType_filter_value);
+        }
+        json.addProperty("pageNo", pageNo);//椤电爜
+        json.addProperty("pageSize", pageSize);//椤垫暟
+
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
+            @Override
+            public void onSuccess(String jsonStr) {
+                if (TextUtils.isEmpty(jsonStr)) {
+                    if (cloudCallBeak != null) {
+                        cloudCallBeak.onSuccess(new MessageListClass());
+                    }
+                    return;
+                }
+                Gson gson = new Gson();
+                MessageListClass oldMessageListClass = gson.fromJson(jsonStr, MessageListClass.class);
+                setListMessage(oldMessageListClass.getList());
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onSuccess(oldMessageListClass);
+                }
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onFailure(e);
+                }
+            }
+        });
+
+
+    }
 
     /**
      * 鑾峰彇娑堟伅璇︽儏
@@ -523,6 +615,35 @@
 
     }
 
+    /**
+     * 娑堟伅鍏ㄩ儴宸茶
+     *
+     * @param homeId        娑堟伅id
+     * @param cloudCallBeak -
+     */
+    public void messageAllRead(String homeId, CloudCallBeak<Boolean> cloudCallBeak) {
+        String requestUrl = HttpApi.POST_Message_AllRead;
+        JsonObject json = new JsonObject();
+        json.addProperty("homeId", homeId);
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
+            @Override
+            public void onSuccess(String str) {
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onSuccess(true);
+                }
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onFailure(e);
+                }
+            }
+        });
+
+
+    }
+
 
     public static class MessageListClass {
 

--
Gitblit v1.8.0