From 3ec7de773bff5582411c6f1f659d35cf8fb1734a Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 16 七月 2024 15:13:51 +0800
Subject: [PATCH] Merge branch 'feature/v1.4.1'

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java |   87 +++++++++++++++++++++++++++++++++++++++----
 1 files changed, 78 insertions(+), 9 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
index 56ae254..33d8ebc 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlUniLogic.java
@@ -43,6 +43,7 @@
 import com.hdl.photovoltaic.internet.api.TopicApi;
 import com.hdl.photovoltaic.listener.CloudCallBeak;
 import com.hdl.photovoltaic.listener.LinkCallBack;
+import com.hdl.photovoltaic.ui.bean.BUserInfo;
 import com.hdl.photovoltaic.ui.bean.CUserInfo;
 import com.hdl.photovoltaic.ui.bean.CloudInverterDeviceBean;
 import com.hdl.photovoltaic.ui.bean.DeviceTimeBean;
@@ -181,6 +182,13 @@
 
                         if (callback != null) {
                             uniSuccessCallback(type, null, callback);
+                        }
+                    }
+                    break;
+                    //璐﹀彿涓嬫槸鍚︽湁鐢电珯鍒楄〃
+                    case HDLUniMP.UNI_EVENT_REPLY_HOME_LIST: {
+                        if (callback != null) {
+                            uniSuccessCallback(type, HdlResidenceLogic.getInstance().getHouseIdList().size(), callback);
                         }
                     }
                     break;
@@ -525,6 +533,12 @@
 
                     }
                     break;
+                    //涓嬭浇鎴愬憳锛堝瓙璐﹀彿锛夊ご鍍�
+                    case HDLUniMP.UNI_EVENT_REPLY_DOWNLOAD_MEMBER_AVATAR: {
+                        uniGetHeadPIortrait(type, data, callback);
+
+                    }
+                    break;
                     //鎴愬憳鍒楄〃
                     case HDLUniMP.UNI_EVENT_REPLY_MEMBER_LIST: {
                         uniGetMemberList(type, data, callback);
@@ -579,7 +593,7 @@
                     }
                     break;
                     //鑾峰彇褰撳墠璐﹀彿鍦ㄥ叕鍙哥殑韬唤
-                    case HDLUniMP.UNI_EVENT_REPLY_USERRIGHTTYPe: {
+                    case HDLUniMP.UNI_EVENT_REPLY_USERRIGHTTYP: {
                         uniGetUserRightType(type, data, callback);
 
                     }
@@ -996,6 +1010,32 @@
         HdlMemberLogic.getInstance().getMemberAdd(memberBean, new CloudCallBeak<Boolean>() {
             @Override
             public void onSuccess(Boolean obj) {
+                uniSuccessCallback(type, obj, callback);
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                uniExceptionCallback(type, e, callback);
+            }
+        });
+    }
+
+    /**
+     * 涓嬭浇鎴愬憳锛堝瓙璐﹀彿锛夊ご鍍�
+     */
+    private void uniGetHeadPIortrait(String type, Object data, DCUniMPJSCallback callback) {
+        MemberBean memberBean = new MemberBean();
+        String memberInfo = getKeyValue("memberInfo", getKeyValue("data", data));
+        if (!TextUtils.isEmpty(memberInfo)) {
+            try {
+                memberBean = new Gson().fromJson(memberInfo, MemberBean.class);
+            } catch (Exception ignored) {
+            }
+        }
+
+        HdlMemberLogic.getInstance().getHeadPIortrait(memberBean, new CloudCallBeak<byte[]>() {
+            @Override
+            public void onSuccess(byte[] obj) {
                 uniSuccessCallback(type, obj, callback);
             }
 
@@ -1990,6 +2030,22 @@
 
                                         @Override
                                         public void onFailure(HDLException e) {
+                                            //娣诲姞閫嗗彉鍣ㄥけ璐ュ悗鍒濆鍖栭�嗗彉鍣�
+                                            HdlLogLogic.print("娣诲姞閫嗗彉鍣ㄥけ璐ュ悗寮�濮嬪垵濮嬪寲閫嗗彉鍣�-->", true);
+                                            for (int i = 0; i < list.size(); i++) {
+                                                GatewayBean gatewayBean = list.get(i);
+                                                HdlDeviceLogic.getInstance().initializeInverter(gatewayBean.getDevice_mac(), new LinkCallBack<Boolean>() {
+                                                    @Override
+                                                    public void onSuccess(Boolean obj) {
+                                                        HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄦ垚鍔�-->mac:" + gatewayBean.getDevice_mac(), true);
+                                                    }
+
+                                                    @Override
+                                                    public void onError(HDLLinkException e) {
+                                                        HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄥけ璐�-->mac:" + gatewayBean.getDevice_mac(), true);
+                                                    }
+                                                });
+                                            }
                                             uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
                                         }
                                     });
@@ -2042,7 +2098,25 @@
 
             @Override
             public void onFailure(HDLException e) {
-                uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                if (e.getCode() == 121005) {
+                    //璁惧涓嶅瓨鍦紙121005锛夌姸鎬佺爜
+                    //鍒濆鍖栭�嗗彉鍣ㄨ澶�
+                    HdlDeviceLogic.getInstance().initializeInverter(mac, new LinkCallBack<Boolean>() {
+                        @Override
+                        public void onSuccess(Boolean obj) {
+                            //绉婚櫎鏈湴缂撳瓨
+                            HdlDeviceLogic.getInstance().removeLocalCacheMemoryGatewayToDeviceId(homeId, deviceId);
+                            uniSuccessCallback(type, null, callback);
+                        }
+
+                        @Override
+                        public void onError(HDLLinkException e) {
+                            uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                        }
+                    });
+                } else {
+                    uniCallbackData(type, null, e.getCode(), e.getMsg(), callback);
+                }
             }
         });
     }
@@ -2082,19 +2156,14 @@
         HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(homeId, new CloudCallBeak<List<GatewayBean>>() {
             @Override
             public void onSuccess(List<GatewayBean> list) {
-                if (list == null || list.size() == 0) {
-                    if (callback != null) {
-                        uniSuccessCallback(type, list, callback);
-                    }
-                    return;
-                }
                 if (callback != null) {
                     uniSuccessCallback(type, list, callback);
                 }
                 //EventBus浜嬩欢鍒嗗彂,杩涘叆浣忓畢寮�濮嬭闃呬富棰�
                 BaseEventBus baseEventBus = new BaseEventBus();
+                baseEventBus.setTopic(HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST);
                 baseEventBus.setType(HDLUniMP.UNI_EVENT_REPLY_DEVICE_LIST);
-                baseEventBus.setData(list);
+                baseEventBus.setData(homeId);
                 EventBus.getDefault().post(baseEventBus);
                 //杩涙潵浣忓畢璇︽儏閮借涓婁紶涓�娆id鍒楄〃鍒颁簯绔�;
                 HdlDeviceLogic.getInstance().uploadOidDataToCloud(homeId, list, false, null);

--
Gitblit v1.8.0