From 20119c1e9849ab28add56b977ffbca87e13e1072 Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期五, 14 二月 2025 10:47:09 +0800
Subject: [PATCH] 2025年02月14日10:46:45

---
 app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java |  143 ++++++++++++++++++++++-------------------------
 1 files changed, 67 insertions(+), 76 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 cff9650..b48aa9d 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
@@ -1,6 +1,9 @@
 package com.hdl.photovoltaic.ui.newC;
 
 
+import android.Manifest;
+import android.content.DialogInterface;
+import android.content.Intent;
 import android.os.Bundle;
 import android.view.View;
 
@@ -11,6 +14,7 @@
 import com.hdl.linkpm.sdk.core.exception.HDLException;
 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;
@@ -21,10 +25,13 @@
 import com.hdl.photovoltaic.other.HdlThreadLogic;
 import com.hdl.photovoltaic.other.HdlUniLogic;
 import com.hdl.photovoltaic.ui.bean.HouseIdBean;
-import com.hdl.photovoltaic.ui.device.FastScanActivity;
+import com.hdl.photovoltaic.ui.device.ScanActivity;
 import com.hdl.photovoltaic.ui.newC.adapter.HouseListAdapter;
 import com.hdl.photovoltaic.uni.HDLUniMP;
+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;
@@ -37,12 +44,11 @@
  * C绔數绔欏垪琛ㄧ紪杈�
  */
 public class PowerStationsListEdit extends CustomBaseActivity {
-    private ActivityPowerStationsListBinding viewBinding;
+    private ActivityPowerStationsListBinding viewBinding;//鏄惁鍦ㄧ紪杈戠姸鎬�
 
     private HouseListAdapter houseListAdapter;
     private List<HouseIdBean> houseListBeanIDList;
 
-    private boolean is_edit = false;
 
     @Override
     public Object getContentView() {
@@ -53,8 +59,8 @@
 
     @Override
     public void onBindView(Bundle savedInstanceState) {
-        setNotificationBarBackgroundColor(CustomColor.white);
-        setStatusBarTextColor();
+        setStatusBarTranslucent();
+        getWindow().setNavigationBarColor(getColor(R.color.text_FF000000));
         //鍒濆鍖栨暟鎹�
         initData();
         //鍒濆鍖�
@@ -66,37 +72,24 @@
     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.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.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.GONE);
-                initData();//鍒濆鍖栫紦瀛樻暟鎹�
-                setAllItemEdit(true);
-                houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃
+                Intent intent = new Intent();
+                intent.setClass(_mActivity, PowerStationsMoveActivity.class);
+                startActivity(intent);
             }
         });
 
@@ -110,37 +103,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) {
@@ -157,15 +119,27 @@
                     houseSelectionDialog(houseBean);
                 }
             });
-
         }
 
         viewBinding.addPowerStationTv.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-//                String path = HDLUniMP.UNI_EVENT_OPEN_DEVICESCAN + "?scanType=addPowerStation";
-//                HdlUniLogic.getInstance().openUniMP(path, null);
-                startActivity(FastScanActivity.class);
+
+                // 鏈巿鏉� 濡傛灉搴旂敤绋嬪簭娌℃湁鎵�闇�鐨勬潈闄愶紝鍒欐樉绀鸿В閲婅鏄�
+                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) {
+                        PermissionExplanationDialog.getInstance().dismiss();
+                        if (value == PermissionUtils.STATUS_REFUSE_PERMANENT | value == PermissionUtils.STATUS_REFUSE) {
+//                            HdlThreadLogic.toast(_mActivity, R.string.permission_open);
+                            return;
+                        }
+
+
+                        startActivity(ScanActivity.class);
+                    }
+                }, true);
 
             }
         });
@@ -173,12 +147,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);
@@ -209,7 +181,7 @@
                             HdlResidenceLogic.getInstance().setHouseIdList(list);
                             if (houseListAdapter != null) {
                                 initData();
-                                setAllItemEdit(is_edit);
+                                setSelectState();
                                 //鏇存柊UI
                                 houseListAdapter.setList(houseListBeanIDList);
                             }
@@ -238,16 +210,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);
             }
         }
     }
@@ -270,10 +238,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());
@@ -308,6 +277,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();
+            }
+        });
     }
 
 
@@ -331,11 +315,18 @@
 
                     @Override
                     public void onFailure(HDLException e) {
-
+                        HdlThreadLogic.toast(_mActivity, e);
                     }
                 });
 
             }
+        } else if (ConstantManage.REFRESH_HOME_LIST.equals(eventBus.getTopic())) {
+            if (houseListAdapter != null) {
+                initData();
+                setSelectState();
+                //鏇存柊UI
+                houseListAdapter.setList(houseListBeanIDList);
+            }
         }
     }
 

--
Gitblit v1.8.0