From c11d709a36f61948676c0f28613d3cbd97e8851f Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期四, 21 三月 2024 13:08:45 +0800
Subject: [PATCH] s2024年03月21日13:08:39

---
 app/src/main/res/values-zh/strings.xml                                            |    2 
 app/src/main/res/values/strings.xml                                               |    2 
 app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListEditActivity.java |   72 +++++++++++++----------
 app/src/main/res/values-en/strings.xml                                            |    2 
 app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java             |    2 
 app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java         |    8 ++
 app/src/main/res/drawable/selected.png                                            |    0 
 app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java     |   78 +++++++++++++++-----------
 8 files changed, 98 insertions(+), 68 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
index 5ec3a0c..245cf96 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/MyPowerStationActivity.java
@@ -92,7 +92,7 @@
         this.initMqttClient();
         //涓婁紶鏋佸厜娉ㄥ唽ID鍒颁簯绔�
         this.pushTokens();
-//        //鐐瑰嚮鏋佸厜閫氱煡鏍忔秷鎭繘鏉�
+        //鐐瑰嚮鏋佸厜閫氱煡鏍忔秷鎭繘鏉�
         this.clickJpushNotificationMessage();
         //鍒濆鍖栨潈闄�
         this.requestPermissions();
diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java b/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java
index e0ce829..ee6e3c8 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java
@@ -108,9 +108,13 @@
             houseListAdapter.setMoveOnclickListener(new HouseListAdapter.OnMoveClickListener() {
                 @Override
                 public void onMoveClick(int position, HouseIdBean houseIdBean) {
+                    if (position == 0) {
+                        HdlThreadLogic.toast(_mActivity, getString(R.string.already_the_first_one));
+                        return;
+                    }
                     String frontHomeId = "";
-                    if (position > 0) {
-                        frontHomeId = houseListBeanIDList.get(position - 1).getHomeId();
+                    if (position > 1) {
+                        frontHomeId = houseListBeanIDList.get(position - 2).getHomeId();
                     }
                     HdlResidenceLogic.getInstance().moveResidence(houseIdBean.getHomeId(), frontHomeId, new CloudCallBeak<Boolean>() {
                         @Override
diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListEditActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListEditActivity.java
index 5a97c8e..8188d93 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListEditActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListEditActivity.java
@@ -27,6 +27,7 @@
 import com.hdl.photovoltaic.widget.DelayedConfirmationCancelDialog;
 import com.hdl.sdk.link.common.exception.HDLLinkException;
 import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
+import com.hdl.sdk.link.core.bean.gateway.GatewayBean;
 
 import org.greenrobot.eventbus.EventBus;
 
@@ -100,11 +101,12 @@
                 @Override
                 public void onMoveClick(int position, HouseIdBean houseIdBean) {
                     if (position == 0) {
+                        HdlThreadLogic.toast(_mActivity, getString(R.string.already_the_first_one));
                         return;
                     }
                     String frontHomeId = "";
                     if (position > 1) {
-                        frontHomeId = houseListBeanIDList.get(position - 1).getHomeId();
+                        frontHomeId = houseListBeanIDList.get(position - 2).getHomeId();
                     }
                     HdlResidenceLogic.getInstance().moveResidence(houseIdBean.getHomeId(), frontHomeId, new CloudCallBeak<Boolean>() {
                         @Override
@@ -138,8 +140,20 @@
                     delayedConfirmationCancelDialog.setYesOnclickListener(new DelayedConfirmationCancelDialog.onYesOnclickListener() {
                         @Override
                         public void Confirm() {
-                            delayedConfirmationCancelDialog.dismiss();
-                            delete(houseIdBean.getHomeId());
+
+                            showLoading(getString(R.string.deleting_please_wait));
+                            HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(houseIdBean.getHomeId(), new CloudCallBeak<List<GatewayBean>>() {
+                                @Override
+                                public void onSuccess(List<GatewayBean> list) {
+                                    deleteResidence(houseIdBean.getHomeId(), delayedConfirmationCancelDialog);
+                                    initializeInverter(list);
+                                }
+
+                                @Override
+                                public void onFailure(HDLException e) {
+                                    deleteResidence(houseIdBean.getHomeId(), delayedConfirmationCancelDialog);
+                                }
+                            });
 //                            //鍒犻櫎浣忓畢
 //                            HdlResidenceLogic.getInstance().delResidence(houseIdBean.getHomeId(), new CloudCallBeak<Boolean>() {
 //                                @Override
@@ -185,38 +199,28 @@
 
     /**
      * 鍒犻櫎鐢电珯,閫嗗彉鍣�
-     * (鍏堣幏鍙栦簯绔笂閫嗗彉鍣ㄥ垪琛�,寮�濮嬪垹闄ょ數绔欙紝鍚屾椂锛屽悜閫嗗彉鍣ㄥ彂閫佸垵濮嬪寲閫嗗彉鍣ㄦ寚浠�)
+     * (寮�濮嬪垹闄ょ數绔欙紝鍚屾椂锛屽悜閫嗗彉鍣ㄥ彂閫佸垵濮嬪寲閫嗗彉鍣ㄦ寚浠�,鏃犻』澶勭悊缁撴灉)
      *
-     * @param homeId 鐢电珯id
+     * @param list 璁惧鍒楄〃
      */
-    private void delete(String homeId) {
-        HdlDeviceLogic.getInstance().getCloudInverterDeviceList(homeId, new CloudCallBeak<List<CloudInverterDeviceBean>>() {
-            @Override
-            public void onSuccess(List<CloudInverterDeviceBean> list) {
-                deleteResidence(homeId);
-                if (list != null) {
-                    for (int i = 0; i < list.size(); i++) {
-                        CloudInverterDeviceBean cloudInverterDeviceBean = list.get(i);
-                        HdlDeviceLogic.getInstance().initializeGateway(cloudInverterDeviceBean.getOsn(), new LinkCallBack<Boolean>() {
-                            @Override
-                            public void onSuccess(Boolean obj) {
-
-                            }
-
-                            @Override
-                            public void onError(HDLLinkException e) {
-
-                            }
-                        });
-                    }
+    private void initializeInverter(List<GatewayBean> list) {
+        if (list == null || list.size() == 0) {
+            return;
+        }
+        for (int i = 0; i < list.size(); i++) {
+            GatewayBean gatewayBean = list.get(i);
+            HdlDeviceLogic.getInstance().initializeGateway(gatewayBean.getDevice_mac(), new LinkCallBack<Boolean>() {
+                @Override
+                public void onSuccess(Boolean obj) {
+//                                HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄦ垚鍔�-->mac:" + cloudInverterDeviceBean.getOsn(),true);
                 }
-            }
 
-            @Override
-            public void onFailure(HDLException e) {
-                deleteResidence(homeId);
-            }
-        });
+                @Override
+                public void onError(HDLLinkException e) {
+//                                HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄥけ璐�-->mac:" + cloudInverterDeviceBean.getOsn(),true);
+                }
+            });
+        }
     }
 
     /**
@@ -224,11 +228,13 @@
      *
      * @param homeId 鐢电珯id
      */
-    private void deleteResidence(String homeId) {
+    private void deleteResidence(String homeId, DelayedConfirmationCancelDialog delayedConfirmationCancelDialog) {
         //鍒犻櫎浣忓畢
         HdlResidenceLogic.getInstance().delResidence(homeId, new CloudCallBeak<Boolean>() {
             @Override
             public void onSuccess(Boolean obj) {
+                hideLoading();
+                delayedConfirmationCancelDialog.dismiss();
                 HdlResidenceLogic.getInstance().delHouseId(homeId);
                 initData();//鍒濆鍖栫紦瀛樻暟鎹�
                 houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃
@@ -237,6 +243,8 @@
 
             @Override
             public void onFailure(HDLException e) {
+                hideLoading();
+                delayedConfirmationCancelDialog.dismiss();
                 HdlThreadLogic.toast(_mActivity, e);
             }
         });
diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java b/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java
index 8387e0b..dea8cc6 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java
@@ -38,6 +38,7 @@
 import com.hdl.photovoltaic.widget.DelayedConfirmationCancelDialog;
 import com.hdl.sdk.link.common.exception.HDLLinkException;
 import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
+import com.hdl.sdk.link.core.bean.gateway.GatewayBean;
 import com.hdl.sdk.link.core.utils.mqtt.MqttRecvClient;
 
 import java.util.ArrayList;
@@ -103,9 +104,13 @@
 
             @Override
             public void onMoveClick(int position, HouseIdBean houseIdBean) {
+                if (position == 0) {
+                    HdlThreadLogic.toast(_mActivity, getString(R.string.already_the_first_one));
+                    return;
+                }
                 String frontHomeId = "";
-                if (position > 0) {
-                    frontHomeId = houseListBeanIDList.get(position - 1).getHomeId();
+                if (position > 1) {
+                    frontHomeId = houseListBeanIDList.get(position - 2).getHomeId();
                 }
                 HdlResidenceLogic.getInstance().moveResidence(houseIdBean.getHomeId(), frontHomeId, new CloudCallBeak<Boolean>() {
                     @Override
@@ -128,6 +133,7 @@
 
             @Override
             public void onDelClick(int position, HouseIdBean houseIdBean) {
+
                 DelayedConfirmationCancelDialog delayedConfirmationCancelDialog = new DelayedConfirmationCancelDialog(_mActivity);
                 delayedConfirmationCancelDialog.setTitleContent(getString(R.string.loading_title_tip));
                 String homeName = "\"" + houseIdBean.getHomeName() + "\"";
@@ -137,8 +143,20 @@
                 delayedConfirmationCancelDialog.setYesOnclickListener(new DelayedConfirmationCancelDialog.onYesOnclickListener() {
                     @Override
                     public void Confirm() {
-                        delayedConfirmationCancelDialog.dismiss();
-                        delete(houseIdBean.getHomeId());
+                        showLoading(getString(R.string.deleting_please_wait));
+                        HdlDeviceLogic.getInstance().getCurrentHomeLocalAndCloudGatewayList(houseIdBean.getHomeId(), new CloudCallBeak<List<GatewayBean>>() {
+                            @Override
+                            public void onSuccess(List<GatewayBean> list) {
+                                deleteResidence(houseIdBean.getHomeId(), delayedConfirmationCancelDialog);
+                                initializeInverter(list);
+                            }
+
+                            @Override
+                            public void onFailure(HDLException e) {
+                                deleteResidence(houseIdBean.getHomeId(), delayedConfirmationCancelDialog);
+                            }
+                        });
+
 //                        //鍒犻櫎浣忓畢
 //                        HdlResidenceLogic.getInstance().delResidence(houseIdBean.getHomeId(), new CloudCallBeak<Boolean>() {
 //                            @Override
@@ -242,7 +260,6 @@
 
             }
         } else if (HDLUniMP.UNI_EVENT_REPLY_HOME_CLOSE_HOME_DETAILS_PAGE.equals(eventBus.getType())) {
-
             //uin鍏抽棴浣忓畢璇︽儏鐣岄潰閫氱煡
             if (MqttRecvClient.getInstance() != null) {
                 MqttRecvClient.getInstance().removeAllTopic();
@@ -378,38 +395,28 @@
 
     /**
      * 鍒犻櫎鐢电珯,閫嗗彉鍣�
-     * (鍏堣幏鍙栦簯绔笂閫嗗彉鍣ㄥ垪琛�,寮�濮嬪垹闄ょ數绔欙紝鍚屾椂锛屽悜閫嗗彉鍣ㄥ彂閫佸垵濮嬪寲閫嗗彉鍣ㄦ寚浠�)
+     * (寮�濮嬪垹闄ょ數绔欙紝鍚屾椂锛屽悜閫嗗彉鍣ㄥ彂閫佸垵濮嬪寲閫嗗彉鍣ㄦ寚浠�,鏃犻』澶勭悊缁撴灉)
      *
-     * @param homeId 鐢电珯id
+     * @param list 璁惧鍒楄〃
      */
-    private void delete(String homeId) {
-        HdlDeviceLogic.getInstance().getCloudInverterDeviceList(homeId, new CloudCallBeak<List<CloudInverterDeviceBean>>() {
-            @Override
-            public void onSuccess(List<CloudInverterDeviceBean> list) {
-                deleteResidence(homeId);
-                if (list != null) {
-                    for (int i = 0; i < list.size(); i++) {
-                        CloudInverterDeviceBean cloudInverterDeviceBean = list.get(i);
-                        HdlDeviceLogic.getInstance().initializeGateway(cloudInverterDeviceBean.getOsn(), new LinkCallBack<Boolean>() {
-                            @Override
-                            public void onSuccess(Boolean obj) {
+    private void initializeInverter(List<GatewayBean> list) {
+        if (list == null || list.size() == 0) {
+            return;
+        }
+        for (int i = 0; i < list.size(); i++) {
+            GatewayBean gatewayBean = list.get(i);
+            HdlDeviceLogic.getInstance().initializeGateway(gatewayBean.getDevice_mac(), new LinkCallBack<Boolean>() {
+                @Override
+                public void onSuccess(Boolean obj) {
 //                                HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄦ垚鍔�-->mac:" + cloudInverterDeviceBean.getOsn(),true);
-                            }
-
-                            @Override
-                            public void onError(HDLLinkException e) {
-//                                HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄥけ璐�-->mac:" + cloudInverterDeviceBean.getOsn(),true);
-                            }
-                        });
-                    }
                 }
-            }
 
-            @Override
-            public void onFailure(HDLException e) {
-                deleteResidence(homeId);
-            }
-        });
+                @Override
+                public void onError(HDLLinkException e) {
+//                                HdlLogLogic.print("鍒濆鍖栭�嗗彉鍣ㄥけ璐�-->mac:" + cloudInverterDeviceBean.getOsn(),true);
+                }
+            });
+        }
     }
 
     /**
@@ -417,11 +424,14 @@
      *
      * @param homeId 鐢电珯id
      */
-    private void deleteResidence(String homeId) {
+    private void deleteResidence(String homeId, DelayedConfirmationCancelDialog delayedConfirmationCancelDialog) {
+
         //鍒犻櫎浣忓畢
         HdlResidenceLogic.getInstance().delResidence(homeId, new CloudCallBeak<Boolean>() {
             @Override
             public void onSuccess(Boolean obj) {
+                hideLoading();
+                delayedConfirmationCancelDialog.dismiss();
                 HdlResidenceLogic.getInstance().delHouseId(homeId);
                 initData();//鍒濆鍖栫紦瀛樻暟鎹�
                 houseInfoAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃
@@ -430,6 +440,8 @@
 
             @Override
             public void onFailure(HDLException e) {
+                hideLoading();
+                delayedConfirmationCancelDialog.dismiss();
                 HdlThreadLogic.toast(_mActivity, e);
             }
         });
diff --git a/app/src/main/res/drawable/selected.png b/app/src/main/res/drawable/selected.png
index 5819252..6fb74a3 100644
--- a/app/src/main/res/drawable/selected.png
+++ b/app/src/main/res/drawable/selected.png
Binary files differ
diff --git a/app/src/main/res/values-en/strings.xml b/app/src/main/res/values-en/strings.xml
index 7abc314..21f1100 100644
--- a/app/src/main/res/values-en/strings.xml
+++ b/app/src/main/res/values-en/strings.xml
@@ -241,5 +241,7 @@
     <string name="alarm_record">Alarm record</string>
     <string name="power_station_editing">Power station editing</string>
     <string name="switch_power_station">Do you want to switch the %s power station?</string>
+    <string name="deleting_please_wait">Deleting, please wait鈥�</string>
+    <string name="already_the_first_one">It\'s already the first one</string>
 
 </resources>
\ No newline at end of file
diff --git a/app/src/main/res/values-zh/strings.xml b/app/src/main/res/values-zh/strings.xml
index f61a620..adeb842 100644
--- a/app/src/main/res/values-zh/strings.xml
+++ b/app/src/main/res/values-zh/strings.xml
@@ -241,6 +241,8 @@
     <string name="alarm_record">鎶ヨ璁板綍</string>
     <string name="power_station_editing">鐢电珯缂栬緫</string>
     <string name="switch_power_station">鏄惁瑕佸垏鎹�%s鐢电珯?</string>
+    <string name="deleting_please_wait">鍒犻櫎涓�,璇风◢绛夆��</string>
+    <string name="already_the_first_one">宸茬粡鏄涓�涓簡.</string>
 
 
 </resources>
\ No newline at end of file
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 99f8730..b1f4726 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -240,6 +240,8 @@
     <string name="alarm_record">鎶ヨ璁板綍</string>
     <string name="power_station_editing">鐢电珯缂栬緫</string>
     <string name="switch_power_station">鏄惁瑕佸垏鎹�%s鐢电珯?</string>
+    <string name="deleting_please_wait">鍒犻櫎涓�,璇风◢绛夆��</string>
+    <string name="already_the_first_one">宸茬粡鏄涓�涓簡.</string>
 
 
 </resources>
\ No newline at end of file

--
Gitblit v1.8.0