From b9cc7390e8e8ce64c41c26fb369c98ce669d660c Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期三, 07 五月 2025 15:02:30 +0800
Subject: [PATCH] Merge branch '1.2.0'

---
 app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java |  187 ++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 161 insertions(+), 26 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 ddf7acf..af6c830 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
@@ -5,6 +5,11 @@
 import android.content.DialogInterface;
 import android.content.Intent;
 import android.os.Bundle;
+import android.os.Handler;
+import android.os.Looper;
+import android.os.SystemClock;
+import android.text.TextUtils;
+import android.util.Log;
 import android.view.View;
 
 import androidx.recyclerview.widget.LinearLayoutManager;
@@ -12,6 +17,7 @@
 
 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;
@@ -21,6 +27,7 @@
 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;
@@ -31,18 +38,24 @@
 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.photovoltaic.widget.refreshlayout.BGARefreshLayout;
+import com.hdl.photovoltaic.widget.refreshlayout.HDLRefreshViewHolder;
 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;
 
 /**
  * C绔數绔欏垪琛ㄧ紪杈�
  */
 public class PowerStationsListEdit extends CustomBaseActivity {
+    private Handler handler;
+    private Runnable delayedRunnable;
     private ActivityPowerStationsListBinding viewBinding;//鏄惁鍦ㄧ紪杈戠姸鎬�
 
     private HouseListAdapter houseListAdapter;
@@ -59,13 +72,15 @@
     @Override
     public void onBindView(Bundle savedInstanceState) {
         setStatusBarTranslucent();
-        getWindow().setNavigationBarColor(getColor(R.color.text_FF333738));
+        getWindow().setNavigationBarColor(getColor(R.color.text_FF000000));
         //鍒濆鍖栨暟鎹�
         initData();
         //鍒濆鍖�
         initView();
         //鍒濆鍖栫晫闈㈢洃鍚櫒
         initEvent();
+        //鍚庡彴璇诲彇浣忓畢鍒楄〃
+//        downReadData(false);
     }
 
     private void initData() {
@@ -92,15 +107,6 @@
             }
         });
 
-        //璁剧疆涓嬫媺绠ご棰滆壊
-        viewBinding.fragmentHouseSrl.setColorSchemeResources(R.color.text_FF245EC3);
-        //鍒楄〃涓嬫媺鎸夐挳
-        viewBinding.fragmentHouseSrl.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
-            @Override
-            public void onRefresh() {
-                downReadData(true);
-            }
-        });
         if (houseListAdapter != null) {
             houseListAdapter.setOnItemClickListener(new HouseListAdapter.OnItemClickListener() {
                 @Override
@@ -123,22 +129,22 @@
         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);
 
             }
         });
@@ -156,6 +162,52 @@
         viewBinding.fragmentHouseSrlListRc.setAdapter(houseListAdapter);
         houseListAdapter.setList(this.houseListBeanIDList);
         this.nullDataUpdateUi(houseListBeanIDList);
+        pullToRefresh();
+    }
+
+    /**
+     * 涓嬫媺鍒锋柊鐨勯�昏緫
+     */
+    protected void pullToRefresh() {
+        viewBinding.fragmentHouseSrl.setDelegate(new BGARefreshLayout.BGARefreshLayoutDelegate() {
+            @Override
+            public void onBGARefreshLayoutBeginRefreshing(BGARefreshLayout refreshLayout) {
+                handler = new Handler(Looper.getMainLooper());
+
+                delayedRunnable = new Runnable() {
+                    @Override
+                    public void run() {
+                        viewBinding.fragmentHouseSrl.endRefreshing();
+                        downReadData(false);
+                    }
+                };
+                // 寤惰繜 5 绉掓墽琛�
+                handler.postDelayed(delayedRunnable, 1000);
+            }
+
+
+            @Override
+            public boolean onBGARefreshLayoutBeginLoadingMore(BGARefreshLayout refreshLayout) {
+
+                handler = new Handler(Looper.getMainLooper());
+                delayedRunnable = new Runnable() {
+                    @Override
+                    public void run() {
+                        viewBinding.fragmentHouseSrl.endLoadingMore();
+
+                    }
+                };
+                // 寤惰繜 5 绉掓墽琛�
+                handler.postDelayed(delayedRunnable, 10);
+
+                return true;
+            }
+        });
+        HDLRefreshViewHolder hdlRefreshViewHolder = new HDLRefreshViewHolder(_mActivity, true);
+        hdlRefreshViewHolder.setPullDownImageResource(R.mipmap.loading_44);
+        hdlRefreshViewHolder.setChangeToReleaseRefreshAnimResId(R.drawable.loading_refresh);
+        hdlRefreshViewHolder.setRefreshingAnimResId(R.drawable.loading_refresh_end);
+        viewBinding.fragmentHouseSrl.setRefreshViewHolder(hdlRefreshViewHolder);
     }
 
     /**
@@ -164,6 +216,9 @@
      * @param isRefreshing 琛ㄧず鏄笅鎷夊埛鏂扮殑
      */
     private void downReadData(boolean isRefreshing) {
+        if (isRefreshing) {
+            showLoading();
+        }
         //鑾峰彇浣忓畢(鐢电珯)ID鍒楄〃
         HdlResidenceLogic.getInstance().getResidenceIdList("", "", new CloudCallBeak<List<HouseIdBean>>() {
             @Override
@@ -173,18 +228,24 @@
                     public void run() {
                         if (isRefreshing) {
                             //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦�
-                            viewBinding.fragmentHouseSrl.setRefreshing(false);
+                            hideLoading();
                         }
-                        if (list != null && list.size() > 0) {
-                            //鏇存柊缂撳瓨
-                            HdlResidenceLogic.getInstance().setHouseIdList(list);
-                            if (houseListAdapter != null) {
-                                initData();
-                                setSelectState();
-                                //鏇存柊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);
                     }
@@ -199,8 +260,10 @@
                     public void run() {
                         if (isRefreshing) {
                             //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦�
-                            viewBinding.fragmentHouseSrl.setRefreshing(false);
+                            hideLoading();
                         }
+
+                        HdlThreadLogic.toast(_mActivity, e.getMsg() + "(" + e.getCode() + ")");
 
                     }
                 }, _mActivity, ShowErrorMode.YES);
@@ -329,4 +392,76 @@
         }
     }
 
+
+    /**
+     * 姣旇緝浣忓畢鍒楄〃鏁版嵁鏄惁閮戒竴鏍�
+     *
+     * @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) {
+        }
+    }
+
+    @Override
+    protected void onDestroy() {
+        if (handler != null && delayedRunnable != null) {
+            handler.removeCallbacks(delayedRunnable);
+        }
+        super.onDestroy();
+    }
 }
\ No newline at end of file

--
Gitblit v1.8.0