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