From cdf49871675e42a5576f725a93eec7ca15294c6f Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期二, 15 四月 2025 17:22:34 +0800
Subject: [PATCH] Merge branch '1.5.2'

---
 app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java |  225 ++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 138 insertions(+), 87 deletions(-)

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 ac55b8b..efa0636 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
@@ -2,7 +2,12 @@
 
 
 import android.Manifest;
+import android.content.DialogInterface;
+import android.content.Intent;
 import android.os.Bundle;
+import android.os.SystemClock;
+import android.text.TextUtils;
+import android.util.Log;
 import android.view.View;
 
 import androidx.recyclerview.widget.LinearLayoutManager;
@@ -10,14 +15,17 @@
 
 import com.google.gson.JsonObject;
 import com.hdl.linkpm.sdk.core.exception.HDLException;
+import com.hdl.linkpm.sdk.user.HDLLinkPMUser;
 import com.hdl.photovoltaic.R;
 import com.hdl.photovoltaic.base.CustomBaseActivity;
+import com.hdl.photovoltaic.config.ConstantManage;
 import com.hdl.photovoltaic.config.UserConfigManage;
 import com.hdl.photovoltaic.databinding.ActivityPowerStationsListBinding;
 import com.hdl.photovoltaic.enums.ShowErrorMode;
 import com.hdl.photovoltaic.internet.HttpClient;
 import com.hdl.photovoltaic.listener.CloudCallBeak;
 import com.hdl.photovoltaic.other.HdlCommonLogic;
+import com.hdl.photovoltaic.other.HdlLogLogic;
 import com.hdl.photovoltaic.other.HdlResidenceLogic;
 import com.hdl.photovoltaic.other.HdlThreadLogic;
 import com.hdl.photovoltaic.other.HdlUniLogic;
@@ -28,12 +36,14 @@
 import com.hdl.photovoltaic.utils.LocalManageUtil;
 import com.hdl.photovoltaic.utils.PermissionUtils;
 import com.hdl.photovoltaic.widget.ConfirmationCancelDialog;
+import com.hdl.photovoltaic.widget.PermissionExplanationDialog;
 import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
 
 import org.greenrobot.eventbus.Subscribe;
 import org.greenrobot.eventbus.ThreadMode;
 
 import java.util.ArrayList;
+import java.util.Collections;
 import java.util.List;
 
 /**
@@ -45,7 +55,6 @@
     private HouseListAdapter houseListAdapter;
     private List<HouseIdBean> houseListBeanIDList;
 
-    private boolean is_edit = false;//琛ㄧず鏄惁鍦ㄧ紪杈戠姸鎬�(true=鍦ㄧ紪杈戠姸鎬�)
 
     @Override
     public Object getContentView() {
@@ -56,54 +65,39 @@
 
     @Override
     public void onBindView(Bundle savedInstanceState) {
-        setNotificationBarBackgroundColor(CustomColor.white);
-        setStatusBarTextColor();
+        setStatusBarTranslucent();
+        getWindow().setNavigationBarColor(getColor(R.color.text_FF000000));
         //鍒濆鍖栨暟鎹�
         initData();
         //鍒濆鍖�
         initView();
         //鍒濆鍖栫晫闈㈢洃鍚櫒
         initEvent();
+        //鍚庡彴璇诲彇浣忓畢鍒楄〃
+//        downReadData(false);
     }
 
     private void initData() {
         this.houseListBeanIDList = new ArrayList<>();
         this.houseListBeanIDList.addAll(HdlResidenceLogic.getInstance().getHouseIdList());
-        setAllItemEdit(false);
+        setSelectState();
     }
 
     private void initEvent() {
         //杩斿洖鎸夐挳
-        viewBinding.toolbarTopFragmentHouseListRl.topBackLl.setOnClickListener(new View.OnClickListener() {
+        viewBinding.toolbarTopRl.topBackLl.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-                if (!is_edit) {
-                    finish();
-                    return;
-                }
-
-                is_edit = false;
-                viewBinding.addPowerStationRl.setVisibility(View.VISIBLE);//娣诲姞鐢电珯缁勪欢
-                viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.VISIBLE);
-                initData();//鍒濆鍖栫紦瀛樻暟鎹�
-                setAllItemEdit(false);
-                houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃
+                finish();
             }
         });
         //缂栬緫鎸夐挳
-        viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setOnClickListener(new View.OnClickListener() {
+        viewBinding.toolbarTopRl.topMoreBtn.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-                if (is_edit) {
-                    return;
-                }
-
-                is_edit = true;
-                viewBinding.addPowerStationRl.setVisibility(View.GONE);//娣诲姞鐢电珯缁勪欢
-                viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.GONE);
-                initData();//鍒濆鍖栫紦瀛樻暟鎹�
-                setAllItemEdit(true);
-                houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃
+                Intent intent = new Intent();
+                intent.setClass(_mActivity, PowerStationsMoveActivity.class);
+                startActivity(intent);
             }
         });
 
@@ -117,37 +111,6 @@
             }
         });
         if (houseListAdapter != null) {
-            //鐢电珯绉诲姩浣嶇疆鎸夐挳
-            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 > 1) {
-                        frontHomeId = houseListBeanIDList.get(position - 2).getHomeId();
-                    }
-                    HdlResidenceLogic.getInstance().moveResidence(houseIdBean.getHomeId(), frontHomeId, new CloudCallBeak<Boolean>() {
-                        @Override
-                        public void onSuccess(Boolean obj) {
-                            //绉诲姩鐢电珯浣嶇疆
-                            HdlResidenceLogic.getInstance().moveHouseId(houseIdBean.getHomeId());
-                            initData();//鍒濆鍖栫紦瀛樻暟鎹�
-                            setAllItemEdit(is_edit);
-                            houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃
-                            nullDataUpdateUi(houseListBeanIDList);//妫�娴嬫暟鎹槸鍚︿负绌�
-                        }
-
-                        @Override
-                        public void onFailure(HDLException e) {
-                            HdlThreadLogic.toast(_mActivity, e);
-                        }
-                    });
-
-                }
-            });
             houseListAdapter.setOnItemClickListener(new HouseListAdapter.OnItemClickListener() {
                 @Override
                 public void onItemClick(int position, HouseIdBean houseBean) {
@@ -164,28 +127,27 @@
                     houseSelectionDialog(houseBean);
                 }
             });
-
         }
 
         viewBinding.addPowerStationTv.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
+
+                // 鏈巿鏉� 濡傛灉搴旂敤绋嬪簭娌℃湁鎵�闇�鐨勬潈闄愶紝鍒欐樉绀鸿В閲婅鏄�
+                PermissionExplanationDialog.getInstance().showPortConflictPdDialog(_mActivity, getString(R.string.camera_storage_instructions), getString(R.string.camera_storage_purpose));
                 PermissionUtils.requestPermissionsResultCallback(_mActivity, Manifest.permission.CAMERA, new PermissionUtils.PermissionState() {
                     @Override
                     public void Success(int value) {
-                        if (value == PermissionUtils.STATUS_REFUSE_PERMANENT) {
+                        PermissionExplanationDialog.getInstance().dismiss();
+                        if (value == PermissionUtils.STATUS_REFUSE_PERMANENT | value == PermissionUtils.STATUS_REFUSE) {
 //                            HdlThreadLogic.toast(_mActivity, R.string.permission_open);
                             return;
                         }
 
 
-//                        startActivity(CaptureActivity.class);
                         startActivity(ScanActivity.class);
                     }
                 }, true);
-//                String path = HDLUniMP.UNI_EVENT_OPEN_DEVICESCAN + "?scanType=addPowerStation";
-//                HdlUniLogic.getInstance().openUniMP(path, null);
-//                startActivity(FastScanActivity.class);
 
             }
         });
@@ -193,12 +155,10 @@
     }
 
     private void initView() {
-        viewBinding.toolbarTopFragmentHouseListRl.getRoot().setBackgroundColor(getColor(R.color.text_FFFFFFFF));
-        viewBinding.toolbarTopFragmentHouseListRl.topBackLl.setVisibility(View.VISIBLE);
-        viewBinding.toolbarTopFragmentHouseListRl.topLeftIv.setImageResource(R.drawable.back_c);
-        viewBinding.toolbarTopFragmentHouseListRl.topTitleTv.setText(R.string.power_station_selection);
-        viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.VISIBLE);
-        viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setImageResource(R.drawable.editor_house);
+        viewBinding.toolbarTopRl.topBackLl.setVisibility(View.VISIBLE);
+        viewBinding.toolbarTopRl.topTitleTv.setText(R.string.power_station_selection);
+        viewBinding.toolbarTopRl.topMoreBtn.setVisibility(View.VISIBLE);
+        viewBinding.toolbarTopRl.topMoreIv.setImageResource(R.drawable.editor_house);
         LinearLayoutManager linearLayout = new LinearLayoutManager(_mActivity);
         houseListAdapter = new HouseListAdapter(_mActivity);
         viewBinding.fragmentHouseSrlListRc.setLayoutManager(linearLayout);
@@ -224,16 +184,22 @@
                             //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦�
                             viewBinding.fragmentHouseSrl.setRefreshing(false);
                         }
-                        if (list != null && list.size() > 0) {
-                            //鏇存柊缂撳瓨
-                            HdlResidenceLogic.getInstance().setHouseIdList(list);
-                            if (houseListAdapter != null) {
-                                initData();
-                                setAllItemEdit(is_edit);
-                                //鏇存柊UI
-                                houseListAdapter.setList(houseListBeanIDList);
-                            }
+                        if (list != null && !list.isEmpty()) {
+                            if (!comparableList(houseListBeanIDList, list)) {
+                                //鏇存柊缂撳瓨
+                                HdlResidenceLogic.getInstance().setHouseIdList(list, true);
+                                if (houseListAdapter != null) {
+                                    //閲嶆柊鑾峰彇鍒楄〃鏁版嵁
+                                    initData();
+                                    refreshDetails();
+                                    //鏇存柊鐢电珯閫変腑鐘舵��
+                                    setSelectState();
+                                    //鏇存柊鍒楄〃鏁版嵁
+                                    houseListAdapter.setList(houseListBeanIDList);
+                                }
 
+
+                            }
                         }
                         nullDataUpdateUi(list);
                     }
@@ -251,6 +217,8 @@
                             viewBinding.fragmentHouseSrl.setRefreshing(false);
                         }
 
+                        HdlThreadLogic.toast(_mActivity, e.getMsg() + "(" + e.getCode() + ")");
+
                     }
                 }, _mActivity, ShowErrorMode.YES);
             }
@@ -258,16 +226,12 @@
     }
 
     /**
-     * 璁剧疆鍏ㄩ儴缂撳瓨鏁版嵁缂栬緫鐘舵��
-     *
-     * @param edit true琛ㄧず鍦ㄧ紪杈戠姸鎬�
+     * 璁剧疆褰撳墠鐢电珯閫変腑鐘舵��
      */
-    private void setAllItemEdit(boolean edit) {
+    private void setSelectState() {
         for (int i = 0; i < houseListBeanIDList.size(); i++) {
-            houseListBeanIDList.get(i).setMove(edit);
-            houseListBeanIDList.get(i).setDelIcon(false);
             if (UserConfigManage.getInstance().getHomeId().equals(houseListBeanIDList.get(i).getHomeId())) {
-                this.houseListBeanIDList.get(i).setState_select(!edit);
+                this.houseListBeanIDList.get(i).setState_select(true);
             }
         }
     }
@@ -290,10 +254,11 @@
         dialog.setTitle(getString(R.string.loading_title_tip));
         dialog.setContent(getString(R.string.switch_power_station).replace("%s", "\"" + houseIdBean.getHomeName() + "\""));
         dialog.show();
+        dialog.isHideTitle(true);
         dialog.setYesOnclickListener(new ConfirmationCancelDialog.onYesOnclickListener() {
             @Override
             public void Confirm() {
-                HdlResidenceLogic.getInstance().switchHouse(houseIdBean);
+                HdlResidenceLogic.getInstance().switchHouse(houseIdBean, true);
                 dialog.dismiss();
                 JsonObject jsonObject = new JsonObject();
                 jsonObject.addProperty("homeId", houseIdBean.getHomeId());
@@ -328,6 +293,21 @@
                 dialog.dismiss();
             }
         });
+
+        dialog.setOnDismissListener(new DialogInterface.OnDismissListener() {
+            @Override
+            public void onDismiss(DialogInterface dialog) {
+                //鍙栨秷涔嬪悗杩樺師涔嬪墠鐘舵��
+                for (int i = 0; i < houseListBeanIDList.size(); i++) {
+                    HouseIdBean houseIdBean = houseListBeanIDList.get(i);
+                    houseIdBean.setState_select(false);
+                    if (UserConfigManage.getInstance().getHomeId().equals(houseIdBean.getHomeId())) {
+                        houseIdBean.setState_select(true);
+                    }
+                }
+                houseListAdapter.notifyDataSetChanged();
+            }
+        });
     }
 
 
@@ -356,7 +336,78 @@
                 });
 
             }
+        } else if (ConstantManage.REFRESH_HOME_LIST.equals(eventBus.getTopic())) {
+            if (houseListAdapter != null) {
+                initData();
+                setSelectState();
+                //鏇存柊UI
+                houseListAdapter.setList(houseListBeanIDList);
+            }
         }
     }
 
+
+    /**
+     * 姣旇緝浣忓畢鍒楄〃鏁版嵁鏄惁閮戒竴鏍�
+     *
+     * @param oldList 鏃у垪琛�
+     * @param newList 鏂板垪琛�
+     * @return 鐩稿悓杩斿洖true锛屽惁鍒欒繑鍥瀎alse
+     */
+    boolean comparableList(List<HouseIdBean> oldList, List<HouseIdBean> newList) {
+        if (oldList == null || newList == null) return false;
+        if (oldList.size() != newList.size()) return false;
+        List<String> oidStrList = new ArrayList<>();
+        for (int i = 0; i < oldList.size(); i++) {
+            oidStrList.add(oldList.get(i).getHomeId());
+        }
+
+        List<String> newStrList = new ArrayList<>();
+        for (int i = 0; i < newList.size(); i++) {
+            newStrList.add(newList.get(i).getHomeId());
+        }
+        Collections.sort(oidStrList);
+        Collections.sort(newStrList);
+        return oidStrList.equals(newStrList);
+    }
+
+    /**
+     * 閫氱煡uni鏇存柊鏁版嵁
+     * 锛堝湪骞冲彴涓婂垹闄绔綋鍓嶄綇瀹呭悗,鑾峰彇鍒楄〃瀹炴敹瑕侀�氱煡uni閭h竟鏇存柊鐣岄潰鍗$墖锛�
+     */
+    private void refreshDetails() {
+        try {
+            List<HouseIdBean> localHouseIdList = HdlResidenceLogic.getInstance().getHouseIdList();
+            if (localHouseIdList.isEmpty()) {
+                JsonObject jsonObject = new JsonObject();
+                jsonObject.addProperty("homeId", "");
+                HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean();
+                uniCallBackBaseBean.setType(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_REFRESH_DETAILS);
+                uniCallBackBaseBean.setData(jsonObject);
+                HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean);
+            } else {
+                int select_home = -1;
+                for (int i = 0; i < localHouseIdList.size(); i++) {
+                    if (localHouseIdList.get(i).getHomeId().equals(UserConfigManage.getInstance().getHomeId())) {
+                        select_home = i;
+                        break;
+                    }
+                }
+                if (select_home == -1) {
+                    //鎵句笉鍒伴粯璁ょ涓�涓�
+                    HouseIdBean houseIdBean = localHouseIdList.get(0);
+                    HdlResidenceLogic.getInstance().switchHouse(houseIdBean, true);
+                    JsonObject jsonObject = new JsonObject();
+                    jsonObject.addProperty("homeId", houseIdBean.getHomeId());
+                    jsonObject.addProperty("homeName", houseIdBean.getHomeName());
+                    jsonObject.addProperty("powerStationStatus", houseIdBean.getPowerStationStatus() + "");
+                    HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean();
+                    uniCallBackBaseBean.setType(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_REFRESH_DETAILS);
+                    uniCallBackBaseBean.setData(jsonObject);
+                    HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean);
+                }
+            }
+        } catch (Exception e) {
+        }
+    }
 }
\ No newline at end of file

--
Gitblit v1.8.0